From 1987678f3e12e42e72b026c08eafa15149233d82 Mon Sep 17 00:00:00 2001 From: litetex <40789489+litetex@users.noreply.github.com> Date: Fri, 24 Jun 2022 22:07:46 +0200 Subject: [PATCH] Code cleanup Updated javadoc Cleanup more code * Improve /Add java doc * Remove unused code * Convert TODOs to followup issues --- ...BandcampSearchStreamInfoItemExtractor.java | 2 +- .../MediaCCCLiveStreamExtractor.java | 28 +++++++++++++++++- .../MediaCCCLiveStreamMapperDTO.java | 29 ------------------- .../extractors/PeertubeStreamExtractor.java | 1 - .../extractors/SoundcloudStreamExtractor.java | 2 +- .../AbstractYoutubeDashManifestCreator.java | 13 ++++++++- .../extractors/YoutubeStreamExtractor.java | 16 +++++++++- .../format/registry/ItagFormatRegistry.java | 10 ++++++- .../services/youtube/itag/info/ItagInfo.java | 1 - .../DashManifestCreatorConstants.java | 2 +- .../SimpleDASHManifestDeliveryDataImpl.java | 11 ------- .../SimpleVideoAudioStreamImpl.java | 7 ----- .../schabi/newpipe/extractor/utils/Pair.java | 2 +- 13 files changed, 67 insertions(+), 57 deletions(-) delete mode 100644 extractor/src/main/java/org/schabi/newpipe/extractor/services/media_ccc/extractors/MediaCCCLiveStreamMapperDTO.java diff --git a/extractor/src/main/java/org/schabi/newpipe/extractor/services/bandcamp/extractors/streaminfoitem/BandcampSearchStreamInfoItemExtractor.java b/extractor/src/main/java/org/schabi/newpipe/extractor/services/bandcamp/extractors/streaminfoitem/BandcampSearchStreamInfoItemExtractor.java index ef384496fc..d1a55b33a1 100644 --- a/extractor/src/main/java/org/schabi/newpipe/extractor/services/bandcamp/extractors/streaminfoitem/BandcampSearchStreamInfoItemExtractor.java +++ b/extractor/src/main/java/org/schabi/newpipe/extractor/services/bandcamp/extractors/streaminfoitem/BandcampSearchStreamInfoItemExtractor.java @@ -22,7 +22,7 @@ public BandcampSearchStreamInfoItemExtractor(final Element searchResult, public String getUploaderName() { final String subhead = resultInfo.getElementsByClass("subhead").text(); final String[] splitBy = subhead.split("by "); - return splitBy.length > 1 ? splitBy[1] : splitBy[0]; + return splitBy[splitBy.length > 1 ? 1 : 0]; } @Nullable diff --git a/extractor/src/main/java/org/schabi/newpipe/extractor/services/media_ccc/extractors/MediaCCCLiveStreamExtractor.java b/extractor/src/main/java/org/schabi/newpipe/extractor/services/media_ccc/extractors/MediaCCCLiveStreamExtractor.java index 10a4fe9419..7322f75405 100644 --- a/extractor/src/main/java/org/schabi/newpipe/extractor/services/media_ccc/extractors/MediaCCCLiveStreamExtractor.java +++ b/extractor/src/main/java/org/schabi/newpipe/extractor/services/media_ccc/extractors/MediaCCCLiveStreamExtractor.java @@ -182,7 +182,6 @@ public List getVideoStreams() throws IOException, ExtractionEx dto.getStreamJsonObj().getArray("videoSize"); return new SimpleVideoAudioStreamImpl( - // TODO: This looks wrong new VideoAudioFormatRegistry() .getFromSuffixOrThrow(dto.getUrlKey()), buildDeliveryData(dto), @@ -234,4 +233,31 @@ public boolean isLive() { public String getCategory() { return group; } + + static final class MediaCCCLiveStreamMapperDTO { + private final JsonObject streamJsonObj; + private final String urlKey; + private final JsonObject urlValue; + + MediaCCCLiveStreamMapperDTO(final JsonObject streamJsonObj, + final String urlKey, + final JsonObject urlValue) { + this.streamJsonObj = streamJsonObj; + this.urlKey = urlKey; + this.urlValue = urlValue; + } + + JsonObject getStreamJsonObj() { + return streamJsonObj; + } + + String getUrlKey() { + return urlKey; + } + + JsonObject getUrlValue() { + return urlValue; + } + } + } diff --git a/extractor/src/main/java/org/schabi/newpipe/extractor/services/media_ccc/extractors/MediaCCCLiveStreamMapperDTO.java b/extractor/src/main/java/org/schabi/newpipe/extractor/services/media_ccc/extractors/MediaCCCLiveStreamMapperDTO.java deleted file mode 100644 index c06ef736bf..0000000000 --- a/extractor/src/main/java/org/schabi/newpipe/extractor/services/media_ccc/extractors/MediaCCCLiveStreamMapperDTO.java +++ /dev/null @@ -1,29 +0,0 @@ -package org.schabi.newpipe.extractor.services.media_ccc.extractors; - -import com.grack.nanojson.JsonObject; - -final class MediaCCCLiveStreamMapperDTO { - private final JsonObject streamJsonObj; - private final String urlKey; - private final JsonObject urlValue; - - MediaCCCLiveStreamMapperDTO(final JsonObject streamJsonObj, - final String urlKey, - final JsonObject urlValue) { - this.streamJsonObj = streamJsonObj; - this.urlKey = urlKey; - this.urlValue = urlValue; - } - - JsonObject getStreamJsonObj() { - return streamJsonObj; - } - - String getUrlKey() { - return urlKey; - } - - JsonObject getUrlValue() { - return urlValue; - } -} diff --git a/extractor/src/main/java/org/schabi/newpipe/extractor/services/peertube/extractors/PeertubeStreamExtractor.java b/extractor/src/main/java/org/schabi/newpipe/extractor/services/peertube/extractors/PeertubeStreamExtractor.java index 9905c754b5..6fb6b7dd1e 100644 --- a/extractor/src/main/java/org/schabi/newpipe/extractor/services/peertube/extractors/PeertubeStreamExtractor.java +++ b/extractor/src/main/java/org/schabi/newpipe/extractor/services/peertube/extractors/PeertubeStreamExtractor.java @@ -401,7 +401,6 @@ private void tryExtractSubtitles() { baseUrl + JsonUtils.getString(caption, "captionPath"); return new SimpleSubtitleStreamImpl( - // TODO: Check for null new SubtitleFormatRegistry() .getFromSuffixOrThrow( url.substring(url.lastIndexOf(".") + 1)), diff --git a/extractor/src/main/java/org/schabi/newpipe/extractor/services/soundcloud/extractors/SoundcloudStreamExtractor.java b/extractor/src/main/java/org/schabi/newpipe/extractor/services/soundcloud/extractors/SoundcloudStreamExtractor.java index 7f24425c57..c63cbed1d0 100644 --- a/extractor/src/main/java/org/schabi/newpipe/extractor/services/soundcloud/extractors/SoundcloudStreamExtractor.java +++ b/extractor/src/main/java/org/schabi/newpipe/extractor/services/soundcloud/extractors/SoundcloudStreamExtractor.java @@ -270,7 +270,7 @@ private List extractAudioStreams() { return null; } - return (AudioStream) new SimpleAudioStreamImpl( + return new SimpleAudioStreamImpl( mediaFormat, protocol.equals("hls") ? new SimpleHLSDeliveryDataImpl(mediaUrl) diff --git a/extractor/src/main/java/org/schabi/newpipe/extractor/services/youtube/dashmanifestcreator/AbstractYoutubeDashManifestCreator.java b/extractor/src/main/java/org/schabi/newpipe/extractor/services/youtube/dashmanifestcreator/AbstractYoutubeDashManifestCreator.java index a0bcb47155..f8c2cc9a2d 100644 --- a/extractor/src/main/java/org/schabi/newpipe/extractor/services/youtube/dashmanifestcreator/AbstractYoutubeDashManifestCreator.java +++ b/extractor/src/main/java/org/schabi/newpipe/extractor/services/youtube/dashmanifestcreator/AbstractYoutubeDashManifestCreator.java @@ -54,7 +54,18 @@ import javax.xml.transform.dom.DOMSource; import javax.xml.transform.stream.StreamResult; -// TODO: Doc +/** + * Abstract class for YouTube DASH manifest creation. + * + *

+ * This class includes common methods of manifest creators and useful constants. + *

+ * + *

+ * Generation of DASH documents and their conversion as a string is done using external classes + * from {@link org.w3c.dom} and {@link javax.xml} packages. + *

+ */ public abstract class AbstractYoutubeDashManifestCreator implements DashManifestCreator { /** diff --git a/extractor/src/main/java/org/schabi/newpipe/extractor/services/youtube/extractors/YoutubeStreamExtractor.java b/extractor/src/main/java/org/schabi/newpipe/extractor/services/youtube/extractors/YoutubeStreamExtractor.java index adafc92c0c..69dabd543f 100644 --- a/extractor/src/main/java/org/schabi/newpipe/extractor/services/youtube/extractors/YoutubeStreamExtractor.java +++ b/extractor/src/main/java/org/schabi/newpipe/extractor/services/youtube/extractors/YoutubeStreamExtractor.java @@ -614,7 +614,8 @@ public List getAudioStreams() throws ExtractionException { @Override public List getVideoStreams() throws ExtractionException { - return buildStrems(FORMATS, + return buildStrems( + FORMATS, ItagFormatRegistry.VIDEO_AUDIO_FORMATS, (itagInfo, deliveryData) -> new SimpleVideoAudioStreamImpl( itagInfo.getItagFormat().mediaFormat(), @@ -1199,6 +1200,19 @@ I extends ItagFormat> List buildStrems( } } + /* + * Note: We build the manifests for YT ourself because the provided ones (according to AudricV) + *
    + *
  • aren't working https://github.com/google/ExoPlayer/issues/2422#issuecomment-283080031 + *
  • + *
  • causes memory problems; TransactionTooLargeException: data parcel size 3174340
  • + *
  • are not always returned, only for videos with OTF streams, or on (ended or not) + * livestreams
  • + *
  • Instead of downloading a 10MB manifest when you can generate one which is 1 or 2MB + * large
  • + *
  • Also, this manifest isn't used at all by modern YouTube clients.
  • + *
+ */ @Nonnull private > DeliveryData buildDeliveryData(final ItagInfo itagInfo) { final ItagFormatDeliveryData iDeliveryData = itagInfo.getItagFormat().deliveryData(); diff --git a/extractor/src/main/java/org/schabi/newpipe/extractor/services/youtube/itag/format/registry/ItagFormatRegistry.java b/extractor/src/main/java/org/schabi/newpipe/extractor/services/youtube/itag/format/registry/ItagFormatRegistry.java index e69dc49887..030230ee0a 100644 --- a/extractor/src/main/java/org/schabi/newpipe/extractor/services/youtube/itag/format/registry/ItagFormatRegistry.java +++ b/extractor/src/main/java/org/schabi/newpipe/extractor/services/youtube/itag/format/registry/ItagFormatRegistry.java @@ -21,7 +21,15 @@ import java.util.stream.Stream; // CHECKSTYLE:OFF - Link is too long -// https://github.com/ytdl-org/youtube-dl/blob/9aa8e5340f3d5ece372b983f8e399277ca1f1fe4/youtube_dl/extractor/youtube.py#L1195 +/** + * A registry that contains all supported YouTube itags. + *

+ * For additional information you may also check: + *

    + *
  • https://github.com/ytdl-org/youtube-dl/blob/9aa8e5340f3d5ece372b983f8e399277ca1f1fe4/youtube_dl/extractor/youtube.py#L1195
  • + *
  • https://gist.github.com/AgentOak/34d47c65b1d28829bb17c24c04a0096f
  • + *
+ */ // CHECKSTYLE:ON public final class ItagFormatRegistry { diff --git a/extractor/src/main/java/org/schabi/newpipe/extractor/services/youtube/itag/info/ItagInfo.java b/extractor/src/main/java/org/schabi/newpipe/extractor/services/youtube/itag/info/ItagInfo.java index 5e8b7ed1a8..13c704d4cb 100644 --- a/extractor/src/main/java/org/schabi/newpipe/extractor/services/youtube/itag/info/ItagInfo.java +++ b/extractor/src/main/java/org/schabi/newpipe/extractor/services/youtube/itag/info/ItagInfo.java @@ -15,7 +15,6 @@ public class ItagInfo> { @Nonnull private final I itagFormat; - // TODO: Maybe generate the streamUrl on-demand and not always instantly? @Nonnull private final String streamUrl; diff --git a/extractor/src/main/java/org/schabi/newpipe/extractor/streamdata/delivery/dashmanifestcreator/DashManifestCreatorConstants.java b/extractor/src/main/java/org/schabi/newpipe/extractor/streamdata/delivery/dashmanifestcreator/DashManifestCreatorConstants.java index 10d74239c0..01c494dcc4 100644 --- a/extractor/src/main/java/org/schabi/newpipe/extractor/streamdata/delivery/dashmanifestcreator/DashManifestCreatorConstants.java +++ b/extractor/src/main/java/org/schabi/newpipe/extractor/streamdata/delivery/dashmanifestcreator/DashManifestCreatorConstants.java @@ -2,7 +2,7 @@ public final class DashManifestCreatorConstants { private DashManifestCreatorConstants() { - // No impl! + // No impl } // XML elements of DASH MPD manifests diff --git a/extractor/src/main/java/org/schabi/newpipe/extractor/streamdata/delivery/simpleimpl/SimpleDASHManifestDeliveryDataImpl.java b/extractor/src/main/java/org/schabi/newpipe/extractor/streamdata/delivery/simpleimpl/SimpleDASHManifestDeliveryDataImpl.java index d625016e63..a32e6b86d6 100644 --- a/extractor/src/main/java/org/schabi/newpipe/extractor/streamdata/delivery/simpleimpl/SimpleDASHManifestDeliveryDataImpl.java +++ b/extractor/src/main/java/org/schabi/newpipe/extractor/streamdata/delivery/simpleimpl/SimpleDASHManifestDeliveryDataImpl.java @@ -7,17 +7,6 @@ import javax.annotation.Nonnull; -/** - * Note we build the manifests for YT ourself because the provided ones (according to TiA4f8R) - *
    - *
  • aren't working https://github.com/google/ExoPlayer/issues/2422#issuecomment-283080031
  • - *
  • causes memory problems; TransactionTooLargeException: data parcel size 3174340
  • - *
  • are not always returned, only for videos with OTF streams, or on (ended or not) - * livestreams
  • - *
  • Instead of downloading a 10MB manifest when you can generate one which is 1 or 2MB large
  • - *
  • Also, this manifest isn't used at all by modern YouTube clients.
  • - *
- */ public class SimpleDASHManifestDeliveryDataImpl extends AbstractDeliveryDataImpl implements DASHManifestDeliveryData { @Nonnull diff --git a/extractor/src/main/java/org/schabi/newpipe/extractor/streamdata/stream/simpleimpl/SimpleVideoAudioStreamImpl.java b/extractor/src/main/java/org/schabi/newpipe/extractor/streamdata/stream/simpleimpl/SimpleVideoAudioStreamImpl.java index 6d0bc18298..68d03a090e 100644 --- a/extractor/src/main/java/org/schabi/newpipe/extractor/streamdata/stream/simpleimpl/SimpleVideoAudioStreamImpl.java +++ b/extractor/src/main/java/org/schabi/newpipe/extractor/streamdata/stream/simpleimpl/SimpleVideoAudioStreamImpl.java @@ -36,13 +36,6 @@ public SimpleVideoAudioStreamImpl( this(mediaFormat, deliveryData, videoQualityData, UNKNOWN_AVG_BITRATE); } - public SimpleVideoAudioStreamImpl( - @Nonnull final VideoAudioMediaFormat mediaFormat, - @Nonnull final DeliveryData deliveryData - ) { - this(mediaFormat, deliveryData, VideoQualityData.fromUnknown()); - } - @Nonnull @Override public VideoQualityData videoQualityData() { diff --git a/extractor/src/main/java/org/schabi/newpipe/extractor/utils/Pair.java b/extractor/src/main/java/org/schabi/newpipe/extractor/utils/Pair.java index 43da033ec5..943f9ddac2 100644 --- a/extractor/src/main/java/org/schabi/newpipe/extractor/utils/Pair.java +++ b/extractor/src/main/java/org/schabi/newpipe/extractor/utils/Pair.java @@ -3,7 +3,7 @@ import java.util.Objects; /** - * class to create a pair of objects. + * Class to create a pair of objects. * * *