Skip to content

Commit

Permalink
Update documentation for the pillarbox-player module (#817)
Browse files Browse the repository at this point in the history
  • Loading branch information
MGaetan89 authored Nov 28, 2024
1 parent bd05b1d commit a987d49
Show file tree
Hide file tree
Showing 59 changed files with 838 additions and 600 deletions.
2 changes: 1 addition & 1 deletion docs/CONTINUOUS_INTEGRATION.md
Original file line number Diff line number Diff line change
Expand Up @@ -4,7 +4,7 @@ The project provides support for continuous integration with GitHub Actions.

## Code quality checks

Every time a Pull Request is made or something is pushed to the `main` branch, the [`build.yml`](https://github.com/SRGSSR/pillarbox-android/blob/main/.github/workflows/build.yml)
Every time a Pull Request is made or something is pushed to the `main` branch, the [`quality.yml`](https://github.com/SRGSSR/pillarbox-android/blob/main/.github/workflows/quality.yml)
workflow is triggered by GitHub Actions. It checks that the project builds on various platforms, runs code linters, dependencies check and finally
run tests. Result are posted directly in the Pull Request.

Expand Down
4 changes: 2 additions & 2 deletions docs/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -4,10 +4,10 @@

[![Last release](https://img.shields.io/github/v/release/SRGSSR/pillarbox-android?label=Release)](https://github.com/SRGSSR/pillarbox-android/releases)
[![Android min SDK](https://img.shields.io/badge/Android-21%2B-34A853)](https://github.com/SRGSSR/pillarbox-android)
[![Build status](https://img.shields.io/github/actions/workflow/status/SRGSSR/pillarbox-android/build.yml?label=Build)](https://github.com/SRGSSR/pillarbox-android/actions/workflows/build.yml)
[![Build status](https://img.shields.io/github/actions/workflow/status/SRGSSR/pillarbox-android/quality.yml?label=Build)](https://github.com/SRGSSR/pillarbox-android/actions/workflows/quality.yml)
[![License](https://img.shields.io/github/license/SRGSSR/pillarbox-android?label=License)](https://github.com/SRGSSR/pillarbox-android/blob/main/LICENSE)

Pillarbox is the modern SRG SSR multimedia player ecosystem, built on top of [AndroidX Media3](https://developer.android.com/media/media3).
Pillarbox is the modern SRG SSR multimedia player ecosystem, built on top of [AndroidX Media3](https://developer.android.com/media/media3).
Pillarbox has been designed with robustness, flexibility, and efficiency in mind, with full customization of:
- Metadata and asset URL retrieval.
- Asset resource loading, including support for Widevine and PlayReady.
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -9,9 +9,10 @@ import androidx.media3.exoplayer.upstream.BandwidthMeter
import androidx.media3.exoplayer.upstream.DefaultBandwidthMeter

/**
* Preconfigured [BandwidthMeter] for Pillarbox.
* Provides a pre-configured instance of [BandwidthMeter] suitable for use within Pillarbox.
*
* @param context The [Context] needed to create the [BandwidthMeter].
* @param context The [Context] required for initializing the [BandwidthMeter].
* @return A [BandwidthMeter] ready for use within Pillarbox.
*/
@Suppress("FunctionName")
fun PillarboxBandwidthMeter(context: Context): BandwidthMeter {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -36,13 +36,20 @@ import kotlin.time.Duration.Companion.ZERO
import kotlin.time.Duration.Companion.milliseconds

/**
* Marker for Pillarbox's DSL.
* Marks a class or function as part of the Pillarbox DSL (Domain Specific Language).
*
* This annotation serves as a marker for the Kotlin compiler, enabling DSL-specific features like type-safe builders and improved code completion.
* Applying this annotation to a class or function indicates that it's intended to be used within the context of the Pillarbox DSL.
*
* This annotation is primarily intended for internal use within the Pillarbox library.
*/
@DslMarker
annotation class PillarboxDsl

/**
* Builder to create a new instance of [PillarboxExoPlayer].
* A builder class for creating instances of [PillarboxExoPlayer].
*
* This builder provides a fluent API for configuring various aspects of the player, such as asset loaders, coroutine context, seek increments, ...
*/
@PillarboxDsl
@Suppress("TooManyFunctions")
Expand All @@ -61,16 +68,16 @@ abstract class PillarboxBuilder {
private var preloadConfiguration = ExoPlayer.PreloadConfiguration.DEFAULT

/**
* Add an [AssetLoader] to the [PillarboxExoPlayer].
* Registers a custom [AssetLoader] with the [PillarboxExoPlayer].
*
* @param assetLoader The [assetLoader] to add.
* @param assetLoader The [AssetLoader] to add.
*/
fun addAssetLoader(assetLoader: AssetLoader) {
assetLoaders.add(assetLoader)
}

/**
* Add an [AssetLoader] to the [PillarboxExoPlayer].
* Registers a custom [AssetLoader] with the [PillarboxExoPlayer].
*
* @receiver The [AssetLoader] to add.
*/
Expand All @@ -79,9 +86,11 @@ abstract class PillarboxBuilder {
}

/**
* Set the internal [Clock] used by the player.
* Sets the internal [Clock] used by the player.
*
* @param clock The internal clock used by the player.
* **Note:** this function is intended for internal use and should not be called by applications.
*
* @param clock The [Clock] instance to be used by the player.
*/
@VisibleForTesting
@RestrictTo(RestrictTo.Scope.LIBRARY_GROUP)
Expand All @@ -90,41 +99,41 @@ abstract class PillarboxBuilder {
}

/**
* Set the coroutine context used by the player.
* Sets the [CoroutineContext] used by the player.
*
* @param coroutineContext The coroutine context used by the player.
* @param coroutineContext The [CoroutineContext] to be used by the player.
*/
fun coroutineContext(coroutineContext: CoroutineContext) {
this.coroutineContext = coroutineContext
}

/**
* Set the load control used by the player.
* Sets the [LoadControl] used by the player.
*
* @param loadControl The load control used by the player.
* @param loadControl The [LoadControl] to be used by the player.
*/
fun loadControl(loadControl: LoadControl) {
this.loadControl = loadControl
}

/**
* Set the [Player.getMaxSeekToPreviousPosition] value.
* Sets the maximum duration the player can seek backward when using [Player.seekToPrevious].
*
* @param maxSeekToPreviousPosition The [Player.getMaxSeekToPreviousPosition] value.
* @param maxSeekToPreviousPosition The maximum duration to seek backward.
*/
fun maxSeekToPreviousPosition(maxSeekToPreviousPosition: Duration) {
this.maxSeekToPreviousPosition = maxSeekToPreviousPosition
}

/**
* Disable the monitoring for this player
* Disables the monitoring for this player.
*/
fun disableMonitoring() {
monitoring = NoOp()
}

/**
* Make the monitoring logs all events to Logcat, using the default config.
* Logs all monitoring events to Logcat.
*
* @param type [Logcat].
*/
Expand All @@ -135,11 +144,11 @@ abstract class PillarboxBuilder {
}

/**
* Make the monitoring sends all events to a remote server.
* Configures the monitoring to send all events to a remote server.
*
* @param endpointUrl The endpoint receiving monitoring messages.
* @param httpClient The [HttpClient] to use to send the events.
* @param coroutineScope The scope used to send the monitoring message.
* @param endpointUrl The URL of the endpoint responsible for receiving monitoring messages.
* @param httpClient The [HttpClient] instance used for transmitting events to the endpoint.
* @param coroutineScope The [CoroutineScope] which manages the coroutine responsible for sending monitoring messages.
*/
fun monitoring(
endpointUrl: String,
Expand All @@ -152,12 +161,12 @@ abstract class PillarboxBuilder {
}

/**
* Configure the monitoring for this player.
* Configures monitoring for this player.
*
* @param Config The type of the config to create.
* @param Factory The type of the [MonitoringMessageHandlerFactory].
* @param type The type of [MonitoringMessageHandler] to use.
* @param createConfig The configuration builder to create the [MonitoringMessageHandler].
* @param Config The type of the configuration object used to setup the monitoring handler.
* @param Factory The type of the [MonitoringMessageHandlerFactory] used to create the monitoring handler.
* @param type The type of [MonitoringMessageHandler] to create.
* @param createConfig A lambda that returns a configuration of type [Config].
*/
fun <Config, Factory : MonitoringMessageHandlerFactory<Config>> monitoring(
type: MonitoringMessageHandlerType<Config, Factory>,
Expand All @@ -167,48 +176,41 @@ abstract class PillarboxBuilder {
}

/**
* Set the [Looper] to use for playback.
* Sets the [Looper] used by the player.
*
* @param playbackLooper The [Looper] used for playback.
* @param playbackLooper The [Looper] to be used by the player.
*/
fun playbackLooper(playbackLooper: Looper) {
this.playbackLooper = playbackLooper
}

/**
* Set the seek back increment duration.
* Sets the duration by which the player seeks backward when performing a "seek backward" operation.
*
* @param seekBackwardIncrement The seek back increment duration.
* @param seekBackwardIncrement The duration to seek backward by.
*/
fun seekBackwardIncrement(seekBackwardIncrement: Duration) {
this.seekBackwardIncrement = seekBackwardIncrement
}

/**
* Set the seek forward increment duration.
* Sets the duration by which the player seeks forward when performing a "seek forward" action.
*
* @param seekForwardIncrement The seek forward increment duration.
* @param seekForwardIncrement The duration to seek forward by.
*/
fun seekForwardIncrement(seekForwardIncrement: Duration) {
this.seekForwardIncrement = seekForwardIncrement
}

/**
* Set the [ExoPlayer.PreloadConfiguration] used by the player.
* Sets the [ExoPlayer.PreloadConfiguration] used by the player.
*
* @param preloadConfiguration The [ExoPlayer.PreloadConfiguration].
* @param preloadConfiguration The [ExoPlayer.PreloadConfiguration] to be used by the player.
*/
fun preloadConfiguration(preloadConfiguration: ExoPlayer.PreloadConfiguration) {
this.preloadConfiguration = preloadConfiguration
}

/**
* Create a new instance of [PillarboxExoPlayer].
*
* @param context The [Context].
*
* @return A new instance of [PillarboxExoPlayer].
*/
internal fun create(context: Context): PillarboxExoPlayer {
return PillarboxExoPlayer(
context = context,
Expand All @@ -221,7 +223,9 @@ abstract class PillarboxBuilder {
}

/**
* Create a new instance of [ExoPlayer.Builder], used internally by [PillarboxExoPlayer].
* Creates the instance of [ExoPlayer.Builder], that will be used internally by [PillarboxExoPlayer].
*
* Subclasses can override this method to customize the [ExoPlayer.Builder] further, but they **MUST** ensure to call the super implementation.
*
* @param context The [Context].
*
Expand Down Expand Up @@ -256,27 +260,29 @@ abstract class PillarboxBuilder {
}

/**
* Factory used to create instances of [PillarboxBuilder].
* Defines a factory for creating instances of [PillarboxBuilder].
*
* @param Builder The type of [PillarboxBuilder] to create.
* @param Builder The type of [PillarboxBuilder] that this factory creates.
*/
interface PlayerConfig<Builder : PillarboxBuilder> {
/**
* Create a new instance of [Builder].
* Creates a new instance of the [Builder] class.
*
* @return A new instance of the [Builder].
*/
fun create(): Builder
}

/**
* Default implementation used to create simple [PillarboxExoPlayer].
* Default configuration for creating a [PillarboxExoPlayer], which closely matches an [ExoPlayer].
*/
object Default : PlayerConfig<Default.Builder> {
override fun create(): Builder {
return Builder()
}

/**
* Default implementation used to create simple [PillarboxExoPlayer].
* A builder class for creating and configuring a [PillarboxExoPlayer].
*/
class Builder : PillarboxBuilder() {
init {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -38,6 +38,14 @@ import kotlin.coroutines.CoroutineContext
/**
* Create a new instance of [PillarboxExoPlayer].
*
* **Usage**
* ```kotlin
* val player = PillarboxExoPlayer(context, Default) {
* addAssetLoader(MyAssetLoader())
* coroutineContext(Dispatchers.Main)
* }
* ```
*
* @param Builder The type of the [PillarboxBuilder].
* @param context The [Context].
* @param type The [PlayerConfig].
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -20,9 +20,9 @@ import kotlin.time.Duration.Companion.milliseconds
import kotlin.time.Duration.Companion.seconds

/**
* Pillarbox [LoadControl] implementation that optimize content loading.
* A [LoadControl] implementation tailored for Pillarbox, optimizing content loading.
*
* @param bufferDurations Buffer durations to set [DefaultLoadControl.Builder.setBufferDurationsMs].
* @param bufferDurations Buffer durations to customize the internal [DefaultLoadControl]'s behavior.
* @param allocator The [DefaultAllocator] to use in the internal [DefaultLoadControl].
*/
class PillarboxLoadControl(
Expand Down Expand Up @@ -91,14 +91,13 @@ class PillarboxLoadControl(
}

/**
* Buffer durations to use for [DefaultLoadControl.Builder.setBufferDurationsMs].
* Represents the buffer durations used by [DefaultLoadControl.Builder.setBufferDurationsMs].
*
* @property minBufferDuration The minimum duration of media that the player will attempt to ensure is buffered at all times.
* @property maxBufferDuration The maximum duration of media that the player will attempt to buffer.
* @property bufferForPlayback The duration of media that must be buffered for playback to start or resume following a user action such as a seek.
* @property bufferForPlaybackAfterRebuffer The default duration of media that must be buffered for playback to resume after a rebuffer.
* A rebuffer is defined to be caused by buffer depletion rather than a user action.
* @constructor Create empty Buffer durations
* @property bufferForPlaybackAfterRebuffer The duration of media that must be buffered for playback to resume after a rebuffer. A rebuffer is
* defined to be caused by buffer depletion rather than a user action.
*/
data class BufferDurations(
val minBufferDuration: Duration = DefaultLoadControl.DEFAULT_MIN_BUFFER_MS.milliseconds,
Expand Down
Loading

0 comments on commit a987d49

Please sign in to comment.