Apply reviews: improve comments, remove FILE, remove Stream#equals(Stream)
This commit is contained in:
parent
07b045f20d
commit
50272db946
|
@ -210,7 +210,7 @@ public class MediaCCCLiveStreamExtractor extends StreamExtractor {
|
||||||
// Ensure that we use only process JsonObjects
|
// Ensure that we use only process JsonObjects
|
||||||
.filter(JsonObject.class::isInstance)
|
.filter(JsonObject.class::isInstance)
|
||||||
.map(JsonObject.class::cast)
|
.map(JsonObject.class::cast)
|
||||||
// Only process audio streams
|
// Only process streams of requested type
|
||||||
.filter(streamJsonObj -> streamType.equals(streamJsonObj.getString("type")))
|
.filter(streamJsonObj -> streamType.equals(streamJsonObj.getString("type")))
|
||||||
// Flatmap Urls and ensure that we use only process JsonObjects
|
// Flatmap Urls and ensure that we use only process JsonObjects
|
||||||
.flatMap(streamJsonObj -> streamJsonObj.getObject(URLS).entrySet().stream()
|
.flatMap(streamJsonObj -> streamJsonObj.getObject(URLS).entrySet().stream()
|
||||||
|
|
|
@ -147,8 +147,8 @@ public class MediaCCCStreamExtractor extends StreamExtractor {
|
||||||
mediaFormat = null;
|
mediaFormat = null;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Don't use the containsSimilarStream method because it will remove the
|
// Don't use the containsSimilarStream method because it will prevent the
|
||||||
// extraction of some video versions (mostly languages). So if there are multiple
|
// extraction of some video variations (mostly languages). So if there are multiple
|
||||||
// video streams available, only the first one will be extracted in this case.
|
// video streams available, only the first one will be extracted in this case.
|
||||||
videoStreams.add(new VideoStream.Builder()
|
videoStreams.add(new VideoStream.Builder()
|
||||||
.setId(recording.getString("filename", ID_UNKNOWN))
|
.setId(recording.getString("filename", ID_UNKNOWN))
|
||||||
|
|
|
@ -1264,8 +1264,8 @@ public final class YoutubeParsingHelper {
|
||||||
// Spoofing an Android 12 device with the hardcoded version of the Android app
|
// Spoofing an Android 12 device with the hardcoded version of the Android app
|
||||||
return "com.google.android.youtube/" + MOBILE_YOUTUBE_CLIENT_VERSION
|
return "com.google.android.youtube/" + MOBILE_YOUTUBE_CLIENT_VERSION
|
||||||
+ " (Linux; U; Android 12; "
|
+ " (Linux; U; Android 12; "
|
||||||
+ (localization != null ? localization.getCountryCode()
|
+ (localization == null ? Localization.DEFAULT.getCountryCode()
|
||||||
: Localization.DEFAULT.getCountryCode())
|
: localization.getCountryCode())
|
||||||
+ ") gzip";
|
+ ") gzip";
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -7,14 +7,13 @@ package org.schabi.newpipe.extractor.stream;
|
||||||
public enum DeliveryMethod {
|
public enum DeliveryMethod {
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Enum constant which represents the use of the progressive HTTP streaming method to fetch a
|
* Used for {@link Stream}s served using the progressive HTTP streaming method.
|
||||||
* {@link Stream stream}.
|
|
||||||
*/
|
*/
|
||||||
PROGRESSIVE_HTTP,
|
PROGRESSIVE_HTTP,
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Enum constant which represents the use of the DASH (Dynamic Adaptive Streaming over HTTP)
|
* Used for {@link Stream}s served using the DASH (Dynamic Adaptive Streaming over HTTP)
|
||||||
* adaptive streaming method to fetch a {@link Stream stream}.
|
* adaptive streaming method.
|
||||||
*
|
*
|
||||||
* @see <a href="https://en.wikipedia.org/wiki/Dynamic_Adaptive_Streaming_over_HTTP">the
|
* @see <a href="https://en.wikipedia.org/wiki/Dynamic_Adaptive_Streaming_over_HTTP">the
|
||||||
* Dynamic Adaptive Streaming over HTTP Wikipedia page</a> and <a href="https://dashif.org/">
|
* Dynamic Adaptive Streaming over HTTP Wikipedia page</a> and <a href="https://dashif.org/">
|
||||||
|
@ -23,8 +22,8 @@ public enum DeliveryMethod {
|
||||||
DASH,
|
DASH,
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Enum constant which represents the use of the HLS (HTTP Live Streaming) adaptive streaming
|
* Used for {@link Stream}s served using the HLS (HTTP Live Streaming) adaptive streaming
|
||||||
* method to fetch a {@link Stream stream}.
|
* method.
|
||||||
*
|
*
|
||||||
* @see <a href="https://en.wikipedia.org/wiki/HTTP_Live_Streaming">the HTTP Live Streaming
|
* @see <a href="https://en.wikipedia.org/wiki/HTTP_Live_Streaming">the HTTP Live Streaming
|
||||||
* page</a> and <a href="https://developer.apple.com/streaming">Apple's developers website page
|
* page</a> and <a href="https://developer.apple.com/streaming">Apple's developers website page
|
||||||
|
@ -33,8 +32,7 @@ public enum DeliveryMethod {
|
||||||
HLS,
|
HLS,
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Enum constant which represents the use of the SmoothStreaming adaptive streaming method to
|
* Used for {@link Stream}s served using the SmoothStreaming adaptive streaming method.
|
||||||
* fetch a {@link Stream stream}.
|
|
||||||
*
|
*
|
||||||
* @see <a href="https://en.wikipedia.org/wiki/Adaptive_bitrate_streaming
|
* @see <a href="https://en.wikipedia.org/wiki/Adaptive_bitrate_streaming
|
||||||
* #Microsoft_Smooth_Streaming_(MSS)">Wikipedia's page about adaptive bitrate streaming,
|
* #Microsoft_Smooth_Streaming_(MSS)">Wikipedia's page about adaptive bitrate streaming,
|
||||||
|
@ -44,7 +42,7 @@ public enum DeliveryMethod {
|
||||||
SS,
|
SS,
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Enum constant which represents the use of a torrent file to fetch a {@link Stream stream}.
|
* Used for {@link Stream}s served via a torrent file.
|
||||||
*
|
*
|
||||||
* @see <a href="https://en.wikipedia.org/wiki/BitTorrent">Wikipedia's BitTorrent's page</a>,
|
* @see <a href="https://en.wikipedia.org/wiki/BitTorrent">Wikipedia's BitTorrent's page</a>,
|
||||||
* <a href="https://en.wikipedia.org/wiki/Torrent_file">Wikipedia's page about torrent files
|
* <a href="https://en.wikipedia.org/wiki/Torrent_file">Wikipedia's page about torrent files
|
||||||
|
|
|
@ -115,19 +115,6 @@ public abstract class Stream implements Serializable {
|
||||||
: areUsingSameDeliveryMethodAndAreUrlStreams;
|
: areUsingSameDeliveryMethodAndAreUrlStreams;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* Reveals whether two streams are equal.
|
|
||||||
*
|
|
||||||
* @param cmp a {@link Stream} object to be compared to this {@link Stream} instance.
|
|
||||||
* @return whether the compared streams are equal
|
|
||||||
* @deprecated Use {@link #equalStats(Stream)} to compare statistics of two streams and
|
|
||||||
* {@link #equals(Object)} to compare the equality of two streams instead.
|
|
||||||
*/
|
|
||||||
@Deprecated
|
|
||||||
public boolean equals(final Stream cmp) {
|
|
||||||
return equalStats(cmp) && content.equals(cmp.content);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Gets the identifier of this stream, e.g. the itag for YouTube.
|
* Gets the identifier of this stream, e.g. the itag for YouTube.
|
||||||
*
|
*
|
||||||
|
|
|
@ -1,74 +1,52 @@
|
||||||
package org.schabi.newpipe.extractor.stream;
|
package org.schabi.newpipe.extractor.stream;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* An enum representing the stream types of stream contents returned by the extractor.
|
* An enum representing the stream type of a {@link StreamInfo} extracted by a {@link
|
||||||
|
* StreamExtractor}.
|
||||||
*/
|
*/
|
||||||
public enum StreamType {
|
public enum StreamType {
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Placeholder to check if the stream type of stream content was checked or not.
|
* Placeholder to check if the stream type was checked or not. It doesn't make sense to use this
|
||||||
*
|
* enum constant outside of the extractor as it will never be returned by an {@link
|
||||||
* <p>
|
* org.schabi.newpipe.extractor.Extractor} and is only used internally.
|
||||||
* It doesn't make sense to use this enum constant outside of the extractor as it will never be
|
|
||||||
* returned by an {@link org.schabi.newpipe.extractor.Extractor extractor} and is only used
|
|
||||||
* internally.
|
|
||||||
* </p>
|
|
||||||
*/
|
*/
|
||||||
NONE,
|
NONE,
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Enum constant to indicate that the stream type of stream content is a live video.
|
* A normal video stream, usually with audio. Note that the {@link StreamInfo} <strong>can also
|
||||||
*
|
* provide audio-only {@link AudioStream}s</strong> in addition to video or video-only {@link
|
||||||
* <p>
|
* VideoStream}s.
|
||||||
* Note that contents <strong>may contain audio streams</strong> even if they also contain
|
|
||||||
* video streams (video-only or video with audio, depending of the stream/the content/the
|
|
||||||
* service).
|
|
||||||
* </p>
|
|
||||||
*/
|
*/
|
||||||
VIDEO_STREAM,
|
VIDEO_STREAM,
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Enum constant to indicate that the stream type of stream content is an audio.
|
* An audio-only stream. There should be no {@link VideoStream}s available! In order to prevent
|
||||||
*
|
* unexpected behaviors, when {@link StreamExtractor}s return this stream type, they should
|
||||||
* <p>
|
* ensure that no video stream is returned in {@link StreamExtractor#getVideoStreams()} and
|
||||||
* Note that contents returned as audio streams should not return video streams.
|
* {@link StreamExtractor#getVideoOnlyStreams()}.
|
||||||
* </p>
|
|
||||||
*
|
|
||||||
* <p>
|
|
||||||
* So, in order to prevent unexpected behaviors, stream extractors which are returning this
|
|
||||||
* stream type for a content should ensure that no video stream is returned for this content.
|
|
||||||
* </p>
|
|
||||||
*/
|
*/
|
||||||
AUDIO_STREAM,
|
AUDIO_STREAM,
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Enum constant to indicate that the stream type of stream content is a video.
|
* A video live stream, usually with audio. Note that the {@link StreamInfo} <strong>can also
|
||||||
*
|
* provide audio-only {@link AudioStream}s</strong> in addition to video or video-only {@link
|
||||||
* <p>
|
* VideoStream}s.
|
||||||
* Note that contents <strong>can contain audio live streams</strong> even if they also contain
|
|
||||||
* live video streams (so video-only or video with audio, depending on the stream/the content/
|
|
||||||
* the service).
|
|
||||||
* </p>
|
|
||||||
*/
|
*/
|
||||||
LIVE_STREAM,
|
LIVE_STREAM,
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Enum constant to indicate that the stream type of stream content is a live audio.
|
* An audio-only live stream. There should be no {@link VideoStream}s available! In order to
|
||||||
*
|
* prevent unexpected behaviors, when {@link StreamExtractor}s return this stream type, they
|
||||||
* <p>
|
* should ensure that no video stream is returned in {@link StreamExtractor#getVideoStreams()}
|
||||||
* Note that contents returned as live audio streams should not return live video streams.
|
* and {@link StreamExtractor#getVideoOnlyStreams()}.
|
||||||
* </p>
|
|
||||||
*
|
|
||||||
* <p>
|
|
||||||
* To prevent unexpected behavior, stream extractors which are returning this stream type for a
|
|
||||||
* content should ensure that no live video stream is returned along with it.
|
|
||||||
* </p>
|
|
||||||
*/
|
*/
|
||||||
AUDIO_LIVE_STREAM,
|
AUDIO_LIVE_STREAM,
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Enum constant to indicate that the stream type of stream content is a video content of an
|
* A video live stream that has just ended but has not yet been encoded into a normal video
|
||||||
* ended live video stream.
|
* stream. Note that the {@link StreamInfo} <strong>can also provide audio-only {@link
|
||||||
|
* AudioStream}s</strong> in addition to video or video-only {@link VideoStream}s.
|
||||||
*
|
*
|
||||||
* <p>
|
* <p>
|
||||||
* Note that most of the content of an ended live video (or audio) may be extracted as {@link
|
* Note that most of the content of an ended live video (or audio) may be extracted as {@link
|
||||||
|
@ -76,39 +54,21 @@ public enum StreamType {
|
||||||
* later, because the service may encode them again later as normal video/audio streams. That's
|
* later, because the service may encode them again later as normal video/audio streams. That's
|
||||||
* the case on YouTube, for example.
|
* the case on YouTube, for example.
|
||||||
* </p>
|
* </p>
|
||||||
*
|
|
||||||
* <p>
|
|
||||||
* Note that contents <strong>can contain post-live audio streams</strong> even if they also
|
|
||||||
* contain post-live video streams (video-only or video with audio, depending of the stream/the
|
|
||||||
* content/the service).
|
|
||||||
* </p>
|
|
||||||
*/
|
*/
|
||||||
POST_LIVE_STREAM,
|
POST_LIVE_STREAM,
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Enum constant to indicate that the stream type of stream content is an audio content of an
|
* An audio live stream that has just ended but has not yet been encoded into a normal audio
|
||||||
* ended live audio stream.
|
* stream. There should be no {@link VideoStream}s available! In order to prevent unexpected
|
||||||
|
* behaviors, when {@link StreamExtractor}s return this stream type, they should ensure that no
|
||||||
|
* video stream is returned in {@link StreamExtractor#getVideoStreams()} and
|
||||||
|
* {@link StreamExtractor#getVideoOnlyStreams()}.
|
||||||
*
|
*
|
||||||
* <p>
|
* <p>
|
||||||
* Note that most of ended live audio streams extracted with this value are processed as
|
* Note that most of ended live audio streams extracted with this value are processed as
|
||||||
* {@link #AUDIO_STREAM regular audio streams} later, because the service may encode them
|
* {@link #AUDIO_STREAM regular audio streams} later, because the service may encode them
|
||||||
* again later.
|
* again later.
|
||||||
* </p>
|
* </p>
|
||||||
*
|
|
||||||
* <p>
|
|
||||||
* Contents returned as post-live audio streams should not return post-live video streams.
|
|
||||||
* </p>
|
|
||||||
*
|
|
||||||
* <p>
|
|
||||||
* So, in order to prevent unexpected behaviors, stream extractors which are returning this
|
|
||||||
* stream type for a content should ensure that no post-live video stream is returned for this
|
|
||||||
* content.
|
|
||||||
* </p>
|
|
||||||
*/
|
*/
|
||||||
POST_LIVE_AUDIO_STREAM,
|
POST_LIVE_AUDIO_STREAM
|
||||||
|
|
||||||
/**
|
|
||||||
* Enum constant to indicate that the stream type of stream content is a file.
|
|
||||||
*/
|
|
||||||
FILE
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -141,17 +141,13 @@ public final class ManifestCreatorCache<K extends Serializable, V extends Serial
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Returns the number of cached manifests in the cache.
|
* @return the number of cached manifests in the cache
|
||||||
*
|
|
||||||
* @return the number of cached manifests
|
|
||||||
*/
|
*/
|
||||||
public int size() {
|
public int size() {
|
||||||
return concurrentHashMap.size();
|
return concurrentHashMap.size();
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Gets the maximum size of the cache.
|
|
||||||
*
|
|
||||||
* @return the maximum size of the cache
|
* @return the maximum size of the cache
|
||||||
*/
|
*/
|
||||||
public long getMaximumSize() {
|
public long getMaximumSize() {
|
||||||
|
@ -188,9 +184,7 @@ public final class ManifestCreatorCache<K extends Serializable, V extends Serial
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Gets the current clear factor of the cache, used when the cache limit size is reached.
|
* @return the current clear factor of the cache, used when the cache limit size is reached
|
||||||
*
|
|
||||||
* @return the current clear factor of the cache
|
|
||||||
*/
|
*/
|
||||||
public double getClearFactor() {
|
public double getClearFactor() {
|
||||||
return clearFactor;
|
return clearFactor;
|
||||||
|
|
Loading…
Reference in New Issue