changeset 1533:37df1530519d

Fix failure to apply new frame when pasting events
author Chris Cannam
date Wed, 09 Oct 2019 11:51:19 +0100 (2019-10-09)
parents 14a162f6870f
children bfd8b22fd67c
files layer/BoxLayer.cpp layer/FlexiNoteLayer.cpp layer/ImageLayer.cpp layer/NoteLayer.cpp layer/RegionLayer.cpp layer/TextLayer.cpp layer/TimeInstantLayer.cpp layer/TimeValueLayer.cpp
diffstat 8 files changed, 30 insertions(+), 16 deletions(-) [+]
line wrap: on
line diff
--- a/layer/BoxLayer.cpp	Wed Oct 09 11:33:33 2019 +0100
+++ b/layer/BoxLayer.cpp	Wed Oct 09 11:51:19 2019 +0100
@@ -1106,7 +1106,8 @@
 }
 
 bool
-BoxLayer::paste(LayerGeometryProvider *v, const Clipboard &from, sv_frame_t /* frameOffset */, bool /* interactive */)
+BoxLayer::paste(LayerGeometryProvider *v, const Clipboard &from,
+                sv_frame_t /* frameOffset */, bool /* interactive */)
 {
     auto model = ModelById::getAs<BoxModel>(m_model);
     if (!model) return false;
@@ -1154,7 +1155,8 @@
             }
         }
 
-        Event p = *i;
+        Event p = i->withFrame(frame);
+        
         Event newPoint = p;
         if (!p.hasValue()) {
             newPoint = newPoint.withValue((model->getValueMinimum() +
--- a/layer/FlexiNoteLayer.cpp	Wed Oct 09 11:33:33 2019 +0100
+++ b/layer/FlexiNoteLayer.cpp	Wed Oct 09 11:51:19 2019 +0100
@@ -1740,7 +1740,8 @@
 }
 
 bool
-FlexiNoteLayer::paste(LayerGeometryProvider *v, const Clipboard &from, sv_frame_t /*frameOffset */, bool /* interactive */)
+FlexiNoteLayer::paste(LayerGeometryProvider *v, const Clipboard &from,
+                      sv_frame_t /*frameOffset */, bool /* interactive */)
 {
     auto model = ModelById::getAs<NoteModel>(m_model);
     if (!model) return false;
@@ -1787,7 +1788,8 @@
             }
         }
 
-        Event p = *i;
+        Event p = i->withFrame(frame);
+
         Event newPoint = p;
         if (!p.hasValue()) {
             newPoint = newPoint.withValue((model->getValueMinimum() +
--- a/layer/ImageLayer.cpp	Wed Oct 09 11:33:33 2019 +0100
+++ b/layer/ImageLayer.cpp	Wed Oct 09 11:51:19 2019 +0100
@@ -795,7 +795,8 @@
 }
 
 bool
-ImageLayer::paste(LayerGeometryProvider *v, const Clipboard &from, sv_frame_t /* frameOffset */, bool /* interactive */)
+ImageLayer::paste(LayerGeometryProvider *v, const Clipboard &from,
+                  sv_frame_t /* frameOffset */, bool /* interactive */)
 {
     auto model = ModelById::getAs<ImageModel>(m_model);
     if (!model) return false;
@@ -842,7 +843,8 @@
             }
         }
 
-        Event p = *i;
+        Event p = i->withFrame(frame);
+
         Event newPoint = p;
 
         //!!! inadequate
--- a/layer/NoteLayer.cpp	Wed Oct 09 11:33:33 2019 +0100
+++ b/layer/NoteLayer.cpp	Wed Oct 09 11:51:19 2019 +0100
@@ -1237,7 +1237,8 @@
             }
         }
 
