 |
Verovio
Source code documentation
|
8 #ifndef __VRV_PREPAREDATAFUNCTOR_H__
9 #define __VRV_PREPAREDATAFUNCTOR_H__
16 class SystemMilestoneInterface;
45 FunctorCode VisitDiv(
Div *div)
override;
46 FunctorCode VisitChord(
Chord *chord)
override;
47 FunctorCode VisitFloatingObject(
FloatingObject *floatingObject)
override;
48 FunctorCode VisitKeySig(
KeySig *keySig)
override;
49 FunctorCode VisitRepeatMark(
RepeatMark *repeatMark)
override;
50 FunctorCode VisitScore(
Score *score)
override;
51 FunctorCode VisitTextLayoutElement(
TextLayoutElement *textLayoutElement)
override;
90 FunctorCode VisitLayerElement(
LayerElement *layerElement)
override;
129 FunctorCode VisitLayerElement(
LayerElement *layerElement)
override;
130 FunctorCode VisitLayerElementEnd(
LayerElement *layerElement)
override;
131 FunctorCode VisitMeasure(
Measure *measure)
override;
144 Staff *m_currentCrossStaff;
146 Layer *m_currentCrossLayer;
174 SymbolTable *GetSymbolTable()
const {
return m_symbolTable; }
180 FunctorCode VisitObject(Object *
object)
override;
191 SymbolTable *m_symbolTable;
219 const ListOfObjects &GetZonelessSyls()
const {
return m_zonelessSyls; }
224 Facsimile *GetFacsimile()
const {
return m_facsimile; }
230 FunctorCode VisitObject(Object *
object)
override;
241 Facsimile *m_facsimile;
243 ListOfObjects m_zonelessSyls;
272 const MapOfLinkingInterfaceIDPairs &GetNextIDPairs()
const {
return m_nextIDPairs; }
273 const MapOfLinkingInterfaceIDPairs &GetSameasIDPairs()
const {
return m_sameasIDPairs; }
274 const MapOfNoteIDPairs &GetStemSameasIDPairs()
const {
return m_stemSameasIDPairs; }
281 void InsertNextIDPair(
const std::string &nextID, LinkingInterface *interface);
282 void InsertSameasIDPair(
const std::string &sameasID, LinkingInterface *interface);
289 FunctorCode VisitObject(Object *
object)
override;
301 void ResolveStemSameas(Note *note);
307 MapOfLinkingInterfaceIDPairs m_nextIDPairs;
309 MapOfLinkingInterfaceIDPairs m_sameasIDPairs;
311 MapOfNoteIDPairs m_stemSameasIDPairs;
340 const ArrayOfPlistInterfaceIDPairs &GetInterfaceIDPairs()
const {
return m_interfaceIDPairs; }
341 void InsertInterfaceIDPair(
const std::string &elementID, PlistInterface *interface);
348 FunctorCode VisitObject(Object *
object)
override;
359 ArrayOfPlistInterfaceIDPairs m_interfaceIDPairs;
388 FunctorCode VisitLayerElement(
LayerElement *layerElement)
override;
389 FunctorCode VisitScore(
Score *score)
override;
390 FunctorCode VisitScoreDef(
ScoreDef *scoreDef)
override;
391 FunctorCode VisitStaffDef(
StaffDef *staffDef)
override;
402 data_DURATION m_durDefault;
404 std::map<int, data_DURATION> m_durDefaultForStaffN;
440 FunctorCode VisitF(
F *f)
override;
441 FunctorCode VisitFloatingObject(
FloatingObject *floatingObject)
override;
442 FunctorCode VisitLayerElement(
LayerElement *layerElement)
override;
443 FunctorCode VisitMeasureEnd(
Measure *measure)
override;
454 ListOfPointingInterClassIdPairs m_timePointingInterfaces;
485 const ListOfSpanningInterOwnerPairs &GetInterfaceOwnerPairs()
const {
return m_timeSpanningInterfaces; }
486 void InsertInterfaceOwnerPair(Object *owner, TimeSpanningInterface *interface);
493 FunctorCode VisitF(F *f)
override;
494 FunctorCode VisitFloatingObject(FloatingObject *floatingObject)
override;
495 FunctorCode VisitLayerElement(LayerElement *layerElement)
override;
496 FunctorCode VisitMeasure(Measure *measure)
override;
497 FunctorCode VisitMeasureEnd(Measure *measure)
override;
504 FunctorCode CallPseudoFunctor(Object *timeSpanningObject);
510 ListOfSpanningInterOwnerPairs m_timeSpanningInterfaces;
512 bool m_insideMeasure;
543 const ListOfSpanningInterClassIdPairs &GetInterfaceIDPairs()
const {
return m_timeSpanningInterfaces; }
544 void InsertInterfaceIDPair(ClassId classID, TimeSpanningInterface *interface);
545 void InsertObjectBeatPair(Object *
object,
const data_MEASUREBEAT &beat);
552 FunctorCode VisitDocEnd(Doc *doc)
override;
553 FunctorCode VisitF(F *f)
override;
554 FunctorCode VisitFloatingObject(FloatingObject *floatingObject)
override;
555 FunctorCode VisitMeasureEnd(Measure *measure)
override;
566 ListOfSpanningInterClassIdPairs m_timeSpanningInterfaces;
568 ListOfObjectBeatPairs m_tstamps;
597 FunctorCode VisitMeasureEnd(
Measure *measure)
override;
598 FunctorCode VisitPedal(
Pedal *pedal)
override;
609 std::list<Pedal *> m_pedalLines;
639 FunctorCode VisitDot(
Dot *dot)
override;
640 FunctorCode VisitLayerElement(
LayerElement *layerElement)
override;
641 FunctorCode VisitMeasureEnd(
Measure *measure)
override;
685 FunctorCode VisitChord(
Chord *chord)
override;
686 FunctorCode VisitDocEnd(
Doc *doc)
override;
687 FunctorCode VisitNote(
Note *note)
override;
688 FunctorCode VisitSyl(
Syl *syl)
override;
732 FunctorCode VisitChord(
Chord *chord)
override;
733 FunctorCode VisitNote(
Note *note)
override;
734 FunctorCode VisitRest(
Rest *rest)
override;
735 FunctorCode VisitTabDurSym(
TabDurSym *tabDurSym)
override;
736 FunctorCode VisitTuplet(
Tuplet *tuplet)
override;
745 Dots *ProcessDots(
Dots *dots,
Object *parent,
bool shouldExist)
const;
747 Flag *ProcessFlag(
Flag *flag,
Object *parent,
bool shouldExist)
const;
782 FunctorCode VisitLayer(
Layer *layer)
override;
783 FunctorCode VisitMRpt(
MRpt *mRpt)
override;
784 FunctorCode VisitStaff(
Staff *staff)
override;
797 data_BOOLEAN m_multiNumber;
826 const std::map<LayerElement *, Turn *> &GetDelayedTurns()
const {
return m_delayedTurns; }
837 FunctorCode VisitLayerElement(LayerElement *layerElement)
override;
838 FunctorCode VisitTurn(Turn *turn)
override;
849 LayerElement *m_previousElement;
851 Chord *m_currentChord;
855 std::map<LayerElement *, Turn *> m_delayedTurns;
884 const std::vector<SystemMilestoneInterface *> &GetStartMilestones()
const {
return m_startMilestones; }
885 void InsertStartMilestone(SystemMilestoneInterface *interface);
892 FunctorCode VisitEditorialElement(EditorialElement *editorialElement)
override;
893 FunctorCode VisitEnding(Ending *ending)
override;
894 FunctorCode VisitMeasure(Measure *measure)
override;
895 FunctorCode VisitSection(Section *section)
override;
896 FunctorCode VisitSystemMilestone(SystemMilestoneEnd *systemMilestoneEnd)
override;
907 Measure *m_lastMeasure;
909 Ending *m_currentEnding;
911 std::vector<SystemMilestoneInterface *> m_startMilestones;
941 FunctorCode VisitDir(
Dir *dir)
override;
942 FunctorCode VisitDynam(
Dynam *dynam)
override;
943 FunctorCode VisitEnding(
Ending *ending)
override;
944 FunctorCode VisitHairpin(
Hairpin *hairpin)
override;
945 FunctorCode VisitHarm(
Harm *harm)
override;
946 FunctorCode VisitMeasure(
Measure *measure)
override;
947 FunctorCode VisitMeasureEnd(
Measure *measure)
override;
948 FunctorCode VisitPedal(
Pedal *pedal)
override;
962 std::vector<Dynam *> m_dynams;
964 std::vector<Hairpin *> m_hairpins;
966 std::map<std::string, Harm *> m_harms;
997 const ArrayOfObjects &GetTimeSpanningElements()
const {
return m_timeSpanningElements; }
998 void InsertTimeSpanningElement(Object *element);
1005 FunctorCode VisitF(F *f)
override;
1006 FunctorCode VisitFloatingObject(FloatingObject *floatingObject)
override;
1007 FunctorCode VisitMeasureEnd(Measure *measure)
override;
1008 FunctorCode VisitStaff(Staff *staff)
override;
1009 FunctorCode VisitSyl(Syl *syl)
override;
1020 ArrayOfObjects m_timeSpanningElements;
1049 FunctorCode VisitReh(
Reh *reh)
override;
1089 FunctorCode VisitBeamSpan(
BeamSpan *beamSpan)
override;
1097 ArrayOfObjects GetBeamSpanElementList(
BeamSpan *beamSpan,
Layer *layer,
const Staff *staff)
const;
1107 #endif // __VRV_PREPAREDATAFUNCTOR_H__
This class matches the start for TimePointingInterface elements (such as fermata or harm).
Definition: preparedatafunctor.h:414
This class represents a MEI staffDef.
Definition: staffdef.h:26
This class represents a staff in a laid-out score (Doc).
Definition: staff.h:102
This class represents a measure in a page-based score (Doc).
Definition: measure.h:37
This class models the MEI <ornam> element.
Definition: repeatmark.h:26
bool ImplementsEndInterface() const override
Return true if the functor implements the end interface.
Definition: preparedatafunctor.h:991
This class models the MEI <f> element.
Definition: f.h:24
This class processes by layer and sets drawing pointers.
Definition: preparedatafunctor.h:620
bool ImplementsEndInterface() const override
Return true if the functor implements the end interface.
Definition: preparedatafunctor.h:679
This class models the MEI <beamSpan> element.
Definition: beamspan.h:31
This class sets the Measure of Ending.
Definition: preparedatafunctor.h:865
This class is a hold the data and corresponds to the model of a MVC design pattern.
Definition: doc.h:41
bool ImplementsEndInterface() const override
Return true if the functor implements the end interface.
Definition: preparedatafunctor.h:935
This class sets the cross staff and cross layer pointers on layer elements.
Definition: preparedatafunctor.h:110
This class represents an MEI Div.
Definition: div.h:24
This class models the MEI <tabDurSym> element.
Definition: tabdursym.h:25
This class groups FloatingObjects by drawingGrpId.
Definition: preparedatafunctor.h:922
This class represents a MEI ending.
Definition: ending.h:28
bool ImplementsEndInterface() const override
Return true if the functor implements the end interface.
Definition: preparedatafunctor.h:633
This class models a group of dots as a layer element part and has no direct MEI equivalent.
Definition: elementpart.h:27
This class represents a collection of notes in the same layer with the same onset time.
Definition: chord.h:32
This class represents a basic object.
Definition: object.h:59
This class models the MEI <pedal> element.
Definition: pedal.h:27
This class sets wordpos and connector ends.
Definition: preparedatafunctor.h:666
bool ImplementsEndInterface() const override
Return true if the functor implements the end interface.
Definition: preparedatafunctor.h:39
This class models a stem as a layer element part and has no direct MEI equivalent.
Definition: elementpart.h:97
This class models the MEI <dir> element.
Definition: dir.h:26
This class gets the list of referenced elements for the BeamSpan and marks referenced objects as cont...
Definition: preparedatafunctor.h:1070
bool ImplementsEndInterface() const override
Return true if the functor implements the end interface.
Definition: preparedatafunctor.h:123
This class is responsible for one time member initialization at the very begin.
Definition: preparedatafunctor.h:26
This class matches elements of @plist.
Definition: preparedatafunctor.h:321
bool ImplementsEndInterface() const override
Return true if the functor implements the end interface.
Definition: preparedatafunctor.h:382
This class matches down and up pedal lines.
Definition: preparedatafunctor.h:578
This class goes through all the TimeSpanningInterface elements and sets them for each staff that is c...
Definition: preparedatafunctor.h:978
bool ImplementsEndInterface() const override
Return true if the functor implements the end interface.
Definition: preparedatafunctor.h:776
bool ImplementsEndInterface() const override
Return true if the functor implements the end interface.
Definition: preparedatafunctor.h:1083
bool ImplementsEndInterface() const override
Return true if the functor implements the end interface.
Definition: preparedatafunctor.h:266
bool ImplementsEndInterface() const override
Return true if the functor implements the end interface.
Definition: preparedatafunctor.h:878
bool ImplementsEndInterface() const override
Return true if the functor implements the end interface.
Definition: preparedatafunctor.h:427
This class models an end milestone element at the system level.
Definition: systemmilestone.h:28
Definition: symboltable.h:20
This abstract class is the base class for all mutable functors.
Definition: functor.h:101
This class matches start and end for TimeSpanningInterface elements with tstamp(2) attributes.
Definition: preparedatafunctor.h:524
bool ImplementsEndInterface() const override
Return true if the functor implements the end interface.
Definition: preparedatafunctor.h:479
bool ImplementsEndInterface() const override
Return true if the functor implements the end interface.
Definition: preparedatafunctor.h:84
bool ImplementsEndInterface() const override
Return true if the functor implements the end interface.
Definition: preparedatafunctor.h:169
bool ImplementsEndInterface() const override
Return true if the functor implements the end interface.
Definition: preparedatafunctor.h:214
This class resolves the Reh time pointing position in case none is set.
Definition: preparedatafunctor.h:1030
This class represents elements appearing within a measure.
Definition: floatingobject.h:28
This class models the MEI <mRpt> element.
Definition: mrpt.h:26
This class models the MEI <reh> element.
Definition: reh.h:26
This class models the MEI <note> element.
Definition: note.h:47
This class matches start and end for TimeSpanningInterface elements (such as tie or slur).
Definition: preparedatafunctor.h:466
Implements the facsimile element in MEI.
Definition: facsimile.h:31
This class sets mRpt drawing numbers (if required).
Definition: preparedatafunctor.h:763
bool ImplementsEndInterface() const override
Return true if the functor implements the end interface.
Definition: preparedatafunctor.h:821
This class sets Turn::m_drawingEndNote for delayed turns.
Definition: preparedatafunctor.h:808
bool ImplementsEndInterface() const override
Return true if the functor implements the end interface.
Definition: preparedatafunctor.h:1043
This class adds LayerElement parts (stem, flag, dots, etc).
Definition: preparedatafunctor.h:713
bool ImplementsEndInterface() const override
Return true if the functor implements the end interface.
Definition: preparedatafunctor.h:726
bool ImplementsEndInterface() const override
Return true if the functor implements the end interface.
Definition: preparedatafunctor.h:537
Syl is a TimeSpanningInterface for managing syllable connectors.
Definition: syl.h:31
bool ImplementsEndInterface() const override
Return true if the functor implements the end interface.
Definition: preparedatafunctor.h:591
This class models a stem as a layer element part and as MEI <stem> element.
Definition: stem.h:27
This class associates layer elements with @facs to the appropriate zone.
Definition: preparedatafunctor.h:201
This class represents a MEI scoreDef.
Definition: scoredef.h:129
This class matches the @altsym element to the corresponding symbolDef.
Definition: preparedatafunctor.h:156
This class matches linking elements (e.g, @next).
Definition: preparedatafunctor.h:253
This class models the MEI <rest> element.
Definition: rest.h:37
This class is a mixin for all functors that require two step processing: (1) Collecing data.
Definition: functor.h:220
This class represent a <score> in MEI.
Definition: score.h:30
This class extracts the default duration from scoredef/staffdef.
Definition: preparedatafunctor.h:369
This class models the MEI <keySig> element.
Definition: keysig.h:44
This class represents a text element featuring horizontal and vertical layout.
Definition: textlayoutelement.h:24
This class is a base class for the Layer (<layer>) content.
Definition: layerelement.h:46
This class represents a layer in a laid-out score (Doc).
Definition: layer.h:33
This class models the MEI <harm> element.
Definition: harm.h:27
This abstract class is the base class for all mutable functors that need access to the document.
Definition: functor.h:151
bool ImplementsEndInterface() const override
Return true if the functor implements the end interface.
Definition: preparedatafunctor.h:334
This class models the MEI <hairpin> element.
Definition: hairpin.h:25
This class sets the drawing cue size for all layer elements.
Definition: preparedatafunctor.h:71
This class is an interface for elements having a single time point, such as tempo,...
Definition: timeinterface.h:35