about summary refs log tree commit diff
diff options
context:
space:
mode:
authorPhilipp Hagemeister <phihag@phihag.de>2011-09-13 21:51:44 +0200
committerPhilipp Hagemeister <phihag@phihag.de>2011-09-13 21:51:44 +0200
commitf166bccc8f4366531783d0e0c4c1eb3a585cdfb0 (patch)
treefe39d9cc1fa679ccbbfac0fd66ab6ae841c33bde
parent5a2ba45e09aca26f3277089194f963e4e8ae1909 (diff)
downloadyoutube-dl-f166bccc8f4366531783d0e0c4c1eb3a585cdfb0.tar.gz
youtube-dl-f166bccc8f4366531783d0e0c4c1eb3a585cdfb0.tar.xz
youtube-dl-f166bccc8f4366531783d0e0c4c1eb3a585cdfb0.zip
Allow downloading current thedailyshow episode with youtube-dl :tds
-rwxr-xr-xyoutube-dl32
1 files changed, 28 insertions, 4 deletions
diff --git a/youtube-dl b/youtube-dl
index 1b2ccae2f..9d379dcd1 100755
--- a/youtube-dl
+++ b/youtube-dl
@@ -3037,9 +3037,9 @@ class MyVideoIE(InfoExtractor):
 			self._downloader.trouble(u'\nERROR: Unable to download video')
 
 class ComedyCentralIE(InfoExtractor):
-	"""Information extractor for blip.tv"""
+	"""Information extractor for The Daily Show and Colbert Report """
 
-	_VALID_URL = r'^(?:https?://)?(www\.)?(thedailyshow|colbertnation)\.com/full-episodes/(.*)$'
+	_VALID_URL = r'^(:(?P<shortname>tds|thedailyshow|cr|colbert|colbertnation|colbertreport))|(https?://)?(www\.)(?P<showname>thedailyshow|colbertnation)\.com/full-episodes/(?P<episode>.*)$'
 
 	@staticmethod
 	def suitable(url):
@@ -3064,15 +3064,39 @@ class ComedyCentralIE(InfoExtractor):
 		if mobj is None:
 			self._downloader.trouble(u'ERROR: invalid URL: %s' % url)
 			return
-		epTitle = mobj.group(3)
+
+		if mobj.group('shortname'):
+			if mobj.group('shortname') in ('tds', 'thedailyshow'):
+				url = 'http://www.thedailyshow.com/full-episodes/'
+			else:
+				url = 'http://www.colbertnation.com/full-episodes/'
+			mobj = re.match(self._VALID_URL, url)
+			assert mobj is not None
+
+		dlNewest = not mobj.group('episode')
+		if dlNewest:
+			epTitle = mobj.group('showname')
+		else:
+			epTitle = mobj.group('episode')
 
 		req = urllib2.Request(url)
 		self.report_extraction(epTitle)
 		try:
-			html = urllib2.urlopen(req).read()
+			htmlHandle = urllib2.urlopen(req)
+			html = htmlHandle.read()
 		except (urllib2.URLError, httplib.HTTPException, socket.error), err:
 			self._downloader.trouble(u'ERROR: unable to download webpage: %s' % unicode(err))
 			return
+		if dlNewest:
+			url = htmlHandle.geturl()
+			mobj = re.match(self._VALID_URL, url)
+			if mobj is None:
+				self._downloader.trouble(u'ERROR: Invalid redirected URL: ' + url)
+				return
+			if mobj.group('episode') == '':
+				self._downloader.trouble(u'ERROR: Redirected URL is still not specific: ' + url)
+				return
+			epTitle = mobj.group('episode')
 
 		mMovieParams = re.findall('<param name="movie" value="(http://media.mtvnservices.com/(.*?:episode:([^:]*):)(.*?))"/>', html)
 		if len(mMovieParams) == 0: