diff options
| author | Ricardo Garcia <sarbalap+freshmeat@gmail.com> | 2010-03-19 18:15:43 +0100 | 
|---|---|---|
| committer | Ricardo Garcia <sarbalap+freshmeat@gmail.com> | 2010-10-31 11:26:48 +0100 | 
| commit | 6ba562b0e46f266fa674eb56d86a3b66f4a007d2 (patch) | |
| tree | 5ded30225329c0b603ad5415832c410edeb489e1 | |
| parent | 131bc7651a546d09028cdbb231339b624bf1fbbf (diff) | |
Added --all-format option from tweaked patch (fixes issue #102)
| -rwxr-xr-x | youtube-dl | 38 | 
1 files changed, 32 insertions, 6 deletions
| diff --git a/youtube-dl b/youtube-dl index b79ab0294..407a393a7 100755 --- a/youtube-dl +++ b/youtube-dl @@ -593,6 +593,7 @@ class InfoExtractor(object):  	title:		Literal title.  	stitle:		Simplified title.  	ext:		Video filename extension. +	format:		Video format.  	Subclasses of this one should re-define the _real_initialize() and  	_real_extract() methods, as well as the suitable() static method. @@ -764,6 +765,7 @@ class YoutubeIE(InfoExtractor):  		# Downloader parameters  		best_quality = False +		all_formats = False  		format_param = None  		quality_index = 0  		if self._downloader is not None: @@ -772,6 +774,9 @@ class YoutubeIE(InfoExtractor):  			if format_param == '0':  				format_param = self._available_formats[quality_index]  				best_quality = True +			elif format_param == '-1': +				format_param = self._available_formats[quality_index] +				all_formats = True  		while True:  			# Extension @@ -838,20 +843,35 @@ class YoutubeIE(InfoExtractor):  					'title':	video_title,  					'stitle':	simple_title,  					'ext':		video_extension.decode('utf-8'), +					'format':	(format_param is None and u'NA' or format_param.decode('utf-8')),  				}) +				if all_formats: +					if quality_index == len(self._available_formats) - 1: +						# None left to get +						return +					else: +						quality_index += 1 +						format_param = self._available_formats[quality_index] +						if format_param == None: +							return +						continue +  				return  			except UnavailableFormatError, err: -				if best_quality: +				if best_quality or all_formats:  					if quality_index == len(self._available_formats) - 1:  						# I don't ever expect this to happen -						self._downloader.trouble(u'ERROR: no known formats available for video') +						if not all_formats: +							self._downloader.trouble(u'ERROR: no known formats available for video')  						return  					else:  						self.report_unavailable_format(video_id, format_param)  						quality_index += 1  						format_param = self._available_formats[quality_index] +						if format_param == None: +							return  						continue  				else:   					self._downloader.trouble('ERROR: format not available for video') @@ -980,6 +1000,7 @@ class MetacafeIE(InfoExtractor):  				'title':	video_title,  				'stitle':	simple_title,  				'ext':		video_extension.decode('utf-8'), +				'format':	u'NA',  			})  		except UnavailableFormatError:  			self._downloader.trouble(u'ERROR: format not available for video') @@ -1051,18 +1072,16 @@ class GoogleIE(InfoExtractor):  		video_title = sanitize_title(video_title)  		simple_title = re.sub(ur'(?u)([^%s]+)' % simple_title_chars, ur'_', video_title) -		# Google Video doesn't show uploader nicknames? -		video_uploader = 'NA' -  		try:  			# Process video information  			self._downloader.process_info({  				'id':		video_id.decode('utf-8'),  				'url':		video_url.decode('utf-8'), -				'uploader':	video_uploader.decode('utf-8'), +				'uploader':	u'NA',  				'title':	video_title,  				'stitle':	simple_title,  				'ext':		video_extension.decode('utf-8'), +				'format':	u'NA',  			})  		except UnavailableFormatError:  			self._downloader.trouble(u'ERROR: format not available for video') @@ -1140,6 +1159,7 @@ class PhotobucketIE(InfoExtractor):  				'title':	video_title,  				'stitle':	simple_title,  				'ext':		video_extension.decode('utf-8'), +				'format':	u'NA',  			})  		except UnavailableFormatError:  			self._downloader.trouble(u'ERROR: format not available for video') @@ -1234,6 +1254,7 @@ class GenericIE(InfoExtractor):  				'title':	video_title,  				'stitle':	simple_title,  				'ext':		video_extension.decode('utf-8'), +				'format':	u'NA',  			})  		except UnavailableFormatError:  			self._downloader.trouble(u'ERROR: format not available for video') @@ -1555,6 +1576,8 @@ if __name__ == '__main__':  				action='store_const', dest='format', help='alias for -f 17', const='17')  		video_format.add_option('-d', '--high-def',  				action='store_const', dest='format', help='alias for -f 22', const='22') +		video_format.add_option('--all-formats', +				action='store_const', dest='format', help='download all available video formats', const='-1')  		parser.add_option_group(video_format)  		verbosity = optparse.OptionGroup(parser, 'Verbosity / Simulation Options') @@ -1636,6 +1659,9 @@ if __name__ == '__main__':  			'simulate': (opts.simulate or opts.geturl or opts.gettitle),  			'format': opts.format,  			'outtmpl': ((opts.outtmpl is not None and opts.outtmpl.decode(preferredencoding())) +				or (opts.format == '-1' and opts.usetitle and u'%(stitle)s-%(id)s-%(format)s.%(ext)s') +				or (opts.format == '-1' and opts.useliteral and u'%(title)s-%(id)s-%(format)s.%(ext)s') +				or (opts.format == '-1' and u'%(id)s-%(format)s.%(ext)s')  				or (opts.usetitle and u'%(stitle)s-%(id)s.%(ext)s')  				or (opts.useliteral and u'%(title)s-%(id)s.%(ext)s')  				or u'%(id)s.%(ext)s'), | 
