diff options
author | nick_m <mainsbridge@gmail.com> | 2016-06-06 14:26:43 +1000 |
---|---|---|
committer | nick_m <mainsbridge@gmail.com> | 2016-06-06 14:26:43 +1000 |
commit | f0f2e3bb713287a3e170ff6e9c8feb5b1b2188ca (patch) | |
tree | 7c77ceabe2c586c03ddca97d01fa94416b0dd6a6 /libs/ardour/region.cc | |
parent | 01812f53c34bf0298430da42bc636ee29dcdfd6a (diff) |
Consolidate notifications when MidiRegion changes length due to position change.
Diffstat (limited to 'libs/ardour/region.cc')
-rw-r--r-- | libs/ardour/region.cc | 14 |
1 files changed, 13 insertions, 1 deletions
diff --git a/libs/ardour/region.cc b/libs/ardour/region.cc index 1b9793313d..105aa3af59 100644 --- a/libs/ardour/region.cc +++ b/libs/ardour/region.cc @@ -578,7 +578,19 @@ Region::set_position (framepos_t pos) /* do this even if the position is the same. this helps out a GUI that has moved its representation already. */ - send_change (Properties::position); + PropertyChange p_and_l; + + p_and_l.add (Properties::position); + /* Currently length change due to position change is only implemented + for MidiRegion (Region has no length in beats). + Notify a length change regardless (its more efficient for MidiRegions), + and when Region has a _length_beats we will need it here anyway). + */ + if (position_lock_style() == MusicTime) { + p_and_l.add (Properties::length); + } + + send_change (p_and_l); } |