MUSX Document Model
Loading...
Searching...
No Matches
Staff.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 <type_traits>
25
26#include "musx/util/Logger.h"
27#include "musx/util/Fraction.h"
28
29#include "BaseClasses.h"
30#include "CommonClasses.h"
31 // do not add other dom class dependencies. Use .cpp files for implementations that need total class access.
32
33namespace musx {
34namespace dom {
35
36namespace details {
37class Baseline;
38class BaselineNoInci;
39class ShapeNoteBase;
40}
41
42namespace others {
43
44class StaffStyle;
51class Staff : public OthersBase
52{
53public:
66
71 enum class NotationStyle
72 {
73 Standard,
75 Tablature
76 };
77
82 enum class HideMode
83 {
84 None,
85 Cutaway,
87 Score
88 };
89
95 {
96 Normal,
98 Rhythmic,
99 Blank,
103 };
104
110 {
111 public:
112 int interval{};
113 int adjust{};
114
116 };
117
130
139 {
140 public:
142
143 bool setToClef{};
145
147 std::shared_ptr<KeySigTransposition> keysig;
148
150 std::shared_ptr<ChromaticTransposition> chromatic;
151
153 bool isSame(const Transposition& other) const;
154
155 void integrityCheck(const std::shared_ptr<EnigmaBase>& ptrToThis) override
156 {
158 Cmper thisCmper = 0;
159 if (const auto parent = getParent<others::Staff>()) {
160 thisCmper = parent->getCmper();
161 }
162 if (!keysig && !chromatic) {
163 MUSX_INTEGRITY_ERROR("Transposition settings " + std::to_string(thisCmper) + " has neither a key signature nor chromatic settings.");
164 } else if (keysig && chromatic) {
165 MUSX_INTEGRITY_ERROR("Transposition settings " + std::to_string(thisCmper) + " has both key signature and chromatic settings.");
166 }
167 }
168
170 };
171
173 explicit Staff(const DocumentWeakPtr& document, Cmper partId, ShareMode shareMode, Cmper cmper)
174 : OthersBase(document, partId, shareMode, cmper) {}
175
176 // WARNING: Any fields added here must have a mask added in StaffStyle (if it does not already exist)
177 // and must be added to StaffComposite::applyStyle.
178
179 // Public properties corresponding to the XML structure
181 std::shared_ptr<FontInfo> noteFont;
183 bool useNoteFont{};
186 std::optional<int> staffLines{};
187 std::optional<std::vector<int>> customStaff;
189 std::string instUuid;
190 int capoPos{};
192 bool floatKeys{};
193 bool floatTime{};
194 bool blineBreak{};
195 bool rbarBreak{};
196 bool hasStyles{};
199 std::shared_ptr<Transposition> transposition;
216 bool flatBeams{};
220 bool hideLyrics{};
221 bool noOptimize{};
224 bool hideRepeats{};
226 bool hideRptBars{};
227 bool hideKeySigs{};
229 bool hideClefs{};
231 bool hideChords{};
232 bool noKey{};
237 bool hideRests{};
238 bool hideTies{};
239 bool hideDots{};
249 bool hideTuplets{};
251 bool hideStems{};
253 bool hideBeams{};
271
272 // The following values are not in xml but computed by the factory.
273
287 std::optional<int> autoNumberValue;
288 std::optional<Cmper> percussionMapId;
289
293
297
299 bool calcShowName() const;
300
303
307
311 util::EnigmaParsingContext getFullInstrumentNameCtx(Cmper forPartId, bool preferStaffName = false) const;
312
316 util::EnigmaParsingContext getAbbreviatedInstrumentNameCtx(Cmper forPartId, bool preferStaffName = false) const;
317
322 std::string getFullInstrumentName(util::EnigmaString::AccidentalStyle accidentalStyle = util::EnigmaString::AccidentalStyle::Ascii, bool preferStaffName = false) const;
323
328 std::string getAbbreviatedInstrumentName(util::EnigmaString::AccidentalStyle accidentalStyle = util::EnigmaString::AccidentalStyle::Ascii, bool preferStaffName = false) const;
329
331 bool calcShowInstrumentName() const;
332
335
338
341
343 bool showNamesForPart(Cmper partId) const
344 { return partId == SCORE_PARTID ? !hideNameInScore : showNameInParts; }
345
355 static void calcAllAutoNumberValues(const DocumentPtr& document);
356
362 template <typename SubType>
363 static void calcAllRuntimeValues(const DocumentPtr& document);
364
369 std::pair<std::string, bool> calcAutoNumberingAffix() const;
370
374 std::string addAutoNumbering(const std::string& plainName) const;
375
380 ClefIndex calcClefIndexAt(MeasCmper measureId, Edu position, bool forWrittenPitch = false) const;
381
383 ClefIndex calcFirstClefIndex(bool forWrittenPitch = false) const
384 { return calcClefIndexAt(1, 0, forWrittenPitch); }
385
390 static ClefIndex calcFirstClefIndex(const DocumentPtr& document, Cmper partId, StaffCmper staffCmper);
391
393 int calcNumberOfStafflines() const;
394
396 int calcMiddleStaffPosition() const;
397
404
409 template<typename BaselineType,
410 std::enable_if_t<std::is_base_of<details::BaselineNoInci, BaselineType>::value, int> = 0>
412 {
413 return calcBaselinePositionImpl<BaselineType>(systemId, std::nullopt);
414 }
415
421 template<typename BaselineType,
422 std::enable_if_t<std::is_base_of<details::Baseline, BaselineType>::value &&
423 !std::is_base_of<details::BaselineNoInci, BaselineType>::value, int> = 0>
424 Evpu calcBaselinePosition(SystemCmper systemId, Cmper lyricNumber) const
425 {
426 return calcBaselinePositionImpl<BaselineType>(systemId, lyricNumber);
427 }
428
432 std::vector<LyricsLineInfo> createLyricsLineInfo(SystemCmper systemId) const;
433
435 int calcTopLinePosition() const;
436
438 int calcBottomLinePosition() const;
439
441 bool hasInstrumentAssigned() const;
442
448 std::pair<int, int> calcTranspositionInterval() const;
449
452 MusxInstanceList<PartDefinition> getContainingParts(bool includeScore = true) const;
453
457
460 bool calcAlternateNotationHidesEntries(LayerIndex forLayerIndex) const;
461
465 bool iterateEntries(std::function<bool(const EntryInfoPtr&)> iterator) const;
466
469 bool calcIsSameNotationStyle(const Staff& other) const;
470
471 void integrityCheck(const std::shared_ptr<EnigmaBase>& ptrToThis) override
472 {
474 if (!staffLines && !customStaff) {
475 MUSX_INTEGRITY_ERROR("Staff or StaffStyle " + std::to_string(getCmper()) + " has neither a standard nor a custom staff definition.");
476 } else if (staffLines && customStaff) {
477 MUSX_INTEGRITY_ERROR("Staff or StaffStyle " + std::to_string(getCmper()) + " has both a standard and a custom staff definition.");
478 }
479 if (customStaff) { // guarantee ascending order of staves.
480 std::sort(customStaff.value().begin(), customStaff.value().end(),
481 [](const auto& a, const auto& b) { return a < b; });
482 }
483 if (transposition) {
484 if (!transposition->chromatic && !transposition->keysig) {
485 MUSX_INTEGRITY_ERROR("Staff or StaffStyle " + std::to_string(getCmper()) + " has transposition with neither keysig nor chromatic transposition defined.");
486 } else if (transposition->chromatic && transposition->keysig) {
487 MUSX_INTEGRITY_ERROR("Staff or StaffStyle " + std::to_string(getCmper()) + " has transposition with both keysig and chromatic transposition defined.");
488 }
489 }
490 if (useNoteFont && !noteFont) {
491 noteFont = std::make_shared<FontInfo>(getDocument()); // do this first to avoid unreachable code warning, since MUSX_INTEGRITY_ERROR might throw
492 MUSX_INTEGRITY_ERROR("Staff or StaffStyle " + std::to_string(getCmper()) + " specifies to use a custom notehead font, but no custom font was provided.");
493 }
494 }
495
496 constexpr static std::string_view XmlNodeName = "staffSpec";
498
499private:
500 template <typename NamePositionType>
501 MusxInstance<NamePositioning> getNamePosition() const;
502
503 template<typename BaselineType>
504 Evpu calcBaselinePositionImpl(SystemCmper systemId, std::optional<Cmper> lyricNumber) const;
505};
506
514class StaffStyle : public Staff
515{
516protected:
518 explicit StaffStyle(const MusxInstance<Staff>& staff)
519 : Staff(*staff) {}
520
524 {
525 masks = std::make_shared<Masks>(ptrToSelf);
526 }
527
528public:
530 explicit StaffStyle(const DocumentWeakPtr& document, Cmper partId, ShareMode shareMode, Cmper cmper)
531 : Staff(document, partId, shareMode, cmper) {}
532
583
584 std::string styleName;
585 bool copyable{};
586 bool addToMenu{};
587 std::shared_ptr<Masks> masks;
589
612 bool containsInstrumentChange() const;
613
622 Cmper partId, StaffCmper staffId, MeasCmper measId, Edu eduPosition);
623
624 void integrityCheck(const std::shared_ptr<EnigmaBase>& ptrToThis) override
625 {
626 if (!masks) {
627 // Finale allows creation of staff styles with no masks, so this is just a verbose comment
629 + " (" + std::to_string(getCmper()) + ") does not override anything.");
630 createMasks(ptrToThis);
631 }
632 if (useNoteFont && !masks->floatNoteheadFont && !noteFont) {
633 useNoteFont = false; // silence integrity check in Staff.
634 }
635 Staff::integrityCheck(ptrToThis);
636 }
637
638 constexpr static std::string_view XmlNodeName = "staffStyle";
640};
641
652{
653public:
655 explicit StaffStyleAssign(const DocumentWeakPtr& document, Cmper partId, ShareMode shareMode, Cmper cmper, Inci inci)
656 : EnigmaMusicRange(document, partId, shareMode, cmper, inci) {}
657
659
664
665 void integrityCheck(const std::shared_ptr<EnigmaBase>& ptrToThis) override
666 {
668 if (!styleId) {
669 MUSX_INTEGRITY_ERROR(std::string("Staff style assignment has no staff style id:")
670 + " Part " + std::to_string(getSourcePartId())
671 + " Staff " + std::to_string(getCmper())
672 );
673 }
674 }
675
676 constexpr static std::string_view XmlNodeName = "staffStyleAssign";
678};
679
688{
689private:
691 explicit StaffComposite(const MusxInstance<Staff>& staff, MeasCmper measId, Edu eduPosition)
692 : StaffStyle(staff), m_measureId(measId), m_eduPosition(eduPosition) {}
693
696 void applyStyle(const MusxInstance<StaffStyle>& staffStyle);
697
698 const MeasCmper m_measureId;
699 const Edu m_eduPosition;
700 bool m_instUuidChanged{};
701
702public:
714 static MusxInstance<StaffComposite> createCurrent(const DocumentPtr& document, Cmper partId, StaffCmper staffId, MeasCmper measId, Edu eduPosition);
715
717 MeasCmper getMeasureId() const { return m_measureId; }
718
720 Edu getEduPosition() const { return m_eduPosition; }
721
723 bool getInstrumentUuidChanged() const { return m_instUuidChanged; }
724
727 ClefIndex calcClefIndex(bool forWrittenPitch = false) const
728 { return this->calcClefIndexAt(m_measureId, m_eduPosition, forWrittenPitch); }
729
732};
733
734} // namespace others
735} // namespace dom
736} // namespace musx
EnigmaBase class for classes that are contained by other classes.
Definition BaseClasses.h:185
ContainedClassBase(const MusxInstance< EnigmaBase > &parent)
Constructs a ContainedClassBase object.
Definition BaseClasses.h:194
DocumentPtr getDocument() const
Gets a reference to the Document.
Definition DocumentElement.h:58
ShareMode
Describes how this instance is shared between part and score.
Definition BaseClasses.h:91
Cmper getSourcePartId() const
Gets the source partId for this instance. If an instance is fully shared with the score,...
Definition BaseClasses.h:104
virtual void integrityCheck(const std::shared_ptr< EnigmaBase > &ptrToThis)
Performs a final consistency check after population.
Definition BaseClasses.h:125
Wraps a frame of shared_ptr<const EntryInfo> and an index for per entry access. This class manages ow...
Definition Entries.h:513
Provides optional per-type extension methods for MusxInstanceList.
Definition MusxInstance.h:118
EnigmaBase class for all "others" types.
Definition BaseClasses.h:244
Cmper getCmper() const
Gets the cmper key value.
Definition BaseClasses.h:289
The representation of a range of music used by Enigma files.
Definition CommonClasses.h:721
Represents a composite of an underlying Staff instance with any applicable StaffStyle instances appli...
Definition Staff.h:688
static MusxInstance< StaffComposite > createCurrent(const DocumentPtr &document, Cmper partId, StaffCmper staffId, MeasCmper measId, Edu eduPosition)
Calculates the current staff at the specified metric position by applying all relevant staff styles,...
Definition Staff.cpp:1063
bool getInstrumentUuidChanged() const
Returns if this composite staff includes an instrument uuid changed by a staff style.
Definition Staff.h:723
ClefIndex calcClefIndex(bool forWrittenPitch=false) const
Returns the clef in this staff at the location of the composite staff.
Definition Staff.h:727
Edu getEduPosition() const
Returns the Edu position this staff composite was created with.
Definition Staff.h:720
MusxInstance< others::Staff > getRawStaff() const
Returns the underlying staff without any staff styles applied.
Definition Staff.cpp:1054
MeasCmper getMeasureId() const
Returns the measure this staff composite was created with.
Definition Staff.h:717
Represents an assignment.
Definition Staff.h:652
Cmper styleId
The cmper of the assigned StaffStyle.
Definition Staff.h:658
void integrityCheck(const std::shared_ptr< EnigmaBase > &ptrToThis) override
Performs a final consistency check after population.
Definition Staff.h:665
StaffStyleAssign(const DocumentWeakPtr &document, Cmper partId, ShareMode shareMode, Cmper cmper, Inci inci)
Constructor function.
Definition Staff.h:655
static const xml::XmlElementArray< StaffStyleAssign > & xmlMappingArray()
Required for musx::factory::FieldPopulator.
static constexpr std::string_view XmlNodeName
The XML node name for this type.
Definition Staff.h:676
MusxInstance< StaffStyle > getStaffStyle() const
Returns the StaffStyle instance for this assignment.
Definition Staff.cpp:1119
lists the masks that deterimine if this staff style overrides the staff settings
Definition Staff.h:535
bool rbarBreak
overrides Staff::rbarBreak
Definition Staff.h:549
bool blineBreak
overrides Staff::blineBreak
Definition Staff.h:548
bool hideRptBars
overrides Staff::hideRptBars
Definition Staff.h:558
bool showTies
overrides Staff::hideTies
Definition Staff.h:567
bool negTimeParts
overrides Staff::hideTimeSigsInParts
Definition Staff.h:578
bool hideStaffLines
overrides Staff::hideStaffLines
Definition Staff.h:576
bool fullName
overrides Staff::fullNameTextId
Definition Staff.h:554
bool floatNoteheadFont
overrides notehead font settings
Definition Staff.h:539
bool negKey
overrides Staff::hideKeySigs
Definition Staff.h:559
bool negClef
overrides Staff::hideClefs
Definition Staff.h:561
bool negRepeat
overrides Staff::hideRepeats
Definition Staff.h:551
bool flatBeams
overrides Staff::flatBeams
Definition Staff.h:541
bool showNameParts
overrides Staff::showNameInParts
Definition Staff.h:574
bool hideChords
overrides Staff::hideChords
Definition Staff.h:571
bool hideBarlines
overrides Staff::hideBarlines
Definition Staff.h:553
bool noOptimize
overrides Staff::noOptimize
Definition Staff.h:543
bool blankMeasureRest
overrides Staff::blankMeasure
Definition Staff.h:542
bool staffType
overrides staff properties (see StaffComposite::applyStyle)
Definition Staff.h:546
bool negMnumb
overrides Staff::hideMeasNums
Definition Staff.h:550
bool hideKeySigsShowAccis
overrides Staff::hideKeySigsShowAccis
Definition Staff.h:579
bool redisplayLayerAccis
overrides Staff::redisplayLayerAccis
Definition Staff.h:577
bool negNameScore
overrides Staff::hideNameInScore
Definition Staff.h:552
static const xml::XmlElementArray< Masks > & xmlMappingArray()
Required for musx::factory::FieldPopulator.
bool hideFretboards
overrides Staff::hideFretboards
Definition Staff.h:572
bool hideLyrics
overrides Staff::hideLyrics
Definition Staff.h:573
bool fullNamePos
overrides presence, absence of NamePositionStyleFull instance.
Definition Staff.h:564
bool transposition
overrides transposition fields
Definition Staff.h:547
bool abrvName
overrides Staff::abbrvNameTextId
Definition Staff.h:555
bool negTime
overrides Staff::hideTimeSigs (in Score)
Definition Staff.h:560
bool altNotation
overrides alternate notation properties (see StaffComposite::applyStyle)
Definition Staff.h:566
bool showNoteColors
overrides Staff::showNoteColors
Definition Staff.h:575
bool showStems
overrides stem properties (see StaffComposite::applyStyle)
Definition Staff.h:570
bool abrvNamePos
overrides presence, absence of NamePositionStyleAbbreviated instance.
Definition Staff.h:565
bool floatKeys
overrides Staff::floatKeys
Definition Staff.h:556
bool notationStyle
overrides notations style
Definition Staff.h:544
bool showRests
overrides Staff::hideRests
Definition Staff.h:569
bool useNoteShapes
overrides Staff::useNoteShapes
Definition Staff.h:540
bool floatTime
overrides Staff::floatTime
Definition Staff.h:557
bool hideStaff
overrides Staff::hideMode
Definition Staff.h:562
bool defaultClef
overrides Staff::defaultClef
Definition Staff.h:545
bool noKey
overrides Staff::noKey
Definition Staff.h:563
bool showDots
overrides Staff::hideDots
Definition Staff.h:568
Represents a Finale staff style.
Definition Staff.h:515
std::shared_ptr< Masks > masks
Definition Staff.h:587
static const xml::XmlElementArray< StaffStyle > & xmlMappingArray()
Required for musx::factory::FieldPopulator.
StaffStyle(const MusxInstance< Staff > &staff)
protected constructor for StaffComposite. This constructor must be followed by a call to createMasks.
Definition Staff.h:518
void integrityCheck(const std::shared_ptr< EnigmaBase > &ptrToThis) override
Performs a final consistency check after population.
Definition Staff.h:624
StaffStyle(const DocumentWeakPtr &document, Cmper partId, ShareMode shareMode, Cmper cmper)
Constructor function.
Definition Staff.h:530
static constexpr std::string_view XmlNodeName
The XML node name for this type.
Definition Staff.h:638
bool containsInstrumentChange() const
Determines whether this staff style represents or includes an instrument change.
Definition Staff.cpp:1087
static MusxInstanceList< StaffStyle > findAllOverlappingStyles(const DocumentPtr &document, Cmper partId, StaffCmper staffId, MeasCmper measId, Edu eduPosition)
Finds a subset from all StaffStyle instances that overlap with the specified metric position on a giv...
Definition Staff.cpp:1095
bool copyable
whether the staff style assignments for this style should be copied when copy/pasting music
Definition Staff.h:585
void createMasks(const MusxInstance< EnigmaBase > &ptrToSelf)
Separate creator for masks.
Definition Staff.h:523
std::string styleName
name of staff style
Definition Staff.h:584
bool addToMenu
add this staff style to the context menu for staff styles
Definition Staff.h:586
Represents chromatic transposition details.
Definition Staff.h:123
static const xml::XmlElementArray< ChromaticTransposition > & xmlMappingArray()
Required for musx::factory::FieldPopulator.
int diatonic
The diatonic interval. See music_theory::Transposer for more information.
Definition Staff.h:126
int alteration
The alteration that defines the chromatic interval (in chromatic half-steps). See music_theory::Trans...
Definition Staff.h:125
Represents key signature transposition details.
Definition Staff.h:110
int adjust
The adjustment to the number of sharps or flats in the key signature.
Definition Staff.h:113
static const xml::XmlElementArray< KeySigTransposition > & xmlMappingArray()
Required for musx::factory::FieldPopulator.
int interval
The diatonic transposition interval.
Definition Staff.h:112
Encapsulates transposition options for a staff.
Definition Staff.h:139
std::shared_ptr< ChromaticTransposition > chromatic
Shared pointer to the chromatic transposition details, if any.
Definition Staff.h:150
void integrityCheck(const std::shared_ptr< EnigmaBase > &ptrToThis) override
Performs a final consistency check after population.
Definition Staff.h:155
std::shared_ptr< KeySigTransposition > keysig
Shared pointer to the key signature transposition details, if any.
Definition Staff.h:147
bool noSimplifyKey
Inverse of "Simplify Key" (xml node is <noKeyOpt>)
Definition Staff.h:144
static const xml::XmlElementArray< Transposition > & xmlMappingArray()
Required for musx::factory::FieldPopulator.
bool isSame(const Transposition &other) const
Returns true if the input has the same contents as this.
Definition Staff.cpp:776
bool setToClef
If true, forces the clef in Staff::transposedClef.
Definition Staff.h:143
Represents the definition of a Finale staff.
Definition Staff.h:52
bool altHideOtherLyrics
Hide lyrics in other layers in alternate notation.
Definition Staff.h:212
bool hideDots
Inverse of "Display Augmentation Dots".
Definition Staff.h:239
AutoNumberingStyle
Enum for auto-numbering style. Auto-numbering is based on instUuid.
Definition Staff.h:59
@ ArabicSuffix
Arabic numeral suffix (default). May not appear in xml.
@ ArabicPrefix
Arabic numeral prefix (with dot): 1. 2. 3. ...
@ OrdinalPrefix
Ordinal number prefix: 1st 2nd 3rd, ...
bool noteShapesFromStyle
True if noteShapesId is for a staff style. (Determines which note shapes class to retrieve....
Definition Staff.h:276
Evpu dwRestOffset
Offset for downstem rests.
Definition Staff.h:233
bool hideRepeats
Inverse of "Display Endings and Text Repeats".
Definition Staff.h:224
ClefIndex defaultClef
Index of default clef for the staff.
Definition Staff.h:184
AlternateNotation
Enum for alternate notation styles.
Definition Staff.h:95
@ BlankWithRests
Blank Notation with Rests.
@ SlashBeats
Slash Notation (on beats)
util::EnigmaParsingContext getAbbreviatedInstrumentNameCtx(Cmper forPartId, bool preferStaffName=false) const
Returns the parsing context for the abbreviated name.
Definition Staff.cpp:357
bool hideClefs
Inverse of "Display Clefs".
Definition Staff.h:229
MusxInstanceList< PartDefinition > getContainingParts(bool includeScore=true) const
Gets a list of all parts that contain this staff.
Definition Staff.cpp:685
bool altRhythmStemsUp
Show stems up in alternate Rhythmic Notation mode.
Definition Staff.h:207
Efix horzStemOffDown
Horizontal Stem Offsets: Down Stem.
Definition Staff.h:260
std::pair< std::string, bool > calcAutoNumberingAffix() const
Calculate the auto numbering prefix or suffix, if needed.
Definition Staff.cpp:243
std::vector< LyricsLineInfo > createLyricsLineInfo(SystemCmper systemId) const
Creates a vector of LyricsLineInfo for the current requested part.
Definition Staff.cpp:596
bool hideRepeatTopDot
Inverse of "Top Repeat Dot" in Staff Setup dialog.
Definition Staff.h:219
Evpu hRestOffset
Offset for half rests.
Definition Staff.h:235
std::optional< int > staffLines
Number of lines in the staff (if no custom staff)
Definition Staff.h:186
Efix vertStemStartOffUp
Vertical Stem Offsets For Notehead End: Up Stem.
Definition Staff.h:261
bool hideKeySigs
Inverse of "Display Key Signatures".
Definition Staff.h:227
Cmper multiStaffInstId
Definition Staff.h:285
NotationStyle
Enum for notation style.
Definition Staff.h:72
bool hideStaffLines
Inverse of "Display Staff Lines".
Definition Staff.h:230
bool hideTimeSigs
Inverse of "Display Time Signatures in Score".
Definition Staff.h:228
bool noOptimize
Inverse of "Allow Hiding When Empty".
Definition Staff.h:221
std::optional< std::vector< int > > customStaff
A list of stafflines from 0..26 where a standard 5-line staff is values 11, 12, 13,...
Definition Staff.h:187
Efix vertTabNumOff
Vertical offset for tab number. (Tablature Staff Attributes)
Definition Staff.h:245
int calcNumberOfStafflines() const
Calculates the number of staff lines on this staff.
Definition Staff.cpp:483
bool noKey
"Ignore Key Signatures"
Definition Staff.h:232
static void calcAllRuntimeValues(const DocumentPtr &document)
Populate runtime values for all staves or staffstyles, such as percussion map Id if any.
Definition Staff.cpp:118
std::shared_ptr< FontInfo > noteFont
The custom font to use for noteheads. Guaranteed non-null by integrityCheck if useNoteFont is true.
Definition Staff.h:181
static void calcAllAutoNumberValues(const DocumentPtr &document)
Get the auto-numbering value for this staff, if applicable.
Definition Staff.cpp:37
std::pair< int, int > calcTranspositionInterval() const
Calculates the transposition interval for this staff or staff composite.
Definition Staff.cpp:672
bool hideRepeatBottomDot
Inverse of "Bottom Repeat Dot" in Staff Setup dialog.
Definition Staff.h:215
bool altSlashDots
Show dots on beat slashes in compound meter.
Definition Staff.h:208
int capoPos
"Capo Position" (Tablature Staff Attributes)
Definition Staff.h:190
void integrityCheck(const std::shared_ptr< EnigmaBase > &ptrToThis) override
Performs a final consistency check after population.
Definition Staff.h:471
bool fullNamePosFromStyle
Definition Staff.h:279
bool hasStyles
Indicates that this staff has staff style assignments.
Definition Staff.h:196
Cmper abrvNamePosId
Definition Staff.h:281
Evpu calcBaselinePosition(SystemCmper systemId, Cmper lyricNumber) const
Returns the baseline position for the staff at the given system. The staff should be the staff at the...
Definition Staff.h:424
Efix vertStemEndOffUp
Vertical Stem Offsets For Stem End: Up Stem.
Definition Staff.h:263
int calcTopLinePosition() const
Calculates the position of the top staff line, relative to the reference line.
Definition Staff.cpp:508
bool altHideArtics
Hide Articulations in alternate notation (in Apply-To Layer)
Definition Staff.h:204
MusxInstance< MultiStaffInstrumentGroup > getMultiStaffInstGroup() const
Returns the MultiStaffInstrumentGroup for this staff if it is part of one in the data....
Definition Staff.cpp:295
std::string addAutoNumbering(const std::string &plainName) const
Add auto numbering as a prefix or suffix, if needed.
Definition Staff.cpp:265
StemDirection stemDirection
stem direction for staff (xml node is <stemDir>)
Definition Staff.h:252
bool hideStems
Inverse of "Display Stems".
Definition Staff.h:251
Evpu otherRestOffset
Offset for other rests.
Definition Staff.h:236
std::string getFullInstrumentName(util::EnigmaString::AccidentalStyle accidentalStyle=util::EnigmaString::AccidentalStyle::Ascii, bool preferStaffName=false) const
Returns the full instrument name for this staff without Enigma tags and with autonumbering (if any)
Definition Staff.cpp:349
std::optional< int > autoNumberValue
Calculated autonumbering value. It is computed by calcAllAutoNumberValues.
Definition Staff.h:287
Efix horzStemOffUp
Horizontal Stem Offsets: Up Stem.
Definition Staff.h:259
bool abrvNamePosFromStyle
Definition Staff.h:283
bool iterateEntries(std::function< bool(const EntryInfoPtr &)> iterator) const
Iterate all entries in the document by staff and then measure. This function wraps MusxInstanceList<S...
Definition Staff.cpp:726
Efix vertStemStartOffDown
Vertical Stem Offsets For Notehead End: Down Stem.
Definition Staff.h:262
Evpu lineSpace
Distance between staff lines.
Definition Staff.h:188
Evpu wRestOffset
Offset for whole rests.
Definition Staff.h:234
bool stemStartFromStaff
Definition Staff.h:254
bool calcShowInstrumentName() const
Returns true if the staff shows its full or abbreviated instrument name for the current requested par...
Definition Staff.cpp:384
bool altHideSmartShapes
Hide Smart Shapes (in Apply-To layer: probably only affects entry-attached shapes)
Definition Staff.h:206
AlternateNotation altNotation
Alternate notation on the staff.
Definition Staff.h:202
bool stemsFixedEnd
"Use Vertical Offset For Beam End Of Stems (Offset From Staff)"
Definition Staff.h:257
MusxInstance< details::ShapeNoteBase > getNoteShapes() const
Returns the note shape record in effect for this staff instance.
Definition Staff.cpp:392
HideMode hideMode
"Force Hide Staff" option
Definition Staff.h:265
bool hideTuplets
Inverse of "Show Tuplets" (Tablature Staff Attributes)
Definition Staff.h:249
Staff(const DocumentWeakPtr &document, Cmper partId, ShareMode shareMode, Cmper cmper)
Constructor function.
Definition Staff.h:173
bool hideBarlines
Inverse of "Display Barlines".
Definition Staff.h:225
int lowestFret
"Default Lowest Fret" (Tablature Staff Attributes)
Definition Staff.h:191
bool useNoteShapes
Indicates that note shapes should be used. It is ignored is no staff- or staffstyle-specific note sha...
Definition Staff.h:182
bool hasInstrumentAssigned() const
Return true if this staff has an instrument assigned.
Definition Staff.cpp:664
LayerIndex altLayer
Alternate notation Apply To Layer index (0..3)
Definition Staff.h:203
bool floatKeys
"Independent Key Signature"
Definition Staff.h:192
Cmper fullNameTextId
Full name TextBlock ID. (xml node is <fullName>)
Definition Staff.h:241
NotationStyle notationStyle
Standard, percussion, or tablature.
Definition Staff.h:180
bool useAutoNumbering
Whether names should be auto-numbered. (xml node is <useAutoNum>)
Definition Staff.h:269
bool hideTies
Inverse of "Display Ties".
Definition Staff.h:238
util::EnigmaParsingContext getFullInstrumentNameCtx(Cmper forPartId, bool preferStaffName=false) const
Returns the parsing context for the full name.
Definition Staff.cpp:330
bool showNameInParts
"Display Staff Name in Parts" (xml node is <showNameParts>)
Definition Staff.h:197
ClefIndex transposedClef
Index of transposed clef for the staff. Only used if Transposition::setToClef is true.
Definition Staff.h:185
bool floatTime
"Independent Time Signature"
Definition Staff.h:193
bool altHideOtherSmartShapes
Hide Smart Shapes in other layers in alternate notation.
Definition Staff.h:213
std::optional< Cmper > percussionMapId
Calculated percussion map Id for a percussion staff. (Populated by in calcAllRuntimeValues....
Definition Staff.h:288
int calcMiddleStaffPosition() const
Calculates the middle staff position. For staves with even numbers of lines, it is the middle space.
Definition Staff.cpp:493
Evpu botBarlineOffset
Offset for the bottom barline.
Definition Staff.h:201
Evpu calcBaselinePosition(SystemCmper systemId) const
Returns the baseline position for the staff at the given system. The staff should be the staff at the...
Definition Staff.h:411
bool calcAlternateNotationHidesEntries(LayerIndex forLayerIndex) const
Returns true if the given layer is hidden by alternate notation.
Definition Staff.cpp:720
bool hideLyrics
Inverse of "Display Lyrics".
Definition Staff.h:220
Efix vertStemEndOffDown
Vertical Stem Offsets For Stem End: Down Stem.
Definition Staff.h:264
std::string getFullName(util::EnigmaString::AccidentalStyle accidentalStyle=util::EnigmaString::AccidentalStyle::Ascii) const
Returns the full staff name without Enigma tags. If the full name contains part-specific tags (rare),...
Definition Staff.cpp:277
Cmper abbrvNameTextId
Abbreviated name TextBlock ID. (xml node is <abbrvName>)
Definition Staff.h:242
std::string getAbbreviatedName(util::EnigmaString::AccidentalStyle accidentalStyle=util::EnigmaString::AccidentalStyle::Ascii) const
Returns the abbreviated staff name without Enigma tags. If the abbreviated name contains part-specifi...
Definition Staff.cpp:282
bool hideFretboards
Inverse of "Display Fretboards".
Definition Staff.h:217
bool calcIsSameNotationStyle(const Staff &other) const
Returns true if both instances have the same notation style settings. This is helpful for determining...
Definition Staff.cpp:737
bool rbarBreak
"Break Repeat Barlines Between Staves"
Definition Staff.h:195
bool calcShowName() const
Returns true if the staff shows its full or abbreviated name for the current requested partId.
Definition Staff.cpp:287
Evpu topRepeatDotOff
Offset for top repeat dots.
Definition Staff.h:244
HideMode
Enum for hide mode.
Definition Staff.h:83
@ Score
Collapse in score only.
@ ScoreParts
Collapse in score and parts.
bool showNoteColors
"Color Noteheads" (Score Manager)
Definition Staff.h:198
bool redisplayLayerAccis
"Redisplay Accidentals in Other Layers Within Measures"
Definition Staff.h:266
bool altHideExpressions
Hide Expressions in alternate notation (in Apply-To Layer)
Definition Staff.h:211
bool useNoteFont
Indicates if noteFont should be used.
Definition Staff.h:183
Evpu topBarlineOffset
Offset for the top barline.
Definition Staff.h:222
Cmper fretInstId
Cmper of FretInstrument for TAB strings. (Tablature Staff Attributes)
Definition Staff.h:250
bool hideBeams
Inverse of "Show Beams".
Definition Staff.h:253
bool hideTimeSigsInParts
Inverse of "Display Time Signatures in Parts".
Definition Staff.h:267
MusxInstance< NamePositioning > getFullNamePosition() const
Returns the full name positioning in effect for this staff instance.
Definition Staff.cpp:443
bool hideChords
Inverse of "Display Chords".
Definition Staff.h:231
int calcBottomLinePosition() const
Calculates the position of the top staff line, relative to the reference line.
Definition Staff.cpp:522
Cmper fullNamePosId
Definition Staff.h:277
bool showNamesForPart(Cmper partId) const
Returns if names should be shown for the specified part.
Definition Staff.h:343
bool hideRests
Inverse of "Display Rests".
Definition Staff.h:237
bool breakTabLinesAtNotes
"Break Tablature Lines At Numbers" (Tablature Staff Attributes)
Definition Staff.h:248
int stemReversal
Stem reversal value.
Definition Staff.h:240
bool blankMeasure
Inverse of "Display Rests in Empty Measures".
Definition Staff.h:218
Evpu botRepeatDotOff
Offset for bottom repeat dots.
Definition Staff.h:243
bool altHideOtherArtics
Hide articulations in other layers in alternate notation.
Definition Staff.h:210
bool altHideOtherNotes
Hide notes in other layers in alternate notation.
Definition Staff.h:209
bool blineBreak
"Break Barlines Between Staves"
Definition Staff.h:194
MusxInstance< NamePositioning > getAbbreviatedNamePosition() const
Returns the abbreviated name positioning in effect for this staff instance.
Definition Staff.cpp:451
static const xml::XmlElementArray< Staff > & xmlMappingArray()
Required for musx::factory::FieldPopulator.
MusxInstance< PartDefinition > firstContainingPart() const
Finds the first part that contains this staff, not including the score.
Definition Staff.cpp:704
ClefIndex calcClefIndexAt(MeasCmper measureId, Edu position, bool forWrittenPitch=false) const
Returns the clef in this staff at the specified location.
Definition Staff.cpp:459
MusxInstance< details::StaffGroup > getMultiStaffInstVisualGroup(Cmper forPartId) const
Returns the details::StaffGroup for this staff if it is part of a multistaff instrument (as defined i...
Definition Staff.cpp:306
ClefIndex calcFirstClefIndex(bool forWrittenPitch=false) const
Returns the first clef in this staff.
Definition Staff.h:383
bool useTabLetters
"Use Letters" (Tablature Staff Attributes)
Definition Staff.h:247
bool hideRptBars
Inverse of "Display Repeat Bars".
Definition Staff.h:226
std::shared_ptr< Transposition > transposition
Transposition details, if non-null.
Definition Staff.h:199
bool hideKeySigsShowAccis
"Hide Key Signature and Show Accidentals" transposition option.
Definition Staff.h:270
AutoNumberingStyle autoNumbering
Autonumbering style if useAutoNumbering is true. (xml node is <autoNum>)
Definition Staff.h:268
Cmper noteShapesId
Definition Staff.h:274
bool hideNameInScore
Inverse of "Display Staff Name in Score" (xml node is <hideStfNameInScore>)
Definition Staff.h:200
std::string instUuid
Unique identifier for the type of instrument.
Definition Staff.h:189
bool altHideOtherExpressions
Hide Expressions in other layers in alternate notation.
Definition Staff.h:214
bool stemsFixedStart
"Use Vertical Offset For Notehead End Of Stems"
Definition Staff.h:258
bool hideMeasNums
Inverse of "Display Measure Numbers".
Definition Staff.h:223
std::string getAbbreviatedInstrumentName(util::EnigmaString::AccidentalStyle accidentalStyle=util::EnigmaString::AccidentalStyle::Ascii, bool preferStaffName=false) const
Returns the abbreviated instrument name for this staff without Enigma tags and with autonumbering (if...
Definition Staff.cpp:376
bool flatBeams
"Flat Beams"
Definition Staff.h:216
bool altHideLyrics
Hide Lyrics in alternate notation (in Apply-To Layer)
Definition Staff.h:205
bool showTabClefAllSys
Inverse of "Show Clef Only On First Measure" (Tablature Staff Attributes)
Definition Staff.h:246
Evpu calcBaselineZeroPosition() const
Calculates the baseline zero position for this staff, relative to the reference line,...
Definition Staff.cpp:536
static constexpr std::string_view XmlNodeName
The XML node name for this type.
Definition Staff.h:496
Wrapper class for interpreting and rendering Enigma-style strings with insert handling.
Definition EnigmaString.h:416
AccidentalStyle
Enumeration to specify the type of accidental substitution representation.
Definition EnigmaString.h:192
@ Ascii
Use ASCII substitutions for accidentals.
@ 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
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:40
unsigned int LayerIndex
Layer index (valid values are 0..3)
Definition Fundamentals.h:71
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
uint16_t Cmper
Enigma "comperator" key type.
Definition Fundamentals.h:55
StemDirection
Three-state stem direction setting or override.
Definition EnumClasses.h:174
@ Percussion
Percussion clef, open rectangle (no pitch).
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::weak_ptr< Document > DocumentWeakPtr
Shared weak Document pointer.
Definition DocumentElement.h:37
std::shared_ptr< Document > DocumentPtr
Shared Document pointer.
Definition DocumentElement.h:35
int16_t StaffCmper
Enigma staff (staffId) Cmper (may be negative when not applicable)
Definition Fundamentals.h:65
int16_t SystemCmper
Enigma systems Cmper (may be negative when not applicable)
Definition Fundamentals.h:66
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