From 64ac54a64d68c1fffd352d0453d81b6c3c0455b0 Mon Sep 17 00:00:00 2001 From: Nathan Rajlich Date: Thu, 9 Aug 2012 16:30:41 -0700 Subject: [PATCH] Makefile: add a better check to ensure a node "release" Closes #3841. Closes #3842. --- Makefile | 18 ++++++++++-------- tools/getnodeisrelease.py | 11 +++++++++++ 2 files changed, 21 insertions(+), 8 deletions(-) create mode 100644 tools/getnodeisrelease.py diff --git a/Makefile b/Makefile index 31a2dde735..0213848ab1 100644 --- a/Makefile +++ b/Makefile @@ -192,15 +192,17 @@ docclean: -rm -rf out/doc VERSION=v$(shell $(PYTHON) tools/getnodeversion.py) +RELEASE=$(shell $(PYTHON) tools/getnodeisrelease.py) PLATFORM=$(shell uname | tr '[:upper:]' '[:lower:]') -ifeq ($(DESTCPU),x64) -ARCH=x86_64 -else -ifeq ($(DESTCPU),ia32) -ARCH=i386 +ifeq ($(findstring x86_64,$(shell uname -m)),x86_64) +DESTCPU ?= x64 else -ARCH=$(shell uname -m) +DESTCPU ?= ia32 endif +ifeq ($(DESTCPU),x64) +ARCH=x64 +else +ARCH=x86 endif TARNAME=node-$(VERSION) TARBALL=$(TARNAME).tar.gz @@ -225,11 +227,11 @@ release-only: echo "" >&2 ; \ exit 1 ; \ fi - @if [ $(shell ./node --version) = "$(VERSION)" ]; then \ + @if [ "$(RELEASE)" = "1" ]; then \ exit 0; \ else \ echo "" >&2 ; \ - echo "$(shell ./node --version) doesn't match $(VERSION)." >&2 ; \ + echo "#NODE_VERSION_IS_RELEASE is set to $(RELEASE)." >&2 ; \ echo "Did you remember to update src/node_version.cc?" >&2 ; \ echo "" >&2 ; \ exit 1 ; \ diff --git a/tools/getnodeisrelease.py b/tools/getnodeisrelease.py new file mode 100644 index 0000000000..a23ad2cf24 --- /dev/null +++ b/tools/getnodeisrelease.py @@ -0,0 +1,11 @@ +import sys,os,re + +node_version_h = os.path.join(os.path.dirname(__file__), '..', 'src', + 'node_version.h') + +f = open(node_version_h) + +for line in f: + if re.match('#define NODE_VERSION_IS_RELEASE', line): + release = int(line.split()[2]) + print release