From 3a6b2edd48c571da8504203a6c71bd5f1c1b26b8 Mon Sep 17 00:00:00 2001 From: Yinan Zhou Date: Wed, 11 Dec 2024 10:31:50 -0500 Subject: [PATCH 1/8] fix: call `SyncFromFacsimileDoc` before `LayOutTranscription` - Fix element jump after inserting new clef - Fix element octave for elements after F clef refs: https://github.com/DDMAL/Neon/issues/1248#issuecomment-2518453869 --- src/editortoolkit_neume.cpp | 55 +++++++++++++++++++++++++------------ 1 file changed, 37 insertions(+), 18 deletions(-) diff --git a/src/editortoolkit_neume.cpp b/src/editortoolkit_neume.cpp index 576e4c3549..ce74cf244e 100644 --- a/src/editortoolkit_neume.cpp +++ b/src/editortoolkit_neume.cpp @@ -679,9 +679,8 @@ bool EditorToolkitNeume::Drag(std::string elementId, int x, int y) SortStaves(); - m_doc->GetDrawingPage()->LayOutTranscription(true); - if (m_doc->IsTranscription() && m_doc->HasFacsimile()) m_doc->SyncFromFacsimileDoc(); + m_doc->GetDrawingPage()->LayOutTranscription(true); return true; // Can't reorder by layer since staves contain layers } @@ -740,8 +739,9 @@ bool EditorToolkitNeume::Drag(std::string elementId, int x, int y) } Layer *layer = vrv_cast(element->GetFirstAncestor(LAYER)); layer->ReorderByXPos(); // Reflect position order of elements internally (and in the resulting output file) - m_doc->GetDrawingPage()->LayOutPitchPos(); if (m_doc->IsTranscription() && m_doc->HasFacsimile()) m_doc->SyncFromFacsimileDoc(); + m_doc->GetDrawingPage()->LayOutTranscription(true); + m_editInfo.import("status", status); m_editInfo.import("message", message); return true; @@ -1075,7 +1075,7 @@ bool EditorToolkitNeume::Insert(std::string elementType, std::string staffId, in layer->ReorderByXPos(); // ensure pitched elements associated with this clef keep their x,y positions - + m_doc->ScoreDefSetCurrentDoc(true); // this is needed for staves without clef ClassIdComparison ac(CLEF); Clef *previousClef = dynamic_cast(m_doc->GetDrawingPage()->FindPreviousChild(&ac, clef)); Clef *nextClef = dynamic_cast(m_doc->GetDrawingPage()->FindNextChild(&ac, clef)); @@ -1253,9 +1253,8 @@ bool EditorToolkitNeume::Insert(std::string elementType, std::string staffId, in } layer->ReorderByXPos(); - m_doc->GetDrawingPage()->LayOutTranscription(true); - if (m_doc->IsTranscription() && m_doc->HasFacsimile()) m_doc->SyncFromFacsimileDoc(); + m_doc->GetDrawingPage()->LayOutTranscription(true); m_editInfo.import("status", status); m_editInfo.import("message", message); @@ -3522,8 +3521,8 @@ bool EditorToolkitNeume::ToggleLigature(std::vector elementIds) return false; } - m_doc->GetDrawingPage()->LayOutTranscription(true); if (m_doc->IsTranscription() && m_doc->HasFacsimile()) m_doc->SyncFromFacsimileDoc(); + m_doc->GetDrawingPage()->LayOutTranscription(true); m_editInfo.import("status", "OK"); m_editInfo.import("message", ""); @@ -4230,7 +4229,6 @@ bool EditorToolkitNeume::AdjustPitchFromPosition(Object *obj, Clef *clef) if (clef == NULL) { ClassIdComparison ac(CLEF); clef = dynamic_cast(m_doc->GetDrawingPage()->FindPreviousChild(&ac, obj)); - int clefOffset = 0; if (clef == NULL) { ClassIdComparison ac(CLEF); clef = dynamic_cast(m_doc->GetDrawingPage()->FindPreviousChild(&ac, obj)); @@ -4251,19 +4249,30 @@ bool EditorToolkitNeume::AdjustPitchFromPosition(Object *obj, Clef *clef) data_PITCHNAME pname; const int staffSize = m_doc->GetDrawingUnit(staff->m_drawingStaffSize); + int baseOctave; + switch (clef->GetShape()) { - case CLEFSHAPE_C: pname = PITCHNAME_c; break; - case CLEFSHAPE_F: pname = PITCHNAME_f; break; - case CLEFSHAPE_G: pname = PITCHNAME_g; break; + case CLEFSHAPE_C: + pname = PITCHNAME_c; + baseOctave = 4; + break; + case CLEFSHAPE_F: + pname = PITCHNAME_f; + baseOctave = 3; + break; + case CLEFSHAPE_G: + pname = PITCHNAME_g; + baseOctave = 4; + break; default: LogError("Clef %s does not have valid shape. Shape is %s", clef->GetID().c_str(), clef->GetShape()); return false; } pi->SetPname(pname); - // The default octave = 4, but the actual octave is calculated by + // The actual octave is calculated by // taking into account the displacement of the clef - int octave = 4; + int octave = baseOctave; if (clef->GetDis() && clef->GetDisPlace()) { octave += (clef->GetDisPlace() == STAFFREL_basic_above ? 1 : -1) * (clef->GetDis() / 7); } @@ -4311,11 +4320,21 @@ bool EditorToolkitNeume::AdjustPitchFromPosition(Object *obj, Clef *clef) data_PITCHNAME pname = PITCHNAME_c; const int staffSize = m_doc->GetDrawingUnit(staff->m_drawingStaffSize); + int baseOctave; switch (clef->GetShape()) { - case CLEFSHAPE_C: pname = PITCHNAME_c; break; - case CLEFSHAPE_F: pname = PITCHNAME_f; break; - case CLEFSHAPE_G: pname = PITCHNAME_g; break; + case CLEFSHAPE_C: + pname = PITCHNAME_c; + baseOctave = 4; + break; + case CLEFSHAPE_F: + pname = PITCHNAME_f; + baseOctave = 3; + break; + case CLEFSHAPE_G: + pname = PITCHNAME_g; + baseOctave = 4; + break; default: LogError("Clef %s does not have valid shape. Shape is %s", clef->GetID().c_str(), clef->GetShape()); return false; @@ -4334,9 +4353,9 @@ bool EditorToolkitNeume::AdjustPitchFromPosition(Object *obj, Clef *clef) assert(pi); pi->SetPname(pname); - // The default octave = 4, but the actual octave is calculated by + // The actual octave is calculated by // taking into account the displacement of the clef - int octave = 4; + int octave = baseOctave; if (clef->GetDis() && clef->GetDisPlace()) { octave += (clef->GetDisPlace() == STAFFREL_basic_above ? 1 : -1) * (clef->GetDis() / 7); } From 3c32804fe45fc14da89f483d8f546e2d9e57f439 Mon Sep 17 00:00:00 2001 From: Yinan Zhou Date: Fri, 13 Dec 2024 10:49:20 -0500 Subject: [PATCH 2/8] refactor: `Drag`, `AdjustPitchFromPosition`, add `AdjustPitchAfterDrag` - Refactor `Drag` for syllable, neume, and nc - Add `AdjustPitchAfterDrag` to calculate pitch difference on `y` change, use `AdjustPitchFromPosition` only for `Insert` - Refactor `AdjustPitchFromPosition`, reduce code duplication refs: https://github.com/DDMAL/Neon/issues/1250 --- include/vrv/editortoolkit_neume.h | 5 +- src/editortoolkit_neume.cpp | 376 +++++++++++++----------------- 2 files changed, 159 insertions(+), 222 deletions(-) diff --git a/include/vrv/editortoolkit_neume.h b/include/vrv/editortoolkit_neume.h index 1a925b0c8f..e0a7801e51 100644 --- a/include/vrv/editortoolkit_neume.h +++ b/include/vrv/editortoolkit_neume.h @@ -41,7 +41,7 @@ class EditorToolkitNeume : public EditorToolkit { ///@{ bool Chain(jsonxx::Array actions); bool DisplaceClefOctave(std::string elementId, std::string direction); - bool Drag(std::string elementId, int x, int y); + bool Drag(std::string elementId, int x, int y, bool topLevel = true); bool Insert(std::string elementType, std::string staffId, int ulx, int uly, int lrx, int lry, std::vector> attributes); bool InsertToSyllable(std::string elementId); @@ -102,7 +102,8 @@ class EditorToolkitNeume : public EditorToolkit { * Helper functions for editor actions. */ ///@{ - bool AdjustPitchFromPosition(Object *obj, Clef *clef = NULL); + bool AdjustPitchAfterDrag(Object *obj, int y = 0); + bool AdjustPitchFromPosition(Object *obj); bool AdjustClefLineFromPosition(Clef *clef, Staff *staff = NULL); ///@} }; diff --git a/src/editortoolkit_neume.cpp b/src/editortoolkit_neume.cpp index ce74cf244e..16d77f03a9 100644 --- a/src/editortoolkit_neume.cpp +++ b/src/editortoolkit_neume.cpp @@ -489,7 +489,7 @@ bool EditorToolkitNeume::ClefMovementHandler(Clef *clef, int x, int y) return true; } -bool EditorToolkitNeume::Drag(std::string elementId, int x, int y) +bool EditorToolkitNeume::Drag(std::string elementId, int x, int y, bool topLevel) { std::string status = "OK", message = ""; if (!m_doc->GetDrawingPage()) { @@ -520,87 +520,55 @@ bool EditorToolkitNeume::Drag(std::string elementId, int x, int y) assert(zone); zone->ShiftByXY(x, -y); - AdjustPitchFromPosition(element); + AdjustPitchAfterDrag(element, y); } - else if (element->HasInterface(INTERFACE_PITCH) || element->Is(NEUME) || element->Is(SYLLABLE)) { - Layer *layer = dynamic_cast(element->GetFirstAncestor(LAYER)); - if (!layer) { - LogError("Element does not have Layer parent. This should not happen."); - m_editInfo.import("status", "FAILURE"); - m_editInfo.import("message", "Element does not have Layer parent."); - return false; - } - - // clef association is done at the syllable level because of MEI structure - // also note this will initialize syllable as null in the case of custos - // which is why all the references to syllable are ternary - - Object *syllable = ((element->Is(SYLLABLE) ? (element) : element->GetFirstAncestor(SYLLABLE))); - - ClassIdComparison ac(CLEF); - InterfaceComparison facsIC(INTERFACE_FACSIMILE); - InterfaceComparison pitchIC(INTERFACE_PITCH); - + else if (element->Is(SYLLABLE)) { // Check for clefs in syllable ListOfObjects clefs; - syllable->FindAllDescendantsByComparison(&clefs, &ac); + ClassIdComparison ac(CLEF); + element->FindAllDescendantsByComparison(&clefs, &ac); bool hasClef = (clefs.size() != 0); - - FacsimileInterface *fi = element->GetFacsimileInterface(); - if (fi && fi->HasFacs()) { - bool ignoreFacs = false; - // Dont adjust the same facsimile twice. NCs in a ligature share a single zone. - if (element->Is(NC)) { - Nc *nc = dynamic_cast(element); - if (nc->GetLigated() == BOOLEAN_true) { - Neume *neume = vrv_cast(nc->GetFirstAncestor(NEUME)); - Nc *nextNc = dynamic_cast(neume->GetChild(1 + neume->GetChildIndex(element))); - if (nextNc != NULL && nextNc->GetLigated() == BOOLEAN_true && nextNc->GetZone() == nc->GetZone()) { - ignoreFacs = true; - } - } - } - if (!ignoreFacs) { - FacsimileInterface *fi = element->GetFacsimileInterface(); - assert(fi); - Zone *zone = fi->GetZone(); - assert(zone); - zone->ShiftByXY(x, -y); - } - } - else { - ListOfObjects facsChildren; - element->FindAllDescendantsByComparison(&facsChildren, &facsIC); - for (auto it = facsChildren.begin(); it != facsChildren.end(); ++it) { - // Don't change the text bbox position and skip clefs until later - if ((*it)->Is(SYL) || !(*it)->GetFacsimileInterface()->HasFacs() || (*it)->Is(CLEF)) { - continue; - } - else { - (*it)->GetFacsimileInterface()->GetZone()->ShiftByXY(x, -y); - } - } - } - if (hasClef) { for (Object *obj : clefs) { Clef *clef = dynamic_cast(obj); - ClefMovementHandler(clef, x, 0); + Drag(clef->GetID(), x, y, false); } + } - // if syllable contains clef, adjust individual neumes - ListOfObjects neumes; - ClassIdComparison neumeCompare(NEUME); - element->FindAllDescendantsByComparison(&neumes, &neumeCompare); - for (auto neume = neumes.begin(); neume != neumes.end(); ++neume) { - AdjustPitchFromPosition(*neume); + ListOfObjects ncs; + ClassIdComparison ncComp(NC); + element->FindAllDescendantsByComparison(&ncs, &ncComp); + for (auto nc = ncs.begin(); nc != ncs.end(); ++nc) { + Drag((*nc)->GetID(), x, y, false); + } + } + else if (element->Is(NEUME)) { + ListOfObjects ncs; + ClassIdComparison ncComp(NC); + element->FindAllDescendantsByComparison(&ncs, &ncComp); + for (auto nc = ncs.begin(); nc != ncs.end(); ++nc) { + Drag((*nc)->GetID(), x, y, false); + } + } + else if (element->Is(NC)) { + // Don't adjust the same facsimile twice. NCs in a ligature share a single zone. + bool skipLigature = false; + Nc *nc = dynamic_cast(element); + if (nc->GetLigated() == BOOLEAN_true) { + Neume *neume = vrv_cast(nc->GetFirstAncestor(NEUME)); + Nc *nextNc = dynamic_cast(neume->GetChild(1 + neume->GetChildIndex(element))); + if (nextNc != NULL && nextNc->GetLigated() == BOOLEAN_true && nextNc->GetZone() == nc->GetZone()) { + skipLigature = true; } } - else { - AdjustPitchFromPosition(syllable); + if (!skipLigature) { + FacsimileInterface *fi = element->GetFacsimileInterface(); + assert(fi); + Zone *zone = fi->GetZone(); + assert(zone); + zone->ShiftByXY(x, -y); } - - layer->ReorderByXPos(); + AdjustPitchAfterDrag(nc, y); } else if (element->Is(CLEF)) { Clef *clef = dynamic_cast(element); @@ -653,6 +621,7 @@ bool EditorToolkitNeume::Drag(std::string elementId, int x, int y) else { ClefMovementHandler(clef, x, y); } + m_doc->ScoreDefSetCurrentDoc(true); // this is needed for staves without clef } else if (element->Is(STAFF)) { Staff *staff = vrv_cast(element); @@ -737,13 +706,17 @@ bool EditorToolkitNeume::Drag(std::string elementId, int x, int y) m_editInfo.import("message", "Unsupported element for dragging."); return false; } - Layer *layer = vrv_cast(element->GetFirstAncestor(LAYER)); - layer->ReorderByXPos(); // Reflect position order of elements internally (and in the resulting output file) - if (m_doc->IsTranscription() && m_doc->HasFacsimile()) m_doc->SyncFromFacsimileDoc(); - m_doc->GetDrawingPage()->LayOutTranscription(true); - m_editInfo.import("status", status); - m_editInfo.import("message", message); + if (topLevel) { + Layer *layer = vrv_cast(element->GetFirstAncestor(LAYER)); + layer->ReorderByXPos(); // Reflect position order of elements internally (and in the resulting output file) + if (m_doc->IsTranscription() && m_doc->HasFacsimile()) m_doc->SyncFromFacsimileDoc(); + m_doc->GetDrawingPage()->LayOutTranscription(true); + + m_editInfo.import("status", status); + m_editInfo.import("message", message); + } + return true; } @@ -1116,9 +1089,9 @@ bool EditorToolkitNeume::Insert(std::string elementType, std::string staffId, in uly -= noteHeight / 2; zone->SetUlx(ulx + offsetX); - zone->SetUly(uly); + zone->SetUly(uly + noteHeight); zone->SetLrx(ulx + noteWidth + offsetX); - zone->SetLry(uly + noteHeight); + zone->SetLry(uly + noteHeight * 2); layer->ReorderByXPos(); if (!AdjustPitchFromPosition(custos)) { LogError("Failed to set pitch."); @@ -4199,85 +4172,80 @@ bool EditorToolkitNeume::ParseChangeStaffToAction(jsonxx::Object param, std::str return true; } -bool EditorToolkitNeume::AdjustPitchFromPosition(Object *obj, Clef *clef) +bool EditorToolkitNeume::AdjustPitchAfterDrag(Object *obj, int y) { - // remember to reorderbyxpos! (not called in function so that it can be used in loops) - // this should only be called in cases where finding the old clef is not required - // since doing it based only on clefs is much more efficient than based on position - // also if you are calling this function in a loop you should always be passing a clef argument - // since repeatedly finding the previous clef is very inefficient + if (!obj->Is(NC) && !obj->Is(CUSTOS)) { + LogError("AdjustPitchAfterDrag should only be called on custos or ncs." + "It has been called on %s, whose id is %s", + obj->GetClassName().c_str(), obj->GetID().c_str()); + return false; + } + PitchInterface *pi = obj->GetPitchInterface(); + assert(pi); + Staff *staff = dynamic_cast(obj->GetFirstAncestor(STAFF)); + const int staffSize = m_doc->GetDrawingUnit(staff->m_drawingStaffSize); + const int noteHeight = (int)(staffSize * 2 / NOTE_HEIGHT_TO_STAFF_SIZE_RATIO); + const int yOffset = y > 0 ? noteHeight / 2 : -noteHeight / 2; + const int pitchDifference = (y + yOffset) / staffSize; + pi->AdjustPitchByOffset(pitchDifference); + return true; +} - if (obj->Is(CUSTOS)) { - Custos *custos = dynamic_cast(obj); - Staff *staff = custos->GetAncestorStaff(); +bool EditorToolkitNeume::AdjustPitchFromPosition(Object *obj) +{ + if (!obj->Is(CUSTOS) && !obj->Is(SYLLABLE) && !obj->Is(NEUME)) { + LogError("AdjustPitchFromPosition should only be called on custos or syllables/neumes. Called on %s, ID: %s", + obj->GetClassName().c_str(), obj->GetID().c_str()); + return false; + } - // Check interfaces - if ((custos->GetPitchInterface() == NULL) || (custos->GetFacsimileInterface() == NULL)) { - LogError("Element is lacking an interface which is required for pitch adjusting"); - return false; - } - PitchInterface *pi = custos->GetPitchInterface(); - FacsimileInterface *fi = custos->GetFacsimileInterface(); + // Helper lambda to retrieve the clef and calculate its offset + auto getClefAndOffset = [this](Object *obj, Staff *staff, int staffSize, Clef *&clef, int &clefOffset) -> bool { + clefOffset = 0; + ClassIdComparison ac(CLEF); + clef = dynamic_cast(m_doc->GetDrawingPage()->FindPreviousChild(&ac, obj)); - // Check for facsimile - if (!fi->HasFacs() || !staff->HasFacs()) { - LogError("Could not adjust pitch: the element or staff lacks facsimile data"); - return false; + if (!clef) { + Layer *layer = vrv_cast(staff->FindDescendantByType(LAYER)); + if (!layer) { + LogError("Unable to find layer for staff."); + return false; + } + clef = layer->GetCurrentClef(); } - - int clefOffset = 0; - if (clef == NULL) { - ClassIdComparison ac(CLEF); - clef = dynamic_cast(m_doc->GetDrawingPage()->FindPreviousChild(&ac, obj)); - if (clef == NULL) { - ClassIdComparison ac(CLEF); - clef = dynamic_cast(m_doc->GetDrawingPage()->FindPreviousChild(&ac, obj)); - if (clef == NULL) { - Layer *layer = vrv_cast(staff->FindDescendantByType(LAYER)); - assert(layer); - clef = layer->GetCurrentClef(); - } - else { - Staff *clefStaff = dynamic_cast(clef->GetFirstAncestor(STAFF)); - assert(clefStaff); - clefOffset = round((double)(clefStaff->GetDrawingY() - - clefStaff->GetDrawingRotationOffsetFor(m_view->ToLogicalX(clef->GetZone()->GetUlx())) - - m_view->ToLogicalY(clef->GetZone()->GetUly()))); - } + else { + Staff *clefStaff = dynamic_cast(clef->GetFirstAncestor(STAFF)); + if (!clefStaff) { + LogError("Clef is missing its parent staff."); + return false; } + clefOffset + = round((double)(clefStaff->GetDrawingY() + - clefStaff->GetDrawingRotationOffsetFor(m_view->ToLogicalX(clef->GetZone()->GetUlx())) + - m_view->ToLogicalY(clef->GetZone()->GetUly())) + + staffSize); } + return true; + }; - data_PITCHNAME pname; - const int staffSize = m_doc->GetDrawingUnit(staff->m_drawingStaffSize); - int baseOctave; - - switch (clef->GetShape()) { - case CLEFSHAPE_C: - pname = PITCHNAME_c; - baseOctave = 4; - break; - case CLEFSHAPE_F: - pname = PITCHNAME_f; - baseOctave = 3; - break; - case CLEFSHAPE_G: - pname = PITCHNAME_g; - baseOctave = 4; - break; - default: - LogError("Clef %s does not have valid shape. Shape is %s", clef->GetID().c_str(), clef->GetShape()); - return false; + // Common logic for adjusting pitch + auto adjustPitch = [this](PitchInterface *pi, FacsimileInterface *fi, Clef *clef, int clefOffset, int staffSize, + int baseOctave, data_PITCHNAME pname, Staff *staff) { + if (!pi || !fi || !fi->HasFacs()) { + LogError("Pitch adjustment failed due to missing interfaces or facsimile data."); + return false; } + pi->SetPname(pname); - // The actual octave is calculated by - // taking into account the displacement of the clef + // Calculate the octave based on clef displacement int octave = baseOctave; if (clef->GetDis() && clef->GetDisPlace()) { octave += (clef->GetDisPlace() == STAFFREL_basic_above ? 1 : -1) * (clef->GetDis() / 7); } pi->SetOct(octave); + // Adjust pitch difference const int pitchDifference = round((double)((staff->GetDrawingY() - staff->GetDrawingRotationOffsetFor(m_view->ToLogicalX(fi->GetZone()->GetUlx())) @@ -4285,100 +4253,68 @@ bool EditorToolkitNeume::AdjustPitchFromPosition(Object *obj, Clef *clef) / (double)(staffSize)); pi->AdjustPitchByOffset(-pitchDifference); return true; + }; + + Staff *staff = dynamic_cast(obj->GetFirstAncestor(STAFF)); + const int staffSize = m_doc->GetDrawingUnit(staff->m_drawingStaffSize); + if (!staff) { + LogError("Object does not have a valid parent staff."); + return false; } - else if (obj->Is(SYLLABLE) || obj->Is(NEUME)) { - Staff *staff = dynamic_cast(obj->GetFirstAncestor(STAFF)); - assert(staff); + Clef *clef = nullptr; + int clefOffset = 0; + if (!getClefAndOffset(obj, staff, staffSize, clef, clefOffset)) { + return false; + } + data_PITCHNAME pname; + int baseOctave; + + // Determine pitch name and base octave based on clef shape + switch (clef->GetShape()) { + case CLEFSHAPE_C: + pname = PITCHNAME_c; + baseOctave = 4; + break; + case CLEFSHAPE_F: + pname = PITCHNAME_f; + baseOctave = 3; + break; + case CLEFSHAPE_G: + pname = PITCHNAME_g; + baseOctave = 4; + break; + default: + LogError("Clef %s does not have a valid shape: %s", clef->GetID().c_str(), clef->GetShape()); + return false; + } + + if (obj->Is(CUSTOS)) { + return adjustPitch(obj->GetPitchInterface(), obj->GetFacsimileInterface(), clef, clefOffset, staffSize, + baseOctave, pname, staff); + } + // syllable/neume: call the adjustPitch on children + else { ListOfObjects pitchedChildren; InterfaceComparison ic(INTERFACE_PITCH); obj->FindAllDescendantsByComparison(&pitchedChildren, &ic); if (pitchedChildren.empty()) { - LogWarning("Syllable/neume had no pitched children to reorder for syllable/neume %s", obj->GetID().c_str()); + LogWarning("Syllable/neume has no pitched children: %s", obj->GetID().c_str()); return true; } - int clefOffset = 0; - if (clef == NULL) { - ClassIdComparison ac(CLEF); - clef = dynamic_cast(m_doc->GetDrawingPage()->FindPreviousChild(&ac, obj)); - if (clef == NULL) { - Layer *layer = vrv_cast(staff->FindDescendantByType(LAYER)); - assert(layer); - clef = layer->GetCurrentClef(); - } - else { - Staff *clefStaff = dynamic_cast(clef->GetFirstAncestor(STAFF)); - assert(clefStaff); - clefOffset = round((double)(clefStaff->GetDrawingY() - - clefStaff->GetDrawingRotationOffsetFor(m_view->ToLogicalX(clef->GetZone()->GetUlx())) - - m_view->ToLogicalY(clef->GetZone()->GetUly()))); - } - } - - data_PITCHNAME pname = PITCHNAME_c; - const int staffSize = m_doc->GetDrawingUnit(staff->m_drawingStaffSize); - int baseOctave; - - switch (clef->GetShape()) { - case CLEFSHAPE_C: - pname = PITCHNAME_c; - baseOctave = 4; - break; - case CLEFSHAPE_F: - pname = PITCHNAME_f; - baseOctave = 3; - break; - case CLEFSHAPE_G: - pname = PITCHNAME_g; - baseOctave = 4; - break; - default: - LogError("Clef %s does not have valid shape. Shape is %s", clef->GetID().c_str(), clef->GetShape()); - return false; - } - - for (auto it = pitchedChildren.begin(); it != pitchedChildren.end(); ++it) { - if ((*it)->Is(LIQUESCENT)) continue; - - FacsimileInterface *fi = (*it)->GetFacsimileInterface(); - if (fi == NULL || !fi->HasFacs()) { - LogError("Could not adjust pitch: child %s does not have facsimile data", (*it)->GetID().c_str()); - return false; - } - - PitchInterface *pi = (*it)->GetPitchInterface(); - assert(pi); - pi->SetPname(pname); - - // The actual octave is calculated by - // taking into account the displacement of the clef - int octave = baseOctave; - if (clef->GetDis() && clef->GetDisPlace()) { - octave += (clef->GetDisPlace() == STAFFREL_basic_above ? 1 : -1) * (clef->GetDis() / 7); + for (auto *child : pitchedChildren) { + if (!child->Is(LIQUESCENT)) { + if (!adjustPitch(child->GetPitchInterface(), child->GetFacsimileInterface(), clef, clefOffset, + staffSize, baseOctave, pname, staff)) { + return false; + } } - pi->SetOct(octave); - - const int pitchDifference - = round((double)((staff->GetDrawingY() - - staff->GetDrawingRotationOffsetFor(m_view->ToLogicalX(fi->GetZone()->GetUlx())) - - m_view->ToLogicalY(fi->GetZone()->GetUly()) - clefOffset)) - / (double)(staffSize)); - - pi->AdjustPitchByOffset(-pitchDifference); } - - return true; - } - - else { - LogError("AdjustPitchFromPosition should only be called on custos or syllables." - "It has been called on %s, whose id is %s", - obj->GetClassName().c_str(), obj->GetID().c_str()); - return false; } + return true; } bool EditorToolkitNeume::AdjustClefLineFromPosition(Clef *clef, Staff *staff) From f8a621b1eb93d610ab708abb118f6301ccc5a8c6 Mon Sep 17 00:00:00 2001 From: Yinan Zhou Date: Fri, 13 Dec 2024 11:07:06 -0500 Subject: [PATCH 3/8] fix: layout after staff resize/rotation - for elements jump on dragging after staff resize/rotation refs: https://github.com/DDMAL/Neon/issues/1252 --- src/editortoolkit_neume.cpp | 5 +++-- 1 file changed, 3 insertions(+), 2 deletions(-) diff --git a/src/editortoolkit_neume.cpp b/src/editortoolkit_neume.cpp index 16d77f03a9..9c51155be2 100644 --- a/src/editortoolkit_neume.cpp +++ b/src/editortoolkit_neume.cpp @@ -2496,6 +2496,8 @@ bool EditorToolkitNeume::Resize(std::string elementId, int ulx, int uly, int lrx accidZone->SetLry(accidZone->GetLry() + int(rotationOffset)); } } + if (m_doc->IsTranscription() && m_doc->HasFacsimile()) m_doc->SyncFromFacsimileDoc(); + m_doc->GetDrawingPage()->LayOutTranscription(true); } else if (obj->Is(SYL)) { Syl *syl = vrv_cast(obj); @@ -2530,6 +2532,7 @@ bool EditorToolkitNeume::Resize(std::string elementId, int ulx, int uly, int lrx zone->SetRotate(rotate); } zone->Modify(); + if (m_doc->IsTranscription() && m_doc->HasFacsimile()) m_doc->SyncFromFacsimileDoc(); } else { LogError("Element of type '%s' is unsupported.", obj->GetClassName().c_str()); @@ -2538,8 +2541,6 @@ bool EditorToolkitNeume::Resize(std::string elementId, int ulx, int uly, int lrx return false; } - if (m_doc->IsTranscription() && m_doc->HasFacsimile()) m_doc->SyncFromFacsimileDoc(); - m_editInfo.import("status", "OK"); m_editInfo.import("message", ""); return true; From 3be23105ca28425b8f5dad5ecf626fc70ead45d8 Mon Sep 17 00:00:00 2001 From: rettinghaus Date: Sat, 14 Dec 2024 13:21:48 +0100 Subject: [PATCH 4/8] move color attribute to control element --- include/vrv/arpeg.h | 1 - include/vrv/beamspan.h | 3 +-- include/vrv/bracketspan.h | 1 - include/vrv/breath.h | 2 +- include/vrv/caesura.h | 1 - include/vrv/controlelement.h | 2 ++ include/vrv/fermata.h | 1 - include/vrv/gliss.h | 1 - include/vrv/hairpin.h | 1 - include/vrv/mnum.h | 1 - include/vrv/mordent.h | 1 - include/vrv/octave.h | 1 - include/vrv/ornam.h | 1 - include/vrv/pedal.h | 1 - include/vrv/reh.h | 1 - include/vrv/repeatmark.h | 1 - include/vrv/slur.h | 1 - include/vrv/tie.h | 1 - include/vrv/trill.h | 1 - include/vrv/turn.h | 1 - src/arpeg.cpp | 4 +--- src/beamspan.cpp | 3 --- src/bracketspan.cpp | 3 --- src/breath.cpp | 4 +--- src/caesura.cpp | 3 --- src/controlelement.cpp | 6 +++++- src/fermata.cpp | 3 --- src/gliss.cpp | 3 --- src/hairpin.cpp | 3 --- src/mnum.cpp | 3 --- src/mordent.cpp | 3 --- src/octave.cpp | 3 --- src/ornam.cpp | 3 --- src/pedal.cpp | 3 --- src/reh.cpp | 4 +--- src/repeatmark.cpp | 3 --- src/slur.cpp | 7 ------- src/tie.cpp | 10 +++------- src/trill.cpp | 3 --- src/turn.cpp | 3 --- 40 files changed, 15 insertions(+), 86 deletions(-) diff --git a/include/vrv/arpeg.h b/include/vrv/arpeg.h index 4867378037..80f41500e9 100644 --- a/include/vrv/arpeg.h +++ b/include/vrv/arpeg.h @@ -28,7 +28,6 @@ class Arpeg : public ControlElement, public TimePointInterface, public AttArpegLog, public AttArpegVis, - public AttColor, public AttEnclosingChars { public: /** diff --git a/include/vrv/beamspan.h b/include/vrv/beamspan.h index b66631bb92..5533e5c840 100644 --- a/include/vrv/beamspan.h +++ b/include/vrv/beamspan.h @@ -33,8 +33,7 @@ class BeamSpan : public ControlElement, public PlistInterface, public TimeSpanningInterface, public AttBeamedWith, - public AttBeamRend, - public AttColor { + public AttBeamRend { public: /** * @name Constructors, destructors, and other standard methods diff --git a/include/vrv/bracketspan.h b/include/vrv/bracketspan.h index 22e8c1aa69..5937dd0c0f 100644 --- a/include/vrv/bracketspan.h +++ b/include/vrv/bracketspan.h @@ -24,7 +24,6 @@ namespace vrv { class BracketSpan : public ControlElement, public TimeSpanningInterface, public AttBracketSpanLog, - public AttColor, public AttLineRend, public AttLineRendBase { public: diff --git a/include/vrv/breath.h b/include/vrv/breath.h index 502b510e25..c11ec1213a 100644 --- a/include/vrv/breath.h +++ b/include/vrv/breath.h @@ -21,7 +21,7 @@ namespace vrv { /** * This class models the MEI element. */ -class Breath : public ControlElement, public TimePointInterface, public AttColor, public AttPlacementRelStaff { +class Breath : public ControlElement, public TimePointInterface, public AttPlacementRelStaff { public: /** * @name Constructors, destructors, and other standard methods diff --git a/include/vrv/caesura.h b/include/vrv/caesura.h index 5125f911de..49fe58336d 100644 --- a/include/vrv/caesura.h +++ b/include/vrv/caesura.h @@ -24,7 +24,6 @@ namespace vrv { */ class Caesura : public ControlElement, public TimePointInterface, - public AttColor, public AttExtSymAuth, public AttExtSymNames, public AttPlacementRelStaff { diff --git a/include/vrv/controlelement.h b/include/vrv/controlelement.h index 6d595ddfbc..3253a7213f 100644 --- a/include/vrv/controlelement.h +++ b/include/vrv/controlelement.h @@ -10,6 +10,7 @@ #include "altsyminterface.h" #include "atts_shared.h" +#include "atts_visual.h" #include "devicecontextbase.h" #include "floatingobject.h" #include "linkinginterface.h" @@ -27,6 +28,7 @@ namespace vrv { class ControlElement : public FloatingObject, public AltSymInterface, public LinkingInterface, + public AttColor, public AttLabelled, public AttTyped { public: diff --git a/include/vrv/fermata.h b/include/vrv/fermata.h index 128368fd85..b0429636ed 100644 --- a/include/vrv/fermata.h +++ b/include/vrv/fermata.h @@ -25,7 +25,6 @@ namespace vrv { */ class Fermata : public ControlElement, public TimePointInterface, - public AttColor, public AttEnclosingChars, public AttExtSymAuth, public AttExtSymNames, diff --git a/include/vrv/gliss.h b/include/vrv/gliss.h index 3eb6c55378..a464862fca 100644 --- a/include/vrv/gliss.h +++ b/include/vrv/gliss.h @@ -23,7 +23,6 @@ namespace vrv { */ class Gliss : public ControlElement, public TimeSpanningInterface, - public AttColor, public AttLineRend, public AttLineRendBase, public AttNNumberLike { diff --git a/include/vrv/hairpin.h b/include/vrv/hairpin.h index 8a81dd1d3d..353b53adbc 100644 --- a/include/vrv/hairpin.h +++ b/include/vrv/hairpin.h @@ -24,7 +24,6 @@ namespace vrv { */ class Hairpin : public ControlElement, public TimeSpanningInterface, - public AttColor, public AttHairpinLog, public AttHairpinVis, public AttLineRendBase, diff --git a/include/vrv/mnum.h b/include/vrv/mnum.h index a8d32b1de0..44d3e5329a 100644 --- a/include/vrv/mnum.h +++ b/include/vrv/mnum.h @@ -27,7 +27,6 @@ class MNum : public ControlElement, public TextListInterface, public TextDirInterface, public TimePointInterface, - public AttColor, public AttLang, public AttTypography { public: diff --git a/include/vrv/mordent.h b/include/vrv/mordent.h index 2eaf9ddeaf..c479d62bf8 100644 --- a/include/vrv/mordent.h +++ b/include/vrv/mordent.h @@ -25,7 +25,6 @@ namespace vrv { */ class Mordent : public ControlElement, public TimePointInterface, - public AttColor, public AttExtSymAuth, public AttExtSymNames, public AttOrnamentAccid, diff --git a/include/vrv/octave.h b/include/vrv/octave.h index c9f59f7651..d8ebf6609c 100644 --- a/include/vrv/octave.h +++ b/include/vrv/octave.h @@ -24,7 +24,6 @@ namespace vrv { */ class Octave : public ControlElement, public TimeSpanningInterface, - public AttColor, public AttExtender, public AttLineRend, public AttLineRendBase, diff --git a/include/vrv/ornam.h b/include/vrv/ornam.h index 25950ab63b..2f417fa446 100644 --- a/include/vrv/ornam.h +++ b/include/vrv/ornam.h @@ -28,7 +28,6 @@ class Ornam : public ControlElement, public TextListInterface, public TextDirInterface, public TimePointInterface, - public AttColor, public AttOrnamentAccid { public: /** diff --git a/include/vrv/pedal.h b/include/vrv/pedal.h index 36b521be3a..2bde8f287a 100644 --- a/include/vrv/pedal.h +++ b/include/vrv/pedal.h @@ -26,7 +26,6 @@ class System; */ class Pedal : public ControlElement, public TimeSpanningInterface, - public AttColor, public AttExtSymAuth, public AttExtSymNames, public AttPedalLog, diff --git a/include/vrv/reh.h b/include/vrv/reh.h index 51f837a32f..a371468605 100644 --- a/include/vrv/reh.h +++ b/include/vrv/reh.h @@ -26,7 +26,6 @@ class TextElement; class Reh : public ControlElement, public TextDirInterface, public TimePointInterface, - public AttColor, public AttLang, public AttVerticalGroup { public: diff --git a/include/vrv/repeatmark.h b/include/vrv/repeatmark.h index 87e3cadd8d..ce228b37dc 100644 --- a/include/vrv/repeatmark.h +++ b/include/vrv/repeatmark.h @@ -27,7 +27,6 @@ class RepeatMark : public ControlElement, public TextListInterface, public TextDirInterface, public TimePointInterface, - public AttColor, public AttExtSymAuth, public AttExtSymNames, public AttRepeatMarkLog { diff --git a/include/vrv/slur.h b/include/vrv/slur.h index 6c6e6ac8d7..595a9235cb 100644 --- a/include/vrv/slur.h +++ b/include/vrv/slur.h @@ -52,7 +52,6 @@ enum class PortatoSlurType { None, StemSide, Centered }; class Slur : public ControlElement, public TimeSpanningInterface, - public AttColor, public AttCurvature, public AttLayerIdent, public AttLineRendBase { diff --git a/include/vrv/tie.h b/include/vrv/tie.h index ccd92e5e5e..db3f258f94 100644 --- a/include/vrv/tie.h +++ b/include/vrv/tie.h @@ -26,7 +26,6 @@ class Note; */ class Tie : public ControlElement, public TimeSpanningInterface, - public AttColor, public AttCurvature, public AttLineRendBase { public: diff --git a/include/vrv/trill.h b/include/vrv/trill.h index da61ec3d25..622965a76e 100644 --- a/include/vrv/trill.h +++ b/include/vrv/trill.h @@ -25,7 +25,6 @@ namespace vrv { */ class Trill : public ControlElement, public TimeSpanningInterface, - public AttColor, public AttExtender, public AttExtSymAuth, public AttExtSymNames, diff --git a/include/vrv/turn.h b/include/vrv/turn.h index f11f12e35a..6c7a535780 100644 --- a/include/vrv/turn.h +++ b/include/vrv/turn.h @@ -25,7 +25,6 @@ namespace vrv { */ class Turn : public ControlElement, public TimePointInterface, - public AttColor, public AttExtSymAuth, public AttExtSymNames, public AttOrnamentAccid, diff --git a/src/arpeg.cpp b/src/arpeg.cpp index 09863c30f0..28f38059b7 100644 --- a/src/arpeg.cpp +++ b/src/arpeg.cpp @@ -30,13 +30,12 @@ namespace vrv { static const ClassRegistrar s_factory("arpeg", ARPEG); Arpeg::Arpeg() - : ControlElement(ARPEG, "arpeg-"), PlistInterface(), TimePointInterface(), AttArpegLog(), AttArpegVis(), AttColor() + : ControlElement(ARPEG, "arpeg-"), PlistInterface(), TimePointInterface(), AttArpegLog(), AttArpegVis() { this->RegisterInterface(PlistInterface::GetAttClasses(), PlistInterface::IsInterface()); this->RegisterInterface(TimePointInterface::GetAttClasses(), TimePointInterface::IsInterface()); this->RegisterAttClass(ATT_ARPEGLOG); this->RegisterAttClass(ATT_ARPEGVIS); - this->RegisterAttClass(ATT_COLOR); this->RegisterAttClass(ATT_ENCLOSINGCHARS); this->Reset(); @@ -51,7 +50,6 @@ void Arpeg::Reset() TimePointInterface::Reset(); this->ResetArpegLog(); this->ResetArpegVis(); - this->ResetColor(); this->ResetEnclosingChars(); m_drawingXRel = 0; diff --git a/src/beamspan.cpp b/src/beamspan.cpp index 605016a01e..ea02767983 100644 --- a/src/beamspan.cpp +++ b/src/beamspan.cpp @@ -36,13 +36,11 @@ BeamSpan::BeamSpan() , TimeSpanningInterface() , AttBeamedWith() , AttBeamRend() - , AttColor() { RegisterInterface(PlistInterface::GetAttClasses(), PlistInterface::IsInterface()); RegisterInterface(TimeSpanningInterface::GetAttClasses(), TimeSpanningInterface::IsInterface()); RegisterAttClass(ATT_BEAMEDWITH); RegisterAttClass(ATT_BEAMREND); - RegisterAttClass(ATT_COLOR); Reset(); InitBeamSegments(); @@ -61,7 +59,6 @@ void BeamSpan::Reset() TimeSpanningInterface::Reset(); ResetBeamedWith(); ResetBeamRend(); - ResetColor(); ClearBeamSegments(); } diff --git a/src/bracketspan.cpp b/src/bracketspan.cpp index a793311d60..ed49bcadd5 100644 --- a/src/bracketspan.cpp +++ b/src/bracketspan.cpp @@ -31,13 +31,11 @@ BracketSpan::BracketSpan() : ControlElement(BRACKETSPAN, "bspan-") , TimeSpanningInterface() , AttBracketSpanLog() - , AttColor() , AttLineRend() , AttLineRendBase() { this->RegisterInterface(TimeSpanningInterface::GetAttClasses(), TimeSpanningInterface::IsInterface()); this->RegisterAttClass(ATT_BRACKETSPANLOG); - this->RegisterAttClass(ATT_COLOR); this->RegisterAttClass(ATT_LINEREND); this->RegisterAttClass(ATT_LINERENDBASE); @@ -51,7 +49,6 @@ void BracketSpan::Reset() ControlElement::Reset(); TimeSpanningInterface::Reset(); this->ResetBracketSpanLog(); - this->ResetColor(); this->ResetLineRend(); this->ResetLineRendBase(); } diff --git a/src/breath.cpp b/src/breath.cpp index e0af690624..5237195401 100644 --- a/src/breath.cpp +++ b/src/breath.cpp @@ -24,10 +24,9 @@ namespace vrv { static const ClassRegistrar s_factory("breath", BREATH); -Breath::Breath() : ControlElement(BREATH, "breath-"), TimePointInterface(), AttColor(), AttPlacementRelStaff() +Breath::Breath() : ControlElement(BREATH, "breath-"), TimePointInterface(), AttPlacementRelStaff() { this->RegisterInterface(TimePointInterface::GetAttClasses(), TimePointInterface::IsInterface()); - this->RegisterAttClass(ATT_COLOR); this->RegisterAttClass(ATT_PLACEMENTRELSTAFF); this->Reset(); @@ -39,7 +38,6 @@ void Breath::Reset() { ControlElement::Reset(); TimePointInterface::Reset(); - this->ResetColor(); this->ResetPlacementRelStaff(); } diff --git a/src/caesura.cpp b/src/caesura.cpp index 494baca028..4aab629585 100644 --- a/src/caesura.cpp +++ b/src/caesura.cpp @@ -29,13 +29,11 @@ static const ClassRegistrar s_factory("caesura", CAESURA); Caesura::Caesura() : ControlElement(CAESURA, "caesura-") , TimePointInterface() - , AttColor() , AttExtSymAuth() , AttExtSymNames() , AttPlacementRelStaff() { this->RegisterInterface(TimePointInterface::GetAttClasses(), TimePointInterface::IsInterface()); - this->RegisterAttClass(ATT_COLOR); this->RegisterAttClass(ATT_EXTSYMAUTH); this->RegisterAttClass(ATT_EXTSYMNAMES); this->RegisterAttClass(ATT_PLACEMENTRELSTAFF); @@ -49,7 +47,6 @@ void Caesura::Reset() { ControlElement::Reset(); TimePointInterface::Reset(); - this->ResetColor(); this->ResetPlacementRelStaff(); } diff --git a/src/controlelement.cpp b/src/controlelement.cpp index 9891f5aaeb..82eaf2f95a 100644 --- a/src/controlelement.cpp +++ b/src/controlelement.cpp @@ -28,10 +28,11 @@ namespace vrv { //---------------------------------------------------------------------------- ControlElement::ControlElement() - : FloatingObject(CONTROL_ELEMENT, "ce"), AltSymInterface(), LinkingInterface(), AttLabelled(), AttTyped() + : FloatingObject(CONTROL_ELEMENT, "ce"), AltSymInterface(), LinkingInterface(), AttColor(), AttLabelled(), AttTyped() { this->RegisterInterface(AltSymInterface::GetAttClasses(), AltSymInterface::IsInterface()); this->RegisterInterface(LinkingInterface::GetAttClasses(), LinkingInterface::IsInterface()); + this->RegisterAttClass(ATT_COLOR); this->RegisterAttClass(ATT_LABELLED); this->RegisterAttClass(ATT_TYPED); @@ -43,6 +44,7 @@ ControlElement::ControlElement(ClassId classId) { this->RegisterInterface(AltSymInterface::GetAttClasses(), AltSymInterface::IsInterface()); this->RegisterInterface(LinkingInterface::GetAttClasses(), LinkingInterface::IsInterface()); + this->RegisterAttClass(ATT_COLOR); this->RegisterAttClass(ATT_LABELLED); this->RegisterAttClass(ATT_TYPED); @@ -54,6 +56,7 @@ ControlElement::ControlElement(ClassId classId, const std::string &classIdStr) { this->RegisterInterface(AltSymInterface::GetAttClasses(), AltSymInterface::IsInterface()); this->RegisterInterface(LinkingInterface::GetAttClasses(), LinkingInterface::IsInterface()); + this->RegisterAttClass(ATT_COLOR); this->RegisterAttClass(ATT_LABELLED); this->RegisterAttClass(ATT_TYPED); @@ -67,6 +70,7 @@ void ControlElement::Reset() FloatingObject::Reset(); AltSymInterface::Reset(); LinkingInterface::Reset(); + this->ResetColor(); this->ResetLabelled(); this->ResetTyped(); } diff --git a/src/fermata.cpp b/src/fermata.cpp index 830f9a4dca..34014f4004 100644 --- a/src/fermata.cpp +++ b/src/fermata.cpp @@ -29,14 +29,12 @@ static const ClassRegistrar s_factory("fermata", FERMATA); Fermata::Fermata() : ControlElement(FERMATA, "fermata-") , TimePointInterface() - , AttColor() , AttExtSymAuth() , AttExtSymNames() , AttFermataVis() , AttPlacementRelStaff() { this->RegisterInterface(TimePointInterface::GetAttClasses(), TimePointInterface::IsInterface()); - this->RegisterAttClass(ATT_COLOR); this->RegisterAttClass(ATT_ENCLOSINGCHARS); this->RegisterAttClass(ATT_EXTSYMAUTH); this->RegisterAttClass(ATT_EXTSYMNAMES); @@ -53,7 +51,6 @@ void Fermata::Reset() ControlElement::Reset(); AltSymInterface::Reset(); TimePointInterface::Reset(); - this->ResetColor(); this->ResetEnclosingChars(); this->ResetExtSymAuth(); this->ResetExtSymNames(); diff --git a/src/gliss.cpp b/src/gliss.cpp index 791030e350..21050b3b8f 100644 --- a/src/gliss.cpp +++ b/src/gliss.cpp @@ -29,13 +29,11 @@ static const ClassRegistrar s_factory("gliss", GLISS); Gliss::Gliss() : ControlElement(GLISS, "gliss-") , TimeSpanningInterface() - , AttColor() , AttLineRend() , AttLineRendBase() , AttNNumberLike() { this->RegisterInterface(TimeSpanningInterface::GetAttClasses(), TimeSpanningInterface::IsInterface()); - this->RegisterAttClass(ATT_COLOR); this->RegisterAttClass(ATT_LINEREND); this->RegisterAttClass(ATT_LINERENDBASE); this->RegisterAttClass(ATT_NNUMBERLIKE); @@ -49,7 +47,6 @@ void Gliss::Reset() { ControlElement::Reset(); TimeSpanningInterface::Reset(); - this->ResetColor(); this->ResetLineRend(); this->ResetLineRendBase(); this->ResetNNumberLike(); diff --git a/src/hairpin.cpp b/src/hairpin.cpp index 56115adb49..b5f68b901e 100644 --- a/src/hairpin.cpp +++ b/src/hairpin.cpp @@ -34,14 +34,12 @@ static const ClassRegistrar s_factory("hairpin", HAIRPIN); Hairpin::Hairpin() : ControlElement(HAIRPIN, "hairpin-") , TimeSpanningInterface() - , AttColor() , AttHairpinLog() , AttHairpinVis() , AttPlacementRelStaff() , AttVerticalGroup() { this->RegisterInterface(TimeSpanningInterface::GetAttClasses(), TimeSpanningInterface::IsInterface()); - this->RegisterAttClass(ATT_COLOR); this->RegisterAttClass(ATT_HAIRPINLOG); this->RegisterAttClass(ATT_HAIRPINVIS); this->RegisterAttClass(ATT_LINERENDBASE); @@ -57,7 +55,6 @@ void Hairpin::Reset() { ControlElement::Reset(); TimeSpanningInterface::Reset(); - this->ResetColor(); this->ResetHairpinLog(); this->ResetHairpinVis(); this->ResetLineRendBase(); diff --git a/src/mnum.cpp b/src/mnum.cpp index a98a5ec5d5..6c19384fa6 100644 --- a/src/mnum.cpp +++ b/src/mnum.cpp @@ -30,13 +30,11 @@ MNum::MNum() , TextListInterface() , TextDirInterface() , TimePointInterface() - , AttColor() , AttLang() , AttTypography() { this->RegisterInterface(TextDirInterface::GetAttClasses(), TextDirInterface::IsInterface()); this->RegisterInterface(TimePointInterface::GetAttClasses(), TimePointInterface::IsInterface()); - this->RegisterAttClass(ATT_COLOR); this->RegisterAttClass(ATT_LANG); this->RegisterAttClass(ATT_TYPOGRAPHY); @@ -50,7 +48,6 @@ void MNum::Reset() ControlElement::Reset(); TextDirInterface::Reset(); TimePointInterface::Reset(); - this->ResetColor(); this->ResetLang(); this->ResetTypography(); diff --git a/src/mordent.cpp b/src/mordent.cpp index ac42882eef..f846216424 100644 --- a/src/mordent.cpp +++ b/src/mordent.cpp @@ -29,7 +29,6 @@ static const ClassRegistrar s_factory("mordent", MORDENT); Mordent::Mordent() : ControlElement(MORDENT, "mordent-") , TimePointInterface() - , AttColor() , AttExtSymAuth() , AttExtSymNames() , AttOrnamentAccid() @@ -37,7 +36,6 @@ Mordent::Mordent() , AttMordentLog() { this->RegisterInterface(TimePointInterface::GetAttClasses(), TimePointInterface::IsInterface()); - this->RegisterAttClass(ATT_COLOR); this->RegisterAttClass(ATT_EXTSYMAUTH); this->RegisterAttClass(ATT_EXTSYMNAMES); this->RegisterAttClass(ATT_ORNAMENTACCID); @@ -53,7 +51,6 @@ void Mordent::Reset() { ControlElement::Reset(); TimePointInterface::Reset(); - this->ResetColor(); this->ResetExtSymAuth(); this->ResetExtSymNames(); this->ResetOrnamentAccid(); diff --git a/src/octave.cpp b/src/octave.cpp index db7af715bc..834750f8af 100644 --- a/src/octave.cpp +++ b/src/octave.cpp @@ -29,7 +29,6 @@ static const ClassRegistrar s_factory("octave", OCTAVE); Octave::Octave() : ControlElement(OCTAVE, "octave-") , TimeSpanningInterface() - , AttColor() , AttExtender() , AttLineRend() , AttLineRendBase() @@ -37,7 +36,6 @@ Octave::Octave() , AttOctaveDisplacement() { this->RegisterInterface(TimeSpanningInterface::GetAttClasses(), TimeSpanningInterface::IsInterface()); - this->RegisterAttClass(ATT_COLOR); this->RegisterAttClass(ATT_EXTENDER); this->RegisterAttClass(ATT_LINEREND); this->RegisterAttClass(ATT_LINERENDBASE); @@ -53,7 +51,6 @@ void Octave::Reset() { ControlElement::Reset(); TimeSpanningInterface::Reset(); - this->ResetColor(); this->ResetExtender(); this->ResetLineRend(); this->ResetLineRendBase(); diff --git a/src/ornam.cpp b/src/ornam.cpp index 89ec050612..95b35ee96f 100644 --- a/src/ornam.cpp +++ b/src/ornam.cpp @@ -34,12 +34,10 @@ Ornam::Ornam() , TextListInterface() , TextDirInterface() , TimePointInterface() - , AttColor() , AttOrnamentAccid() { this->RegisterInterface(TextDirInterface::GetAttClasses(), TextDirInterface::IsInterface()); this->RegisterInterface(TimePointInterface::GetAttClasses(), TimePointInterface::IsInterface()); - this->RegisterAttClass(ATT_COLOR); this->RegisterAttClass(ATT_ORNAMENTACCID); this->Reset(); @@ -52,7 +50,6 @@ void Ornam::Reset() ControlElement::Reset(); TextDirInterface::Reset(); TimePointInterface::Reset(); - this->ResetColor(); this->ResetOrnamentAccid(); } diff --git a/src/pedal.cpp b/src/pedal.cpp index 79a162cc67..5438f314a5 100644 --- a/src/pedal.cpp +++ b/src/pedal.cpp @@ -37,7 +37,6 @@ static const ClassRegistrar s_factory("pedal", PEDAL); Pedal::Pedal() : ControlElement(PEDAL, "pedal-") , TimeSpanningInterface() - , AttColor() , AttExtSymAuth() , AttExtSymNames() , AttPedalLog() @@ -46,7 +45,6 @@ Pedal::Pedal() , AttVerticalGroup() { this->RegisterInterface(TimeSpanningInterface::GetAttClasses(), TimeSpanningInterface::IsInterface()); - this->RegisterAttClass(ATT_COLOR); this->RegisterAttClass(ATT_EXTSYMAUTH); this->RegisterAttClass(ATT_EXTSYMNAMES); this->RegisterAttClass(ATT_PEDALLOG); @@ -63,7 +61,6 @@ void Pedal::Reset() { ControlElement::Reset(); TimeSpanningInterface::Reset(); - this->ResetColor(); this->ResetExtSymAuth(); this->ResetExtSymNames(); this->ResetPedalLog(); diff --git a/src/reh.cpp b/src/reh.cpp index 90bf6643ad..116cf3fc4c 100644 --- a/src/reh.cpp +++ b/src/reh.cpp @@ -29,11 +29,10 @@ namespace vrv { static const ClassRegistrar s_factory("reh", REH); Reh::Reh() - : ControlElement(REH, "reh-"), TextDirInterface(), TimePointInterface(), AttColor(), AttLang(), AttVerticalGroup() + : ControlElement(REH, "reh-"), TextDirInterface(), TimePointInterface(), AttLang(), AttVerticalGroup() { this->RegisterInterface(TextDirInterface::GetAttClasses(), TextDirInterface::IsInterface()); this->RegisterInterface(TimePointInterface::GetAttClasses(), TimePointInterface::IsInterface()); - this->RegisterAttClass(ATT_COLOR); this->RegisterAttClass(ATT_LANG); this->RegisterAttClass(ATT_VERTICALGROUP); @@ -47,7 +46,6 @@ void Reh::Reset() ControlElement::Reset(); TextDirInterface::Reset(); TimePointInterface::Reset(); - this->ResetColor(); this->ResetLang(); this->ResetVerticalGroup(); } diff --git a/src/repeatmark.cpp b/src/repeatmark.cpp index 02d4fa6df0..0f662d9476 100644 --- a/src/repeatmark.cpp +++ b/src/repeatmark.cpp @@ -34,14 +34,12 @@ RepeatMark::RepeatMark() , TextListInterface() , TextDirInterface() , TimePointInterface() - , AttColor() , AttExtSymAuth() , AttExtSymNames() , AttRepeatMarkLog() { this->RegisterInterface(TextDirInterface::GetAttClasses(), TextDirInterface::IsInterface()); this->RegisterInterface(TimePointInterface::GetAttClasses(), TimePointInterface::IsInterface()); - this->RegisterAttClass(ATT_COLOR); this->RegisterAttClass(ATT_EXTSYMAUTH); this->RegisterAttClass(ATT_EXTSYMNAMES); this->RegisterAttClass(ATT_REPEATMARKLOG); @@ -56,7 +54,6 @@ void RepeatMark::Reset() ControlElement::Reset(); TextDirInterface::Reset(); TimePointInterface::Reset(); - this->ResetColor(); this->ResetExtSymAuth(); this->ResetExtSymNames(); this->ResetRepeatMarkLog(); diff --git a/src/slur.cpp b/src/slur.cpp index 5250e5ef56..fda215b4bf 100644 --- a/src/slur.cpp +++ b/src/slur.cpp @@ -43,13 +43,11 @@ static const ClassRegistrar s_factory("slur", SLUR); Slur::Slur() : ControlElement(SLUR, "slur-") , TimeSpanningInterface() - , AttColor() , AttCurvature() , AttLayerIdent() , AttLineRendBase() { this->RegisterInterface(TimeSpanningInterface::GetAttClasses(), TimeSpanningInterface::IsInterface()); - this->RegisterAttClass(ATT_COLOR); this->RegisterAttClass(ATT_CURVATURE); this->RegisterAttClass(ATT_LAYERIDENT); this->RegisterAttClass(ATT_LINERENDBASE); @@ -60,13 +58,11 @@ Slur::Slur() Slur::Slur(ClassId classId) : ControlElement(classId, "slur-") , TimeSpanningInterface() - , AttColor() , AttCurvature() , AttLayerIdent() , AttLineRendBase() { this->RegisterInterface(TimeSpanningInterface::GetAttClasses(), TimeSpanningInterface::IsInterface()); - this->RegisterAttClass(ATT_COLOR); this->RegisterAttClass(ATT_CURVATURE); this->RegisterAttClass(ATT_LAYERIDENT); this->RegisterAttClass(ATT_LINERENDBASE); @@ -77,13 +73,11 @@ Slur::Slur(ClassId classId) Slur::Slur(ClassId classId, const std::string &classIdStr) : ControlElement(classId, classIdStr) , TimeSpanningInterface() - , AttColor() , AttCurvature() , AttLayerIdent() , AttLineRendBase() { this->RegisterInterface(TimeSpanningInterface::GetAttClasses(), TimeSpanningInterface::IsInterface()); - this->RegisterAttClass(ATT_COLOR); this->RegisterAttClass(ATT_CURVATURE); this->RegisterAttClass(ATT_LAYERIDENT); this->RegisterAttClass(ATT_LINERENDBASE); @@ -97,7 +91,6 @@ void Slur::Reset() { ControlElement::Reset(); TimeSpanningInterface::Reset(); - this->ResetColor(); this->ResetCurvature(); this->ResetLayerIdent(); this->ResetLineRendBase(); diff --git a/src/tie.cpp b/src/tie.cpp index d66e942061..8fc6aa1aff 100644 --- a/src/tie.cpp +++ b/src/tie.cpp @@ -34,10 +34,9 @@ namespace vrv { static const ClassRegistrar s_factory("tie", TIE); -Tie::Tie() : ControlElement(TIE, "tie-"), TimeSpanningInterface(), AttColor(), AttCurvature(), AttLineRendBase() +Tie::Tie() : ControlElement(TIE, "tie-"), TimeSpanningInterface(), AttCurvature(), AttLineRendBase() { this->RegisterInterface(TimeSpanningInterface::GetAttClasses(), TimeSpanningInterface::IsInterface()); - this->RegisterAttClass(ATT_COLOR); this->RegisterAttClass(ATT_CURVATURE); this->RegisterAttClass(ATT_LINERENDBASE); @@ -45,10 +44,9 @@ Tie::Tie() : ControlElement(TIE, "tie-"), TimeSpanningInterface(), AttColor(), A } Tie::Tie(ClassId classId) - : ControlElement(classId, "tie-"), TimeSpanningInterface(), AttColor(), AttCurvature(), AttLineRendBase() + : ControlElement(classId, "tie-"), TimeSpanningInterface(), AttCurvature(), AttLineRendBase() { this->RegisterInterface(TimeSpanningInterface::GetAttClasses(), TimeSpanningInterface::IsInterface()); - this->RegisterAttClass(ATT_COLOR); this->RegisterAttClass(ATT_CURVATURE); this->RegisterAttClass(ATT_LINERENDBASE); @@ -56,10 +54,9 @@ Tie::Tie(ClassId classId) } Tie::Tie(ClassId classId, const std::string &classIdStr) - : ControlElement(classId, classIdStr), TimeSpanningInterface(), AttColor(), AttCurvature(), AttLineRendBase() + : ControlElement(classId, classIdStr), TimeSpanningInterface(), AttCurvature(), AttLineRendBase() { this->RegisterInterface(TimeSpanningInterface::GetAttClasses(), TimeSpanningInterface::IsInterface()); - this->RegisterAttClass(ATT_COLOR); this->RegisterAttClass(ATT_CURVATURE); this->RegisterAttClass(ATT_LINERENDBASE); @@ -72,7 +69,6 @@ void Tie::Reset() { ControlElement::Reset(); TimeSpanningInterface::Reset(); - this->ResetColor(); this->ResetCurvature(); this->ResetLineRendBase(); } diff --git a/src/trill.cpp b/src/trill.cpp index 8d6b762ff3..418bb1cde6 100644 --- a/src/trill.cpp +++ b/src/trill.cpp @@ -29,7 +29,6 @@ static const ClassRegistrar s_factory("trill", TRILL); Trill::Trill() : ControlElement(TRILL, "trill-") , TimeSpanningInterface() - , AttColor() , AttExtender() , AttExtSymAuth() , AttExtSymNames() @@ -39,7 +38,6 @@ Trill::Trill() , AttPlacementRelStaff() { this->RegisterInterface(TimeSpanningInterface::GetAttClasses(), TimeSpanningInterface::IsInterface()); - this->RegisterAttClass(ATT_COLOR); this->RegisterAttClass(ATT_EXTENDER); this->RegisterAttClass(ATT_EXTSYMAUTH); this->RegisterAttClass(ATT_EXTSYMNAMES); @@ -57,7 +55,6 @@ void Trill::Reset() { ControlElement::Reset(); TimeSpanningInterface::Reset(); - this->ResetColor(); this->ResetExtender(); this->ResetExtSymAuth(); this->ResetExtSymNames(); diff --git a/src/turn.cpp b/src/turn.cpp index 15797caa73..8c6c1b3e2e 100644 --- a/src/turn.cpp +++ b/src/turn.cpp @@ -31,7 +31,6 @@ static const ClassRegistrar s_factory("turn", TURN); Turn::Turn() : ControlElement(TURN, "turn-") , TimePointInterface() - , AttColor() , AttExtSymAuth() , AttExtSymNames() , AttOrnamentAccid() @@ -39,7 +38,6 @@ Turn::Turn() , AttTurnLog() { this->RegisterInterface(TimePointInterface::GetAttClasses(), TimePointInterface::IsInterface()); - this->RegisterAttClass(ATT_COLOR); this->RegisterAttClass(ATT_EXTSYMAUTH); this->RegisterAttClass(ATT_EXTSYMNAMES); this->RegisterAttClass(ATT_ORNAMENTACCID); @@ -55,7 +53,6 @@ void Turn::Reset() { ControlElement::Reset(); TimePointInterface::Reset(); - this->ResetColor(); this->ResetExtSymAuth(); this->ResetExtSymNames(); this->ResetOrnamentAccid(); From 26cb9d0211fe07c8d9a0e698611bcae0effa2142 Mon Sep 17 00:00:00 2001 From: rettinghaus Date: Sat, 14 Dec 2024 13:36:50 +0100 Subject: [PATCH 5/8] adjust reading/writing of color attribute --- src/iomei.cpp | 43 ++----------------------------------------- 1 file changed, 2 insertions(+), 41 deletions(-) diff --git a/src/iomei.cpp b/src/iomei.cpp index e71c091392..a6a4fe2b25 100644 --- a/src/iomei.cpp +++ b/src/iomei.cpp @@ -1951,6 +1951,7 @@ void MEIOutput::WriteControlElement(pugi::xml_node currentNode, ControlElement * this->WriteXmlId(currentNode, controlElement); this->WriteAltSymInterface(currentNode, controlElement); this->WriteLinkingInterface(currentNode, controlElement); + controlElement->WriteColor(currentNode); controlElement->WriteLabelled(currentNode); controlElement->WriteTyped(currentNode); } @@ -1972,7 +1973,6 @@ void MEIOutput::WriteArpeg(pugi::xml_node currentNode, Arpeg *arpeg) this->WriteTimePointInterface(currentNode, arpeg); arpeg->WriteArpegLog(currentNode); arpeg->WriteArpegVis(currentNode); - arpeg->WriteColor(currentNode); arpeg->WriteEnclosingChars(currentNode); } @@ -1985,7 +1985,6 @@ void MEIOutput::WriteBeamSpan(pugi::xml_node currentNode, BeamSpan *beamSpan) WriteTimeSpanningInterface(currentNode, beamSpan); beamSpan->WriteBeamedWith(currentNode); beamSpan->WriteBeamRend(currentNode); - beamSpan->WriteColor(currentNode); } void MEIOutput::WriteBracketSpan(pugi::xml_node currentNode, BracketSpan *bracketSpan) @@ -1995,7 +1994,6 @@ void MEIOutput::WriteBracketSpan(pugi::xml_node currentNode, BracketSpan *bracke this->WriteControlElement(currentNode, bracketSpan); this->WriteTimeSpanningInterface(currentNode, bracketSpan); bracketSpan->WriteBracketSpanLog(currentNode); - bracketSpan->WriteColor(currentNode); bracketSpan->WriteLineRend(currentNode); bracketSpan->WriteLineRendBase(currentNode); } @@ -2006,7 +2004,6 @@ void MEIOutput::WriteBreath(pugi::xml_node currentNode, Breath *breath) this->WriteControlElement(currentNode, breath); this->WriteTimePointInterface(currentNode, breath); - breath->WriteColor(currentNode); breath->WritePlacementRelStaff(currentNode); } @@ -2016,7 +2013,6 @@ void MEIOutput::WriteCaesura(pugi::xml_node currentNode, Caesura *caesura) this->WriteControlElement(currentNode, caesura); this->WriteTimePointInterface(currentNode, caesura); - caesura->WriteColor(currentNode); caesura->WriteExtSymAuth(currentNode); caesura->WriteExtSymNames(currentNode); caesura->WritePlacementRelStaff(currentNode); @@ -2056,7 +2052,6 @@ void MEIOutput::WriteFermata(pugi::xml_node currentNode, Fermata *fermata) this->WriteControlElement(currentNode, fermata); this->WriteTimePointInterface(currentNode, fermata); - fermata->WriteColor(currentNode); fermata->WriteEnclosingChars(currentNode); fermata->WriteExtSymAuth(currentNode); fermata->WriteExtSymNames(currentNode); @@ -2080,7 +2075,6 @@ void MEIOutput::WriteGliss(pugi::xml_node currentNode, Gliss *gliss) this->WriteControlElement(currentNode, gliss); this->WriteTimeSpanningInterface(currentNode, gliss); - gliss->WriteColor(currentNode); gliss->WriteLineRend(currentNode); gliss->WriteLineRendBase(currentNode); gliss->WriteNNumberLike(currentNode); @@ -2092,7 +2086,6 @@ void MEIOutput::WriteHairpin(pugi::xml_node currentNode, Hairpin *hairpin) this->WriteControlElement(currentNode, hairpin); this->WriteTimeSpanningInterface(currentNode, hairpin); - hairpin->WriteColor(currentNode); hairpin->WriteHairpinLog(currentNode); hairpin->WriteHairpinVis(currentNode); hairpin->WriteLineRendBase(currentNode); @@ -2117,7 +2110,6 @@ void MEIOutput::WriteLv(pugi::xml_node currentNode, Lv *lv) this->WriteControlElement(currentNode, lv); this->WriteTimeSpanningInterface(currentNode, lv); - lv->WriteColor(currentNode); lv->WriteCurvature(currentNode); lv->WriteLineRendBase(currentNode); } @@ -2129,7 +2121,6 @@ void MEIOutput::WriteMNum(pugi::xml_node currentNode, MNum *mNum) this->WriteControlElement(currentNode, mNum); this->WriteTextDirInterface(currentNode, mNum); this->WriteTimePointInterface(currentNode, mNum); - mNum->WriteColor(currentNode); mNum->WriteLang(currentNode); mNum->WriteTypography(currentNode); } @@ -2140,7 +2131,6 @@ void MEIOutput::WriteMordent(pugi::xml_node currentNode, Mordent *mordent) this->WriteControlElement(currentNode, mordent); this->WriteTimePointInterface(currentNode, mordent); - mordent->WriteColor(currentNode); mordent->WriteExtSymAuth(currentNode); mordent->WriteExtSymNames(currentNode); mordent->WriteOrnamentAccid(currentNode); @@ -2154,7 +2144,6 @@ void MEIOutput::WriteOctave(pugi::xml_node currentNode, Octave *octave) this->WriteControlElement(currentNode, octave); this->WriteTimeSpanningInterface(currentNode, octave); - octave->WriteColor(currentNode); octave->WriteExtender(currentNode); octave->WriteLineRend(currentNode); octave->WriteLineRendBase(currentNode); @@ -2169,7 +2158,6 @@ void MEIOutput::WriteOrnam(pugi::xml_node currentNode, Ornam *ornam) this->WriteControlElement(currentNode, ornam); this->WriteTextDirInterface(currentNode, ornam); this->WriteTimePointInterface(currentNode, ornam); - ornam->WriteColor(currentNode); ornam->WriteOrnamentAccid(currentNode); } @@ -2179,7 +2167,6 @@ void MEIOutput::WritePedal(pugi::xml_node currentNode, Pedal *pedal) this->WriteControlElement(currentNode, pedal); this->WriteTimeSpanningInterface(currentNode, pedal); - pedal->WriteColor(currentNode); pedal->WriteExtSymAuth(currentNode); pedal->WriteExtSymNames(currentNode); pedal->WritePedalLog(currentNode); @@ -2210,7 +2197,6 @@ void MEIOutput::WriteReh(pugi::xml_node currentNode, Reh *reh) this->WriteControlElement(currentNode, reh); this->WriteTextDirInterface(currentNode, reh); this->WriteTimePointInterface(currentNode, reh); - reh->WriteColor(currentNode); reh->WriteLang(currentNode); reh->WriteVerticalGroup(currentNode); } @@ -2222,7 +2208,6 @@ void MEIOutput::WriteRepeatMark(pugi::xml_node currentNode, RepeatMark *repeatMa this->WriteControlElement(currentNode, repeatMark); this->WriteTextDirInterface(currentNode, repeatMark); this->WriteTimePointInterface(currentNode, repeatMark); - repeatMark->WriteColor(currentNode); repeatMark->WriteExtSymAuth(currentNode); repeatMark->WriteExtSymNames(currentNode); repeatMark->WriteRepeatMarkLog(currentNode); @@ -2234,7 +2219,6 @@ void MEIOutput::WriteSlur(pugi::xml_node currentNode, Slur *slur) this->WriteControlElement(currentNode, slur); this->WriteTimeSpanningInterface(currentNode, slur); - slur->WriteColor(currentNode); slur->WriteCurvature(currentNode); slur->WriteLayerIdent(currentNode); slur->WriteLineRendBase(currentNode); @@ -2276,7 +2260,6 @@ void MEIOutput::WriteTie(pugi::xml_node currentNode, Tie *tie) this->WriteControlElement(currentNode, tie); this->WriteTimeSpanningInterface(currentNode, tie); - tie->WriteColor(currentNode); tie->WriteCurvature(currentNode); tie->WriteLineRendBase(currentNode); } @@ -2287,7 +2270,6 @@ void MEIOutput::WriteTrill(pugi::xml_node currentNode, Trill *trill) this->WriteControlElement(currentNode, trill); this->WriteTimeSpanningInterface(currentNode, trill); - trill->WriteColor(currentNode); trill->WriteExtender(currentNode); trill->WriteExtSymAuth(currentNode); trill->WriteExtSymNames(currentNode); @@ -2303,7 +2285,6 @@ void MEIOutput::WriteTurn(pugi::xml_node currentNode, Turn *turn) this->WriteControlElement(currentNode, turn); this->WriteTimePointInterface(currentNode, turn); - turn->WriteColor(currentNode); turn->WriteExtSymAuth(currentNode); turn->WriteExtSymNames(currentNode); turn->WriteOrnamentAccid(currentNode); @@ -5638,6 +5619,7 @@ bool MEIInput::ReadControlElement(pugi::xml_node element, ControlElement *object this->SetMeiID(element, object); this->ReadAltSymInterface(element, object); this->ReadLinkingInterface(element, object); + object->ReadColor(element); object->ReadLabelled(element); object->ReadTyped(element); @@ -5665,7 +5647,6 @@ bool MEIInput::ReadArpeg(Object *parent, pugi::xml_node arpeg) this->ReadTimePointInterface(arpeg, vrvArpeg); vrvArpeg->ReadArpegLog(arpeg); vrvArpeg->ReadArpegVis(arpeg); - vrvArpeg->ReadColor(arpeg); vrvArpeg->ReadEnclosingChars(arpeg); parent->AddChild(vrvArpeg); @@ -5682,7 +5663,6 @@ bool MEIInput::ReadBeamSpan(Object *parent, pugi::xml_node beamSpan) this->ReadTimeSpanningInterface(beamSpan, vrvBeamSpan); vrvBeamSpan->ReadBeamedWith(beamSpan); vrvBeamSpan->ReadBeamRend(beamSpan); - vrvBeamSpan->ReadColor(beamSpan); parent->AddChild(vrvBeamSpan); this->ReadUnsupportedAttr(beamSpan, vrvBeamSpan); @@ -5696,7 +5676,6 @@ bool MEIInput::ReadBracketSpan(Object *parent, pugi::xml_node bracketSpan) this->ReadTimeSpanningInterface(bracketSpan, vrvBracketSpan); vrvBracketSpan->ReadBracketSpanLog(bracketSpan); - vrvBracketSpan->ReadColor(bracketSpan); vrvBracketSpan->ReadLineRend(bracketSpan); vrvBracketSpan->ReadLineRendBase(bracketSpan); @@ -5711,7 +5690,6 @@ bool MEIInput::ReadBreath(Object *parent, pugi::xml_node breath) this->ReadControlElement(breath, vrvBreath); this->ReadTimePointInterface(breath, vrvBreath); - vrvBreath->ReadColor(breath); vrvBreath->ReadPlacementRelStaff(breath); parent->AddChild(vrvBreath); @@ -5725,7 +5703,6 @@ bool MEIInput::ReadCaesura(Object *parent, pugi::xml_node caesura) this->ReadControlElement(caesura, vrvCaesura); this->ReadTimePointInterface(caesura, vrvCaesura); - vrvCaesura->ReadColor(caesura); vrvCaesura->ReadExtSymAuth(caesura); vrvCaesura->ReadExtSymNames(caesura); vrvCaesura->ReadPlacementRelStaff(caesura); @@ -5777,7 +5754,6 @@ bool MEIInput::ReadFermata(Object *parent, pugi::xml_node fermata) this->ReadControlElement(fermata, vrvFermata); this->ReadTimePointInterface(fermata, vrvFermata); - vrvFermata->ReadColor(fermata); vrvFermata->ReadEnclosingChars(fermata); vrvFermata->ReadExtSymAuth(fermata); vrvFermata->ReadExtSymNames(fermata); @@ -5809,7 +5785,6 @@ bool MEIInput::ReadGliss(Object *parent, pugi::xml_node gliss) this->ReadControlElement(gliss, vrvGliss); this->ReadTimeSpanningInterface(gliss, vrvGliss); - vrvGliss->ReadColor(gliss); vrvGliss->ReadLineRend(gliss); vrvGliss->ReadLineRendBase(gliss); vrvGliss->ReadNNumberLike(gliss); @@ -5825,7 +5800,6 @@ bool MEIInput::ReadHairpin(Object *parent, pugi::xml_node hairpin) this->ReadControlElement(hairpin, vrvHairpin); this->ReadTimeSpanningInterface(hairpin, vrvHairpin); - vrvHairpin->ReadColor(hairpin); vrvHairpin->ReadHairpinLog(hairpin); vrvHairpin->ReadHairpinVis(hairpin); vrvHairpin->ReadLineRendBase(hairpin); @@ -5858,7 +5832,6 @@ bool MEIInput::ReadLv(Object *parent, pugi::xml_node lv) this->ReadControlElement(lv, vrvLv); this->ReadTimeSpanningInterface(lv, vrvLv); - vrvLv->ReadColor(lv); vrvLv->ReadCurvature(lv); vrvLv->ReadLineRendBase(lv); @@ -5874,7 +5847,6 @@ bool MEIInput::ReadMNum(Object *parent, pugi::xml_node mNum) this->ReadTextDirInterface(mNum, vrvMNum); this->ReadTimePointInterface(mNum, vrvMNum); - vrvMNum->ReadColor(mNum); vrvMNum->ReadLang(mNum); vrvMNum->ReadTypography(mNum); @@ -5892,7 +5864,6 @@ bool MEIInput::ReadMordent(Object *parent, pugi::xml_node mordent) } this->ReadTimePointInterface(mordent, vrvMordent); - vrvMordent->ReadColor(mordent); vrvMordent->ReadExtSymAuth(mordent); vrvMordent->ReadExtSymNames(mordent); vrvMordent->ReadOrnamentAccid(mordent); @@ -5910,7 +5881,6 @@ bool MEIInput::ReadOctave(Object *parent, pugi::xml_node octave) this->ReadControlElement(octave, vrvOctave); this->ReadTimeSpanningInterface(octave, vrvOctave); - vrvOctave->ReadColor(octave); vrvOctave->ReadExtender(octave); vrvOctave->ReadLineRend(octave); vrvOctave->ReadLineRendBase(octave); @@ -5929,7 +5899,6 @@ bool MEIInput::ReadOrnam(Object *parent, pugi::xml_node ornam) this->ReadTextDirInterface(ornam, vrvOrnam); this->ReadTimePointInterface(ornam, vrvOrnam); - vrvOrnam->ReadColor(ornam); vrvOrnam->ReadOrnamentAccid(ornam); parent->AddChild(vrvOrnam); @@ -5943,7 +5912,6 @@ bool MEIInput::ReadPedal(Object *parent, pugi::xml_node pedal) this->ReadControlElement(pedal, vrvPedal); this->ReadTimeSpanningInterface(pedal, vrvPedal); - vrvPedal->ReadColor(pedal); vrvPedal->ReadExtSymAuth(pedal); vrvPedal->ReadExtSymNames(pedal); vrvPedal->ReadPedalLog(pedal); @@ -5962,7 +5930,6 @@ bool MEIInput::ReadPhrase(Object *parent, pugi::xml_node phrase) this->ReadControlElement(phrase, vrvPhrase); this->ReadTimeSpanningInterface(phrase, vrvPhrase); - vrvPhrase->ReadColor(phrase); vrvPhrase->ReadCurvature(phrase); vrvPhrase->ReadLayerIdent(phrase); vrvPhrase->ReadLineRendBase(phrase); @@ -5991,7 +5958,6 @@ bool MEIInput::ReadReh(Object *parent, pugi::xml_node reh) this->ReadTextDirInterface(reh, vrvReh); this->ReadTimePointInterface(reh, vrvReh); - vrvReh->ReadColor(reh); vrvReh->ReadLang(reh); vrvReh->ReadVerticalGroup(reh); @@ -6007,7 +5973,6 @@ bool MEIInput::ReadRepeatMark(Object *parent, pugi::xml_node repeatMark) this->ReadTextDirInterface(repeatMark, vrvRepeatMark); this->ReadTimePointInterface(repeatMark, vrvRepeatMark); - vrvRepeatMark->ReadColor(repeatMark); vrvRepeatMark->ReadExtSymAuth(repeatMark); vrvRepeatMark->ReadExtSymNames(repeatMark); vrvRepeatMark->ReadRepeatMarkLog(repeatMark); @@ -6023,7 +5988,6 @@ bool MEIInput::ReadSlur(Object *parent, pugi::xml_node slur) this->ReadControlElement(slur, vrvSlur); this->ReadTimeSpanningInterface(slur, vrvSlur); - vrvSlur->ReadColor(slur); vrvSlur->ReadCurvature(slur); vrvSlur->ReadLayerIdent(slur); vrvSlur->ReadLineRendBase(slur); @@ -6056,7 +6020,6 @@ bool MEIInput::ReadTie(Object *parent, pugi::xml_node tie) this->ReadControlElement(tie, vrvTie); this->ReadTimeSpanningInterface(tie, vrvTie); - vrvTie->ReadColor(tie); vrvTie->ReadCurvature(tie); vrvTie->ReadLineRendBase(tie); @@ -6071,7 +6034,6 @@ bool MEIInput::ReadTrill(Object *parent, pugi::xml_node trill) this->ReadControlElement(trill, vrvTrill); this->ReadTimeSpanningInterface(trill, vrvTrill); - vrvTrill->ReadColor(trill); vrvTrill->ReadExtender(trill); vrvTrill->ReadExtSymAuth(trill); vrvTrill->ReadExtSymNames(trill); @@ -6095,7 +6057,6 @@ bool MEIInput::ReadTurn(Object *parent, pugi::xml_node turn) } this->ReadTimePointInterface(turn, vrvTurn); - vrvTurn->ReadColor(turn); vrvTurn->ReadExtSymAuth(turn); vrvTurn->ReadExtSymNames(turn); vrvTurn->ReadOrnamentAccid(turn); From cee362510d7ab4468d94ac15d593435c6ae181a0 Mon Sep 17 00:00:00 2001 From: rettinghaus Date: Sat, 14 Dec 2024 13:44:47 +0100 Subject: [PATCH 6/8] formatting --- include/vrv/tie.h | 5 +---- src/arpeg.cpp | 3 +-- src/controlelement.cpp | 7 ++++++- src/gliss.cpp | 6 +----- src/ornam.cpp | 6 +----- src/reh.cpp | 3 +-- src/slur.cpp | 18 +++--------------- src/tie.cpp | 3 +-- 8 files changed, 15 insertions(+), 36 deletions(-) diff --git a/include/vrv/tie.h b/include/vrv/tie.h index db3f258f94..8b6686f2cd 100644 --- a/include/vrv/tie.h +++ b/include/vrv/tie.h @@ -24,10 +24,7 @@ class Note; /** * This class models the MEI element. */ -class Tie : public ControlElement, - public TimeSpanningInterface, - public AttCurvature, - public AttLineRendBase { +class Tie : public ControlElement, public TimeSpanningInterface, public AttCurvature, public AttLineRendBase { public: /** * @name Constructors, destructors, and other standard methods diff --git a/src/arpeg.cpp b/src/arpeg.cpp index 28f38059b7..aef7ee75ac 100644 --- a/src/arpeg.cpp +++ b/src/arpeg.cpp @@ -29,8 +29,7 @@ namespace vrv { static const ClassRegistrar s_factory("arpeg", ARPEG); -Arpeg::Arpeg() - : ControlElement(ARPEG, "arpeg-"), PlistInterface(), TimePointInterface(), AttArpegLog(), AttArpegVis() +Arpeg::Arpeg() : ControlElement(ARPEG, "arpeg-"), PlistInterface(), TimePointInterface(), AttArpegLog(), AttArpegVis() { this->RegisterInterface(PlistInterface::GetAttClasses(), PlistInterface::IsInterface()); this->RegisterInterface(TimePointInterface::GetAttClasses(), TimePointInterface::IsInterface()); diff --git a/src/controlelement.cpp b/src/controlelement.cpp index 82eaf2f95a..7024457fdf 100644 --- a/src/controlelement.cpp +++ b/src/controlelement.cpp @@ -28,7 +28,12 @@ namespace vrv { //---------------------------------------------------------------------------- ControlElement::ControlElement() - : FloatingObject(CONTROL_ELEMENT, "ce"), AltSymInterface(), LinkingInterface(), AttColor(), AttLabelled(), AttTyped() + : FloatingObject(CONTROL_ELEMENT, "ce") + , AltSymInterface() + , LinkingInterface() + , AttColor() + , AttLabelled() + , AttTyped() { this->RegisterInterface(AltSymInterface::GetAttClasses(), AltSymInterface::IsInterface()); this->RegisterInterface(LinkingInterface::GetAttClasses(), LinkingInterface::IsInterface()); diff --git a/src/gliss.cpp b/src/gliss.cpp index 21050b3b8f..e2d9c20ade 100644 --- a/src/gliss.cpp +++ b/src/gliss.cpp @@ -27,11 +27,7 @@ namespace vrv { static const ClassRegistrar s_factory("gliss", GLISS); Gliss::Gliss() - : ControlElement(GLISS, "gliss-") - , TimeSpanningInterface() - , AttLineRend() - , AttLineRendBase() - , AttNNumberLike() + : ControlElement(GLISS, "gliss-"), TimeSpanningInterface(), AttLineRend(), AttLineRendBase(), AttNNumberLike() { this->RegisterInterface(TimeSpanningInterface::GetAttClasses(), TimeSpanningInterface::IsInterface()); this->RegisterAttClass(ATT_LINEREND); diff --git a/src/ornam.cpp b/src/ornam.cpp index 95b35ee96f..d53f114ce5 100644 --- a/src/ornam.cpp +++ b/src/ornam.cpp @@ -30,11 +30,7 @@ namespace vrv { static const ClassRegistrar s_factory("ornam", ORNAM); Ornam::Ornam() - : ControlElement(ORNAM, "ornam-") - , TextListInterface() - , TextDirInterface() - , TimePointInterface() - , AttOrnamentAccid() + : ControlElement(ORNAM, "ornam-"), TextListInterface(), TextDirInterface(), TimePointInterface(), AttOrnamentAccid() { this->RegisterInterface(TextDirInterface::GetAttClasses(), TextDirInterface::IsInterface()); this->RegisterInterface(TimePointInterface::GetAttClasses(), TimePointInterface::IsInterface()); diff --git a/src/reh.cpp b/src/reh.cpp index 116cf3fc4c..6627775701 100644 --- a/src/reh.cpp +++ b/src/reh.cpp @@ -28,8 +28,7 @@ namespace vrv { static const ClassRegistrar s_factory("reh", REH); -Reh::Reh() - : ControlElement(REH, "reh-"), TextDirInterface(), TimePointInterface(), AttLang(), AttVerticalGroup() +Reh::Reh() : ControlElement(REH, "reh-"), TextDirInterface(), TimePointInterface(), AttLang(), AttVerticalGroup() { this->RegisterInterface(TextDirInterface::GetAttClasses(), TextDirInterface::IsInterface()); this->RegisterInterface(TimePointInterface::GetAttClasses(), TimePointInterface::IsInterface()); diff --git a/src/slur.cpp b/src/slur.cpp index fda215b4bf..830e11835e 100644 --- a/src/slur.cpp +++ b/src/slur.cpp @@ -41,11 +41,7 @@ namespace vrv { static const ClassRegistrar s_factory("slur", SLUR); Slur::Slur() - : ControlElement(SLUR, "slur-") - , TimeSpanningInterface() - , AttCurvature() - , AttLayerIdent() - , AttLineRendBase() + : ControlElement(SLUR, "slur-"), TimeSpanningInterface(), AttCurvature(), AttLayerIdent(), AttLineRendBase() { this->RegisterInterface(TimeSpanningInterface::GetAttClasses(), TimeSpanningInterface::IsInterface()); this->RegisterAttClass(ATT_CURVATURE); @@ -56,11 +52,7 @@ Slur::Slur() } Slur::Slur(ClassId classId) - : ControlElement(classId, "slur-") - , TimeSpanningInterface() - , AttCurvature() - , AttLayerIdent() - , AttLineRendBase() + : ControlElement(classId, "slur-"), TimeSpanningInterface(), AttCurvature(), AttLayerIdent(), AttLineRendBase() { this->RegisterInterface(TimeSpanningInterface::GetAttClasses(), TimeSpanningInterface::IsInterface()); this->RegisterAttClass(ATT_CURVATURE); @@ -71,11 +63,7 @@ Slur::Slur(ClassId classId) } Slur::Slur(ClassId classId, const std::string &classIdStr) - : ControlElement(classId, classIdStr) - , TimeSpanningInterface() - , AttCurvature() - , AttLayerIdent() - , AttLineRendBase() + : ControlElement(classId, classIdStr), TimeSpanningInterface(), AttCurvature(), AttLayerIdent(), AttLineRendBase() { this->RegisterInterface(TimeSpanningInterface::GetAttClasses(), TimeSpanningInterface::IsInterface()); this->RegisterAttClass(ATT_CURVATURE); diff --git a/src/tie.cpp b/src/tie.cpp index 8fc6aa1aff..3469b28506 100644 --- a/src/tie.cpp +++ b/src/tie.cpp @@ -43,8 +43,7 @@ Tie::Tie() : ControlElement(TIE, "tie-"), TimeSpanningInterface(), AttCurvature( this->Reset(); } -Tie::Tie(ClassId classId) - : ControlElement(classId, "tie-"), TimeSpanningInterface(), AttCurvature(), AttLineRendBase() +Tie::Tie(ClassId classId) : ControlElement(classId, "tie-"), TimeSpanningInterface(), AttCurvature(), AttLineRendBase() { this->RegisterInterface(TimeSpanningInterface::GetAttClasses(), TimeSpanningInterface::IsInterface()); this->RegisterAttClass(ATT_CURVATURE); From c5063f5075446b7c456ff7ddd24b7ab884e7c632 Mon Sep 17 00:00:00 2001 From: Klaus Rettinghaus Date: Mon, 16 Dec 2024 11:25:44 +0100 Subject: [PATCH 7/8] Read all clef changes --- src/iomusxml.cpp | 3 +-- 1 file changed, 1 insertion(+), 2 deletions(-) diff --git a/src/iomusxml.cpp b/src/iomusxml.cpp index 86cb54613d..57f4c2510f 100644 --- a/src/iomusxml.cpp +++ b/src/iomusxml.cpp @@ -1796,8 +1796,7 @@ void MusicXmlInput::ReadMusicXmlAttributes( } // read clef changes as MEI clef and add them to the stack - pugi::xml_node clef = node.child("clef"); - if (clef) { + for (pugi::xml_node clef : node.children("clef")) { // check if we have a staff number short int staffNum = clef.attribute("number").as_int(); staffNum = (staffNum < 1) ? 1 : staffNum; From fdae6f68ea7d3a0ae34fda57cd21444a905876b1 Mon Sep 17 00:00:00 2001 From: Paul Overell Date: Mon, 16 Dec 2024 12:11:32 +0000 Subject: [PATCH 8/8] rexex performance --- src/iohumdrum.cpp | 8 ++++---- src/iomusxml.cpp | 4 ++-- src/iopae.cpp | 2 +- src/vrv.cpp | 10 +++++----- 4 files changed, 12 insertions(+), 12 deletions(-) diff --git a/src/iohumdrum.cpp b/src/iohumdrum.cpp index 5e9e6b5b55..e4a02f50c3 100644 --- a/src/iohumdrum.cpp +++ b/src/iohumdrum.cpp @@ -8443,13 +8443,13 @@ void HumdrumInput::setInstrumentAbbreviation(ELEMENT *element, const std::string std::string name8 = name; // Substitute b and "-flat" for Unicode flat symbol: - std::regex exp1("\\b([ABDEFG])b\\b"); - std::regex exp2("\\b([A-Ga-g])-flat\\b"); + static const std::regex exp1("\\b([ABDEFG])b\\b"); + static const std::regex exp2("\\b([A-Ga-g])-flat\\b"); name8 = std::regex_replace(name8, exp1, "$1\xe2\x99\xad"); name8 = std::regex_replace(name8, exp2, "$1\xe2\x99\xad"); // Substitute # and "-sharp" for Unicode sharp symbol: - std::regex exp3("\\b([A-G])#\\b"); - std::regex exp4("\\b([A-Ga-g])-sharp\\b"); + static const std::regex exp3("\\b([A-G])#\\b"); + static const std::regex exp4("\\b([A-Ga-g])-sharp\\b"); name8 = std::regex_replace(name8, exp3, "$1\xe2\x99\xaf"); name8 = std::regex_replace(name8, exp4, "$1\xe2\x99\xaf"); diff --git a/src/iomusxml.cpp b/src/iomusxml.cpp index 86cb54613d..ca56cf5c08 100644 --- a/src/iomusxml.cpp +++ b/src/iomusxml.cpp @@ -3051,9 +3051,9 @@ void MusicXmlInput::ReadMusicXmlNote( std::string textStr = childNode.text().as_string(); // convert verse numbers to labels - std::regex labelSearch("^([^[:alpha:]]*\\d[^[:alpha:]]*)$"); + static const std::regex labelSearch("^([^[:alpha:]]*\\d[^[:alpha:]]*)$"); std::smatch labelSearchMatches; - std::regex labelPrefixSearch("^([^[:alpha:]]*\\d[^[:alpha:]]*)[\\s\\u00A0]+"); + static const std::regex labelPrefixSearch("^([^[:alpha:]]*\\d[^[:alpha:]]*)[\\s\\u00A0]+"); std::smatch labelPrefixSearchMatches; if (!textStr.empty() && std::regex_search(textStr, labelSearchMatches, labelSearch) && labelSearchMatches.ready() && childNode.next_sibling("elision")) { diff --git a/src/iopae.cpp b/src/iopae.cpp index 75431ad881..d5dcfc412d 100644 --- a/src/iopae.cpp +++ b/src/iopae.cpp @@ -1249,7 +1249,7 @@ int PAEInput::getTupletFermata(const char *incipit, pae::Note *note, int index) // std::regex_constants::ECMAScript is the default syntax, so optional. // Previously these were extended regex syntax, but this case // is the same in ECMAScript syntax. - std::regex exp("^([^)]*[ABCDEFG-][^)]*[ABCDEFG-][^)]*)", std::regex_constants::ECMAScript); + static const std::regex exp("^([^)]*[ABCDEFG-][^)]*[ABCDEFG-][^)]*)", std::regex_constants::ECMAScript); bool is_tuplet = regex_search(incipit + i, exp); if (is_tuplet) { diff --git a/src/vrv.cpp b/src/vrv.cpp index 2378a542dd..115fbf626f 100644 --- a/src/vrv.cpp +++ b/src/vrv.cpp @@ -235,20 +235,20 @@ bool AreEqual(double dFirstVal, double dSecondVal) bool IsValidInteger(const std::string &value) { // Accept "1" " 1 " "+1" "-1" "1." "1.0" - std::regex re(R"(^\s*[+-]?\d+\.?\d*\s*$)"); + static const std::regex re(R"(^\s*[+-]?\d+\.?\d*\s*$)"); return std::regex_match(value, re); } bool IsValidDouble(const std::string &value) { // Accept "1.0" " 1.0 " ".0" "1." "+1.0" "-1.0" - std::regex re(R"(^\s*[+-]?(?:\d+\.?\d*|\.\d+)\s*$)"); + static const std::regex re(R"(^\s*[+-]?(?:\d+\.?\d*|\.\d+)\s*$)"); return std::regex_match(value, re); } bool IsDigits(const std::string &value) { - std::regex re(R"(^\d+$)"); + static const std::regex re(R"(^\d+$)"); return std::regex_match(value, re); } @@ -432,8 +432,8 @@ std::string BaseEncodeInt(uint32_t value, uint8_t base) std::string FromCamelCase(const std::string &s) { - std::regex regExp1("(.)([A-Z][a-z]+)"); - std::regex regExp2("([a-z0-9])([A-Z])"); + static const std::regex regExp1("(.)([A-Z][a-z]+)"); + static const std::regex regExp2("([a-z0-9])([A-Z])"); std::string result = s; result = std::regex_replace(result, regExp1, "$1-$2");