Skip to content

Commit

Permalink
Use bracketSpanLog_FUNC type for bracketSpan@func
Browse files Browse the repository at this point in the history
* Drop two string values in MusicXML importer

(cherry picked from commit fe2d5b1)
  • Loading branch information
lpugin committed Oct 31, 2024
1 parent c811450 commit 90819f6
Show file tree
Hide file tree
Showing 5 changed files with 16 additions and 11 deletions.
5 changes: 5 additions & 0 deletions libmei/datatypes.yml
Original file line number Diff line number Diff line change
Expand Up @@ -187,6 +187,11 @@ defaults:
data_STAFFREL()

modules:
cmn:
att.bracketSpan.log:
func:
type: bracketSpanLog_FUNC

externalsymbols:
att.extsym:
glyphnum:
Expand Down
4 changes: 2 additions & 2 deletions libmei/dist/attmodule.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -304,7 +304,7 @@ bool AttModule::SetCmn(Object *element, const std::string &attrType, const std::
AttBracketSpanLog *att = dynamic_cast<AttBracketSpanLog *>(element);
assert(att);
if (attrType == "func") {
att->SetFunc(att->StrToStr(attrValue));
att->SetFunc(att->StrToBracketSpanLogFunc(attrValue));
return true;
}
}
Expand Down Expand Up @@ -599,7 +599,7 @@ void AttModule::GetCmn(const Object *element, ArrayOfStrAttr *attributes)
const AttBracketSpanLog *att = dynamic_cast<const AttBracketSpanLog *>(element);
assert(att);
if (att->HasFunc()) {
attributes->push_back({ "func", att->StrToStr(att->GetFunc()) });
attributes->push_back({ "func", att->BracketSpanLogFuncToStr(att->GetFunc()) });
}
}
if (element->HasAttClass(ATT_CUTOUT)) {
Expand Down
8 changes: 4 additions & 4 deletions libmei/dist/atts_cmn.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -373,14 +373,14 @@ AttBracketSpanLog::AttBracketSpanLog() : Att()

void AttBracketSpanLog::ResetBracketSpanLog()
{
m_func = "";
m_func = bracketSpanLog_FUNC_NONE;
}

bool AttBracketSpanLog::ReadBracketSpanLog(pugi::xml_node element, bool removeAttr)
{
bool hasAttribute = false;
if (element.attribute("func")) {
this->SetFunc(StrToStr(element.attribute("func").value()));
this->SetFunc(StrToBracketSpanLogFunc(element.attribute("func").value()));
if (removeAttr) element.remove_attribute("func");
hasAttribute = true;
}
Expand All @@ -391,15 +391,15 @@ bool AttBracketSpanLog::WriteBracketSpanLog(pugi::xml_node element)
{
bool wroteAttribute = false;
if (this->HasFunc()) {
element.append_attribute("func") = StrToStr(this->GetFunc()).c_str();
element.append_attribute("func") = BracketSpanLogFuncToStr(this->GetFunc()).c_str();
wroteAttribute = true;
}
return wroteAttribute;
}

bool AttBracketSpanLog::HasFunc() const
{
return (m_func != "");
return (m_func != bracketSpanLog_FUNC_NONE);
}

//----------------------------------------------------------------------------
Expand Down
6 changes: 3 additions & 3 deletions libmei/dist/atts_cmn.h
Original file line number Diff line number Diff line change
Expand Up @@ -435,14 +435,14 @@ class AttBracketSpanLog : public Att {
* to the default value)
**/
///@{
void SetFunc(std::string func_) { m_func = func_; }
std::string GetFunc() const { return m_func; }
void SetFunc(bracketSpanLog_FUNC func_) { m_func = func_; }
bracketSpanLog_FUNC GetFunc() const { return m_func; }
bool HasFunc() const;
///@}

private:
/** Describes the function of the bracketed event sequence. **/
std::string m_func;
bracketSpanLog_FUNC m_func;
};

//----------------------------------------------------------------------------
Expand Down
4 changes: 2 additions & 2 deletions src/iomusxml.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -2009,7 +2009,7 @@ void MusicXmlInput::ReadMusicXmlDirection(
bracketSpan->SetLform(
bracketSpan->AttLineRendBase::StrToLineform(bracket.attribute("line-type").as_string()));
// bracketSpan->SetPlace(bracketSpan->AttPlacementRelStaff::StrToStaffrel(placeStr.c_str()));
bracketSpan->SetFunc("unclear");
// bracketSpan->SetFunc("unclear");
bracketSpan->SetLstartsym(ConvertLineEndSymbol(bracket.attribute("line-end").as_string()));
bracketSpan->SetTstamp(timeStamp);
m_controlElements.push_back({ measureNum, bracketSpan });
Expand Down Expand Up @@ -2434,7 +2434,7 @@ void MusicXmlInput::ReadMusicXmlDirection(
musicxml::OpenSpanner openBracket(voiceNumber, m_measureCounts.at(measure));
bracketSpan->SetColor(lead.attribute("color").as_string());
// bracketSpan->SetPlace(bracketSpan->AttPlacementRelStaff::StrToStaffrel(placeStr.c_str()));
bracketSpan->SetFunc("analytical");
// bracketSpan->SetFunc("analytical");
bracketSpan->SetLstartsym(ConvertLineEndSymbol(lead.attribute("symbol").as_string()));
bracketSpan->SetTstamp(timeStamp);
bracketSpan->SetType("principal-voice");
Expand Down

0 comments on commit 90819f6

Please sign in to comment.