+ SCM elt = get_property ("element");
+ Pitch *old_pit = unsmob_pitch (get_property ("pitch"));
+ if (old_pit)
+ {
+ Pitch new_pit = *old_pit;
+ new_pit = new_pit.to_relative_octave (last);
+
+ SCM check = get_property ("absolute-octave");
+ if (scm_is_number (check)
+ && new_pit.get_octave () != scm_to_int (check))
+ {
+ Pitch expected_pit (scm_to_int (check),
+ new_pit.get_notename (),
+ new_pit.get_alteration ());
+ origin ()->warning (_f ("octave check failed; expected %s, found: %s",
+ expected_pit.to_string (),
+ new_pit.to_string ()));
+ new_pit = expected_pit;
+ }
+
+ set_property ("pitch", new_pit.smobbed_copy ());
+
+ last = new_pit;
+ }
+
+ if (Music *m = unsmob_music (elt))
+ last = m->to_relative_octave (last);
+
+ last = music_list_to_relative (get_property ("elements"), last, false);
+ return last;
+}
+
+Pitch
+Music::to_relative_octave (Pitch last)
+{
+ SCM callback = get_property ("to-relative-callback");
+ if (ly_is_procedure (callback))
+ {
+ Pitch *p = unsmob_pitch (scm_call_2 (callback, self_scm (), last.smobbed_copy ()));
+ return *p;
+ }
+
+ return generic_to_relative_octave (last);
+}
+
+void
+Music::compress (Moment factor)
+{
+ SCM elt = get_property ("element");
+
+ if (Music *m = unsmob_music (elt))
+ m->compress (factor);
+
+ compress_music_list (get_property ("elements"), factor);
+ Duration *d = unsmob_duration (get_property ("duration"));
+ if (d)
+ set_property ("duration", d->compressed (factor.main_part_).smobbed_copy ());
+}
+
+void
+Music::transpose (Pitch delta)
+{
+ if (to_boolean (get_property ("untransposable")))
+ return;
+
+ for (SCM s = this->get_property_alist (true); scm_is_pair (s); s = scm_cdr (s))
+ {
+ SCM entry = scm_car (s);
+ SCM val = scm_cdr (entry);
+
+ if (Pitch *p = unsmob_pitch (val))
+ {
+ Pitch transposed = p->transposed (delta);
+ scm_set_cdr_x (entry, transposed.smobbed_copy ());
+
+ if (abs (transposed.get_alteration ()) > DOUBLE_SHARP)
+ {
+ warning (_f ("transposition by %s makes alteration larger than double",
+ delta.to_string ()));
+ }
+ }
+ }
+
+ SCM elt = get_property ("element");
+
+ if (Music *m = unsmob_music (elt))
+ m->transpose (delta);
+
+ transpose_music_list (get_property ("elements"), delta);
+