mirror of
				https://github.com/yt-dlp/yt-dlp.git
				synced 2025-10-26 20:21:05 +00:00 
			
		
		
		
	[extractor/common] Prefix f4m/m3u8 entries with identifier
This commit is contained in:
		
							parent
							
								
									1b0f3919c1
								
							
						
					
					
						commit
						60ca389c64
					
				| @ -765,7 +765,7 @@ def _sleep(self, timeout, video_id, msg_template=None): | |||||||
|         self.to_screen(msg) |         self.to_screen(msg) | ||||||
|         time.sleep(timeout) |         time.sleep(timeout) | ||||||
| 
 | 
 | ||||||
|     def _extract_f4m_formats(self, manifest_url, video_id): |     def _extract_f4m_formats(self, manifest_url, video_id, preference=None, f4m_id=None): | ||||||
|         manifest = self._download_xml( |         manifest = self._download_xml( | ||||||
|             manifest_url, video_id, 'Downloading f4m manifest', |             manifest_url, video_id, 'Downloading f4m manifest', | ||||||
|             'Unable to download f4m manifest') |             'Unable to download f4m manifest') | ||||||
| @ -780,24 +780,25 @@ def _extract_f4m_formats(self, manifest_url, video_id): | |||||||
|             if manifest_version == '2.0': |             if manifest_version == '2.0': | ||||||
|                 manifest_url = '/'.join(manifest_url.split('/')[:-1]) + '/' + media_el.attrib.get('href') |                 manifest_url = '/'.join(manifest_url.split('/')[:-1]) + '/' + media_el.attrib.get('href') | ||||||
|             tbr = int_or_none(media_el.attrib.get('bitrate')) |             tbr = int_or_none(media_el.attrib.get('bitrate')) | ||||||
|             format_id = 'f4m-%d' % (i if tbr is None else tbr) |  | ||||||
|             formats.append({ |             formats.append({ | ||||||
|                 'format_id': format_id, |                 'format_id': '-'.join(filter(None, [f4m_id, 'f4m-%d' % (i if tbr is None else tbr)])), | ||||||
|                 'url': manifest_url, |                 'url': manifest_url, | ||||||
|                 'ext': 'flv', |                 'ext': 'flv', | ||||||
|                 'tbr': tbr, |                 'tbr': tbr, | ||||||
|                 'width': int_or_none(media_el.attrib.get('width')), |                 'width': int_or_none(media_el.attrib.get('width')), | ||||||
|                 'height': int_or_none(media_el.attrib.get('height')), |                 'height': int_or_none(media_el.attrib.get('height')), | ||||||
|  |                 'preference': preference, | ||||||
|             }) |             }) | ||||||
|         self._sort_formats(formats) |         self._sort_formats(formats) | ||||||
| 
 | 
 | ||||||
|         return formats |         return formats | ||||||
| 
 | 
 | ||||||
|     def _extract_m3u8_formats(self, m3u8_url, video_id, ext=None, |     def _extract_m3u8_formats(self, m3u8_url, video_id, ext=None, | ||||||
|                               entry_protocol='m3u8', preference=None): |                               entry_protocol='m3u8', preference=None, | ||||||
|  |                               m3u8_id=None): | ||||||
| 
 | 
 | ||||||
|         formats = [{ |         formats = [{ | ||||||
|             'format_id': 'm3u8-meta', |             'format_id': '-'.join(filter(None, [m3u8_id, 'm3u8-meta'])), | ||||||
|             'url': m3u8_url, |             'url': m3u8_url, | ||||||
|             'ext': ext, |             'ext': ext, | ||||||
|             'protocol': 'm3u8', |             'protocol': 'm3u8', | ||||||
| @ -833,9 +834,8 @@ def _extract_m3u8_formats(self, m3u8_url, video_id, ext=None, | |||||||
|                     formats.append({'url': format_url(line)}) |                     formats.append({'url': format_url(line)}) | ||||||
|                     continue |                     continue | ||||||
|                 tbr = int_or_none(last_info.get('BANDWIDTH'), scale=1000) |                 tbr = int_or_none(last_info.get('BANDWIDTH'), scale=1000) | ||||||
| 
 |  | ||||||
|                 f = { |                 f = { | ||||||
|                     'format_id': 'm3u8-%d' % (tbr if tbr else len(formats)), |                     'format_id': '-'.join(filter(None, [m3u8_id, 'm3u8-%d' % (tbr if tbr else len(formats))])), | ||||||
|                     'url': format_url(line.strip()), |                     'url': format_url(line.strip()), | ||||||
|                     'tbr': tbr, |                     'tbr': tbr, | ||||||
|                     'ext': ext, |                     'ext': ext, | ||||||
|  | |||||||
		Loading…
	
		Reference in New Issue
	
	Block a user
	 Sergey M․
						Sergey M․