Merge remote-tracking branch 'FiloSottille/vbr'
Conflicts: youtube-dl youtube-dl.exe
This commit is contained in:
		
						commit
						234e230c87
					
				| @ -21,6 +21,7 @@ which means you can modify it, redistribute it or use it however you like. | |||||||
|     -r, --rate-limit LIMIT   download rate limit (e.g. 50k or 44.6m) |     -r, --rate-limit LIMIT   download rate limit (e.g. 50k or 44.6m) | ||||||
|     -R, --retries RETRIES    number of retries (default is 10) |     -R, --retries RETRIES    number of retries (default is 10) | ||||||
|     --dump-user-agent        display the current browser identification |     --dump-user-agent        display the current browser identification | ||||||
|  |     --user-agent None        specify a custom user agent | ||||||
|     --list-extractors        List all supported extractors and the URLs they |     --list-extractors        List all supported extractors and the URLs they | ||||||
|                              would handle |                              would handle | ||||||
| 
 | 
 | ||||||
| @ -93,8 +94,9 @@ which means you can modify it, redistribute it or use it however you like. | |||||||
|                              ffmpeg or avconv and ffprobe or avprobe) |                              ffmpeg or avconv and ffprobe or avprobe) | ||||||
|     --audio-format FORMAT    "best", "aac", "vorbis", "mp3", "m4a", or "wav"; |     --audio-format FORMAT    "best", "aac", "vorbis", "mp3", "m4a", or "wav"; | ||||||
|                              best by default |                              best by default | ||||||
|     --audio-quality QUALITY  ffmpeg/avconv audio bitrate specification, 128k by |     --audio-quality QUALITY  ffmpeg/avconv audio quality specification, insert a | ||||||
|                              default |                              value between 0 (better) and 9 (worse) for VBR or a | ||||||
|  |                              specific bitrate like 128K (default 5) | ||||||
|     -k, --keep-video         keeps the video file on disk after the post- |     -k, --keep-video         keeps the video file on disk after the post- | ||||||
|                              processing; the video is erased by default |                              processing; the video is erased by default | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -25,6 +25,7 @@ redistribute it or use it however you like. | |||||||
| -r,\ --rate-limit\ LIMIT\ \ \ download\ rate\ limit\ (e.g.\ 50k\ or\ 44.6m) | -r,\ --rate-limit\ LIMIT\ \ \ download\ rate\ limit\ (e.g.\ 50k\ or\ 44.6m) | ||||||
| -R,\ --retries\ RETRIES\ \ \ \ number\ of\ retries\ (default\ is\ 10) | -R,\ --retries\ RETRIES\ \ \ \ number\ of\ retries\ (default\ is\ 10) | ||||||
| --dump-user-agent\ \ \ \ \ \ \ \ display\ the\ current\ browser\ identification | --dump-user-agent\ \ \ \ \ \ \ \ display\ the\ current\ browser\ identification | ||||||
|  | --user-agent\ None\ \ \ \ \ \ \ \ specify\ a\ custom\ user\ agent | ||||||
| --list-extractors\ \ \ \ \ \ \ \ List\ all\ supported\ extractors\ and\ the\ URLs\ they | --list-extractors\ \ \ \ \ \ \ \ List\ all\ supported\ extractors\ and\ the\ URLs\ they | ||||||
| \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ would\ handle | \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ would\ handle | ||||||
| \f[] | \f[] | ||||||
| @ -121,8 +122,9 @@ redistribute it or use it however you like. | |||||||
| \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ ffmpeg\ or\ avconv\ and\ ffprobe\ or\ avprobe) | \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ ffmpeg\ or\ avconv\ and\ ffprobe\ or\ avprobe) | ||||||
| --audio-format\ FORMAT\ \ \ \ "best",\ "aac",\ "vorbis",\ "mp3",\ "m4a",\ or\ "wav"; | --audio-format\ FORMAT\ \ \ \ "best",\ "aac",\ "vorbis",\ "mp3",\ "m4a",\ or\ "wav"; | ||||||
| \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ best\ by\ default | \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ best\ by\ default | ||||||
| --audio-quality\ QUALITY\ \ ffmpeg/avconv\ audio\ bitrate\ specification,\ 128k\ by | --audio-quality\ QUALITY\ \ ffmpeg/avconv\ audio\ quality\ specification,\ insert\ a | ||||||
| \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ default | \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ value\ between\ 0\ (better)\ and\ 9\ (worse)\ for\ VBR\ or\ a | ||||||
|  | \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ specific\ bitrate\ like\ 128K\ (default\ 5) | ||||||
| -k,\ --keep-video\ \ \ \ \ \ \ \ \ keeps\ the\ video\ file\ on\ disk\ after\ the\ post- | -k,\ --keep-video\ \ \ \ \ \ \ \ \ keeps\ the\ video\ file\ on\ disk\ after\ the\ post- | ||||||
| \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ processing;\ the\ video\ is\ erased\ by\ default | \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ processing;\ the\ video\ is\ erased\ by\ default | ||||||
| \f[] | \f[] | ||||||
|  | |||||||
| @ -3,7 +3,7 @@ __youtube-dl() | |||||||
|     local cur prev opts |     local cur prev opts | ||||||
|     COMPREPLY=() |     COMPREPLY=() | ||||||
|     cur="${COMP_WORDS[COMP_CWORD]}" |     cur="${COMP_WORDS[COMP_CWORD]}" | ||||||
|     opts="--all-formats --audio-format --audio-quality --auto-number --batch-file --console-title --continue --cookies --dump-user-agent --extract-audio --format --get-description --get-filename --get-format --get-thumbnail --get-title --get-url --help --ignore-errors --keep-video --list-extractors --list-formats --literal --match-title --max-downloads --max-quality --netrc --no-continue --no-mtime --no-overwrites --no-part --no-progress --output --password --playlist-end --playlist-start --prefer-free-formats --quiet --rate-limit --reject-title --retries --simulate --skip-download --srt-lang --title --update --username --verbose --version --write-description --write-info-json --write-srt" |     opts="--all-formats --audio-format --audio-quality --auto-number --batch-file --console-title --continue --cookies --dump-user-agent --extract-audio --format --get-description --get-filename --get-format --get-thumbnail --get-title --get-url --help --ignore-errors --keep-video --list-extractors --list-formats --literal --match-title --max-downloads --max-quality --netrc --no-continue --no-mtime --no-overwrites --no-part --no-progress --output --password --playlist-end --playlist-start --prefer-free-formats --quiet --rate-limit --reject-title --retries --simulate --skip-download --srt-lang --title --update --user-agent --username --verbose --version --write-description --write-info-json --write-srt" | ||||||
| 
 | 
 | ||||||
