mirror of
				https://github.com/yt-dlp/yt-dlp.git
				synced 2025-10-25 03:31:03 +00:00 
			
		
		
		
	Introduced Trouble(Exception) for more elegant non-fatal errors handling
This commit is contained in:
		
							parent
							
								
									3fe294e4ef
								
							
						
					
					
						commit
						0b8c922da9
					
				| @ -359,15 +359,16 @@ def _real_extract(self, url): | ||||
| 		# closed captions | ||||
| 		video_subtitles = None | ||||
| 		if self._downloader.params.get('writesubtitles', False): | ||||
| 			try: | ||||
| 				self.report_video_subtitles_download(video_id) | ||||
| 				request = urllib2.Request('http://video.google.com/timedtext?hl=en&type=list&v=%s' % video_id) | ||||
| 				try: | ||||
| 					srt_list = urllib2.urlopen(request).read() | ||||
| 				except (urllib2.URLError, httplib.HTTPException, socket.error), err: | ||||
| 				self._downloader.trouble(u'WARNING: unable to download video subtitles: %s' % str(err)) | ||||
| 			else: | ||||
| 					raise Trouble(u'WARNING: unable to download video subtitles: %s' % str(err)) | ||||
| 				srt_lang_list = re.findall(r'lang_code="([\w\-]+)"', srt_list) | ||||
| 				if srt_lang_list: | ||||
| 				if not srt_lang_list: | ||||
| 					raise Trouble(u'WARNING: video has no closed captions') | ||||
| 				if self._downloader.params.get('subtitleslang', False): | ||||
| 					srt_lang = self._downloader.params.get('subtitleslang') | ||||
| 				elif 'en' in srt_lang_list: | ||||
| @ -375,17 +376,15 @@ def _real_extract(self, url): | ||||
| 				else: | ||||
| 					srt_lang = srt_lang_list[0] | ||||
| 				if not srt_lang in srt_lang_list: | ||||
| 						self._downloader.trouble(u'WARNING: no closed captions found in the specified language') | ||||
| 					else: | ||||
| 					raise Trouble(u'WARNING: no closed captions found in the specified language') | ||||
| 				request = urllib2.Request('http://video.google.com/timedtext?hl=en&lang=%s&v=%s' % (srt_lang, video_id)) | ||||
| 				try: | ||||
| 					srt_xml = urllib2.urlopen(request).read() | ||||
| 				except (urllib2.URLError, httplib.HTTPException, socket.error), err: | ||||
| 							self._downloader.trouble(u'WARNING: unable to download video subtitles: %s' % str(err)) | ||||
| 						else: | ||||
| 					raise Trouble(u'WARNING: unable to download video subtitles: %s' % str(err)) | ||||
| 				video_subtitles = self._closed_captions_xml_to_srt(srt_xml.decode('utf-8')) | ||||
| 				else: | ||||
| 					self._downloader.trouble(u'WARNING: video has no closed captions') | ||||
| 			except Trouble as trouble: | ||||
| 				self._downloader.trouble(trouble[0]) | ||||
| 
 | ||||
| 		# token | ||||
| 		video_token = urllib.unquote_plus(video_info['token'][0]) | ||||
|  | ||||
| @ -290,6 +290,13 @@ def __init__(self, downloaded, expected): | ||||
| 		self.expected = expected | ||||
| 
 | ||||
| 
 | ||||
| class Trouble(Exception): | ||||
| 	"""Trouble helper exception | ||||
| 	 | ||||
| 	This is an exception to be handled with | ||||
| 	FileDownloader.trouble | ||||
| 	""" | ||||
| 
 | ||||
| class YoutubeDLHandler(urllib2.HTTPHandler): | ||||
| 	"""Handler for HTTP requests and responses. | ||||
| 
 | ||||
|  | ||||
		Loading…
	
		Reference in New Issue
	
	Block a user
	 Filippo Valsorda
						Filippo Valsorda