Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Interpret empty
<forward>
tags as rests on Finale documents only #1636base: master
Are you sure you want to change the base?
Interpret empty
<forward>
tags as rests on Finale documents only #1636Changes from all commits
de901e6
b217557
88871e6
273e9b1
25afc26
ab546f9
5bed7fc
26a83ac
652b393
cdf3359
ee708a2
2ecae3f
7a1cc89
0a5a259
File filter
Filter by extension
Conversations
Jump to
There are no files selected for viewing
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Why move this out of the MeasureParser? If it's just to have access to the
md
instance, we could just query for it in the measure parser (with getContextByClass, which is fast). To do that, we likely need to avoidcoreInsert
'ing it when inserting for the reason mentioned earlier.There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I had a look - I moved it there since it didn't play nice with partwise musicxml files. I think this is because the rests inserted by
makeRests
don't have an entry instaffReference
, and therefore can't be placed in the correct part until after the parts have been pulled apart.One example is schoenberg op19.2. -
testHiddenRests
fails when keeping this inside the measure parser because a hole in voice 2 is filled with a half rest. this voice is supposed to be in the top staff, but the rest ends up in the bottom staff, where we end up with two voices instead of no voices (one with the newly inserted rest, and one with the actual data for the bottom staff).There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I wasn't able to quickly resolve this in another way - lmk if you have any thoughts.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I think this test wasn't failing before because we got lucky and this particular case happened in the last measure of the piece, where the incorrect rest was removed by
removeEndForwardRest
.There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Thanks for the ping. I wanted to see what you were talking about, so here's what I stubbed out:
Now I get:
But when I look at this piece on IMSLP, that seems correct. No rests at the end of the file. So my next thought was to look at how the file is encoded in the version in the music21 corpus.EDIT: outdated, probably was not running test correctlyI have to run, but my intent is to get you an answer in the next few days, unless you already know the answer and can enlighten me :-)Thanks for your persistence.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Do you mean MusicXML files where some parts have more than one staff? Almost all MusicXML files are Partwise, and I don't think music21 even imports Timewise since I've never seen one in the wild.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Yeah I meant multi-staff parts, sorry. Basically anything with a
<staff>
tag that forces m21 to later useseparateOutPartStaves
to move something to a different staff.There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
@jacobtylerwalls i'm not 100% how
addToStaffReference
is supposed to work, but I'm pretty sure measure elements don't have a<staff>
element assigned to them, only notes or rests do. Therefore the added rests will probably always be added to the "NO_STAFF_ASSIGNED" bucket. I think the right way to do this would be to find either the following or preceding note in the same voice and put the added rests in the same staff as that note.Maybe
separateOutPartStaves
is smart enough to do that already?There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Forget that, I must have not used
forceSource=True
or something -- I get a much more understandable failure now.@TimFelixBeyer to your question, you're absolutely right that we need the staff reference. The bulletproof way to do that would be to get it from the
<forward>
tag and rely on that for hidden rest creation, which is what we were doing before. Instead of adding this makeRests() call under a Finale guard, what do you think about putting the oldxmlForward
tag code that created hidden rests and assigned staff references under a Finale guard? You should get the same overall amount of net simplicity, no?There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Note to self: if we decide to leave this here after all, this is probably not needed (but still think MeasureParser is better if I'm not missing something)
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
It's been a while since I've thought through this PR, but I think that this is correct.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I think we can remove this instance attribute now.