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

Fix handling of combo and combo colours around spinners #25551

Merged
merged 6 commits into from
Nov 24, 2023

Conversation

smoogipoo
Copy link
Contributor

Fixes #24270

Lessons learnt (from osu!stable):

During decode:
- Spinners get a NewCombo value from the decoded hitobject line.
- Spinners cannot have a ComboOffset, even though parts of code are written as if they could.
- The first hitobject following a spinner has NewCombo = true.
- The first hitobject in the beatmap has NewCombo = true.

During post-processing (after decoding):
- The first hitobject after each break gets NewCombo = true.
- For combo colour, spinners never start a new combo.
- For combo text, only the first hitobject after a spinner starts a new combo.

@bdach
Copy link
Collaborator

bdach commented Nov 23, 2023

Tests are a bit red :(

@smoogipoo
Copy link
Contributor Author

Looks like that was yet another incorrect implementation/assumption in lazer. Tested the beatmap file against stable and updated accordingly.

@peppy peppy self-requested a review November 24, 2023 01:16
Copy link
Member

@peppy peppy left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I haven't checked the underlying osu!stable assumptions (have faith that you got these right as per conversations yesterday).

Code here looks good / better than what we had.

@peppy peppy enabled auto-merge November 24, 2023 01:30
@peppy peppy merged commit afb8a20 into ppy:master Nov 24, 2023
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.

Color-hexed beatmaps don't translate correctly into Lazer
3 participants