Merge branch 'binary-tarballs' into v0.8
This commit is contained in:
commit
a23df7710a
80
Makefile
80
Makefile
@ -192,8 +192,20 @@ docclean:
|
|||||||
-rm -rf out/doc
|
-rm -rf out/doc
|
||||||
|
|
||||||
VERSION=v$(shell $(PYTHON) tools/getnodeversion.py)
|
VERSION=v$(shell $(PYTHON) tools/getnodeversion.py)
|
||||||
|
PLATFORM=$(shell uname | tr '[:upper:]' '[:lower:]')
|
||||||
|
ifeq ($(DESTCPU),x64)
|
||||||
|
ARCH=x86_64
|
||||||
|
else
|
||||||
|
ifeq ($(DESTCPU),ia32)
|
||||||
|
ARCH=i386
|
||||||
|
else
|
||||||
|
ARCH=$(shell uname -m)
|
||||||
|
endif
|
||||||
|
endif
|
||||||
TARNAME=node-$(VERSION)
|
TARNAME=node-$(VERSION)
|
||||||
TARBALL=$(TARNAME).tar.gz
|
TARBALL=$(TARNAME).tar.gz
|
||||||
|
BINARYNAME=$(TARNAME)-$(PLATFORM)-$(ARCH)
|
||||||
|
BINARYTAR=$(BINARYNAME).tar.gz
|
||||||
PKG=out/$(TARNAME).pkg
|
PKG=out/$(TARNAME).pkg
|
||||||
packagemaker=/Developer/Applications/Utilities/PackageMaker.app/Contents/MacOS/PackageMaker
|
packagemaker=/Developer/Applications/Utilities/PackageMaker.app/Contents/MacOS/PackageMaker
|
||||||
|
|
||||||
@ -201,30 +213,7 @@ dist: doc $(TARBALL) $(PKG)
|
|||||||
|
|
||||||
PKGDIR=out/dist-osx
|
PKGDIR=out/dist-osx
|
||||||
|
|
||||||
pkg: $(PKG)
|
release-only:
|
||||||
|
|
||||||
$(PKG):
|
|
||||||
rm -rf $(PKGDIR)
|
|
||||||
rm -rf out/deps out/Release
|
|
||||||
./configure --prefix=$(PKGDIR)/32/usr/local --without-snapshot --dest-cpu=ia32
|
|
||||||
$(MAKE) install V=$(V)
|
|
||||||
rm -rf out/deps out/Release
|
|
||||||
./configure --prefix=$(PKGDIR)/usr/local --without-snapshot --dest-cpu=x64
|
|
||||||
$(MAKE) install V=$(V)
|
|
||||||
SIGN="$(SIGN)" PKGDIR="$(PKGDIR)" bash tools/osx-codesign.sh
|
|
||||||
lipo $(PKGDIR)/32/usr/local/bin/node \
|
|
||||||
$(PKGDIR)/usr/local/bin/node \
|
|
||||||
-output $(PKGDIR)/usr/local/bin/node-universal \
|
|
||||||
-create
|
|
||||||
mv $(PKGDIR)/usr/local/bin/node-universal $(PKGDIR)/usr/local/bin/node
|
|
||||||
rm -rf $(PKGDIR)/32
|
|
||||||
$(packagemaker) \
|
|
||||||
--id "org.nodejs.Node" \
|
|
||||||
--doc tools/osx-pkg.pmdoc \
|
|
||||||
--out $(PKG)
|
|
||||||
SIGN="$(SIGN)" PKG="$(PKG)" bash tools/osx-productsign.sh
|
|
||||||
|
|
||||||
$(TARBALL): node doc
|
|
||||||
@if [ "$(shell git status --porcelain | egrep -v '^\?\? ')" = "" ]; then \
|
@if [ "$(shell git status --porcelain | egrep -v '^\?\? ')" = "" ]; then \
|
||||||
exit 0 ; \
|
exit 0 ; \
|
||||||
else \
|
else \
|
||||||
@ -245,6 +234,31 @@ $(TARBALL): node doc
|
|||||||
echo "" >&2 ; \
|
echo "" >&2 ; \
|
||||||
exit 1 ; \
|
exit 1 ; \
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
pkg: $(PKG)
|
||||||
|
|
||||||
|
$(PKG): release-only
|
||||||
|
rm -rf $(PKGDIR)
|
||||||
|
rm -rf out/deps out/Release
|
||||||
|
./configure --prefix=$(PKGDIR)/32/usr/local --without-snapshot --dest-cpu=ia32
|
||||||
|
$(MAKE) install V=$(V)
|
||||||
|
rm -rf out/deps out/Release
|
||||||
|
./configure --prefix=$(PKGDIR)/usr/local --without-snapshot --dest-cpu=x64
|
||||||
|
$(MAKE) install V=$(V)
|
||||||
|
SIGN="$(SIGN)" PKGDIR="$(PKGDIR)" bash tools/osx-codesign.sh
|
||||||
|
lipo $(PKGDIR)/32/usr/local/bin/node \
|
||||||
|
$(PKGDIR)/usr/local/bin/node \
|
||||||
|
-output $(PKGDIR)/usr/local/bin/node-universal \
|
||||||
|
-create
|
||||||
|
mv $(PKGDIR)/usr/local/bin/node-universal $(PKGDIR)/usr/local/bin/node
|
||||||
|
rm -rf $(PKGDIR)/32
|
||||||
|
$(packagemaker) \
|
||||||
|
--id "org.nodejs.Node" \
|
||||||
|
--doc tools/osx-pkg.pmdoc \
|
||||||
|
--out $(PKG)
|
||||||
|
SIGN="$(SIGN)" PKG="$(PKG)" bash tools/osx-productsign.sh
|
||||||
|
|
||||||
|
$(TARBALL): release-only node doc
|
||||||
git archive --format=tar --prefix=$(TARNAME)/ HEAD | tar xf -
|
git archive --format=tar --prefix=$(TARNAME)/ HEAD | tar xf -
|
||||||
mkdir -p $(TARNAME)/doc/api
|
mkdir -p $(TARNAME)/doc/api
|
||||||
cp doc/node.1 $(TARNAME)/doc/node.1
|
cp doc/node.1 $(TARNAME)/doc/node.1
|
||||||
@ -256,6 +270,22 @@ $(TARBALL): node doc
|
|||||||
rm -rf $(TARNAME)
|
rm -rf $(TARNAME)
|
||||||
gzip -f -9 $(TARNAME).tar
|
gzip -f -9 $(TARNAME).tar
|
||||||
|
|
||||||
|
tar: $(TARBALL)
|
||||||
|
|
||||||
|
$(BINARYTAR): release-only
|
||||||
|
rm -rf $(BINARYNAME)
|
||||||
|
rm -rf out/deps out/Release
|
||||||
|
./configure --prefix=/ --without-snapshot --dest-cpu=$(DESTCPU)
|
||||||
|
$(MAKE) install DESTDIR=$(BINARYNAME) V=$(V) PORTABLE=1
|
||||||
|
cp README.md $(BINARYNAME)
|
||||||
|
cp LICENSE $(BINARYNAME)
|
||||||
|
cp ChangeLog $(BINARYNAME)
|
||||||
|
tar -cf $(BINARYNAME).tar $(BINARYNAME)
|
||||||
|
rm -rf $(BINARYNAME)
|
||||||
|
gzip -f -9 $(BINARYNAME).tar
|
||||||
|
|
||||||
|
binary: $(BINARYTAR)
|
||||||
|
|
||||||
dist-upload: $(TARBALL) $(PKG)
|
dist-upload: $(TARBALL) $(PKG)
|
||||||
ssh node@nodejs.org mkdir -p web/nodejs.org/dist/$(VERSION)
|
ssh node@nodejs.org mkdir -p web/nodejs.org/dist/$(VERSION)
|
||||||
scp $(TARBALL) node@nodejs.org:~/web/nodejs.org/dist/$(VERSION)/$(TARBALL)
|
scp $(TARBALL) node@nodejs.org:~/web/nodejs.org/dist/$(VERSION)/$(TARBALL)
|
||||||
@ -280,4 +310,4 @@ cpplint:
|
|||||||
|
|
||||||
lint: jslint cpplint
|
lint: jslint cpplint
|
||||||
|
|
||||||
.PHONY: lint cpplint jslint bench clean docopen docclean doc dist distclean check uninstall install install-includes install-bin all staticlib dynamiclib test test-all website-upload pkg blog blogclean
|
.PHONY: lint cpplint jslint bench clean docopen docclean doc dist distclean check uninstall install install-includes install-bin all staticlib dynamiclib test test-all website-upload pkg blog blogclean tar binary release-only
|
||||||
|
@ -8,6 +8,14 @@ Windows x64 Installer: http://nodejs.org/dist/__VERSION__/x64/node-__VERSION__-x
|
|||||||
|
|
||||||
Windows x64 Files: http://nodejs.org/dist/__VERSION__/x64/
|
Windows x64 Files: http://nodejs.org/dist/__VERSION__/x64/
|
||||||
|
|
||||||
|
Linux 32-bit Binary Package: http://nodejs.org/dist/__VERSION__/node-__VERSION__-linux-i686.tar.gz
|
||||||
|
|
||||||
|
Linux 64-bit Binary Package: http://nodejs.org/dist/__VERSION__/node-__VERSION__-linux-x86_64.tar.gz
|
||||||
|
|
||||||
|
Solaris 32-bit Binary Package: http://nodejs.org/dist/__VERSION__/node-__VERSION__-sunos-i386.tar.gz
|
||||||
|
|
||||||
|
Solaris 64-bit Binary Package: http://nodejs.org/dist/__VERSION__/node-__VERSION__-sunos-x86_64.tar.gz
|
||||||
|
|
||||||
Other release files: http://nodejs.org/dist/__VERSION__/
|
Other release files: http://nodejs.org/dist/__VERSION__/
|
||||||
|
|
||||||
Website: http://nodejs.org/docs/__VERSION__/
|
Website: http://nodejs.org/docs/__VERSION__/
|
||||||
|
@ -91,7 +91,9 @@ def waf_files(action):
|
|||||||
'tools/wafadmin/Scripting.py',
|
'tools/wafadmin/Scripting.py',
|
||||||
'tools/wafadmin/TaskGen.py',
|
'tools/wafadmin/TaskGen.py',
|
||||||
'tools/wafadmin/Task.py',
|
'tools/wafadmin/Task.py',
|
||||||
'tools/wafadmin/Tools/ar.py',
|
'tools/wafadmin/Utils.py'],
|
||||||
|
'lib/node/wafadmin/')
|
||||||
|
action(['tools/wafadmin/Tools/ar.py',
|
||||||
'tools/wafadmin/Tools/cc.py',
|
'tools/wafadmin/Tools/cc.py',
|
||||||
'tools/wafadmin/Tools/ccroot.py',
|
'tools/wafadmin/Tools/ccroot.py',
|
||||||
'tools/wafadmin/Tools/compiler_cc.py',
|
'tools/wafadmin/Tools/compiler_cc.py',
|
||||||
@ -123,12 +125,11 @@ def waf_files(action):
|
|||||||
'tools/wafadmin/Tools/unittestw.py',
|
'tools/wafadmin/Tools/unittestw.py',
|
||||||
'tools/wafadmin/Tools/winres.py',
|
'tools/wafadmin/Tools/winres.py',
|
||||||
'tools/wafadmin/Tools/xlc.py',
|
'tools/wafadmin/Tools/xlc.py',
|
||||||
'tools/wafadmin/Tools/xlcxx.py',
|
'tools/wafadmin/Tools/xlcxx.py'],
|
||||||
'tools/wafadmin/Utils.py'],
|
'lib/node/wafadmin/Tools/')
|
||||||
'lib/node/')
|
|
||||||
|
|
||||||
def update_shebang(path, shebang):
|
def update_shebang(path, shebang):
|
||||||
print 'updating shebang of %s' % path
|
print 'updating shebang of %s to %s' % (path, shebang)
|
||||||
s = open(path, 'r').read()
|
s = open(path, 'r').read()
|
||||||
s = re.sub(r'#!.*\n', '#!' + shebang + '\n', s)
|
s = re.sub(r'#!.*\n', '#!' + shebang + '\n', s)
|
||||||
open(path, 'w').write(s)
|
open(path, 'w').write(s)
|
||||||
@ -153,7 +154,16 @@ def npm_files(action):
|
|||||||
action([link_path], 'bin/npm')
|
action([link_path], 'bin/npm')
|
||||||
elif action == install:
|
elif action == install:
|
||||||
try_symlink('../lib/node_modules/npm/bin/npm-cli.js', link_path)
|
try_symlink('../lib/node_modules/npm/bin/npm-cli.js', link_path)
|
||||||
update_shebang(link_path, node_prefix + '/bin/node')
|
if os.environ['PORTABLE']:
|
||||||
|
# This crazy hack is necessary to make the shebang execute the copy
|
||||||
|
# of node relative to the same directory as the npm script. The precompiled
|
||||||
|
# binary tarballs use a prefix of "/" which gets translated to "/bin/node"
|
||||||
|
# in the regular shebang modifying logic, which is incorrect since the
|
||||||
|
# precompiled bundle should be able to be extracted anywhere and "just work"
|
||||||
|
shebang = '/bin/sh\n// 2>/dev/null; exec "`dirname "$0"`/node" "$0" "$@"'
|
||||||
|
else:
|
||||||
|
shebang = os.path.join(node_prefix, 'bin/node')
|
||||||
|
update_shebang(link_path, shebang)
|
||||||
else:
|
else:
|
||||||
assert(0) # unhandled action type
|
assert(0) # unhandled action type
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user