MUSX Document Model
Loading...
Searching...
No Matches
Details.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#include <functional>
24#include <vector>
25#include <unordered_set>
26#include <cmath>
27#include <map>
28
29#include "music_theory/music_theory.hpp"
30
31#include "musx/util/EnigmaString.h"
32#include "MusxInstance.h"
33#include "BaseClasses.h"
34#include "CommonClasses.h"
35#include "Options.h"
36#include "Others.h"
37#include "Staff.h"
38 // do not add other dom class dependencies. Use Implementations.h for implementations that need total class access.
39
40namespace musx {
41namespace dom {
42
43class EntryInfoPtr;
44class EntryFrame;
45class EntryInfo;
46
47namespace others {
48class ChordSuffixElement;
49class FretboardGroup;
50class FretInstrument;
51class FretboardStyle;
52class StaffUsed;
53class Measure;
54class MultiStaffInstrumentGroup;
55class TextBlock;
56} // namespace others
57
58namespace texts {
59class ExpressionText;
60class LyricsChorus;
61class LyricsSection;
62class LyricsVerse;
63} // namespace others
64
69namespace details {
70
80{
81public:
83 explicit AccidentalAlterations(const DocumentWeakPtr& document, Cmper partId, ShareMode shareMode, EntryNumber entnum, Inci inci)
84 : NoteDetailsBase(document, partId, shareMode, entnum, inci), customFont(std::make_shared<FontInfo>(document))
85 {
86 }
87
89 int percent{};
92 char32_t altChar{};
93 std::shared_ptr<FontInfo> customFont;
94 bool useOwnFont{};
95 bool allowVertPos{};
96
97 NoteNumber getNoteId() const override { return noteId; }
98
99 constexpr static std::string_view XmlNodeName = "acciAlter";
101};
102
110{
111public:
120 explicit ArticulationAssign(const DocumentWeakPtr& document, Cmper partId, ShareMode shareMode, EntryNumber entnum, Inci inci)
121 : EntryDetailsBase(document, partId, shareMode, entnum, inci) {}
122
129 bool aboveEntry{};
130 bool hide{};
131 bool neverStack{};
132 bool avoidSlur{};
134
136 constexpr static std::string_view XmlNodeName = "articAssign";
137};
138
152class Baseline : public DetailsBase
153{
154public:
164 explicit Baseline(const DocumentWeakPtr& document, Cmper partId, ShareMode shareMode, Cmper system, Cmper staff, std::optional<Inci> inci)
165 : DetailsBase(document, partId, shareMode, system, staff, inci) {}
166
170 std::optional<Cmper> lyricNumber{};
171
173};
174
180{
181public:
190 explicit BaselineNoInci(const DocumentWeakPtr& document, Cmper partId, ShareMode shareMode, Cmper system, Cmper staff)
191 : Baseline(document, partId, shareMode, system, staff, std::nullopt) {}
192};
193
199{
200public:
202
203 constexpr static std::string_view XmlNodeName = "baselinesSysChords";
204};
205
211{
212public:
214
215 constexpr static std::string_view XmlNodeName = "baselinesSysExprAboveStaff";
216};
217
223{
224public:
226
227 constexpr static std::string_view XmlNodeName = "baselinesSysExprBelowStaff";
228};
229
235{
236public:
238
239 constexpr static std::string_view XmlNodeName = "baselinesSysFingerboards";
240};
241
247{
248public:
249 using Baseline::Baseline;
250
251 constexpr static std::string_view XmlNodeName = "baselinesSysLyricsChorus";
252};
253
259{
260public:
261 using Baseline::Baseline;
262
263 constexpr static std::string_view XmlNodeName = "baselinesSysLyricsSection";
264};
265
271{
272public:
273 using Baseline::Baseline;
274
275 constexpr static std::string_view XmlNodeName = "baselinesSysLyricsVerse";
276};
277
285{
286public:
288
290 constexpr static std::string_view XmlNodeName = "baselinesChords";
291};
292
300{
301public:
303
305 constexpr static std::string_view XmlNodeName = "baselinesExprAboveStaff";
306};
307
315{
316public:
318
320 constexpr static std::string_view XmlNodeName = "baselinesExprBelowStaff";
321};
322
330{
331public:
333
335 constexpr static std::string_view XmlNodeName = "baselinesFingerboards";
336};
337
345{
346public:
347 using Baseline::Baseline;
348
351 constexpr static std::string_view XmlNodeName = "baselinesLyricsChorus";
352};
353
361{
362public:
363 using Baseline::Baseline;
364
367 constexpr static std::string_view XmlNodeName = "baselinesLyricsSection";
368};
369
377{
378public:
379 using Baseline::Baseline;
380
383 constexpr static std::string_view XmlNodeName = "baselinesLyricsVerse";
384};
385
393{
394private:
395 bool m_active = true; // this value is set by the factory.
396
397protected:
399 template <typename SecondaryBeamType>
400 static bool calcIsFeatheredBeamImpl(const EntryInfoPtr& entryInfo, Evpu& outLeftY, Evpu& outRightY);
401
402public:
411 explicit BeamAlterations(const DocumentWeakPtr& document, Cmper partId, ShareMode shareMode, EntryNumber entnum, std::optional<Inci> inci = std::nullopt)
412 : EntryDetailsBase(document, partId, shareMode, entnum, inci) {}
413
416
425
430
433 bool isActive() const { return m_active; }
434
436 template <typename T,
437 std::enable_if_t<std::is_base_of_v<BeamAlterations, T>, int> = 0>
438 static void calcAllActiveFlags(const DocumentPtr& document);
439
441};
442
450{
451public:
459 explicit BeamAlterationsDownStem(const DocumentWeakPtr& document, Cmper partId, ShareMode shareMode, EntryNumber entnum)
460 : BeamAlterations(document, partId, shareMode, entnum) {}
461
462 constexpr static std::string_view XmlNodeName = "beamAltPrimDownStem";
463};
464
472{
473public:
481 explicit BeamAlterationsUpStem(const DocumentWeakPtr& document, Cmper partId, ShareMode shareMode, EntryNumber entnum)
482 : BeamAlterations(document, partId, shareMode, entnum) {}
483
484 constexpr static std::string_view XmlNodeName = "beamAltPrimUpStem";
485};
486
495{
496public:
504 explicit BeamExtension(const DocumentWeakPtr& document, Cmper partId, ShareMode shareMode, EntryNumber entnum)
505 : EntryDetailsBase(document, partId, shareMode, entnum) {}
506
509 unsigned mask{};
516
518};
519
525{
526public:
528
529 constexpr static std::string_view XmlNodeName = "beamExtendDownStem";
530};
531
537{
538public:
540
541 constexpr static std::string_view XmlNodeName = "beamExtendUpStem";
542};
543
553{
554public:
556 explicit BeamStubDirection(const DocumentWeakPtr& document, Cmper partId, ShareMode shareMode, EntryNumber entnum)
557 : EntryDetailsBase(document, partId, shareMode, entnum)
558 {
559 }
560
561 unsigned mask{};
564
566 bool isLeft() const { return mask != 0; }
567
568 constexpr static std::string_view XmlNodeName = "beamStub";
570};
571
584class Bracket : public DetailsBase
585{
586public:
588 explicit Bracket(const DocumentWeakPtr& document, Cmper partId, ShareMode shareMode, Cmper cmper1, Cmper cmper2, Inci inci)
589 : DetailsBase(document, partId, shareMode, cmper1, cmper2, inci)
590 {
591 }
592
594 explicit Bracket(const DocumentWeakPtr& document)
595 : DetailsBase(document, SCORE_PARTID, Base::ShareMode::All, 0, 0, 0)
596 {
597 }
598
603 enum class BracketStyle : int
604 {
605 None = 0,
606 ThickLine = 1,
608 PianoBrace = 3,
609 Unknown4,
610 Unknown5,
612 Unknown7,
613 DeskBracket = 8
614 };
615
621
622 constexpr static std::string_view XmlNodeName = "brackSpec";
624};
625
634{
635 Cmper calcFretboardGroupCmper() const;
636
637public:
647 explicit ChordAssign(const DocumentWeakPtr& document, Cmper partId, ShareMode shareMode, Cmper staffId, Cmper meas, Inci inci)
648 : DetailsBase(document, partId, shareMode, staffId, meas, inci)
649 {
650 }
651
656 enum class BassPosition
657 {
658 AfterRoot, // default value may not appear in xml (but text appears in Finale binary)
659 UnderRoot,
660 Subtext
661 };
662
669 int rootAlter{};
671 bool playSuffix{};
672 bool showRoot{};
673 bool playRoot{};
675 bool showSuffix{};
678 int bassAlter{};
681 bool showAltBass{};
682 bool playAltBass{};
683 int capoValue{};
695 int chPercent{};
696 int fbPercent{};
697
700
704
708
709 constexpr static std::string_view XmlNodeName = "chordAssign";
711};
712
727class ClefOctaveFlats : public DetailsArray<int, 7>
728{
729 std::string_view xmlTag() const override { return XmlNodeName; }
730
731public:
733
734 constexpr static std::string_view XmlNodeName = "clefOctvFlats";
736};
737
756class ClefOctaveSharps : public DetailsArray<int, 7>
757{
758 std::string_view xmlTag() const override { return XmlNodeName; }
759
760public:
762
763 constexpr static std::string_view XmlNodeName = "clefOctvSharps";
765};
766
776{
777public:
779 explicit CrossStaff(const DocumentWeakPtr& document, Cmper partId, ShareMode shareMode, EntryNumber entnum, Inci inci)
780 : NoteDetailsBase(document, partId, shareMode, entnum, inci)
781 {
782 }
783
786
787 NoteNumber getNoteId() const override { return noteId; }
788
789 constexpr static std::string_view XmlNodeName = "crossStaff";
791};
792
802{
803public:
811 explicit CustomStem(const DocumentWeakPtr& document, Cmper partId, ShareMode shareMode, EntryNumber entnum)
812 : EntryDetailsBase(document, partId, shareMode, entnum) {}
813
817
824 bool calcIsHiddenStem() const;
825
827};
828
836{
837public:
839
840 constexpr static std::string_view XmlNodeName = "stemDefDown";
841};
842
850{
851public:
853
854 constexpr static std::string_view XmlNodeName = "stemDefUp";
855};
856
866{
867public:
869 explicit DotAlterations(const DocumentWeakPtr& document, Cmper partId, ShareMode shareMode, EntryNumber entnum, Inci inci)
870 : NoteDetailsBase(document, partId, shareMode, entnum, inci)
871 {
872 }
873
878
879 NoteNumber getNoteId() const override { return noteId; }
880
881 constexpr static std::string_view XmlNodeName = "dotOffset";
883};
884
894{
895public:
903 explicit EntrySize(const DocumentWeakPtr& document, Cmper partId, ShareMode shareMode, EntryNumber entnum)
904 : EntryDetailsBase(document, partId, shareMode, entnum) {}
905
906 int percent{};
907
909 constexpr static std::string_view XmlNodeName = "entrySize";
910};
911
925{
926public:
930 explicit FretboardDiagram(const DocumentWeakPtr& document, Cmper partId, ShareMode shareMode, Cmper cmper1, Cmper cmper2)
931 : DetailsBase(document, partId, shareMode, cmper1, cmper2)
932 {}
933
941 enum class Shape
942 {
943 None,
944 Closed,
945 Open,
946 Muted,
947 Custom
948 };
949
954 class Cell
955 {
956 public:
957 int string{};
958 int fret{};
960 int fingerNum{};
961
963 };
964
969 class Barre
970 {
971 public:
972 int fret{};
974 int endString{};
975
977 };
978
979 int numFrets{};
981 bool lock{};
982 bool showNum{};
985
986 std::vector<std::shared_ptr<Cell>> cells;
987 std::vector<std::shared_ptr<Barre>> barres;
988
989 void integrityCheck(const std::shared_ptr<Base>& ptrToThis) override
990 {
991 this->DetailsBase::integrityCheck(ptrToThis);
992 if (numFretCells != int(cells.size())) {
993 const int oldVal = numFretCells;
994 numFretCells = int(cells.size());
995 MUSX_INTEGRITY_ERROR("FretboardDiagram " + std::to_string(getCmper1()) + ", " + std::to_string(getCmper2())
996 + " specifies the wrong number of cells (" + std::to_string(oldVal) + ").");
997 }
998 if (numFretBarres != int(barres.size())) {
999 const int oldVal = numFretBarres;
1000 numFretBarres = int(barres.size());
1001 MUSX_INTEGRITY_ERROR("FretboardDiagram " + std::to_string(getCmper1()) + ", " + std::to_string(getCmper2())
1002 + " specifies the wrong number of barres (" + std::to_string(oldVal) + ").");
1003 }
1004 }
1005
1006 constexpr static std::string_view XmlNodeName = "fretboard";
1008};
1009
1018{
1019public:
1028 explicit GFrameHold(const DocumentWeakPtr& document, Cmper partId, ShareMode shareMode, Cmper staffId, Cmper meas)
1029 : DetailsBase(document, partId, shareMode, staffId, meas), frames(MAX_LAYERS) {}
1030
1031 // Public properties corresponding to the XML structure
1032 std::optional<ClefIndex> clefId;
1038 std::vector<Cmper> frames;
1039
1042
1045
1047 bool calcIsMultiLayer() const
1048 {
1049 return std::count_if(frames.begin(), frames.end(), [](Cmper frameId) { return frameId != 0; }) > 1;
1050 }
1051
1054 {
1055 return std::find_if(frames.begin(), frames.end(), [](Cmper frameId) { return frameId != 0; }) != frames.end();
1056 }
1057
1058 void integrityCheck(const std::shared_ptr<Base>& ptrToThis) override
1059 {
1060 this->DetailsBase::integrityCheck(ptrToThis);
1061 if (clefListId && clefId.has_value()) {
1062 MUSX_INTEGRITY_ERROR("GFrameHold for staff " + std::to_string(getCmper1()) + " and measure " + std::to_string(getCmper2()) + " has both clef and clef list.");
1063 }
1064 if (!clefListId && !clefId.has_value()) {
1065 MUSX_INTEGRITY_ERROR("GFrameHold for staff " + std::to_string(getCmper1()) + " and measure " + std::to_string(getCmper2()) + " has neither clef nor clef list.");
1066 }
1067 }
1068
1069 constexpr static std::string_view XmlNodeName = "gfhold";
1071};
1072
1081{
1082public:
1091 explicit IndependentStaffDetails(const DocumentWeakPtr& document, Cmper partId, ShareMode shareMode, Cmper staffId, Cmper meas)
1092 : DetailsBase(document, partId, shareMode, staffId, meas)
1093 {
1094 }
1095
1096 // Key signature info
1097 std::shared_ptr<KeySignature> keySig;
1098 bool hasKey{};
1099
1100 // Time signature info
1105
1108 bool altNumTsig{};
1109 bool altDenTsig{};
1112 bool hasTime{};
1113
1116
1120
1121 void integrityCheck(const std::shared_ptr<Base>& ptrToThis) override
1122 {
1123 DetailsBase::integrityCheck(ptrToThis);
1124 if (hasKey && !keySig) {
1125 keySig = std::make_shared<KeySignature>(getDocument());
1126 }
1127 }
1128
1129 constexpr static std::string_view XmlNodeName = "floats";
1131};
1132
1141public:
1143 explicit KeySymbolListElement(const DocumentWeakPtr& document, Cmper partId, ShareMode shareMode, Cmper cmper1, Cmper cmper2)
1144 : DetailsBase(document, partId, shareMode, cmper1, cmper2) {}
1145
1146 std::string accidentalString;
1148
1151 return static_cast<int16_t>(getCmper2());
1152 }
1153
1154 void integrityCheck(const std::shared_ptr<Base>& ptrToThis) override
1155 {
1156 DetailsBase::integrityCheck(ptrToThis);
1157 if (std::abs(getAlterationValue()) > MAX_ALTERATIONS) {
1159 "KeySymbolListElement for list " + std::to_string(getCmper1()) + " has invalid value " + std::to_string(getAlterationValue()));
1160 }
1161 }
1162
1163 constexpr static std::string_view XmlNodeName = "keySymList";
1165};
1166
1172{
1173protected:
1177 template <typename TextType>
1179
1180public:
1189 explicit LyricAssign(const DocumentWeakPtr& document, Cmper partId, ShareMode shareMode, EntryNumber entnum, Inci inci)
1190 : EntryDetailsBase(document, partId, shareMode, entnum, inci) {}
1191
1193 unsigned syllable{};
1201
1203};
1204
1212{
1213public:
1215
1220 { return LyricAssign::getRawTextCtx<TextType>(); }
1221
1223 constexpr static std::string_view XmlNodeName = "lyrDataChorus";
1224};
1225
1233{
1234public:
1236
1241 { return LyricAssign::getRawTextCtx<TextType>(); }
1242
1244 constexpr static std::string_view XmlNodeName = "lyrDataSection";
1245};
1246
1254{
1255public:
1257
1262 { return LyricAssign::getRawTextCtx<TextType>(); }
1263
1265 constexpr static std::string_view XmlNodeName = "lyrDataVerse";
1266};
1267
1276{
1277public:
1280
1289 explicit LyricEntryInfo(const DocumentWeakPtr& document, Cmper partId, ShareMode shareMode, EntryNumber entnum, std::optional<Inci> inci = std::nullopt)
1290 : EntryDetailsBase(document, partId, shareMode, entnum, inci) {}
1291
1292 std::optional<AlignJustify> justify{};
1293 std::optional<AlignJustify> align{};
1294
1296 constexpr static std::string_view XmlNodeName = "lyricEntryInfo";
1297};
1298
1307{
1308public:
1318 explicit MeasureNumberIndividualPositioning(const DocumentWeakPtr& document, Cmper partId, ShareMode shareMode, Cmper staffId, Cmper meas, Inci inci)
1319 : DetailsBase(document, partId, shareMode, staffId, meas, inci)
1320 {
1321 }
1322
1328 {
1329 None,
1330 Show,
1331 Hide
1332 };
1333
1340 std::shared_ptr<others::Enclosure> enclosure;
1341
1342 constexpr static std::string_view XmlNodeName = "measNumbIndivPos";
1344};
1345
1362{
1363public:
1373 explicit MeasureTextAssign(const DocumentWeakPtr& document, Cmper partId, ShareMode shareMode, Cmper staffId, Cmper meas, Inci inci)
1374 : DetailsBase(document, partId, shareMode, staffId, meas, inci)
1375 {
1376 }
1377
1383 bool hidden{};
1384
1387
1390
1391 constexpr static std::string_view XmlNodeName = "measTextAssign";
1393};
1394
1404{
1405public:
1407 explicit NoteAlterations(const DocumentWeakPtr& document, Cmper partId, ShareMode shareMode, EntryNumber entnum, Inci inci)
1408 : NoteDetailsBase(document, partId, shareMode, entnum, inci), customFont(new FontInfo(document))
1409 {
1410 }
1411
1413 int percent{};
1415 char32_t altNhead{};
1416 bool useOwnFont{};
1417 std::shared_ptr<FontInfo> customFont{};
1420 bool enharmonic{};
1422
1423 NoteNumber getNoteId() const override { return noteId; }
1424
1425 constexpr static std::string_view XmlNodeName = "noteAlter";
1427};
1428
1438{
1439public:
1441 explicit PercussionNoteCode(const DocumentWeakPtr& document, Cmper partId, ShareMode shareMode, EntryNumber entnum, Inci inci)
1442 : NoteDetailsBase(document, partId, shareMode, entnum, inci)
1443 {
1444 }
1445
1448
1449 NoteNumber getNoteId() const override { return noteId; }
1450
1451 constexpr static std::string_view XmlNodeName = "percussionNoteCode";
1453};
1454
1462{
1463public:
1473 explicit SecondaryBeamAlterationsDownStem(const DocumentWeakPtr& document, Cmper partId, ShareMode shareMode, EntryNumber entnum, Inci inci)
1474 : BeamAlterations(document, partId, shareMode, entnum, inci) {}
1475
1482 static bool calcIsFeatheredBeam(const EntryInfoPtr& entryInfo, Evpu& outLeftY, Evpu& outRightY)
1483 { return calcIsFeatheredBeamImpl<SecondaryBeamAlterationsDownStem>(entryInfo, outLeftY, outRightY); }
1484
1485 constexpr static std::string_view XmlNodeName = "beamAltSecDownStem";
1486};
1487
1495{
1496public:
1506 explicit SecondaryBeamAlterationsUpStem(const DocumentWeakPtr& document, Cmper partId, ShareMode shareMode, EntryNumber entnum, Inci inci)
1507 : BeamAlterations(document, partId, shareMode, entnum, inci) {}
1508
1515 static bool calcIsFeatheredBeam(const EntryInfoPtr& entryInfo, Evpu& outLeftY, Evpu& outRightY)
1516 { return calcIsFeatheredBeamImpl<SecondaryBeamAlterationsUpStem>(entryInfo, outLeftY, outRightY); }
1517
1518 constexpr static std::string_view XmlNodeName = "beamAltSecUpStem";
1519};
1520
1530{
1531public:
1533 explicit SecondaryBeamBreak(const DocumentWeakPtr& document, Cmper partId, ShareMode shareMode, EntryNumber entnum)
1534 : EntryDetailsBase(document, partId, shareMode, entnum)
1535 {
1536 }
1537
1538 unsigned mask{};
1540
1548 {
1549 MUSX_ASSERT_IF(!mask || mask >= unsigned(NoteType::Eighth)) {
1550 return 0; // invalid mask values have already been flagged and supposedly corrected by #integrityCheck.
1551 }
1552 for (unsigned shift = 0; true; shift++) {
1553 if (mask & (unsigned(NoteType::Note16th) >> shift)) {
1554 return shift + 2; // the 2nd beam is the 16th beam and the first one we checked.
1555 }
1556 }
1557 assert(false); // should not be able to get here
1558 return 0;
1559 }
1560
1561 void integrityCheck(const std::shared_ptr<Base>& ptrToThis) override
1562 {
1564 if (!mask) {
1565 mask = unsigned(NoteType::Note4096th);
1566 MUSX_INTEGRITY_ERROR("Secondary beam break for entry" + std::to_string(getEntryNumber()) + " has no breaks.");
1567 }
1568 if (mask >= unsigned(NoteType::Eighth)) {
1569 mask = unsigned(NoteType::Eighth) - 1;
1570 MUSX_INTEGRITY_ERROR("Secondary beam break for entry" + std::to_string(getEntryNumber()) + " specifies a value that cannot be a secondary beam.");
1571 }
1572 }
1573
1574 constexpr static std::string_view XmlNodeName = "secBeamBreak";
1576};
1577
1588{
1589public:
1592 explicit ShapeNoteBase(const DocumentWeakPtr& document, Cmper partId, ShareMode shareMode, Cmper cmper1, Cmper cmper2)
1593 : DetailsBase(document, partId, shareMode, cmper1, cmper2)
1594 {}
1595
1600 {
1601 public:
1602 char32_t doubleWhole{};
1603 char32_t whole{};
1604 char32_t half{};
1605 char32_t quarter{};
1606
1608 };
1609
1610 std::vector<std::shared_ptr<NoteShapes>> noteShapes;
1613
1614 void integrityCheck(const std::shared_ptr<Base>& ptrToThis) override
1615 {
1616 this->DetailsBase::integrityCheck(ptrToThis);
1617 const size_t currentSize = noteShapes.size();
1618 if (currentSize < music_theory::STANDARD_DIATONIC_STEPS) {
1619 for (size_t x = currentSize; x < music_theory::STANDARD_DIATONIC_STEPS; x++) {
1620 noteShapes.emplace_back(std::make_shared<NoteShapes>());
1621 }
1622 MUSX_INTEGRITY_ERROR("For ShapeNoteBase cmper " + std::to_string(getCmper1()) + ", only " + std::to_string(currentSize)
1623 + " note shapes were provided but at least " + std::to_string(music_theory::STANDARD_DIATONIC_STEPS) + " were expected.");
1624 }
1625 }
1626
1628};
1629
1638{
1639public:
1641
1642 constexpr static std::string_view XmlNodeName = "shapeNote";
1643};
1644
1653{
1654public:
1656
1657 constexpr static std::string_view XmlNodeName = "shapeNoteStyle";
1658};
1659
1666class StaffGroup : public DetailsBase {
1667public:
1676 StaffGroup(const DocumentWeakPtr& document, Cmper partId, Base::ShareMode shareMode, Cmper cmper1, Cmper cmper2)
1677 : DetailsBase(document, partId, shareMode, cmper1, cmper2) {}
1678
1681
1684
1690 {
1691 OnlyOnStaves,
1694 };
1695
1700 enum class HideStaves
1701 {
1702 Normally,
1703 AsGroup,
1704 None
1705 };
1706
1707 // Public properties corresponding to the XML structure, ordered as they appear in the XML
1715 std::shared_ptr<Bracket> bracket{};
1720 bool ownBarline{};
1723 bool hideName{};
1732
1738 std::unordered_set<StaffCmper> staves;
1739
1743
1747
1750
1756
1762
1764 bool isAllMeasures() const
1765 { return (startMeas == 1 && endMeas == (std::numeric_limits<MeasCmper>::max)()); }
1766
1767 void integrityCheck(const std::shared_ptr<Base>& ptrToThis) override
1768 {
1769 this->DetailsBase::integrityCheck(ptrToThis);
1770 if (endMeas <= startMeas || startMeas <= 0) {
1771 MUSX_INTEGRITY_ERROR("Staff group " + std::to_string(getCmper2()) + " for part " + std::to_string(getSourcePartId())
1772 + " starts at measure " + std::to_string(startMeas) + " and ends at measure " + std::to_string(endMeas));
1773 }
1774 if (!bracket) {
1775 // this is not an error. Finale omits the bracket node for groups with entirely default bracket info.
1776 bracket = std::make_shared<Bracket>(getDocument());
1777 }
1778 }
1779
1780 constexpr static std::string_view XmlNodeName = "staffGroup";
1782};
1783
1789{
1790public:
1791 std::optional<size_t> startSlot;
1792 std::optional<size_t> endSlot;
1795
1799 StaffGroupInfo(const MusxInstance<StaffGroup>& staffGroup,
1800 const MusxInstanceList<others::StaffUsed>& inpSysStaves);
1801
1803 std::optional<size_t> numStaves() const
1804 {
1805 if (startSlot && endSlot) {
1806 return endSlot.value() - startSlot.value() + 1;
1807 }
1808 return std::nullopt;
1809 }
1810
1815 void iterateStaves(MeasCmper measId, Edu eduPosition, std::function<bool(const MusxInstance<others::StaffComposite>&)> iterator) const;
1816
1821 static std::vector<StaffGroupInfo> getGroupsAtMeasure(MeasCmper measureId, Cmper linkedPartId,
1823};
1824
1834{
1835public:
1844 explicit StaffSize(const DocumentWeakPtr& document, Cmper partId, ShareMode shareMode, Cmper system, Cmper staffId)
1845 : DetailsBase(document, partId, shareMode, system, staffId)
1846 {
1847 }
1848
1850
1854
1855 constexpr static std::string_view XmlNodeName = "staffSize";
1857};
1858
1868{
1869public:
1871 explicit StemAlterations(const DocumentWeakPtr& document, Cmper partId, ShareMode shareMode, EntryNumber entnum)
1872 : EntryDetailsBase(document, partId, shareMode, entnum)
1873 {
1874 }
1875
1880
1881 constexpr static std::string_view XmlNodeName = "stemAdjust";
1883};
1884
1894{
1895public:
1897
1898 constexpr static std::string_view XmlNodeName = "beamStemAdjust";
1899};
1900
1911{
1912public:
1914 explicit TablatureNoteMods(const DocumentWeakPtr& document, Cmper partId, ShareMode shareMode, EntryNumber entnum, Inci inci)
1915 : NoteDetailsBase(document, partId, shareMode, entnum, inci)
1916 {
1917 }
1918
1922
1923 NoteNumber getNoteId() const override { return noteId; }
1924
1925 constexpr static std::string_view XmlNodeName = "tabAlter";
1927};
1928
1934{
1935public:
1937 explicit TieAlterBase(const DocumentWeakPtr& document, Cmper partId, Base::ShareMode shareMode, EntryNumber entnum, Inci inci)
1938 : NoteDetailsBase(document, partId, shareMode, entnum, inci)
1939 {
1940 }
1941
1947 bool outerLocal{};
1956 bool down{};
1960 bool breakKeyOn{};
1962 bool stPtAdjOn{};
1963 bool enPtAdjOn{};
1968 bool ctlPtAdjOn{};
1969
1970 NoteNumber getNoteId() const override { return noteId; }
1971
1972 bool requireAllFields() const override { return false; }
1974};
1975
1985{
1986public:
1988
1989 constexpr static std::string_view XmlNodeName = "tieAlterEnd";
1991};
1992
2002{
2003public:
2005
2006 constexpr static std::string_view XmlNodeName = "tieAlterStart";
2008};
2009
2019{
2020public:
2022 explicit TupletDef(const DocumentWeakPtr& document, Cmper partId, ShareMode shareMode, EntryNumber entnum, Inci inci)
2023 : EntryDetailsBase(document, partId, shareMode, entnum, inci)
2024 {
2025 }
2026
2035
2040 bool alwaysFlat{};
2041 bool fullDura{};
2043 bool avoidStaff{};
2045 bool hidden{};
2052 bool allowHorz{};
2055 bool matchHooks{};
2064
2067
2070
2073
2074 constexpr static std::string_view XmlNodeName = "tupletDef";
2076};
2077
2078} // namespace details
2079} // namespace dom
2080} // namespace entries
Base class to enforce polymorphism across all DOM classes.
Definition BaseClasses.h:83
DocumentPtr getDocument() const
Gets a reference to the Document.
Definition BaseClasses.h:108
Cmper getSourcePartId() const
Gets the source partId for this instance. If an instance is fully shared with the score,...
Definition BaseClasses.h:124
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
Template pattern for DetailsBase items consisting of an array of a single item.
Definition BaseClasses.h:509
DetailsArray(const DocumentWeakPtr &document, Cmper partId, ShareMode shareMode, Cmper cmper1, Cmper cmper2)
Constructor function.
Definition BaseClasses.h:515
Base class for all "details" types.
Definition BaseClasses.h:407
Cmper getCmper1() const
Gets the cmper1 key value.
Definition BaseClasses.h:451
Cmper getCmper2() const
Gets the cmper2 key value.
Definition BaseClasses.h:456
Base class for all "details" types that use entnum rather than cmper and cmper.
Definition BaseClasses.h:479
EntryNumber getEntryNumber() const
Gets the entnum key value.
Definition BaseClasses.h:497
Wraps a frame of shared_ptr<const EntryInfo> and an index for per entry access. This class manages ow...
Definition Entries.h:388
Represents the default font settings for a particular element type.
Definition CommonClasses.h:123
Provides optional per-type extension methods for MusxInstanceList.
Definition MusxInstance.h:96
Base class note details. Note details are entry details associated with a note ID.
Definition BaseClasses.h:540
Represents display alterations to an accidental for a specific note.
Definition Details.h:80
Evpu hOffset
Horizontal offset: positive is right. (XML node: <axDisp>)
Definition Details.h:91
NoteNumber getNoteId() const override
Required virtual function that returns the note id.
Definition Details.h:97
bool useOwnFont
Whether to use customFont.
Definition Details.h:94
std::shared_ptr< FontInfo > customFont
Font settings for the accidental (populated from <fontID>, <fontSize>, and <efx>)
Definition Details.h:93
NoteNumber noteId
The ID of the note being altered.
Definition Details.h:88
AccidentalAlterations(const DocumentWeakPtr &document, Cmper partId, ShareMode shareMode, EntryNumber entnum, Inci inci)
Constructor.
Definition Details.h:83
Evpu vOffset
Vertical offset: positive is up. (XML node: <ayDisp>)
Definition Details.h:90
char32_t altChar
If non-zero, the character to use for the accidental. (Utf-32 if the font is a Unicode font....
Definition Details.h:92
bool allowVertPos
Whether to use vOffset.
Definition Details.h:95
int percent
The percentage size for the accidental, where 100 is 100%.
Definition Details.h:89
static constexpr std::string_view XmlNodeName
The XML node name for this type.
Definition Details.h:99
static const xml::XmlElementArray< AccidentalAlterations > & xmlMappingArray()
Required for musx::factory::FieldPopulator.
Assigns an articulation to an entry.
Definition Details.h:110
ArticulationAssign(const DocumentWeakPtr &document, Cmper partId, ShareMode shareMode, EntryNumber entnum, Inci inci)
Constructor function.
Definition Details.h:120
Cmper articDef
The articulation definition ID.
Definition Details.h:123
bool hide
Inverse of "Show" option.
Definition Details.h:130
bool neverStack
Whether the articulation should never stack relative to others.
Definition Details.h:131
int numSlursAvoided
Number of slurs avoided. Used internally by Finale's stacking algorithm.
Definition Details.h:133
bool avoidSlur
Whether the articulation should avoid slurs.
Definition Details.h:132
bool aboveEntry
When overridePlacement is true: whether the articulation is forced above or below the entry.
Definition Details.h:129
Evpu horzOffset
Horizontal offset from the default position.
Definition Details.h:124
bool overridePlacement
Whether the default placement is overridden.
Definition Details.h:128
static constexpr std::string_view XmlNodeName
The XML node name for this type.
Definition Details.h:136
static const xml::XmlElementArray< ArticulationAssign > & xmlMappingArray()
Required for musx::factory::FieldPopulator.
Evpu vertOffset
Vertical offset from the default position.
Definition Details.h:126
Evpu vertAdd
Vertical displacement for character copying. (E.g., arpeggiated chord lines)
Definition Details.h:127
Evpu horzAdd
Horizontal displacement for character copying. (E.g., trill lines)
Definition Details.h:125
Contains the baseline offsets for chords.
Definition Details.h:285
static constexpr std::string_view XmlNodeName
The XML node name for this type.
Definition Details.h:290
Contains the baseline offsets for expressions above the staff.
Definition Details.h:300
static constexpr std::string_view XmlNodeName
The XML node name for this type.
Definition Details.h:305
Contains the baseline offsets for expressions below the staff.
Definition Details.h:315
static constexpr std::string_view XmlNodeName
The XML node name for this type.
Definition Details.h:320
Contains the baseline offsets for fretboards.
Definition Details.h:330
static constexpr std::string_view XmlNodeName
The XML node name for this type.
Definition Details.h:335
Contains the baseline offsets for lyrics chorus records.
Definition Details.h:345
static constexpr std::string_view XmlNodeName
The XML node name for this type.
Definition Details.h:351
Contains the baseline offsets for lyrics section records.
Definition Details.h:361
static constexpr std::string_view XmlNodeName
The XML node name for this type.
Definition Details.h:367
Contains the baseline offsets for lyrics verse records.
Definition Details.h:377
static constexpr std::string_view XmlNodeName
The XML node name for this type.
Definition Details.h:383
Encapsulates inci handling for non-inci baselines.
Definition Details.h:180
BaselineNoInci(const DocumentWeakPtr &document, Cmper partId, ShareMode shareMode, Cmper system, Cmper staff)
Constructor function.
Definition Details.h:190
Contains the baseline offsets for chords.
Definition Details.h:199
static constexpr std::string_view XmlNodeName
The XML node name for this type.
Definition Details.h:203
Contains the baseline offsets for expressions above the staff.
Definition Details.h:211
static constexpr std::string_view XmlNodeName
The XML node name for this type.
Definition Details.h:215
Contains the baseline offsets for expressions below the staff.
Definition Details.h:223
static constexpr std::string_view XmlNodeName
The XML node name for this type.
Definition Details.h:227
Contains the baseline offsets for fretboards.
Definition Details.h:235
static constexpr std::string_view XmlNodeName
The XML node name for this type.
Definition Details.h:239
Contains the baseline offsets for lyrics chorus records.
Definition Details.h:247
static constexpr std::string_view XmlNodeName
The XML node name for this type.
Definition Details.h:251
Contains the baseline offsets for lyrics section records.
Definition Details.h:259
static constexpr std::string_view XmlNodeName
The XML node name for this type.
Definition Details.h:263
Contains the baseline offsets for lyrics verse records.
Definition Details.h:271
static constexpr std::string_view XmlNodeName
The XML node name for this type.
Definition Details.h:275
Contains the baseline information for all baseline types.
Definition Details.h:153
std::optional< Cmper > lyricNumber
The 1-based text number of the lyric, if this is a lyrics baseline. Otherwise unused and should be st...
Definition Details.h:170
static const xml::XmlElementArray< Baseline > & xmlMappingArray()
Required for musx::factory::FieldPopulator.
Baseline(const DocumentWeakPtr &document, Cmper partId, ShareMode shareMode, Cmper system, Cmper staff, std::optional< Inci > inci)
Constructor function.
Definition Details.h:164
Evpu baselineDisplacement
Definition Details.h:167
Beam alteration for downstem primary beams.
Definition Details.h:450
static constexpr std::string_view XmlNodeName
The XML node name for this type.
Definition Details.h:462
BeamAlterationsDownStem(const DocumentWeakPtr &document, Cmper partId, ShareMode shareMode, EntryNumber entnum)
Constructor.
Definition Details.h:459
Beam alteration for upstem primary beams.
Definition Details.h:472
BeamAlterationsUpStem(const DocumentWeakPtr &document, Cmper partId, ShareMode shareMode, EntryNumber entnum)
Constructor.
Definition Details.h:481
static constexpr std::string_view XmlNodeName
The XML node name for this type.
Definition Details.h:484
Represents beam alterations applied to a specific entry. This is used to apply additional shaping or ...
Definition Details.h:393
static const xml::XmlElementArray< BeamAlterations > & xmlMappingArray()
Required for musx::factory::FieldPopulator.
bool isActive() const
Returns whether this beam alteration record is active. Its flattenStyle must match the value in optio...
Definition Details.h:433
Edu dura
For secondary beams, specifies the duration corresponding to the secondary beam (16th beam is 256,...
Definition Details.h:421
Evpu rightOffsetY
Vertical adjustment of the beam end. (xml node is <syAdd>)
Definition Details.h:420
FlattenStyle flattenStyle
Beam shaping style (xml node is <context>).
Definition Details.h:422
BeamAlterations(const DocumentWeakPtr &document, Cmper partId, ShareMode shareMode, EntryNumber entnum, std::optional< Inci > inci=std::nullopt)
Constructor.
Definition Details.h:411
static bool calcIsFeatheredBeamImpl(const EntryInfoPtr &entryInfo, Evpu &outLeftY, Evpu &outRightY)
Implementation of SecondaryBeamAlterationsDownStem::calcIsFeatheredBeam and SecondaryBeamAlterationsU...
Definition Details.cpp:86
Evpu rightOffsetH
Horizontal adjustment of the beam end. (xml node is <sxAdd>)
Definition Details.h:419
Evpu leftOffsetY
Vertical adjustment of the beam start. (xml node is <yAdd>)
Definition Details.h:418
Evpu leftOffsetH
Horizontal adjustment of the beam start. (xml node is <xAdd>)
Definition Details.h:417
Efix calcEffectiveBeamWidth() const
Calculates the effective beam width by returning either the default width or the width override value...
Definition Details.cpp:59
static void calcAllActiveFlags(const DocumentPtr &document)
Used by the factory to set active indicators.
Definition Details.cpp:39
Efix beamWidth
The calcEffectiveBeamWidth method handles this for you.
Definition Details.h:423
Beam extension for downstem beams.
Definition Details.h:525
static constexpr std::string_view XmlNodeName
The XML node name for this type.
Definition Details.h:529
Beam extension for upstem beams.
Definition Details.h:537
static constexpr std::string_view XmlNodeName
The XML node name for this type.
Definition Details.h:541
Represents both sides of a beam extension. It is attached to the first entry in the beam....
Definition Details.h:495
bool extBeyond8th
Definition Details.h:512
Evpu rightOffset
Right extension offset. (xml node is <x4Disp>)
Definition Details.h:508
unsigned mask
Definition Details.h:509
static const xml::XmlElementArray< BeamExtension > & xmlMappingArray()
Required for musx::factory::FieldPopulator.
BeamExtension(const DocumentWeakPtr &document, Cmper partId, ShareMode shareMode, EntryNumber entnum)
Constructor.
Definition Details.h:504
Evpu leftOffset
Left extension offset. (xml node is <x3Disp>)
Definition Details.h:507
Specifies the direction for beam stubs (if they are manually overridden.)
Definition Details.h:553
unsigned mask
Definition Details.h:561
static constexpr std::string_view XmlNodeName
The XML node name for this type.
Definition Details.h:568
static const xml::XmlElementArray< BeamStubDirection > & xmlMappingArray()
Required for musx::factory::FieldPopulator.
bool isLeft() const
True if the beam stub(s) point left.
Definition Details.h:566
BeamStubDirection(const DocumentWeakPtr &document, Cmper partId, ShareMode shareMode, EntryNumber entnum)
Constructor function.
Definition Details.h:556
Represents a bracket, used in two different contexts:
Definition Details.h:585
static const xml::XmlElementArray< Bracket > & xmlMappingArray()
Required for musx::factory::FieldPopulator.
static constexpr std::string_view XmlNodeName
The XML node name for this type.
Definition Details.h:622
Evpu horzAdjLeft
"Distance from Left Edge of Staff" (xml node is <bracPos>)
Definition Details.h:617
Evpu vertAdjTop
"Vertical Adjust (Top of Bracket)" (xml node is <bracTop>)
Definition Details.h:618
Bracket(const DocumentWeakPtr &document, Cmper partId, ShareMode shareMode, Cmper cmper1, Cmper cmper2, Inci inci)
Constructor for top-level instances.
Definition Details.h:588
Evpu vertAdjBot
"Vertical Adjust (Bottom of Bracket)" (xml node is <bracBot>)
Definition Details.h:619
Bracket(const DocumentWeakPtr &document)
Constructor for embedded instances.
Definition Details.h:594
BracketStyle style
Bracket style (xml node is <id>)
Definition Details.h:616
BracketStyle
Bracket types.
Definition Details.h:604
@ BracketCurvedHooks
Thick bracket with curved hooks.
@ DeskBracket
Thin bracket with horizontal hook lines.
@ BracketStraightHooks
Thick bracket with straight hooks.
bool showOnSingleStaff
"Show Bracket If Group Contains Only One Staff" (only applies to staff groups: xml node is <onSingle>...
Definition Details.h:620
Represents chord symbol assignment for a staff and measure.
Definition Details.h:634
Edu horzEdu
Edu position in measure.
Definition Details.h:694
Evpu fbHorzOff
Horizontal offset of fretboard (in EVPU)
Definition Details.h:692
bool showFretboard
Show fretboard.
Definition Details.h:674
bool rootLowerCase
Display root in lowercase (minor triad)
Definition Details.h:670
bool playRoot
Playback root.
Definition Details.h:673
bool showRoot
Show root.
Definition Details.h:672
int bassAlter
Bass alteration.
Definition Details.h:678
BassPosition
Bass position options.
Definition Details.h:657
ChordAssign(const DocumentWeakPtr &document, Cmper partId, ShareMode shareMode, Cmper staffId, Cmper meas, Inci inci)
Constructor.
Definition Details.h:647
int rootScaleNum
Root scale degree: 0–6, where zero is the tonic.
Definition Details.h:668
Evpu fbVertOff
Vertical offset of fretboard (in EVPU)
Definition Details.h:693
bool showAltBass
Show alternate bass.
Definition Details.h:681
MusxInstanceList< others::ChordSuffixElement > getChordSuffix() const
Returns the chord suffix as an array of others::ChordSuffixElement.
Definition Details.cpp:161
Evpu horzOff
Horizontal offset of chord (in EVPU)
Definition Details.h:690
bool showSuffix
Show suffix.
Definition Details.h:675
MusxInstance< others::FretboardGroup > getFretboardGroup() const
Get the others::FretboardGroup instance for this chord assignment. You can use this to get the fret i...
Definition Details.cpp:166
Cmper suffixId
Definition Details.h:663
bool useFretboardFont
Definition Details.h:688
Inci fretboardGroupInci
Definition Details.h:685
bool playFretboard
Playback fretboard.
Definition Details.h:676
Cmper fbStyleId
The others::FretboardStyle ID. (Ignored when useFretboardFont is true.)
Definition Details.h:667
int fbPercent
FretboardDiagram scaling (100 means 100%)
Definition Details.h:696
static constexpr std::string_view XmlNodeName
The XML node name for this type.
Definition Details.h:709
int bassScaleNum
Bass scale degree: 0–6, where zero is the tonic.
Definition Details.h:677
Evpu vertOff
Vertical offset of chord (in EVPU)
Definition Details.h:691
int capoValue
Capo value (if useLocalCapo is true)
Definition Details.h:683
bool playAltBass
Playback alternate bass.
Definition Details.h:682
MusxInstance< others::FretboardStyle > getFretboardStyle() const
Returns the others::FretboardStyle instance for this chord assignment.
Definition Details.cpp:175
int chPercent
Chord scaling (100 means 100%)
Definition Details.h:695
int rootAlter
Root alteration.
Definition Details.h:669
bool playSuffix
Playback suffix.
Definition Details.h:671
bool useLocalCapo
Use local capo.
Definition Details.h:684
static const xml::XmlElementArray< ChordAssign > & xmlMappingArray()
Required for musx::factory::FieldPopulator.
bool bassLowerCase
Display bass in lowercase.
Definition Details.h:679
BassPosition bassPosition
Visual position of bass relative to root.
Definition Details.h:680
Defines the octaves in which each clef should display flats in key signatures. Only linear key signat...
Definition Details.h:728
static const xml::XmlElementArray< ClefOctaveFlats > & xmlMappingArray()
Required for musx::factory::FieldPopulator.
static constexpr std::string_view XmlNodeName
The XML node name for this type.
Definition Details.h:734
Defines the octaves in which each clef should display sharps in key signatures.
Definition Details.h:757
static const xml::XmlElementArray< ClefOctaveSharps > & xmlMappingArray()
Required for musx::factory::FieldPopulator.
static constexpr std::string_view XmlNodeName
The XML node name for this type.
Definition Details.h:763
Represents a cross-staff assignment for the note, if any.
Definition Details.h:776
NoteNumber getNoteId() const override
Required virtual function that returns the note id.
Definition Details.h:787
static constexpr std::string_view XmlNodeName
The XML node name for this type.
Definition Details.h:789
static const xml::XmlElementArray< CrossStaff > & xmlMappingArray()
Required for musx::factory::FieldPopulator.
CrossStaff(const DocumentWeakPtr &document, Cmper partId, ShareMode shareMode, EntryNumber entnum, Inci inci)
Constructor function.
Definition Details.h:779
NoteNumber noteId
The ID of the note being assigned to a different staff (XML node: <noteID>)
Definition Details.h:784
StaffCmper staff
The target staff (XML node: <instrument>)
Definition Details.h:785
Custom stem for downstem context.
Definition Details.h:836
static constexpr std::string_view XmlNodeName
The XML node name for this type.
Definition Details.h:840
Represents a custom stem definition (up or down) for an entry. Which stem direction this instance con...
Definition Details.h:802
Evpu yOffset
Optional vertical displacement. (xml node is <ydisp>)
Definition Details.h:816
bool calcIsHiddenStem() const
Calculates if this custom stem record hides the stem. The stem is determined to be hidden if one of t...
Definition Details.cpp:187
static const xml::XmlElementArray< CustomStem > & xmlMappingArray()
Required for musx::factory::FieldPopulator.
Cmper shapeDef
The Cmper of the associated others::ShapeDef. Setting this value to zero hides the stem.
Definition Details.h:814
Evpu xOffset
Optional horizontal displacement. (xml node is <xdisp>)
Definition Details.h:815
CustomStem(const DocumentWeakPtr &document, Cmper partId, ShareMode shareMode, EntryNumber entnum)
Constructor.
Definition Details.h:811
Custom stem for upstem context.
Definition Details.h:850
static constexpr std::string_view XmlNodeName
The XML node name for this type.
Definition Details.h:854
Represents display offsets and spacing adjustments for augmentation dots on a specific note.
Definition Details.h:866
static constexpr std::string_view XmlNodeName
The XML node name for this type.
Definition Details.h:881
NoteNumber noteId
The ID of the note whose dots are adjusted.
Definition Details.h:874
Evpu hOffset
Horizontal offset for the dot (XML: <xadd>)
Definition Details.h:875
Evpu vOffset
Vertical offset for the dot (XML: <yadd>)
Definition Details.h:876
static const xml::XmlElementArray< DotAlterations > & xmlMappingArray()
Required for musx::factory::FieldPopulator.
Evpu interdotSpacing
Additional spacing between dots (XML: <posIncr>)
Definition Details.h:877
DotAlterations(const DocumentWeakPtr &document, Cmper partId, ShareMode shareMode, EntryNumber entnum, Inci inci)
Constructor.
Definition Details.h:869
NoteNumber getNoteId() const override
Required virtual function that returns the note id.
Definition Details.h:879
Specifies a custom size for an entry. It scales the entire entry, including the stem and all notehead...
Definition Details.h:894
static constexpr std::string_view XmlNodeName
The XML node name for this type.
Definition Details.h:909
int percent
The note/chord size as a percent (e.g., 65 for 65%).
Definition Details.h:906
static const xml::XmlElementArray< EntrySize > & xmlMappingArray()
Required for musx::factory::FieldPopulator.
EntrySize(const DocumentWeakPtr &document, Cmper partId, ShareMode shareMode, EntryNumber entnum)
Constructor.
Definition Details.h:903
Represents a barre (spanning multiple strings).
Definition Details.h:970
int endString
Ending 1-based string number.
Definition Details.h:974
int startString
Starting 1-based string number.
Definition Details.h:973
static const xml::XmlElementArray< Barre > & xmlMappingArray()
Required for musx::factory::FieldPopulator.
int fret
0-based fret number, where 0 signifies the open string. (Finale allows nut barres....
Definition Details.h:972
Represents a single fretboard cell (string/fret position).
Definition Details.h:955
Shape shape
Cell shape.
Definition Details.h:959
int fingerNum
Finger number 0..5, where 0 means there is no finger number and 5 means T (thumb).
Definition Details.h:960
int fret
0-based fret number, where 0 signifies the open string.
Definition Details.h:958
static const xml::XmlElementArray< Cell > & xmlMappingArray()
Required for musx::factory::FieldPopulator.
FretboardDiagram diagram for chord symbols.
Definition Details.h:925
int fretboardNum
FretboardDiagram number: the starting fret of the fretboard diagram (xml node <fretNum>).
Definition Details.h:980
bool showNum
Show fretboard number.
Definition Details.h:982
std::vector< std::shared_ptr< Barre > > barres
Array of fretboard barres.
Definition Details.h:987
static const xml::XmlElementArray< FretboardDiagram > & xmlMappingArray()
Required for musx::factory::FieldPopulator.
int numFretCells
Number of fret cells (xml node <numFretCells>).
Definition Details.h:983
Shape
Shape type for a fretboard cell.
Definition Details.h:942
@ None
No explicit shape. This is the default value and may not occur in the xml.
@ Custom
Custom symbol. By default this is an open diamond signifying a harmonic.
bool lock
Lock flag (xml node <lock>).
Definition Details.h:981
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 Details.h:989
int numFretBarres
Number of fret barres (xml node <numFretBarres>).
Definition Details.h:984
FretboardDiagram(const DocumentWeakPtr &document, Cmper partId, ShareMode shareMode, Cmper cmper1, Cmper cmper2)
Constructor function.
Definition Details.h:930
int numFrets
Number of frets.
Definition Details.h:979
static constexpr std::string_view XmlNodeName
XML node name for this type.
Definition Details.h:1006
std::vector< std::shared_ptr< Cell > > cells
Array of fretboard cells.
Definition Details.h:986
Represents the attributes of a Finale frame holder.
Definition Details.h:1018
StaffCmper getStaff() const
returns the staffId (staff) number for this GFrameHold
Definition Details.h:1041
GFrameHold(const DocumentWeakPtr &document, Cmper partId, ShareMode shareMode, Cmper staffId, Cmper meas)
Constructor function.
Definition Details.h:1028
std::optional< ClefIndex > clefId
clef index when there are no mid-measure clef changes. (xml tag is <clefID>).
Definition Details.h:1032
int clefPercent
Clef percent where 100 means 100%.
Definition Details.h:1037
ShowClefMode showClefMode
"Show Clef" mode. (xml tag is <clefMode>)
Definition Details.h:1034
bool mirrorFrame
Indicates this is a mirror frame. (Not used after Finale 14.5.)
Definition Details.h:1035
static const xml::XmlElementArray< GFrameHold > & xmlMappingArray()
Required for musx::factory::FieldPopulator.
MeasCmper getMeasure() const
returns the measure number for this GFrameHold
Definition Details.h:1044
bool calcContainsMusic() const
Returns true if the GFrameHold contains any layer frames.
Definition Details.h:1053
static constexpr std::string_view XmlNodeName
The XML node name for this type.
Definition Details.h:1069
bool calcIsMultiLayer() const
Returns true if the GFrameHold instance has more than one layer.
Definition Details.h:1047
bool clefAfterBarline
"Place Clef After Barline"
Definition Details.h:1036
Cmper clefListId
The clef list ID when there are mid-measure clef changes, if non-zero. (xml tag is <clefListID>).
Definition Details.h:1033
std::vector< Cmper > frames
others::Frame values for layers 1..4 (layer indices 0..3) if non-zero
Definition Details.h:1038
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 Details.h:1058
Represents independent time and key signature overrides for a staff.
Definition Details.h:1081
bool hasTime
If true, this item contains an independent time signature.
Definition Details.h:1112
MusxInstance< TimeSignature > createTimeSignature() const
Create a shared pointer to an instance of the TimeSignature for this instance.
Definition Details.cpp:201
Cmper divBeat
Time signature denominator in Edu or a Cmper to a composite record.
Definition Details.h:1102
bool displayAltDenTsig
If true, dispDivBeat is the Cmper of a others::TimeCompositeLower record.
Definition Details.h:1107
Cmper dispDivBeat
Display time signature denominator in Edu or a Cmper to a composite record.
Definition Details.h:1104
bool altNumTsig
If true, beats is the Cmper of a others::TimeCompositeUpper record.
Definition Details.h:1108
bool hasKey
If true, this item contains an independent key signature.
Definition Details.h:1098
std::shared_ptr< KeySignature > keySig
The key signature value if present. (xml tag is <keySig>/<key>)
Definition Details.h:1097
IndependentStaffDetails(const DocumentWeakPtr &document, Cmper partId, ShareMode shareMode, Cmper staffId, Cmper meas)
Constructor function.
Definition Details.h:1091
bool altDenTsig
If true, divBeat is the Cmper of a others::TimeCompositeLower record.
Definition Details.h:1109
static const xml::XmlElementArray< IndependentStaffDetails > & xmlMappingArray()
Required for musx::factory::FieldPopulator.
bool hasDispTime
If true, the display time signature is present.
Definition Details.h:1111
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 Details.h:1121
bool displayAbbrvTime
If true, the display time signature is abbreviated.
Definition Details.h:1110
static constexpr std::string_view XmlNodeName
The XML node name for this type.
Definition Details.h:1129
Cmper dispBeats
Display time signature numerator or a Cmper to a composite record.
Definition Details.h:1103
bool displayAltNumTsig
If true, dispBeats is the Cmper of a others::TimeCompositeUpper record.
Definition Details.h:1106
MusxInstance< TimeSignature > createDisplayTimeSignature() const
Create a shared pointer to an instance of the display TimeSignature for this measure and staff.
Definition Details.cpp:206
Cmper beats
Time signature numerator or a Cmper to a composite record.
Definition Details.h:1101
Represents a single element in a Finale accidental symbol list.
Definition Details.h:1140
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 Details.h:1154
int getAlterationValue() const
Returns the alteration value that this symbol corresponds with.
Definition Details.h:1150
KeySymbolListElement(const DocumentWeakPtr &document, Cmper partId, ShareMode shareMode, Cmper cmper1, Cmper cmper2)
Constructor function.
Definition Details.h:1143
static const xml::XmlElementArray< KeySymbolListElement > & xmlMappingArray()
Required for musx::factory::FieldPopulator.
static constexpr std::string_view XmlNodeName
The XML node name for this type.
Definition Details.h:1163
std::string accidentalString
Definition Details.h:1146
Contains the syllable assignments for lyrics chorus blocks.
Definition Details.h:1212
util::EnigmaParsingContext getRawTextCtx() const
Return an Enigma parsing context for the associated lyrics text block.
Definition Details.h:1219
static constexpr std::string_view XmlNodeName
The XML node name for this type.
Definition Details.h:1223
Contains the syllable assignments for lyrics section blocks.
Definition Details.h:1233
static constexpr std::string_view XmlNodeName
The XML node name for this type.
Definition Details.h:1244
util::EnigmaParsingContext getRawTextCtx() const
Return an Enigma parsing context for the associated lyrics text block.
Definition Details.h:1240
Contains the syllable assignments for lyrics verse blocks.
Definition Details.h:1254
util::EnigmaParsingContext getRawTextCtx() const
Return an Enigma parsing context for the associated lyrics text block.
Definition Details.h:1261
static constexpr std::string_view XmlNodeName
The XML node name for this type.
Definition Details.h:1265
Contains assignment data for a lyric assignment (a single syllable)
Definition Details.h:1172
Evpu wext
Definition Details.h:1197
LyricAssign(const DocumentWeakPtr &document, Cmper partId, ShareMode shareMode, EntryNumber entnum, Inci inci)
Constructor function.
Definition Details.h:1189
static const xml::XmlElementArray< LyricAssign > & xmlMappingArray()
Required for musx::factory::FieldPopulator.
Cmper lyricNumber
the text number of the lyric.
Definition Details.h:1192
unsigned syllable
the 1-based syllable number. Subtract 1 to get the index. (xml node is <syll>)
Definition Details.h:1193
Evpu floatingHorzOff
This appears to have something to do with note spacing. It may simply be a cache that Finale changes ...
Definition Details.h:1196
Evpu horzOffset
horizontal offset from default position. (xml node is <horzOff>)
Definition Details.h:1194
Evpu vertOffset
horizontal offset from default position. (xml node is <vertOff>)
Definition Details.h:1195
bool displayVerseNum
If set, the text block number displays to the left of the syllable. (E.g., when numbering verses in a...
Definition Details.h:1200
util::EnigmaParsingContext getRawTextCtx() const
Return an Enigma parsing context for the associated lyrics text block.
Specifies lyric alignment and justification for a single entry. This affects all lyric assignments on...
Definition Details.h:1276
static constexpr std::string_view XmlNodeName
The XML node name for this type.
Definition Details.h:1296
std::optional< AlignJustify > align
Override default alignment if present. (xml node is <align>)
Definition Details.h:1293
static const xml::XmlElementArray< LyricEntryInfo > & xmlMappingArray()
Required for musx::factory::FieldPopulator.
LyricEntryInfo(const DocumentWeakPtr &document, Cmper partId, ShareMode shareMode, EntryNumber entnum, std::optional< Inci > inci=std::nullopt)
Constructor.
Definition Details.h:1289
std::optional< AlignJustify > justify
Override default justification if present. (xml node is <justify>)
Definition Details.h:1292
Per-staff/per-measure overrides for the position and appearance of a measure number.
Definition Details.h:1307
ForceVisibility
Force-visibility options for the measure number at this location.
Definition Details.h:1328
@ Show
Force the number to display (xml text value: "force")
@ Hide
Force the number to be hidden (xml text value: "hide")
@ None
No override (default; node may be omitted in XML)
bool useEnclosure
Whether to use an enclosure for this number. (xml node is <useEncl>)
Definition Details.h:1339
Evpu xOffset
Horizontal offset for the measure number. (xml node is <x1add>)
Definition Details.h:1335
Evpu xOffset2
Horizontal offset for the measure number range under a multimeasure rest (Page View only)....
Definition Details.h:1337
MeasureNumberIndividualPositioning(const DocumentWeakPtr &document, Cmper partId, ShareMode shareMode, Cmper staffId, Cmper meas, Inci inci)
Constructor.
Definition Details.h:1318
static const xml::XmlElementArray< MeasureNumberIndividualPositioning > & xmlMappingArray()
Required for musx::
ForceVisibility forceVisibility
Force-visibility behavior. (xml node is <forceHide>)
Definition Details.h:1338
Cmper measNumRegion
The Cmper of the others::MeasureNumberRegion that this override applies to. (xml node is <region>)
Definition Details.h:1334
std::shared_ptr< others::Enclosure > enclosure
Optional enclosure settings. (xml node is <encl>)
Definition Details.h:1340
static constexpr std::string_view XmlNodeName
The XML node name for this type.
Definition Details.h:1342
Evpu yOffset
Vertical offset for the measure number. (xml node is <y1add>)
Definition Details.h:1336
Represents a text block assignment for a staff and measure.
Definition Details.h:1362
static constexpr std::string_view XmlNodeName
The XML node name for this type.
Definition Details.h:1391
util::EnigmaParsingContext getRawTextCtx(Cmper forPartId) const
Gets the raw text for this assignment, or nullptr if none.
Definition Details.cpp:244
Evpu yDisp
Vertical displacement in Evpu (xml node is <ydisp>)
Definition Details.h:1382
Evpu xDispEvpu
Negative horizontal displacement in Evpu, when xDispEdu is zero. (xml node is <xdispEvpu>)
Definition Details.h:1381
MusxInstance< others::TextBlock > getTextBlock() const
Gets the TextBlock for this assignment, or nullptr if none.
Definition Details.cpp:239
MeasureTextAssign(const DocumentWeakPtr &document, Cmper partId, ShareMode shareMode, Cmper staffId, Cmper meas, Inci inci)
Constructor.
Definition Details.h:1373
Cmper block
Text block ID.
Definition Details.h:1378
bool hidden
Indicates the text appears only on screen (xml node is <postIt/>)
Definition Details.h:1383
static const xml::XmlElementArray< MeasureTextAssign > & xmlMappingArray()
Required for musx::factory::FieldPopulator.
Edu xDispEdu
Definition Details.h:1379
Represents graphical and notational alterations applied to a note.
Definition Details.h:1404
bool allowVertPos
Whether vertical positioning is allowed .
Definition Details.h:1418
int percent
Size percentage for the notehead. (A value of 100 means 100%.)
Definition Details.h:1413
char32_t altNhead
Alternate notehead character.
Definition Details.h:1415
static constexpr std::string_view XmlNodeName
The XML node name for this type.
Definition Details.h:1425
NoteAlterations(const DocumentWeakPtr &document, Cmper partId, ShareMode shareMode, EntryNumber entnum, Inci inci)
Constructor function.
Definition Details.h:1407
Evpu nydisp
Vertical notehead offset.
Definition Details.h:1419
std::shared_ptr< FontInfo > customFont
Custom font info (consolidates: <fontID>, <fontSize>, <efx>)
Definition Details.h:1417
bool useOwnFont
Whether to use the custom font.
Definition Details.h:1416
Evpu nxdisp
Horizontal notehead offset.
Definition Details.h:1414
NoteNumber getNoteId() const override
Required virtual function that returns the note id.
Definition Details.h:1423
bool enharmonic
Definition Details.h:1420
NoteNumber noteId
The ID of the note being altered. (xml node is <noteID>)
Definition Details.h:1412
static const xml::XmlElementArray< NoteAlterations > & xmlMappingArray()
Required for musx::factory::FieldPopulator.
Represents a percussion note code override for a single note.
Definition Details.h:1438
NoteNumber getNoteId() const override
Required virtual function that returns the note id.
Definition Details.h:1449
NoteNumber noteId
The ID of the note being assigned a code.
Definition Details.h:1446
PercussionNoteTypeId noteCode
The percussion note code. Use this to search the incis of the percussion map for the specific note.
Definition Details.h:1447
static const xml::XmlElementArray< PercussionNoteCode > & xmlMappingArray()
Required for musx::factory::FieldPopulator.
PercussionNoteCode(const DocumentWeakPtr &document, Cmper partId, ShareMode shareMode, EntryNumber entnum, Inci inci)
Constructor function.
Definition Details.h:1441
static constexpr std::string_view XmlNodeName
The XML node name for this type.
Definition Details.h:1451
Beam alteration for downstem secondary beams.
Definition Details.h:1462
static bool calcIsFeatheredBeam(const EntryInfoPtr &entryInfo, Evpu &outLeftY, Evpu &outRightY)
Calculates if the input entry starts a feathered beam and returns information about it.
Definition Details.h:1482
SecondaryBeamAlterationsDownStem(const DocumentWeakPtr &document, Cmper partId, ShareMode shareMode, EntryNumber entnum, Inci inci)
Constructor.
Definition Details.h:1473
static constexpr std::string_view XmlNodeName
The XML node name for this type.
Definition Details.h:1485
Beam alteration for downstem secondary beams.
Definition Details.h:1495
static bool calcIsFeatheredBeam(const EntryInfoPtr &entryInfo, Evpu &outLeftY, Evpu &outRightY)
Calculates if the input entry starts a feathered beam and returns information about it.
Definition Details.h:1515
static constexpr std::string_view XmlNodeName
The XML node name for this type.
Definition Details.h:1518
SecondaryBeamAlterationsUpStem(const DocumentWeakPtr &document, Cmper partId, ShareMode shareMode, EntryNumber entnum, Inci inci)
Constructor.
Definition Details.h:1506
Specifies which secondary beams break and restart on the associated entry.
Definition Details.h:1530
SecondaryBeamBreak(const DocumentWeakPtr &document, Cmper partId, ShareMode shareMode, EntryNumber entnum)
Constructor function.
Definition Details.h:1533
static constexpr std::string_view XmlNodeName
The XML node name for this type.
Definition Details.h:1574
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 Details.h:1561
BeamNumber calcLowestBreak() const
Calculates the lowest (largest note-value) beam specified for a secondary beam break.
Definition Details.h:1547
bool breakThrough
True if the beam should be broken through to the largest specified beam value.
Definition Details.h:1539
unsigned mask
Composite mask of beam breaks, derived from <do16th> through <do4096th> tags.
Definition Details.h:1538
static const xml::XmlElementArray< SecondaryBeamBreak > & xmlMappingArray()
Required for musx::factory::FieldPopulator.
Embedded shape record for a single index in noteShapes.
Definition Details.h:1600
char32_t quarter
Filled (quarter) notehead symbol (xml nodename is <q>).
Definition Details.h:1605
char32_t whole
Whole notehead symbol (xml nodename is <w>).
Definition Details.h:1603
static const xml::XmlElementArray< NoteShapes > & xmlMappingArray()
Required for musx::factory::FieldPopulator.
char32_t doubleWhole
Double-whole notehead symbol (xml nodename is <d>).
Definition Details.h:1602
char32_t half
Half notehead symbol (xml nodename is <h>).
Definition Details.h:1604
Shape Note settings for staves and staffs style.
Definition Details.h:1588
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 Details.h:1614
ShapeNoteBase(const DocumentWeakPtr &document, Cmper partId, ShareMode shareMode, Cmper cmper1, Cmper cmper2)
Constructor function.
Definition Details.h:1592
std::vector< std::shared_ptr< NoteShapes > > noteShapes
Notehead shapes (only the first seven elements are used).
Definition Details.h:1610
bool arrangedByPitch
Definition Details.h:1611
static const xml::XmlElementArray< ShapeNoteBase > & xmlMappingArray()
Required for musx::factory::FieldPopulator.
Shape Note settings for staff styles.
Definition Details.h:1653
static constexpr std::string_view XmlNodeName
XML node name for this type.
Definition Details.h:1657
Shape Note settings for staves.
Definition Details.h:1638
static constexpr std::string_view XmlNodeName
XML node name for this type.
Definition Details.h:1642
Provides run-time information about Staff Groups within a system or list of others::StaffUsed.
Definition Details.h:1789
std::optional< size_t > startSlot
the 0-based start slot (index) of the group in the system staves.
Definition Details.h:1791
std::optional< size_t > endSlot
the 0-based end slot (index) of the group in the system staves.
Definition Details.h:1792
std::optional< size_t > numStaves() const
The number of staves in the group for the systemStaves.
Definition Details.h:1803
MusxInstanceList< others::StaffUsed > systemStaves
the system staves referred to by startSlot and endSlot
Definition Details.h:1794
MusxInstance< StaffGroup > group
the StaffGroup record for the group.
Definition Details.h:1793
void iterateStaves(MeasCmper measId, Edu eduPosition, std::function< bool(const MusxInstance< others::StaffComposite > &)> iterator) const
Iterates the staves in the group in order according to systemStaves.
Definition Details.cpp:323
static std::vector< StaffGroupInfo > getGroupsAtMeasure(MeasCmper measureId, Cmper linkedPartId, const MusxInstanceList< others::StaffUsed > &systemStaves)
Creates a vector of StaffGroupInfo instances for the measure, part, and system staves.
Definition Details.cpp:343
Represents the attributes of a Finale staff group that brackets staves.
Definition Details.h:1666
AlignJustify abbrvNameJustify
Abbreviated name justification (xml node is <abbrvJustify>)
Definition Details.h:1718
bool abbrvNameExpand
"Expand Single Word" for abbreviated name (xml node is <abbrvExpand>)
Definition Details.h:1730
Cmper multiStaffGroupId
Definition Details.h:1733
static const xml::XmlElementArray< StaffGroup > & xmlMappingArray()
Required for musx::factory::FieldPopulator.
bool fullNameExpand
"Expand Single Word" for full name (xml node is <fullExpand>)
Definition Details.h:1729
bool ownBarline
"Use Alternate Group Barline"
Definition Details.h:1720
int abbrvNameYadj
Vertical adjustment for abbreviated name (xml node is <abbrvYadj>)
Definition Details.h:1726
DrawBarlineStyle
Enum for how to draw group barlines.
Definition Details.h:1690
@ Mensurstriche
Draw barlines between staves (xml value is "Mensurstriche" with capitalization)
@ ThroughStaves
Draw barlines through staves (xml value is "group")
@ OnlyOnStaves
Default value (may not appear in xml)
std::string getAbbreviatedInstrumentName(util::EnigmaString::AccidentalStyle accidentalStyle=util::EnigmaString::AccidentalStyle::Ascii) const
Returns the abbreviated instrument name for this group without Enigma tags and with autonumbering (if...
Definition Details.cpp:289
bool isAllMeasures() const
Returns true if this group spans all measures.
Definition Details.h:1764
Cmper abbrvNameId
Abbreviated name TextBlock cmper (xml node is <abbrvID>)
Definition Details.h:1724
StaffCmper startInst
Starting staff ID.
Definition Details.h:1708
int fullNameXadj
Horizontal adjustment for full name (xml node is <fullXadj>)
Definition Details.h:1713
std::shared_ptr< Bracket > bracket
Bracket Options. The factory guarantees this value to exist.
Definition Details.h:1715
std::string getAbbreviatedName(util::EnigmaString::AccidentalStyle accidentalStyle=util::EnigmaString::AccidentalStyle::Ascii) const
Get the abbreviated staff name without Enigma tags.
Definition Details.cpp:263
AlignJustify fullNameJustify
Full name justification (xml node is <fullJustify>)
Definition Details.h:1717
DrawBarlineStyle drawBarlines
"Draw Barlines" option (xml node is <groupBarlineStyle>)
Definition Details.h:1719
AlignJustify abbrvNameAlign
Abbreviated name horizontal alignment (xml node is <abbrvHAlign>)
Definition Details.h:1728
std::unordered_set< StaffCmper > staves
Calculated list of staves in the group.
Definition Details.h:1738
int fullNameYadj
Vertical adjustment for full name (xml node is <fullYadj>)
Definition Details.h:1714
HideStaves hideStaves
"When Hiding Empty Staves" option (xml node is <optimize>)
Definition Details.h:1731
BarlineType barlineType
Group barline type (xml node is <barline>)
Definition Details.h:1716
AlignJustify fullNameAlign
Full name horizontal alignment (xml node is <fullHAlign>)
Definition Details.h:1727
Cmper fullNameId
Full name TextBlock cmper (xml node is <fullID>)
Definition Details.h:1712
std::string getFullInstrumentName(util::EnigmaString::AccidentalStyle accidentalStyle=util::EnigmaString::AccidentalStyle::Ascii) const
Returns the full instrument name for this group without Enigma tags and with autonumbering (if any).
Definition Details.cpp:279
StaffGroup(const DocumentWeakPtr &document, Cmper partId, Base::ShareMode shareMode, Cmper cmper1, Cmper cmper2)
Constructor.
Definition Details.h:1676
StaffCmper endInst
Ending staff ID.
Definition Details.h:1709
static constexpr std::string_view XmlNodeName
XML node name for this type.
Definition Details.h:1780
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 Details.h:1767
MeasCmper startMeas
Starting measure number.
Definition Details.h:1710
std::string getFullName(util::EnigmaString::AccidentalStyle accidentalStyle=util::EnigmaString::AccidentalStyle::Ascii) const
Get the full staff name without Enigma tags.
Definition Details.cpp:258
MusxInstance< others::MultiStaffInstrumentGroup > getMultiStaffInstGroup() const
Returns the others::MultiStaffInstrumentGroup for this group if it is part of one....
Definition Details.cpp:268
MeasCmper endMeas
Ending measure number.
Definition Details.h:1711
bool hideName
Inverse of "Show Group Name".
Definition Details.h:1723
bool fullNameIndivPos
Indicates if full name has individual position (xml node is <fullIndivPos>)
Definition Details.h:1721
bool abbrvNameIndivPos
Indicates if abbreviated name has individual position (xml node is <abbrvIndivPos>)
Definition Details.h:1722
int abbrvNameXadj
Horizontal adjustment for abbreviated name (xml node is <abbrvXadj>)
Definition Details.h:1725
HideStaves
Enum for optimization options.
Definition Details.h:1701
@ AsGroup
Hide staves only if all staves are empty.
@ Normally
Hide staves as if there were no StaffGroup (this is the default and may not appear in the xml)
@ None
Never hide the staves in this StaffGroup.
Represents a per-staff-size override for a specific staff in a system.
Definition Details.h:1834
static constexpr std::string_view XmlNodeName
The XML node name for this type.
Definition Details.h:1855
static const xml::XmlElementArray< StaffSize > & xmlMappingArray()
Required for musx::factory::FieldPopulator.
util::Fraction calcStaffScaling() const
Calculate the effect staff scaling.
Definition Details.h:1852
StaffSize(const DocumentWeakPtr &document, Cmper partId, ShareMode shareMode, Cmper system, Cmper staffId)
Constructor.
Definition Details.h:1844
int staffPercent
The staff size percentage override. (A value of 100 means 100%, i.e, no staff scaling....
Definition Details.h:1849
Specifies horizontal and vertical adjustments for stems under beam.
Definition Details.h:1894
static constexpr std::string_view XmlNodeName
The XML node name for this type.
Definition Details.h:1898
Specifies horizontal and vertical stem adjustments for upstem and downstem contexts.
Definition Details.h:1868
Evpu upVertAdjust
Vertical adjustment for upstem context (positive is up).
Definition Details.h:1876
Evpu downHorzAdjust
Horizontal adjustment for downstem context (positive is right).
Definition Details.h:1879
Evpu downVertAdjust
Vertical adjustment for downstem context (positive is up).
Definition Details.h:1877
static const xml::XmlElementArray< StemAlterations > & xmlMappingArray()
Required for musx::factory::FieldPopulator.
Evpu upHorzAdjust
Horizontal adjustment for upstem context (positive is right).
Definition Details.h:1878
StemAlterations(const DocumentWeakPtr &document, Cmper partId, ShareMode shareMode, EntryNumber entnum)
Constructor function.
Definition Details.h:1871
static constexpr std::string_view XmlNodeName
The XML node name for this type.
Definition Details.h:1881
Specifies the TAB string a note appears on. Finale automatically figures out the fret number from the...
Definition Details.h:1911
TablatureNoteMods(const DocumentWeakPtr &document, Cmper partId, ShareMode shareMode, EntryNumber entnum, Inci inci)
Constructor function.
Definition Details.h:1914
NoteNumber getNoteId() const override
Required virtual function that returns the note id.
Definition Details.h:1923
static const xml::XmlElementArray< TablatureNoteMods > & xmlMappingArray()
Required for musx::factory::FieldPopulator.
static constexpr std::string_view XmlNodeName
The XML node name for this type.
Definition Details.h:1925
NoteNumber noteId
The ID of the tablature note being modified. (xml node is <noteID>)
Definition Details.h:1919
int stringNumber
Definition Details.h:1920
Base class for tie alteration properties. (Used for both ties and tie ends.)
Definition Details.h:1934
Evpu yEnd
Vertical end position of the tie.
Definition Details.h:1946
NoteNumber noteId
Note ID associated with the tie alteration. (xml node is <noteID>)
Definition Details.h:1942
bool outerLocal
Local setting for "Outer Tie".
Definition Details.h:1947
Evpu xStart
Horizontal start position of the tie.
Definition Details.h:1943
Evpu height1
Height of the first control point.
Definition Details.h:1965
NoteNumber getNoteId() const override
Required virtual function that returns the note id.
Definition Details.h:1970
bool afterMultiDotsLocal
Local setting for "After Multiple Dots".
Definition Details.h:1950
bool shiftForSecondsOn
Enable "Shift for Seconds".
Definition Details.h:1953
Evpu height2
Height of the second control point.
Definition Details.h:1967
TieAlterBase(const DocumentWeakPtr &document, Cmper partId, Base::ShareMode shareMode, EntryNumber entnum, Inci inci)
Constructor function.
Definition Details.h:1937
Evpu insetRatio1
Inset ratio for the first control point.
Definition Details.h:1964
bool enPtAdjOn
Enable end point adjustment.
Definition Details.h:1963
bool shiftForSecondsLocal
Local setting for "Shift for Seconds".
Definition Details.h:1952
bool afterSingleDotOn
Enable "After Single Dot".
Definition Details.h:1949
bool afterMultiDotsOn
Enable "After Multiple Dots".
Definition Details.h:1951
Evpu insetRatio2
Inset ratio for the second control point.
Definition Details.h:1966
bool breakKeyLocal
Local setting for "Break at Key Signature".
Definition Details.h:1959
bool breakKeyOn
Enable "Break at Key Signature".
Definition Details.h:1960
bool down
Downward tie. Only applicable if freezeDirection is true. (False freezes the tie up....
Definition Details.h:1956
bool beforeSingleAcciOn
Enable "Before Single Accidental".
Definition Details.h:1955
bool stPtAdjOn
Enable start point adjustment.
Definition Details.h:1962
static const xml::XmlElementArray< TieAlterBase > & xmlMappingArray()
Required for musx::factory::FieldPopulator.
bool beforeSingleAcciLocal
Local setting for "Before Single Accidental".
Definition Details.h:1954
Evpu xEnd
Horizontal end position of the tie.
Definition Details.h:1944
bool ctlPtAdjOn
Enable control point adjustment.
Definition Details.h:1968
bool breakTimeLocal
Local setting for "Break at Time Signature".
Definition Details.h:1957
bool freezeDirection
Freeze tie direction. (xml node is <freeze>)
Definition Details.h:1961
Evpu yStart
Vertical start position of the tie.
Definition Details.h:1945
bool afterSingleDotLocal
Local setting for "After Single Dot".
Definition Details.h:1948
bool breakTimeOn
Enable "Break at Time Signature".
Definition Details.h:1958
bool requireAllFields() const override
Unless we decide to figure out connection types, this will stay here.
Definition Details.h:1972
Alterations for tie ends.
Definition Details.h:1985
static constexpr std::string_view XmlNodeName
The XML node name for this type.
Definition Details.h:1989
static const xml::XmlElementArray< TieAlterEnd > & xmlMappingArray()
Required for musx::factory::FieldPopulator.
Alterations for tie starts. (Tie starts are normal ties.)
Definition Details.h:2002
static constexpr std::string_view XmlNodeName
The XML node name for this type.
Definition Details.h:2006
static const xml::XmlElementArray< TieAlterStart > & xmlMappingArray()
Required for musx::factory::FieldPopulator.
Options controlling the appearance of tuplets.
Definition Details.h:2019
bool hidden
Inverse of "Show".
Definition Details.h:2045
util::Fraction calcRatio() const
return the tuplet ratio (reference / display)
Definition Details.h:2072
util::Fraction calcDisplayDuration() const
return the display duration as a util::Fraction of a whole note
Definition Details.h:2069
Evpu tupOffX
Horizontal offset.
Definition Details.h:2046
Evpu rightHookLen
Length of the right hook in the tuplet bracket. (This value is sign-reversed in the Finale UI....
Definition Details.h:2061
Evpu brackOffY
Vertical offset for brackets.
Definition Details.h:2049
BracketStyle brackStyle
Bracket style.
Definition Details.h:2057
bool avoidStaff
"Avoid Staff"
Definition Details.h:2043
AutoBracketStyle autoBracketStyle
Autobracket style.
Definition Details.h:2044
bool alwaysFlat
"Always Flat" (xml node is <flat>)
Definition Details.h:2040
bool fullDura
"Bracket Full Duration"
Definition Details.h:2041
bool allowHorz
"Allow Horizontal Drag"
Definition Details.h:2052
int referenceNumber
The number of notes "in the time of" (xml node is <refNum>)
Definition Details.h:2038
Evpu rightHookExt
Extension of the right hook beyond the tuplet bracket.
Definition Details.h:2062
Evpu leftHookExt
Extension of the left hook beyond the tuplet bracket.
Definition Details.h:2060
bool ignoreHorzNumOffset
"Ignore Horizontal Number Offset" (xml node is <ignoreGlOffs>)
Definition Details.h:2053
TupletDef(const DocumentWeakPtr &document, Cmper partId, ShareMode shareMode, EntryNumber entnum, Inci inci)
Constructor function.
Definition Details.h:2022
util::Fraction calcReferenceDuration() const
return the reference duration as a util::Fraction of a whole note
Definition Details.h:2066
bool smartTuplet
"Engraver Tuplets"
Definition Details.h:2058
Edu displayDuration
The duration of each note to display (xml node is <symbolicDur>)
Definition Details.h:2037
Evpu tupOffY
Vertical.
Definition Details.h:2047
NumberStyle numStyle
Number style.
Definition Details.h:2050
static const xml::XmlElementArray< TupletDef > & xmlMappingArray()
Required for musx::factory::FieldPopulator.
Evpu brackOffX
Horizontal offset for brackets.
Definition Details.h:2048
Evpu manualSlopeAdj
"Manual Slope Adjustment" in Evpu. (xml node is <slope>)
Definition Details.h:2063
static constexpr std::string_view XmlNodeName
The XML node name for this type.
Definition Details.h:2074
bool breakBracket
"Break Slur or Bracket"
Definition Details.h:2054
int displayNumber
The number of notes to display (xml node is <symbolicNum>)
Definition Details.h:2036
bool metricCenter
"Center Number Using Duration"
Definition Details.h:2042
bool useBottomNote
"Use Bottom Note" (xml node is <noteBelow>)
Definition Details.h:2056
bool matchHooks
"Match Length of Hooks"
Definition Details.h:2055
PositioningStyle posStyle
Positioning style.
Definition Details.h:2051
Edu referenceDuration
The duration of eacn note "in the time of" (xml node is <refDur>)
Definition Details.h:2039
Evpu leftHookLen
Length of the left hook in the tuplet bracket. (This value is sign-reversed in the Finale UI....
Definition Details.h:2059
FlattenStyle
Beaming style choices for when to flatten beams.
Definition Options.h:177
AlignJustify
Horizontal and vertical alignment/justification values.
Definition Options.h:605
BracketStyle
Bracket style options.
Definition Options.h:1825
PositioningStyle
Positioning style options.
Definition Options.h:1812
AutoBracketStyle
Auto-bracket style options.
Definition Options.h:1784
NumberStyle
Number style options.
Definition Options.h:1799
BarlineType
Barline type for left and right barlines.
Definition Others.h:1110
AlignJustify
Alignment and justification options for staff and group names.
Definition CommonClasses.h:654
Contains chorus text for lyrics.
Definition Texts.h:152
Contains section text for lyrics.
Definition Texts.h:167
Contains verse text for lyrics.
Definition Texts.h:137
Wrapper class for interpreting and rendering Enigma-style strings with insert handling.
Definition EnigmaString.h:415
AccidentalStyle
Enumeration to specify the type of accidental substitution representation.
Definition EnigmaString.h:191
@ Ascii
Use ASCII substitutions for accidentals.
A class to represent fractions with integer m_numerator and m_denominator, automatically reduced to s...
Definition Fraction.h:38
static Fraction fromPercent(int percent)
Constructs a Fraction from a percent (where 100 is 100%)
Definition Fraction.h:89
@ Verbose
Informational messages that should only displayed when verbose logging is requested.
static void log(LogLevel level, const std::string &message)
Logs a message with a specific severity level.
Definition Logger.h:87
constexpr int STANDARD_DIATONIC_STEPS
currently this is the only supported number of diatonic steps.
Definition music_theory.hpp:45
constexpr int MAX_ALTERATIONS
Maximum absolute value for chromatic alterations supported in Finale.
Definition Fundamentals.h:78
ShowClefMode
Enum representing the clef display mode for a frame.
Definition CommonClasses.h:109
uint16_t PercussionNoteTypeId
multiple times in one layout. The rest are the "pure" note type. See percussion::PercussionNoteType.
Definition Fundamentals.h:74
int16_t MeasCmper
Enigma meas Cmper (may be negative when not applicable)
Definition Fundamentals.h:64
int32_t Efix
EFIX value (64 per EVPU, 64*288=18432 per inch)
Definition Fundamentals.h:60
std::shared_ptr< const T > MusxInstance
Defines the type of a musx instance stored in a pool.
Definition MusxInstance.h:35
constexpr Cmper SCORE_PARTID
The part id of the score.
Definition Fundamentals.h:79
int16_t Inci
Enigma "incident" key type.
Definition Fundamentals.h:56
int32_t Evpu
EVPU value (288 per inch)
Definition Fundamentals.h:57
constexpr int MAX_LAYERS
The maximum number of music layers in a Finale document.
Definition Fundamentals.h:77
uint16_t Cmper
Enigma "comperator" key type.
Definition Fundamentals.h:55
int32_t Edu
"Enigma Durational Units" value (1024 per quarter note)
Definition Fundamentals.h:61
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
int16_t StaffCmper
Enigma staff (staffId) Cmper (may be negative when not applicable)
Definition Fundamentals.h:65
unsigned int BeamNumber
A number where 1 corresponds to the primary (8th note) beam, 2 the 16th beam, 3 the 32nd beam,...
Definition Fundamentals.h:72
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