MUSX Document Model
|
Represents the attributes of a TGF entry frame. More...
#include <Others.h>
Public Member Functions | |
Frame (const DocumentWeakPtr &document, Cmper partId, ShareMode shareMode, Cmper cmper, Inci inci=0) | |
Constructor function. | |
void | iterateRawEntries (std::function< bool(const std::shared_ptr< Entry > &entry)> iterator) const |
Iterates all the raw entries in a frame, passing them to the iterator function. If the iterator function returns false, iteration stops. | |
std::vector< std::shared_ptr< const Entry > > | getEntries () const |
Returns a vector of entries contained in the frame. | |
void | integrityCheck () override |
Allows a class to determine if it has been properly contructed by the factory and fix issues that it can, such as creating default instances of contained classes. | |
![]() | |
Cmper | getCmper () const |
Gets the cmper key value. | |
std::optional< Inci > | getInci () const |
Gets the optional array index (inci ). | |
![]() | |
virtual | ~Base () noexcept(false)=default |
Virtual destructor for polymorphic behavior. | |
DocumentPtr | getDocument () const |
Gets a reference to the Document. | |
virtual Cmper | getPartId () const |
Gets the partId for this instance (or SCORE_PARTID for score) | |
ShareMode | getShareMode () const |
Gets the sharing mode for this instance. | |
const SharedNodes & | getUnlinkedNodes () const |
Gets the unlinked nodes for this instance. (Only populated for ShareMode::Partial ) | |
void | addUnlinkedNode (const std::string &nodeName) |
Adds a shared node for this instance. | |
virtual bool | requireAllFields () const |
Specifies if the parser should alert (print or throw) when an unknown xml tag is found for this class. | |
Static Public Member Functions | |
static const xml::XmlElementArray< Frame > & | xmlMappingArray () |
Required for musx::factory::FieldPopulator. | |
Public Attributes | |
EntryNumber | startEntry {} |
Start entry number for this frame. (Appears to be zero when startTime is supplied.) | |
EntryNumber | endEntry {} |
End entry number for this frame. (Appears to be zero when startTime is supplied.) | |
Edu | startTime {} |
The starting position within the measure. (Appears to be zero when startEntry and endEntry are supplied.) | |
Static Public Attributes | |
static constexpr std::string_view | XmlNodeName = "frameSpec" |
The XML node name for this type. | |
Additional Inherited Members | |
![]() | |
enum class | ShareMode { All , Partial , None } |
Describes how this instance is shared between part and score. More... | |
using | SharedNodes = std::set< std::string > |
The container type for shared nodes. | |
![]() | |
OthersBase (const DocumentWeakPtr &document, Cmper partId, ShareMode shareMode, Cmper cmper, std::optional< Inci > inci=std::nullopt) | |
Constructs an OthersBase object. | |
![]() | |
Base (const DocumentWeakPtr &document, Cmper partId, ShareMode shareMode) | |
Constructs the base class. | |
Base (const Base &)=default | |
explicit default copy constructor | |
Base (Base &&) noexcept=default | |
explicit default move constructor | |
Base & | operator= (const Base &) |
no-op copy assignment operator allows subclasses to copy their values. | |
Base & | operator= (Base &&) noexcept |
no-op move assignment operator allows subclasses to move their values. | |
Represents the attributes of a TGF entry frame.
The inci is almost always zero. It appears there can be multiple incis when there is an old-style pickup. In this case, the observed order of Frame incis is
inci 0
: startTimeinci 1
: startEntry & endEntryThe class is identified by the XML node name "frameSpec".
std::vector< std::shared_ptr< const Entry > > musx::dom::others::Frame::getEntries | ( | ) | const |
Returns a vector of entries contained in the frame.
These are raw entries. Use details::GFrameHoldContext::createEntryFrame for a vector of entries with computed values.
|
inlineoverridevirtual |
Allows a class to determine if it has been properly contructed by the factory and fix issues that it can, such as creating default instances of contained classes.
The default implementation should always be called inside an overridden implementation.
musx::dom::integrity_error | if there is a problem. |
Reimplemented from musx::dom::Base.
void musx::dom::others::Frame::iterateRawEntries | ( | std::function< bool(const std::shared_ptr< Entry > &entry)> | iterator | ) | const |
Iterates all the raw entries in a frame, passing them to the iterator function. If the iterator function returns false, iteration stops.
iterator | function. |