1
0
mirror of https://github.com/TeamNewPipe/NewPipe synced 2025-10-24 03:47:38 +00:00

renamed video classes to stream classes

This commit is contained in:
Christian Schabesberger
2016-02-27 16:37:15 +01:00
parent b1fe197c11
commit 045ca40a77
20 changed files with 190 additions and 189 deletions

View File

@@ -2,7 +2,7 @@ package org.schabi.newpipe.extractor.youtube;
import android.test.AndroidTestCase; import android.test.AndroidTestCase;
import org.schabi.newpipe.extractor.VideoPreviewInfo; import org.schabi.newpipe.extractor.StreamPreviewInfo;
import org.schabi.newpipe.extractor.SearchEngine; import org.schabi.newpipe.extractor.SearchEngine;
import org.schabi.newpipe.extractor.services.youtube.YoutubeSearchEngine; import org.schabi.newpipe.extractor.services.youtube.YoutubeSearchEngine;
import org.schabi.newpipe.Downloader; import org.schabi.newpipe.Downloader;
@@ -52,44 +52,44 @@ public class YoutubeSearchEngineTest extends AndroidTestCase {
} }
public void testItemsHaveTitle() { public void testItemsHaveTitle() {
for(VideoPreviewInfo i : result.resultList) { for(StreamPreviewInfo i : result.resultList) {
assertEquals(i.title.isEmpty(), false); assertEquals(i.title.isEmpty(), false);
} }
} }
public void testItemsHaveUploader() { public void testItemsHaveUploader() {
for(VideoPreviewInfo i : result.resultList) { for(StreamPreviewInfo i : result.resultList) {
assertEquals(i.uploader.isEmpty(), false); assertEquals(i.uploader.isEmpty(), false);
} }
} }
public void testItemsHaveRightDuration() { public void testItemsHaveRightDuration() {
for(VideoPreviewInfo i : result.resultList) { for(StreamPreviewInfo i : result.resultList) {
assertTrue(i.duration, i.duration.contains(":")); assertTrue(i.duration, i.duration.contains(":"));
} }
} }
public void testItemsHaveRightThumbnail() { public void testItemsHaveRightThumbnail() {
for (VideoPreviewInfo i : result.resultList) { for (StreamPreviewInfo i : result.resultList) {
assertTrue(i.thumbnail_url, i.thumbnail_url.contains("https://")); assertTrue(i.thumbnail_url, i.thumbnail_url.contains("https://"));
} }
} }
public void testItemsHaveRightVideoUrl() { public void testItemsHaveRightVideoUrl() {
for (VideoPreviewInfo i : result.resultList) { for (StreamPreviewInfo i : result.resultList) {
assertTrue(i.webpage_url, i.webpage_url.contains("https://")); assertTrue(i.webpage_url, i.webpage_url.contains("https://"));
} }
} }
public void testViewCount() { public void testViewCount() {
/* /*
for(VideoPreviewInfo i : result.resultList) { for(StreamPreviewInfo i : result.resultList) {
assertTrue(Long.toString(i.view_count), i.view_count != -1); assertTrue(Long.toString(i.view_count), i.view_count != -1);
} }
*/ */
// that specific link used for this test, there are no videos with less // that specific link used for this test, there are no videos with less
// than 10.000 views, so we can test against that. // than 10.000 views, so we can test against that.
for(VideoPreviewInfo i : result.resultList) { for(StreamPreviewInfo i : result.resultList) {
assertTrue(Long.toString(i.view_count), i.view_count >= 10000); assertTrue(Long.toString(i.view_count), i.view_count >= 10000);
} }
} }

View File

