mirror of
https://github.com/jquery/jquery.git
synced 2024-11-23 02:54:22 +00:00
Makefile: cleanup
* updating init to either pull or clone, not do both * make sure it building only when it needs to * make some variables overridable * use variables when they should be used instead of direct text * add V verbosity variable
This commit is contained in:
parent
8e1d369710
commit
06883449d6
65
Makefile
65
Makefile
@ -1,9 +1,18 @@
|
|||||||
|
V ?= 0
|
||||||
|
|
||||||
SRC_DIR = src
|
SRC_DIR = src
|
||||||
|
TEST_DIR = test
|
||||||
BUILD_DIR = build
|
BUILD_DIR = build
|
||||||
|
|
||||||
PREFIX = .
|
PREFIX = .
|
||||||
DIST_DIR = ${PREFIX}/dist
|
DIST_DIR = ${PREFIX}/dist
|
||||||
|
|
||||||
|
RHINO ?= java -jar ${BUILD_DIR}/js.jar
|
||||||
|
|
||||||
|
CLOSURE_COMPILER = ${BUILD_DIR}/google-compiler-20091218.jar
|
||||||
|
|
||||||
|
MINJAR ?= java -jar ${CLOSURE_COMPILER}
|
||||||
|
|
||||||
BASE_FILES = ${SRC_DIR}/core.js\
|
BASE_FILES = ${SRC_DIR}/core.js\
|
||||||
${SRC_DIR}/support.js\
|
${SRC_DIR}/support.js\
|
||||||
${SRC_DIR}/data.js\
|
${SRC_DIR}/data.js\
|
||||||
@ -26,44 +35,58 @@ MODULES = ${SRC_DIR}/intro.js\
|
|||||||
JQ = ${DIST_DIR}/jquery.js
|
JQ = ${DIST_DIR}/jquery.js
|
||||||
JQ_MIN = ${DIST_DIR}/jquery.min.js
|
JQ_MIN = ${DIST_DIR}/jquery.min.js
|
||||||
|
|
||||||
JQ_VER = `cat version.txt`
|
SIZZLE_DIR = ${SRC_DIR}/sizzle
|
||||||
|
QUNIT_DIR = ${TEST_DIR}/qunit
|
||||||
|
|
||||||
|
JQ_VER = $(shell cat version.txt)
|
||||||
VER = sed s/@VERSION/${JQ_VER}/
|
VER = sed s/@VERSION/${JQ_VER}/
|
||||||
|
|
||||||
RHINO = java -jar ${BUILD_DIR}/js.jar
|
DATE=$(shell git log -1 --pretty=format:%ad)
|
||||||
MINJAR = java -jar ${BUILD_DIR}/google-compiler-20091218.jar
|
|
||||||
|
|
||||||
DATE=`git log -1 --pretty=format:%ad`
|
all: init jquery min lint
|
||||||
|
|
||||||
all: jquery lint min
|
|
||||||
@@echo "jQuery build complete."
|
@@echo "jQuery build complete."
|
||||||
|
|
||||||
${DIST_DIR}:
|
${DIST_DIR}:
|
||||||
@@mkdir -p ${DIST_DIR}
|
@@mkdir -p ${DIST_DIR}
|
||||||
|
|
||||||
|
ifeq ($(strip $(V)),0)
|
||||||
|
verbose = --quiet
|
||||||
|
else ifeq ($(strip $(V)),1)
|
||||||
|
verbose =
|
||||||
|
else
|
||||||
|
verbose = --verbose
|
||||||
|
endif
|
||||||
|
|
||||||
|
define clone_or_pull
|
||||||
|
-@@if test ! -d $(strip ${1})/.git; then \
|
||||||
|
echo "Cloning $(strip ${1})..."; \
|
||||||
|
git clone $(strip ${verbose}) --depth=1 $(strip ${2}) $(strip ${1}); \
|
||||||
|
else \
|
||||||
|
echo "Pulling $(strip ${1})..."; \
|
||||||
|
git --git-dir=$(strip ${1})/.git pull $(strip ${verbose}) origin master; \
|
||||||
|
fi
|
||||||
|
|
||||||
|
endef
|
||||||
|
|
||||||
init:
|
init:
|
||||||
@@echo "Grabbing external dependencies..."
|
$(call clone_or_pull, ${QUNIT_DIR}, git://github.com/jquery/qunit.git)
|
||||||
@@if test ! -d test/qunit/.git; then git clone git://github.com/jquery/qunit.git test/qunit; fi
|
$(call clone_or_pull, ${SIZZLE_DIR}, git://github.com/jeresig/sizzle.git)
|
||||||
@@if test ! -d src/sizzle/.git; then git clone git://github.com/jeresig/sizzle.git src/sizzle; fi
|
|
||||||
- @@cd src/sizzle && git pull origin master > /dev/null 2>&1
|
|
||||||
- @@cd test/qunit && git pull origin master > /dev/null 2>&1
|
|
||||||
|
|
||||||
jquery: ${DIST_DIR} selector ${JQ}
|
jquery: ${JQ}
|
||||||
jq: ${DIST_DIR} ${JQ}
|
jq: ${JQ}
|
||||||
|
|
||||||
${JQ}: selector ${MODULES}
|
${JQ}: ${MODULES} ${DIST_DIR}
|
||||||
@@echo "Building" ${JQ}
|
@@echo "Building" ${JQ}
|
||||||
|
|
||||||
@@mkdir -p ${DIST_DIR}
|
|
||||||
|
|
||||||
@@cat ${MODULES} | \
|
@@cat ${MODULES} | \
|
||||||
sed 's/.function..jQuery...{//' | \
|
sed 's/.function..jQuery...{//' | \
|
||||||
sed 's/}...jQuery..;//' | \
|
sed 's/}...jQuery..;//' | \
|
||||||
sed 's/Date:./&'"${DATE}"'/' | \
|
sed 's/Date:./&'"${DATE}"'/' | \
|
||||||
${VER} > ${JQ};
|
${VER} > ${JQ};
|
||||||
|
|
||||||
selector: ${DIST_DIR} init
|
${SRC_DIR}/selector.js: ${SIZZLE_DIR}/sizzle.js
|
||||||
@@echo "Building selector code from Sizzle"
|
@@echo "Building selector code from Sizzle"
|
||||||
@@sed '/EXPOSE/r src/sizzle-jquery.js' src/sizzle/sizzle.js | grep -v window.Sizzle > src/selector.js
|
@@sed '/EXPOSE/r src/sizzle-jquery.js' ${SIZZLE_DIR}/sizzle.js | grep -v window.Sizzle > ${SRC_DIR}/selector.js
|
||||||
|
|
||||||
lint: ${JQ}
|
lint: ${JQ}
|
||||||
@@echo "Checking jQuery against JSLint..."
|
@@echo "Checking jQuery against JSLint..."
|
||||||
@ -74,8 +97,8 @@ min: ${JQ_MIN}
|
|||||||
${JQ_MIN}: ${JQ}
|
${JQ_MIN}: ${JQ}
|
||||||
@@echo "Building" ${JQ_MIN}
|
@@echo "Building" ${JQ_MIN}
|
||||||
|
|
||||||
@@head -15 ${JQ} > ${JQ_MIN}
|
@@head -$(shell grep -m 1 -n '*/' ${JQ} | cut -f1 -d:) ${JQ} > ${JQ_MIN}
|
||||||
@@${MINJAR} --js ${JQ} --warning_level QUIET >> ${JQ_MIN}
|
@@${MINJAR} --js ${JQ} --warning_level QUIET --js_output_file ${JQ_MIN}
|
||||||
|
|
||||||
clean:
|
clean:
|
||||||
@@echo "Removing Distribution directory:" ${DIST_DIR}
|
@@echo "Removing Distribution directory:" ${DIST_DIR}
|
||||||
@ -86,3 +109,5 @@ clean:
|
|||||||
|
|
||||||
@@echo "Removing cloned directories"
|
@@echo "Removing cloned directories"
|
||||||
@@rm -rf test/qunit src/sizzle
|
@@rm -rf test/qunit src/sizzle
|
||||||
|
|
||||||
|
.PHONY: all jquery lint min init jq clean
|
||||||
|
Loading…
Reference in New Issue
Block a user