|     if [[ ${cur} == * ]] ; then |     if [[ ${cur} == * ]] ; then | ||||||
|         COMPREPLY=( $(compgen -W "${opts}" -- ${cur}) ) |         COMPREPLY=( $(compgen -W "${opts}" -- ${cur}) ) | ||||||
|  | |||||||
| @ -142,6 +142,9 @@ class FFmpegExtractAudioPP(PostProcessor): | |||||||
| 				extension = 'mp3' | 				extension = 'mp3' | ||||||
| 				more_opts = [] | 				more_opts = [] | ||||||
| 				if self._preferredquality is not None: | 				if self._preferredquality is not None: | ||||||
|  | 					if int(self._preferredquality) < 10: | ||||||
|  | 						more_opts += [self._exes['avconv'] and '-q:a' or '-aq', self._preferredquality] | ||||||
|  | 					else: | ||||||
| 						more_opts += [self._exes['avconv'] and '-b:a' or '-ab', self._preferredquality] | 						more_opts += [self._exes['avconv'] and '-b:a' or '-ab', self._preferredquality] | ||||||
| 		else: | 		else: | ||||||
| 			# We convert the audio (lossy) | 			# We convert the audio (lossy) | ||||||
| @ -149,6 +152,9 @@ class FFmpegExtractAudioPP(PostProcessor): | |||||||
| 			extension = self._preferredcodec | 			extension = self._preferredcodec | ||||||
| 			more_opts = [] | 			more_opts = [] | ||||||
| 			if self._preferredquality is not None: | 			if self._preferredquality is not None: | ||||||
|  | 				if int(self._preferredquality) < 10: | ||||||
|  | 					more_opts += [self._exes['avconv'] and '-q:a' or '-aq', self._preferredquality] | ||||||
|  | 				else: | ||||||
| 					more_opts += [self._exes['avconv'] and '-b:a' or '-ab', self._preferredquality] | 					more_opts += [self._exes['avconv'] and '-b:a' or '-ab', self._preferredquality] | ||||||
| 			if self._preferredcodec == 'aac': | 			if self._preferredcodec == 'aac': | ||||||
| 				more_opts += ['-f', 'adts'] | 				more_opts += ['-f', 'adts'] | ||||||
|  | |||||||
| @ -298,8 +298,8 @@ def parseOpts(): | |||||||
| 			help='convert video files to audio-only files (requires ffmpeg or avconv and ffprobe or avprobe)') | 			help='convert video files to audio-only files (requires ffmpeg or avconv and ffprobe or avprobe)') | ||||||
| 	postproc.add_option('--audio-format', metavar='FORMAT', dest='audioformat', default='best', | 	postproc.add_option('--audio-format', metavar='FORMAT', dest='audioformat', default='best', | ||||||
| 			help='"best", "aac", "vorbis", "mp3", "m4a", or "wav"; best by default') | 			help='"best", "aac", "vorbis", "mp3", "m4a", or "wav"; best by default') | ||||||
| 	postproc.add_option('--audio-quality', metavar='QUALITY', dest='audioquality', default='128K', | 	postproc.add_option('--audio-quality', metavar='QUALITY', dest='audioquality', default='5', | ||||||
| 			help='ffmpeg/avconv audio bitrate specification, 128k by default') | 			help='ffmpeg/avconv audio quality specification, insert a value between 0 (better) and 9 (worse) for VBR or a specific bitrate like 128K (default 5)') | ||||||
| 	postproc.add_option('-k', '--keep-video', action='store_true', dest='keepvideo', default=False, | 	postproc.add_option('-k', '--keep-video', action='store_true', dest='keepvideo', default=False, | ||||||
| 			help='keeps the video file on disk after the post-processing; the video is erased by default') | 			help='keeps the video file on disk after the post-processing; the video is erased by default') | ||||||
| 
 | 
 | ||||||
| @ -451,6 +451,10 @@ def _real_main(): | |||||||
| 	if opts.extractaudio: | 	if opts.extractaudio: | ||||||
| 		if opts.audioformat not in ['best', 'aac', 'mp3', 'vorbis', 'm4a', 'wav']: | 		if opts.audioformat not in ['best', 'aac', 'mp3', 'vorbis', 'm4a', 'wav']: | ||||||
| 			parser.error(u'invalid audio format specified') | 			parser.error(u'invalid audio format specified') | ||||||
|  | 	if opts.audioquality: | ||||||
|  | 		opts.audioquality = opts.audioquality.strip('k').strip('K') | ||||||
|  | 		if not opts.audioquality.isdigit(): | ||||||
|  | 			parser.error(u'invalid audio quality specified') | ||||||
| 
 | 
 | ||||||
| 	# File downloader | 	# File downloader | ||||||
| 	fd = FileDownloader({ | 	fd = FileDownloader({ | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user