Move helper functions into a common module.

This commit is contained in:
Cheng Zhao 2013-06-20 22:51:58 +08:00
parent 07260731ca
commit 9983e7c0ba
4 changed files with 56 additions and 53 deletions

1
.gitignore vendored
View file

@ -10,3 +10,4 @@ out/
vendor/
*.xcodeproj
*.swp
*.pyc

0
script/lib/__init__.py Normal file
View file

53
script/lib/util.py Normal file
View file

@ -0,0 +1,53 @@
import atexit
import shutil
import tarfile
import tempfile
import urllib2
def download(text, url, filename):
directory = tempfile.mkdtemp(prefix='atom-shell-')
atexit.register(shutil.rmtree, directory)
web_file = urllib2.urlopen(url)
file_size = int(web_file.info().getheaders("Content-Length")[0])
downloaded_size = 0
block_size = 128
with open(os.path.join(directory, filename), 'w+') as local_file:
while True:
buf = web_file.read(block_size)
if not buf:
break
downloaded_size += len(buf)
local_file.write(buf)
percent = downloaded_size * 100. / file_size
status = "\r%s %10d [%3.1f%%]" % (text, downloaded_size, percent)
print status,
print
return directory
def extract_tarball(tarball_path, member, path):
with tarfile.open(tarball_path) as tarball:
tarball.extract(member, path)
def safe_unlink(path):
try:
os.unlink(path)
except OSError as e:
if e.errno != errno.ENOENT:
raise
def safe_mkdir(path):
try:
os.makedirs(path)
except OSError as e:
if e.errno != errno.EEXIST:
raise

View file

@ -1,15 +1,12 @@
#!/usr/bin/env python
import argparse
import atexit
import errno
import shutil
import subprocess
import sys
import tarfile
import tempfile
import os
import urllib2
from lib.util import *
SOURCE_ROOT = os.path.dirname(os.path.dirname(__file__))
@ -78,53 +75,5 @@ def copy_node(node_path):
os.rename(node_path, node)
def download(text, url, filename):
directory = tempfile.mkdtemp(prefix='atom-shell-')
atexit.register(shutil.rmtree, directory)
web_file = urllib2.urlopen(url)
file_size = int(web_file.info().getheaders("Content-Length")[0])
downloaded_size = 0
block_size = 128
with open(os.path.join(directory, filename), 'w+') as local_file:
while True:
buf = web_file.read(block_size)
if not buf:
break
downloaded_size += len(buf)
local_file.write(buf)
percent = downloaded_size * 100. / file_size
status = "\r%s %10d [%3.1f%%]" % (text, downloaded_size, percent)
print status,
print
return directory
def extract_tarball(tarball_path, member, path):
with tarfile.open(tarball_path) as tarball:
tarball.extract(member, path)
def safe_unlink(path):
try:
os.unlink(path)
except OSError as e:
if e.errno != errno.ENOENT:
raise
def safe_mkdir(path):
try:
os.makedirs(path)
except OSError as e:
if e.errno != errno.EEXIST:
raise
if __name__ == '__main__':
sys.exit(main())