summary refs log tree commit diff
diff options
context:
space:
mode:
authordannycolligan <devnull@localhost>2009-04-28 14:39:23 -0700
committerRicardo Garcia <sarbalap+freshmeat@gmail.com>2010-10-31 11:24:12 +0100
commit42bcd27d3bc30c12218630c68af364190f819cc2 (patch)
tree3a6bf48bf772c2ee53b10737b438a89a5aaa40d4
parent2740c509b3c19fe8589b6aa6f746005aa12a7f82 (diff)
downloadyoutube-dl-42bcd27d3bc30c12218630c68af364190f819cc2.tar.gz
youtube-dl-42bcd27d3bc30c12218630c68af364190f819cc2.tar.xz
youtube-dl-42bcd27d3bc30c12218630c68af364190f819cc2.zip
Some consistency changes and ghost-file bugfix after discussion with rg3
-rwxr-xr-xyoutube-dl62
1 files changed, 35 insertions, 27 deletions
diff --git a/youtube-dl b/youtube-dl
index 8143de35e..4acdecd79 100755
--- a/youtube-dl
+++ b/youtube-dl
@@ -284,11 +284,8 @@ class FileDownloader(object):
 			self._do_download(outstream, info_dict['url'])
 			outstream.close()
 		except (OSError, IOError), err:
-			if info_dict['best_quality']:
-				raise UnavailableFormatError
-			else:
-				self.trouble('ERROR: unable to write video data: %s' % str(err))
-				return
+			os.remove(filename)
+			raise UnavailableFormatError
 		except (urllib2.URLError, httplib.HTTPException, socket.error), err:
 			self.trouble('ERROR: unable to download video data: %s' % str(err))
 			return
@@ -643,21 +640,25 @@ class YoutubeIE(InfoExtractor):
 					'title':	video_title,
 					'stitle':	simple_title,
 					'ext':		video_extension.decode('utf-8'),
-					'best_quality': best_quality,
 				})
 
 				return
 
-			except UnavailableFormatError:
-				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')
+			except UnavailableFormatError, err:
+				if best_quality:
+					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')
+						return
+					else:
+						self.report_unavailable_format(video_id, format_param)
+						quality_index += 1
+						format_param = self._available_formats[quality_index]
+						continue
+				else: 
+					self._downloader.trouble('ERROR: format not available for video')
 					return
-				else:
-					self.report_unavailable_format(video_id, format_param)
-					quality_index += 1
-					format_param = self._available_formats[quality_index]
-					continue
+
 
 class MetacafeIE(InfoExtractor):
 	"""Information Extractor for metacafe.com."""
@@ -769,16 +770,18 @@ class MetacafeIE(InfoExtractor):
 			return
 		video_uploader = mobj.group(1)
 
-		# 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'),
-			'title':	video_title,
-			'stitle':	simple_title,
-			'ext':		video_extension.decode('utf-8'),
-			'best_quality': False, # TODO
-		})
+		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'),
+				'title':	video_title,
+				'stitle':	simple_title,
+				'ext':		video_extension.decode('utf-8'),
+			})
+		except UnavailableFormatError:
+			self._downloader.trouble(u'ERROR: format not available for video')
 
 
 class YoutubeSearchIE(InfoExtractor):
@@ -1079,8 +1082,13 @@ if __name__ == '__main__':
 			if numeric_limit is None:
 				parser.error(u'invalid rate limit specified')
 			opts.ratelimit = numeric_limit
-		if len(opts.format) > 1:
+		if opts.format is not None and len(opts.format) > 1:
 			parser.error(u'pass at most one of the video format option flags (-f, -b, -m, -d)')
+		if opts.format is None:
+			real_format = None
+		else:
+			real_format = opts.format[0]
+
 
 		# Information extractors
 		youtube_ie = YoutubeIE()
@@ -1097,7 +1105,7 @@ if __name__ == '__main__':
 			'forceurl': opts.geturl,
 			'forcetitle': opts.gettitle,
 			'simulate': (opts.simulate or opts.geturl or opts.gettitle),
-			'format': opts.format[0],
+			'format': real_format,
 			'outtmpl': ((opts.outtmpl is not None and opts.outtmpl.decode(locale.getpreferredencoding()))
 				or (opts.usetitle and u'%(stitle)s-%(id)s.%(ext)s')
 				or (opts.useliteral and u'%(title)s-%(id)s.%(ext)s')