29#include "musx/util/Fraction.h"
30#include "BaseClasses.h"
31#include "CommonClasses.h"
41enum class PseudoTieMode;
49class PercussionNoteInfo;
113 {
return m_honorPartVoicing ? m_partVoicing :
nullptr; }
127 explicit operator bool() const noexcept {
return static_cast<bool>(m_hold); }
170 std::map<LayerIndex, int>
calcVoices(
bool excludeHidden =
false)
const;
224 Cmper m_requestedPartId{};
227 bool m_honorPartVoicing{};
363 :
Base(document, partId, shareMode), m_entnum(entnum), m_prev(prev), m_next(next)
422 std::vector<std::shared_ptr<Note>>
notes;
487 MUSX_INTEGRITY_ERROR(
"Entry " + std::to_string(m_entnum) +
" has an incorrect number of notes.");
527 class InterpretedIterator;
537 explicit EntryInfoPtr(
const std::shared_ptr<const EntryFrame>& entryFrame,
size_t index = 0)
538 : m_entryFrame(entryFrame), m_indexInFrame(index) {}
554 const std::shared_ptr<const EntryInfo>
operator->()
const;
557 operator bool() const noexcept;
644 [[nodiscard]] std::optional<size_t>
calcNextTupletIndex(std::optional<size_t> currentIndex = 0)
const;
696 [[nodiscard]] InterpretedIterator
asInterpretedIterator(
bool remapBeamOverBarlineEntries =
true)
const;
701 {
return iterateBeamGroup<&EntryInfoPtr::nextPotentialInBeam, &EntryInfoPtr::previousPotentialInBeam>(beamIterationMode); }
706 {
return iterateBeamGroup<&EntryInfoPtr::previousPotentialInBeam, &EntryInfoPtr::nextPotentialInBeam>(beamIterationMode); }
756 if (m_upStem.has_value()) {
757 return m_upStem.value();
759 m_upStem = calcUpStemImpl();
760 return m_upStem.value();
869 [[nodiscard]]
bool calcIsCue(
bool includeVisibleInScore =
false)
const;
977 bool iterateStartingSmartShapes(std::function<
bool(
const MusxInstance<others::SmartShape>&)> callback,
bool findExact =
false)
const;
982 if (m_entryFrame != other.m_entryFrame)
983 return m_entryFrame < other.m_entryFrame;
984 return m_indexInFrame < other.m_indexInFrame;
988 [[nodiscard]]
unsigned calcVisibleBeams()
const;
990 [[nodiscard]]
bool calcUpStemImpl()
const;
992 template<EntryInfoPtr(EntryInfoPtr::* Iterator)() const>
993 [[nodiscard]] std::optional<unsigned> iterateFindRestsInSecondaryBeam(
const EntryInfoPtr nextOrPrevInBeam)
const;
995 template<EntryInfoPtr(EntryInfoPtr::* Iterator)() const>
996 [[nodiscard]]
EntryInfoPtr iteratePotentialEntryInBeam()
const;
998 template<EntryInfoPtr(EntryInfoPtr::* Iterator)() const>
999 [[nodiscard]]
bool iterateNotesExistLeftOrRight()
const;
1006 template<BeamIteratorFn Iterator, BeamIteratorFn ReverseIterator>
1012 [[nodiscard]]
EntryInfoPtr findLeftBeamAnchorForBeamOverBarline()
const;
1017 [[nodiscard]]
EntryInfoPtr findRightBeamAnchorForBeamOverBarline()
const;
1019 std::shared_ptr<const EntryFrame> m_entryFrame;
1020 size_t m_indexInFrame{};
1023 mutable MusxInstance<others::StaffComposite> m_cachedStaff;
1026 mutable std::optional<bool> m_upStem;
1077 bool m_effectiveHidden{};
1082 bool m_useIteratedForBackLaunch{};
1083 bool m_remapBeamOverBarlineEntries{};
1085 [[nodiscard]]
const EntryInfoPtr& getIteratedEntry()
const noexcept
1086 {
return m_iteratedEntry ? m_iteratedEntry : m_entry; }
1088 [[nodiscard]]
const EntryInfoPtr& getForwardLaunchEntry()
const noexcept
1089 {
return getIteratedEntry(); }
1091 [[nodiscard]]
const EntryInfoPtr& getBackwardLaunchEntry()
const noexcept
1092 {
return m_useIteratedForBackLaunch ? getIteratedEntry() : m_entry; }
1154 explicit operator bool() const noexcept
1156 return static_cast<bool>(m_entry);
1166class EntryFrame :
public std::enable_shared_from_this<EntryFrame>
1178 m_layerIndex(layerIndex),
1179 m_timeStretch(timeStretch),
1180 m_startStaff(startStaff)
1205 throw std::logic_error(
"TupletInfo has invalid start and end indices.");
1277 bool calcCreatesSingleton(
bool left)
const;
1280 const std::shared_ptr<const EntryFrame> getParent()
const
1282 auto result = m_parent.lock();
1283 MUSX_ASSERT_IF(!result) {
1284 throw std::logic_error(
"Unable to obtain lock on parent entry frame.");
1289 const std::weak_ptr<const EntryFrame> m_parent;
1339 const std::vector<std::shared_ptr<const EntryInfo>>&
getEntries()
const
1340 {
return m_entries; }
1410 void addEntry(
const std::shared_ptr<const EntryInfo>& entry)
1411 { m_entries.emplace_back(entry); }
1417 std::shared_ptr<const EntryFrame>
getNext(std::optional<MeasCmper> targetMeasure = std::nullopt)
const;
1423 std::shared_ptr<const EntryFrame>
getPrevious(std::optional<MeasCmper> targetMeasure = std::nullopt)
const;
1428 {
return m_startStaff; }
1478 std::vector<std::shared_ptr<const EntryInfo>> m_entries;
1508#ifndef DOXYGEN_SHOULD_IGNORE_THIS
1529 auto retval = m_entry.lock();
1531 throw std::logic_error(
"Entry pointer is no longer valid");
1556 : m_entry(entryInfo), m_noteIndex(noteIndex)
1560 explicit operator bool() const noexcept
1561 {
return m_entry && m_noteIndex < m_entry->getEntry()->notes.size(); }
1567 {
return m_entry.
isSameEntry(src.m_entry) && m_noteIndex == src.m_noteIndex; }
1579 MUSX_ASSERT_IF(m_noteIndex >= m_entry->getEntry()->notes.size()) {
1580 throw std::logic_error(
"Note index is too large for notes array.");
1582 return m_entry->getEntry()->notes[m_noteIndex];
1593 {
return m_noteIndex; }
1694 if (m_noteIndex >= m_entry->getEntry()->notes.size()) {
1705 if (m_noteIndex <= 0) {
1799 enum class TieFromSearchAction {
1806 const std::function<TieFromSearchAction(
const NoteInfoPtr&,
bool)>& decide);
1819 std::vector<CurveContourDirection>& directions,
1820 const std::vector<size_t>* eligibleNoteIndices =
nullptr)
const;
1832 bool isSamePitchValues(
const NoteInfoPtr& src)
const;
1843 NoteInfoPtr calcTieFromWithPreviousMeasure(
Cmper previousMeasure,
bool requireTie)
const;
1845 EntryInfoPtr m_entry;
1849 mutable std::optional<CurveContourDirection> m_tieDirection{};
Base class to enforce polymorphism across all DOM classes.
Definition BaseClasses.h:83
virtual void integrityCheck(const std::shared_ptr< Base > &ptrToThis)
Allows a class to determine if it has been properly contructed by the factory and fix issues that it ...
Definition BaseClasses.h:154
ShareMode
Describes how this instance is shared between part and score.
Definition BaseClasses.h:91
Wraps a reference to an existing object or owns a temporary value if needed.
Definition MusxInstance.h:179
Represents a vector of EntryInfo instances for a given frame, along with computed information.
Definition Entries.h:1167
util::Fraction getTimeStretch() const
Get the time stretch in this frame. Rather than accessing this value directly, consider using EntryIn...
Definition Entries.h:1335
util::Fraction maxElapsedStaffDuration
Definition Entries.h:1301
EntryFrame(const details::GFrameHoldContext &gfhold, LayerIndex layerIndex, util::Fraction timeStretch, const MusxInstance< others::StaffComposite > &startStaff)
Constructor function.
Definition Entries.h:1176
util::Fraction measureStaffDuration
The duration of the measure in staff duration units.
Definition Entries.h:1300
EntryInfoPtr getLastInVoice(int voice) const
Returns the last entry in the specified v1/v2 or null if none.
Definition Entries.cpp:158
MusxInstance< others::StaffComposite > getStartStaffInstance() const
Gets the staff at eduPosition 0 without needing to create it again.
Definition Entries.h:1427
bool calcAreAllEntriesHiddenInFrame() const
Calculates if this all notes in the frame are hidden. This routine only checks that entries are indiv...
Definition Entries.cpp:232
EntryInfoPtr calcNearestEntry(util::Fraction position, bool findExact=true, MatchVoice matchVoice=MatchVoice::Any, util::Fraction atGraceNoteDuration=0) const
Calculates the nearest non-grace-note entry at the given position.
Definition Entries.cpp:243
MeasCmper getMeasure() const
Get the measure for the entry frame.
Definition Entries.cpp:132
MusxInstance< others::Measure > getMeasureInstance() const
Get the measure instance.
Definition Entries.cpp:211
void addEntry(const std::shared_ptr< const EntryInfo > &entry)
Add an entry to the list.
Definition Entries.h:1410
const std::vector< std::shared_ptr< const EntryInfo > > & getEntries() const
Get the entry list.
Definition Entries.h:1339
EntryInfoPtr getFirstInVoice(int voice) const
Returns the first entry in the specified v1/v2 or null if none.
Definition Entries.cpp:142
StaffCmper getStaff() const
Get the staff for the entry.
Definition Entries.cpp:130
Cmper getRequestedPartId() const
Get the requested part ID for the entry frame.
Definition Entries.h:1314
std::shared_ptr< const EntryFrame > getNext(std::optional< MeasCmper > targetMeasure=std::nullopt) const
Gets the entry frame for the next measure with the same staff and layer.
Definition Entries.cpp:181
MusxInstance< others::StaffComposite > createCurrentStaff(Edu eduPosition, const std::optional< StaffCmper > &forStaffId=std::nullopt) const
Creates a current StaffComposite for the entry frame.
Definition Entries.cpp:202
MusxInstance< KeySignature > keySignature
This can be different than the measure key sig if the staff has independent key signatures.
Definition Entries.h:1299
MusxInstance< others::LayerAttributes > getLayerAttributes() const
Get the LayerAttributes for this entry frame.
Definition Entries.cpp:134
const details::GFrameHoldContext & getContext() const
Get the frame context for this frame.
Definition Entries.h:1310
LayerIndex getLayerIndex() const
Get the layer index (0..3) of the entry frame.
Definition Entries.h:1326
bool iterateEntries(std::function< bool(const EntryInfoPtr &)> iterator) const
Iterates the entries for the specified layer in this EntryFrame from left to right.
Definition Entries.cpp:285
DocumentPtr getDocument() const
Get the document for the entry frame.
Definition Entries.cpp:128
std::shared_ptr< const EntryFrame > getPrevious(std::optional< MeasCmper > targetMeasure=std::nullopt) const
Gets the entry frame for the previous measure with the same staff and layer.
Definition Entries.cpp:190
std::vector< TupletInfo > tupletInfo
A list of the tuplets in the frame and their calculated starting and ending information.
Definition Entries.h:1298
EntryInfoPtr::InterpretedIterator getFirstInterpretedIterator(int voice, bool remapBeamOverBarlineEntries=true) const
Returns a workaround-aware iterator at the first entry in the specified voice.
Definition Entries.cpp:168
bool calcIsCueFrame(bool includeVisibleInScore=false) const
Calculates if this entry frame is part of a cue.
Definition Entries.cpp:216
Iterator-style wrapper for workaround-aware voice traversal.
Definition Entries.h:1075
const EntryInfoPtr & getEntryInfo() const noexcept
Returns the entry at the current iterator position.
Definition Entries.h:1108
bool calcIsPastLogicalEndOfFrame() const
Returns true is this entry is past the logical end of the frame, as defined by the length of the meas...
Definition Entries.cpp:2229
InterpretedIterator getNext() const
Returns an iterator advanced to the next usable entry in this voice.
Definition Entries.cpp:2264
util::Fraction getEffectiveMeasureStaffDuration() const
Return the effective measure staff duration of the entry. Calling code using InterpretedIterator shou...
Definition Entries.cpp:2224
InterpretedIterator getPrevious() const
Returns an iterator advanced to the previous usable entry in this voice.
Definition Entries.cpp:2276
bool getEffectiveHidden() const noexcept
Returns whether the entry should be treated as hidden.
Definition Entries.h:1113
InterpretedIterator()=default
Default constructor allows null return values by caller.
util::Fraction getEffectiveActualDuration(bool global=false) const
Return the effective actual duration of the entry. Calling code using InterpretedIterator should use ...
Definition Entries.cpp:2208
util::Fraction getEffectiveElapsedDuration(bool global=false) const
Return the effective elapsed duration of the entry. Calling code using InterpretedIterator should use...
Definition Entries.cpp:2216
Wraps a frame of shared_ptr<const EntryInfo> and an index for per entry access. This class manages ow...
Definition Entries.h:512
bool calcUpStemDefault() const
Calculates if the entry is upstem by default, without considering voices, layers, staff options,...
Definition Entries.cpp:956
EntryInfoPtr getNextInFrame() const
Get the next entry in the frame.
Definition Entries.cpp:749
EntryInfoPtr getPreviousInBeamGroupAcrossBars(BeamIterationMode beamIterationMode=BeamIterationMode::Normal) const
Gets the previous entry in a beamed group or nullptr if the entry is not beamed or is the first in th...
Definition Entries.cpp:897
bool calcIsBeamStart(BeamIterationMode beamIterationMode=BeamIterationMode::Normal) const
Returns whether this is the start of a primary beam.
Definition Entries.cpp:1109
bool calcBeamMustStartHere() const
Determines if a beam must start on this entry.
Definition Entries.cpp:1104
EntryInfoPtr(const std::shared_ptr< const EntryFrame > &entryFrame, size_t index=0)
Constructor function.
Definition Entries.h:537
EntryInfoPtr getNextSameV() const
Get the next entry in the frame in the same voice.
Definition Entries.cpp:757
bool calcCanBeBeamed() const
Determines if this entry can be beamed.
Definition Entries.cpp:1091
EntryInfoPtr findMainEntryForGraceNote(bool ignoreRests=false) const
Finds the main entry for a grace note, taking into account hidden entries for beams over barlines.
Definition Entries.cpp:1357
size_t getIndexInFrame() const
Returns the index within the frame.
Definition Entries.h:610
util::Fraction calcGlobalElapsedDuration() const
Calculates the elapsed duration in global edu, removing any time stretch due to independent time sign...
Definition Entries.cpp:1712
std::pair< bool, bool > calcEntryStemSettings() const
Returns the Entry stem settings for the current requested part. This function encapsulates handling o...
Definition Entries.cpp:675
EntryInfoPtr calcBeamContinuesLeftOverBarline() const
Determines if this entry continues a beam across a barline from the previous measure.
Definition Entries.cpp:1392
EntryInfoPtr getNextInBeamGroup(BeamIterationMode beamIterationMode=BeamIterationMode::Normal) const
Gets the next entry in a beamed group or nullptr if the entry is not beamed or is the last in the gro...
Definition Entries.h:700
bool calcIfLayerSettingsApply() const
Calculates whether the conditions are met for the layer attributes dependent on others::LayerAttribut...
Definition Entries.cpp:1987
EntryInfoPtr getPreviousInVoice(int voice) const
Returns the previous entry in the frame in the specified v1/v2 or null if none.
Definition Entries.cpp:865
bool iterateStartingSmartShapes(std::function< bool(const MusxInstance< others::SmartShape > &)> callback, bool findExact=false) const
Iterates all smart shapes whose start anchor resolves to this entry.
Definition Entries.cpp:2146
unsigned calcReverseGraceIndex() const
Caclulates the grace index counting leftward (used by other standards such as MNX)
Definition Entries.cpp:692
static EntryInfoPtr fromEntryNumber(const DocumentPtr &document, Cmper partId, EntryNumber entryNumber, util::Fraction timeOffset=0)
Returns an EntryInfoPtr for the entry specified by entryNumber.
Definition Entries.cpp:475
EntryInfoPtr getPreviousSameVNoGrace() const
Get the previous entry in the frame in the same voice, skipping grace notes.
Definition Entries.cpp:846
MusxInstance< details::EntryPartFieldDetail > getPartFieldData() const
Gets the applicable part data for the entry, or nullptr if none.
Definition Entries.cpp:652
BeamIterationMode
Controls which entries are included when iterating over beams.
Definition Entries.h:517
@ Normal
Skip hidden entries. This is how Finale displays beams.
@ IncludeAll
Include all entries, even if they are hidden.
bool calcContainsPitchContent(const EntryInfoPtr &src, bool compareConcert=true) const
Returns whether src represent the same notated value.
Definition Entries.cpp:529
bool calcIsImmediatelyFollowedBy(const EntryInfoPtr &nextEntry) const
Returns true if nextEntry starts immediately after (or at) the end of this entry in time.
Definition Entries.cpp:785
Evpu calcManuaOffset() const
Returns the manual offset of the entry for the current requested part. This function encapsulates han...
Definition Entries.cpp:667
EntryInfoPtr getNextInLayer(std::optional< MeasCmper > targetMeasure=std::nullopt) const
Get the next entry in the same layer and staff. This can be in the next measure.
Definition Entries.cpp:738
unsigned calcLowestBeamStart(bool considerBeamOverBarlines=false) const
Returns the lowest beam number starting at this entry, where 1 = 8th note beam, 2 = 16th note beam,...
Definition Entries.cpp:1567
bool isSameEntry(const EntryInfoPtr &src) const
Returns whether the input and the current instance refer to the same entry.
Definition Entries.cpp:516
EntryInfoPtr findHiddenSourceForBeamOverBarline() const
Find the hidden source entry for a mid-system beam created by the Beam Over Barline plugin....
Definition Entries.cpp:1230
unsigned calcLowestBeamStub() const
Returns the lowest beam stub at this entry, where 2 = 16th note stub, 3 = 32nd note stub,...
Definition Entries.cpp:1653
bool calcIsBeamedRestWorkaroundVisibleRest() const
A common workaround in Finale is to hide a rest in v1 and supply it in v2. Typically it is used when ...
Definition Entries.cpp:1953
bool calcIsSamePitchContent(const EntryInfoPtr &src, bool compareConcert=true) const
Returns whether this entry and src contain the same pitch content or rest value.
Definition Entries.cpp:580
util::Fraction calcGraceElapsedDuration() const
Calculates a grace note's symbolic starting duration as a negative offset from the main note....
Definition Entries.cpp:704
unsigned calcLowestBeamEnd() const
Returns the lowest beam number ending at this entry, where 1 = 8th note beam, 2 = 16th note beam,...
Definition Entries.cpp:1609
LayerIndex getLayerIndex() const
Get the layer index (0..3) of the entry.
Definition Entries.cpp:644
bool calcIsSingletonGrace() const
Return true if this entry is a grace note and the only grace in the sequence at this location.
Definition Entries.cpp:2073
unsigned calcLowestBeamEndAcrossBarlines() const
Returns the lowest beam number ending at this entry, where 1 = 8th note beam, 2 = 16th note beam,...
Definition Entries.cpp:1632
unsigned calcNumberOfBeams() const
Calculates the number of beams or flags on the entry.
Definition Entries.cpp:1516
EntryInfoPtr getNextInBeamGroupAcrossBars(BeamIterationMode beamIterationMode=BeamIterationMode::Normal) const
Gets the next entry in a beamed group, or nullptr if the entry is not beamed or is the last in the gr...
Definition Entries.cpp:881
EntryInfoPtr getPreviousInFrame() const
Get the previous entry in the frame.
Definition Entries.cpp:823
std::shared_ptr< const EntryFrame > getFrame() const
Returns the frame.
Definition Entries.h:607
bool calcUpStem() const
Determines the effective stem direction of the entry, taking into account voices, layers,...
Definition Entries.h:754
bool calcIsBeamedRestWorkaroundHiddenRest() const
A common workaround in Finale is to hide a rest in v1 and supply it in v2. Typically it is used when ...
Definition Entries.cpp:1933
int getVoice() const
Gets the voice as integer value 1 or 2.
Definition Entries.cpp:524
bool calcIsSamePitchContentAndDuration(const EntryInfoPtr &src, bool compareConcert=true, bool requireSameVoice=true, bool requireSameGraceElapsedDura=false) const
Returns whether this entry and src represent the same notated value.
Definition Entries.cpp:616
EntryInfoPtr findBeamStartOrCurrent() const
Finds the first entry of a beamed group or returns the current entry if it is not beams.
Definition Entries.cpp:1481
bool calcDisplaysAsRest() const
Calculates if an entry displays as a rest.
Definition Entries.cpp:913
MusxInstance< KeySignature > getKeySignature() const
Get the key signature of the entry.
Definition Entries.cpp:650
bool calcIsCue(bool includeVisibleInScore=false) const
Calculates if this entry is part of a cue.
Definition Entries.cpp:1883
EntryInfoPtr getPreviousInBeamGroup(BeamIterationMode beamIterationMode=BeamIterationMode::Normal) const
Gets the previous entry in a beamed group or nullptr if the entry is not beamed or is the first in th...
Definition Entries.h:705
InterpretedIterator asInterpretedIterator(bool remapBeamOverBarlineEntries=true) const
Returns this EntryInfoPtr in a InterpretedIterator instance.
Definition Entries.cpp:875
bool calcCreatesSingletonBeamLeft() const
Determines if this entry contains a tuplet that creates a singleton beam left. See EntryFrame::Tuplet...
Definition Entries.cpp:1121
bool operator<(const EntryInfoPtr &other) const
Explicit operator< for std::map.
Definition Entries.h:980
EntryInfoPtr getPreviousInLayer(std::optional< MeasCmper > targetMeasure=std::nullopt) const
Get the previous entry in the same layer and staff. This can be in the previous measure.
Definition Entries.cpp:812
std::optional< size_t > calcNextTupletIndex(std::optional< size_t > currentIndex=0) const
Returns the next higher tuplet index that this entry starts, or std::nullopt if none.
Definition Entries.cpp:717
std::pair< int, int > calcTopBottomStaffPositions() const
Calculates the top and bottom staff positions of the entry, taking into account percussion notes....
Definition Entries.cpp:931
StaffCmper getStaff() const
Get the staff cmper.
Definition Entries.cpp:646
EntryInfoPtr findBeamEnd() const
Finds the end entry of a beamed group.
Definition Entries.cpp:1498
int calcEntrySize() const
Returns the entry size as a percentage, taking into account the beaming.
Definition Entries.cpp:1869
EntryInfoPtr getPreviousSameV() const
Get the previous entry in the frame in the same voice.
Definition Entries.cpp:831
int calcCrossStaffDirectionForAll(DeferredReference< MusxInstanceList< others::StaffUsed > > staffList={}) const
Calculates if this entry has cross-staffed notes all in a single direction.
Definition Entries.cpp:2028
MusxInstance< others::StaffComposite > createCurrentStaff(const std::optional< StaffCmper > &forStaffId=std::nullopt) const
Creates the current StaffComposite for the entry.
Definition Entries.cpp:684
EntryInfoPtr findDisplayEntryForBeamOverBarline() const
Find the display entry for a hidden source entry. The display entry is one or more bars previous to t...
Definition Entries.cpp:1305
bool calcIsTrillToGraceEntry() const
Calculates if this entry is a trill-to entry as created by the Parenthesize Trill-To Notes plugin.
Definition Entries.cpp:2096
int calcIsAuxiliaryPitchMarker() const
Return true if this entry is an auxiliary pitch marker (specifically, a trill-to or gliss-to pitch ma...
Definition Entries.cpp:2085
EntryInfoPtr getNextInVoice(int voice) const
Returns the next entry in the frame in the specified v1/v2 or null if none.
Definition Entries.cpp:855
EntryInfoPtr calcBeamContinuesRightOverBarline() const
Determines if this entry continues a beam across a barline to the next measure.
Definition Entries.cpp:1436
std::optional< StaffCmper > calcCrossedStaffForAll() const
Calculates all the notes in this entry are crossed to the same staff.
Definition Entries.cpp:2052
const std::shared_ptr< const EntryInfo > operator->() const
Allows -> access to the underlying EntryInfo instance.
Definition Entries.cpp:500
bool calcUnbeamed() const
Returns whether this is an unbeamed entry.
Definition Entries.cpp:1082
EntryInfoPtr()
Default constructor.
Definition Entries.h:530
bool calcCreatesSingletonBeamRight() const
Determines if this entry contains a tuplet that creates a singleton beam right. See EntryFrame::Tuple...
Definition Entries.cpp:1132
bool calcBeamStubIsLeft() const
Calculates if a beam stub on this entry would go left or right. It does not check that an entry actua...
Definition Entries.cpp:1663
bool calcIsGlissToGraceEntry() const
Calculates if this entry is a gliss-to entry as created by the Parenthesize Trill-To Notes plugin.
Definition Entries.cpp:2119
bool calcIsFullMeasureRest() const
Returns whether this is a full measure rest.
Definition Entries.cpp:1909
util::Fraction calcGlobalActualDuration() const
Calculates the actual duration in global edu, removing any time stretch due to independent time signa...
Definition Entries.cpp:1717
MeasCmper getMeasure() const
Get the measure cmper.
Definition Entries.cpp:648
EntryInfoPtr getNextSameVNoGrace() const
Get the next entry in the frame in the same voice, skipping grace notes.
Definition Entries.cpp:775
std::vector< size_t > findTupletInfo() const
Finds the tuplet info for tuplets that include this entry.
Definition Entries.cpp:1973
bool calcIsFeatheredBeamStart(Evpu &outLeftY, Evpu &outRightY) const
Calculates if the entry starts a feathered beam and returns information about it if so.
Definition Entries.cpp:1834
Information an entry along with the entry.
Definition Entries.h:1500
unsigned graceIndex
Definition Entries.h:1519
ClefIndex clefIndex
the clef index in effect for the entry.
Definition Entries.h:1521
util::Fraction calcNextElapsedDuration() const
Calculates the next duration position after this entry.
Definition Entries.h:1538
util::Fraction cumulativeRatio
Definition Entries.h:1517
util::Fraction elapsedDuration
Definition Entries.h:1513
ClefIndex clefIndexConcert
the concert clef index in effect for the entry.
Definition Entries.h:1522
util::Fraction actualDuration
Definition Entries.h:1515
MusxInstance< Entry > getEntry() const
Get the entry.
Definition Entries.h:1527
Represents an entry containing metadata and notes.
Definition Entries.h:356
bool splitStem
Definition Entries.h:404
Entry(const DocumentWeakPtr &document, Cmper partId, ShareMode shareMode, EntryNumber entnum, EntryNumber prev, EntryNumber next)
Constructor function.
Definition Entries.h:362
EntryNumber getEntryNumber() const
Gets the entry number for this entry.
Definition Entries.h:444
bool articDetail
Indicates there is an articulation on the entry.
Definition Entries.h:386
bool upStemScore
Whether a stem is up or down as set in the score. (Only reliable when freezeStemScore is true....
Definition Entries.h:406
bool isNote
If this value is false, the entry is a rest.
Definition Entries.h:379
bool noLeger
Hide ledger lines.
Definition Entries.h:411
MusxInstance< Entry > getNext() const
Gets the next entry in this list or nullptr if none.
Definition Entries.cpp:50
bool noPlayback
Indicates that the entry should not be played back.
Definition Entries.h:417
bool voice2
This is a V2 note. (xml node <v2>)
Definition Entries.h:381
bool splitRest
Indicates that rests in different layers are not combined on this entry.
Definition Entries.h:389
bool beamExt
Indicates that there is a beam extension on the entry.
Definition Entries.h:393
bool createdByHP
Indicates the entry was created by Finale's smart playback engine.
Definition Entries.h:382
static constexpr std::string_view XmlNodeName
The XML node name for this type.
Definition Entries.h:495
MusxInstance< Entry > getPrevious() const
Gets the previous entry in this list or nullptr if none.
Definition Entries.cpp:60
bool secBeam
Signifies a secondary beam break occurs on the entry.
Definition Entries.h:397
bool stemDetail
Indicates there are stem modifications.
Definition Entries.h:399
bool slashGrace
Definition Entries.h:413
bool isValid
Should always be true but otherwise appears to be used internally by Finale.
Definition Entries.h:378
bool playDisabledByHP
Used by Finale's smart playback engine.
Definition Entries.h:383
bool flipTie
Indicates the existence of a flipped tie, either in Speedy Entry or Layer Attributes.
Definition Entries.h:394
bool flatBeam
Forces any beam that starts on this entry to be flat by default.
Definition Entries.h:416
std::vector< std::shared_ptr< Note > > notes
Collection of notes that comprise the entry. These are in order from lowest to highest.
Definition Entries.h:422
void integrityCheck(const std::shared_ptr< Base > &ptrToThis) override
Allows a class to determine if it has been properly contructed by the factory and fix issues that it ...
Definition Entries.h:483
bool dummy
Definition Entries.h:408
Evpu hOffsetScore
Manual offset created with the Note Position Tool in the score. (xml node is <posi>....
Definition Entries.h:377
bool checkAccis
Used by Finale to convert pre-2014 .mus files. May never be saved in .musx.
Definition Entries.h:407
bool noteDetail
Indicates there is a note detail or EntrySize record for the entry.
Definition Entries.h:385
util::Fraction calcFraction() const
Calculates the duration as a util::Fraction of a whole note.
Definition Entries.h:468
static const xml::XmlElementArray< Entry > & xmlMappingArray()
Required for musx::factory::FieldPopulator.
bool hasStem() const
Returns true if the entry's duration has a stem.
Definition Entries.h:473
bool crossStaff
Signifies that at least one note in the entry has been cross staffed.
Definition Entries.h:400
bool floatRest
Is floating rest. If false, the first note element gives the staff position of the rest.
Definition Entries.h:391
bool smartShapeDetail
Indicates this entry has a smart shape assignment.
Definition Entries.h:410
Edu duration
Duration of the entry, not taking into account tuplets.
Definition Entries.h:375
bool isHidden
Indicates the entry is hidden, (xml node is <ignore>)
Definition Entries.h:392
bool tupletStart
Indicates that a tuplet start on the entry.
Definition Entries.h:388
bool lyricDetail
Indicates there is a lyric assignment on the entry.
Definition Entries.h:387
int numNotes
Number of notes in the entry. There is an error if this is not the same as notes.size().
Definition Entries.h:376
bool sorted
Sorted flag.
Definition Entries.h:412
bool reverseDownStem
Indicates that a stem normally down is reversed.
Definition Entries.h:402
bool reverseUpStem
Indicates that a stem normally up is reversed.
Definition Entries.h:401
bool v2Launch
Indicates if this entry (which is voice1) launches a voice2 sequence. (xml node is <controller>)
Definition Entries.h:380
bool doubleStem
Creates a double stem on the entry. (Appears to be exclusive with splitStem.)
Definition Entries.h:403
bool isPossibleFullMeasureRest() const
Returns true if the entry could be a full-measure rest.
Definition Entries.h:480
bool beam
Signifies the start of a beam or singleton entry. (That is, any beam breaks at this entry....
Definition Entries.h:396
bool freezeStemScore
Freeze stem flag in the score. (upStemScore gives the direction.)
Definition Entries.h:398
bool performanceData
Indicates there is performance data on the entry.
Definition Entries.h:390
bool noSpacing
Indicates that the entry should be ignored when calculating music spacing.
Definition Entries.h:418
bool dotTieAlt
Indicates dot or tie alterations are present.
Definition Entries.h:395
bool freezeBeam
Freeze beam flag (Derived from the presence of <freezeBeam> node.)
Definition Entries.h:419
struct musx::dom::Entry::EntryLocation location
The location of this entry.
bool graceNote
Indicate the entry is a grace note.
Definition Entries.h:384
Duration calcDurationInfo() const
Calculates the NoteType and number of augmentation dots. (See calcDurationInfoFromEdu....
Definition Entries.h:462
static void calcLocations(const DocumentPtr &document)
Calculates the locations for all entries in the document. This function is normally only called by th...
Definition Entries.cpp:105
KeyContext
Indicates whether to compute key signature values in concert or written pitch.
Definition CommonClasses.h:203
Provides optional per-type extension methods for MusxInstanceList.
Definition MusxInstance.h:103
Wraps an EntryInfo instance and a note index.
Definition Entries.h:1547
size_t getNoteIndex() const
Gets the note index for this note.
Definition Entries.h:1592
int calcStaffPosition() const
Calculates the staff position for this note, taking into account percussion notes.
EntryInfoPtr getEntryInfo() const
Gets the entry info for this note.
Definition Entries.h:1587
MusxInstance< others::PercussionNoteInfo > calcPercussionNoteInfo() const
Calculates the percussion note info for this note, if any.
Definition Entries.cpp:2959
MusxInstance< Note > operator->() const
Allows -> access to the underlying Note instance.
Definition Entries.h:1577
bool calcHasInnerTie(bool forTieEnd=false) const
Determines whether this note has an inner tie at the specified endpoint.
Definition Entries.cpp:2881
std::vector< std::pair< NoteInfoPtr, CurveContourDirection > > calcJumpTieContinuationsFrom() const
Calculates the notes in prior measures that continue a "jump" tie into this note.
Definition Entries.cpp:3259
bool isSameNote(const NoteInfoPtr &src) const
Returns whether the input and the current instance refer to the same note.
Definition Entries.h:1566
StaffCmper calcStaff() const
Calculates the staff number, taking into account cross staffing.
Definition Entries.cpp:2891
bool calcIsBottom() const
Return true if this is the bottom note in the entry.
Definition Entries.cpp:3091
CurveContourDirection calcEffectiveTieDirection(bool forTieEnd=false) const
Calculates the effective tie direction for this note, taking into account all options and overrides.
Definition Entries.cpp:2863
NoteInfoPtr getPrevious() const
Gets the next note in a chord on the same entry.
Definition Entries.h:1703
Note::NoteProperties calcNotePropertiesConcert(bool alwaysUseEntryStaff=false) const
Calculates the note name, octave number, actual alteration, and staff position for the concert pitch ...
Definition Entries.cpp:2933
bool calcIsEnharmonicRespellInAnyPart() const
Calculates if any linked part has this note enharmonically respelled.
Definition Entries.cpp:2996
NoteInfoPtr calcArpeggiatedTieToNote(CurveContourDirection *tieDirection=nullptr) const
If this note has a smart shape acting as an arpeggio tie, return the tied-to note....
Definition Entries.cpp:3109
bool calcHasPseudoLvTie(CurveContourDirection *tieDirection=nullptr) const
Calculates if this note has a smart shape, shape expression, or shape articulation acting as a laisse...
Definition Entries.cpp:3132
NoteInfoPtr calcTieFrom(bool requireTie=true) const
Calculates the note that this note could tie from.
Definition Entries.cpp:2858
bool calcIsIncludedInVoicing() const
Returns true if this note is included in the part voicing. This function returns the correct value ev...
Definition Entries.cpp:3065
bool calcHasOuterTie(bool forTieEnd=false) const
Determines whether this note has an outer tie at the specified endpoint.
Definition Entries.cpp:2871
bool calcIsEnharmonicRespell() const
Returns if this note is enharmonically respelled in the current part view.
Definition Entries.cpp:2985
std::pair< int, int > calcDefaultEnharmonic() const
Calculates the default enharmonic equivalent of this note. This is the value that Finale uses when de...
Definition Entries.h:1725
Note::NoteProperties calcNotePropertiesInView(bool alwaysUseEntryStaff=false) const
Calculates the note name, octave number, actual alteration, and staff position for the pitch of the n...
Definition Entries.cpp:2949
int calcCrossStaffDirection(DeferredReference< MusxInstanceList< others::StaffUsed > > staffList={}) const
Calculates if this note is cross-staffed and if so, which direction.
Definition Entries.cpp:3042
NoteInfoPtr(const EntryInfoPtr &entryInfo, size_t noteIndex)
Constructor.
Definition Entries.h:1555
NoteInfoPtr calcTieTo() const
Calculates the note that this note could tie to. Check the return value's Note::tieEnd to see if ther...
Definition Entries.cpp:2853
bool calcIsTop() const
Return true if this is the top note in the entry.
Definition Entries.cpp:3073
NoteInfoPtr findEqualPitch(const EntryInfoPtr &entry) const
Finds a note with the same pitch in the supplied entry.
Definition Entries.cpp:2712
NoteInfoPtr getNext() const
Gets the next note in a chord on the same entry.
Definition Entries.h:1692
NoteInfoPtr()
Default constructor.
Definition Entries.h:1550
std::unique_ptr< music_theory::Transposer > createTransposer() const
Creates a transposer for this Note instance.
Definition Entries.cpp:2980
Note::NoteProperties calcNoteProperties(EnharmonicOverride enharmonicOverride=EnharmonicOverride::None, bool alwaysUseEntryStaff=false) const
Calculates the note name, octave number, actual alteration, and staff position. This function does no...
Definition Entries.cpp:2906
bool calcHasPseudoTieEnd(CurveContourDirection *tieDirection=nullptr) const
Calculates if this note has a smart shape, shape expression, or shape articulation acting as a tie en...
Definition Entries.cpp:3137
Represents a single note element in an entry.
Definition Entries.h:257
bool upStemSecond
When the entry is upstem, it is drawn on the "wrong" side of the stem.
Definition Entries.h:283
bool isValid
Should always be true but otherwise appears to be used internally by Finale.
Definition Entries.h:279
bool playDisabledByHP
Used by Finale's smart playback engine.
Definition Entries.h:294
static constexpr NoteNumber RESTID
Non floating rests have a note with this noteId that defines their staff positions.
Definition Entries.h:266
int harmAlt
Chromatic alteration relative to the key signature. Never has a magnitude greater than +/-7.
Definition Entries.h:278
bool upSplitStem
Definition Entries.h:287
NoteNumber getNoteId() const
Gets the note id for this note. This value does not change, even if the notes in a chord are rearrang...
Definition Entries.h:299
bool tieEnd
Indicates a tie ends on this note.
Definition Entries.h:281
Note(const DocumentWeakPtr &document, NoteNumber noteId)
Constructor function.
Definition Entries.h:260
bool tieStart
Indicates a tie starts on this note.
Definition Entries.h:280
bool crossStaff
Signifies that the note has a details::CrossStaff note detail.
Definition Entries.h:282
std::pair< int, int > calcDefaultEnharmonic(const MusxInstance< KeySignature > &key) const
Calculates the default enharmonic equivalent of this note. This is the value that Finale uses when de...
Definition Entries.cpp:2631
int harmLev
Diatonic displacement relative to middle C or to the tonic in the middle C octave (if the key signatu...
Definition Entries.h:277
static const xml::XmlElementArray< Note > & xmlMappingArray()
Required for musx::factory::FieldPopulator.
bool downStemSecond
When the entry is downstem, it is drawn on the "wrong" side of the stem.
Definition Entries.h:285
std::tuple< music_theory::NoteName, int, int, int > NoteProperties
Note properites. A tuple containing:
Definition Entries.h:275
bool noPlayback
Indicates that this note should not be played back.
Definition Entries.h:291
bool parenAcci
True if the accidental has parentheses.
Definition Entries.h:290
bool noSpacing
Indicates that this note should ignored when calculating spacing.
Definition Entries.h:292
bool showAcci
True if the note has an accidental. (Dynamically changed by Finale unless freezeAcci is set....
Definition Entries.h:289
bool freezeAcci
True if the accidental should be forced on or off (based on showAcci.)
Definition Entries.h:293
NoteProperties calcNoteProperties(const MusxInstance< KeySignature > &key, KeySignature::KeyContext ctx, ClefIndex clefIndex, const MusxInstance< others::PercussionNoteInfo > &percNoteInfo, const MusxInstance< others::Staff > &staff=nullptr, bool respellEnharmonic=false) const
Calculates the note name, octave number, actual alteration, and staff position. This function does no...
Definition Entries.cpp:2666
A context wrapper for GFrameHold associated with a specific part and location.
Definition Entries.h:67
const GFrameHold * operator->() const
Provides const pointer-style access to the underlying GFrameHold.
Definition Entries.h:120
MusxInstance< others::PartVoicing > getPolicyPartVoicing() const
Returns the part voicing for the requested part, based on the document's PartVoicingPolicy.
Definition Entries.h:112
MusxInstance< others::PartVoicing > getPartVoicing() const
Returns the part voicing for the requested part.
Definition Entries.h:104
std::map< LayerIndex, int > calcVoices(bool excludeHidden=false) const
Calculates the number of voices used by the GFrameHold instance.
Definition Entries.cpp:2479
std::shared_ptr< const EntryFrame > createEntryFrame(LayerIndex layerIndex) const
Returns the EntryFrame for all entries in the given layer.
Definition Entries.cpp:2342
util::Fraction getTimeOffset() const
Return the time offset applied to entries in this instance. One reason this might be non-zero is if t...
Definition Entries.h:220
util::Fraction snapLocationToEntryOrKeep(util::Fraction location, bool findExact=true) const
Snaps a measure position to the nearest entry if possible.
Definition Entries.cpp:2591
ClefIndex calcClefIndexAt(util::Fraction position) const
Returns the clef index in effect for at the specified util::Fraction position (as a fraction of whole...
Definition Entries.h:139
util::Fraction calcMinLegacyPickupSpacer() const
Calculates the minimum legacy pickup spacer, if any.
Definition Entries.cpp:2602
bool iterateEntries(LayerIndex layerIndex, std::function< bool(const EntryInfoPtr &)> iterator) const
iterates the entries for the specified layer in this GFrameHold from left to right
Definition Entries.cpp:2460
bool calcIsCuesOnly(bool includeVisibleInScore=false) const
Calculates if this staff in this measure contains only a cue layer and full-measure rest layers.
Definition Entries.cpp:2534
bool calcVoicingIncludesLayer(LayerIndex layerIndex) const
Calculates if the part voicing for the current requested part includes the specified layer....
Definition Entries.cpp:2619
bool calcPolicyVoicingIncludesLayer(LayerIndex layerIndex) const
Similar to calcVoicingIncludesLayer, but honoring the document's part voicing policy.
Definition Entries.h:214
Cmper getRequestedPartId() const
Returns the requested part ID associated with this context.
Definition Entries.h:96
EntryInfoPtr calcNearestEntry(util::Fraction position, bool findExact=true, std::optional< LayerIndex > matchLayer=std::nullopt, MatchVoice matchVoice=MatchVoice::Any, util::Fraction atGraceNoteDuration=0) const
Calculates the nearest non-grace-note entry at the given position.
Definition Entries.cpp:2559
ClefIndex calcClefIndexAt(Edu position) const
Returns the clef index in effect for at the specified Edu position. This function does not take into ...
Definition Entries.cpp:2508
Represents the attributes of a Finale frame holder.
Definition Details.h:1096
A class to represent fractions with integer m_numerator and m_denominator, automatically reduced to s...
Definition Fraction.h:38
static constexpr Fraction fromEdu(dom::Edu edu)
Constructs a Fraction from edu.
Definition Fraction.h:93
constexpr dom::Edu calcEduDuration() const
Calculates duration as a fraction of a whole note. The result is rounded to the nearest integer Edu v...
Definition Fraction.h:142
A dependency-free, header-only collection of useful functions for music theory.
NoteName
The available note names in array order.
Definition music_theory.hpp:66
CurveContourDirection
Curve contour direction for ties and slurs.
Definition EnumClasses.h:62
MatchVoice
Specifies which voice(s) are considered when matching entries.
Definition EnumClasses.h:128
@ Any
Consider entries from either voice. (Default)
int16_t MeasCmper
Enigma meas Cmper (may be negative when not applicable)
Definition Fundamentals.h:64
std::shared_ptr< const T > MusxInstance
Defines the type of a musx instance stored in a pool.
Definition MusxInstance.h:39
EnharmonicOverride
Provides a three-state override option for enharmonic respelling.
Definition EnumClasses.h:108
@ None
Do not override the existing enharmonic state. (Default)
unsigned int LayerIndex
Layer index (valid values are 0..3)
Definition Fundamentals.h:71
int32_t Evpu
EVPU value (288 per inch)
Definition Fundamentals.h:57
uint16_t Cmper
Enigma "comperator" key type.
Definition Fundamentals.h:55
uint16_t ClefIndex
Index into options::ClefOptions::clefDefs.
Definition Fundamentals.h:68
int32_t Edu
"Enigma Durational Units" value (1024 per quarter note)
Definition Fundamentals.h:61
std::pair< NoteType, unsigned > Duration
Expresses a duration as a NoteType and a number of dots (unsigned)
Definition CommonClasses.h:54
unsigned calcNumberOfBeamsInEdu(Edu duration)
Returns the number of beams implied by an EDU duration.
Definition Entries.cpp:92
std::weak_ptr< Document > DocumentWeakPtr
Shared weak Document pointer.
Definition BaseClasses.h:57
int32_t EntryNumber
Entry identifier.
Definition Fundamentals.h:69
uint16_t NoteNumber
Note identifier.
Definition Fundamentals.h:70
std::shared_ptr< Document > DocumentPtr
Shared Document pointer.
Definition BaseClasses.h:55
Duration calcDurationInfoFromEdu(Edu duration)
Calculates the NoteType and number of dots in an Edu value.
Definition Entries.cpp:70
int16_t StaffCmper
Enigma staff (staffId) Cmper (may be negative when not applicable)
Definition Fundamentals.h:65
std::weak_ptr< const T > MusxInstanceWeak
Defines a weak ptr to the type of a musx instance stored in a pool.
Definition MusxInstance.h:44
std::vector< XmlElementDescriptor< T > > XmlElementArray
an array type for XmlElementDescriptor instances.
Definition XmlInterface.h:127
object model for musx file (enigmaxml)
Definition BaseClasses.h:36
class to track tuplets in the frame
Definition Entries.h:1186
size_t startIndex
the index of the first entry in the tuplet
Definition Entries.h:1188
bool calcCreatesSingletonBeamRight() const
Calculates if this tuplet is being used to create a singleton beam to the right.
Definition Entries.h:1247
TupletInfo(const std::weak_ptr< const EntryFrame > &parent, const MusxInstance< details::TupletDef > &tup, size_t index, util::Fraction start, bool forVoice2)
Constructor.
Definition Entries.h:1195
bool calcIsTremolo() const
Calculates if this tuplet represents a tremolo based on the following criteria.
Definition Entries.cpp:295
size_t endIndex
the index of the last entry in the tuplet
Definition Entries.h:1189
bool includesEntry(const EntryInfoPtr &entryInfo) const
Return true if the entry is part of this tuplet.
Definition Entries.h:1213
util::Fraction endDura
the actual duration where the tuplet ends
Definition Entries.h:1191
size_t numEntries() const
Return the number of entries in the tuplet.
Definition Entries.h:1202
util::Fraction startDura
the actual duration where the tuplet starts
Definition Entries.h:1190
bool calcCreatesSingletonBeamLeft() const
Calculates if this tuplet is being used to create a singleton beam to the left.
Definition Entries.h:1259
MusxInstance< details::TupletDef > tuplet
the tuplet
Definition Entries.h:1187
bool voice2
whether this tuplet is for voice2
Definition Entries.h:1192
bool calcCreatesTimeStretch() const
Detects tuplets being used to create time stretch in an independent time signature.
Definition Entries.cpp:441
The location of this entry as calculated by calcLocations, which is called by the factory.
Definition Entries.h:430
void clear()
Clears the entry location. (Mainly used for benchmarking.)
Definition Entries.h:439
size_t entryIndex
The 0-based index of this entry within its layer.
Definition Entries.h:434
bool found() const
Returns if this entry has been found.
Definition Entries.h:437
MeasCmper measureId
The measure containing this entry.
Definition Entries.h:432
LayerIndex layerIndex
The layer containing this entry within the measure.
Definition Entries.h:433
StaffCmper staffId
The staff containing this entry.
Definition Entries.h:431