Skip to content
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

update beatloop size for loops set manually with IN/OUT #12522

Draft
wants to merge 8 commits into
base: main
Choose a base branch
from

Conversation

ronso0
Copy link
Member

@ronso0 ronso0 commented Jan 6, 2024

This updates the beatloop_size for loops set manually with IN/OUT, which also enables loop_halve/_double.
This is on top of #12509, so check only the last two commits.

That was discussed in #1187 and rejected for some reasons (or rather concerns and assumptions IMO).
I disabled the respective tests.

Fixing #10511 in #12509 made the previous inconsistency obvious (#12509 (comment)).

The second commit tries to address the concerns raised in #1187:
When a track with an unusual loop size is ejected, that loop size is kept (now not only for saved loops but also for temp. loops).
If a track with no loop is loaded, beatloop_size is reset to default (4 beats), or, if there's a saved loop, its size is adopted.

What do you think?
(I know it's a bit late for such a change)

@ronso0 ronso0 changed the base branch from main to 2.4 January 6, 2024 01:35
@ronso0 ronso0 changed the title TEST: update beatloop size immediatly for loops set manually with IN/OUT TEST: update beatloop size for loops set manually with IN/OUT Jan 6, 2024
@ywwg
Copy link
Member

ywwg commented Jan 6, 2024

Yeah this is a tough one -- it feels like a lot of risky change so close to release. I feel like our test coverage is pretty good for beatloop size stuff though? In my opinion, given the bugs you are describing, they seem pretty minor and cosmetic. There is some annoyance, but the current experience is not that bad. Whereas, if there are bugs introduced here, we risk breaking loops which is a major feature.

My position would be to save this fix for the next patch release.

@ronso0
Copy link
Member Author

ronso0 commented Jan 6, 2024

You're right, this should go to 2.4.1
I'm pretty confident though this doesn't break anything, actually it makes workflows consistent. I started with #12509 to fix a minor bug but this grew a bit beyond a small bugfix due to the consequneces / other bug it revealed.

@ronso0 ronso0 added this to the 2.4.1 milestone Jan 6, 2024
@ronso0
Copy link
Member Author

ronso0 commented Jan 6, 2024

It is not clear to me why LoopingControlTest, LoopInOutButtons_QuantizeEnabled fails with this change.

Furthermore, if I do the test steps manually with 2.4 I don't get the expected result:

  • enable quantize
  • set playpos slightly after a beat
  • set IN
    = ✔️ IN snaps to beat, playpos is unchanged
  • move forward by 4 beats
    = ✔️ playpos is slightly after the beat
  • set OUT
    = ✔️ OUT snaps to beat
    = (loop is activated)
    = ❌ playpos jumps to [loop_in + playpos/beat offset] (which feels correct)
    expected: playpos remains after the beat

@ronso0 ronso0 changed the title TEST: update beatloop size for loops set manually with IN/OUT update beatloop size for loops set manually with IN/OUT Jan 8, 2024
@ronso0
Copy link
Member Author

ronso0 commented Jan 8, 2024

I feel like our test coverage is pretty good for beatloop size stuff though?

Yes. And no, see #12522 (comment)
I assume the test succeed because no visuals are involved?
IMO Mixxx behaves correctly, but the test expects behaviour that deosn't make sense to me (why not jump inside the loop like with other loop activation controls?).

Can anyone confirm my observation, or does it behave as expected?

@ywwg
Copy link
Member

ywwg commented Feb 5, 2024

expected: playpos remains after the beat

confirmed this is a bad expectation in the test and that we have a bug -- if there is an existing inactive loop, setting an out point just after a beat creates a loop but does not cause a seek into the loop. There is a missing seek-inside-loop check somewhere

@ronso0 ronso0 mentioned this pull request Feb 5, 2024
1 task
@ronso0
Copy link
Member Author

ronso0 commented Feb 7, 2024

The second commit tries to address the concerns raised in #1187:
When a track with an unusual loop size¹ is ejected, that loop size is kept (now not only for saved loops but also for temp. loops).
If a track with no loop is loaded, beatloop_size is reset to default (4 beats), or, if there's a saved loop, its size is adopted.
¹a loop size that's not in the list of 2^n sizes

and quoting from #12509
I'd even vote for not adopting any loop size after track load. I don't understand why loop halve/double should immediatly affect the existing loop (temp or saved), that's unhandy if I just want to preprare a new loop to be activated with beatloop_activate.
We can keep the previous loop size if it is in the list of 2^n sizes, else reset to the default value (4).

Copy link

github-actions bot commented Aug 7, 2024

This PR is marked as stale because it has been open 90 days with no activity.

@github-actions github-actions bot added the stale Stale issues that haven't been updated for a long time. label Aug 7, 2024
@ronso0 ronso0 changed the base branch from 2.4 to main August 7, 2024 11:35
@ronso0 ronso0 force-pushed the loop-manual-update-beatloop_size branch from 7437d9a to 91c8c0a Compare August 7, 2024 12:23
@ronso0
Copy link
Member Author

ronso0 commented Aug 7, 2024

Rebased onto main, will do manual test soonish.

@ronso0 ronso0 removed code quality stale Stale issues that haven't been updated for a long time. labels Aug 7, 2024
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants