Install apm from npm, fixes #236.

This commit is contained in:
Cheng Zhao 2014-04-28 10:05:22 +08:00
parent 97006bcbc3
commit 3ccd90a690
4 changed files with 18 additions and 24 deletions

3
.gitmodules vendored
View file

@ -7,9 +7,6 @@
[submodule "vendor/depot_tools"]
path = vendor/depot_tools
url = https://chromium.googlesource.com/chromium/tools/depot_tools.git
[submodule "vendor/apm"]
path = vendor/apm
url = https://github.com/atom/apm.git
[submodule "vendor/breakpad"]
path = vendor/breakpad
url = https://github.com/atom/chromium-breakpad.git

View file

@ -3,6 +3,7 @@
"version": "0.11.10",
"devDependencies": {
"atom-package-manager": "0.41.x",
"coffee-script": "~1.6.3",
"coffeelint": "~0.6.1",
"formidable": "~1.0.14",

View file

@ -12,6 +12,7 @@ from lib.util import execute, scoped_cwd
SOURCE_ROOT = os.path.abspath(os.path.dirname(os.path.dirname(__file__)))
VENDOR_DIR = os.path.join(SOURCE_ROOT, 'vendor')
PYTHON_26_URL = 'https://chromium.googlesource.com/chromium/deps/python_26'
NPM = 'npm.cmd' if sys.platform == 'win32' else 'npm'
def main():
@ -19,8 +20,9 @@ def main():
args = parse_args()
update_submodules()
update_apm()
update_node_modules()
update_npm()
update_node_modules('.')
update_atom_modules('atom/browser/default_app')
bootstrap_brightray(args.url)
if sys.platform == 'cygwin':
update_win32_python()
@ -51,30 +53,25 @@ def bootstrap_brightray(url):
url])
def update_apm():
npm = 'npm.cmd' if sys.platform == 'win32' else 'npm'
def update_npm():
global NPM
if os.environ.get('CI') == '1':
execute([npm, 'install', 'npm'])
npm = os.path.join(SOURCE_ROOT, 'node_modules', '.bin', 'npm')
execute([NPM, 'install', 'npm'])
NPM = os.path.join(SOURCE_ROOT, 'node_modules', '.bin', 'npm')
if sys.platform == 'win32':
npm += '.cmd'
NPM += '.cmd'
with scoped_cwd(os.path.join('vendor', 'apm')):
execute([npm, 'install', '.'])
def update_node_modules():
for dirname in ['atom/browser/default_app', '.']:
update_node_modules_for_dir(dirname)
def update_node_modules_for_dir(dirname):
def update_node_modules(dirname):
with scoped_cwd(dirname):
apm = os.path.join(SOURCE_ROOT, 'vendor', 'apm', 'bin', 'apm')
execute([NPM, 'install'])
def update_atom_modules(dirname):
with scoped_cwd(dirname):
apm = os.path.join(SOURCE_ROOT, 'node_modules', '.bin', 'apm')
if sys.platform in ['win32', 'cygwin']:
apm += '.cmd'
subprocess.check_call([apm, 'install'])
execute([apm, 'install'])
def update_win32_python():

1
vendor/apm vendored

@ -1 +0,0 @@
Subproject commit 2ce1206e6720c133fd2acf53bebeb9b37de2b65a