MNX Document Model
Loading...
Searching...
No Matches
mnx::part::PartTransposition Class Reference

Describes a part's instrument transposition. More...

#include <Part.h>

+ Inheritance diagram for mnx::part::PartTransposition:

Public Member Functions

 PartTransposition (const std::shared_ptr< json > &root, json_pointer pointer)
 Constructor for existing Clef instances.
 
 PartTransposition (Base &parent, const std::string_view &key, int diatonic, int chromatic)
 Creates a new Clef class as a child of a JSON element.
 
 MNX_REQUIRED_CHILD (Interval, interval)
 the transposition interval
 
 MNX_OPTIONAL_PROPERTY (int, keyFifthsFlipAt)
 the number of sharps (positive) or flats (negative) at which to simplify the key signature
 
 MNX_OPTIONAL_PROPERTY_WITH_DEFAULT (bool, prefersWrittenPitches, false)
 concert-pitch score. (Examples could be piccolo, double base, glockenspiel, etc.)
 
- Public Member Functions inherited from mnx::Object
 Object (const std::shared_ptr< json > &root, json_pointer pointer)
 Wraps an Object class around an existing JSON object node.
 
 Object (Base &parent, const std::string_view &key)
 Creates a new Object class as a child of a JSON node.
 
 MNX_OPTIONAL_PROPERTY (std::string, _c)
 An optional comment. This serves a similar function as XML or HTML comments.
 
 MNX_OPTIONAL_PROPERTY (std::string, id)
 Uniquely identifies the object.
 
- Public Member Functions inherited from mnx::Base
 Base (const Base &src)
 Copy constructor.
 
 Base (Base &&src) noexcept
 Move constructor.
 
Baseoperator= (const Base &src)
 Copy assignment operator.
 
Baseoperator= (Base &&src)
 Move assignment operator.
 
std::string dump (int indents=-1)
 Dumps the branch to a string. Useful in debugging.
 
template<typename T >
parent () const
 Returns the parent object for this node.
 
template<typename T >
std::optional< T > getEnclosingElement () const
 Returns the enclosing array element for this instance.
 
json_pointer pointer () const
 Returns the json_pointer for this node.
 

Additional Inherited Members

- Protected Member Functions inherited from mnx::Base
jsonref () const
 Convert this node for retrieval.
 
jsonref ()
 Access the JSON node for modification.
 
const std::shared_ptr< json > & root () const
 Returns the root.
 
 Base (const std::shared_ptr< json > &root, json_pointer pointer)
 Wrap a Base instance around a specific JSON reference using a json_pointer.
 
 Base (json &&jsonRef, Base &parent, const std::string_view &key)
 Construct a Base reference as a child inside a parent node.
 
template<typename T >
getChild (const std::string_view &key) const
 Retrieves and validates a required child node.
 
template<typename T >
setChild (const std::string_view &key, const T &value)
 Sets a child node.
 
template<typename T >
std::optional< T > getOptionalChild (const std::string_view &key) const
 Retrieves an optional child node.
 

Detailed Description

Describes a part's instrument transposition.

Constructor & Destructor Documentation

◆ PartTransposition()

mnx::part::PartTransposition::PartTransposition ( Base parent,
const std::string_view &  key,
int  diatonic,
int  chromatic 
)
inline

Creates a new Clef class as a child of a JSON element.

Parameters
parentThe parent class instance
keyThe JSON key to use for embedding in parent.
diatonicThe number of diatonic steps in the interval (negative is down)
chromaticThe number of 12-EDO chromatic halfsteps in the interval (negative is down)

Member Function Documentation

◆ MNX_OPTIONAL_PROPERTY_WITH_DEFAULT()

mnx::part::PartTransposition::MNX_OPTIONAL_PROPERTY_WITH_DEFAULT ( bool  ,
prefersWrittenPitches  ,
false   
)

concert-pitch score. (Examples could be piccolo, double base, glockenspiel, etc.)

if true, this instrument prefers displaying written pitches even in the context of