From 07260731ca9c9771acfd16ab36924610fd72c16a Mon Sep 17 00:00:00 2001 From: Cheng Zhao Date: Thu, 20 Jun 2013 22:49:11 +0800 Subject: [PATCH] Rewrite update-node script in python. --- script/{bootstrap => bootstrap.py} | 0 script/update-node | 145 ++++++++++++++++++++++++----- 2 files changed, 122 insertions(+), 23 deletions(-) rename script/{bootstrap => bootstrap.py} (100%) diff --git a/script/bootstrap b/script/bootstrap.py similarity index 100% rename from script/bootstrap rename to script/bootstrap.py diff --git a/script/update-node b/script/update-node index 54edd321ce8..c406cfaff2e 100755 --- a/script/update-node +++ b/script/update-node @@ -1,31 +1,130 @@ -#!/bin/bash +#!/usr/bin/env python -set -e +import argparse +import atexit +import errno +import shutil +import subprocess +import sys +import tarfile +import tempfile +import os +import urllib2 -cd "$(dirname $0)/.." -NODE_VERSION=v0.10.5 -[ -z $1 ] || NODE_VERSION=$1 +SOURCE_ROOT = os.path.dirname(os.path.dirname(__file__)) +NODE_VERSION = 'v0.10.9' +NODE_DIST_URL = 'https://gh-contractor-zcbenz.s3.amazonaws.com/node/dist' +IS_POSIX = (sys.platform != 'win32') and (sys.platform != 'cygwin') -# Test whether we need update. -if [ -f "node/node" ] && [[ `node/node --version` == $NODE_VERSION ]] ; then - exit 0 -fi -case $OSTYPE in - darwin*) NODE_PLATFORM=darwin ;; - linux*) NODE_PLATFORM=linux ;; - *) echo "Unsupported platform $OSTYPE" && exit 1 ;; -esac +def main(): + os.chdir(SOURCE_ROOT) -NODE_DIST_NAME="node-$NODE_VERSION-$NODE_PLATFORM-x86" + args = parse_args() + if not node_needs_update(args.version): + return 0 -# Download node and untar -NODE_TARBALL_URL="https://gh-contractor-zcbenz.s3.amazonaws.com/node/dist/$NODE_DIST_NAME.tar.gz" -TARGET_DIR='node' -[ -d "$TARGET_DIR" ] || mkdir "$TARGET_DIR" -cd "$TARGET_DIR" -curl -fsSkL $NODE_TARBALL_URL | tar -zx || exit 1 + url, filename = get_node_url(args.url, args.version) + directory = download('Download node', url, filename) -cp "$NODE_DIST_NAME/bin/node" . -rm -rf "$NODE_DIST_NAME" + if IS_POSIX: + root_name = 'node-{0}-{1}-x86'.format(args.version, sys.platform) + member = os.path.join(root_name, 'bin', 'node') + extract_tarball(os.path.join(directory, filename), member, directory) + node_path = os.path.join(directory, member) + + copy_node(node_path) + + +def parse_args(): + parser = argparse.ArgumentParser(description='Update node binary') + parser.add_argument('--version', + help='Version of node', + default=NODE_VERSION, + required=False) + parser.add_argument('--url', + help='URL to download node', + default=NODE_DIST_URL, + required=False) + return parser.parse_args() + + +def node_needs_update(target_version): + try: + node = os.path.join('node', 'node') + if not IS_POSIX: + node += '.exe' + version = subprocess.check_output([node, '--version']) + return version.strip() != target_version + except OSError as e: + if e.errno != errno.ENOENT: + raise + return True + + +def get_node_url(base_url, target_version): + if IS_POSIX: + distname = 'node-{0}-{1}-x86.tar.gz'.format(target_version, sys.platform) + else: + distname = 'node-{0}.exe'.format(target_version) + return '{0}/{1}'.format(base_url, distname), distname + + +def copy_node(node_path): + safe_mkdir('node') + node = os.path.join('node', 'node') + safe_unlink(node) + 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())