diff options
Diffstat (limited to 'devscripts')
| -rwxr-xr-x | devscripts/bash-completion.py | 7 | ||||
| -rw-r--r-- | devscripts/buildserver.py | 5 | ||||
| -rw-r--r-- | devscripts/check-porn.py | 1 | ||||
| -rw-r--r-- | devscripts/fish-completion.in | 5 | ||||
| -rwxr-xr-x | devscripts/fish-completion.py | 48 | ||||
| -rwxr-xr-x | devscripts/gh-pages/add-version.py | 1 | ||||
| -rwxr-xr-x | devscripts/gh-pages/generate-download.py | 5 | ||||
| -rwxr-xr-x | devscripts/gh-pages/sign-versions.py | 20 | ||||
| -rwxr-xr-x | devscripts/gh-pages/update-copyright.py | 6 | ||||
| -rwxr-xr-x | devscripts/gh-pages/update-feed.py | 2 | ||||
| -rwxr-xr-x | devscripts/gh-pages/update-sites.py | 4 | ||||
| -rwxr-xr-x | devscripts/make_contributing.py | 32 | ||||
| -rwxr-xr-x | devscripts/make_readme.py | 2 | ||||
| -rw-r--r-- | devscripts/prepare_manpage.py | 1 | ||||
| -rwxr-xr-x | devscripts/release.sh | 1 | ||||
| -rw-r--r-- | devscripts/transition_helper.py | 40 | ||||
| -rw-r--r-- | devscripts/transition_helper_exe/setup.py | 12 | ||||
| -rw-r--r-- | devscripts/transition_helper_exe/youtube-dl.py | 102 | ||||
| -rw-r--r-- | devscripts/zsh-completion.in | 28 | ||||
| -rwxr-xr-x | devscripts/zsh-completion.py | 48 | 
20 files changed, 194 insertions, 176 deletions
| diff --git a/devscripts/bash-completion.py b/devscripts/bash-completion.py index 49287724d..cd26cc089 100755 --- a/devscripts/bash-completion.py +++ b/devscripts/bash-completion.py @@ -1,4 +1,6 @@  #!/usr/bin/env python +from __future__ import unicode_literals +  import os  from os.path import dirname as dirn  import sys @@ -9,16 +11,17 @@ import youtube_dl  BASH_COMPLETION_FILE = "youtube-dl.bash-completion"  BASH_COMPLETION_TEMPLATE = "devscripts/bash-completion.in" +  def build_completion(opt_parser):      opts_flag = []      for group in opt_parser.option_groups:          for option in group.option_list: -            #for every long flag +            # for every long flag              opts_flag.append(option.get_opt_string())      with open(BASH_COMPLETION_TEMPLATE) as f:          template = f.read()      with open(BASH_COMPLETION_FILE, "w") as f: -        #just using the special char +        # just using the special char          filled_template = template.replace("{{flags}}", " ".join(opts_flag))          f.write(filled_template) diff --git a/devscripts/buildserver.py b/devscripts/buildserver.py index e0c3cc83e..7c2f49f8b 100644 --- a/devscripts/buildserver.py +++ b/devscripts/buildserver.py @@ -142,7 +142,7 @@ def win_service_set_status(handle, status_code):  def win_service_main(service_name, real_main, argc, argv_raw):      try: -        #args = [argv_raw[i].value for i in range(argc)] +        # args = [argv_raw[i].value for i in range(argc)]          stop_event = threading.Event()          handler = HandlerEx(functools.partial(stop_event, win_service_handler))          h = advapi32.RegisterServiceCtrlHandlerExW(service_name, handler, None) @@ -233,6 +233,7 @@ def rmtree(path):  #============================================================================== +  class BuildError(Exception):      def __init__(self, output, code=500):          self.output = output @@ -369,7 +370,7 @@ class Builder(PythonBuilder, GITBuilder, YoutubeDLBuilder, DownloadBuilder, Clea  class BuildHTTPRequestHandler(BaseHTTPRequestHandler): -    actionDict = { 'build': Builder, 'download': Builder } # They're the same, no more caching. +    actionDict = {'build': Builder, 'download': Builder}  # They're the same, no more caching.      def do_GET(self):          path = urlparse.urlparse(self.path) diff --git a/devscripts/check-porn.py b/devscripts/check-porn.py index 86aa37b5f..216282712 100644 --- a/devscripts/check-porn.py +++ b/devscripts/check-porn.py @@ -1,4 +1,5 @@  #!/usr/bin/env python +from __future__ import unicode_literals  """  This script employs a VERY basic heuristic ('porn' in webpage.lower()) to check diff --git a/devscripts/fish-completion.in b/devscripts/fish-completion.in new file mode 100644 index 000000000..eb79765da --- /dev/null +++ b/devscripts/fish-completion.in @@ -0,0 +1,5 @@ + +{{commands}} + + +complete --command youtube-dl --arguments ":ytfavorites :ytrecommended :ytsubscriptions :ytwatchlater :ythistory" diff --git a/devscripts/fish-completion.py b/devscripts/fish-completion.py new file mode 100755 index 000000000..c2f238798 --- /dev/null +++ b/devscripts/fish-completion.py @@ -0,0 +1,48 @@ +#!/usr/bin/env python +from __future__ import unicode_literals + +import optparse +import os +from os.path import dirname as dirn +import sys + +sys.path.append(dirn(dirn((os.path.abspath(__file__))))) +import youtube_dl +from youtube_dl.utils import shell_quote + +FISH_COMPLETION_FILE = 'youtube-dl.fish' +FISH_COMPLETION_TEMPLATE = 'devscripts/fish-completion.in' + +EXTRA_ARGS = { +    'recode-video': ['--arguments', 'mp4 flv ogg webm mkv', '--exclusive'], + +    # Options that need a file parameter +    'download-archive': ['--require-parameter'], +    'cookies': ['--require-parameter'], +    'load-info': ['--require-parameter'], +    'batch-file': ['--require-parameter'], +} + + +def build_completion(opt_parser): +    commands = [] + +    for group in opt_parser.option_groups: +        for option in group.option_list: +            long_option = option.get_opt_string().strip('-') +            complete_cmd = ['complete', '--command', 'youtube-dl', '--long-option', long_option] +            if option._short_opts: +                complete_cmd += ['--short-option', option._short_opts[0].strip('-')] +            if option.help != optparse.SUPPRESS_HELP: +                complete_cmd += ['--description', option.help] +            complete_cmd.extend(EXTRA_ARGS.get(long_option, [])) +            commands.append(shell_quote(complete_cmd)) + +    with open(FISH_COMPLETION_TEMPLATE) as f: +        template = f.read() +    filled_template = template.replace('{{commands}}', '\n'.join(commands)) +    with open(FISH_COMPLETION_FILE, 'w') as f: +        f.write(filled_template) + +parser = youtube_dl.parseOpts()[0] +build_completion(parser) diff --git a/devscripts/gh-pages/add-version.py b/devscripts/gh-pages/add-version.py index 35865b2f3..867ea0048 100755 --- a/devscripts/gh-pages/add-version.py +++ b/devscripts/gh-pages/add-version.py @@ -1,4 +1,5 @@  #!/usr/bin/env python3 +from __future__ import unicode_literals  import json  import sys diff --git a/devscripts/gh-pages/generate-download.py b/devscripts/gh-pages/generate-download.py index 55912e12c..392e3ba21 100755 --- a/devscripts/gh-pages/generate-download.py +++ b/devscripts/gh-pages/generate-download.py @@ -1,8 +1,7 @@  #!/usr/bin/env python3 +from __future__ import unicode_literals +  import hashlib -import shutil -import subprocess -import tempfile  import urllib.request  import json diff --git a/devscripts/gh-pages/sign-versions.py b/devscripts/gh-pages/sign-versions.py index 8a824df56..fa389c358 100755 --- a/devscripts/gh-pages/sign-versions.py +++ b/devscripts/gh-pages/sign-versions.py @@ -1,4 +1,5 @@  #!/usr/bin/env python3 +from __future__ import unicode_literals, with_statement  import rsa  import json @@ -11,22 +12,23 @@ except NameError:  versions_info = json.load(open('update/versions.json'))  if 'signature' in versions_info: -	del versions_info['signature'] +    del versions_info['signature']  print('Enter the PKCS1 private key, followed by a blank line:')  privkey = b''  while True: -	try: -		line = input() -	except EOFError: -		break -	if line == '': -		break -	privkey += line.encode('ascii') + b'\n' +    try: +        line = input() +    except EOFError: +        break +    if line == '': +        break +    privkey += line.encode('ascii') + b'\n'  privkey = rsa.PrivateKey.load_pkcs1(privkey)  signature = hexlify(rsa.pkcs1.sign(json.dumps(versions_info, sort_keys=True).encode('utf-8'), privkey, 'SHA-256')).decode()  print('signature: ' + signature)  versions_info['signature'] = signature -json.dump(versions_info, open('update/versions.json', 'w'), indent=4, sort_keys=True)
\ No newline at end of file +with open('update/versions.json', 'w') as versionsf: +    json.dump(versions_info, versionsf, indent=4, sort_keys=True) diff --git a/devscripts/gh-pages/update-copyright.py b/devscripts/gh-pages/update-copyright.py index 12c2a9194..3663c8afe 100755 --- a/devscripts/gh-pages/update-copyright.py +++ b/devscripts/gh-pages/update-copyright.py @@ -1,11 +1,11 @@  #!/usr/bin/env python  # coding: utf-8 -from __future__ import with_statement +from __future__ import with_statement, unicode_literals  import datetime  import glob -import io # For Python 2 compatibilty +import io  # For Python 2 compatibilty  import os  import re @@ -13,7 +13,7 @@ year = str(datetime.datetime.now().year)  for fn in glob.glob('*.html*'):      with io.open(fn, encoding='utf-8') as f:          content = f.read() -    newc = re.sub(u'(?P<copyright>Copyright © 2006-)(?P<year>[0-9]{4})', u'Copyright © 2006-' + year, content) +    newc = re.sub(r'(?P<copyright>Copyright © 2006-)(?P<year>[0-9]{4})', 'Copyright © 2006-' + year, content)      if content != newc:          tmpFn = fn + '.part'          with io.open(tmpFn, 'wt', encoding='utf-8') as outf: diff --git a/devscripts/gh-pages/update-feed.py b/devscripts/gh-pages/update-feed.py index 0ba15ae0f..e93eb60fb 100755 --- a/devscripts/gh-pages/update-feed.py +++ b/devscripts/gh-pages/update-feed.py @@ -1,4 +1,5 @@  #!/usr/bin/env python3 +from __future__ import unicode_literals  import datetime  import io @@ -73,4 +74,3 @@ atom_template = atom_template.replace('@ENTRIES@', entries_str)  with io.open('update/releases.atom', 'w', encoding='utf-8') as atom_file:      atom_file.write(atom_template) - diff --git a/devscripts/gh-pages/update-sites.py b/devscripts/gh-pages/update-sites.py index 153e15c8a..f0f0481c7 100755 --- a/devscripts/gh-pages/update-sites.py +++ b/devscripts/gh-pages/update-sites.py @@ -1,4 +1,5 @@  #!/usr/bin/env python3 +from __future__ import unicode_literals  import sys  import os @@ -9,6 +10,7 @@ sys.path.append(os.path.dirname(os.path.dirname(os.path.dirname(os.path.abspath(  import youtube_dl +  def main():      with open('supportedsites.html.in', 'r', encoding='utf-8') as tmplf:          template = tmplf.read() @@ -21,7 +23,7 @@ def main():              continue          elif ie_desc is not None:              ie_html += ': {}'.format(ie.IE_DESC) -        if ie.working() == False: +        if not ie.working():              ie_html += ' (Currently broken)'          ie_htmls.append('<li>{}</li>'.format(ie_html)) diff --git a/devscripts/make_contributing.py b/devscripts/make_contributing.py new file mode 100755 index 000000000..5fa8cf851 --- /dev/null +++ b/devscripts/make_contributing.py @@ -0,0 +1,32 @@ +#!/usr/bin/env python +from __future__ import unicode_literals + +import argparse +import io +import re + + +def main(): +    parser = argparse.ArgumentParser() +    parser.add_argument( +        'INFILE', help='README.md file name to read from') +    parser.add_argument( +        'OUTFILE', help='CONTRIBUTING.md file name to write to') +    args = parser.parse_args() + +    with io.open(args.INFILE, encoding='utf-8') as inf: +        readme = inf.read() + +    bug_text = re.search( +        r'(?s)#\s*BUGS\s*[^\n]*\s*(.*?)#\s*COPYRIGHT', readme).group(1) +    dev_text = re.search( +        r'(?s)(#\s*DEVELOPER INSTRUCTIONS.*?)#\s*EMBEDDING YOUTUBE-DL', +        readme).group(1) + +    out = bug_text + dev_text + +    with io.open(args.OUTFILE, 'w', encoding='utf-8') as outf: +        outf.write(out) + +if __name__ == '__main__': +    main() diff --git a/devscripts/make_readme.py b/devscripts/make_readme.py index 70fa942dd..8fbce0796 100755 --- a/devscripts/make_readme.py +++ b/devscripts/make_readme.py @@ -1,3 +1,5 @@ +from __future__ import unicode_literals +  import io  import sys  import re diff --git a/devscripts/prepare_manpage.py b/devscripts/prepare_manpage.py index d9c857015..f66bebfea 100644 --- a/devscripts/prepare_manpage.py +++ b/devscripts/prepare_manpage.py @@ -1,3 +1,4 @@ +from __future__ import unicode_literals  import io  import os.path diff --git a/devscripts/release.sh b/devscripts/release.sh index 453087e5f..691517ceb 100755 --- a/devscripts/release.sh +++ b/devscripts/release.sh @@ -73,7 +73,6 @@ RELEASE_FILES="youtube-dl youtube-dl.exe youtube-dl-$version.tar.gz"  (cd build/$version/ && sha1sum $RELEASE_FILES > SHA1SUMS)  (cd build/$version/ && sha256sum $RELEASE_FILES > SHA2-256SUMS)  (cd build/$version/ && sha512sum $RELEASE_FILES > SHA2-512SUMS) -git checkout HEAD -- youtube-dl youtube-dl.exe  /bin/echo -e "\n### Signing and uploading the new binaries to yt-dl.org ..."  for f in $RELEASE_FILES; do gpg --passphrase-repeat 5 --detach-sig "build/$version/$f"; done diff --git a/devscripts/transition_helper.py b/devscripts/transition_helper.py deleted file mode 100644 index d5ca2d4ba..000000000 --- a/devscripts/transition_helper.py +++ /dev/null @@ -1,40 +0,0 @@ -#!/usr/bin/env python - -import sys, os - -try: -    import urllib.request as compat_urllib_request -except ImportError: # Python 2 -    import urllib2 as compat_urllib_request - -sys.stderr.write(u'Hi! We changed distribution method and now youtube-dl needs to update itself one more time.\n') -sys.stderr.write(u'This will only happen once. Simply press enter to go on. Sorry for the trouble!\n') -sys.stderr.write(u'The new location of the binaries is https://github.com/rg3/youtube-dl/downloads, not the git repository.\n\n') - -try: -	raw_input() -except NameError: # Python 3 -	input() - -filename = sys.argv[0] - -API_URL = "https://api.github.com/repos/rg3/youtube-dl/downloads" -BIN_URL = "https://github.com/downloads/rg3/youtube-dl/youtube-dl" - -if not os.access(filename, os.W_OK): -    sys.exit('ERROR: no write permissions on %s' % filename) - -try: -    urlh = compat_urllib_request.urlopen(BIN_URL) -    newcontent = urlh.read() -    urlh.close() -except (IOError, OSError) as err: -    sys.exit('ERROR: unable to download latest version') - -try: -    with open(filename, 'wb') as outf: -        outf.write(newcontent) -except (IOError, OSError) as err: -    sys.exit('ERROR: unable to overwrite current version') - -sys.stderr.write(u'Done! Now you can run youtube-dl.\n') diff --git a/devscripts/transition_helper_exe/setup.py b/devscripts/transition_helper_exe/setup.py deleted file mode 100644 index aaf5c2983..000000000 --- a/devscripts/transition_helper_exe/setup.py +++ /dev/null @@ -1,12 +0,0 @@ -from distutils.core import setup -import py2exe - -py2exe_options = { -    "bundle_files": 1, -    "compressed": 1, -    "optimize": 2, -    "dist_dir": '.', -    "dll_excludes": ['w9xpopen.exe'] -} - -setup(console=['youtube-dl.py'], options={ "py2exe": py2exe_options }, zipfile=None)
\ No newline at end of file diff --git a/devscripts/transition_helper_exe/youtube-dl.py b/devscripts/transition_helper_exe/youtube-dl.py deleted file mode 100644 index 6297dfd40..000000000 --- a/devscripts/transition_helper_exe/youtube-dl.py +++ /dev/null @@ -1,102 +0,0 @@ -#!/usr/bin/env python - -import sys, os -import urllib2 -import json, hashlib - -def rsa_verify(message, signature, key): -    from struct import pack -    from hashlib import sha256 -    from sys import version_info -    def b(x): -        if version_info[0] == 2: return x -        else: return x.encode('latin1') -    assert(type(message) == type(b(''))) -    block_size = 0 -    n = key[0] -    while n: -        block_size += 1 -        n >>= 8 -    signature = pow(int(signature, 16), key[1], key[0]) -    raw_bytes = [] -    while signature: -        raw_bytes.insert(0, pack("B", signature & 0xFF)) -        signature >>= 8 -    signature = (block_size - len(raw_bytes)) * b('\x00') + b('').join(raw_bytes) -    if signature[0:2] != b('\x00\x01'): return False -    signature = signature[2:] -    if not b('\x00') in signature: return False -    signature = signature[signature.index(b('\x00'))+1:] -    if not signature.startswith(b('\x30\x31\x30\x0D\x06\x09\x60\x86\x48\x01\x65\x03\x04\x02\x01\x05\x00\x04\x20')): return False -    signature = signature[19:] -    if signature != sha256(message).digest(): return False -    return True - -sys.stderr.write(u'Hi! We changed distribution method and now youtube-dl needs to update itself one more time.\n') -sys.stderr.write(u'This will only happen once. Simply press enter to go on. Sorry for the trouble!\n') -sys.stderr.write(u'From now on, get the binaries from http://rg3.github.com/youtube-dl/download.html, not from the git repository.\n\n') - -raw_input() - -filename = sys.argv[0] - -UPDATE_URL = "http://rg3.github.io/youtube-dl/update/" -VERSION_URL = UPDATE_URL + 'LATEST_VERSION' -JSON_URL = UPDATE_URL + 'versions.json' -UPDATES_RSA_KEY = (0x9d60ee4d8f805312fdb15a62f87b95bd66177b91df176765d13514a0f1754bcd2057295c5b6f1d35daa6742c3ffc9a82d3e118861c207995a8031e151d863c9927e304576bc80692bc8e094896fcf11b66f3e29e04e3a71e9a11558558acea1840aec37fc396fb6b65dc81a1c4144e03bd1c011de62e3f1357b327d08426fe93, 65537) - -if not os.access(filename, os.W_OK): -    sys.exit('ERROR: no write permissions on %s' % filename) - -exe = os.path.abspath(filename) -directory = os.path.dirname(exe) -if not os.access(directory, os.W_OK): -    sys.exit('ERROR: no write permissions on %s' % directory) - -try: -    versions_info = urllib2.urlopen(JSON_URL).read().decode('utf-8') -    versions_info = json.loads(versions_info) -except: -    sys.exit(u'ERROR: can\'t obtain versions info. Please try again later.') -if not 'signature' in versions_info: -    sys.exit(u'ERROR: the versions file is not signed or corrupted. Aborting.') -signature = versions_info['signature'] -del versions_info['signature'] -if not rsa_verify(json.dumps(versions_info, sort_keys=True), signature, UPDATES_RSA_KEY): -    sys.exit(u'ERROR: the versions file signature is invalid. Aborting.') - -version = versions_info['versions'][versions_info['latest']] - -try: -    urlh = urllib2.urlopen(version['exe'][0]) -    newcontent = urlh.read() -    urlh.close() -except (IOError, OSError) as err: -    sys.exit('ERROR: unable to download latest version') - -newcontent_hash = hashlib.sha256(newcontent).hexdigest() -if newcontent_hash != version['exe'][1]: -    sys.exit(u'ERROR: the downloaded file hash does not match. Aborting.') - -try: -    with open(exe + '.new', 'wb') as outf: -        outf.write(newcontent) -except (IOError, OSError) as err: -    sys.exit(u'ERROR: unable to write the new version') - -try: -    bat = os.path.join(directory, 'youtube-dl-updater.bat') -    b = open(bat, 'w') -    b.write(""" -echo Updating youtube-dl... -ping 127.0.0.1 -n 5 -w 1000 > NUL -move /Y "%s.new" "%s" -del "%s" -    \n""" %(exe, exe, bat)) -    b.close() - -    os.startfile(bat) -except (IOError, OSError) as err: -    sys.exit('ERROR: unable to overwrite current version') - -sys.stderr.write(u'Done! Now you can run youtube-dl.\n') diff --git a/devscripts/zsh-completion.in b/devscripts/zsh-completion.in new file mode 100644 index 000000000..b394a1ae7 --- /dev/null +++ b/devscripts/zsh-completion.in @@ -0,0 +1,28 @@ +#compdef youtube-dl + +__youtube_dl() { +    local curcontext="$curcontext" fileopts diropts cur prev +    typeset -A opt_args +    fileopts="{{fileopts}}" +    diropts="{{diropts}}" +    cur=$words[CURRENT] +    case $cur in +        :) +            _arguments '*: :(::ytfavorites ::ytrecommended ::ytsubscriptions ::ytwatchlater ::ythistory)' +        ;; +        *) +            prev=$words[CURRENT-1] +            if [[ ${prev} =~ ${fileopts} ]]; then +                _path_files +            elif [[ ${prev} =~ ${diropts} ]]; then +                _path_files -/ +            elif [[ ${prev} == "--recode-video" ]]; then +                _arguments '*: :(mp4 flv ogg webm mkv)' +            else +                _arguments '*: :({{flags}})' +            fi +        ;; +    esac +} + +__youtube_dl
\ No newline at end of file diff --git a/devscripts/zsh-completion.py b/devscripts/zsh-completion.py new file mode 100755 index 000000000..f200f2c80 --- /dev/null +++ b/devscripts/zsh-completion.py @@ -0,0 +1,48 @@ +#!/usr/bin/env python +from __future__ import unicode_literals + +import os +from os.path import dirname as dirn +import sys + +sys.path.append(dirn(dirn((os.path.abspath(__file__))))) +import youtube_dl + +ZSH_COMPLETION_FILE = "youtube-dl.zsh" +ZSH_COMPLETION_TEMPLATE = "devscripts/zsh-completion.in" + + +def build_completion(opt_parser): +    opts = [opt for group in opt_parser.option_groups +            for opt in group.option_list] +    opts_file = [opt for opt in opts if opt.metavar == "FILE"] +    opts_dir = [opt for opt in opts if opt.metavar == "DIR"] + +    fileopts = [] +    for opt in opts_file: +        if opt._short_opts: +            fileopts.extend(opt._short_opts) +        if opt._long_opts: +            fileopts.extend(opt._long_opts) + +    diropts = [] +    for opt in opts_dir: +        if opt._short_opts: +            diropts.extend(opt._short_opts) +        if opt._long_opts: +            diropts.extend(opt._long_opts) + +    flags = [opt.get_opt_string() for opt in opts] + +    with open(ZSH_COMPLETION_TEMPLATE) as f: +        template = f.read() + +    template = template.replace("{{fileopts}}", "|".join(fileopts)) +    template = template.replace("{{diropts}}", "|".join(diropts)) +    template = template.replace("{{flags}}", " ".join(flags)) + +    with open(ZSH_COMPLETION_FILE, "w") as f: +        f.write(template) + +parser = youtube_dl.parseOpts()[0] +build_completion(parser) | 
