Merge branch 'master' into opener-to-ydl
This commit is contained in:
		@@ -104,6 +104,7 @@ class YoutubeDL(object):
 | 
			
		||||
    playlistend:       Playlist item to end at.
 | 
			
		||||
    matchtitle:        Download only matching titles.
 | 
			
		||||
    rejecttitle:       Reject downloads for matching titles.
 | 
			
		||||
    logger:            Log messages to a logging.Logger instance.
 | 
			
		||||
    logtostderr:       Log messages to stderr instead of stdout.
 | 
			
		||||
    writedescription:  Write the video description to a .description file
 | 
			
		||||
    writeinfojson:     Write the video description to a .info.json file
 | 
			
		||||
@@ -204,7 +205,9 @@ class YoutubeDL(object):
 | 
			
		||||
 | 
			
		||||
    def to_screen(self, message, skip_eol=False):
 | 
			
		||||
        """Print message to stdout if not in quiet mode."""
 | 
			
		||||
        if not self.params.get('quiet', False):
 | 
			
		||||
        if self.params.get('logger'):
 | 
			
		||||
            self.params['logger'].debug(message)
 | 
			
		||||
        elif not self.params.get('quiet', False):
 | 
			
		||||
            terminator = [u'\n', u''][skip_eol]
 | 
			
		||||
            output = message + terminator
 | 
			
		||||
            write_string(output, self._screen_file)
 | 
			
		||||
@@ -212,10 +215,13 @@ class YoutubeDL(object):
 | 
			
		||||
    def to_stderr(self, message):
 | 
			
		||||
        """Print message to stderr."""
 | 
			
		||||
        assert type(message) == type(u'')
 | 
			
		||||
        output = message + u'\n'
 | 
			
		||||
        if 'b' in getattr(self._screen_file, 'mode', '') or sys.version_info[0] < 3: # Python 2 lies about the mode of sys.stdout/sys.stderr
 | 
			
		||||
            output = output.encode(preferredencoding())
 | 
			
		||||
        sys.stderr.write(output)
 | 
			
		||||
        if self.params.get('logger'):
 | 
			
		||||
            self.params['logger'].error(message)
 | 
			
		||||
        else:
 | 
			
		||||
            output = message + u'\n'
 | 
			
		||||
            if 'b' in getattr(self._screen_file, 'mode', '') or sys.version_info[0] < 3: # Python 2 lies about the mode of sys.stdout/sys.stderr
 | 
			
		||||
                output = output.encode(preferredencoding())
 | 
			
		||||
            sys.stderr.write(output)
 | 
			
		||||
 | 
			
		||||
    def to_console_title(self, message):
 | 
			
		||||
        if not self.params.get('consoletitle', False):
 | 
			
		||||
@@ -370,15 +376,17 @@ class YoutubeDL(object):
 | 
			
		||||
    def _match_entry(self, info_dict):
 | 
			
		||||
        """ Returns None iff the file should be downloaded """
 | 
			
		||||
 | 
			
		||||
        title = info_dict['title']
 | 
			
		||||
        matchtitle = self.params.get('matchtitle', False)
 | 
			
		||||
        if matchtitle:
 | 
			
		||||
            if not re.search(matchtitle, title, re.IGNORECASE):
 | 
			
		||||
                return u'[download] "' + title + '" title did not match pattern "' + matchtitle + '"'
 | 
			
		||||
        rejecttitle = self.params.get('rejecttitle', False)
 | 
			
		||||
        if rejecttitle:
 | 
			
		||||
            if re.search(rejecttitle, title, re.IGNORECASE):
 | 
			
		||||
                return u'"' + title + '" title matched reject pattern "' + rejecttitle + '"'
 | 
			
		||||
        if 'title' in info_dict:
 | 
			
		||||
            # This can happen when we're just evaluating the playlist
 | 
			
		||||
            title = info_dict['title']
 | 
			
		||||
            matchtitle = self.params.get('matchtitle', False)
 | 
			
		||||
            if matchtitle:
 | 
			
		||||
                if not re.search(matchtitle, title, re.IGNORECASE):
 | 
			
		||||
                    return u'[download] "' + title + '" title did not match pattern "' + matchtitle + '"'
 | 
			
		||||
            rejecttitle = self.params.get('rejecttitle', False)
 | 
			
		||||
            if rejecttitle:
 | 
			
		||||
                if re.search(rejecttitle, title, re.IGNORECASE):
 | 
			
		||||
                    return u'"' + title + '" title matched reject pattern "' + rejecttitle + '"'
 | 
			
		||||
        date = info_dict.get('upload_date', None)
 | 
			
		||||
        if date is not None:
 | 
			
		||||
            dateRange = self.params.get('daterange', DateRange())
 | 
			
		||||
