Skip to content

Commit

Permalink
Add inferencing for incorrect part names
Browse files Browse the repository at this point in the history
Sibelius seems to export part names as "P#" rather than specifying
print-object="no". This commit adds handling of this case, omitting
part names of the (regex) form "$P[0-9]+^".

Duplicate of musescore#8326, part 2
  • Loading branch information
iveshenry18 authored and Jojo-Schmitz committed Jun 28, 2021
1 parent cea1bd8 commit cf748c6
Show file tree
Hide file tree
Showing 4 changed files with 862 additions and 89 deletions.
15 changes: 14 additions & 1 deletion importexport/musicxml/importmxmlpass2.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -1439,6 +1439,19 @@ SpannerSet MusicXMLParserPass2::findIncompleteSpannersAtPartEnd()
return res;
}


//---------------------------------------------------------
// isLikelyIncorrectPartName
//---------------------------------------------------------
/**
Sibelius exports part names of the form "P#" rather than
specifying print-object="no". This finds those.
*/

static bool isLikelyIncorrectPartName(const QString& partName) {
return partName.contains(QRegularExpression("^P[0-9]+$"));
}

//---------------------------------------------------------
// multi-measure rest state handling
//---------------------------------------------------------
Expand Down Expand Up @@ -1656,7 +1669,7 @@ void MusicXMLParserPass2::part()
// set the part name
auto mxmlPart = _pass1.getMusicXmlPart(id);
_pass1.getPart(id)->setPartName(mxmlPart.getName());
if (mxmlPart.getPrintName())
if (mxmlPart.getPrintName() && !isLikelyIncorrectPartName(mxmlPart.getName()))
_pass1.getPart(id)->setLongName(mxmlPart.getName());
else
_pass1.getPart(id)->setLongName("");
Expand Down
Binary file modified mtest/musicxml/io/testPartNames.pdf
Binary file not shown.
Loading

0 comments on commit cf748c6

Please sign in to comment.