MNX Document Model
Loading...
Searching...
No Matches
Sequence.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 "BaseTypes.h"
25#include "CommonClasses.h"
26#include "Enumerations.h"
27#include "EventMarkings.h"
28
29namespace mnx {
30
31class Sequence; // forward declaration
32
37namespace sequence {
38
44{
45public:
47 AccidentalEnclosure(const std::shared_ptr<json>& root, json_pointer pointer)
49 {
50 }
51
56 AccidentalEnclosure(Base& parent, const std::string_view& key, AccidentalEnclosureSymbol inSymbol)
57 : Object(parent, key)
58 {
59 set_symbol(inSymbol);
60 }
61
63};
64
70{
71public:
73 AccidentalDisplay(const std::shared_ptr<json>& root, json_pointer pointer)
75 {
76 }
77
82 AccidentalDisplay(Base& parent, const std::string_view& key, bool showAcci)
83 : Object(parent, key)
84 {
85 set_show(showAcci);
86 }
87
91};
92
98{
99public:
100 using ArrayElementObject::ArrayElementObject;
101
102 MNX_OPTIONAL_PROPERTY(int, staffPosition);
103};
104
109class Pitch : public Object
110{
111public:
113 Pitch(const std::shared_ptr<json>& root, json_pointer pointer)
115 {
116 }
117
124 Pitch(Base& parent, const std::string_view& key, NoteStep inpStep, int inpOctave, std::optional<int> inpAlter = std::nullopt)
125 : Object(parent, key)
126 {
127 set_step(inpStep);
128 set_octave(inpOctave);
129 if (inpAlter) {
130 set_alter(inpAlter.value());
131 }
132 }
133
137
141 bool isSamePitch(const Pitch& src) const;
142};
143
149{
150public:
152 Slur(const std::shared_ptr<json>& root, json_pointer pointer)
154 {
155 }
156
161 Slur(Base& parent, const std::string_view& key, const std::string& target)
163 {
164 set_target(target);
165 }
166
167 MNX_OPTIONAL_PROPERTY(std::string, endNote);
171 MNX_OPTIONAL_PROPERTY(std::string, startNote);
172 MNX_REQUIRED_PROPERTY(std::string, target);
173};
174
180{
181public:
183 Tie(const std::shared_ptr<json>& root, json_pointer pointer)
185 {
186 }
187
192 Tie(Base& parent, const std::string_view& key, const std::optional<std::string>& target = std::nullopt)
194 {
195 if (target) {
196 set_target(target.value());
197 } else {
198 set_lv(true);
199 }
200 }
201
204 MNX_OPTIONAL_PROPERTY(std::string, target);
205};
206
212{
213public:
215 Note(const std::shared_ptr<json>& root, json_pointer pointer)
217 {
218 }
219
226 Note(Base& parent, const std::string_view& key, NoteStep step, int octave, std::optional<int> alter = std::nullopt)
228 {
229 create_pitch(step, octave, alter);
230 }
231
233 MNX_OPTIONAL_NAMED_PROPERTY(std::string, styleClass, "class");
234 MNX_OPTIONAL_PROPERTY(std::string, id);
237 MNX_OPTIONAL_PROPERTY(std::string, smuflFont);
240};
241
247{
248public:
250 EventLyricLine(const std::shared_ptr<json>& root, json_pointer pointer)
252 {
253 }
254
259 EventLyricLine(Base& parent, const std::string_view& key, const std::string& syllableText)
261 {
262 set_text(syllableText);
263 }
264
265 MNX_REQUIRED_PROPERTY(std::string, text);
267};
268
273class EventLyrics : public Object
274{
275public:
276 using Object::Object;
277
279};
280
285class Event : public ContentObject
286{
287public:
289 Event(const std::shared_ptr<json>& root, json_pointer pointer)
291 {
292 }
293
298 Event(Base& parent, const std::string_view& key, std::optional<NoteValue::Initializer> noteValue = std::nullopt)
299 : ContentObject(parent, key)
300 {
301 // per the specification, either noteValue or the full-measure boolean *must* be supplied.
302 if (noteValue) {
303 create_duration(noteValue.value());
304 } else {
305 set_measure(true);
306 }
307 }
308
310 MNX_OPTIONAL_PROPERTY(std::string, id);
320
324 std::optional<Note> findNote(const std::string& noteId) const;
325
327 bool isGrace() const;
328
331 Sequence getSequence() const;
332
333 static constexpr std::string_view ContentTypeValue = ContentObject::ContentTypeValueDefault;
334};
335
340class Space : public ContentObject
341{
342public:
344 Space(const std::shared_ptr<json>& root, json_pointer pointer)
346 {
347 }
348
353 Space(Base& parent, const std::string_view& key, const Fraction::Initializer& duration)
354 : ContentObject(parent, key)
355 {
356 create_duration(duration);
357 }
358
360
361 static constexpr std::string_view ContentTypeValue = "space";
362};
363
368class Grace : public ContentObject
369{
370public:
372 Grace(const std::shared_ptr<json>& root, json_pointer pointer)
374 {
375 }
376
380 Grace(Base& parent, const std::string_view& key)
381 : ContentObject(parent, key)
382 {
383 create_content();
384 }
385
386 MNX_OPTIONAL_NAMED_PROPERTY(std::string, styleClass, "class");
387 MNX_OPTIONAL_PROPERTY(std::string, color);
391
392 static constexpr std::string_view ContentTypeValue = "grace";
393};
394
399class Tuplet : public ContentObject
400{
401public:
403 Tuplet(const std::shared_ptr<json>& root, json_pointer pointer)
405 {
406 }
407
415 Tuplet(Base& parent, const std::string_view& key,
416 unsigned innerCount, const NoteValue::Initializer& innerNoteValue,
417 unsigned outerCount, const NoteValue::Initializer& outerNoteValue)
418 : ContentObject(parent, key)
419 {
420 create_inner(innerCount, innerNoteValue);
421 create_outer(outerCount, outerNoteValue);
422 create_content();
423 }
424
430 MNX_OPTIONAL_PROPERTY_WITH_DEFAULT(TupletDisplaySetting, showNumber, TupletDisplaySetting::Inner);
431 MNX_OPTIONAL_PROPERTY_WITH_DEFAULT(TupletDisplaySetting, showValue, TupletDisplaySetting::NoNumber);
433
434 static constexpr std::string_view ContentTypeValue = "tuplet";
435};
436
437} // namespace sequence
438
444{
445public:
447 Sequence(const std::shared_ptr<json>& root, json_pointer pointer)
449 {
450 }
451
455 Sequence(Base& parent, const std::string_view& key)
457 {
458 create_content();
459 }
460
464 MNX_OPTIONAL_PROPERTY(std::string, voice);
465};
466
467} // namespace mnx
Represents an MNX object that is included as an array element.
Definition BaseTypes.h:615
Represents an MNX array, encapsulating property access.
Definition BaseTypes.h:483
Base class wrapper for all MNX JSON nodes.
Definition BaseTypes.h:210
json_pointer pointer() const
Returns the json_pointer for this node.
Definition BaseTypes.h:271
T parent() const
Returns the parent object for this node.
Definition BaseTypes.h:258
const std::shared_ptr< json > & root() const
Returns the root.
Definition BaseTypes.h:288
Class for content arrays.
Definition BaseTypes.h:700
Base class for objects that are elements of content arrays.
Definition BaseTypes.h:640
static constexpr std::string_view ContentTypeValueDefault
default type value that identifies the type within the content array
Definition BaseTypes.h:642
Represents an MNX dictionary, where each key is a user-defined string.
Definition BaseTypes.h:769
Represents a fraction of a whole note, for measuring musical time.
Definition CommonClasses.h:34
std::pair< NumType, NumType > Initializer
initializer for Fraction class (numerator, denominator)
Definition CommonClasses.h:43
Represents a quantity of symbolic note values=.
Definition CommonClasses.h:232
Definition CommonClasses.h:193
Represents a symbolic note value (not necessarily a duration)
Definition CommonClasses.h:190
Represents an MNX object, encapsulating property access.
Definition BaseTypes.h:420
Object(const std::shared_ptr< json > &root, json_pointer pointer)
Wraps an Object class around an existing JSON object node.
Definition BaseTypes.h:425
A sequence of events and other items in this measure for a voice in a part.
Definition Sequence.h:444
Sequence(Base &parent, const std::string_view &key)
Creates a new Sequence class as a child of a JSON element.
Definition Sequence.h:455
MNX_OPTIONAL_PROPERTY(std::string, voice)
the unique (per measure) voice label for this sequence.
MNX_REQUIRED_CHILD(ContentArray, content)
MNX_OPTIONAL_PROPERTY(int, staff)
the staff number for this sequence
Sequence(const std::shared_ptr< json > &root, json_pointer pointer)
Constructor for existing Sequence objects.
Definition Sequence.h:447
Represents an explicit directive to show or hide an accidental.
Definition Sequence.h:70
AccidentalDisplay(Base &parent, const std::string_view &key, bool showAcci)
Creates a new Pitch class as a child of a JSON element.
Definition Sequence.h:82
MNX_OPTIONAL_PROPERTY_WITH_DEFAULT(bool, force, false)
Whether this accidental was set intentionally (e.g., a courtesy accidental).
MNX_OPTIONAL_CHILD(AccidentalEnclosure, enclosure)
The enclosure type (brackets or parentheses). Omit if none.
MNX_REQUIRED_PROPERTY(bool, show)
Whether to show or hide the accidental.
AccidentalDisplay(const std::shared_ptr< json > &root, json_pointer pointer)
Constructor for existing AccidentalEnclosure objects.
Definition Sequence.h:73
Represents the enclosure on an accidental.
Definition Sequence.h:44
AccidentalEnclosure(Base &parent, const std::string_view &key, AccidentalEnclosureSymbol inSymbol)
Creates a new Pitch class as a child of a JSON element.
Definition Sequence.h:56
AccidentalEnclosure(const std::shared_ptr< json > &root, json_pointer pointer)
Constructor for existing AccidentalEnclosure objects.
Definition Sequence.h:47
MNX_REQUIRED_PROPERTY(AccidentalEnclosureSymbol, symbol)
The symbol to use for the enclosure.
Contains information about a lyric syllable from one lyric line on a note.
Definition Sequence.h:247
MNX_REQUIRED_PROPERTY(std::string, text)
the syllable text
EventLyricLine(const std::shared_ptr< json > &root, json_pointer pointer)
Constructor for existing EventLyricLine objects.
Definition Sequence.h:250
EventLyricLine(Base &parent, const std::string_view &key, const std::string &syllableText)
Creates a new EventLyricLine class as a child of a JSON element.
Definition Sequence.h:259
MNX_OPTIONAL_PROPERTY(LyricLineType, type)
the type of syllable (in relation to the complete word)
Contains information about the lyric syllables on the event.
Definition Sequence.h:274
MNX_OPTIONAL_CHILD(Dictionary< EventLyricLine >, lines)
the syllables per lyric line
Container for any markings on an event.
Definition EventMarkings.h:177
Represents a musical event within a sequence.
Definition Sequence.h:286
Event(const std::shared_ptr< json > &root, json_pointer pointer)
Constructor for existing Event objects.
Definition Sequence.h:289
MNX_OPTIONAL_PROPERTY(StemDirection, stemDirection)
Forced stem direction.
std::optional< Note > findNote(const std::string &noteId) const
Finds a note in the event by its ID.
Definition Implementations.cpp:182
MNX_OPTIONAL_CHILD(Rest, rest)
indicates this event is a rest.
MNX_OPTIONAL_CHILD(Array< Slur >, slurs)
The slurs that start on this event.
bool isGrace() const
Returns true if this event is part of a grace note sequence.
Definition Implementations.cpp:194
Sequence getSequence() const
Returns the Sequence instance for this event.
Definition Implementations.cpp:204
static constexpr std::string_view ContentTypeValue
type value that identifies the type within the content array
Definition Sequence.h:333
MNX_OPTIONAL_CHILD(NoteValue, duration)
Symbolic duration of the event.
MNX_OPTIONAL_CHILD(EventMarkings, markings)
Articulation markings on this event.
Event(Base &parent, const std::string_view &key, std::optional< NoteValue::Initializer > noteValue=std::nullopt)
Creates a new Event class as a child of a JSON element.
Definition Sequence.h:298
MNX_OPTIONAL_CHILD(EventLyrics, lyrics)
The lyric syllables on this event.
MNX_OPTIONAL_PROPERTY(int, staff)
Staff number override (e.g., for cross-staff events.)
MNX_OPTIONAL_CHILD(Array< Note >, notes)
MNX_OPTIONAL_PROPERTY(std::string, id)
Identifying string for the event.
MNX_OPTIONAL_PROPERTY_WITH_DEFAULT(bool, measure, false)
Whether this event is a whole-measure event.
Represents a grace note sequence within a sequence.
Definition Sequence.h:369
MNX_OPTIONAL_NAMED_PROPERTY(std::string, styleClass, "class")
style class
MNX_REQUIRED_CHILD(ContentArray, content)
static constexpr std::string_view ContentTypeValue
type value that identifies the type within the content array
Definition Sequence.h:392
MNX_OPTIONAL_PROPERTY_WITH_DEFAULT(bool, slash, true)
whether to show a slash on the grace note
Grace(Base &parent, const std::string_view &key)
Creates a new Grace class as a child of a JSON element.
Definition Sequence.h:380
Grace(const std::shared_ptr< json > &root, json_pointer pointer)
Constructor for existing Grace objects.
Definition Sequence.h:372
MNX_OPTIONAL_PROPERTY(std::string, color)
color to use when rendering the grace note sequence
Represents a single note (i.e., within a chord) within a musical event within a sequence.
Definition Sequence.h:212
MNX_OPTIONAL_CHILD(Array< Tie >, ties)
The (forward) ties, if any.
MNX_OPTIONAL_PROPERTY(std::string, smuflFont)
The SMuFL-complaint font to use for rendering the note.
MNX_OPTIONAL_PROPERTY(int, staff)
Staff number override (e.g., for cross-staff notes.)
MNX_OPTIONAL_CHILD(AccidentalDisplay, accidentalDisplay)
the forced show/hide state of the accidental
Note(Base &parent, const std::string_view &key, NoteStep step, int octave, std::optional< int > alter=std::nullopt)
Creates a new Note class as a child of a JSON element.
Definition Sequence.h:226
MNX_REQUIRED_CHILD(Pitch, pitch)
the pitch of the note
Note(const std::shared_ptr< json > &root, json_pointer pointer)
Constructor for existing Note objects.
Definition Sequence.h:215
MNX_OPTIONAL_PROPERTY(std::string, id)
MNX_OPTIONAL_NAMED_PROPERTY(std::string, styleClass, "class")
style class
Represents the pitch of a note.
Definition Sequence.h:110
Pitch(Base &parent, const std::string_view &key, NoteStep inpStep, int inpOctave, std::optional< int > inpAlter=std::nullopt)
Creates a new Pitch class as a child of a JSON element.
Definition Sequence.h:124
Pitch(const std::shared_ptr< json > &root, json_pointer pointer)
Constructor for existing Pitch objects.
Definition Sequence.h:113
MNX_OPTIONAL_PROPERTY(int, alter)
chromatic alteration
MNX_REQUIRED_PROPERTY(int, octave)
the octave number
bool isSamePitch(const Pitch &src) const
Checks if the input pitch is the same as this pitch, including enharmonic equivalents.
Definition Implementations.cpp:217
MNX_REQUIRED_PROPERTY(NoteStep, step)
the note step, (i.e., "A".."G")
Represents a rest within a musical event within a sequence.
Definition Sequence.h:98
MNX_OPTIONAL_PROPERTY(int, staffPosition)
The staff position of non-floating rests.
Contains information about a tie on a note.
Definition Sequence.h:149
MNX_OPTIONAL_PROPERTY(SlurTieSide, side)
used to force slur direction (if present)
MNX_OPTIONAL_PROPERTY(SlurTieSide, sideEnd)
used to force slur's endpoint direction (if different than side)
Slur(const std::shared_ptr< json > &root, json_pointer pointer)
Constructor for existing Slur objects.
Definition Sequence.h:152
MNX_OPTIONAL_PROPERTY(std::string, startNote)
the specific note ID this slur starts on
MNX_OPTIONAL_PROPERTY(std::string, endNote)
the specific note ID this slur ends on
Slur(Base &parent, const std::string_view &key, const std::string &target)
Creates a new Slur class as a child of a JSON element.
Definition Sequence.h:161
MNX_OPTIONAL_PROPERTY(LineType, lineType)
the type of line for the slur
MNX_REQUIRED_PROPERTY(std::string, target)
the event ID this slur ends on (if present)
Occupies metric space without showing anything.
Definition Sequence.h:341
MNX_REQUIRED_CHILD(Fraction, duration)
Duration of space to occupy.
static constexpr std::string_view ContentTypeValue
type value that identifies the type within the content array
Definition Sequence.h:361
Space(Base &parent, const std::string_view &key, const Fraction::Initializer &duration)
Creates a new Space class as a child of a JSON element.
Definition Sequence.h:353
Space(const std::shared_ptr< json > &root, json_pointer pointer)
Constructor for existing Space objects.
Definition Sequence.h:344
Contains information about a tie on a note.
Definition Sequence.h:180
Tie(Base &parent, const std::string_view &key, const std::optional< std::string > &target=std::nullopt)
Creates a new Tie class as a child of a JSON element.
Definition Sequence.h:192
MNX_OPTIONAL_PROPERTY(std::string, target)
the note id of the tied-to note
MNX_OPTIONAL_PROPERTY(SlurTieSide, side)
used to force tie direction (if present)
Tie(const std::shared_ptr< json > &root, json_pointer pointer)
Constructor for existing Tie objects.
Definition Sequence.h:183
MNX_OPTIONAL_PROPERTY_WITH_DEFAULT(bool, lv, false)
Indicates the presence of an l.v. tie (instead of target)
Represents a tuplet sequence within a sequence.
Definition Sequence.h:400
MNX_OPTIONAL_PROPERTY_WITH_DEFAULT(TupletDisplaySetting, showValue, TupletDisplaySetting::NoNumber)
How and whether to show the tuplet note value(s)
MNX_REQUIRED_CHILD(NoteValueQuantity, inner)
Inner quantity: 3 quarters in the time of 2 quarters.
Tuplet(const std::shared_ptr< json > &root, json_pointer pointer)
Constructor for existing Tuplet objects.
Definition Sequence.h:403
Tuplet(Base &parent, const std::string_view &key, unsigned innerCount, const NoteValue::Initializer &innerNoteValue, unsigned outerCount, const NoteValue::Initializer &outerNoteValue)
Creates a new Tuplet class as a child of a JSON element.
Definition Sequence.h:415
static constexpr std::string_view ContentTypeValue
type value that identifies the type within the content array
Definition Sequence.h:434
MNX_OPTIONAL_PROPERTY_WITH_DEFAULT(AutoYesNo, bracket, AutoYesNo::Auto)
bracket style
MNX_OPTIONAL_PROPERTY_WITH_DEFAULT(TupletDisplaySetting, showNumber, TupletDisplaySetting::Inner)
How and whether to show the tuplet number(s)
MNX_OPTIONAL_PROPERTY(int, staff)
Staff number override (e.g., for cross-staff notes.)
MNX_REQUIRED_CHILD(NoteValueQuantity, outer)
MNX_REQUIRED_CHILD(ContentArray, content)
array of events (and tuplets, at least for now)
object model for MNX format
LineType
Specifies the visual style of a line in (specifically) slurs.
Definition Enumerations.h:136
json::json_pointer json_pointer
JSON pointer class for MNX.
Definition BaseTypes.h:197
LyricLineType
The symbols available to bracket a staff group.
Definition Enumerations.h:148
AccidentalEnclosureSymbol
The types of accidental enclosure symbols.
Definition Enumerations.h:31
AutoYesNo
3-state choice enum
Definition Enumerations.h:41
NoteStep
The diatonic note step values.
Definition Enumerations.h:172
SlurTieSide
Specifies the direction of a slur or tie.
Definition Enumerations.h:256
TupletDisplaySetting
Controls display of a tuplet's number or note value.
Definition Enumerations.h:292
StemDirection
The values available in a labelref.
Definition Enumerations.h:266