MUSX Document Model
Loading...
Searching...
No Matches
Entries.h
1/*
2 * Copyright (C) 2025, Robert Patterson
3 *
4 * Permission is hereby granted, free of charge, to any person obtaining a copy
5 * of this software and associated documentation files (the "Software"), to deal
6 * in the Software without restriction, including without limitation the rights
7 * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
8 * copies of the Software, and to permit persons to whom the Software is
9 * furnished to do so, subject to the following conditions:
10 *
11 * The above copyright notice and this permission notice shall be included in
12 * all copies or substantial portions of the Software.
13 *
14 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
15 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
16 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
17 * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
18 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
19 * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
20 * THE SOFTWARE.
21 */
22#pragma once
23
24#include <functional>
25#include <map>
26#include <tuple>
27#include <utility>
28
29#include "musx/util/Fraction.h"
30#include "BaseClasses.h"
31#include "CommonClasses.h"
32 // do not add other dom class dependencies. Use Implementations.h for implementations that need total class access.
33
34namespace music_theory {
35enum class NoteName : int;
36class Transposer;
37} // namespace music_theory
38
39namespace musx {
40namespace utils {
41enum class PseudoTieMode;
42} // namespace utils
43
44namespace dom {
45
46namespace others {
47class Frame;
48class PartVoicing;
49class PercussionNoteInfo;
50class SmartShape;
51class Staff;
52class StaffComposite;
53class StaffUsed;
54} // namespace others
55
56namespace details {
57class TupletDef;
58class GFrameHold;
59
68{
69public:
80 GFrameHoldContext(const DocumentPtr& document, Cmper partId, Cmper staffId, Cmper measureId, util::Fraction timeOffset = 0);
81
89 GFrameHoldContext(const MusxInstance<GFrameHold>& gfHold, util::Fraction timeOffset = 0);
90
96 [[nodiscard]]
97 Cmper getRequestedPartId() const { return m_requestedPartId; }
98
104 [[nodiscard]]
105 MusxInstance<others::PartVoicing> getPartVoicing() const { return m_partVoicing; }
106
112 [[nodiscard]]
114 { return m_honorPartVoicing ? m_partVoicing : nullptr; }
115
121 const GFrameHold* operator->() const { return m_hold.get(); }
122
128 explicit operator bool() const noexcept { return static_cast<bool>(m_hold); }
129
133 [[nodiscard]]
134 ClefIndex calcClefIndexAt(Edu position) const;
135
139 [[nodiscard]]
141 { return calcClefIndexAt(position.calcEduDuration()); }
142
148 [[nodiscard]]
149 std::shared_ptr<const EntryFrame> createEntryFrame(LayerIndex layerIndex) const;
150
158 bool iterateEntries(LayerIndex layerIndex, std::function<bool(const EntryInfoPtr&)> iterator) const;
159
165 bool iterateEntries(std::function<bool(const EntryInfoPtr&)> iterator) const;
166
170 [[nodiscard]]
171 std::map<LayerIndex, int> calcVoices(bool excludeHidden = false) const;
172
175 [[nodiscard]]
176 bool calcIsCuesOnly(bool includeVisibleInScore = false) const;
177
186 [[nodiscard]]
187 EntryInfoPtr calcNearestEntry(util::Fraction position, bool findExact = true, std::optional<LayerIndex> matchLayer = std::nullopt,
188 MatchVoice matchVoice = MatchVoice::Any, util::Fraction atGraceNoteDuration = 0) const;
189
196 util::Fraction snapLocationToEntryOrKeep(util::Fraction location, bool findExact = true) const;
197
203 [[nodiscard]]
205
210 [[nodiscard]]
211 bool calcVoicingIncludesLayer(LayerIndex layerIndex) const;
212
214 [[nodiscard]]
216 { return !m_honorPartVoicing || calcVoicingIncludesLayer(layerIndex); }
217
220 [[nodiscard]]
221 util::Fraction getTimeOffset() const { return m_timeOffset; }
222
223private:
225 Cmper m_requestedPartId{};
226 util::Fraction m_timeOffset;
228 bool m_honorPartVoicing{};
229};
230
231} // namespace details
232
243
249unsigned calcNumberOfBeamsInEdu(Edu duration);
250
257class Note : public EnigmaBase
258{
259public:
261 explicit Note(const DocumentWeakPtr& document, NoteNumber noteId)
262 : EnigmaBase(document, 0, ShareMode::All), m_noteId(noteId)
263 {
264 }
265
267 static constexpr NoteNumber RESTID = 31;
268
276 using NoteProperties = std::tuple<music_theory::NoteName, int, int, int>;
277
278 int harmLev{};
279 int harmAlt{};
280 bool isValid{};
281 bool tieStart{};
282 bool tieEnd{};
283 bool crossStaff{};
288 bool upSplitStem{};
290 bool showAcci{};
291 bool parenAcci{};
292 bool noPlayback{};
293 bool noSpacing{};
294 bool freezeAcci{};
296
299 [[nodiscard]]
300 NoteNumber getNoteId() const { return m_noteId; }
301
312 [[nodiscard]]
313 std::pair<int, int> calcDefaultEnharmonic(const MusxInstance<KeySignature>& key) const;
314
340 [[nodiscard]]
342 const MusxInstance<others::PercussionNoteInfo>& percNoteInfo, const MusxInstance<others::Staff>& staff = nullptr, bool respellEnharmonic = false) const;
343
345
346private:
347 NoteNumber m_noteId{};
348};
349
356class Entry : public EnigmaBase
357{
358public:
363 explicit Entry(const DocumentWeakPtr& document, Cmper partId, ShareMode shareMode, EntryNumber entnum, EntryNumber prev, EntryNumber next)
364 : EnigmaBase(document, partId, shareMode), m_entnum(entnum), m_prev(prev), m_next(next)
365 {
366 }
367
377 int numNotes{};
379 bool isValid{};
380 bool isNote{};
381 bool v2Launch{};
382 bool voice2{};
383 bool createdByHP{};
385 bool graceNote{};
386 bool noteDetail{};
387 bool articDetail{};
388 bool lyricDetail{};
389 bool tupletStart{};
390 bool splitRest{};
392 bool floatRest{};
393 bool isHidden{};
394 bool beamExt{};
395 bool flipTie{};
396 bool dotTieAlt{};
397 bool beam{};
398 bool secBeam{};
400 bool stemDetail{};
401 bool crossStaff{};
404 bool doubleStem{};
405 bool splitStem{};
407 bool upStemScore{};
408 bool checkAccis{};
409 bool dummy{};
412 bool noLeger{};
413 bool sorted{};
414 bool slashGrace{};
417 bool flatBeam{};
418 bool noPlayback{};
419 bool noSpacing{};
420 bool freezeBeam{};
421
423 std::vector<std::shared_ptr<Note>> notes;
424
431 {
435 size_t entryIndex{};
436
438 bool found() const { return staffId != 0 && measureId != 0; }
440 void clear() { *this = {}; }
442
444 [[nodiscard]]
445 EntryNumber getEntryNumber() const { return m_entnum; }
446
450 [[nodiscard]]
452
456 [[nodiscard]]
458
462 [[nodiscard]]
464
468 [[nodiscard]]
470
473 [[nodiscard]]
474 bool hasStem() const { return duration < Edu(NoteType::Whole); }
475
480 [[nodiscard]]
482 { return !isNote && !isHidden && duration == Edu(NoteType::Whole); }
483
484 void integrityCheck(const std::shared_ptr<EnigmaBase>& ptrToThis) override
485 {
486 this->EnigmaBase::integrityCheck(ptrToThis);
487 if (size_t(numNotes) != notes.size()) {
488 MUSX_INTEGRITY_ERROR("Entry " + std::to_string(m_entnum) + " has an incorrect number of notes.");
489 }
490 }
491
494 static void calcLocations(const DocumentPtr& document);
495
496 constexpr static std::string_view XmlNodeName = "entry";
498
499private:
500 EntryNumber m_entnum{};
501 EntryNumber m_prev{};
502 EntryNumber m_next{};
503};
504
505class EntryInfo;
506class EntryFrame;
507class NoteInfoPtr;
508
513{
514public:
518 {
519 Normal,
520 IncludeAll,
526 };
527
528 class InterpretedIterator;
529
531 EntryInfoPtr() : m_entryFrame(nullptr), m_indexInFrame(0) {}
532
538 explicit EntryInfoPtr(const std::shared_ptr<const EntryFrame>& entryFrame, size_t index = 0)
539 : m_entryFrame(entryFrame), m_indexInFrame(index) {}
540
551 [[nodiscard]]
552 static EntryInfoPtr fromEntryNumber(const DocumentPtr& document, Cmper partId, EntryNumber entryNumber, util::Fraction timeOffset = 0);
553
555 const std::shared_ptr<const EntryInfo> operator->() const;
556
558 operator bool() const noexcept;
559
561 [[nodiscard]] int getVoice() const;
562
565 [[nodiscard]] bool isSameEntry(const EntryInfoPtr& src) const;
566
575 [[nodiscard]] bool calcIsSamePitchContent(const EntryInfoPtr& src, bool compareConcert = true) const;
576
589 [[nodiscard]]
590 bool calcIsSamePitchContentAndDuration(const EntryInfoPtr& src, bool compareConcert = true, bool requireSameVoice = true, bool requireSameGraceElapsedDura = false) const;
591
604 [[nodiscard]]
605 bool calcContainsPitchContent(const EntryInfoPtr& src, bool compareConcert = true) const;
606
610 [[nodiscard]]
611 NoteInfoPtr findNoteId(NoteNumber noteId) const;
612
614 [[nodiscard]] std::shared_ptr<const EntryFrame> getFrame() const { return m_entryFrame; }
615
617 [[nodiscard]] size_t getIndexInFrame() const { return m_indexInFrame; }
618
620 [[nodiscard]] LayerIndex getLayerIndex() const;
621
623 [[nodiscard]] StaffCmper getStaff() const;
624
627 [[nodiscard]] MusxInstance<others::StaffComposite> createCurrentStaff(const std::optional<StaffCmper>& forStaffId = std::nullopt) const;
628
630 [[nodiscard]] MeasCmper getMeasure() const;
631
633 [[nodiscard]] MusxInstance<KeySignature> getKeySignature() const;
634
637
640 [[nodiscard]] Evpu calcManuaOffset() const;
641
643 [[nodiscard]] unsigned calcReverseGraceIndex() const;
644
648 [[nodiscard]] util::Fraction calcGraceElapsedDuration() const;
649
651 [[nodiscard]] std::optional<size_t> calcNextTupletIndex(std::optional<size_t> currentIndex = 0) const;
652
654 [[nodiscard]] EntryInfoPtr getNextInFrame() const;
655
659 [[nodiscard]] EntryInfoPtr getNextInLayer(std::optional<MeasCmper> targetMeasure = std::nullopt) const;
660
664 [[nodiscard]] EntryInfoPtr getNextSameV() const;
665
668 [[nodiscard]] EntryInfoPtr getNextSameVNoGrace() const;
669
673 [[nodiscard]] EntryInfoPtr getPreviousInLayer(std::optional<MeasCmper> targetMeasure = std::nullopt) const;
674
676 [[nodiscard]] EntryInfoPtr getPreviousInFrame() const;
677
681 [[nodiscard]] EntryInfoPtr getPreviousSameV() const;
682
685 [[nodiscard]] EntryInfoPtr getPreviousSameVNoGrace() const;
686
692 [[nodiscard]] EntryInfoPtr getNextInVoice(int voice) const;
693
699 [[nodiscard]] EntryInfoPtr getPreviousInVoice(int voice) const;
700
703 [[nodiscard]] InterpretedIterator asInterpretedIterator(bool remapBeamOverBarlineEntries = true) const;
704
706 [[nodiscard]]
708 { return iterateBeamGroup<&EntryInfoPtr::nextPotentialInBeam, &EntryInfoPtr::previousPotentialInBeam>(beamIterationMode); }
709
711 [[nodiscard]]
713 { return iterateBeamGroup<&EntryInfoPtr::previousPotentialInBeam, &EntryInfoPtr::nextPotentialInBeam>(beamIterationMode); }
714
719
724
728 [[nodiscard]] bool calcDisplaysAsRest() const;
729
733 [[nodiscard]] std::pair<int, int> calcTopBottomStaffPositions() const;
734
740 [[nodiscard]] std::pair<bool, bool> calcEntryStemSettings() const;
741
745 [[nodiscard]] bool calcUpStemDefault() const;
746
751 [[nodiscard]] StemDirection calcStemDirectionForced() const;
752
767 [[nodiscard]] bool calcUpStem() const
768 {
769 if (m_upStem.has_value()) {
770 return m_upStem.value();
771 }
772 m_upStem = calcUpStemImpl();
773 return m_upStem.value();
774 }
775
778 [[nodiscard]] bool calcUnbeamed() const;
779
781 [[nodiscard]] bool calcIsBeamStart(BeamIterationMode beamIterationMode = BeamIterationMode::Normal) const;
782
785 [[nodiscard]] bool calcCreatesSingletonBeamLeft() const;
786
789 [[nodiscard]] bool calcCreatesSingletonBeamRight() const;
790
799
808
813 [[nodiscard]] bool calcIsFeatheredBeamStart(Evpu& outLeftY, Evpu& outRightY) const;
814
819 [[nodiscard]] EntryInfoPtr findBeamStartOrCurrent() const;
820
823 [[nodiscard]] EntryInfoPtr findBeamEnd() const;
824
826 [[nodiscard]] unsigned calcNumberOfBeams() const;
827
831 [[nodiscard]] unsigned calcLowestBeamStart(bool considerBeamOverBarlines = false) const;
832
835 [[nodiscard]] unsigned calcLowestBeamEnd() const;
836
840 [[nodiscard]] unsigned calcLowestBeamEndAcrossBarlines() const;
841
844 [[nodiscard]] unsigned calcLowestBeamStub() const;
845
851 [[nodiscard]] bool calcBeamStubIsLeft() const;
852
854 [[nodiscard]] util::Fraction calcGlobalElapsedDuration() const;
855
857 [[nodiscard]] util::Fraction calcGlobalActualDuration() const;
858
864 [[nodiscard]]
865 bool calcIsImmediatelyFollowedBy(const EntryInfoPtr& nextEntry) const;
866
868 [[nodiscard]] bool calcCanBeBeamed() const;
869
871 [[nodiscard]] bool calcBeamMustStartHere() const;
872
875 [[nodiscard]] int calcEntrySize() const;
876
882 [[nodiscard]] bool calcIsCue(bool includeVisibleInScore = false) const;
883
886 [[nodiscard]] bool calcIsFullMeasureRest() const;
887
891 [[nodiscard]] bool calcIsBeamedRestWorkaroundHiddenRest() const;
892
896 [[nodiscard]] bool calcIsBeamedRestWorkaroundVisibleRest() const;
897
900 [[nodiscard]] std::vector<size_t> findTupletInfo() const;
901
905 [[nodiscard]] bool calcIfLayerSettingsApply() const;
906
917
921 [[nodiscard]] std::optional<StaffCmper> calcCrossedStaffForAll() const;
922
924 [[nodiscard]] bool calcIsSingletonGrace() const;
925
931 [[nodiscard]] int calcIsAuxiliaryPitchMarker() const;
932
943 [[nodiscard]] bool calcIsTrillToGraceEntry() const;
944
952 [[nodiscard]] bool calcIsGlissToGraceEntry() const;
953
959
966
972 [[nodiscard]] EntryInfoPtr findMainEntryForGraceNote(bool ignoreRests = false) const;
973
990 bool iterateStartingSmartShapes(std::function<bool(const MusxInstance<others::SmartShape>&)> callback, bool findExact = false) const;
991
993 bool operator<(const EntryInfoPtr& other) const
994 {
995 if (m_entryFrame != other.m_entryFrame)
996 return m_entryFrame < other.m_entryFrame;
997 return m_indexInFrame < other.m_indexInFrame;
998 }
999
1000private:
1001 [[nodiscard]] unsigned calcVisibleBeams() const;
1002
1003 [[nodiscard]] bool calcUpStemImpl() const;
1004
1005 template<EntryInfoPtr(EntryInfoPtr::* Iterator)() const>
1006 [[nodiscard]] std::optional<unsigned> iterateFindRestsInSecondaryBeam(const EntryInfoPtr nextOrPrevInBeam) const;
1007
1008 template<EntryInfoPtr(EntryInfoPtr::* Iterator)() const>
1009 [[nodiscard]] EntryInfoPtr iteratePotentialEntryInBeam() const;
1010
1011 template<EntryInfoPtr(EntryInfoPtr::* Iterator)() const>
1012 [[nodiscard]] bool iterateNotesExistLeftOrRight() const;
1013
1014 [[nodiscard]] EntryInfoPtr nextPotentialInBeam(BeamIterationMode beamIterationMode) const;
1015
1016 [[nodiscard]] EntryInfoPtr previousPotentialInBeam(BeamIterationMode beamIterationMode) const;
1017
1018 using BeamIteratorFn = EntryInfoPtr (EntryInfoPtr::*)(BeamIterationMode) const;
1019 template<BeamIteratorFn Iterator, BeamIteratorFn ReverseIterator>
1020 [[nodiscard]] EntryInfoPtr iterateBeamGroup(BeamIterationMode beamIterationMode) const;
1021
1025 [[nodiscard]] EntryInfoPtr findLeftBeamAnchorForBeamOverBarline() const;
1026
1030 [[nodiscard]] EntryInfoPtr findRightBeamAnchorForBeamOverBarline() const;
1031
1032 std::shared_ptr<const EntryFrame> m_entryFrame;
1033 size_t m_indexInFrame{};
1034
1036 mutable MusxInstance<others::StaffComposite> m_cachedStaff;
1037
1039 mutable std::optional<bool> m_upStem;
1040};
1041
1056// the the caller should use for calculating elapsed time.
1088{
1089 EntryInfoPtr m_entry;
1090 bool m_effectiveHidden{};
1091 // --------
1092 // internal
1093 // --------
1094 EntryInfoPtr m_iteratedEntry;
1095 bool m_useIteratedForBackLaunch{};
1096 bool m_remapBeamOverBarlineEntries{};
1097
1098 [[nodiscard]] const EntryInfoPtr& getIteratedEntry() const noexcept
1099 { return m_iteratedEntry ? m_iteratedEntry : m_entry; }
1100
1101 [[nodiscard]] const EntryInfoPtr& getForwardLaunchEntry() const noexcept
1102 { return getIteratedEntry(); }
1103
1104 [[nodiscard]] const EntryInfoPtr& getBackwardLaunchEntry() const noexcept
1105 { return m_useIteratedForBackLaunch ? getIteratedEntry() : m_entry; }
1106
1110 InterpretedIterator(EntryInfoPtr entry, bool remapBeamOverBarlineEntries);
1111
1112 friend class EntryFrame;
1113 friend class EntryInfoPtr;
1114
1115public:
1118
1121 [[nodiscard]] const EntryInfoPtr& getEntryInfo() const noexcept { return m_entry; }
1122
1126 [[nodiscard]] bool getEffectiveHidden() const noexcept { return m_effectiveHidden; }
1127
1131 [[nodiscard]] util::Fraction getEffectiveActualDuration(bool global = false) const;
1132
1136 [[nodiscard]] util::Fraction getEffectiveElapsedDuration(bool global = false) const;
1137
1141
1144 [[nodiscard]] bool calcIsPastLogicalEndOfFrame() const;
1145
1153 [[nodiscard]] InterpretedIterator getNext() const;
1154
1162 [[nodiscard]] InterpretedIterator getPrevious() const;
1163
1167 explicit operator bool() const noexcept
1168 {
1169 return static_cast<bool>(m_entry);
1170 }
1171};
1172
1179class EntryFrame : public std::enable_shared_from_this<EntryFrame>
1180{
1181public:
1189 explicit EntryFrame(const details::GFrameHoldContext& gfhold, LayerIndex layerIndex, util::Fraction timeStretch, const MusxInstance<others::StaffComposite>& startStaff) :
1190 m_context(gfhold),
1191 m_layerIndex(layerIndex),
1192 m_timeStretch(timeStretch),
1193 m_startStaff(startStaff)
1194 {
1195 }
1196
1199 {
1201 size_t startIndex;
1202 size_t endIndex;
1205 bool voice2;
1206
1208 TupletInfo(const std::weak_ptr<const EntryFrame>& parent, const MusxInstance<details::TupletDef>& tup, size_t index, util::Fraction start, bool forVoice2)
1209 : tuplet(tup), startIndex(index), endIndex((std::numeric_limits<size_t>::max)()),
1210 startDura(start), endDura(-1), voice2(forVoice2), m_parent(parent)
1211 {}
1212
1214 [[nodiscard]]
1215 size_t numEntries() const
1216 {
1217 MUSX_ASSERT_IF(startIndex > endIndex) {
1218 throw std::logic_error("TupletInfo has invalid start and end indices.");
1219 }
1220 return endIndex - startIndex + 1;
1221 }
1222
1225 [[nodiscard]]
1226 bool includesEntry(const EntryInfoPtr& entryInfo) const
1227 {
1228 const size_t x = entryInfo.getIndexInFrame();
1229 return (x >= startIndex && x <= endIndex);
1230 }
1231
1243 [[nodiscard]]
1244 bool calcIsTremolo() const;
1245
1259 [[nodiscard]]
1260 bool calcCreatesSingletonBeamRight() const { return calcCreatesSingleton(false); }
1261
1271 [[nodiscard]]
1272 bool calcCreatesSingletonBeamLeft() const { return calcCreatesSingleton(true); }
1273
1284 // - the independent display time signature matches the tuplet's total display duration
1285 [[nodiscard]]
1286 bool calcCreatesTimeStretch() const;
1287
1288 private:
1289 [[nodiscard]]
1290 bool calcCreatesSingleton(bool left) const;
1291
1292 [[nodiscard]]
1293 const std::shared_ptr<const EntryFrame> getParent() const
1294 {
1295 auto result = m_parent.lock();
1296 MUSX_ASSERT_IF(!result) {
1297 throw std::logic_error("Unable to obtain lock on parent entry frame.");
1298 }
1299 return result;
1300 }
1301
1302 const std::weak_ptr<const EntryFrame> m_parent;
1303 };
1304
1311 std::vector<TupletInfo> tupletInfo;
1316
1318 [[nodiscard]]
1319 DocumentPtr getDocument() const;
1320
1322 [[nodiscard]]
1323 const details::GFrameHoldContext& getContext() const { return m_context; }
1324
1326 [[nodiscard]]
1327 Cmper getRequestedPartId() const { return m_context.getRequestedPartId(); }
1328
1330 [[nodiscard]]
1331 StaffCmper getStaff() const;
1332
1334 [[nodiscard]]
1335 MeasCmper getMeasure() const;
1336
1338 [[nodiscard]]
1339 LayerIndex getLayerIndex() const { return m_layerIndex; }
1340
1342 [[nodiscard]]
1344
1347 [[nodiscard]]
1348 util::Fraction getTimeStretch() const { return m_timeStretch; }
1349
1351 [[nodiscard]]
1352 const std::vector<std::shared_ptr<const EntryInfo>>& getEntries() const
1353 { return m_entries; }
1354
1358 [[nodiscard]]
1359 EntryInfoPtr getFirstInVoice(int voice) const;
1360
1364 [[nodiscard]]
1365 EntryInfoPtr getLastInVoice(int voice) const;
1366
1419 [[nodiscard]]
1420 EntryInfoPtr::InterpretedIterator getFirstInterpretedIterator(int voice, bool remapBeamOverBarlineEntries = true) const;
1421
1423 void addEntry(const std::shared_ptr<const EntryInfo>& entry)
1424 { m_entries.emplace_back(entry); }
1425
1429 [[nodiscard]]
1430 std::shared_ptr<const EntryFrame> getNext(std::optional<MeasCmper> targetMeasure = std::nullopt) const;
1431
1435 [[nodiscard]]
1436 std::shared_ptr<const EntryFrame> getPrevious(std::optional<MeasCmper> targetMeasure = std::nullopt) const;
1437
1439 [[nodiscard]]
1442
1446 [[nodiscard]]
1447 MusxInstance<others::StaffComposite> createCurrentStaff(Edu eduPosition, const std::optional<StaffCmper>& forStaffId = std::nullopt) const;
1448
1450 [[nodiscard]]
1452
1458 [[nodiscard]]
1459 bool calcIsCueFrame(bool includeVisibleInScore = false) const;
1460
1466 [[nodiscard]]
1467 bool calcAreAllEntriesHiddenInFrame() const;
1468
1476 [[nodiscard]]
1477 EntryInfoPtr calcNearestEntry(util::Fraction position, bool findExact = true, MatchVoice matchVoice = MatchVoice::Any,
1478 util::Fraction atGraceNoteDuration = 0) const;
1479
1484 bool iterateEntries(std::function<bool(const EntryInfoPtr&)> iterator) const;
1485
1486private:
1488 LayerIndex m_layerIndex;
1489 util::Fraction m_timeStretch;
1490
1491 std::vector<std::shared_ptr<const EntryInfo>> m_entries;
1492
1495
1497 mutable MusxInstance<others::LayerAttributes> m_cachedLayerAttributes;
1498};
1499
1500namespace details {
1501class GFrameHold;
1502} // namespace details
1503
1513{
1518 explicit EntryInfo(const MusxInstance<Entry>& entry)
1519 : m_entry(entry) {}
1520
1521#ifndef DOXYGEN_SHOULD_IGNORE_THIS
1523#endif
1524
1525public:
1532 unsigned graceIndex{};
1536
1539 [[nodiscard]]
1541 {
1542 auto retval = m_entry.lock();
1543 if (!retval) {
1544 throw std::logic_error("Entry pointer is no longer valid");
1545 }
1546 return retval;
1547 }
1548
1550 [[nodiscard]]
1553
1554private:
1556};
1557
1560{
1561public:
1563 NoteInfoPtr() : m_entry(), m_noteIndex(0) {}
1564
1568 NoteInfoPtr(const EntryInfoPtr& entryInfo, size_t noteIndex)
1569 : m_entry(entryInfo), m_noteIndex(noteIndex)
1570 {}
1571
1573 explicit operator bool() const noexcept
1574 { return m_entry && m_noteIndex < m_entry->getEntry()->notes.size(); }
1575
1578 [[nodiscard]]
1579 bool isSameNote(const NoteInfoPtr& src) const
1580 { return m_entry.isSameEntry(src.m_entry) && m_noteIndex == src.m_noteIndex; }
1581
1585 [[nodiscard]]
1586 NoteInfoPtr findEqualPitch(const EntryInfoPtr& entry) const;
1587
1589 [[nodiscard]]
1591 {
1592 MUSX_ASSERT_IF(m_noteIndex >= m_entry->getEntry()->notes.size()) {
1593 throw std::logic_error("Note index is too large for notes array.");
1594 }
1595 return m_entry->getEntry()->notes[m_noteIndex];
1596 }
1597
1599 [[nodiscard]]
1601 { return m_entry; }
1602
1604 [[nodiscard]]
1605 size_t getNoteIndex() const
1606 { return m_noteIndex; }
1607
1621 [[nodiscard]]
1622 Note::NoteProperties calcNoteProperties(EnharmonicOverride enharmonicOverride = EnharmonicOverride::None, bool alwaysUseEntryStaff = false) const;
1623
1631 [[nodiscard]]
1632 Note::NoteProperties calcNotePropertiesConcert(bool alwaysUseEntryStaff = false) const;
1633
1642 [[nodiscard]]
1643 Note::NoteProperties calcNotePropertiesInView(bool alwaysUseEntryStaff = false) const;
1644
1647 [[nodiscard]]
1649
1652 [[nodiscard]]
1654
1658 [[nodiscard]]
1659 NoteInfoPtr calcTieTo() const;
1660
1665 [[nodiscard]]
1666 NoteInfoPtr calcTieFrom(bool requireTie = true) const;
1667
1673 [[nodiscard]]
1674 CurveContourDirection calcFreezeTieDirection(bool forTieEnd = false) const;
1676
1682 [[nodiscard]]
1683 CurveContourDirection calcEffectiveTieDirection(bool forTieEnd = false) const;
1691 [[nodiscard]] bool calcHasOuterTie(bool forTieEnd = false) const;
1692
1700 [[nodiscard]] bool calcHasInnerTie(bool forTieEnd = false) const;
1701
1703 [[nodiscard]]
1704 StaffCmper calcStaff() const;
1705
1708 [[nodiscard]]
1709 std::unique_ptr<music_theory::Transposer> createTransposer() const;
1710
1713 [[nodiscard]]
1715 {
1716 if (m_noteIndex >= m_entry->getEntry()->notes.size()) {
1717 return NoteInfoPtr();
1718 }
1719 return NoteInfoPtr(m_entry, m_noteIndex + 1);
1720 }
1721
1724 [[nodiscard]]
1726 {
1727 if (m_noteIndex <= 0) {
1728 return NoteInfoPtr();
1729 }
1730 return NoteInfoPtr(m_entry, m_noteIndex - 1);
1731 }
1732
1734 [[nodiscard]]
1735 bool calcIsEnharmonicRespell() const;
1736
1746 [[nodiscard]]
1747 std::pair<int, int> calcDefaultEnharmonic() const
1748 { return (*this)->calcDefaultEnharmonic(m_entry.getKeySignature()); }
1749
1752 [[nodiscard]]
1754
1764 [[nodiscard]]
1766
1769 [[nodiscard]]
1770 bool calcIsIncludedInVoicing() const;
1771
1774 [[nodiscard]]
1775 bool calcIsTop() const;
1776
1779 [[nodiscard]]
1780 bool calcIsBottom() const;
1781
1804
1814
1818 {
1819 bool matched{};
1821 std::vector<TieStandInSource> sources{};
1822
1824 explicit operator bool() const noexcept { return matched; }
1825 };
1826
1830 [[nodiscard]]
1831 std::optional<ArpeggiatedTieInfo> calcArpeggiatedTieInfo() const;
1832
1835 [[nodiscard]]
1836 PseudoTieInfo calcPseudoLvTieInfo() const;
1837
1840 [[nodiscard]]
1841 PseudoTieInfo calcPseudoTieEndInfo() const;
1842
1849 [[nodiscard]]
1850 std::vector<std::pair<NoteInfoPtr, CurveContourDirection>> calcJumpTieContinuationsFrom() const;
1851
1852private:
1853 enum class TieFromSearchAction {
1854 Continue,
1855 Accept,
1856 Stop,
1857 };
1858
1859 static NoteInfoPtr findTieFromCandidate(const NoteInfoPtr& note, Cmper previousMeasure,
1860 const std::function<TieFromSearchAction(const NoteInfoPtr&, bool)>& decide);
1861
1863 [[nodiscard]]
1864 PseudoTieInfo calcPseudoTieInfoInternal(utils::PseudoTieMode mode) const;
1865
1867 [[nodiscard]]
1868 bool selectPseudoTieDirectionAndMatch(PseudoTieInfo* info,
1869 std::vector<CurveContourDirection>& directions,
1870 const std::vector<size_t>* eligibleNoteIndices = nullptr) const;
1871
1875 [[nodiscard]]
1876 bool isSamePitch(const NoteInfoPtr& src) const;
1877
1881 [[nodiscard]]
1882 bool isSamePitchValues(const NoteInfoPtr& src) const;
1883
1886 [[nodiscard]]
1887 NoteInfoPtr calcTieToWithNextMeasure(Cmper nextMeasure) const;
1888
1892 [[nodiscard]]
1893 NoteInfoPtr calcTieFromWithPreviousMeasure(Cmper previousMeasure, bool requireTie) const;
1894
1895 EntryInfoPtr m_entry;
1896 size_t m_noteIndex;
1897
1899 mutable std::optional<CurveContourDirection> m_tieDirection{};
1900};
1901
1902} // namespace dom
1903} // namespace entries
Wraps a reference to an existing object or owns a temporary value if needed.
Definition MusxInstance.h:194
Base for DOM classes that are represented in EnigmaData.
Definition BaseClasses.h:81
ShareMode
Describes how this instance is shared between part and score.
Definition BaseClasses.h:91
virtual void integrityCheck(const std::shared_ptr< EnigmaBase > &ptrToThis)
Performs a final consistency check after population.
Definition BaseClasses.h:125
Represents a vector of EntryInfo instances for a given frame, along with computed information.
Definition Entries.h:1180
util::Fraction getTimeStretch() const
Get the time stretch in this frame. Rather than accessing this value directly, consider using EntryIn...
Definition Entries.h:1348
util::Fraction maxElapsedStaffDuration
Definition Entries.h:1314
EntryFrame(const details::GFrameHoldContext &gfhold, LayerIndex layerIndex, util::Fraction timeStretch, const MusxInstance< others::StaffComposite > &startStaff)
Constructor function.
Definition Entries.h:1189
util::Fraction measureStaffDuration
The duration of the measure in staff duration units.
Definition Entries.h:1313
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:1440
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:1423
const std::vector< std::shared_ptr< const EntryInfo > > & getEntries() const
Get the entry list.
Definition Entries.h:1352
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:1327
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:1312
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:1323
LayerIndex getLayerIndex() const
Get the layer index (0..3) of the entry frame.
Definition Entries.h:1339
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:1311
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:1088
const EntryInfoPtr & getEntryInfo() const noexcept
Returns the entry at the current iterator position.
Definition Entries.h:1121
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:2249
InterpretedIterator getNext() const
Returns an iterator advanced to the next usable entry in this voice.
Definition Entries.cpp:2284
util::Fraction getEffectiveMeasureStaffDuration() const
Return the effective measure staff duration of the entry. Calling code using InterpretedIterator shou...
Definition Entries.cpp:2244
InterpretedIterator getPrevious() const
Returns an iterator advanced to the previous usable entry in this voice.
Definition Entries.cpp:2296
bool getEffectiveHidden() const noexcept
Returns whether the entry should be treated as hidden.
Definition Entries.h:1126
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:2228
util::Fraction getEffectiveElapsedDuration(bool global=false) const
Return the effective elapsed duration of the entry. Calling code using InterpretedIterator should use...
Definition Entries.cpp:2236
Wraps a frame of shared_ptr<const EntryInfo> and an index for per entry access. This class manages ow...
Definition Entries.h:513
bool calcUpStemDefault() const
Calculates if the entry is upstem by default, without considering voices, layers, staff options,...
Definition Entries.cpp:967
EntryInfoPtr getNextInFrame() const
Get the next entry in the frame.
Definition Entries.cpp:760
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:908
bool calcIsBeamStart(BeamIterationMode beamIterationMode=BeamIterationMode::Normal) const
Returns whether this is the start of a primary beam.
Definition Entries.cpp:1129
bool calcBeamMustStartHere() const
Determines if a beam must start on this entry.
Definition Entries.cpp:1124
EntryInfoPtr(const std::shared_ptr< const EntryFrame > &entryFrame, size_t index=0)
Constructor function.
Definition Entries.h:538
EntryInfoPtr getNextSameV() const
Get the next entry in the frame in the same voice.
Definition Entries.cpp:768
bool calcCanBeBeamed() const
Determines if this entry can be beamed.
Definition Entries.cpp:1111
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:1377
size_t getIndexInFrame() const
Returns the index within the frame.
Definition Entries.h:617
util::Fraction calcGlobalElapsedDuration() const
Calculates the elapsed duration in global edu, removing any time stretch due to independent time sign...
Definition Entries.cpp:1732
std::pair< bool, bool > calcEntryStemSettings() const
Returns the Entry stem settings for the current requested part. This function encapsulates handling o...
Definition Entries.cpp:686
EntryInfoPtr calcBeamContinuesLeftOverBarline() const
Determines if this entry continues a beam across a barline from the previous measure.
Definition Entries.cpp:1412
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:707
bool calcIfLayerSettingsApply() const
Calculates whether the conditions are met for the layer attributes dependent on others::LayerAttribut...
Definition Entries.cpp:2007
EntryInfoPtr getPreviousInVoice(int voice) const
Returns the previous entry in the frame in the specified v1/v2 or null if none.
Definition Entries.cpp:876
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:2166
unsigned calcReverseGraceIndex() const
Caclulates the grace index counting leftward (used by other standards such as MNX)
Definition Entries.cpp:703
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:857
MusxInstance< details::EntryPartFieldDetail > getPartFieldData() const
Gets the applicable part data for the entry, or nullptr if none.
Definition Entries.cpp:663
BeamIterationMode
Controls which entries are included when iterating over beams.
Definition Entries.h:518
@ 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:796
Evpu calcManuaOffset() const
Returns the manual offset of the entry for the current requested part. This function encapsulates han...
Definition Entries.cpp:678
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:749
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:1587
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:1250
unsigned calcLowestBeamStub() const
Returns the lowest beam stub at this entry, where 2 = 16th note stub, 3 = 32nd note stub,...
Definition Entries.cpp:1673
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:1973
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:715
unsigned calcLowestBeamEnd() const
Returns the lowest beam number ending at this entry, where 1 = 8th note beam, 2 = 16th note beam,...
Definition Entries.cpp:1629
LayerIndex getLayerIndex() const
Get the layer index (0..3) of the entry.
Definition Entries.cpp:655
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:2093
unsigned calcLowestBeamEndAcrossBarlines() const
Returns the lowest beam number ending at this entry, where 1 = 8th note beam, 2 = 16th note beam,...
Definition Entries.cpp:1652
StemDirection calcStemDirectionForced() const
Returns the forced stem direction if any.
Definition Entries.cpp:1061
unsigned calcNumberOfBeams() const
Calculates the number of beams or flags on the entry.
Definition Entries.cpp:1536
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:892
EntryInfoPtr getPreviousInFrame() const
Get the previous entry in the frame.
Definition Entries.cpp:834
std::shared_ptr< const EntryFrame > getFrame() const
Returns the frame.
Definition Entries.h:614
bool calcUpStem() const
Determines the effective stem direction of the entry, taking into account voices, layers,...
Definition Entries.h:767
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:1953
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:1501
bool calcDisplaysAsRest() const
Calculates if an entry displays as a rest.
Definition Entries.cpp:924
MusxInstance< KeySignature > getKeySignature() const
Get the key signature of the entry.
Definition Entries.cpp:661
bool calcIsCue(bool includeVisibleInScore=false) const
Calculates if this entry is part of a cue.
Definition Entries.cpp:1903
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:712
InterpretedIterator asInterpretedIterator(bool remapBeamOverBarlineEntries=true) const
Returns this EntryInfoPtr in a InterpretedIterator instance.
Definition Entries.cpp:886
bool calcCreatesSingletonBeamLeft() const
Determines if this entry contains a tuplet that creates a singleton beam left. See EntryFrame::Tuplet...
Definition Entries.cpp:1141
bool operator<(const EntryInfoPtr &other) const
Explicit operator< for std::map.
Definition Entries.h:993
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:823
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:728
std::pair< int, int > calcTopBottomStaffPositions() const
Calculates the top and bottom staff positions of the entry, taking into account percussion notes....
Definition Entries.cpp:942
StaffCmper getStaff() const
Get the staff cmper.
Definition Entries.cpp:657
EntryInfoPtr findBeamEnd() const
Finds the end entry of a beamed group.
Definition Entries.cpp:1518
int calcEntrySize() const
Returns the entry size as a percentage, taking into account the beaming.
Definition Entries.cpp:1889
EntryInfoPtr getPreviousSameV() const
Get the previous entry in the frame in the same voice.
Definition Entries.cpp:842
int calcCrossStaffDirectionForAll(DeferredReference< MusxInstanceList< others::StaffUsed > > staffList={}) const
Calculates if this entry has cross-staffed notes all in a single direction.
Definition Entries.cpp:2048
MusxInstance< others::StaffComposite > createCurrentStaff(const std::optional< StaffCmper > &forStaffId=std::nullopt) const
Creates the current StaffComposite for the entry.
Definition Entries.cpp:695
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:1325
bool calcIsTrillToGraceEntry() const
Calculates if this entry is a trill-to entry as created by the Parenthesize Trill-To Notes plugin.
Definition Entries.cpp:2116
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:2105
EntryInfoPtr getNextInVoice(int voice) const
Returns the next entry in the frame in the specified v1/v2 or null if none.
Definition Entries.cpp:866
EntryInfoPtr calcBeamContinuesRightOverBarline() const
Determines if this entry continues a beam across a barline to the next measure.
Definition Entries.cpp:1456
std::optional< StaffCmper > calcCrossedStaffForAll() const
Calculates all the notes in this entry are crossed to the same staff.
Definition Entries.cpp:2072
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:1102
NoteInfoPtr findNoteId(NoteNumber noteId) const
Returns a NoteInfoPtr for the note specified by noteId within this entry.
Definition Entries.cpp:644
EntryInfoPtr()
Default constructor.
Definition Entries.h:531
bool calcCreatesSingletonBeamRight() const
Determines if this entry contains a tuplet that creates a singleton beam right. See EntryFrame::Tuple...
Definition Entries.cpp:1152
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:1683
bool calcIsGlissToGraceEntry() const
Calculates if this entry is a gliss-to entry as created by the Parenthesize Trill-To Notes plugin.
Definition Entries.cpp:2139
bool calcIsFullMeasureRest() const
Returns whether this is a full measure rest.
Definition Entries.cpp:1929
util::Fraction calcGlobalActualDuration() const
Calculates the actual duration in global edu, removing any time stretch due to independent time signa...
Definition Entries.cpp:1737
MeasCmper getMeasure() const
Get the measure cmper.
Definition Entries.cpp:659
EntryInfoPtr getNextSameVNoGrace() const
Get the next entry in the frame in the same voice, skipping grace notes.
Definition Entries.cpp:786
std::vector< size_t > findTupletInfo() const
Finds the tuplet info for tuplets that include this entry.
Definition Entries.cpp:1993
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:1854
Information an entry along with the entry.
Definition Entries.h:1513
unsigned graceIndex
Definition Entries.h:1532
ClefIndex clefIndex
the clef index in effect for the entry.
Definition Entries.h:1534
util::Fraction calcNextElapsedDuration() const
Calculates the next duration position after this entry.
Definition Entries.h:1551
util::Fraction cumulativeRatio
Definition Entries.h:1530
util::Fraction elapsedDuration
Definition Entries.h:1526
ClefIndex clefIndexConcert
the concert clef index in effect for the entry.
Definition Entries.h:1535
util::Fraction actualDuration
Definition Entries.h:1528
MusxInstance< Entry > getEntry() const
Get the entry.
Definition Entries.h:1540
Represents an entry containing metadata and notes.
Definition Entries.h:357
bool splitStem
Definition Entries.h:405
Entry(const DocumentWeakPtr &document, Cmper partId, ShareMode shareMode, EntryNumber entnum, EntryNumber prev, EntryNumber next)
Constructor function.
Definition Entries.h:363
EntryNumber getEntryNumber() const
Gets the entry number for this entry.
Definition Entries.h:445
bool articDetail
Indicates there is an articulation on the entry.
Definition Entries.h:387
bool upStemScore
Whether a stem is up or down as set in the score. (Only reliable when freezeStemScore is true....
Definition Entries.h:407
bool isNote
If this value is false, the entry is a rest.
Definition Entries.h:380
bool noLeger
Hide ledger lines.
Definition Entries.h:412
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:418
bool voice2
This is a V2 note. (xml node <v2>)
Definition Entries.h:382
bool splitRest
Indicates that rests in different layers are not combined on this entry.
Definition Entries.h:390
bool beamExt
Indicates that there is a beam extension on the entry.
Definition Entries.h:394
bool createdByHP
Indicates the entry was created by Finale's smart playback engine.
Definition Entries.h:383
static constexpr std::string_view XmlNodeName
The XML node name for this type.
Definition Entries.h:496
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:398
bool stemDetail
Indicates there are stem modifications.
Definition Entries.h:400
bool slashGrace
Definition Entries.h:414
bool isValid
Should always be true but otherwise appears to be used internally by Finale.
Definition Entries.h:379
bool playDisabledByHP
Used by Finale's smart playback engine.
Definition Entries.h:384
bool flipTie
Indicates the existence of a flipped tie, either in Speedy Entry or Layer Attributes.
Definition Entries.h:395
bool flatBeam
Forces any beam that starts on this entry to be flat by default.
Definition Entries.h:417
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:423
bool dummy
Definition Entries.h:409
Evpu hOffsetScore
Manual offset created with the Note Position Tool in the score. (xml node is <posi>....
Definition Entries.h:378
bool checkAccis
Used by Finale to convert pre-2014 .mus files. May never be saved in .musx.
Definition Entries.h:408
bool noteDetail
Indicates there is a note detail or EntrySize record for the entry.
Definition Entries.h:386
util::Fraction calcFraction() const
Calculates the duration as a util::Fraction of a whole note.
Definition Entries.h:469
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:474
bool crossStaff
Signifies that at least one note in the entry has been cross staffed.
Definition Entries.h:401
bool floatRest
Is floating rest. If false, the first note element gives the staff position of the rest.
Definition Entries.h:392
bool smartShapeDetail
Indicates this entry has a smart shape assignment.
Definition Entries.h:411
Edu duration
Duration of the entry, not taking into account tuplets.
Definition Entries.h:376
bool isHidden
Indicates the entry is hidden, (xml node is <ignore>)
Definition Entries.h:393
void integrityCheck(const std::shared_ptr< EnigmaBase > &ptrToThis) override
Performs a final consistency check after population.
Definition Entries.h:484
bool tupletStart
Indicates that a tuplet start on the entry.
Definition Entries.h:389
bool lyricDetail
Indicates there is a lyric assignment on the entry.
Definition Entries.h:388
int numNotes
Number of notes in the entry. There is an error if this is not the same as notes.size().
Definition Entries.h:377
bool sorted
Sorted flag.
Definition Entries.h:413
bool reverseDownStem
Indicates that a stem normally down is reversed.
Definition Entries.h:403
bool reverseUpStem
Indicates that a stem normally up is reversed.
Definition Entries.h:402
bool v2Launch
Indicates if this entry (which is voice1) launches a voice2 sequence. (xml node is <controller>)
Definition Entries.h:381
bool doubleStem
Creates a double stem on the entry. (Appears to be exclusive with splitStem.)
Definition Entries.h:404
bool isPossibleFullMeasureRest() const
Returns true if the entry could be a full-measure rest.
Definition Entries.h:481
bool beam
Signifies the start of a beam or singleton entry. (That is, any beam breaks at this entry....
Definition Entries.h:397
bool freezeStemScore
Freeze stem flag in the score. (upStemScore gives the direction.)
Definition Entries.h:399
bool performanceData
Indicates there is performance data on the entry.
Definition Entries.h:391
bool noSpacing
Indicates that the entry should be ignored when calculating music spacing.
Definition Entries.h:419
bool dotTieAlt
Indicates dot or tie alterations are present.
Definition Entries.h:396
bool freezeBeam
Freeze beam flag (Derived from the presence of <freezeBeam> node.)
Definition Entries.h:420
struct musx::dom::Entry::EntryLocation location
The location of this entry.
bool graceNote
Indicate the entry is a grace note.
Definition Entries.h:385
Duration calcDurationInfo() const
Calculates the NoteType and number of augmentation dots. (See calcDurationInfoFromEdu....
Definition Entries.h:463
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:118
Wraps an EntryInfo instance and a note index.
Definition Entries.h:1560
CurveContourDirection calcFreezeTieDirection(bool forTieEnd=false) const
Calculates the user-frozen tie direction for this note, if any.
Definition Entries.cpp:2883
size_t getNoteIndex() const
Gets the note index for this note.
Definition Entries.h:1605
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:1600
MusxInstance< others::PercussionNoteInfo > calcPercussionNoteInfo() const
Calculates the percussion note info for this note, if any.
Definition Entries.cpp:2989
MusxInstance< Note > operator->() const
Allows -> access to the underlying Note instance.
Definition Entries.h:1590
bool calcHasInnerTie(bool forTieEnd=false) const
Determines whether this note has an inner tie at the specified endpoint.
Definition Entries.cpp:2911
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:3322
bool isSameNote(const NoteInfoPtr &src) const
Returns whether the input and the current instance refer to the same note.
Definition Entries.h:1579
StaffCmper calcStaff() const
Calculates the staff number, taking into account cross staffing.
Definition Entries.cpp:2921
bool calcIsBottom() const
Return true if this is the bottom note in the entry.
Definition Entries.cpp:3121
CurveContourDirection calcEffectiveTieDirection(bool forTieEnd=false) const
Determines whether this note has an outer tie at the specified endpoint.
Definition Entries.cpp:2893
NoteInfoPtr getPrevious() const
Gets the next note in a chord on the same entry.
Definition Entries.h:1725
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:2963
bool calcIsEnharmonicRespellInAnyPart() const
Calculates if any linked part has this note enharmonically respelled.
Definition Entries.cpp:3026
NoteInfoPtr calcTieFrom(bool requireTie=true) const
Calculates the note that this note could tie from.
Definition Entries.cpp:2878
PseudoTieInfo calcPseudoTieEndInfo() const
Calculates whether this note has a stand-in tie-end and returns tie metadata. For a match,...
Definition Entries.cpp:3170
bool calcIsIncludedInVoicing() const
Returns true if this note is included in the part voicing. This function returns the correct value ev...
Definition Entries.cpp:3095
bool calcHasOuterTie(bool forTieEnd=false) const
Determines whether this note has an outer tie at the specified endpoint.
Definition Entries.cpp:2901
bool calcIsEnharmonicRespell() const
Returns if this note is enharmonically respelled in the current part view.
Definition Entries.cpp:3015
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:1747
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:2979
int calcCrossStaffDirection(DeferredReference< MusxInstanceList< others::StaffUsed > > staffList={}) const
Calculates if this note is cross-staffed and if so, which direction.
Definition Entries.cpp:3072
PseudoTieInfo calcPseudoLvTieInfo() const
Calculates whether this note has a stand-in laissez-vibrer tie and returns tie metadata....
Definition Entries.cpp:3165
NoteInfoPtr(const EntryInfoPtr &entryInfo, size_t noteIndex)
Constructor.
Definition Entries.h:1568
std::optional< ArpeggiatedTieInfo > calcArpeggiatedTieInfo() const
If this note has a smart shape acting as an arpeggio tie, returns tie metadata. If this note is part ...
Definition Entries.cpp:3139
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:2873
bool calcIsTop() const
Return true if this is the top note in the entry.
Definition Entries.cpp:3103
NoteInfoPtr findEqualPitch(const EntryInfoPtr &entry) const
Finds a note with the same pitch in the supplied entry.
Definition Entries.cpp:2732
NoteInfoPtr getNext() const
Gets the next note in a chord on the same entry.
Definition Entries.h:1714
NoteInfoPtr()
Default constructor.
Definition Entries.h:1563
std::unique_ptr< music_theory::Transposer > createTransposer() const
Creates a transposer for this Note instance.
Definition Entries.cpp:3010
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:2936
Represents a single note element in an entry.
Definition Entries.h:258
bool upStemSecond
When the entry is upstem, it is drawn on the "wrong" side of the stem.
Definition Entries.h:284
bool isValid
Should always be true but otherwise appears to be used internally by Finale.
Definition Entries.h:280
bool playDisabledByHP
Used by Finale's smart playback engine.
Definition Entries.h:295
static constexpr NoteNumber RESTID
Non floating rests have a note with this noteId that defines their staff positions.
Definition Entries.h:267
int harmAlt
Chromatic alteration relative to the key signature. Never has a magnitude greater than +/-7.
Definition Entries.h:279
bool upSplitStem
Definition Entries.h:288
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:300
bool tieEnd
Indicates a tie ends on this note.
Definition Entries.h:282
Note(const DocumentWeakPtr &document, NoteNumber noteId)
Constructor function.
Definition Entries.h:261
bool tieStart
Indicates a tie starts on this note.
Definition Entries.h:281
bool crossStaff
Signifies that the note has a details::CrossStaff note detail.
Definition Entries.h:283
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:2651
int harmLev
Diatonic displacement relative to middle C or to the tonic in the middle C octave (if the key signatu...
Definition Entries.h:278
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:286
std::tuple< music_theory::NoteName, int, int, int > NoteProperties
Note properites. A tuple containing:
Definition Entries.h:276
bool noPlayback
Indicates that this note should not be played back.
Definition Entries.h:292
bool parenAcci
True if the accidental has parentheses.
Definition Entries.h:291
bool noSpacing
Indicates that this note should ignored when calculating spacing.
Definition Entries.h:293
bool showAcci
True if the note has an accidental. (Dynamically changed by Finale unless freezeAcci is set....
Definition Entries.h:290
bool freezeAcci
True if the accidental should be forced on or off (based on showAcci.)
Definition Entries.h:294
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:2686
A context wrapper for GFrameHold associated with a specific part and location.
Definition Entries.h:68
const GFrameHold * operator->() const
Provides const pointer-style access to the underlying GFrameHold.
Definition Entries.h:121
MusxInstance< others::PartVoicing > getPolicyPartVoicing() const
Returns the part voicing for the requested part, based on the document's PartVoicingPolicy.
Definition Entries.h:113
MusxInstance< others::PartVoicing > getPartVoicing() const
Returns the part voicing for the requested part.
Definition Entries.h:105
std::map< LayerIndex, int > calcVoices(bool excludeHidden=false) const
Calculates the number of voices used by the GFrameHold instance.
Definition Entries.cpp:2499
std::shared_ptr< const EntryFrame > createEntryFrame(LayerIndex layerIndex) const
Returns the EntryFrame for all entries in the given layer.
Definition Entries.cpp:2362
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:221
util::Fraction snapLocationToEntryOrKeep(util::Fraction location, bool findExact=true) const
Snaps a measure position to the nearest entry if possible.
Definition Entries.cpp:2611
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:140
util::Fraction calcMinLegacyPickupSpacer() const
Calculates the minimum legacy pickup spacer, if any.
Definition Entries.cpp:2622
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:2480
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:2554
bool calcVoicingIncludesLayer(LayerIndex layerIndex) const
Calculates if the part voicing for the current requested part includes the specified layer....
Definition Entries.cpp:2639
bool calcPolicyVoicingIncludesLayer(LayerIndex layerIndex) const
Similar to calcVoicingIncludesLayer, but honoring the document's part voicing policy.
Definition Entries.h:215
Cmper getRequestedPartId() const
Returns the requested part ID associated with this context.
Definition Entries.h:97
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:2579
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:2528
Represents the attributes of a Finale frame holder.
Definition Details.h:1128
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
@ Unspecified
contour is automatic, indeterminate, or does not apply
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:40
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
StemDirection
Three-state stem direction setting or override.
Definition EnumClasses.h:174
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 DocumentElement.h:37
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 DocumentElement.h:35
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:45
std::vector< XmlElementDescriptor< T > > XmlElementArray
an array type for XmlElementDescriptor instances.
Definition XmlInterface.h:127
object model for musx file (enigmaxml)
Definition BaseClasses.h:38
class to track tuplets in the frame
Definition Entries.h:1199
size_t startIndex
the index of the first entry in the tuplet
Definition Entries.h:1201
bool calcCreatesSingletonBeamRight() const
Calculates if this tuplet is being used to create a singleton beam to the right.
Definition Entries.h:1260
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:1208
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:1202
bool includesEntry(const EntryInfoPtr &entryInfo) const
Return true if the entry is part of this tuplet.
Definition Entries.h:1226
util::Fraction endDura
the actual duration where the tuplet ends
Definition Entries.h:1204
size_t numEntries() const
Return the number of entries in the tuplet.
Definition Entries.h:1215
util::Fraction startDura
the actual duration where the tuplet starts
Definition Entries.h:1203
bool calcCreatesSingletonBeamLeft() const
Calculates if this tuplet is being used to create a singleton beam to the left.
Definition Entries.h:1272
MusxInstance< details::TupletDef > tuplet
the tuplet
Definition Entries.h:1200
bool voice2
whether this tuplet is for voice2
Definition Entries.h:1205
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:431
void clear()
Clears the entry location. (Mainly used for benchmarking.)
Definition Entries.h:440
size_t entryIndex
The 0-based index of this entry within its layer.
Definition Entries.h:435
bool found() const
Returns if this entry has been found.
Definition Entries.h:438
MeasCmper measureId
The measure containing this entry.
Definition Entries.h:433
LayerIndex layerIndex
The layer containing this entry within the measure.
Definition Entries.h:434
StaffCmper staffId
The staff containing this entry.
Definition Entries.h:432
Metadata for a smart-shape arpeggiated tie match.
Definition Entries.h:1808
CurveContourDirection direction
Contour direction reported by the source smart shape.
Definition Entries.h:1811
size_t targetNoteIndex
Note index within targetEntry.
Definition Entries.h:1810
Cmper smartShapeId
Cmper of the smart shape that produced the match.
Definition Entries.h:1812
EntryInfoPtr targetEntry
Entry containing the tied-to note.
Definition Entries.h:1809
Metadata for pseudo tie and pseudo tie-end detection.
Definition Entries.h:1818
std::vector< TieStandInSource > sources
Contributing surrogate tie sources from the winning source type.
Definition Entries.h:1821
bool matched
True when this note satisfies the pseudo tie criteria.
Definition Entries.h:1819
CurveContourDirection direction
Resolved contour direction for this note.
Definition Entries.h:1820
Identifies one surrogate tie source matched for a note.
Definition Entries.h:1789
std::optional< Inci > sourceInci
Optional incidence index for sources that are inci-addressed.
Definition Entries.h:1801
Type
The category of source that produced the pseudo tie candidate.
Definition Entries.h:1793
@ ShapeExpression
Measure expression assignment with a tie-like shape.
@ SmartShape
Smart shape record from the Others pool.
@ ShapeArticulation
Articulation assignment with a tie-like shape.
CurveContourDirection direction
Contour direction resolved for this source.
Definition Entries.h:1802
Cmper sourceId
Source identifier within the source category.
Definition Entries.h:1800
Type type
The matched source category.
Definition Entries.h:1799