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

Allow the odd empty segment to be skipped like a gap segment #5676

Merged
merged 2 commits into from
Jul 18, 2023

Conversation

robwalch
Copy link
Collaborator

@robwalch robwalch commented Jul 18, 2023

This PR will...

Treat the odd empty segment FRAG_PARSING_ERROR as a gap. The stream controller will advance to the next segment without loop loading. If subsequent errors occur, a level switch will be attempted, up to maxRetry count.

Why is this Pull Request needed?

Fixes regression of #4799 in v1.3 and v1.4 that introduced loop loading, and fatal errors after parsing errors accumulated beyond maxRetry count.

Are there any points in the code the reviewer needs to double check?

Some care was taken not to regress frag parsing error handling and gap jumping:

For the sample streams provided in #5674 the empty segments are not needed and once the following segments are appended there are not gaps. The player does not recognize this to the case, and proceeds naively. In most cases we would want to switch variants when an error like this occurs to find an alternative, but in this case all variants are empty at the same playlist position. For that reason, this fix works well for that case, by avoiding switching. The problem is this may not work as well in cases where a better alternative would be found by switching down. In those cases, the down switch would not be made unless two consecutive errors occur.

Resolves issues:

Resolves #5674

Checklist

  • changes have been done against master branch, and PR does not conflict
  • new unit / functional tests have been added (whenever applicable)
  • API or design changes are documented in API.md

@robwalch robwalch added this to the 1.4.10 milestone Jul 18, 2023
@robwalch robwalch merged commit 7cde71f into patch/v1.4.x Jul 18, 2023
@robwalch robwalch deleted the bugfix/odd-empty-segment-gap branch July 18, 2023 20:37
robwalch added a commit that referenced this pull request Jul 18, 2023
* patch/v1.4.x:
  Allow the odd empty segment to be skipped like a gap segment (#5676)
  Use input timescale when remuxing inband captions (#5675)
@robwalch robwalch added the GAP segments #EXT-X-GAP support and Fragment.gap usage label Jan 2, 2025
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
GAP segments #EXT-X-GAP support and Fragment.gap usage
Projects
None yet
Development

Successfully merging this pull request may close these issues.

1 participant