rx-player 3.33.4-dev.2024083000 → 3.33.4
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.prettierignore +1 -0
- package/.prettierrc +4 -0
- package/.vscode/settings.json +9 -0
- package/CHANGELOG.md +1662 -1076
- package/MAINTAINERS.md +9 -12
- package/README.md +111 -127
- package/VERSION +1 -1
- package/dist/_esm5.processed/compat/add_class_name.js +4 -3
- package/dist/_esm5.processed/compat/add_text_track.d.ts +1 -1
- package/dist/_esm5.processed/compat/add_text_track.js +4 -4
- package/dist/_esm5.processed/compat/browser_compatibility_types.d.ts +2 -1
- package/dist/_esm5.processed/compat/browser_compatibility_types.js +15 -10
- package/dist/_esm5.processed/compat/browser_detection.d.ts +3 -1
- package/dist/_esm5.processed/compat/browser_detection.js +18 -10
- package/dist/_esm5.processed/compat/can_reuse_media_keys.d.ts +4 -0
- package/dist/_esm5.processed/compat/can_reuse_media_keys.js +6 -2
- package/dist/_esm5.processed/compat/change_source_buffer_type.d.ts +1 -1
- package/dist/_esm5.processed/compat/eme/close_session.d.ts +1 -1
- package/dist/_esm5.processed/compat/eme/close_session.js +17 -13
- package/dist/_esm5.processed/compat/eme/custom_key_system_access.d.ts +1 -1
- package/dist/_esm5.processed/compat/eme/custom_media_keys/ie11_media_keys.d.ts +1 -1
- package/dist/_esm5.processed/compat/eme/custom_media_keys/ie11_media_keys.js +8 -9
- package/dist/_esm5.processed/compat/eme/custom_media_keys/index.d.ts +3 -2
- package/dist/_esm5.processed/compat/eme/custom_media_keys/index.js +1 -1
- package/dist/_esm5.processed/compat/eme/custom_media_keys/moz_media_keys_constructor.d.ts +1 -1
- package/dist/_esm5.processed/compat/eme/custom_media_keys/old_webkit_media_keys.d.ts +1 -1
- package/dist/_esm5.processed/compat/eme/custom_media_keys/old_webkit_media_keys.js +7 -9
- package/dist/_esm5.processed/compat/eme/custom_media_keys/types.d.ts +4 -1
- package/dist/_esm5.processed/compat/eme/custom_media_keys/webkit_media_keys.d.ts +2 -2
- package/dist/_esm5.processed/compat/eme/custom_media_keys/webkit_media_keys.js +6 -12
- package/dist/_esm5.processed/compat/eme/custom_media_keys/webkit_media_keys_constructor.d.ts +2 -1
- package/dist/_esm5.processed/compat/eme/custom_media_keys/webkit_media_keys_constructor.js +3 -3
- package/dist/_esm5.processed/compat/eme/eme-api-implementation.d.ts +4 -4
- package/dist/_esm5.processed/compat/eme/eme-api-implementation.js +26 -11
- package/dist/_esm5.processed/compat/eme/generate_key_request.d.ts +1 -1
- package/dist/_esm5.processed/compat/eme/generate_key_request.js +17 -20
- package/dist/_esm5.processed/compat/eme/get_init_data.d.ts +3 -1
- package/dist/_esm5.processed/compat/eme/get_init_data.js +7 -9
- package/dist/_esm5.processed/compat/eme/get_uuid_kid_from_keystatus_kid.js +2 -3
- package/dist/_esm5.processed/compat/eme/get_webkit_fairplay_initdata.js +12 -13
- package/dist/_esm5.processed/compat/eme/index.d.ts +8 -5
- package/dist/_esm5.processed/compat/eme/index.js +1 -1
- package/dist/_esm5.processed/compat/eme/load_session.d.ts +1 -1
- package/dist/_esm5.processed/compat/enable_audio_track.d.ts +1 -1
- package/dist/_esm5.processed/compat/event_listeners.d.ts +26 -24
- package/dist/_esm5.processed/compat/event_listeners.js +14 -29
- package/dist/_esm5.processed/compat/fullscreen.d.ts +1 -1
- package/dist/_esm5.processed/compat/fullscreen.js +1 -1
- package/dist/_esm5.processed/compat/generate_init_data.js +3 -5
- package/dist/_esm5.processed/compat/index.d.ts +6 -3
- package/dist/_esm5.processed/compat/index.js +2 -2
- package/dist/_esm5.processed/compat/is_vtt_cue.d.ts +1 -1
- package/dist/_esm5.processed/compat/make_vtt_cue.d.ts +1 -1
- package/dist/_esm5.processed/compat/on_height_width_change.d.ts +2 -2
- package/dist/_esm5.processed/compat/on_height_width_change.js +3 -2
- package/dist/_esm5.processed/compat/patch_webkit_source_buffer.js +28 -29
- package/dist/_esm5.processed/compat/should_favour_custom_safari_EME.js +2 -2
- package/dist/_esm5.processed/compat/should_reload_media_source_on_decipherability_update.js +1 -2
- package/dist/_esm5.processed/config.d.ts +1 -1
- package/dist/_esm5.processed/config.js +0 -15
- package/dist/_esm5.processed/core/adaptive/adaptive_representation_selector.d.ts +7 -6
- package/dist/_esm5.processed/core/adaptive/adaptive_representation_selector.js +45 -22
- package/dist/_esm5.processed/core/adaptive/buffer_based_chooser.d.ts +1 -1
- package/dist/_esm5.processed/core/adaptive/buffer_based_chooser.js +11 -10
- package/dist/_esm5.processed/core/adaptive/guess_based_chooser.d.ts +4 -4
- package/dist/_esm5.processed/core/adaptive/guess_based_chooser.js +7 -6
- package/dist/_esm5.processed/core/adaptive/index.d.ts +3 -2
- package/dist/_esm5.processed/core/adaptive/network_analyzer.d.ts +4 -4
- package/dist/_esm5.processed/core/adaptive/network_analyzer.js +43 -38
- package/dist/_esm5.processed/core/adaptive/utils/bandwidth_estimator.js +1 -1
- package/dist/_esm5.processed/core/adaptive/utils/ewma.js +1 -2
- package/dist/_esm5.processed/core/adaptive/utils/filter_by_bitrate.d.ts +1 -1
- package/dist/_esm5.processed/core/adaptive/utils/filter_by_width.d.ts +1 -1
- package/dist/_esm5.processed/core/adaptive/utils/filter_by_width.js +3 -6
- package/dist/_esm5.processed/core/adaptive/utils/get_buffer_levels.js +7 -4
- package/dist/_esm5.processed/core/adaptive/utils/last_estimate_storage.d.ts +1 -1
- package/dist/_esm5.processed/core/adaptive/utils/pending_requests_store.d.ts +2 -1
- package/dist/_esm5.processed/core/adaptive/utils/representation_score_calculator.d.ts +1 -1
- package/dist/_esm5.processed/core/adaptive/utils/representation_score_calculator.js +8 -5
- package/dist/_esm5.processed/core/adaptive/utils/select_optimal_representation.d.ts +1 -1
- package/dist/_esm5.processed/core/adaptive/utils/select_optimal_representation.js +5 -3
- package/dist/_esm5.processed/core/api/debug/buffer_graph.d.ts +1 -1
- package/dist/_esm5.processed/core/api/debug/buffer_graph.js +3 -8
- package/dist/_esm5.processed/core/api/debug/buffer_size_graph.js +1 -2
- package/dist/_esm5.processed/core/api/debug/modules/general_info.d.ts +2 -2
- package/dist/_esm5.processed/core/api/debug/modules/general_info.js +17 -13
- package/dist/_esm5.processed/core/api/debug/modules/segment_buffer_content.d.ts +3 -3
- package/dist/_esm5.processed/core/api/debug/modules/segment_buffer_content.js +4 -2
- package/dist/_esm5.processed/core/api/debug/modules/segment_buffer_size.d.ts +2 -2
- package/dist/_esm5.processed/core/api/debug/modules/segment_buffer_size.js +1 -1
- package/dist/_esm5.processed/core/api/debug/render.d.ts +2 -2
- package/dist/_esm5.processed/core/api/debug/utils.d.ts +5 -5
- package/dist/_esm5.processed/core/api/index.d.ts +1 -1
- package/dist/_esm5.processed/core/api/option_utils.d.ts +3 -3
- package/dist/_esm5.processed/core/api/option_utils.js +85 -48
- package/dist/_esm5.processed/core/api/playback_observer.d.ts +16 -18
- package/dist/_esm5.processed/core/api/playback_observer.js +65 -42
- package/dist/_esm5.processed/core/api/public_api.d.ts +10 -9
- package/dist/_esm5.processed/core/api/public_api.js +103 -94
- package/dist/_esm5.processed/core/api/tracks_management/media_element_track_choice_manager.d.ts +1 -1
- package/dist/_esm5.processed/core/api/tracks_management/media_element_track_choice_manager.js +25 -14
- package/dist/_esm5.processed/core/api/tracks_management/track_choice_manager.d.ts +3 -3
- package/dist/_esm5.processed/core/api/tracks_management/track_choice_manager.js +72 -80
- package/dist/_esm5.processed/core/api/utils.d.ts +5 -5
- package/dist/_esm5.processed/core/api/utils.js +5 -8
- package/dist/_esm5.processed/core/decrypt/__tests__/__global__/utils.d.ts +12 -54
- package/dist/_esm5.processed/core/decrypt/__tests__/__global__/utils.js +55 -66
- package/dist/_esm5.processed/core/decrypt/attach_media_keys.d.ts +10 -5
- package/dist/_esm5.processed/core/decrypt/attach_media_keys.js +16 -8
- package/dist/_esm5.processed/core/decrypt/content_decryptor.d.ts +11 -2
- package/dist/_esm5.processed/core/decrypt/content_decryptor.js +136 -65
- package/dist/_esm5.processed/core/decrypt/create_or_load_session.d.ts +5 -4
- package/dist/_esm5.processed/core/decrypt/create_or_load_session.js +18 -7
- package/dist/_esm5.processed/core/decrypt/create_session.d.ts +5 -4
- package/dist/_esm5.processed/core/decrypt/create_session.js +6 -12
- package/dist/_esm5.processed/core/decrypt/dispose_decryption_resources.js +1 -2
- package/dist/_esm5.processed/core/decrypt/find_key_system.d.ts +13 -3
- package/dist/_esm5.processed/core/decrypt/find_key_system.js +45 -22
- package/dist/_esm5.processed/core/decrypt/get_key_system_configuration.js +1 -2
- package/dist/_esm5.processed/core/decrypt/get_media_keys.d.ts +9 -4
- package/dist/_esm5.processed/core/decrypt/get_media_keys.js +17 -6
- package/dist/_esm5.processed/core/decrypt/init_media_keys.d.ts +3 -3
- package/dist/_esm5.processed/core/decrypt/session_events_listener.d.ts +2 -2
- package/dist/_esm5.processed/core/decrypt/session_events_listener.js +12 -16
- package/dist/_esm5.processed/core/decrypt/set_server_certificate.d.ts +3 -3
- package/dist/_esm5.processed/core/decrypt/set_server_certificate.js +6 -7
- package/dist/_esm5.processed/core/decrypt/types.d.ts +11 -5
- package/dist/_esm5.processed/core/decrypt/utils/are_init_values_compatible.js +20 -12
- package/dist/_esm5.processed/core/decrypt/utils/check_key_statuses.d.ts +2 -2
- package/dist/_esm5.processed/core/decrypt/utils/check_key_statuses.js +5 -4
- package/dist/_esm5.processed/core/decrypt/utils/clean_old_loaded_sessions.d.ts +1 -1
- package/dist/_esm5.processed/core/decrypt/utils/clean_old_stored_persistent_info.d.ts +1 -1
- package/dist/_esm5.processed/core/decrypt/utils/init_data_values_container.d.ts +1 -1
- package/dist/_esm5.processed/core/decrypt/utils/init_data_values_container.js +16 -9
- package/dist/_esm5.processed/core/decrypt/utils/is_session_usable.d.ts +1 -1
- package/dist/_esm5.processed/core/decrypt/utils/is_session_usable.js +1 -2
- package/dist/_esm5.processed/core/decrypt/utils/key_session_record.d.ts +1 -1
- package/dist/_esm5.processed/core/decrypt/utils/key_session_record.js +1 -2
- package/dist/_esm5.processed/core/decrypt/utils/loaded_sessions_store.d.ts +11 -13
- package/dist/_esm5.processed/core/decrypt/utils/loaded_sessions_store.js +13 -13
- package/dist/_esm5.processed/core/decrypt/utils/media_keys_infos_store.d.ts +8 -3
- package/dist/_esm5.processed/core/decrypt/utils/media_keys_infos_store.js +1 -2
- package/dist/_esm5.processed/core/decrypt/utils/persistent_sessions_store.d.ts +3 -3
- package/dist/_esm5.processed/core/decrypt/utils/persistent_sessions_store.js +27 -16
- package/dist/_esm5.processed/core/decrypt/utils/serializable_bytes.js +1 -1
- package/dist/_esm5.processed/core/decrypt/utils/server_certificate_store.d.ts +1 -1
- package/dist/_esm5.processed/core/decrypt/utils/server_certificate_store.js +19 -12
- package/dist/_esm5.processed/core/fetchers/cdn_prioritizer.d.ts +2 -2
- package/dist/_esm5.processed/core/fetchers/cdn_prioritizer.js +5 -6
- package/dist/_esm5.processed/core/fetchers/index.d.ts +6 -3
- package/dist/_esm5.processed/core/fetchers/index.js +1 -1
- package/dist/_esm5.processed/core/fetchers/manifest/index.d.ts +3 -2
- package/dist/_esm5.processed/core/fetchers/manifest/manifest_fetcher.d.ts +2 -2
- package/dist/_esm5.processed/core/fetchers/manifest/manifest_fetcher.js +68 -61
- package/dist/_esm5.processed/core/fetchers/segment/index.d.ts +4 -3
- package/dist/_esm5.processed/core/fetchers/segment/prioritized_segment_fetcher.d.ts +4 -3
- package/dist/_esm5.processed/core/fetchers/segment/segment_fetcher.d.ts +9 -8
- package/dist/_esm5.processed/core/fetchers/segment/segment_fetcher.js +41 -29
- package/dist/_esm5.processed/core/fetchers/segment/segment_fetcher_creator.d.ts +5 -5
- package/dist/_esm5.processed/core/fetchers/segment/segment_fetcher_creator.js +2 -3
- package/dist/_esm5.processed/core/fetchers/segment/task_prioritizer.d.ts +1 -1
- package/dist/_esm5.processed/core/fetchers/segment/task_prioritizer.js +19 -18
- package/dist/_esm5.processed/core/fetchers/utils/error_selector.d.ts +1 -1
- package/dist/_esm5.processed/core/fetchers/utils/error_selector.js +1 -1
- package/dist/_esm5.processed/core/fetchers/utils/schedule_request.d.ts +3 -3
- package/dist/_esm5.processed/core/fetchers/utils/schedule_request.js +25 -25
- package/dist/_esm5.processed/core/init/directfile_content_initializer.d.ts +4 -4
- package/dist/_esm5.processed/core/init/directfile_content_initializer.js +21 -17
- package/dist/_esm5.processed/core/init/index.d.ts +2 -1
- package/dist/_esm5.processed/core/init/index.js +1 -1
- package/dist/_esm5.processed/core/init/media_source_content_initializer.d.ts +9 -9
- package/dist/_esm5.processed/core/init/media_source_content_initializer.js +64 -32
- package/dist/_esm5.processed/core/init/types.d.ts +10 -12
- package/dist/_esm5.processed/core/init/utils/content_time_boundaries_observer.d.ts +6 -5
- package/dist/_esm5.processed/core/init/utils/content_time_boundaries_observer.js +20 -19
- package/dist/_esm5.processed/core/init/utils/create_media_source.d.ts +1 -1
- package/dist/_esm5.processed/core/init/utils/create_media_source.js +2 -3
- package/dist/_esm5.processed/core/init/utils/create_stream_playback_observer.d.ts +6 -6
- package/dist/_esm5.processed/core/init/utils/create_stream_playback_observer.js +5 -3
- package/dist/_esm5.processed/core/init/utils/end_of_stream.d.ts +1 -1
- package/dist/_esm5.processed/core/init/utils/get_initial_time.d.ts +1 -1
- package/dist/_esm5.processed/core/init/utils/get_initial_time.js +12 -15
- package/dist/_esm5.processed/core/init/utils/get_loaded_reference.d.ts +3 -3
- package/dist/_esm5.processed/core/init/utils/get_loaded_reference.js +1 -2
- package/dist/_esm5.processed/core/init/utils/initial_seek_and_play.d.ts +9 -9
- package/dist/_esm5.processed/core/init/utils/initial_seek_and_play.js +39 -3
- package/dist/_esm5.processed/core/init/utils/initialize_content_decryption.d.ts +9 -8
- package/dist/_esm5.processed/core/init/utils/initialize_content_decryption.js +12 -9
- package/dist/_esm5.processed/core/init/utils/media_source_duration_updater.js +10 -7
- package/dist/_esm5.processed/core/init/utils/rebuffering_controller.d.ts +7 -6
- package/dist/_esm5.processed/core/init/utils/rebuffering_controller.js +24 -24
- package/dist/_esm5.processed/core/init/utils/stream_events_emitter/are_same_stream_events.js +1 -3
- package/dist/_esm5.processed/core/init/utils/stream_events_emitter/index.d.ts +1 -1
- package/dist/_esm5.processed/core/init/utils/stream_events_emitter/refresh_scheduled_events_list.d.ts +2 -2
- package/dist/_esm5.processed/core/init/utils/stream_events_emitter/refresh_scheduled_events_list.js +14 -6
- package/dist/_esm5.processed/core/init/utils/stream_events_emitter/stream_events_emitter.d.ts +3 -3
- package/dist/_esm5.processed/core/init/utils/stream_events_emitter/stream_events_emitter.js +12 -19
- package/dist/_esm5.processed/core/init/utils/stream_events_emitter/types.d.ts +1 -1
- package/dist/_esm5.processed/core/init/utils/throw_on_media_error.d.ts +1 -1
- package/dist/_esm5.processed/core/init/utils/throw_on_media_error.js +11 -6
- package/dist/_esm5.processed/core/segment_buffers/garbage_collector.d.ts +6 -6
- package/dist/_esm5.processed/core/segment_buffers/garbage_collector.js +12 -13
- package/dist/_esm5.processed/core/segment_buffers/implementations/audio_video/audio_video_segment_buffer.d.ts +3 -2
- package/dist/_esm5.processed/core/segment_buffers/implementations/audio_video/audio_video_segment_buffer.js +6 -9
- package/dist/_esm5.processed/core/segment_buffers/implementations/image/image_segment_buffer.d.ts +3 -2
- package/dist/_esm5.processed/core/segment_buffers/implementations/image/image_segment_buffer.js +1 -1
- package/dist/_esm5.processed/core/segment_buffers/implementations/text/html/html_text_segment_buffer.d.ts +2 -1
- package/dist/_esm5.processed/core/segment_buffers/implementations/text/html/html_text_segment_buffer.js +7 -7
- package/dist/_esm5.processed/core/segment_buffers/implementations/text/html/text_track_cues_store.d.ts +1 -1
- package/dist/_esm5.processed/core/segment_buffers/implementations/text/html/text_track_cues_store.js +4 -4
- package/dist/_esm5.processed/core/segment_buffers/implementations/text/html/update_proportional_elements.js +1 -2
- package/dist/_esm5.processed/core/segment_buffers/implementations/text/html/utils.d.ts +1 -1
- package/dist/_esm5.processed/core/segment_buffers/implementations/text/html/utils.js +2 -6
- package/dist/_esm5.processed/core/segment_buffers/implementations/text/native/native_text_segment_buffer.d.ts +2 -1
- package/dist/_esm5.processed/core/segment_buffers/implementations/text/native/native_text_segment_buffer.js +2 -2
- package/dist/_esm5.processed/core/segment_buffers/implementations/text/native/parsers.d.ts +1 -1
- package/dist/_esm5.processed/core/segment_buffers/implementations/types.d.ts +5 -7
- package/dist/_esm5.processed/core/segment_buffers/implementations/utils/manual_time_ranges.js +1 -1
- package/dist/_esm5.processed/core/segment_buffers/index.d.ts +8 -4
- package/dist/_esm5.processed/core/segment_buffers/index.js +2 -2
- package/dist/_esm5.processed/core/segment_buffers/inventory/buffered_history.d.ts +1 -1
- package/dist/_esm5.processed/core/segment_buffers/inventory/index.d.ts +6 -4
- package/dist/_esm5.processed/core/segment_buffers/inventory/segment_inventory.d.ts +4 -4
- package/dist/_esm5.processed/core/segment_buffers/inventory/segment_inventory.js +63 -54
- package/dist/_esm5.processed/core/segment_buffers/inventory/types.d.ts +1 -1
- package/dist/_esm5.processed/core/segment_buffers/segment_buffers_store.d.ts +2 -2
- package/dist/_esm5.processed/core/segment_buffers/segment_buffers_store.js +17 -23
- package/dist/_esm5.processed/core/stream/adaptation/adaptation_stream.d.ts +3 -3
- package/dist/_esm5.processed/core/stream/adaptation/adaptation_stream.js +49 -22
- package/dist/_esm5.processed/core/stream/adaptation/types.d.ts +8 -7
- package/dist/_esm5.processed/core/stream/adaptation/utils/create_representation_estimator.d.ts +7 -6
- package/dist/_esm5.processed/core/stream/adaptation/utils/create_representation_estimator.js +2 -1
- package/dist/_esm5.processed/core/stream/index.d.ts +6 -5
- package/dist/_esm5.processed/core/stream/orchestrator/get_time_ranges_for_content.d.ts +3 -3
- package/dist/_esm5.processed/core/stream/orchestrator/get_time_ranges_for_content.js +2 -2
- package/dist/_esm5.processed/core/stream/orchestrator/index.d.ts +3 -2
- package/dist/_esm5.processed/core/stream/orchestrator/stream_orchestrator.d.ts +9 -7
- package/dist/_esm5.processed/core/stream/orchestrator/stream_orchestrator.js +47 -34
- package/dist/_esm5.processed/core/stream/period/period_stream.d.ts +3 -3
- package/dist/_esm5.processed/core/stream/period/period_stream.js +49 -16
- package/dist/_esm5.processed/core/stream/period/types.d.ts +15 -12
- package/dist/_esm5.processed/core/stream/period/utils/get_adaptation_switch_strategy.d.ts +9 -9
- package/dist/_esm5.processed/core/stream/period/utils/get_adaptation_switch_strategy.js +26 -25
- package/dist/_esm5.processed/core/stream/representation/representation_stream.d.ts +3 -3
- package/dist/_esm5.processed/core/stream/representation/representation_stream.js +47 -23
- package/dist/_esm5.processed/core/stream/representation/types.d.ts +9 -8
- package/dist/_esm5.processed/core/stream/representation/utils/append_segment_to_buffer.d.ts +4 -4
- package/dist/_esm5.processed/core/stream/representation/utils/append_segment_to_buffer.js +10 -7
- package/dist/_esm5.processed/core/stream/representation/utils/check_for_discontinuity.d.ts +4 -3
- package/dist/_esm5.processed/core/stream/representation/utils/check_for_discontinuity.js +16 -18
- package/dist/_esm5.processed/core/stream/representation/utils/downloading_queue.d.ts +7 -6
- package/dist/_esm5.processed/core/stream/representation/utils/downloading_queue.js +11 -11
- package/dist/_esm5.processed/core/stream/representation/utils/force_garbage_collection.d.ts +2 -2
- package/dist/_esm5.processed/core/stream/representation/utils/force_garbage_collection.js +6 -8
- package/dist/_esm5.processed/core/stream/representation/utils/get_buffer_status.d.ts +5 -4
- package/dist/_esm5.processed/core/stream/representation/utils/get_buffer_status.js +40 -19
- package/dist/_esm5.processed/core/stream/representation/utils/get_needed_segments.d.ts +4 -3
- package/dist/_esm5.processed/core/stream/representation/utils/get_needed_segments.js +27 -28
- package/dist/_esm5.processed/core/stream/representation/utils/push_init_segment.d.ts +6 -5
- package/dist/_esm5.processed/core/stream/representation/utils/push_init_segment.js +7 -5
- package/dist/_esm5.processed/core/stream/representation/utils/push_media_segment.d.ts +8 -7
- package/dist/_esm5.processed/core/stream/representation/utils/push_media_segment.js +13 -10
- package/dist/_esm5.processed/default_config.js +20 -16
- package/dist/_esm5.processed/errors/encrypted_media_error.d.ts +2 -2
- package/dist/_esm5.processed/errors/encrypted_media_error.js +1 -1
- package/dist/_esm5.processed/errors/error_codes.d.ts +1 -1
- package/dist/_esm5.processed/errors/error_codes.js +1 -1
- package/dist/_esm5.processed/errors/format_error.d.ts +2 -2
- package/dist/_esm5.processed/errors/format_error.js +1 -2
- package/dist/_esm5.processed/errors/index.d.ts +6 -3
- package/dist/_esm5.processed/errors/index.js +2 -2
- package/dist/_esm5.processed/errors/is_known_error.d.ts +1 -1
- package/dist/_esm5.processed/errors/is_known_error.js +2 -2
- package/dist/_esm5.processed/errors/media_error.d.ts +3 -3
- package/dist/_esm5.processed/errors/media_error.js +4 -7
- package/dist/_esm5.processed/errors/network_error.d.ts +2 -2
- package/dist/_esm5.processed/errors/network_error.js +3 -3
- package/dist/_esm5.processed/errors/other_error.d.ts +1 -1
- package/dist/_esm5.processed/errors/other_error.js +1 -1
- package/dist/_esm5.processed/errors/request_error.d.ts +1 -1
- package/dist/_esm5.processed/experimental/features/dash_wasm.d.ts +2 -2
- package/dist/_esm5.processed/experimental/features/debug_element.d.ts +1 -1
- package/dist/_esm5.processed/experimental/features/local.d.ts +1 -1
- package/dist/_esm5.processed/experimental/features/metaplaylist.d.ts +1 -1
- package/dist/_esm5.processed/experimental/index.d.ts +1 -1
- package/dist/_esm5.processed/experimental/index.js +1 -1
- package/dist/_esm5.processed/experimental/tools/VideoThumbnailLoader/features/dash.d.ts +1 -1
- package/dist/_esm5.processed/experimental/tools/VideoThumbnailLoader/features/metaplaylist.d.ts +1 -1
- package/dist/_esm5.processed/experimental/tools/VideoThumbnailLoader/index.d.ts +1 -1
- package/dist/_esm5.processed/experimental/tools/VideoThumbnailLoader/index.js +2 -2
- package/dist/_esm5.processed/experimental/tools/VideoThumbnailLoader/load_and_push_segment.d.ts +3 -3
- package/dist/_esm5.processed/experimental/tools/VideoThumbnailLoader/load_and_push_segment.js +7 -3
- package/dist/_esm5.processed/experimental/tools/VideoThumbnailLoader/prepare_source_buffer.d.ts +1 -1
- package/dist/_esm5.processed/experimental/tools/VideoThumbnailLoader/prepare_source_buffer.js +1 -2
- package/dist/_esm5.processed/experimental/tools/VideoThumbnailLoader/remove_buffer_around_time.d.ts +2 -2
- package/dist/_esm5.processed/experimental/tools/VideoThumbnailLoader/remove_buffer_around_time.js +2 -2
- package/dist/_esm5.processed/experimental/tools/VideoThumbnailLoader/types.d.ts +3 -2
- package/dist/_esm5.processed/experimental/tools/VideoThumbnailLoader/video_thumbnail_loader.d.ts +2 -2
- package/dist/_esm5.processed/experimental/tools/VideoThumbnailLoader/video_thumbnail_loader.js +12 -18
- package/dist/_esm5.processed/experimental/tools/createMetaplaylist/get_duration_from_manifest.js +13 -23
- package/dist/_esm5.processed/experimental/tools/createMetaplaylist/index.d.ts +1 -1
- package/dist/_esm5.processed/experimental/tools/createMetaplaylist/index.js +8 -7
- package/dist/_esm5.processed/experimental/tools/mediaCapabilitiesProber/api/index.d.ts +1 -1
- package/dist/_esm5.processed/experimental/tools/mediaCapabilitiesProber/api/index.js +9 -13
- package/dist/_esm5.processed/experimental/tools/mediaCapabilitiesProber/api/probeMediaConfiguration.d.ts +4 -3
- package/dist/_esm5.processed/experimental/tools/mediaCapabilitiesProber/api/probeMediaConfiguration.js +5 -3
- package/dist/_esm5.processed/experimental/tools/mediaCapabilitiesProber/capabilities.d.ts +1 -1
- package/dist/_esm5.processed/experimental/tools/mediaCapabilitiesProber/capabilities.js +10 -47
- package/dist/_esm5.processed/experimental/tools/mediaCapabilitiesProber/probers/DRMInfos.d.ts +2 -1
- package/dist/_esm5.processed/experimental/tools/mediaCapabilitiesProber/probers/DRMInfos.js +8 -5
- package/dist/_esm5.processed/experimental/tools/mediaCapabilitiesProber/probers/HDCPPolicy.d.ts +2 -1
- package/dist/_esm5.processed/experimental/tools/mediaCapabilitiesProber/probers/HDCPPolicy.js +21 -13
- package/dist/_esm5.processed/experimental/tools/mediaCapabilitiesProber/probers/decodingInfo.d.ts +2 -1
- package/dist/_esm5.processed/experimental/tools/mediaCapabilitiesProber/probers/decodingInfo.js +22 -18
- package/dist/_esm5.processed/experimental/tools/mediaCapabilitiesProber/probers/defaultCodecsFinder.js +4 -7
- package/dist/_esm5.processed/experimental/tools/mediaCapabilitiesProber/probers/index.d.ts +1 -1
- package/dist/_esm5.processed/experimental/tools/mediaCapabilitiesProber/probers/mediaContentType.d.ts +2 -1
- package/dist/_esm5.processed/experimental/tools/mediaCapabilitiesProber/probers/mediaContentType.js +3 -5
- package/dist/_esm5.processed/experimental/tools/mediaCapabilitiesProber/probers/mediaContentTypeWithFeatures/format.d.ts +1 -1
- package/dist/_esm5.processed/experimental/tools/mediaCapabilitiesProber/probers/mediaContentTypeWithFeatures/format.js +4 -10
- package/dist/_esm5.processed/experimental/tools/mediaCapabilitiesProber/probers/mediaContentTypeWithFeatures/index.d.ts +2 -1
- package/dist/_esm5.processed/experimental/tools/mediaCapabilitiesProber/probers/mediaContentTypeWithFeatures/index.js +2 -3
- package/dist/_esm5.processed/experimental/tools/mediaCapabilitiesProber/probers/mediaDisplayInfos.d.ts +2 -1
- package/dist/_esm5.processed/experimental/tools/mediaCapabilitiesProber/probers/mediaDisplayInfos.js +2 -3
- package/dist/_esm5.processed/experimental/tools/mediaCapabilitiesProber/types.d.ts +2 -2
- package/dist/_esm5.processed/experimental/tools/mediaCapabilitiesProber/utils.d.ts +1 -1
- package/dist/_esm5.processed/experimental/tools/mediaCapabilitiesProber/utils.js +6 -6
- package/dist/_esm5.processed/experimental/tools/parseBIFThumbnails.js +5 -4
- package/dist/_esm5.processed/features/add_features.d.ts +1 -1
- package/dist/_esm5.processed/features/features_object.d.ts +1 -1
- package/dist/_esm5.processed/features/features_object.js +4 -3
- package/dist/_esm5.processed/features/index.d.ts +3 -2
- package/dist/_esm5.processed/features/index.js +1 -1
- package/dist/_esm5.processed/features/list/bif_parser.d.ts +1 -1
- package/dist/_esm5.processed/features/list/dash.d.ts +1 -1
- package/dist/_esm5.processed/features/list/directfile.d.ts +1 -1
- package/dist/_esm5.processed/features/list/eme.d.ts +1 -1
- package/dist/_esm5.processed/features/list/html_sami_parser.d.ts +1 -1
- package/dist/_esm5.processed/features/list/html_srt_parser.d.ts +1 -1
- package/dist/_esm5.processed/features/list/html_text_buffer.d.ts +1 -1
- package/dist/_esm5.processed/features/list/html_ttml_parser.d.ts +1 -1
- package/dist/_esm5.processed/features/list/html_vtt_parser.d.ts +1 -1
- package/dist/_esm5.processed/features/list/image_buffer.d.ts +1 -1
- package/dist/_esm5.processed/features/list/native_sami_parser.d.ts +1 -1
- package/dist/_esm5.processed/features/list/native_srt_parser.d.ts +1 -1
- package/dist/_esm5.processed/features/list/native_text_buffer.d.ts +1 -1
- package/dist/_esm5.processed/features/list/native_ttml_parser.d.ts +1 -1
- package/dist/_esm5.processed/features/list/native_vtt_parser.d.ts +1 -1
- package/dist/_esm5.processed/features/list/smooth.d.ts +1 -1
- package/dist/_esm5.processed/features/types.d.ts +11 -11
- package/dist/_esm5.processed/manifest/adaptation.d.ts +3 -3
- package/dist/_esm5.processed/manifest/adaptation.js +24 -14
- package/dist/_esm5.processed/manifest/index.d.ts +9 -5
- package/dist/_esm5.processed/manifest/index.js +4 -8
- package/dist/_esm5.processed/manifest/manifest.d.ts +8 -7
- package/dist/_esm5.processed/manifest/manifest.js +37 -33
- package/dist/_esm5.processed/manifest/period.d.ts +4 -4
- package/dist/_esm5.processed/manifest/period.js +7 -14
- package/dist/_esm5.processed/manifest/representation.d.ts +4 -4
- package/dist/_esm5.processed/manifest/representation.js +5 -5
- package/dist/_esm5.processed/manifest/representation_index/index.d.ts +3 -2
- package/dist/_esm5.processed/manifest/representation_index/index.js +1 -1
- package/dist/_esm5.processed/manifest/representation_index/static.d.ts +1 -1
- package/dist/_esm5.processed/manifest/representation_index/static.js +6 -2
- package/dist/_esm5.processed/manifest/representation_index/types.d.ts +6 -5
- package/dist/_esm5.processed/manifest/update_period_in_place.d.ts +3 -3
- package/dist/_esm5.processed/manifest/update_period_in_place.js +9 -9
- package/dist/_esm5.processed/manifest/update_periods.d.ts +2 -2
- package/dist/_esm5.processed/manifest/update_periods.js +6 -3
- package/dist/_esm5.processed/manifest/utils.d.ts +4 -4
- package/dist/_esm5.processed/manifest/utils.js +6 -4
- package/dist/_esm5.processed/parsers/containers/isobmff/create_box.d.ts +1 -1
- package/dist/_esm5.processed/parsers/containers/isobmff/create_box.js +5 -4
- package/dist/_esm5.processed/parsers/containers/isobmff/drm/playready.js +2 -3
- package/dist/_esm5.processed/parsers/containers/isobmff/get_box.js +3 -5
- package/dist/_esm5.processed/parsers/containers/isobmff/index.d.ts +5 -4
- package/dist/_esm5.processed/parsers/containers/isobmff/index.js +4 -4
- package/dist/_esm5.processed/parsers/containers/isobmff/read.d.ts +1 -1
- package/dist/_esm5.processed/parsers/containers/isobmff/read.js +9 -9
- package/dist/_esm5.processed/parsers/containers/isobmff/take_pssh_out.js +3 -4
- package/dist/_esm5.processed/parsers/containers/isobmff/utils.js +51 -41
- package/dist/_esm5.processed/parsers/containers/matroska/index.d.ts +2 -1
- package/dist/_esm5.processed/parsers/containers/matroska/index.js +1 -1
- package/dist/_esm5.processed/parsers/containers/matroska/utils.js +29 -16
- package/dist/_esm5.processed/parsers/images/bif.js +15 -5
- package/dist/_esm5.processed/parsers/manifest/dash/common/attach_trickmode_track.d.ts +1 -1
- package/dist/_esm5.processed/parsers/manifest/dash/common/convert_supplemental_codecs.js +1 -3
- package/dist/_esm5.processed/parsers/manifest/dash/common/flatten_overlapping_periods.d.ts +1 -1
- package/dist/_esm5.processed/parsers/manifest/dash/common/flatten_overlapping_periods.js +1 -1
- package/dist/_esm5.processed/parsers/manifest/dash/common/get_hdr_information.js +4 -12
- package/dist/_esm5.processed/parsers/manifest/dash/common/get_http_utc-timing_url.d.ts +1 -1
- package/dist/_esm5.processed/parsers/manifest/dash/common/get_http_utc-timing_url.js +4 -5
- package/dist/_esm5.processed/parsers/manifest/dash/common/get_minimum_and_maximum_positions.d.ts +1 -1
- package/dist/_esm5.processed/parsers/manifest/dash/common/get_minimum_and_maximum_positions.js +5 -2
- package/dist/_esm5.processed/parsers/manifest/dash/common/get_periods_time_infos.d.ts +1 -1
- package/dist/_esm5.processed/parsers/manifest/dash/common/get_periods_time_infos.js +5 -6
- package/dist/_esm5.processed/parsers/manifest/dash/common/index.d.ts +3 -2
- package/dist/_esm5.processed/parsers/manifest/dash/common/indexes/base.d.ts +4 -4
- package/dist/_esm5.processed/parsers/manifest/dash/common/indexes/base.js +34 -28
- package/dist/_esm5.processed/parsers/manifest/dash/common/indexes/get_init_segment.d.ts +2 -2
- package/dist/_esm5.processed/parsers/manifest/dash/common/indexes/get_init_segment.js +7 -4
- package/dist/_esm5.processed/parsers/manifest/dash/common/indexes/get_segments_from_timeline.d.ts +4 -4
- package/dist/_esm5.processed/parsers/manifest/dash/common/indexes/get_segments_from_timeline.js +15 -11
- package/dist/_esm5.processed/parsers/manifest/dash/common/indexes/index.d.ts +10 -5
- package/dist/_esm5.processed/parsers/manifest/dash/common/indexes/list.d.ts +2 -2
- package/dist/_esm5.processed/parsers/manifest/dash/common/indexes/list.js +30 -18
- package/dist/_esm5.processed/parsers/manifest/dash/common/indexes/template.d.ts +3 -3
- package/dist/_esm5.processed/parsers/manifest/dash/common/indexes/template.js +56 -55
- package/dist/_esm5.processed/parsers/manifest/dash/common/indexes/timeline/construct_timeline_from_elements.d.ts +1 -1
- package/dist/_esm5.processed/parsers/manifest/dash/common/indexes/timeline/construct_timeline_from_elements.js +2 -6
- package/dist/_esm5.processed/parsers/manifest/dash/common/indexes/timeline/construct_timeline_from_previous_timeline.d.ts +1 -1
- package/dist/_esm5.processed/parsers/manifest/dash/common/indexes/timeline/construct_timeline_from_previous_timeline.js +11 -15
- package/dist/_esm5.processed/parsers/manifest/dash/common/indexes/timeline/convert_element_to_index_segment.d.ts +1 -1
- package/dist/_esm5.processed/parsers/manifest/dash/common/indexes/timeline/convert_element_to_index_segment.js +12 -9
- package/dist/_esm5.processed/parsers/manifest/dash/common/indexes/timeline/find_first_common_start_time.d.ts +1 -1
- package/dist/_esm5.processed/parsers/manifest/dash/common/indexes/timeline/find_first_common_start_time.js +29 -19
- package/dist/_esm5.processed/parsers/manifest/dash/common/indexes/timeline/index.d.ts +3 -2
- package/dist/_esm5.processed/parsers/manifest/dash/common/indexes/timeline/timeline_representation_index.d.ts +6 -6
- package/dist/_esm5.processed/parsers/manifest/dash/common/indexes/timeline/timeline_representation_index.js +73 -59
- package/dist/_esm5.processed/parsers/manifest/dash/common/indexes/tokens.js +2 -4
- package/dist/_esm5.processed/parsers/manifest/dash/common/infer_adaptation_type.d.ts +1 -1
- package/dist/_esm5.processed/parsers/manifest/dash/common/manifest_bounds_calculator.js +7 -8
- package/dist/_esm5.processed/parsers/manifest/dash/common/parse_adaptation_sets.d.ts +4 -4
- package/dist/_esm5.processed/parsers/manifest/dash/common/parse_adaptation_sets.js +52 -50
- package/dist/_esm5.processed/parsers/manifest/dash/common/parse_availability_start_time.d.ts +1 -1
- package/dist/_esm5.processed/parsers/manifest/dash/common/parse_mpd.d.ts +6 -6
- package/dist/_esm5.processed/parsers/manifest/dash/common/parse_mpd.js +52 -31
- package/dist/_esm5.processed/parsers/manifest/dash/common/parse_periods.d.ts +4 -4
- package/dist/_esm5.processed/parsers/manifest/dash/common/parse_periods.js +41 -30
- package/dist/_esm5.processed/parsers/manifest/dash/common/parse_representation_index.d.ts +4 -4
- package/dist/_esm5.processed/parsers/manifest/dash/common/parse_representation_index.js +1 -2
- package/dist/_esm5.processed/parsers/manifest/dash/common/parse_representations.d.ts +4 -4
- package/dist/_esm5.processed/parsers/manifest/dash/common/parse_representations.js +63 -64
- package/dist/_esm5.processed/parsers/manifest/dash/common/resolve_base_urls.d.ts +1 -1
- package/dist/_esm5.processed/parsers/manifest/dash/common/resolve_base_urls.js +4 -2
- package/dist/_esm5.processed/parsers/manifest/dash/js-parser/node_parsers/AdaptationSet.d.ts +1 -1
- package/dist/_esm5.processed/parsers/manifest/dash/js-parser/node_parsers/AdaptationSet.js +73 -37
- package/dist/_esm5.processed/parsers/manifest/dash/js-parser/node_parsers/BaseURL.d.ts +1 -1
- package/dist/_esm5.processed/parsers/manifest/dash/js-parser/node_parsers/BaseURL.js +1 -2
- package/dist/_esm5.processed/parsers/manifest/dash/js-parser/node_parsers/ContentComponent.d.ts +1 -1
- package/dist/_esm5.processed/parsers/manifest/dash/js-parser/node_parsers/ContentProtection.d.ts +1 -1
- package/dist/_esm5.processed/parsers/manifest/dash/js-parser/node_parsers/EventStream.d.ts +1 -1
- package/dist/_esm5.processed/parsers/manifest/dash/js-parser/node_parsers/EventStream.js +13 -7
- package/dist/_esm5.processed/parsers/manifest/dash/js-parser/node_parsers/Initialization.d.ts +1 -1
- package/dist/_esm5.processed/parsers/manifest/dash/js-parser/node_parsers/Initialization.js +5 -3
- package/dist/_esm5.processed/parsers/manifest/dash/js-parser/node_parsers/MPD.d.ts +1 -1
- package/dist/_esm5.processed/parsers/manifest/dash/js-parser/node_parsers/MPD.js +44 -27
- package/dist/_esm5.processed/parsers/manifest/dash/js-parser/node_parsers/Period.d.ts +1 -1
- package/dist/_esm5.processed/parsers/manifest/dash/js-parser/node_parsers/Period.js +14 -8
- package/dist/_esm5.processed/parsers/manifest/dash/js-parser/node_parsers/Representation.d.ts +1 -1
- package/dist/_esm5.processed/parsers/manifest/dash/js-parser/node_parsers/Representation.js +36 -18
- package/dist/_esm5.processed/parsers/manifest/dash/js-parser/node_parsers/SegmentBase.d.ts +1 -1
- package/dist/_esm5.processed/parsers/manifest/dash/js-parser/node_parsers/SegmentBase.js +36 -18
- package/dist/_esm5.processed/parsers/manifest/dash/js-parser/node_parsers/SegmentList.d.ts +1 -1
- package/dist/_esm5.processed/parsers/manifest/dash/js-parser/node_parsers/SegmentTemplate.d.ts +1 -1
- package/dist/_esm5.processed/parsers/manifest/dash/js-parser/node_parsers/SegmentTemplate.js +17 -8
- package/dist/_esm5.processed/parsers/manifest/dash/js-parser/node_parsers/SegmentTimeline.d.ts +1 -1
- package/dist/_esm5.processed/parsers/manifest/dash/js-parser/node_parsers/SegmentURL.d.ts +1 -1
- package/dist/_esm5.processed/parsers/manifest/dash/js-parser/node_parsers/SegmentURL.js +9 -5
- package/dist/_esm5.processed/parsers/manifest/dash/js-parser/node_parsers/utils.d.ts +8 -26
- package/dist/_esm5.processed/parsers/manifest/dash/js-parser/node_parsers/utils.js +6 -12
- package/dist/_esm5.processed/parsers/manifest/dash/js-parser/parse_from_document.d.ts +2 -2
- package/dist/_esm5.processed/parsers/manifest/dash/js-parser/parse_from_document.js +9 -4
- package/dist/_esm5.processed/parsers/manifest/dash/parsers_types.d.ts +2 -2
- package/dist/_esm5.processed/parsers/manifest/dash/wasm-parser/index.d.ts +3 -2
- package/dist/_esm5.processed/parsers/manifest/dash/wasm-parser/ts/dash-wasm-parser.d.ts +1 -1
- package/dist/_esm5.processed/parsers/manifest/dash/wasm-parser/ts/dash-wasm-parser.js +29 -16
- package/dist/_esm5.processed/parsers/manifest/dash/wasm-parser/ts/generators/AdaptationSet.d.ts +3 -2
- package/dist/_esm5.processed/parsers/manifest/dash/wasm-parser/ts/generators/AdaptationSet.js +22 -35
- package/dist/_esm5.processed/parsers/manifest/dash/wasm-parser/ts/generators/BaseURL.d.ts +2 -2
- package/dist/_esm5.processed/parsers/manifest/dash/wasm-parser/ts/generators/ContentComponent.d.ts +2 -2
- package/dist/_esm5.processed/parsers/manifest/dash/wasm-parser/ts/generators/ContentProtection.d.ts +2 -2
- package/dist/_esm5.processed/parsers/manifest/dash/wasm-parser/ts/generators/ContentProtection.js +3 -1
- package/dist/_esm5.processed/parsers/manifest/dash/wasm-parser/ts/generators/EventStream.d.ts +3 -2
- package/dist/_esm5.processed/parsers/manifest/dash/wasm-parser/ts/generators/EventStream.js +2 -4
- package/dist/_esm5.processed/parsers/manifest/dash/wasm-parser/ts/generators/Label.d.ts +3 -0
- package/dist/_esm5.processed/parsers/manifest/dash/wasm-parser/ts/generators/Label.js +9 -0
- package/dist/_esm5.processed/parsers/manifest/dash/wasm-parser/ts/generators/MPD.d.ts +3 -2
- package/dist/_esm5.processed/parsers/manifest/dash/wasm-parser/ts/generators/MPD.js +5 -5
- package/dist/_esm5.processed/parsers/manifest/dash/wasm-parser/ts/generators/Period.d.ts +3 -2
- package/dist/_esm5.processed/parsers/manifest/dash/wasm-parser/ts/generators/Period.js +9 -6
- package/dist/_esm5.processed/parsers/manifest/dash/wasm-parser/ts/generators/Representation.d.ts +3 -2
- package/dist/_esm5.processed/parsers/manifest/dash/wasm-parser/ts/generators/Representation.js +8 -16
- package/dist/_esm5.processed/parsers/manifest/dash/wasm-parser/ts/generators/Scheme.d.ts +2 -2
- package/dist/_esm5.processed/parsers/manifest/dash/wasm-parser/ts/generators/SegmentBase.d.ts +2 -2
- package/dist/_esm5.processed/parsers/manifest/dash/wasm-parser/ts/generators/SegmentBase.js +5 -10
- package/dist/_esm5.processed/parsers/manifest/dash/wasm-parser/ts/generators/SegmentList.d.ts +3 -2
- package/dist/_esm5.processed/parsers/manifest/dash/wasm-parser/ts/generators/SegmentTemplate.d.ts +2 -2
- package/dist/_esm5.processed/parsers/manifest/dash/wasm-parser/ts/generators/SegmentTemplate.js +11 -18
- package/dist/_esm5.processed/parsers/manifest/dash/wasm-parser/ts/generators/SegmentUrl.d.ts +2 -2
- package/dist/_esm5.processed/parsers/manifest/dash/wasm-parser/ts/generators/SegmentUrl.js +2 -4
- package/dist/_esm5.processed/parsers/manifest/dash/wasm-parser/ts/generators/XLink.d.ts +3 -2
- package/dist/_esm5.processed/parsers/manifest/dash/wasm-parser/ts/generators/XLink.js +5 -5
- package/dist/_esm5.processed/parsers/manifest/dash/wasm-parser/ts/generators/root.d.ts +2 -2
- package/dist/_esm5.processed/parsers/manifest/dash/wasm-parser/ts/generators/root.js +5 -6
- package/dist/_esm5.processed/parsers/manifest/dash/wasm-parser/ts/parsers_stack.d.ts +1 -1
- package/dist/_esm5.processed/parsers/manifest/dash/wasm-parser/ts/parsers_stack.js +1 -2
- package/dist/_esm5.processed/parsers/manifest/dash/wasm-parser/ts/types.d.ts +2 -1
- package/dist/_esm5.processed/parsers/manifest/dash/wasm-parser/ts/utils.d.ts +1 -1
- package/dist/_esm5.processed/parsers/manifest/dash/wasm-parser/ts/utils.js +2 -4
- package/dist/_esm5.processed/parsers/manifest/local/index.d.ts +1 -1
- package/dist/_esm5.processed/parsers/manifest/local/parse_local_manifest.d.ts +2 -2
- package/dist/_esm5.processed/parsers/manifest/local/parse_local_manifest.js +25 -16
- package/dist/_esm5.processed/parsers/manifest/local/representation_index.d.ts +2 -2
- package/dist/_esm5.processed/parsers/manifest/local/representation_index.js +5 -10
- package/dist/_esm5.processed/parsers/manifest/metaplaylist/index.d.ts +3 -2
- package/dist/_esm5.processed/parsers/manifest/metaplaylist/metaplaylist_parser.d.ts +2 -2
- package/dist/_esm5.processed/parsers/manifest/metaplaylist/metaplaylist_parser.js +33 -29
- package/dist/_esm5.processed/parsers/manifest/metaplaylist/representation_index.d.ts +2 -2
- package/dist/_esm5.processed/parsers/manifest/metaplaylist/representation_index.js +9 -7
- package/dist/_esm5.processed/parsers/manifest/smooth/create_parser.d.ts +3 -3
- package/dist/_esm5.processed/parsers/manifest/smooth/create_parser.js +136 -109
- package/dist/_esm5.processed/parsers/manifest/smooth/get_codecs.js +3 -3
- package/dist/_esm5.processed/parsers/manifest/smooth/index.d.ts +4 -2
- package/dist/_esm5.processed/parsers/manifest/smooth/index.js +1 -1
- package/dist/_esm5.processed/parsers/manifest/smooth/parse_C_nodes.js +6 -6
- package/dist/_esm5.processed/parsers/manifest/smooth/parse_protection_node.js +12 -8
- package/dist/_esm5.processed/parsers/manifest/smooth/representation_index.d.ts +2 -2
- package/dist/_esm5.processed/parsers/manifest/smooth/representation_index.js +48 -53
- package/dist/_esm5.processed/parsers/manifest/smooth/utils/add_segment_infos.js +10 -7
- package/dist/_esm5.processed/parsers/manifest/smooth/utils/tokens.d.ts +1 -1
- package/dist/_esm5.processed/parsers/manifest/smooth/utils/tokens.js +2 -3
- package/dist/_esm5.processed/parsers/manifest/types.d.ts +2 -2
- package/dist/_esm5.processed/parsers/manifest/utils/check_manifest_ids.d.ts +1 -1
- package/dist/_esm5.processed/parsers/manifest/utils/clear_timeline_from_position.d.ts +1 -1
- package/dist/_esm5.processed/parsers/manifest/utils/clear_timeline_from_position.js +9 -6
- package/dist/_esm5.processed/parsers/manifest/utils/get_first_time_from_adaptation.d.ts +1 -1
- package/dist/_esm5.processed/parsers/manifest/utils/get_first_time_from_adaptation.js +5 -4
- package/dist/_esm5.processed/parsers/manifest/utils/get_last_time_from_adaptation.d.ts +1 -1
- package/dist/_esm5.processed/parsers/manifest/utils/get_last_time_from_adaptation.js +5 -4
- package/dist/_esm5.processed/parsers/manifest/utils/get_maximum_positions.d.ts +1 -1
- package/dist/_esm5.processed/parsers/manifest/utils/get_maximum_positions.js +10 -16
- package/dist/_esm5.processed/parsers/manifest/utils/get_minimum_position.d.ts +1 -1
- package/dist/_esm5.processed/parsers/manifest/utils/get_minimum_position.js +4 -10
- package/dist/_esm5.processed/parsers/manifest/utils/index_helpers.d.ts +1 -1
- package/dist/_esm5.processed/parsers/manifest/utils/index_helpers.js +4 -5
- package/dist/_esm5.processed/parsers/manifest/utils/update_segment_timeline.d.ts +1 -1
- package/dist/_esm5.processed/parsers/manifest/utils/update_segment_timeline.js +18 -18
- package/dist/_esm5.processed/parsers/texttracks/index.d.ts +1 -1
- package/dist/_esm5.processed/parsers/texttracks/sami/html.d.ts +1 -1
- package/dist/_esm5.processed/parsers/texttracks/sami/html.js +15 -15
- package/dist/_esm5.processed/parsers/texttracks/sami/native.d.ts +1 -1
- package/dist/_esm5.processed/parsers/texttracks/sami/native.js +7 -14
- package/dist/_esm5.processed/parsers/texttracks/srt/html.js +6 -6
- package/dist/_esm5.processed/parsers/texttracks/srt/native.d.ts +1 -1
- package/dist/_esm5.processed/parsers/texttracks/srt/native.js +1 -7
- package/dist/_esm5.processed/parsers/texttracks/srt/parse_cue.js +4 -8
- package/dist/_esm5.processed/parsers/texttracks/ttml/get_parameters.js +4 -8
- package/dist/_esm5.processed/parsers/texttracks/ttml/get_time_delimiters.d.ts +1 -1
- package/dist/_esm5.processed/parsers/texttracks/ttml/get_time_delimiters.js +6 -8
- package/dist/_esm5.processed/parsers/texttracks/ttml/html/apply_default_ttml_paragraph_style.js +2 -2
- package/dist/_esm5.processed/parsers/texttracks/ttml/html/apply_extent.js +2 -6
- package/dist/_esm5.processed/parsers/texttracks/ttml/html/apply_font_size.js +3 -4
- package/dist/_esm5.processed/parsers/texttracks/ttml/html/apply_origin.js +2 -6
- package/dist/_esm5.processed/parsers/texttracks/ttml/html/apply_padding.js +2 -6
- package/dist/_esm5.processed/parsers/texttracks/ttml/html/create_element.d.ts +2 -2
- package/dist/_esm5.processed/parsers/texttracks/ttml/html/create_element.js +22 -21
- package/dist/_esm5.processed/parsers/texttracks/ttml/html/generate_css_test_outline.js +2 -2
- package/dist/_esm5.processed/parsers/texttracks/ttml/html/parse_cue.d.ts +1 -1
- package/dist/_esm5.processed/parsers/texttracks/ttml/html/parse_cue.js +5 -3
- package/dist/_esm5.processed/parsers/texttracks/ttml/html/parse_ttml_to_div.d.ts +1 -1
- package/dist/_esm5.processed/parsers/texttracks/ttml/html/ttml_color_to_css_color.js +34 -19
- package/dist/_esm5.processed/parsers/texttracks/ttml/native/parse_cue.d.ts +2 -2
- package/dist/_esm5.processed/parsers/texttracks/ttml/native/parse_cue.js +9 -10
- package/dist/_esm5.processed/parsers/texttracks/ttml/native/parse_ttml_to_vtt.d.ts +1 -1
- package/dist/_esm5.processed/parsers/texttracks/ttml/parse_ttml.d.ts +3 -3
- package/dist/_esm5.processed/parsers/texttracks/ttml/parse_ttml.js +28 -16
- package/dist/_esm5.processed/parsers/texttracks/ttml/resolve_styles_inheritance.d.ts +1 -1
- package/dist/_esm5.processed/parsers/texttracks/ttml/time_parsing.d.ts +1 -1
- package/dist/_esm5.processed/parsers/texttracks/ttml/time_parsing.js +2 -2
- package/dist/_esm5.processed/parsers/texttracks/types.d.ts +1 -1
- package/dist/_esm5.processed/parsers/texttracks/webvtt/get_cue_blocks.js +1 -1
- package/dist/_esm5.processed/parsers/texttracks/webvtt/get_style_blocks.js +2 -1
- package/dist/_esm5.processed/parsers/texttracks/webvtt/html/convert_payload_to_html.d.ts +1 -1
- package/dist/_esm5.processed/parsers/texttracks/webvtt/html/create_default_style_elements.d.ts +1 -1
- package/dist/_esm5.processed/parsers/texttracks/webvtt/html/create_style_attribute.js +6 -12
- package/dist/_esm5.processed/parsers/texttracks/webvtt/html/create_styled_element.d.ts +1 -1
- package/dist/_esm5.processed/parsers/texttracks/webvtt/html/create_styled_element.js +7 -8
- package/dist/_esm5.processed/parsers/texttracks/webvtt/html/index.d.ts +1 -1
- package/dist/_esm5.processed/parsers/texttracks/webvtt/html/parse_style_block.js +4 -4
- package/dist/_esm5.processed/parsers/texttracks/webvtt/html/parse_webvtt_to_div.d.ts +1 -1
- package/dist/_esm5.processed/parsers/texttracks/webvtt/html/to_html.d.ts +1 -1
- package/dist/_esm5.processed/parsers/texttracks/webvtt/html/to_html.js +4 -10
- package/dist/_esm5.processed/parsers/texttracks/webvtt/native/parse_vtt_to_cues.d.ts +1 -1
- package/dist/_esm5.processed/parsers/texttracks/webvtt/native/parse_vtt_to_cues.js +2 -6
- package/dist/_esm5.processed/parsers/texttracks/webvtt/native/set_settings_on_cue.d.ts +1 -1
- package/dist/_esm5.processed/parsers/texttracks/webvtt/native/to_native_cue.d.ts +1 -1
- package/dist/_esm5.processed/parsers/texttracks/webvtt/native/to_native_cue.js +1 -1
- package/dist/_esm5.processed/parsers/texttracks/webvtt/parse_cue_block.js +2 -4
- package/dist/_esm5.processed/parsers/texttracks/webvtt/parse_timestamp.js +1 -2
- package/dist/_esm5.processed/parsers/texttracks/webvtt/utils.js +6 -6
- package/dist/_esm5.processed/public_types.d.ts +13 -11
- package/dist/_esm5.processed/tools/TextTrackRenderer/index.d.ts +3 -2
- package/dist/_esm5.processed/tools/TextTrackRenderer/text_track_renderer.d.ts +2 -2
- package/dist/_esm5.processed/tools/TextTrackRenderer/text_track_renderer.js +15 -10
- package/dist/_esm5.processed/transports/dash/add_segment_integrity_checks_to_loader.d.ts +1 -1
- package/dist/_esm5.processed/transports/dash/add_segment_integrity_checks_to_loader.js +2 -3
- package/dist/_esm5.processed/transports/dash/construct_segment_url.d.ts +2 -2
- package/dist/_esm5.processed/transports/dash/construct_segment_url.js +5 -3
- package/dist/_esm5.processed/transports/dash/extract_complete_chunks.js +2 -2
- package/dist/_esm5.processed/transports/dash/get_events_out_of_emsgs.d.ts +2 -2
- package/dist/_esm5.processed/transports/dash/get_events_out_of_emsgs.js +9 -10
- package/dist/_esm5.processed/transports/dash/image_pipelines.d.ts +3 -3
- package/dist/_esm5.processed/transports/dash/image_pipelines.js +32 -19
- package/dist/_esm5.processed/transports/dash/init_segment_loader.d.ts +3 -3
- package/dist/_esm5.processed/transports/dash/init_segment_loader.js +46 -22
- package/dist/_esm5.processed/transports/dash/low_latency_segment_loader.d.ts +2 -2
- package/dist/_esm5.processed/transports/dash/low_latency_segment_loader.js +13 -9
- package/dist/_esm5.processed/transports/dash/manifest_parser.d.ts +2 -2
- package/dist/_esm5.processed/transports/dash/manifest_parser.js +35 -22
- package/dist/_esm5.processed/transports/dash/pipelines.d.ts +1 -1
- package/dist/_esm5.processed/transports/dash/pipelines.js +11 -15
- package/dist/_esm5.processed/transports/dash/segment_loader.d.ts +4 -4
- package/dist/_esm5.processed/transports/dash/segment_loader.js +30 -21
- package/dist/_esm5.processed/transports/dash/segment_parser.d.ts +2 -2
- package/dist/_esm5.processed/transports/dash/segment_parser.js +47 -21
- package/dist/_esm5.processed/transports/dash/text_loader.d.ts +2 -2
- package/dist/_esm5.processed/transports/dash/text_loader.js +19 -19
- package/dist/_esm5.processed/transports/dash/text_parser.d.ts +2 -2
- package/dist/_esm5.processed/transports/dash/text_parser.js +45 -24
- package/dist/_esm5.processed/transports/local/pipelines.d.ts +1 -1
- package/dist/_esm5.processed/transports/local/pipelines.js +7 -8
- package/dist/_esm5.processed/transports/local/segment_loader.d.ts +3 -3
- package/dist/_esm5.processed/transports/local/segment_loader.js +14 -6
- package/dist/_esm5.processed/transports/local/segment_parser.d.ts +1 -1
- package/dist/_esm5.processed/transports/local/segment_parser.js +31 -13
- package/dist/_esm5.processed/transports/local/text_parser.d.ts +1 -1
- package/dist/_esm5.processed/transports/local/text_parser.js +44 -19
- package/dist/_esm5.processed/transports/metaplaylist/manifest_loader.d.ts +4 -4
- package/dist/_esm5.processed/transports/metaplaylist/manifest_loader.js +9 -5
- package/dist/_esm5.processed/transports/metaplaylist/pipelines.d.ts +1 -1
- package/dist/_esm5.processed/transports/metaplaylist/pipelines.js +25 -18
- package/dist/_esm5.processed/transports/smooth/extract_timings_infos.d.ts +2 -2
- package/dist/_esm5.processed/transports/smooth/extract_timings_infos.js +16 -15
- package/dist/_esm5.processed/transports/smooth/isobmff/create_audio_init_segment.js +3 -3
- package/dist/_esm5.processed/transports/smooth/isobmff/create_boxes.js +14 -32
- package/dist/_esm5.processed/transports/smooth/isobmff/create_init_segment.js +2 -2
- package/dist/_esm5.processed/transports/smooth/isobmff/create_traf_box.js +2 -2
- package/dist/_esm5.processed/transports/smooth/isobmff/get_aaces_header.js +4 -16
- package/dist/_esm5.processed/transports/smooth/isobmff/index.d.ts +4 -2
- package/dist/_esm5.processed/transports/smooth/isobmff/parse_tfrf.js +2 -2
- package/dist/_esm5.processed/transports/smooth/isobmff/parse_tfxd.js +1 -1
- package/dist/_esm5.processed/transports/smooth/isobmff/patch_segment.js +11 -10
- package/dist/_esm5.processed/transports/smooth/pipelines.d.ts +1 -1
- package/dist/_esm5.processed/transports/smooth/pipelines.js +121 -79
- package/dist/_esm5.processed/transports/smooth/segment_loader.d.ts +3 -3
- package/dist/_esm5.processed/transports/smooth/segment_loader.js +53 -27
- package/dist/_esm5.processed/transports/smooth/utils.d.ts +2 -2
- package/dist/_esm5.processed/transports/smooth/utils.js +7 -5
- package/dist/_esm5.processed/transports/types.d.ts +11 -25
- package/dist/_esm5.processed/transports/utils/byte_range.js +1 -2
- package/dist/_esm5.processed/transports/utils/call_custom_manifest_loader.d.ts +3 -3
- package/dist/_esm5.processed/transports/utils/call_custom_manifest_loader.js +13 -7
- package/dist/_esm5.processed/transports/utils/check_isobmff_integrity.js +3 -3
- package/dist/_esm5.processed/transports/utils/find_complete_box.js +3 -2
- package/dist/_esm5.processed/transports/utils/generate_manifest_loader.d.ts +3 -3
- package/dist/_esm5.processed/transports/utils/generate_manifest_loader.js +18 -6
- package/dist/_esm5.processed/transports/utils/get_isobmff_timing_infos.d.ts +2 -2
- package/dist/_esm5.processed/transports/utils/get_isobmff_timing_infos.js +12 -11
- package/dist/_esm5.processed/transports/utils/infer_segment_container.d.ts +1 -1
- package/dist/_esm5.processed/transports/utils/infer_segment_container.js +1 -3
- package/dist/_esm5.processed/transports/utils/parse_text_track.d.ts +4 -4
- package/dist/_esm5.processed/transports/utils/parse_text_track.js +9 -6
- package/dist/_esm5.processed/utils/are_codecs_compatible.js +5 -1
- package/dist/_esm5.processed/utils/array_includes.js +2 -6
- package/dist/_esm5.processed/utils/assert.js +3 -4
- package/dist/_esm5.processed/utils/base64.js +87 -29
- package/dist/_esm5.processed/utils/byte_parsing.js +60 -56
- package/dist/_esm5.processed/utils/cancellable_sleep.d.ts +1 -1
- package/dist/_esm5.processed/utils/create_cancellable_promise.d.ts +1 -1
- package/dist/_esm5.processed/utils/deep_merge.js +4 -4
- package/dist/_esm5.processed/utils/event_emitter.d.ts +1 -1
- package/dist/_esm5.processed/utils/get_fuzzed_delay.js +1 -1
- package/dist/_esm5.processed/utils/hash_buffer.js +1 -1
- package/dist/_esm5.processed/utils/initialization_segment_cache.d.ts +2 -2
- package/dist/_esm5.processed/utils/languages/index.d.ts +4 -2
- package/dist/_esm5.processed/utils/languages/index.js +2 -2
- package/dist/_esm5.processed/utils/languages/normalize.d.ts +2 -1
- package/dist/_esm5.processed/utils/languages/normalize.js +5 -3
- package/dist/_esm5.processed/utils/logger.js +7 -14
- package/dist/_esm5.processed/utils/object_assign.js +5 -5
- package/dist/_esm5.processed/utils/object_values.d.ts +1 -1
- package/dist/_esm5.processed/utils/object_values.js +2 -3
- package/dist/_esm5.processed/utils/ranges.d.ts +2 -1
- package/dist/_esm5.processed/utils/ranges.js +19 -23
- package/dist/_esm5.processed/utils/reference.d.ts +3 -3
- package/dist/_esm5.processed/utils/reference.js +1 -3
- package/dist/_esm5.processed/utils/request/fetch.d.ts +1 -1
- package/dist/_esm5.processed/utils/request/fetch.js +34 -23
- package/dist/_esm5.processed/utils/request/index.d.ts +6 -3
- package/dist/_esm5.processed/utils/request/index.js +2 -2
- package/dist/_esm5.processed/utils/request/xhr.d.ts +1 -1
- package/dist/_esm5.processed/utils/request/xhr.js +28 -17
- package/dist/_esm5.processed/utils/retry_promise_with_backoff.d.ts +2 -2
- package/dist/_esm5.processed/utils/slice_uint8array.js +3 -3
- package/dist/_esm5.processed/utils/starts_with.js +3 -3
- package/dist/_esm5.processed/utils/string_parsing.js +16 -18
- package/dist/_esm5.processed/utils/task_canceller.js +1 -2
- package/dist/_esm5.processed/utils/uniq.d.ts +1 -1
- package/dist/_esm5.processed/utils/uniq.js +4 -3
- package/dist/_esm5.processed/utils/weak_map_memory.js +0 -1
- package/dist/_esm5.processed/utils/wrapInPromise.d.ts +1 -1
- package/dist/mpd-parser.wasm +0 -0
- package/dist/rx-player.js +345 -236
- package/dist/rx-player.min.js +1 -1
- package/experimental/features/index.d.ts-E +16 -0
- package/experimental/features/index.js-E +16 -0
- package/experimental/index.d.ts +1 -1
- package/experimental/index.d.ts-E +16 -0
- package/experimental/index.js +1 -1
- package/experimental/index.js-E +16 -0
- package/experimental/tools/VideoThumbnailLoader/index.d.ts-E +18 -0
- package/experimental/tools/VideoThumbnailLoader/index.js-E +18 -0
- package/experimental/tools/index.d.ts-E +16 -0
- package/experimental/tools/index.js-E +16 -0
- package/features/index.d.ts-E +16 -0
- package/features/index.js-E +16 -0
- package/logger/index.d.ts-E +17 -0
- package/logger/index.js-E +17 -0
- package/minimal/index.d.ts-E +17 -0
- package/minimal/index.js-E +17 -0
- package/package.json +29 -14
- package/tools/TextTrackRenderer.d.ts-E +18 -0
- package/tools/TextTrackRenderer.js-E +18 -0
- package/tools/index.d.ts-E +16 -0
- package/tools/index.js-E +16 -0
- package/tools/string-utils.d.ts-E +18 -0
- package/tools/string-utils.js-E +18 -0
- package/types/index.d.ts-E +16 -0
- package/types/index.js-E +15 -0
|
@@ -25,7 +25,7 @@ import config from "../../../config";
|
|
|
25
25
|
import log from "../../../log";
|
|
26
26
|
import objectAssign from "../../../utils/object_assign";
|
|
27
27
|
import SharedReference from "../../../utils/reference";
|
|
28
|
-
import TaskCanceller, { CancellationError
|
|
28
|
+
import TaskCanceller, { CancellationError } from "../../../utils/task_canceller";
|
|
29
29
|
import DownloadingQueue from "./utils/downloading_queue";
|
|
30
30
|
import getBufferStatus from "./utils/get_buffer_status";
|
|
31
31
|
import getSegmentPriority from "./utils/get_segment_priority";
|
|
@@ -116,7 +116,8 @@ export default function RepresentationStream(_a, callbacks, parentCancelSignal)
|
|
|
116
116
|
var encryptionData = representation.getEncryptionData(drmSystemId);
|
|
117
117
|
// If some key ids are not known yet, it may be safer to wait for this initialization
|
|
118
118
|
// segment to be loaded first
|
|
119
|
-
if (encryptionData.length > 0 &&
|
|
119
|
+
if (encryptionData.length > 0 &&
|
|
120
|
+
encryptionData.every(function (e) { return e.keyIds !== undefined; })) {
|
|
120
121
|
hasSentEncryptionData = true;
|
|
121
122
|
callbacks.encryptionDataEncountered(encryptionData.map(function (d) { return objectAssign({ content: content }, d); }));
|
|
122
123
|
if (globalCanceller.isUsed()) {
|
|
@@ -151,7 +152,8 @@ export default function RepresentationStream(_a, callbacks, parentCancelSignal)
|
|
|
151
152
|
}
|
|
152
153
|
});
|
|
153
154
|
downloadingQueue.addEventListener("fullyLoadedSegment", function (segment) {
|
|
154
|
-
segmentBuffer
|
|
155
|
+
segmentBuffer
|
|
156
|
+
.endOfSegment(objectAssign({ segment: segment }, content), globalCanceller.signal)
|
|
155
157
|
.catch(onFatalBufferError);
|
|
156
158
|
});
|
|
157
159
|
downloadingQueue.start();
|
|
@@ -204,21 +206,27 @@ export default function RepresentationStream(_a, callbacks, parentCancelSignal)
|
|
|
204
206
|
}
|
|
205
207
|
else {
|
|
206
208
|
var wantedStart = (_b = observation.position.pending) !== null && _b !== void 0 ? _b : observation.position.last;
|
|
207
|
-
neededInitSegment = {
|
|
208
|
-
|
|
209
|
+
neededInitSegment = {
|
|
210
|
+
segment: initSegmentState.segment,
|
|
211
|
+
priority: getSegmentPriority(period.start, wantedStart),
|
|
212
|
+
};
|
|
209
213
|
}
|
|
210
214
|
}
|
|
211
215
|
else if (neededSegments.length > 0 &&
|
|
212
216
|
!initSegmentState.isLoaded &&
|
|
213
217
|
initSegmentState.segment !== null) {
|
|
214
218
|
var initSegmentPriority = neededSegments[0].priority;
|
|
215
|
-
neededInitSegment = {
|
|
216
|
-
|
|
219
|
+
neededInitSegment = {
|
|
220
|
+
segment: initSegmentState.segment,
|
|
221
|
+
priority: initSegmentPriority,
|
|
222
|
+
};
|
|
217
223
|
}
|
|
218
224
|
var terminateVal = terminate.getValue();
|
|
219
225
|
if (terminateVal === null) {
|
|
220
|
-
lastSegmentQueue.setValue({
|
|
221
|
-
|
|
226
|
+
lastSegmentQueue.setValue({
|
|
227
|
+
initSegment: neededInitSegment,
|
|
228
|
+
segmentQueue: neededSegments,
|
|
229
|
+
});
|
|
222
230
|
}
|
|
223
231
|
else if (terminateVal.urgent) {
|
|
224
232
|
log.debug("Stream: Urgent switch, terminate now.", bufferType);
|
|
@@ -238,13 +246,11 @@ export default function RepresentationStream(_a, callbacks, parentCancelSignal)
|
|
|
238
246
|
var currentSegmentRequest = downloadingQueue.getRequestedMediaSegment();
|
|
239
247
|
var nextQueue = currentSegmentRequest === null ||
|
|
240
248
|
mostNeededSegment === undefined ||
|
|
241
|
-
currentSegmentRequest.id !== mostNeededSegment.segment.id
|
|
242
|
-
[]
|
|
243
|
-
[mostNeededSegment];
|
|
244
|
-
var nextInit = initSegmentRequest === null ? null :
|
|
245
|
-
|
|
246
|
-
lastSegmentQueue.setValue({ initSegment: nextInit,
|
|
247
|
-
segmentQueue: nextQueue });
|
|
249
|
+
currentSegmentRequest.id !== mostNeededSegment.segment.id
|
|
250
|
+
? []
|
|
251
|
+
: [mostNeededSegment];
|
|
252
|
+
var nextInit = initSegmentRequest === null ? null : neededInitSegment;
|
|
253
|
+
lastSegmentQueue.setValue({ initSegment: nextInit, segmentQueue: nextQueue });
|
|
248
254
|
if (nextQueue.length === 0 && nextInit === null) {
|
|
249
255
|
log.debug("Stream: No request left, terminate", bufferType);
|
|
250
256
|
lastSegmentQueue.finish();
|
|
@@ -253,10 +259,15 @@ export default function RepresentationStream(_a, callbacks, parentCancelSignal)
|
|
|
253
259
|
return;
|
|
254
260
|
}
|
|
255
261
|
}
|
|
256
|
-
callbacks.streamStatusUpdate({
|
|
262
|
+
callbacks.streamStatusUpdate({
|
|
263
|
+
period: period,
|
|
264
|
+
position: observation.position.last,
|
|
265
|
+
bufferType: bufferType,
|
|
266
|
+
imminentDiscontinuity: status.imminentDiscontinuity,
|
|
257
267
|
isEmptyStream: false,
|
|
258
268
|
hasFinishedLoading: status.hasFinishedLoading,
|
|
259
|
-
neededSegments: status.neededSegments
|
|
269
|
+
neededSegments: status.neededSegments,
|
|
270
|
+
});
|
|
260
271
|
if (segmentsLoadingCanceller.signal.isCancelled()) {
|
|
261
272
|
return; // previous callback has stopped loading operations by side-effect
|
|
262
273
|
}
|
|
@@ -264,7 +275,8 @@ export default function RepresentationStream(_a, callbacks, parentCancelSignal)
|
|
|
264
275
|
if (status.isBufferFull) {
|
|
265
276
|
var gcedPosition = Math.max(0, initialWantedTime - UPTO_CURRENT_POSITION_CLEANUP);
|
|
266
277
|
if (gcedPosition > 0) {
|
|
267
|
-
segmentBuffer
|
|
278
|
+
segmentBuffer
|
|
279
|
+
.removeBuffer(0, gcedPosition, globalCanceller.signal)
|
|
268
280
|
.catch(onFatalBufferError);
|
|
269
281
|
}
|
|
270
282
|
}
|
|
@@ -301,8 +313,14 @@ export default function RepresentationStream(_a, callbacks, parentCancelSignal)
|
|
|
301
313
|
var initSegmentUniqueId = representation.uniqueId;
|
|
302
314
|
initSegmentState.uniqueId = initSegmentUniqueId;
|
|
303
315
|
segmentBuffer.declareInitSegment(initSegmentUniqueId, evt.initializationData);
|
|
304
|
-
pushInitSegment({
|
|
305
|
-
|
|
316
|
+
pushInitSegment({
|
|
317
|
+
playbackObserver: playbackObserver,
|
|
318
|
+
content: content,
|
|
319
|
+
initSegmentUniqueId: initSegmentUniqueId,
|
|
320
|
+
segment: evt.segment,
|
|
321
|
+
segmentData: evt.initializationData,
|
|
322
|
+
segmentBuffer: segmentBuffer,
|
|
323
|
+
}, globalCanceller.signal)
|
|
306
324
|
.then(function (result) {
|
|
307
325
|
if (result !== null) {
|
|
308
326
|
callbacks.addedSegment(result);
|
|
@@ -340,8 +358,14 @@ export default function RepresentationStream(_a, callbacks, parentCancelSignal)
|
|
|
340
358
|
}
|
|
341
359
|
}
|
|
342
360
|
var initSegmentUniqueId = initSegmentState.uniqueId;
|
|
343
|
-
pushMediaSegment({
|
|
344
|
-
|
|
361
|
+
pushMediaSegment({
|
|
362
|
+
playbackObserver: playbackObserver,
|
|
363
|
+
content: content,
|
|
364
|
+
initSegmentUniqueId: initSegmentUniqueId,
|
|
365
|
+
parsedSegment: evt,
|
|
366
|
+
segment: evt.segment,
|
|
367
|
+
segmentBuffer: segmentBuffer,
|
|
368
|
+
}, globalCanceller.signal)
|
|
345
369
|
.then(function (result) {
|
|
346
370
|
if (result !== null) {
|
|
347
371
|
callbacks.addedSegment(result);
|
|
@@ -1,11 +1,12 @@
|
|
|
1
|
-
import
|
|
2
|
-
import
|
|
3
|
-
import {
|
|
4
|
-
import {
|
|
5
|
-
import {
|
|
6
|
-
import {
|
|
7
|
-
import {
|
|
8
|
-
import {
|
|
1
|
+
import type { Adaptation, ISegment, Period, Representation } from "../../../manifest";
|
|
2
|
+
import type Manifest from "../../../manifest";
|
|
3
|
+
import type { IEMSG } from "../../../parsers/containers/isobmff";
|
|
4
|
+
import type { IPlayerError } from "../../../public_types";
|
|
5
|
+
import type { IReadOnlySharedReference } from "../../../utils/reference";
|
|
6
|
+
import type { IReadOnlyPlaybackObserver } from "../../api";
|
|
7
|
+
import type { IContentProtection } from "../../decrypt";
|
|
8
|
+
import type { IPrioritizedSegmentFetcher } from "../../fetchers";
|
|
9
|
+
import type { IBufferType, SegmentBuffer } from "../../segment_buffers";
|
|
9
10
|
/** Callbacks called by the `RepresentationStream` on various events. */
|
|
10
11
|
export interface IRepresentationStreamCallbacks<TSegmentDataType> {
|
|
11
12
|
/**
|
|
@@ -13,10 +13,10 @@
|
|
|
13
13
|
* See the License for the specific language governing permissions and
|
|
14
14
|
* limitations under the License.
|
|
15
15
|
*/
|
|
16
|
-
import { CancellationSignal } from "../../../../utils/task_canceller";
|
|
17
|
-
import { IReadOnlyPlaybackObserver } from "../../../api";
|
|
18
|
-
import { IInsertedChunkInfos, IPushChunkInfos, SegmentBuffer } from "../../../segment_buffers";
|
|
19
|
-
import { IRepresentationStreamPlaybackObservation } from "../types";
|
|
16
|
+
import type { CancellationSignal } from "../../../../utils/task_canceller";
|
|
17
|
+
import type { IReadOnlyPlaybackObserver } from "../../../api";
|
|
18
|
+
import type { IInsertedChunkInfos, IPushChunkInfos, SegmentBuffer } from "../../../segment_buffers";
|
|
19
|
+
import type { IRepresentationStreamPlaybackObservation } from "../types";
|
|
20
20
|
/**
|
|
21
21
|
* Append a segment to the given segmentBuffer.
|
|
22
22
|
* If it leads to a QuotaExceededError, try to run our custom range
|
|
@@ -85,10 +85,12 @@ export default function appendSegmentToBuffer(playbackObserver, segmentBuffer, d
|
|
|
85
85
|
}
|
|
86
86
|
else if (!(appendError_1 instanceof Error) ||
|
|
87
87
|
appendError_1.name !== "QuotaExceededError") {
|
|
88
|
-
reason = appendError_1 instanceof Error
|
|
89
|
-
appendError_1.toString()
|
|
90
|
-
"An unknown error happened when pushing content";
|
|
91
|
-
throw new MediaError("BUFFER_APPEND_ERROR", reason, {
|
|
88
|
+
reason = appendError_1 instanceof Error
|
|
89
|
+
? appendError_1.toString()
|
|
90
|
+
: "An unknown error happened when pushing content";
|
|
91
|
+
throw new MediaError("BUFFER_APPEND_ERROR", reason, {
|
|
92
|
+
adaptation: dataInfos.inventoryInfos.adaptation,
|
|
93
|
+
});
|
|
92
94
|
}
|
|
93
95
|
position = playbackObserver.getReference().getValue().position;
|
|
94
96
|
currentPos = (_a = position.pending) !== null && _a !== void 0 ? _a : position.last;
|
|
@@ -110,9 +112,10 @@ export default function appendSegmentToBuffer(playbackObserver, segmentBuffer, d
|
|
|
110
112
|
return [3 /*break*/, 8];
|
|
111
113
|
case 7:
|
|
112
114
|
err2_1 = _b.sent();
|
|
113
|
-
reason = err2_1 instanceof Error ? err2_1.toString() :
|
|
114
|
-
|
|
115
|
-
|
|
115
|
+
reason = err2_1 instanceof Error ? err2_1.toString() : "Could not clean the buffer";
|
|
116
|
+
throw new MediaError("BUFFER_FULL_ERROR", reason, {
|
|
117
|
+
adaptation: dataInfos.inventoryInfos.adaptation,
|
|
118
|
+
});
|
|
116
119
|
case 8: return [3 /*break*/, 9];
|
|
117
120
|
case 9: return [2 /*return*/];
|
|
118
121
|
}
|
|
@@ -13,9 +13,10 @@
|
|
|
13
13
|
* See the License for the specific language governing permissions and
|
|
14
14
|
* limitations under the License.
|
|
15
15
|
*/
|
|
16
|
-
import
|
|
17
|
-
import
|
|
18
|
-
import {
|
|
16
|
+
import type { Adaptation, Period, Representation } from "../../../../manifest";
|
|
17
|
+
import type Manifest from "../../../../manifest";
|
|
18
|
+
import type { IBufferedChunk } from "../../../segment_buffers";
|
|
19
|
+
import type { IBufferDiscontinuity } from "../types";
|
|
19
20
|
/**
|
|
20
21
|
* Check if there is a soon-to-be-encountered discontinuity in the buffer that
|
|
21
22
|
* won't be filled by any future segment.
|
|
@@ -49,7 +49,8 @@ export default function checkForDiscontinuity(content, checkedRange, nextSegment
|
|
|
49
49
|
var nextBufferedInRangeIdx = getIndexOfFirstChunkInRange(bufferedSegments, checkedRange);
|
|
50
50
|
if (nextBufferedInRangeIdx === null) {
|
|
51
51
|
// There's no segment currently buffered for the current range.
|
|
52
|
-
if (nextSegmentStart === null) {
|
|
52
|
+
if (nextSegmentStart === null) {
|
|
53
|
+
// No segment to load in that range
|
|
53
54
|
// Check if we are in a discontinuity at the end of the current Period
|
|
54
55
|
if (hasFinishedLoading &&
|
|
55
56
|
period.end !== undefined &&
|
|
@@ -57,11 +58,9 @@ export default function checkForDiscontinuity(content, checkedRange, nextSegment
|
|
|
57
58
|
return { start: undefined, end: null }; // discontinuity to Period's end
|
|
58
59
|
}
|
|
59
60
|
// Check that there is a discontinuity announced in the Manifest there
|
|
60
|
-
var discontinuityEnd = representation.index
|
|
61
|
-
.checkDiscontinuity(checkedRange.start);
|
|
61
|
+
var discontinuityEnd = representation.index.checkDiscontinuity(checkedRange.start);
|
|
62
62
|
if (discontinuityEnd !== null) {
|
|
63
|
-
return { start: undefined,
|
|
64
|
-
end: discontinuityEnd };
|
|
63
|
+
return { start: undefined, end: discontinuityEnd };
|
|
65
64
|
}
|
|
66
65
|
}
|
|
67
66
|
return null;
|
|
@@ -77,12 +76,12 @@ export default function checkForDiscontinuity(content, checkedRange, nextSegment
|
|
|
77
76
|
nextBufferedSegment.infos.segment.end <= nextSegmentStart)) {
|
|
78
77
|
var discontinuityEnd = nextBufferedSegment.bufferedStart;
|
|
79
78
|
if (!hasFinishedLoading &&
|
|
80
|
-
representation.index.awaitSegmentBetween(checkedRange.start, discontinuityEnd) !==
|
|
79
|
+
representation.index.awaitSegmentBetween(checkedRange.start, discontinuityEnd) !==
|
|
80
|
+
false) {
|
|
81
81
|
return null;
|
|
82
82
|
}
|
|
83
83
|
log.debug("RS: current discontinuity encountered", adaptation.type, nextBufferedSegment.bufferedStart);
|
|
84
|
-
return { start: undefined,
|
|
85
|
-
end: discontinuityEnd };
|
|
84
|
+
return { start: undefined, end: discontinuityEnd };
|
|
86
85
|
}
|
|
87
86
|
// Check if there's a discontinuity BETWEEN segments of the current range
|
|
88
87
|
var nextHoleIdx = getIndexOfFirstDiscontinuityBetweenChunks(bufferedSegments, checkedRange, nextBufferedInRangeIdx + 1);
|
|
@@ -93,8 +92,8 @@ export default function checkForDiscontinuity(content, checkedRange, nextSegment
|
|
|
93
92
|
var segmentInfoAfterHole = bufferedSegments[nextHoleIdx];
|
|
94
93
|
if (nextSegmentStart === null ||
|
|
95
94
|
segmentInfoAfterHole.infos.segment.end <= nextSegmentStart) {
|
|
96
|
-
if (!hasFinishedLoading &&
|
|
97
|
-
.awaitSegmentBetween(segmentInfoBeforeHole.infos.segment.end, segmentInfoAfterHole.infos.segment.time) !== false) {
|
|
95
|
+
if (!hasFinishedLoading &&
|
|
96
|
+
representation.index.awaitSegmentBetween(segmentInfoBeforeHole.infos.segment.end, segmentInfoAfterHole.infos.segment.time) !== false) {
|
|
98
97
|
return null;
|
|
99
98
|
}
|
|
100
99
|
var start = segmentInfoBeforeHole.bufferedEnd;
|
|
@@ -106,8 +105,10 @@ export default function checkForDiscontinuity(content, checkedRange, nextSegment
|
|
|
106
105
|
if (nextSegmentStart === null) {
|
|
107
106
|
// If no hole between segments and no segment to load, check for a
|
|
108
107
|
// discontinuity at the end of the Period
|
|
109
|
-
if (hasFinishedLoading && period.end !== undefined) {
|
|
110
|
-
|
|
108
|
+
if (hasFinishedLoading && period.end !== undefined) {
|
|
109
|
+
// Period is finished
|
|
110
|
+
if (checkedRange.end < period.end) {
|
|
111
|
+
// We've not reached the Period's end yet
|
|
111
112
|
return null;
|
|
112
113
|
}
|
|
113
114
|
// Check if the last buffered segment ends before this Period's end
|
|
@@ -118,8 +119,7 @@ export default function checkForDiscontinuity(content, checkedRange, nextSegment
|
|
|
118
119
|
if (lastSegment.bufferedEnd !== undefined &&
|
|
119
120
|
lastSegment.bufferedEnd < period.end) {
|
|
120
121
|
log.debug("RS: discontinuity encountered at the end of the current period", adaptation.type, lastSegment.bufferedEnd, period.end);
|
|
121
|
-
return { start: lastSegment.bufferedEnd,
|
|
122
|
-
end: null };
|
|
122
|
+
return { start: lastSegment.bufferedEnd, end: null };
|
|
123
123
|
}
|
|
124
124
|
}
|
|
125
125
|
}
|
|
@@ -136,11 +136,9 @@ export default function checkForDiscontinuity(content, checkedRange, nextSegment
|
|
|
136
136
|
}
|
|
137
137
|
if (bufSeg.bufferedStart < checkedRange.end) {
|
|
138
138
|
if (bufSeg.bufferedEnd !== undefined && bufSeg.bufferedEnd < checkedRange.end) {
|
|
139
|
-
var discontinuityEnd = representation.index
|
|
140
|
-
.checkDiscontinuity(checkedRange.end);
|
|
139
|
+
var discontinuityEnd = representation.index.checkDiscontinuity(checkedRange.end);
|
|
141
140
|
if (discontinuityEnd !== null) {
|
|
142
|
-
return { start: bufSeg.bufferedEnd,
|
|
143
|
-
end: discontinuityEnd };
|
|
141
|
+
return { start: bufSeg.bufferedEnd, end: discontinuityEnd };
|
|
144
142
|
}
|
|
145
143
|
}
|
|
146
144
|
return null;
|
|
@@ -13,13 +13,14 @@
|
|
|
13
13
|
* See the License for the specific language governing permissions and
|
|
14
14
|
* limitations under the License.
|
|
15
15
|
*/
|
|
16
|
-
import
|
|
17
|
-
import
|
|
18
|
-
import {
|
|
16
|
+
import type { Adaptation, ISegment, Period, Representation } from "../../../../manifest";
|
|
17
|
+
import type Manifest from "../../../../manifest";
|
|
18
|
+
import type { IPlayerError } from "../../../../public_types";
|
|
19
|
+
import type { ISegmentParserParsedInitChunk, ISegmentParserParsedMediaChunk } from "../../../../transports";
|
|
19
20
|
import EventEmitter from "../../../../utils/event_emitter";
|
|
20
|
-
import { IReadOnlySharedReference } from "../../../../utils/reference";
|
|
21
|
-
import { IPrioritizedSegmentFetcher } from "../../../fetchers";
|
|
22
|
-
import { IQueuedSegment } from "../types";
|
|
21
|
+
import type { IReadOnlySharedReference } from "../../../../utils/reference";
|
|
22
|
+
import type { IPrioritizedSegmentFetcher } from "../../../fetchers";
|
|
23
|
+
import type { IQueuedSegment } from "../types";
|
|
23
24
|
/**
|
|
24
25
|
* Class scheduling segment downloads for a single Representation.
|
|
25
26
|
*
|
|
@@ -87,8 +87,7 @@ var DownloadingQueue = /** @class */ (function (_super) {
|
|
|
87
87
|
* @returns {Object | null}
|
|
88
88
|
*/
|
|
89
89
|
DownloadingQueue.prototype.getRequestedInitSegment = function () {
|
|
90
|
-
return this._initSegmentRequest === null ? null :
|
|
91
|
-
this._initSegmentRequest.segment;
|
|
90
|
+
return this._initSegmentRequest === null ? null : this._initSegmentRequest.segment;
|
|
92
91
|
};
|
|
93
92
|
/**
|
|
94
93
|
* Returns the media segment currently being requested.
|
|
@@ -96,8 +95,7 @@ var DownloadingQueue = /** @class */ (function (_super) {
|
|
|
96
95
|
* @returns {Object | null}
|
|
97
96
|
*/
|
|
98
97
|
DownloadingQueue.prototype.getRequestedMediaSegment = function () {
|
|
99
|
-
return this._mediaSegmentRequest === null ? null :
|
|
100
|
-
this._mediaSegmentRequest.segment;
|
|
98
|
+
return this._mediaSegmentRequest === null ? null : this._mediaSegmentRequest.segment;
|
|
101
99
|
};
|
|
102
100
|
/**
|
|
103
101
|
* Start the current downloading queue, emitting events as it loads and parses
|
|
@@ -195,9 +193,9 @@ var DownloadingQueue = /** @class */ (function (_super) {
|
|
|
195
193
|
return;
|
|
196
194
|
}
|
|
197
195
|
var canceller = new TaskCanceller();
|
|
198
|
-
var unlinkCanceller = _this._currentCanceller === null
|
|
199
|
-
noop
|
|
200
|
-
canceller.linkToSignal(_this._currentCanceller.signal);
|
|
196
|
+
var unlinkCanceller = _this._currentCanceller === null
|
|
197
|
+
? noop
|
|
198
|
+
: canceller.linkToSignal(_this._currentCanceller.signal);
|
|
201
199
|
var segment = startingSegment.segment, priority = startingSegment.priority;
|
|
202
200
|
var context = objectAssign({ segment: segment }, _this._content);
|
|
203
201
|
/**
|
|
@@ -296,7 +294,9 @@ var DownloadingQueue = /** @class */ (function (_super) {
|
|
|
296
294
|
unlinkCanceller();
|
|
297
295
|
_this._mediaSegmentRequest = null;
|
|
298
296
|
if (isWaitingOnInitSegment) {
|
|
299
|
-
_this._initSegmentInfoRef.waitUntilDefined(continueToNextSegment, {
|
|
297
|
+
_this._initSegmentInfoRef.waitUntilDefined(continueToNextSegment, {
|
|
298
|
+
clearSignal: canceller.signal,
|
|
299
|
+
});
|
|
300
300
|
}
|
|
301
301
|
else {
|
|
302
302
|
continueToNextSegment();
|
|
@@ -331,9 +331,9 @@ var DownloadingQueue = /** @class */ (function (_super) {
|
|
|
331
331
|
return;
|
|
332
332
|
}
|
|
333
333
|
var canceller = new TaskCanceller();
|
|
334
|
-
var unlinkCanceller = this._currentCanceller === null
|
|
335
|
-
noop
|
|
336
|
-
canceller.linkToSignal(this._currentCanceller.signal);
|
|
334
|
+
var unlinkCanceller = this._currentCanceller === null
|
|
335
|
+
? noop
|
|
336
|
+
: canceller.linkToSignal(this._currentCanceller.signal);
|
|
337
337
|
var segment = queuedInitSegment.segment, priority = queuedInitSegment.priority;
|
|
338
338
|
var context = objectAssign({ segment: segment }, this._content);
|
|
339
339
|
/**
|
|
@@ -13,8 +13,8 @@
|
|
|
13
13
|
* See the License for the specific language governing permissions and
|
|
14
14
|
* limitations under the License.
|
|
15
15
|
*/
|
|
16
|
-
import { CancellationSignal } from "../../../../utils/task_canceller";
|
|
17
|
-
import { SegmentBuffer } from "../../../segment_buffers";
|
|
16
|
+
import type { CancellationSignal } from "../../../../utils/task_canceller";
|
|
17
|
+
import type { SegmentBuffer } from "../../../segment_buffers";
|
|
18
18
|
/**
|
|
19
19
|
* Run the garbage collector.
|
|
20
20
|
*
|
|
@@ -82,8 +82,7 @@ export default function forceGarbageCollection(currentPosition, bufferingQueue,
|
|
|
82
82
|
log.debug("Stream: GC cleaning", cleanedupRanges.map(function (_a) {
|
|
83
83
|
var start = _a.start, end = _a.end;
|
|
84
84
|
return "start: ".concat(start, " - end ").concat(end);
|
|
85
|
-
})
|
|
86
|
-
.join(", "));
|
|
85
|
+
}).join(", "));
|
|
87
86
|
}
|
|
88
87
|
_i = 0, cleanedupRanges_1 = cleanedupRanges;
|
|
89
88
|
_a.label = 1;
|
|
@@ -124,26 +123,25 @@ function selectGCedRanges(position, buffered, gcGap) {
|
|
|
124
123
|
// current time and respect the gcGap
|
|
125
124
|
for (var i = 0; i < outerRanges.length; i++) {
|
|
126
125
|
var outerRange = outerRanges[i];
|
|
127
|
-
if (
|
|
126
|
+
if (position - gcGap > outerRange.end || position + gcGap < outerRange.start) {
|
|
128
127
|
cleanedupRanges.push(outerRange);
|
|
129
128
|
}
|
|
130
129
|
}
|
|
131
130
|
// try to clean up some space in the current range
|
|
132
131
|
if (innerRange !== null) {
|
|
133
132
|
if (log.hasLevel("DEBUG")) {
|
|
134
|
-
log.debug("Stream: GC removing part of inner range", cleanedupRanges
|
|
133
|
+
log.debug("Stream: GC removing part of inner range", cleanedupRanges
|
|
134
|
+
.map(function (_a) {
|
|
135
135
|
var start = _a.start, end = _a.end;
|
|
136
136
|
return "start: ".concat(start, " - end ").concat(end);
|
|
137
137
|
})
|
|
138
138
|
.join(", "));
|
|
139
139
|
}
|
|
140
140
|
if (position - gcGap > innerRange.start) {
|
|
141
|
-
cleanedupRanges.push({ start: innerRange.start,
|
|
142
|
-
end: position - gcGap });
|
|
141
|
+
cleanedupRanges.push({ start: innerRange.start, end: position - gcGap });
|
|
143
142
|
}
|
|
144
143
|
if (position + gcGap < innerRange.end) {
|
|
145
|
-
cleanedupRanges.push({ start: position + gcGap,
|
|
146
|
-
end: innerRange.end });
|
|
144
|
+
cleanedupRanges.push({ start: position + gcGap, end: innerRange.end });
|
|
147
145
|
}
|
|
148
146
|
}
|
|
149
147
|
return cleanedupRanges;
|
|
@@ -13,10 +13,11 @@
|
|
|
13
13
|
* See the License for the specific language governing permissions and
|
|
14
14
|
* limitations under the License.
|
|
15
15
|
*/
|
|
16
|
-
import
|
|
17
|
-
import
|
|
18
|
-
import {
|
|
19
|
-
import {
|
|
16
|
+
import type { Adaptation, Period, Representation } from "../../../../manifest";
|
|
17
|
+
import type Manifest from "../../../../manifest";
|
|
18
|
+
import type { IReadOnlyPlaybackObserver } from "../../../api";
|
|
19
|
+
import type { SegmentBuffer } from "../../../segment_buffers";
|
|
20
|
+
import type { IBufferDiscontinuity, IQueuedSegment } from "../types";
|
|
20
21
|
/** Analysis of the current buffer's status. */
|
|
21
22
|
export interface IBufferStatus {
|
|
22
23
|
/**
|
|
@@ -14,7 +14,7 @@
|
|
|
14
14
|
* limitations under the License.
|
|
15
15
|
*/
|
|
16
16
|
import isNullOrUndefined from "../../../../utils/is_null_or_undefined";
|
|
17
|
-
import SegmentBuffersStore, { SegmentBufferOperation
|
|
17
|
+
import SegmentBuffersStore, { SegmentBufferOperation } from "../../../segment_buffers";
|
|
18
18
|
import checkForDiscontinuity from "./check_for_discontinuity";
|
|
19
19
|
import getNeededSegments from "./get_needed_segments";
|
|
20
20
|
import getSegmentPriority from "./get_segment_priority";
|
|
@@ -37,27 +37,37 @@ import getSegmentPriority from "./get_segment_priority";
|
|
|
37
37
|
export default function getBufferStatus(content, initialWantedTime, playbackObserver, fastSwitchThreshold, bufferGoal, maxBufferSize, segmentBuffer) {
|
|
38
38
|
segmentBuffer.synchronizeInventory();
|
|
39
39
|
var representation = content.representation;
|
|
40
|
-
var askedStart = playbackObserver.getIsPaused() ||
|
|
41
|
-
|
|
42
|
-
initialWantedTime
|
|
43
|
-
initialWantedTime;
|
|
40
|
+
var askedStart = playbackObserver.getIsPaused() || playbackObserver.getPlaybackRate() <= 0
|
|
41
|
+
? initialWantedTime - 0.1
|
|
42
|
+
: initialWantedTime;
|
|
44
43
|
var neededRange = getRangeOfNeededSegments(content, askedStart, bufferGoal);
|
|
45
44
|
var shouldRefreshManifest = representation.index.shouldRefresh(neededRange.start, neededRange.end);
|
|
46
45
|
/**
|
|
47
46
|
* Every segment awaiting an "EndOfSegment" operation, which indicates that a
|
|
48
47
|
* completely-loaded segment is still being pushed to the SegmentBuffer.
|
|
49
48
|
*/
|
|
50
|
-
var segmentsBeingPushed = segmentBuffer
|
|
49
|
+
var segmentsBeingPushed = segmentBuffer
|
|
50
|
+
.getPendingOperations()
|
|
51
51
|
.filter(function (operation) {
|
|
52
52
|
return operation.type === SegmentBufferOperation.EndOfSegment;
|
|
53
|
-
})
|
|
53
|
+
})
|
|
54
|
+
.map(function (operation) { return operation.value; });
|
|
54
55
|
/** Data on every segments buffered around `neededRange`. */
|
|
55
56
|
var bufferedSegments = segmentBuffer.getInventory();
|
|
56
57
|
var currentPlaybackTime = playbackObserver.getCurrentTime();
|
|
57
58
|
/** Callback allowing to retrieve a segment's history in the buffer. */
|
|
58
59
|
var getBufferedHistory = segmentBuffer.getSegmentHistory.bind(segmentBuffer);
|
|
59
60
|
/** List of segments we will need to download. */
|
|
60
|
-
var _a = getNeededSegments({
|
|
61
|
+
var _a = getNeededSegments({
|
|
62
|
+
content: content,
|
|
63
|
+
bufferedSegments: bufferedSegments,
|
|
64
|
+
currentPlaybackTime: currentPlaybackTime,
|
|
65
|
+
fastSwitchThreshold: fastSwitchThreshold,
|
|
66
|
+
getBufferedHistory: getBufferedHistory,
|
|
67
|
+
neededRange: neededRange,
|
|
68
|
+
segmentsBeingPushed: segmentsBeingPushed,
|
|
69
|
+
maxBufferSize: maxBufferSize,
|
|
70
|
+
}), segmentsToLoad = _a.segmentsToLoad, segmentsOnHold = _a.segmentsOnHold, isBufferFull = _a.isBufferFull;
|
|
61
71
|
var prioritizedNeededSegments = segmentsToLoad.map(function (segment) { return ({
|
|
62
72
|
priority: getSegmentPriority(segment.time, askedStart),
|
|
63
73
|
segment: segment,
|
|
@@ -80,17 +90,25 @@ export default function getBufferStatus(content, initialWantedTime, playbackObse
|
|
|
80
90
|
nextSegmentStart = Math.min.apply(Math, segmentsBeingPushed.map(function (info) { return info.segment.time; }));
|
|
81
91
|
}
|
|
82
92
|
if (segmentsOnHold.length > 0) {
|
|
83
|
-
nextSegmentStart =
|
|
84
|
-
|
|
85
|
-
|
|
93
|
+
nextSegmentStart =
|
|
94
|
+
nextSegmentStart !== null
|
|
95
|
+
? Math.min(nextSegmentStart, segmentsOnHold[0].time)
|
|
96
|
+
: segmentsOnHold[0].time;
|
|
86
97
|
}
|
|
87
98
|
if (prioritizedNeededSegments.length > 0) {
|
|
88
|
-
nextSegmentStart =
|
|
89
|
-
|
|
90
|
-
|
|
99
|
+
nextSegmentStart =
|
|
100
|
+
nextSegmentStart !== null
|
|
101
|
+
? Math.min(nextSegmentStart, prioritizedNeededSegments[0].segment.time)
|
|
102
|
+
: prioritizedNeededSegments[0].segment.time;
|
|
91
103
|
}
|
|
92
104
|
var imminentDiscontinuity = checkForDiscontinuity(content, neededRange, nextSegmentStart, hasFinishedLoading, bufferedSegments);
|
|
93
|
-
return {
|
|
105
|
+
return {
|
|
106
|
+
imminentDiscontinuity: imminentDiscontinuity,
|
|
107
|
+
hasFinishedLoading: hasFinishedLoading,
|
|
108
|
+
neededSegments: prioritizedNeededSegments,
|
|
109
|
+
isBufferFull: isBufferFull,
|
|
110
|
+
shouldRefreshManifest: shouldRefreshManifest,
|
|
111
|
+
};
|
|
94
112
|
}
|
|
95
113
|
/**
|
|
96
114
|
* Returns both the time range of segments that should be loaded (from a
|
|
@@ -146,8 +164,11 @@ function getRangeOfNeededSegments(content, initialWantedTime, bufferGoal) {
|
|
|
146
164
|
// downloaded the last segments and have nothing left to do: full.
|
|
147
165
|
hasReachedPeriodEnd = wantedEndPosition >= lastIndexPosition;
|
|
148
166
|
}
|
|
149
|
-
return {
|
|
150
|
-
|
|
167
|
+
return {
|
|
168
|
+
start: Math.max(wantedStartPosition, period.start),
|
|
169
|
+
end: Math.min(wantedEndPosition, (_a = period.end) !== null && _a !== void 0 ? _a : Infinity),
|
|
170
|
+
hasReachedPeriodEnd: hasReachedPeriodEnd,
|
|
171
|
+
};
|
|
151
172
|
}
|
|
152
173
|
/**
|
|
153
174
|
* Returns `true` if the given Period is both:
|
|
@@ -162,7 +183,7 @@ function getRangeOfNeededSegments(content, initialWantedTime, bufferGoal) {
|
|
|
162
183
|
function isPeriodTheCurrentAndLastOne(manifest, period, time) {
|
|
163
184
|
var _a;
|
|
164
185
|
var nextPeriod = manifest.getPeriodAfter(period);
|
|
165
|
-
return period.containsTime(time, nextPeriod) &&
|
|
186
|
+
return (period.containsTime(time, nextPeriod) &&
|
|
166
187
|
manifest.isLastPeriodKnown &&
|
|
167
|
-
period.id === ((_a = manifest.periods[manifest.periods.length - 1]) === null || _a === void 0 ? void 0 : _a.id);
|
|
188
|
+
period.id === ((_a = manifest.periods[manifest.periods.length - 1]) === null || _a === void 0 ? void 0 : _a.id));
|
|
168
189
|
}
|
|
@@ -13,9 +13,10 @@
|
|
|
13
13
|
* See the License for the specific language governing permissions and
|
|
14
14
|
* limitations under the License.
|
|
15
15
|
*/
|
|
16
|
-
import
|
|
17
|
-
import
|
|
18
|
-
import {
|
|
16
|
+
import type { Adaptation, ISegment, Period, Representation } from "../../../../manifest";
|
|
17
|
+
import type Manifest from "../../../../manifest";
|
|
18
|
+
import type { IBufferedChunk, IEndOfSegmentInfos } from "../../../segment_buffers";
|
|
19
|
+
import type { IBufferedHistoryEntry, IChunkContext } from "../../../segment_buffers/inventory";
|
|
19
20
|
interface IContentContext {
|
|
20
21
|
adaptation: Adaptation;
|
|
21
22
|
manifest: Manifest;
|