@@ -6,7 +6,7 @@ import org.schabi.newpipe.Downloader;
import org.schabi.newpipe.extractor.ExtractionException; import org.schabi.newpipe.extractor.ExtractionException;
import org.schabi.newpipe.extractor.ParsingException; import org.schabi.newpipe.extractor.ParsingException;
import org.schabi.newpipe.extractor.services.youtube.YoutubeStreamExtractor; import org.schabi.newpipe.extractor.services.youtube.YoutubeStreamExtractor;
import org.schabi.newpipe.extractor.VideoInfo; import org.schabi.newpipe.extractor.StreamInfo;
import java.io.IOException; import java.io.IOException;
@@ -94,7 +94,7 @@ public class YoutubeStreamExtractorDefaultTest extends AndroidTestCase {
} }
public void testGetVideoStreams() throws ParsingException { public void testGetVideoStreams() throws ParsingException {
for(VideoInfo.VideoStream s : extractor.getVideoStreams()) { for(StreamInfo.VideoStream s : extractor.getVideoStreams()) {
assertTrue(s.url, assertTrue(s.url,
s.url.contains("https://")); s.url.contains("https://"));
assertTrue(s.resolution.length() > 0); assertTrue(s.resolution.length() > 0);

View File

@@ -5,7 +5,7 @@ import android.test.AndroidTestCase;
import org.schabi.newpipe.Downloader; import org.schabi.newpipe.Downloader;
import org.schabi.newpipe.extractor.ExtractionException; import org.schabi.newpipe.extractor.ExtractionException;
import org.schabi.newpipe.extractor.ParsingException; import org.schabi.newpipe.extractor.ParsingException;
import org.schabi.newpipe.extractor.VideoInfo; import org.schabi.newpipe.extractor.StreamInfo;
import org.schabi.newpipe.extractor.services.youtube.YoutubeStreamExtractor; import org.schabi.newpipe.extractor.services.youtube.YoutubeStreamExtractor;
import java.io.IOException; import java.io.IOException;
@@ -73,7 +73,7 @@ public class YoutubeStreamExtractorRestrictedTest extends AndroidTestCase {
} }
public void testGetVideoStreams() throws ParsingException { public void testGetVideoStreams() throws ParsingException {
for(VideoInfo.VideoStream s : extractor.getVideoStreams()) { for(StreamInfo.VideoStream s : extractor.getVideoStreams()) {
assertTrue(s.url, assertTrue(s.url,
s.url.contains("https://")); s.url.contains("https://"));
assertTrue(s.resolution.length() > 0); assertTrue(s.resolution.length() > 0);

View File

@@ -12,7 +12,7 @@ import android.view.MenuItem;
import android.widget.ArrayAdapter; import android.widget.ArrayAdapter;
import org.schabi.newpipe.extractor.MediaFormat; import org.schabi.newpipe.extractor.MediaFormat;
import org.schabi.newpipe.extractor.VideoInfo; import org.schabi.newpipe.extractor.StreamInfo;
import java.util.List; import java.util.List;
@@ -75,7 +75,7 @@ class ActionBarHandler {
} }
} }
public void setupStreamList(final List<VideoInfo.VideoStream> videoStreams) { public void setupStreamList(final List<StreamInfo.VideoStream> videoStreams) {
if (activity != null) { if (activity != null) {
selectedVideoStream = 0; selectedVideoStream = 0;
@@ -83,7 +83,7 @@ class ActionBarHandler {
// this array will be shown in the dropdown menu for selecting the stream/resolution. // this array will be shown in the dropdown menu for selecting the stream/resolution.
String[] itemArray = new String[videoStreams.size()]; String[] itemArray = new String[videoStreams.size()];
for (int i = 0; i < videoStreams.size(); i++) { for (int i = 0; i < videoStreams.size(); i++) {
VideoInfo.VideoStream item = videoStreams.get(i); StreamInfo.VideoStream item = videoStreams.get(i);
itemArray[i] = MediaFormat.getNameById(item.format) + " " + item.resolution; itemArray[i] = MediaFormat.getNameById(item.format) + " " + item.resolution;
} }
int defaultResolution = getDefaultResolution(videoStreams); int defaultResolution = getDefaultResolution(videoStreams);
@@ -108,13 +108,13 @@ class ActionBarHandler {
} }
private int getDefaultResolution(final List<VideoInfo.VideoStream> videoStreams) { private int getDefaultResolution(final List<StreamInfo.VideoStream> videoStreams) {
String defaultResolution = defaultPreferences String defaultResolution = defaultPreferences
.getString(activity.getString(R.string.default_resolution_key), .getString(activity.getString(R.string.default_resolution_key),
activity.getString(R.string.default_resolution_value)); activity.getString(R.string.default_resolution_value));
for (int i = 0; i < videoStreams.size(); i++) { for (int i = 0; i < videoStreams.size(); i++) {
VideoInfo.VideoStream item = videoStreams.get(i); StreamInfo.VideoStream item = videoStreams.get(i);
if (defaultResolution.equals(item.resolution)) { if (defaultResolution.equals(item.resolution)) {
return i; return i;
} }

View File

@@ -7,7 +7,8 @@ import android.view.ViewGroup;
import android.widget.ImageView; import android.widget.ImageView;
import android.widget.TextView; import android.widget.TextView;
import org.schabi.newpipe.extractor.VideoPreviewInfo; import org.schabi.newpipe.extractor.StreamPreviewInfo;
import com.nostra13.universalimageloader.core.DisplayImageOptions; import com.nostra13.universalimageloader.core.DisplayImageOptions;
import com.nostra13.universalimageloader.core.ImageLoader; import com.nostra13.universalimageloader.core.ImageLoader;
@@ -40,7 +41,7 @@ class VideoInfoItemViewCreator {
this.inflater = inflater; this.inflater = inflater;
} }
public View getViewFromVideoInfoItem(View convertView, ViewGroup parent, VideoPreviewInfo info, Context context) { public View getViewFromVideoInfoItem(View convertView, ViewGroup parent, StreamPreviewInfo info, Context context) {
ViewHolder holder; ViewHolder holder;
if(convertView == null) { if(convertView == null) {
convertView = inflater.inflate(R.layout.video_item, parent, false); convertView = inflater.inflate(R.layout.video_item, parent, false);

View File

@@ -50,9 +50,9 @@ import org.schabi.newpipe.extractor.MediaFormat;
import org.schabi.newpipe.extractor.ParsingException; import org.schabi.newpipe.extractor.ParsingException;
import org.schabi.newpipe.extractor.ServiceList; import org.schabi.newpipe.extractor.ServiceList;
import org.schabi.newpipe.extractor.StreamExtractor; import org.schabi.newpipe.extractor.StreamExtractor;
import org.schabi.newpipe.extractor.VideoPreviewInfo; import org.schabi.newpipe.extractor.StreamInfo;
import org.schabi.newpipe.extractor.StreamPreviewInfo;
import org.schabi.newpipe.extractor.StreamingService; import org.schabi.newpipe.extractor.StreamingService;
import org.schabi.newpipe.extractor.VideoInfo;
import org.schabi.newpipe.extractor.services.youtube.YoutubeStreamExtractor; import org.schabi.newpipe.extractor.services.youtube.YoutubeStreamExtractor;
@@ -127,12 +127,12 @@ public class VideoItemDetailFragment extends Fragment {
@Override @Override
public void run() { public void run() {
VideoInfo videoInfo = null; StreamInfo streamInfo = null;
try { try {
streamExtractor = service.getExtractorInstance(videoUrl, new Downloader()); streamExtractor = service.getExtractorInstance(videoUrl, new Downloader());
videoInfo = VideoInfo.getVideoInfo(streamExtractor, new Downloader()); streamInfo = StreamInfo.getVideoInfo(streamExtractor, new Downloader());
h.post(new VideoResultReturnedRunnable(videoInfo)); h.post(new VideoResultReturnedRunnable(streamInfo));
} catch (IOException e) { } catch (IOException e) {
postNewErrorToast(h, R.string.network_error); postNewErrorToast(h, R.string.network_error);
e.printStackTrace(); e.printStackTrace();
@@ -165,14 +165,14 @@ public class VideoItemDetailFragment extends Fragment {
} }
}); });
e.printStackTrace(); e.printStackTrace();
} catch(VideoInfo.StreamExctractException e) { } catch(StreamInfo.StreamExctractException e) {
if(!videoInfo.errors.isEmpty()) { if(!streamInfo.errors.isEmpty()) {
// !!! if this case ever kicks in someone gets kicked out !!! // !!! if this case ever kicks in someone gets kicked out !!!
ErrorActivity.reportError(h, getActivity(), e, VideoItemListActivity.class, null, ErrorActivity.reportError(h, getActivity(), e, VideoItemListActivity.class, null,
ErrorActivity.ErrorInfo.make(ErrorActivity.REQUESTED_STREAM, ErrorActivity.ErrorInfo.make(ErrorActivity.REQUESTED_STREAM,
service.getServiceInfo().name, videoUrl, R.string.could_not_get_stream)); service.getServiceInfo().name, videoUrl, R.string.could_not_get_stream));
} else { } else {
ErrorActivity.reportError(h, getActivity(), videoInfo.errors, VideoItemListActivity.class, null, ErrorActivity.reportError(h, getActivity(), streamInfo.errors, VideoItemListActivity.class, null,
ErrorActivity.ErrorInfo.make(ErrorActivity.REQUESTED_STREAM, ErrorActivity.ErrorInfo.make(ErrorActivity.REQUESTED_STREAM,
service.getServiceInfo().name, videoUrl, R.string.could_not_get_stream)); service.getServiceInfo().name, videoUrl, R.string.could_not_get_stream));
} }
@@ -206,17 +206,17 @@ public class VideoItemDetailFragment extends Fragment {
}); });
e.printStackTrace(); e.printStackTrace();
} finally { } finally {
if(videoInfo != null && if(streamInfo != null &&
!videoInfo.errors.isEmpty()) { !streamInfo.errors.isEmpty()) {
Log.e(TAG, "OCCURRED ERRORS DURING EXTRACTION:"); Log.e(TAG, "OCCURRED ERRORS DURING EXTRACTION:");
for(Exception e : videoInfo.errors) { for(Exception e : streamInfo.errors) {
e.printStackTrace(); e.printStackTrace();
} }
Activity a = getActivity(); Activity a = getActivity();
View rootView = a != null ? a.findViewById(R.id.videoitem_detail) : null; View rootView = a != null ? a.findViewById(R.id.videoitem_detail) : null;
ErrorActivity.reportError(h, getActivity(), ErrorActivity.reportError(h, getActivity(),
videoInfo.errors, null, rootView, streamInfo.errors, null, rootView,
ErrorActivity.ErrorInfo.make(ErrorActivity.REQUESTED_STREAM, ErrorActivity.ErrorInfo.make(ErrorActivity.REQUESTED_STREAM,
service.getServiceInfo().name, videoUrl, 0 /* no message for the user */)); service.getServiceInfo().name, videoUrl, 0 /* no message for the user */));
} }
@@ -225,16 +225,16 @@ public class VideoItemDetailFragment extends Fragment {
} }
private class VideoResultReturnedRunnable implements Runnable { private class VideoResultReturnedRunnable implements Runnable {
private final VideoInfo videoInfo; private final StreamInfo streamInfo;
public VideoResultReturnedRunnable(VideoInfo videoInfo) { public VideoResultReturnedRunnable(StreamInfo streamInfo) {
this.videoInfo = videoInfo; this.streamInfo = streamInfo;
} }
@Override @Override
public void run() { public void run() {
boolean show_age_restricted_content = PreferenceManager.getDefaultSharedPreferences(getActivity()) boolean show_age_restricted_content = PreferenceManager.getDefaultSharedPreferences(getActivity())
.getBoolean(activity.getString(R.string.show_age_restricted_content), false); .getBoolean(activity.getString(R.string.show_age_restricted_content), false);
if(videoInfo.age_limit == 0 || show_age_restricted_content) { if(streamInfo.age_limit == 0 || show_age_restricted_content) {
updateInfo(videoInfo); updateInfo(streamInfo);
} else { } else {
onNotSpecifiedContentErrorWithMessage(R.string.video_is_age_restricted); onNotSpecifiedContentErrorWithMessage(R.string.video_is_age_restricted);
} }
@@ -261,7 +261,7 @@ public class VideoItemDetailFragment extends Fragment {
public void onLoadingCancelled(String imageUri, View view) {} public void onLoadingCancelled(String imageUri, View view) {}
} }
private void updateInfo(final VideoInfo info) { private void updateInfo(final StreamInfo info) {
try { try {
Context c = getContext(); Context c = getContext();
VideoInfoItemViewCreator videoItemViewCreator = VideoInfoItemViewCreator videoItemViewCreator =
@@ -378,8 +378,8 @@ public class VideoItemDetailFragment extends Fragment {
descriptionView.setMovementMethod(LinkMovementMethod.getInstance()); descriptionView.setMovementMethod(LinkMovementMethod.getInstance());
// parse streams // parse streams
Vector<VideoInfo.VideoStream> streamsToUse = new Vector<>(); Vector<StreamInfo.VideoStream> streamsToUse = new Vector<>();
for (VideoInfo.VideoStream i : info.video_streams) { for (StreamInfo.VideoStream i : info.video_streams) {
if (useStream(i, streamsToUse)) { if (useStream(i, streamsToUse)) {
streamsToUse.add(i); streamsToUse.add(i);
} }
@@ -435,7 +435,7 @@ public class VideoItemDetailFragment extends Fragment {
} }
} }
private void initThumbnailViews(VideoInfo info, View nextVideoFrame) { private void initThumbnailViews(StreamInfo info, View nextVideoFrame) {
ImageView videoThumbnailView = (ImageView) activity.findViewById(R.id.detailThumbnailView); ImageView videoThumbnailView = (ImageView) activity.findViewById(R.id.detailThumbnailView);
ImageView uploaderThumb ImageView uploaderThumb
= (ImageView) activity.findViewById(R.id.detailUploaderThumbnailView); = (ImageView) activity.findViewById(R.id.detailUploaderThumbnailView);
@@ -478,7 +478,7 @@ public class VideoItemDetailFragment extends Fragment {
} }
} }
private void setupActionBarHandler(final VideoInfo info) { private void setupActionBarHandler(final StreamInfo info) {
actionBarHandler.setupStreamList(info.video_streams); actionBarHandler.setupStreamList(info.video_streams);
actionBarHandler.setOnShareListener(new ActionBarHandler.OnActionListener() { actionBarHandler.setOnShareListener(new ActionBarHandler.OnActionListener() {
@@ -545,7 +545,7 @@ public class VideoItemDetailFragment extends Fragment {
// website which was crawled. Then the ui has to understand this and act right. // website which was crawled. Then the ui has to understand this and act right.
if (info.audio_streams != null) { if (info.audio_streams != null) {
VideoInfo.AudioStream audioStream = StreamInfo.AudioStream audioStream =
info.audio_streams.get(getPreferredAudioStreamId(info)); info.audio_streams.get(getPreferredAudioStreamId(info));
String audioSuffix = "." + MediaFormat.getSuffixById(audioStream.format); String audioSuffix = "." + MediaFormat.getSuffixById(audioStream.format);
@@ -554,7 +554,7 @@ public class VideoItemDetailFragment extends Fragment {
} }
if (info.video_streams != null) { if (info.video_streams != null) {
VideoInfo.VideoStream selectedStreamItem = info.video_streams.get(selectedStreamId); StreamInfo.VideoStream selectedStreamItem = info.video_streams.get(selectedStreamId);
String videoSuffix = "." + MediaFormat.getSuffixById(selectedStreamItem.format); String videoSuffix = "." + MediaFormat.getSuffixById(selectedStreamItem.format);
args.putString(DownloadDialog.FILE_SUFFIX_VIDEO, videoSuffix); args.putString(DownloadDialog.FILE_SUFFIX_VIDEO, videoSuffix);
args.putString(DownloadDialog.VIDEO_URL, selectedStreamItem.url); args.putString(DownloadDialog.VIDEO_URL, selectedStreamItem.url);
@@ -581,7 +581,7 @@ public class VideoItemDetailFragment extends Fragment {
boolean useExternalAudioPlayer = PreferenceManager.getDefaultSharedPreferences(activity) boolean useExternalAudioPlayer = PreferenceManager.getDefaultSharedPreferences(activity)
.getBoolean(activity.getString(R.string.use_external_audio_player_key), false); .getBoolean(activity.getString(R.string.use_external_audio_player_key), false);
Intent intent; Intent intent;
VideoInfo.AudioStream audioStream = StreamInfo.AudioStream audioStream =
info.audio_streams.get(getPreferredAudioStreamId(info)); info.audio_streams.get(getPreferredAudioStreamId(info));
if (!useExternalAudioPlayer && android.os.Build.VERSION.SDK_INT >= 18) { if (!useExternalAudioPlayer && android.os.Build.VERSION.SDK_INT >= 18) {
//internal music player: explicit intent //internal music player: explicit intent
@@ -640,7 +640,7 @@ public class VideoItemDetailFragment extends Fragment {
} }
} }
private int getPreferredAudioStreamId(final VideoInfo info) { private int getPreferredAudioStreamId(final StreamInfo info) {
String preferredFormatString = PreferenceManager.getDefaultSharedPreferences(getActivity()) String preferredFormatString = PreferenceManager.getDefaultSharedPreferences(getActivity())
.getString(activity.getString(R.string.default_audio_format_key), "webm"); .getString(activity.getString(R.string.default_audio_format_key), "webm");
@@ -667,10 +667,10 @@ public class VideoItemDetailFragment extends Fragment {
return 0; return 0;
} }
private void initSimilarVideos(final VideoInfo info, VideoInfoItemViewCreator videoItemViewCreator) { private void initSimilarVideos(final StreamInfo info, VideoInfoItemViewCreator videoItemViewCreator) {
LinearLayout similarLayout = (LinearLayout) activity.findViewById(R.id.similarVideosView); LinearLayout similarLayout = (LinearLayout) activity.findViewById(R.id.similarVideosView);
ArrayList<VideoPreviewInfo> similar = new ArrayList<>(info.related_videos); ArrayList<StreamPreviewInfo> similar = new ArrayList<>(info.related_videos);
for (final VideoPreviewInfo item : similar) { for (final StreamPreviewInfo item : similar) {
View similarView = videoItemViewCreator View similarView = videoItemViewCreator
.getViewFromVideoInfoItem(null, similarLayout, item, getContext()); .getViewFromVideoInfoItem(null, similarLayout, item, getContext());
@@ -744,8 +744,8 @@ public class VideoItemDetailFragment extends Fragment {
.show(); .show();
} }
private boolean useStream(VideoInfo.VideoStream stream, Vector<VideoInfo.VideoStream> streams) { private boolean useStream(StreamInfo.VideoStream stream, Vector<StreamInfo.VideoStream> streams) {
for(VideoInfo.VideoStream i : streams) { for(StreamInfo.VideoStream i : streams) {
if(i.resolution.equals(stream.resolution)) { if(i.resolution.equals(stream.resolution)) {
return false; return false;
} }
@@ -835,9 +835,9 @@ public class VideoItemDetailFragment extends Fragment {
} }
} }
public void playVideo(final VideoInfo info) { public void playVideo(final StreamInfo info) {
// ----------- THE MAGIC MOMENT --------------- // ----------- THE MAGIC MOMENT ---------------
VideoInfo.VideoStream selectedVideoStream = StreamInfo.VideoStream selectedVideoStream =
info.video_streams.get(actionBarHandler.getSelectedVideoStream()); info.video_streams.get(actionBarHandler.getSelectedVideoStream());
if (PreferenceManager.getDefaultSharedPreferences(activity) if (PreferenceManager.getDefaultSharedPreferences(activity)

View File

@@ -17,7 +17,7 @@ import java.io.IOException;
import java.util.List; import java.util.List;
import org.schabi.newpipe.extractor.ExtractionException; import org.schabi.newpipe.extractor.ExtractionException;
import org.schabi.newpipe.extractor.VideoPreviewInfo; import org.schabi.newpipe.extractor.StreamPreviewInfo;
import org.schabi.newpipe.extractor.SearchEngine; import org.schabi.newpipe.extractor.SearchEngine;
import org.schabi.newpipe.extractor.StreamingService; import org.schabi.newpipe.extractor.StreamingService;
@@ -125,7 +125,7 @@ public class VideoItemListFragment extends ListFragment {
} }
} }
public void present(List<VideoPreviewInfo> videoList) { public void present(List<StreamPreviewInfo> videoList) {
mode = PRESENT_VIDEOS_MODE; mode = PRESENT_VIDEOS_MODE;
setListShown(true); setListShown(true);
getListView().smoothScrollToPosition(0); getListView().smoothScrollToPosition(0);
@@ -180,7 +180,7 @@ public class VideoItemListFragment extends ListFragment {
} }
} }
private void updateList(List<VideoPreviewInfo> list) { private void updateList(List<StreamPreviewInfo> list) {
try { try {
videoListAdapter.addVideoList(list); videoListAdapter.addVideoList(list);
terminateThreads(); terminateThreads();

View File

@@ -8,7 +8,7 @@ import android.view.ViewGroup;
import android.widget.BaseAdapter; import android.widget.BaseAdapter;
import android.widget.ListView; import android.widget.ListView;
import org.schabi.newpipe.extractor.VideoPreviewInfo; import org.schabi.newpipe.extractor.StreamPreviewInfo;
import java.util.List; import java.util.List;
import java.util.Vector; import java.util.Vector;
@@ -36,7 +36,7 @@ import java.util.Vector;
class VideoListAdapter extends BaseAdapter { class VideoListAdapter extends BaseAdapter {
private final Context context; private final Context context;
private final VideoInfoItemViewCreator viewCreator; private final VideoInfoItemViewCreator viewCreator;
private Vector<VideoPreviewInfo> videoList = new Vector<>(); private Vector<StreamPreviewInfo> videoList = new Vector<>();
private final ListView listView; private final ListView listView;
public VideoListAdapter(Context context, VideoItemListFragment videoListFragment) { public VideoListAdapter(Context context, VideoItemListFragment videoListFragment) {
@@ -47,7 +47,7 @@ class VideoListAdapter extends BaseAdapter {
this.context = context; this.context = context;
} }
public void addVideoList(List<VideoPreviewInfo> videos) { public void addVideoList(List<StreamPreviewInfo> videos) {
videoList.addAll(videos); videoList.addAll(videos);
notifyDataSetChanged(); notifyDataSetChanged();
} }
@@ -57,7 +57,7 @@ class VideoListAdapter extends BaseAdapter {
notifyDataSetChanged(); notifyDataSetChanged();
} }
public Vector<VideoPreviewInfo> getVideoList() { public Vector<StreamPreviewInfo> getVideoList() {
return videoList; return videoList;
} }

View File

@@ -20,7 +20,7 @@ import android.graphics.Bitmap;
* along with NewPipe. If not, see <http://www.gnu.org/licenses/>. * along with NewPipe. If not, see <http://www.gnu.org/licenses/>.
*/ */
/**Common properties between VideoInfo and VideoPreviewInfo.*/ /**Common properties between StreamInfo and StreamPreviewInfo.*/
public abstract class AbstractVideoInfo { public abstract class AbstractVideoInfo {
public String id = ""; public String id = "";
public String title = ""; public String title = "";

View File

@@ -37,7 +37,7 @@ public class DashMpdParser {
} }
} }
public static List<VideoInfo.AudioStream> getAudioStreams(String dashManifestUrl, public static List<StreamInfo.AudioStream> getAudioStreams(String dashManifestUrl,
Downloader downloader) Downloader downloader)
throws DashMpdParsingException { throws DashMpdParsingException {
String dashDoc; String dashDoc;
@@ -46,7 +46,7 @@ public class DashMpdParser {
} catch(IOException ioe) { } catch(IOException ioe) {
throw new DashMpdParsingException("Could not get dash mpd: " + dashManifestUrl, ioe); throw new DashMpdParsingException("Could not get dash mpd: " + dashManifestUrl, ioe);
} }
Vector<VideoInfo.AudioStream> audioStreams = new Vector<>(); Vector<StreamInfo.AudioStream> audioStreams = new Vector<>();
try { try {
XmlPullParser parser = Xml.newPullParser(); XmlPullParser parser = Xml.newPullParser();
parser.setInput(new StringReader(dashDoc)); parser.setInput(new StringReader(dashDoc));
@@ -83,7 +83,7 @@ public class DashMpdParser {
} else if(currentMimeType.equals(MediaFormat.M4A.mimeType)) { } else if(currentMimeType.equals(MediaFormat.M4A.mimeType)) {
format = MediaFormat.M4A.id; format = MediaFormat.M4A.id;
} }
audioStreams.add(new VideoInfo.AudioStream(parser.getText(), audioStreams.add(new StreamInfo.AudioStream(parser.getText(),
format, currentBandwidth, currentSamplingRate)); format, currentBandwidth, currentSamplingRate));
} }
break; break;

View File

@@ -30,7 +30,7 @@ public interface SearchEngine {
class Result { class Result {
public String errorMessage = ""; public String errorMessage = "";
public String suggestion = ""; public String suggestion = "";
public final List<VideoPreviewInfo> resultList = new Vector<>(); public final List<StreamPreviewInfo> resultList = new Vector<>();
} }
ArrayList<String> suggestionList(String query,String contentCountry, Downloader dl) ArrayList<String> suggestionList(String query,String contentCountry, Downloader dl)

View File

@@ -3,7 +3,7 @@ package org.schabi.newpipe.extractor;
/** /**
* Created by Christian Schabesberger on 10.08.15. * Created by Christian Schabesberger on 10.08.15.
* *
* Copyright (C) Christian Schabesberger 2015 <chris.schabesberger@mailbox.org> * Copyright (C) Christian Schabesberger 2016 <chris.schabesberger@mailbox.org>
* StreamExtractor.java is part of NewPipe. * StreamExtractor.java is part of NewPipe.
* *
* NewPipe is free software: you can redistribute it and/or modify * NewPipe is free software: you can redistribute it and/or modify
@@ -61,16 +61,16 @@ public interface StreamExtractor {
public abstract String getUploadDate() throws ParsingException; public abstract String getUploadDate() throws ParsingException;
public abstract String getThumbnailUrl() throws ParsingException; public abstract String getThumbnailUrl() throws ParsingException;
public abstract String getUploaderThumbnailUrl() throws ParsingException; public abstract String getUploaderThumbnailUrl() throws ParsingException;
public abstract List<VideoInfo.AudioStream> getAudioStreams() throws ParsingException; public abstract List<StreamInfo.AudioStream> getAudioStreams() throws ParsingException;
public abstract List<VideoInfo.VideoStream> getVideoStreams() throws ParsingException; public abstract List<StreamInfo.VideoStream> getVideoStreams() throws ParsingException;
public abstract List<VideoInfo.VideoStream> getVideoOnlyStreams() throws ParsingException; public abstract List<StreamInfo.VideoStream> getVideoOnlyStreams() throws ParsingException;
public abstract String getDashMpdUrl() throws ParsingException; public abstract String getDashMpdUrl() throws ParsingException;
public abstract int getAgeLimit() throws ParsingException; public abstract int getAgeLimit() throws ParsingException;
public abstract String getAverageRating() throws ParsingException; public abstract String getAverageRating() throws ParsingException;
public abstract int getLikeCount() throws ParsingException; public abstract int getLikeCount() throws ParsingException;
public abstract int getDislikeCount() throws ParsingException; public abstract int getDislikeCount() throws ParsingException;
public abstract VideoPreviewInfo getNextVideo() throws ParsingException; public abstract StreamPreviewInfo getNextVideo() throws ParsingException;
public abstract List<VideoPreviewInfo> getRelatedVideos() throws ParsingException; public abstract List<StreamPreviewInfo> getRelatedVideos() throws ParsingException;
public abstract VideoUrlIdHandler getUrlIdConverter(); public abstract StreamUrlIdHandler getUrlIdConverter();
public abstract String getPageUrl(); public abstract String getPageUrl();
} }

View File

@@ -7,8 +7,8 @@ import java.util.Vector;
/** /**
* Created by Christian Schabesberger on 26.08.15. * Created by Christian Schabesberger on 26.08.15.
* *
* Copyright (C) Christian Schabesberger 2015 <chris.schabesberger@mailbox.org> * Copyright (C) Christian Schabesberger 2016 <chris.schabesberger@mailbox.org>
* VideoInfo.java is part of NewPipe. * StreamInfo.java is part of NewPipe.
* *
* NewPipe is free software: you can redistribute it and/or modify * NewPipe is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by * it under the terms of the GNU General Public License as published by
@@ -26,7 +26,7 @@ import java.util.Vector;
/**Info object for opened videos, ie the video ready to play.*/ /**Info object for opened videos, ie the video ready to play.*/
@SuppressWarnings("ALL") @SuppressWarnings("ALL")
public class VideoInfo extends AbstractVideoInfo { public class StreamInfo extends AbstractVideoInfo {
public static class StreamExctractException extends ExtractionException { public static class StreamExctractException extends ExtractionException {
StreamExctractException(String message) { StreamExctractException(String message) {
@@ -36,178 +36,178 @@ public class VideoInfo extends AbstractVideoInfo {
/**Fills out the video info fields which are common to all services. /**Fills out the video info fields which are common to all services.
* Probably needs to be overridden by subclasses*/ * Probably needs to be overridden by subclasses*/
public static VideoInfo getVideoInfo(StreamExtractor extractor, Downloader downloader) public static StreamInfo getVideoInfo(StreamExtractor extractor, Downloader downloader)
throws ExtractionException, IOException { throws ExtractionException, IOException {
VideoInfo videoInfo = new VideoInfo(); StreamInfo streamInfo = new StreamInfo();
videoInfo = extractImportantData(videoInfo, extractor, downloader); streamInfo = extractImportantData(streamInfo, extractor, downloader);
videoInfo = extractStreams(videoInfo, extractor, downloader); streamInfo = extractStreams(streamInfo, extractor, downloader);
videoInfo = extractOptionalData(videoInfo, extractor, downloader); streamInfo = extractOptionalData(streamInfo, extractor, downloader);
return videoInfo; return streamInfo;
} }
private static VideoInfo extractImportantData( private static StreamInfo extractImportantData(
VideoInfo videoInfo, StreamExtractor extractor, Downloader downloader) StreamInfo streamInfo, StreamExtractor extractor, Downloader downloader)
throws ExtractionException, IOException { throws ExtractionException, IOException {
/* ---- importand data, withoug the video can't be displayed goes here: ---- */ /* ---- importand data, withoug the video can't be displayed goes here: ---- */
// if one of these is not available an exception is ment to be thrown directly into the frontend. // if one of these is not available an exception is ment to be thrown directly into the frontend.
VideoUrlIdHandler uiconv = extractor.getUrlIdConverter(); StreamUrlIdHandler uiconv = extractor.getUrlIdConverter();
videoInfo.webpage_url = extractor.getPageUrl(); streamInfo.webpage_url = extractor.getPageUrl();
videoInfo.id = uiconv.getVideoId(extractor.getPageUrl()); streamInfo.id = uiconv.getVideoId(extractor.getPageUrl());
videoInfo.title = extractor.getTitle(); streamInfo.title = extractor.getTitle();
videoInfo.age_limit = extractor.getAgeLimit(); streamInfo.age_limit = extractor.getAgeLimit();
if((videoInfo.webpage_url == null || videoInfo.webpage_url.isEmpty()) if((streamInfo.webpage_url == null || streamInfo.webpage_url.isEmpty())
|| (videoInfo.id == null || videoInfo.id.isEmpty()) || (streamInfo.id == null || streamInfo.id.isEmpty())
|| (videoInfo.title == null /* videoInfo.title can be empty of course */) || (streamInfo.title == null /* streamInfo.title can be empty of course */)
|| (videoInfo.age_limit == -1)); || (streamInfo.age_limit == -1));
return videoInfo; return streamInfo;
} }
private static VideoInfo extractStreams( private static StreamInfo extractStreams(
VideoInfo videoInfo, StreamExtractor extractor, Downloader downloader) StreamInfo streamInfo, StreamExtractor extractor, Downloader downloader)
throws ExtractionException, IOException { throws ExtractionException, IOException {
/* ---- stream extraction goes here ---- */ /* ---- stream extraction goes here ---- */
// At least one type of stream has to be available, // At least one type of stream has to be available,
// otherwise an exception will be thrown directly into the frontend. // otherwise an exception will be thrown directly into the frontend.
try { try {
videoInfo.dashMpdUrl = extractor.getDashMpdUrl(); streamInfo.dashMpdUrl = extractor.getDashMpdUrl();
} catch(Exception e) { } catch(Exception e) {
videoInfo.addException(new ExtractionException("Couldn't get Dash manifest", e)); streamInfo.addException(new ExtractionException("Couldn't get Dash manifest", e));
} }
/* Load and extract audio */ /* Load and extract audio */
try { try {
videoInfo.audio_streams = extractor.getAudioStreams(); streamInfo.audio_streams = extractor.getAudioStreams();
} catch(Exception e) { } catch(Exception e) {
videoInfo.addException(new ExtractionException("Couldn't get audio streams", e)); streamInfo.addException(new ExtractionException("Couldn't get audio streams", e));
} }
// also try to get streams from the dashMpd // also try to get streams from the dashMpd
if(videoInfo.dashMpdUrl != null && !videoInfo.dashMpdUrl.isEmpty()) { if(streamInfo.dashMpdUrl != null && !streamInfo.dashMpdUrl.isEmpty()) {
if(videoInfo.audio_streams == null) { if(streamInfo.audio_streams == null) {
videoInfo.audio_streams = new Vector<AudioStream>(); streamInfo.audio_streams = new Vector<AudioStream>();
} }
//todo: make this quick and dirty solution a real fallback //todo: make this quick and dirty solution a real fallback
// same as the quick and dirty aboth // same as the quick and dirty aboth
try { try {
videoInfo.audio_streams.addAll( streamInfo.audio_streams.addAll(
DashMpdParser.getAudioStreams(videoInfo.dashMpdUrl, downloader)); DashMpdParser.getAudioStreams(streamInfo.dashMpdUrl, downloader));
} catch(Exception e) { } catch(Exception e) {
videoInfo.addException( streamInfo.addException(
new ExtractionException("Couldn't get audio streams from dash mpd", e)); new ExtractionException("Couldn't get audio streams from dash mpd", e));
} }
} }
/* Extract video stream url*/ /* Extract video stream url*/
try { try {
videoInfo.video_streams = extractor.getVideoStreams(); streamInfo.video_streams = extractor.getVideoStreams();
} catch (Exception e) { } catch (Exception e) {
videoInfo.addException( streamInfo.addException(
new ExtractionException("Couldn't get video streams", e)); new ExtractionException("Couldn't get video streams", e));
} }
/* Extract video only stream url*/ /* Extract video only stream url*/
try { try {
videoInfo.video_only_streams = extractor.getVideoOnlyStreams(); streamInfo.video_only_streams = extractor.getVideoOnlyStreams();
} catch(Exception e) { } catch(Exception e) {
videoInfo.addException( streamInfo.addException(
new ExtractionException("Couldn't get video only streams", e)); new ExtractionException("Couldn't get video only streams", e));
} }
// either dash_mpd audio_only or video has to be available, otherwise we didn't get a stream, // either dash_mpd audio_only or video has to be available, otherwise we didn't get a stream,
// and therefore failed. (Since video_only_streams are just optional they don't caunt). // and therefore failed. (Since video_only_streams are just optional they don't caunt).
if((videoInfo.video_streams == null || videoInfo.video_streams.isEmpty()) if((streamInfo.video_streams == null || streamInfo.video_streams.isEmpty())
&& (videoInfo.audio_streams == null || videoInfo.audio_streams.isEmpty()) && (streamInfo.audio_streams == null || streamInfo.audio_streams.isEmpty())
&& (videoInfo.dashMpdUrl == null || videoInfo.dashMpdUrl.isEmpty())) { && (streamInfo.dashMpdUrl == null || streamInfo.dashMpdUrl.isEmpty())) {
throw new StreamExctractException( throw new StreamExctractException(
"Could not get any stream. See error variable to get further details."); "Could not get any stream. See error variable to get further details.");
} }
return videoInfo; return streamInfo;
} }
private static VideoInfo extractOptionalData( private static StreamInfo extractOptionalData(
VideoInfo videoInfo, StreamExtractor extractor, Downloader downloader) { StreamInfo streamInfo, StreamExtractor extractor, Downloader downloader) {
/* ---- optional data goes here: ---- */ /* ---- optional data goes here: ---- */
// If one of these failes, the frontend neets to handle that they are not available. // If one of these failes, the frontend neets to handle that they are not available.
// Exceptions are therfore not thrown into the frontend, but stored into the error List, // Exceptions are therfore not thrown into the frontend, but stored into the error List,
// so the frontend can afterwads check where errors happend. // so the frontend can afterwads check where errors happend.
try { try {
videoInfo.thumbnail_url = extractor.getThumbnailUrl(); streamInfo.thumbnail_url = extractor.getThumbnailUrl();
} catch(Exception e) { } catch(Exception e) {
videoInfo.addException(e); streamInfo.addException(e);
} }
try { try {
videoInfo.duration = extractor.getLength(); streamInfo.duration = extractor.getLength();
} catch(Exception e) { } catch(Exception e) {
videoInfo.addException(e); streamInfo.addException(e);
} }
try { try {
videoInfo.uploader = extractor.getUploader(); streamInfo.uploader = extractor.getUploader();
} catch(Exception e) { } catch(Exception e) {
videoInfo.addException(e); streamInfo.addException(e);
} }
try { try {
videoInfo.description = extractor.getDescription(); streamInfo.description = extractor.getDescription();
} catch(Exception e) { } catch(Exception e) {
videoInfo.addException(e); streamInfo.addException(e);
} }
try { try {
videoInfo.view_count = extractor.getViewCount(); streamInfo.view_count = extractor.getViewCount();
} catch(Exception e) { } catch(Exception e) {
videoInfo.addException(e); streamInfo.addException(e);
} }
try { try {
videoInfo.upload_date = extractor.getUploadDate(); streamInfo.upload_date = extractor.getUploadDate();
} catch(Exception e) { } catch(Exception e) {
videoInfo.addException(e); streamInfo.addException(e);
} }
try { try {
videoInfo.uploader_thumbnail_url = extractor.getUploaderThumbnailUrl(); streamInfo.uploader_thumbnail_url = extractor.getUploaderThumbnailUrl();
} catch(Exception e) { } catch(Exception e) {
videoInfo.addException(e); streamInfo.addException(e);
} }
try { try {
videoInfo.start_position = extractor.getTimeStamp(); streamInfo.start_position = extractor.getTimeStamp();
} catch(Exception e) { } catch(Exception e) {
videoInfo.addException(e); streamInfo.addException(e);
} }
try { try {
videoInfo.average_rating = extractor.getAverageRating(); streamInfo.average_rating = extractor.getAverageRating();
} catch(Exception e) { } catch(Exception e) {
videoInfo.addException(e); streamInfo.addException(e);
} }
try { try {
videoInfo.like_count = extractor.getLikeCount(); streamInfo.like_count = extractor.getLikeCount();
} catch(Exception e) { } catch(Exception e) {
videoInfo.addException(e); streamInfo.addException(e);
} }
try { try {
videoInfo.dislike_count = extractor.getDislikeCount(); streamInfo.dislike_count = extractor.getDislikeCount();
} catch(Exception e) { } catch(Exception e) {
videoInfo.addException(e); streamInfo.addException(e);
} }
try { try {
videoInfo.next_video = extractor.getNextVideo(); streamInfo.next_video = extractor.getNextVideo();
} catch(Exception e) { } catch(Exception e) {
videoInfo.addException(e); streamInfo.addException(e);
} }
try { try {
videoInfo.related_videos = extractor.getRelatedVideos(); streamInfo.related_videos = extractor.getRelatedVideos();
} catch(Exception e) { } catch(Exception e) {
videoInfo.addException(e); streamInfo.addException(e);
} }
try { try {
} catch (Exception e) { } catch (Exception e) {
videoInfo.addException(e); streamInfo.addException(e);
} }
return videoInfo; return streamInfo;
} }
public String uploader_thumbnail_url = ""; public String uploader_thumbnail_url = "";
@@ -227,20 +227,20 @@ public class VideoInfo extends AbstractVideoInfo {
public int like_count = -1; public int like_count = -1;
public int dislike_count = -1; public int dislike_count = -1;
public String average_rating = ""; public String average_rating = "";
public VideoPreviewInfo next_video = null; public StreamPreviewInfo next_video = null;
public List<VideoPreviewInfo> related_videos = null; public List<StreamPreviewInfo> related_videos = null;
//in seconds. some metadata is not passed using a VideoInfo object! //in seconds. some metadata is not passed using a StreamInfo object!
public int start_position = 0; public int start_position = 0;
//todo: public int service_id = -1; //todo: public int service_id = -1;
public List<Exception> errors = new Vector<>(); public List<Exception> errors = new Vector<>();
public VideoInfo() {} public StreamInfo() {}
/**Creates a new VideoInfo object from an existing AbstractVideoInfo. /**Creates a new StreamInfo object from an existing AbstractVideoInfo.
* All the shared properties are copied to the new VideoInfo.*/ * All the shared properties are copied to the new StreamInfo.*/
@SuppressWarnings("WeakerAccess") @SuppressWarnings("WeakerAccess")
public VideoInfo(AbstractVideoInfo avi) { public StreamInfo(AbstractVideoInfo avi) {
this.id = avi.id; this.id = avi.id;
this.title = avi.title; this.title = avi.title;
this.uploader = avi.uploader; this.uploader = avi.uploader;
@@ -252,9 +252,9 @@ public class VideoInfo extends AbstractVideoInfo {
this.view_count = avi.view_count; this.view_count = avi.view_count;
//todo: better than this //todo: better than this
if(avi instanceof VideoPreviewInfo) { if(avi instanceof StreamPreviewInfo) {
//shitty String to convert code //shitty String to convert code
String dur = ((VideoPreviewInfo)avi).duration; String dur = ((StreamPreviewInfo)avi).duration;
int minutes = Integer.parseInt(dur.substring(0, dur.indexOf(":"))); int minutes = Integer.parseInt(dur.substring(0, dur.indexOf(":")));
int seconds = Integer.parseInt(dur.substring(dur.indexOf(":")+1, dur.length())); int seconds = Integer.parseInt(dur.substring(dur.indexOf(":")+1, dur.length()));
this.duration = (minutes*60)+seconds; this.duration = (minutes*60)+seconds;

View File

@@ -7,8 +7,8 @@ import android.os.Parcelable;
/** /**
* Created by Christian Schabesberger on 26.08.15. * Created by Christian Schabesberger on 26.08.15.
* *
* Copyright (C) Christian Schabesberger 2015 <chris.schabesberger@mailbox.org> * Copyright (C) Christian Schabesberger 2016 <chris.schabesberger@mailbox.org>
* VideoPreviewInfo.java is part of NewPipe. * StreamPreviewInfo.java is part of NewPipe.
* *
* NewPipe is free software: you can redistribute it and/or modify * NewPipe is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by * it under the terms of the GNU General Public License as published by
@@ -25,6 +25,6 @@ import android.os.Parcelable;
*/ */
/**Info object for previews of unopened videos, eg search results, related videos*/ /**Info object for previews of unopened videos, eg search results, related videos*/
public class VideoPreviewInfo extends AbstractVideoInfo { public class StreamPreviewInfo extends AbstractVideoInfo {
public String duration = ""; public String duration = "";
} }

View File

@@ -4,7 +4,7 @@ package org.schabi.newpipe.extractor;
* Created by Christian Schabesberger on 02.02.16. * Created by Christian Schabesberger on 02.02.16.
* *
* Copyright (C) Christian Schabesberger 2016 <chris.schabesberger@mailbox.org> * Copyright (C) Christian Schabesberger 2016 <chris.schabesberger@mailbox.org>
* VideoUrlIdHandler.java is part of NewPipe. * StreamUrlIdHandler.java is part of NewPipe.
* *
* NewPipe is free software: you can redistribute it and/or modify * NewPipe is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by * it under the terms of the GNU General Public License as published by
@@ -20,7 +20,7 @@ package org.schabi.newpipe.extractor;
* along with NewPipe. If not, see <http://www.gnu.org/licenses/>. * along with NewPipe. If not, see <http://www.gnu.org/licenses/>.
*/ */
public interface VideoUrlIdHandler { public interface StreamUrlIdHandler {
String getVideoUrl(String videoId); String getVideoUrl(String videoId);
String getVideoId(String siteUrl) throws ParsingException; String getVideoId(String siteUrl) throws ParsingException;
String cleanUrl(String siteUrl) throws ParsingException; String cleanUrl(String siteUrl) throws ParsingException;

View File

@@ -5,7 +5,7 @@ import java.io.IOException;
/** /**
* Created by Christian Schabesberger on 23.08.15. * Created by Christian Schabesberger on 23.08.15.
* *
* Copyright (C) Christian Schabesberger 2015 <chris.schabesberger@mailbox.org> * Copyright (C) Christian Schabesberger 2016 <chris.schabesberger@mailbox.org>
* StreamingService.java is part of NewPipe. * StreamingService.java is part of NewPipe.
* *
* NewPipe is free software: you can redistribute it and/or modify * NewPipe is free software: you can redistribute it and/or modify
@@ -31,7 +31,7 @@ public interface StreamingService {
throws IOException, ExtractionException; throws IOException, ExtractionException;
SearchEngine getSearchEngineInstance(); SearchEngine getSearchEngineInstance();
VideoUrlIdHandler getUrlIdHandler(); StreamUrlIdHandler getUrlIdHandler();
} }

View File

@@ -10,7 +10,7 @@ import org.schabi.newpipe.extractor.Downloader;
import org.schabi.newpipe.extractor.Parser; import org.schabi.newpipe.extractor.Parser;
import org.schabi.newpipe.extractor.ParsingException; import org.schabi.newpipe.extractor.ParsingException;
import org.schabi.newpipe.extractor.SearchEngine; import org.schabi.newpipe.extractor.SearchEngine;
import org.schabi.newpipe.extractor.VideoPreviewInfo; import org.schabi.newpipe.extractor.StreamPreviewInfo;
import org.w3c.dom.Node; import org.w3c.dom.Node;
import org.w3c.dom.NodeList; import org.w3c.dom.NodeList;
import org.xml.sax.InputSource; import org.xml.sax.InputSource;
@@ -99,11 +99,11 @@ public class YoutubeSearchEngine implements SearchEngine {
// video item type // video item type
} else if (!((el = item.select("div[class*=\"yt-lockup-video\"").first()) == null)) { } else if (!((el = item.select("div[class*=\"yt-lockup-video\"").first()) == null)) {
VideoPreviewInfo resultItem = new VideoPreviewInfo(); StreamPreviewInfo resultItem = new StreamPreviewInfo();
// importand information // importand information
resultItem.webpage_url = getWebpageUrl(item); resultItem.webpage_url = getWebpageUrl(item);
resultItem.id = (new YoutubeVideoUrlIdHandler()).getVideoId(resultItem.webpage_url); resultItem.id = (new YoutubeStreamUrlIdHandler()).getVideoId(resultItem.webpage_url);
resultItem.title = getTitle(item); resultItem.title = getTitle(item);
// optional iformation // optional iformation
@@ -147,7 +147,7 @@ public class YoutubeSearchEngine implements SearchEngine {
} }
@Override @Override
public ArrayList<String> suggestionList(String query,String contentCountry, Downloader dl) public ArrayList<String> suggestionList(String query, String contentCountry, Downloader dl)
throws IOException, ParsingException { throws IOException, ParsingException {
ArrayList<String> suggestions = new ArrayList<>(); ArrayList<String> suggestions = new ArrayList<>();

View File

@@ -4,7 +4,7 @@ import org.schabi.newpipe.extractor.ExtractionException;
import org.schabi.newpipe.extractor.Downloader; import org.schabi.newpipe.extractor.Downloader;
import org.schabi.newpipe.extractor.StreamExtractor; import org.schabi.newpipe.extractor.StreamExtractor;
import org.schabi.newpipe.extractor.StreamingService; import org.schabi.newpipe.extractor.StreamingService;
import org.schabi.newpipe.extractor.VideoUrlIdHandler; import org.schabi.newpipe.extractor.StreamUrlIdHandler;
import org.schabi.newpipe.extractor.SearchEngine; import org.schabi.newpipe.extractor.SearchEngine;
import java.io.IOException; import java.io.IOException;
@@ -40,7 +40,7 @@ public class YoutubeService implements StreamingService {
@Override @Override
public StreamExtractor getExtractorInstance(String url, Downloader downloader) public StreamExtractor getExtractorInstance(String url, Downloader downloader)
throws ExtractionException, IOException { throws ExtractionException, IOException {
VideoUrlIdHandler urlIdHandler = new YoutubeVideoUrlIdHandler(); StreamUrlIdHandler urlIdHandler = new YoutubeStreamUrlIdHandler();
if(urlIdHandler.acceptUrl(url)) { if(urlIdHandler.acceptUrl(url)) {
return new YoutubeStreamExtractor(url, downloader) ; return new YoutubeStreamExtractor(url, downloader) ;
} }
@@ -54,7 +54,7 @@ public class YoutubeService implements StreamingService {
} }
@Override @Override
public VideoUrlIdHandler getUrlIdHandler() { public StreamUrlIdHandler getUrlIdHandler() {
return new YoutubeVideoUrlIdHandler(); return new YoutubeStreamUrlIdHandler();
} }
} }

View File

@@ -14,11 +14,11 @@ import org.schabi.newpipe.extractor.ExtractionException;
import org.schabi.newpipe.extractor.Downloader; import org.schabi.newpipe.extractor.Downloader;
import org.schabi.newpipe.extractor.Parser; import org.schabi.newpipe.extractor.Parser;
import org.schabi.newpipe.extractor.ParsingException; import org.schabi.newpipe.extractor.ParsingException;
import org.schabi.newpipe.extractor.VideoUrlIdHandler; import org.schabi.newpipe.extractor.StreamInfo;
import org.schabi.newpipe.extractor.StreamPreviewInfo;
import org.schabi.newpipe.extractor.StreamUrlIdHandler;
import org.schabi.newpipe.extractor.StreamExtractor; import org.schabi.newpipe.extractor.StreamExtractor;
import org.schabi.newpipe.extractor.MediaFormat; import org.schabi.newpipe.extractor.MediaFormat;
import org.schabi.newpipe.extractor.VideoInfo;
import org.schabi.newpipe.extractor.VideoPreviewInfo;
import java.io.IOException; import java.io.IOException;
import java.util.List; import java.util.List;
@@ -179,7 +179,7 @@ public class YoutubeStreamExtractor implements StreamExtractor {
// cached values // cached values
private static volatile String decryptionCode = ""; private static volatile String decryptionCode = "";
VideoUrlIdHandler urlidhandler = new YoutubeVideoUrlIdHandler(); StreamUrlIdHandler urlidhandler = new YoutubeStreamUrlIdHandler();
String pageUrl = ""; String pageUrl = "";
private Downloader downloader; private Downloader downloader;
@@ -433,8 +433,8 @@ public class YoutubeStreamExtractor implements StreamExtractor {
@Override @Override
public List<VideoInfo.AudioStream> getAudioStreams() throws ParsingException { public List<StreamInfo.AudioStream> getAudioStreams() throws ParsingException {
Vector<VideoInfo.AudioStream> audioStreams = new Vector<>(); Vector<StreamInfo.AudioStream> audioStreams = new Vector<>();
try{ try{
String encoded_url_map; String encoded_url_map;
// playerArgs could be null if the video is age restricted // playerArgs could be null if the video is age restricted
@@ -461,7 +461,7 @@ public class YoutubeStreamExtractor implements StreamExtractor {
+ decryptSignature(tags.get("s"), decryptionCode); + decryptSignature(tags.get("s"), decryptionCode);
} }
audioStreams.add(new VideoInfo.AudioStream(streamUrl, audioStreams.add(new StreamInfo.AudioStream(streamUrl,
itagItem.mediaFormatId, itagItem.mediaFormatId,
itagItem.bandWidth, itagItem.bandWidth,
itagItem.samplingRate)); itagItem.samplingRate));
@@ -475,8 +475,8 @@ public class YoutubeStreamExtractor implements StreamExtractor {
} }
@Override @Override
public List<VideoInfo.VideoStream> getVideoStreams() throws ParsingException { public List<StreamInfo.VideoStream> getVideoStreams() throws ParsingException {
Vector<VideoInfo.VideoStream> videoStreams = new Vector<>(); Vector<StreamInfo.VideoStream> videoStreams = new Vector<>();
try{ try{
String encoded_url_map; String encoded_url_map;
@@ -504,7 +504,7 @@ public class YoutubeStreamExtractor implements StreamExtractor {
streamUrl = streamUrl + "&signature=" streamUrl = streamUrl + "&signature="
+ decryptSignature(tags.get("s"), decryptionCode); + decryptSignature(tags.get("s"), decryptionCode);
} }
videoStreams.add(new VideoInfo.VideoStream( videoStreams.add(new StreamInfo.VideoStream(
streamUrl, streamUrl,
itagItem.mediaFormatId, itagItem.mediaFormatId,
itagItem.resolutionString)); itagItem.resolutionString));
@@ -527,7 +527,7 @@ public class YoutubeStreamExtractor implements StreamExtractor {
} }
@Override @Override
public List<VideoInfo.VideoStream> getVideoOnlyStreams() throws ParsingException { public List<StreamInfo.VideoStream> getVideoOnlyStreams() throws ParsingException {
return null; return null;
} }
@@ -638,7 +638,7 @@ public class YoutubeStreamExtractor implements StreamExtractor {
} }
@Override @Override
public VideoPreviewInfo getNextVideo() throws ParsingException { public StreamPreviewInfo getNextVideo() throws ParsingException {
try { try {
return extractVideoPreviewInfo(doc.select("div[class=\"watch-sidebar-section\"]").first() return extractVideoPreviewInfo(doc.select("div[class=\"watch-sidebar-section\"]").first()
.select("li").first()); .select("li").first());
@@ -648,9 +648,9 @@ public class YoutubeStreamExtractor implements StreamExtractor {
} }
@Override @Override
public Vector<VideoPreviewInfo> getRelatedVideos() throws ParsingException { public Vector<StreamPreviewInfo> getRelatedVideos() throws ParsingException {
try { try {
Vector<VideoPreviewInfo> relatedVideos = new Vector<>(); Vector<StreamPreviewInfo> relatedVideos = new Vector<>();
for (Element li : doc.select("ul[id=\"watch-related\"]").first().children()) { for (Element li : doc.select("ul[id=\"watch-related\"]").first().children()) {
// first check if we have a playlist. If so leave them out // first check if we have a playlist. If so leave them out
if (li.select("a[class*=\"content-link\"]").first() != null) { if (li.select("a[class*=\"content-link\"]").first() != null) {
@@ -664,8 +664,8 @@ public class YoutubeStreamExtractor implements StreamExtractor {
} }
@Override @Override
public VideoUrlIdHandler getUrlIdConverter() { public StreamUrlIdHandler getUrlIdConverter() {
return new YoutubeVideoUrlIdHandler(); return new YoutubeStreamUrlIdHandler();
} }
@Override @Override
@@ -674,10 +674,10 @@ public class YoutubeStreamExtractor implements StreamExtractor {
} }
/**Provides information about links to other videos on the video page, such as related videos. /**Provides information about links to other videos on the video page, such as related videos.
* This is encapsulated in a VideoPreviewInfo object, * This is encapsulated in a StreamPreviewInfo object,
* which is a subset of the fields in a full VideoInfo.*/ * which is a subset of the fields in a full StreamInfo.*/
private VideoPreviewInfo extractVideoPreviewInfo(Element li) throws ParsingException { private StreamPreviewInfo extractVideoPreviewInfo(Element li) throws ParsingException {
VideoPreviewInfo info = new VideoPreviewInfo(); StreamPreviewInfo info = new StreamPreviewInfo();
try { try {
info.webpage_url = li.select("a.content-link").first() info.webpage_url = li.select("a.content-link").first()

View File

@@ -2,7 +2,7 @@ package org.schabi.newpipe.extractor.services.youtube;
import org.schabi.newpipe.extractor.Parser; import org.schabi.newpipe.extractor.Parser;
import org.schabi.newpipe.extractor.ParsingException; import org.schabi.newpipe.extractor.ParsingException;
import org.schabi.newpipe.extractor.VideoUrlIdHandler; import org.schabi.newpipe.extractor.StreamUrlIdHandler;
import java.io.UnsupportedEncodingException; import java.io.UnsupportedEncodingException;
import java.net.URLDecoder; import java.net.URLDecoder;
@@ -11,7 +11,7 @@ import java.net.URLDecoder;
* Created by Christian Schabesberger on 02.02.16. * Created by Christian Schabesberger on 02.02.16.
* *
* Copyright (C) Christian Schabesberger 2016 <chris.schabesberger@mailbox.org> * Copyright (C) Christian Schabesberger 2016 <chris.schabesberger@mailbox.org>
* YoutubeVideoUrlIdHandler.java is part of NewPipe. * YoutubeStreamUrlIdHandler.java is part of NewPipe.
* *
* NewPipe is free software: you can redistribute it and/or modify * NewPipe is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by * it under the terms of the GNU General Public License as published by
@@ -27,7 +27,7 @@ import java.net.URLDecoder;
* along with NewPipe. If not, see <http://www.gnu.org/licenses/>. * along with NewPipe. If not, see <http://www.gnu.org/licenses/>.
*/ */
public class YoutubeVideoUrlIdHandler implements VideoUrlIdHandler { public class YoutubeStreamUrlIdHandler implements StreamUrlIdHandler {
@SuppressWarnings("WeakerAccess") @SuppressWarnings("WeakerAccess")
@Override @Override
public String getVideoUrl(String videoId) { public String getVideoUrl(String videoId) {