Apply reviews: improve comments, remove FILE, remove Stream#equals(Stream)

This commit is contained in:
Stypox 2022-04-30 19:45:37 +02:00 committed by TiA4f8R
parent 07b045f20d
commit 50272db946
No known key found for this signature in database
GPG Key ID: E6D3E7F5949450DD
7 changed files with 42 additions and 103 deletions

View File

@ -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()

View File

@ -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))

View File

@ -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";
} }

View File

@ -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

View File

@ -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.
* *

View File

@ -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
} }

View 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;