Remove the download script.
This commit is contained in:
parent
5845740844
commit
b17a6c9887
1 changed files with 0 additions and 103 deletions
103
script/download
103
script/download
|
@ -1,103 +0,0 @@
|
|||
#!/usr/bin/env python
|
||||
|
||||
import argparse
|
||||
import contextlib
|
||||
import errno
|
||||
import os
|
||||
import shutil
|
||||
import subprocess
|
||||
import sys
|
||||
import tempfile
|
||||
import urllib2
|
||||
import zipfile
|
||||
|
||||
|
||||
SOURCE_ROOT = os.path.abspath(os.path.dirname(os.path.dirname(__file__)))
|
||||
|
||||
|
||||
class ProgramError(Exception):
|
||||
pass
|
||||
|
||||
|
||||
def main():
|
||||
try:
|
||||
args = parse_args()
|
||||
commit = head_commit()
|
||||
download_if_needed(args.path, args.url, commit, force=args.force)
|
||||
except ProgramError as e:
|
||||
return e.message
|
||||
|
||||
|
||||
def parse_args():
|
||||
parser = argparse.ArgumentParser(description='Download and extract '
|
||||
'atom-shell')
|
||||
parser.add_argument('-f', '--force', action='store_true',
|
||||
help='Overwrite destination if it already exists.')
|
||||
parser.add_argument('url', help='The base URL from which to download '
|
||||
'(i.e., the URL you passed to script/upload)')
|
||||
parser.add_argument('path', help='The path to extract to')
|
||||
return parser.parse_args()
|
||||
|
||||
|
||||
def head_commit():
|
||||
args = [
|
||||
'git',
|
||||
'--git-dir',
|
||||
os.path.join(SOURCE_ROOT, '.git'),
|
||||
'rev-parse',
|
||||
'HEAD',
|
||||
]
|
||||
return subprocess.check_output(args).strip()
|
||||
|
||||
|
||||
def download_if_needed(destination, base_url, commit, force):
|
||||
version_file = os.path.join(destination, '.version')
|
||||
existing_version = ''
|
||||
try:
|
||||
with open(version_file, 'r') as f:
|
||||
existing_version = f.readline().strip()
|
||||
except IOError as e:
|
||||
if e.errno != errno.ENOENT:
|
||||
raise
|
||||
if existing_version == commit:
|
||||
return
|
||||
|
||||
if force:
|
||||
rm_rf(destination)
|
||||
elif os.path.exists(destination):
|
||||
raise ProgramError('Error: {0} already exists. Pass --force if you '
|
||||
'want to overwrite it.'.format(destination))
|
||||
sys.stderr.write('Downloading atom-shell {0}...\n'.format(commit))
|
||||
sys.stderr.flush()
|
||||
download_and_extract(destination, '{0}/{1}/atom-shell.zip'.format(base_url, commit))
|
||||
with open(version_file, 'w') as f:
|
||||
f.write('{0}\n'.format(commit))
|
||||
|
||||
|
||||
def download_and_extract(destination, url):
|
||||
print url
|
||||
with tempfile.TemporaryFile() as t:
|
||||
with contextlib.closing(urllib2.urlopen(url)) as u:
|
||||
while True:
|
||||
chunk = u.read(1024*1024)
|
||||
if not len(chunk):
|
||||
break
|
||||
sys.stderr.write('.')
|
||||
sys.stderr.flush()
|
||||
t.write(chunk)
|
||||
sys.stderr.write('\nExtracting...\n')
|
||||
sys.stderr.flush()
|
||||
with zipfile.ZipFile(t) as z:
|
||||
z.extractall(destination)
|
||||
|
||||
|
||||
def rm_rf(path):
|
||||
try:
|
||||
shutil.rmtree(path)
|
||||
except OSError as e:
|
||||
if e.errno != errno.ENOENT:
|
||||
raise
|
||||
|
||||
|
||||
if __name__ == '__main__':
|
||||
sys.exit(main())
|
Loading…
Add table
Reference in a new issue