better cross platform support

This commit is contained in:
Mathias Buus 2014-10-20 13:56:49 +09:00
parent 359504809b
commit c1dc3e09a8
5 changed files with 22 additions and 10 deletions

5
npm/.gitignore vendored
View file

@ -1,5 +1,4 @@
node_modules node_modules
*.zip *.zip
darwin/ dist
win32/ run.bat
linux/

View file

@ -1,2 +0,0 @@
#!/bin/bash
./darwin/Atom.app/Contents/MacOS/Atom

3
npm/index.js Normal file
View file

@ -0,0 +1,3 @@
var fs = require('fs')
var path = require('path')
module.exports = fs.readFileSync(path.join(__dirname, 'run.bat'), 'utf-8')

View file

@ -4,18 +4,30 @@ var os = require('os')
var path = require('path') var path = require('path')
var nugget = require('nugget') var nugget = require('nugget')
var extract = require('extract-zip') var extract = require('extract-zip')
var fs = require('fs')
var platform = os.platform()
var arch = os.arch()
var version = '0.18.0' var version = '0.18.0'
var name = version+'-atom-shell.zip' var name = 'atom-shell-v'+version+'-'+platform+'-'+arch+'.zip'
var url = 'https://github.com/atom/atom-shell/releases/download/v'+version+'/atom-shell-v'+version+'-'+os.platform()+'-'+os.arch()+'.zip' var url = 'https://github.com/atom/atom-shell/releases/download/v'+version+'/atom-shell-v'+version+'-'+platform+'-'+arch+'.zip'
var onerror = function(err) { var onerror = function(err) {
throw err throw err
} }
var paths = {
darwin: path.join(__dirname, './dist/Atom.app/Contents/MacOS/Atom'),
linux: path.join(__dirname, './dist/atom'),
win32: path.join(__dirname, './dist/atom.exe')
}
if (!paths[platform]) throw new Error('Unknown platform: '+platform)
nugget(url, {target:name, dir:__dirname, resume:true}, function(err) { nugget(url, {target:name, dir:__dirname, resume:true}, function(err) {
if (err) return onerror(err) if (err) return onerror(err)
extract(path.join(__dirname, name), {dir:path.join(__dirname, os.platform())}, function(err) { fs.writeFileSync(path.join(__dirname, 'run.bat'), paths[platform])
extract(path.join(__dirname, name), {dir:path.join(__dirname, 'dist')}, function(err) {
if (err) return onerror(err) if (err) return onerror(err)
}) })
}) })

View file

@ -10,9 +10,9 @@
"install": "./install.js" "install": "./install.js"
}, },
"bin": { "bin": {
"atom-shell": "./darwin.sh" "atom-shell": "run.bat"
}, },
"main": "install.js", "main": "index.js",
"dependencies": { "dependencies": {
"extract-zip": "^1.0.3", "extract-zip": "^1.0.3",
"nugget": "^1.1.2" "nugget": "^1.1.2"