@@ -389,8 +397,8 @@ class YoutubeDL(object):
 | 
			
		||||
            if age_limit < info_dict.get('age_limit', 0):
 | 
			
		||||
                return u'Skipping "' + title + '" because it is age restricted'
 | 
			
		||||
        if self.in_download_archive(info_dict):
 | 
			
		||||
            return (u'%(title)s has already been recorded in archive'
 | 
			
		||||
                    % info_dict)
 | 
			
		||||
            return (u'%s has already been recorded in archive'
 | 
			
		||||
                    % info_dict.get('title', info_dict.get('id', u'video')))
 | 
			
		||||
        return None
 | 
			
		||||
 | 
			
		||||
    @staticmethod
 | 
			
		||||
@@ -469,7 +477,7 @@ class YoutubeDL(object):
 | 
			
		||||
                                     ie_key=ie_result.get('ie_key'),
 | 
			
		||||
                                     extra_info=extra_info)
 | 
			
		||||
        elif result_type == 'playlist':
 | 
			
		||||
            self.add_extra_info(ie_result, extra_info)
 | 
			
		||||
 | 
			
		||||
            # We process each entry in the playlist
 | 
			
		||||
            playlist = ie_result.get('title', None) or ie_result.get('id', None)
 | 
			
		||||
            self.to_screen(u'[download] Downloading playlist: %s' % playlist)
 | 
			
		||||
@@ -499,6 +507,12 @@ class YoutubeDL(object):
 | 
			
		||||
                    'webpage_url': ie_result['webpage_url'],
 | 
			
		||||
                    'extractor_key': ie_result['extractor_key'],
 | 
			
		||||
                }
 | 
			
		||||
 | 
			
		||||
                reason = self._match_entry(entry)
 | 
			
		||||
                if reason is not None:
 | 
			
		||||
                    self.to_screen(u'[download] ' + reason)
 | 
			
		||||
                    continue
 | 
			
		||||
 | 
			
		||||
                entry_result = self.process_ie_result(entry,
 | 
			
		||||
                                                      download=download,
 | 
			
		||||
                                                      extra_info=extra)
 | 
			
		||||
@@ -654,7 +668,7 @@ class YoutubeDL(object):
 | 
			
		||||
 | 
			
		||||
        # Forced printings
 | 
			
		||||
        if self.params.get('forcetitle', False):
 | 
			
		||||
            compat_print(info_dict['title'])
 | 
			
		||||
            compat_print(info_dict['fulltitle'])
 | 
			
		||||
        if self.params.get('forceid', False):
 | 
			
		||||
            compat_print(info_dict['id'])
 | 
			
		||||
        if self.params.get('forceurl', False):
 | 
			
		||||
@@ -825,7 +839,16 @@ class YoutubeDL(object):
 | 
			
		||||
        fn = self.params.get('download_archive')
 | 
			
		||||
        if fn is None:
 | 
			
		||||
            return False
 | 
			
		||||
        vid_id = info_dict['extractor'] + u' ' + info_dict['id']
 | 
			
		||||
        extractor = info_dict.get('extractor_id')
 | 
			
		||||
        if extractor is None:
 | 
			
		||||
            if 'id' in info_dict:
 | 
			
		||||
                extractor = info_dict.get('ie_key')  # key in a playlist
 | 
			
		||||
        if extractor is None:
 | 
			
		||||
            return False  # Incomplete video information
 | 
			
		||||
        # Future-proof against any change in case
 | 
			
		||||
        # and backwards compatibility with prior versions
 | 
			
		||||
        extractor = extractor.lower()
 | 
			
		||||
        vid_id = extractor + u' ' + info_dict['id']
 | 
			
		||||
        try:
 | 
			
		||||
            with locked_file(fn, 'r', encoding='utf-8') as archive_file:
 | 
			
		||||
                for line in archive_file:
 | 
			
		||||
 
 | 
			
		||||
		Reference in New Issue
	
	Block a user