mirror of
https://github.com/libre-tube/LibreTube.git
synced 2024-12-13 13:50:30 +05:30
Merge pull request #6489 from Bnyro/master
refactor: cleanup DashHelper.kt
This commit is contained in:
commit
723faa5f1e
@ -7,7 +7,7 @@ import kotlin.io.path.Path
|
||||
|
||||
@Serializable
|
||||
data class PipedStream(
|
||||
val url: String? = null,
|
||||
var url: String? = null,
|
||||
val format: String? = null,
|
||||
val quality: String? = null,
|
||||
val mimeType: String? = null,
|
||||
|
@ -40,17 +40,25 @@ object DashHelper {
|
||||
|
||||
val adapSetInfos = ArrayList<AdapSetInfo>()
|
||||
|
||||
for (
|
||||
stream in streams.videoStreams
|
||||
for (stream in streams.videoStreams) {
|
||||
// used to avoid including LBRY HLS inside the streams in the manifest
|
||||
.filter { !it.format.orEmpty().contains("HLS") }
|
||||
.filter { supportsHdr || !it.quality.orEmpty().uppercase().contains("HDR") }
|
||||
) {
|
||||
if (stream.format.orEmpty().contains("HLS")) {
|
||||
continue
|
||||
}
|
||||
|
||||
// HDR is only supported by some new devices
|
||||
if (!supportsHdr && stream.quality.orEmpty().uppercase().contains("HDR")) {
|
||||
continue
|
||||
}
|
||||
|
||||
// ignore dual format and OTF streams
|
||||
if (!stream.videoOnly!! || stream.indexEnd!! <= 0) {
|
||||
continue
|
||||
}
|
||||
|
||||
// only unwraps the url if the preference is set in the settings
|
||||
stream.url = ProxyHelper.unwrapStreamUrl(stream.url.orEmpty())
|
||||
|
||||
val adapSetInfo = adapSetInfos.find { it.mimeType == stream.mimeType }
|
||||
if (adapSetInfo != null) {
|
||||
adapSetInfo.formats.add(stream)
|
||||
@ -73,6 +81,10 @@ object DashHelper {
|
||||
adapSetInfo.formats.add(stream)
|
||||
continue
|
||||
}
|
||||
|
||||
// only unwraps the url if the preference is set in the settings
|
||||
stream.url = ProxyHelper.unwrapStreamUrl(stream.url.orEmpty())
|
||||
|
||||
adapSetInfos.add(
|
||||
AdapSetInfo(
|
||||
stream.mimeType!!,
|
||||
|
Loading…
Reference in New Issue
Block a user