-        Event p = *i;
+        Event p = i->withFrame(frame);
+        
         Event newPoint = p;
         if (!p.hasValue()) {
             newPoint = newPoint.withValue((model->getValueMinimum() +
--- a/layer/RegionLayer.cpp	Wed Oct 09 11:33:33 2019 +0100
+++ b/layer/RegionLayer.cpp	Wed Oct 09 11:51:19 2019 +0100
@@ -1456,7 +1456,8 @@
 }
 
 bool
-RegionLayer::paste(LayerGeometryProvider *v, const Clipboard &from, sv_frame_t /* frameOffset */, bool /* interactive */)
+RegionLayer::paste(LayerGeometryProvider *v, const Clipboard &from,
+                   sv_frame_t /* frameOffset */, bool /* interactive */)
 {
     auto model = ModelById::getAs<RegionModel>(m_model);
     if (!model) return false;
@@ -1504,7 +1505,8 @@
             }
         }
 
-        Event p = *i;
+        Event p = i->withFrame(frame);
+
         Event newPoint = p;
         if (!p.hasValue()) {
             newPoint = newPoint.withValue((model->getValueMinimum() +
--- a/layer/TextLayer.cpp	Wed Oct 09 11:33:33 2019 +0100
+++ b/layer/TextLayer.cpp	Wed Oct 09 11:51:19 2019 +0100
@@ -697,7 +697,8 @@
 }
 
 bool
-TextLayer::paste(LayerGeometryProvider *v, const Clipboard &from, sv_frame_t /* frameOffset */, bool /* interactive */)
+TextLayer::paste(LayerGeometryProvider *v, const Clipboard &from,
+                 sv_frame_t /* frameOffset */, bool /* interactive */)
 {
     auto model = ModelById::getAs<TextModel>(m_model);
     if (!model) return false;
@@ -755,7 +756,8 @@
             }
         }
 
-        Event p = *i;
+        Event p = i->withFrame(frame);
+
         Event newPoint = p;
         if (p.hasValue()) {
             newPoint = newPoint.withValue(float((i->getValue() - valueMin) /
--- a/layer/TimeInstantLayer.cpp	Wed Oct 09 11:33:33 2019 +0100
+++ b/layer/TimeInstantLayer.cpp	Wed Oct 09 11:51:19 2019 +0100
@@ -763,7 +763,8 @@
 }
 
 bool
-TimeInstantLayer::paste(LayerGeometryProvider *v, const Clipboard &from, sv_frame_t frameOffset, bool)
+TimeInstantLayer::paste(LayerGeometryProvider *v, const Clipboard &from,
+                        sv_frame_t frameOffset, bool)
 {
     auto model = ModelById::getAs<SparseOneDimensionalModel>(m_model);
     if (!model) return false;
@@ -817,7 +818,8 @@
             else frame = 0;
         }
 
-        Event newPoint = *i;
+        Event newPoint = i->withFrame(frame);
+        
         if (!i->hasLabel() && i->hasValue()) {
             newPoint = newPoint.withLabel(QString("%1").arg(i->getValue()));
         }
--- a/layer/TimeValueLayer.cpp	Wed Oct 09 11:33:33 2019 +0100
+++ b/layer/TimeValueLayer.cpp	Wed Oct 09 11:51:19 2019 +0100
@@ -1686,8 +1686,8 @@
 }
 
 bool
-TimeValueLayer::paste(LayerGeometryProvider *v, const Clipboard &from, sv_frame_t /* frameOffset */,
-                      bool interactive)
+TimeValueLayer::paste(LayerGeometryProvider *v, const Clipboard &from,
+                      sv_frame_t /* frameOffset */, bool interactive)
 {
     auto model = ModelById::getAs<SparseTimeValueModel>(m_model);
     if (!model) return false;
@@ -1842,7 +1842,8 @@
             }
         }
 
-        Event newPoint = *i;
+        Event newPoint = i->withFrame(frame);
+        
         if (!i->hasLabel() && i->hasValue()) {
             newPoint = newPoint.withLabel(QString("%1").arg(i->getValue()));
         }