SRC_DIR = src
+TEST_DIR = test
BUILD_DIR = build
-DOCS_DIR = docs
-DIST_DIR = dist
+PREFIX = .
+DIST_DIR = ${PREFIX}/dist
+
+JS_ENGINE ?= `which node nodejs`
+COMPILER = ${JS_ENGINE} ${BUILD_DIR}/uglify.js --unsafe
+POST_COMPILER = ${JS_ENGINE} ${BUILD_DIR}/post-compile.js
+
+BASE_FILES = ${SRC_DIR}/core.js\
+ ${SRC_DIR}/deferred.js\
+ ${SRC_DIR}/support.js\
+ ${SRC_DIR}/data.js\
+ ${SRC_DIR}/queue.js\
+ ${SRC_DIR}/attributes.js\
+ ${SRC_DIR}/event.js\
+ ${SRC_DIR}/selector.js\
+ ${SRC_DIR}/traversing.js\
+ ${SRC_DIR}/manipulation.js\
+ ${SRC_DIR}/css.js\
+ ${SRC_DIR}/ajax.js\
+ ${SRC_DIR}/ajax/jsonp.js\
+ ${SRC_DIR}/ajax/script.js\
+ ${SRC_DIR}/ajax/xhr.js\
+ ${SRC_DIR}/effects.js\
+ ${SRC_DIR}/offset.js\
+ ${SRC_DIR}/dimensions.js
+
+MODULES = ${SRC_DIR}/intro.js\
+ ${BASE_FILES}\
+ ${SRC_DIR}/outro.js
-MODULES = jquery event fx ajax
JQ = ${DIST_DIR}/jquery.js
-JQ_LITE = ${DIST_DIR}/jquery.lite.js
-JQ_PACK = ${DIST_DIR}/jquery.pack.js
+JQ_MIN = ${DIST_DIR}/jquery.min.js
-all: jquery lite pack docs
+SIZZLE_DIR = ${SRC_DIR}/sizzle
-${DIST_DIR}:
- mkdir -p ${DIST_DIR}
+JQ_VER = $(shell cat version.txt)
+VER = sed "s/@VERSION/${JQ_VER}/"
+
+DATE=$(shell git log -1 --pretty=format:%ad)
-jquery: ${DIST_DIR} ${JQ}
+all: jquery min lint
+ @@echo "jQuery build complete."
-${JQ}:
- @@echo "Building" ${JQ};
+${DIST_DIR}:
+ @@mkdir -p ${DIST_DIR}
- @@for f in ${MODULES}; do \
- echo "Adding module:" $$f;\
- cat ${SRC_DIR}/$$f/$$f.js >> ${JQ};\
- done
+init:
+ @@if [ -d .git ]; then git submodule update --init --recursive; fi
- @@echo ${JQ} "built.";
+jquery: init ${JQ}
+jq: init ${JQ}
-lite: ${JQ_LITE}
+${JQ}: ${MODULES} | ${DIST_DIR}
+ @@echo "Building" ${JQ}
-${JQ_LITE}: ${JQ}
- @@echo "Building" ${JQ_LITE};
- java -jar ${BUILD_DIR}/js.jar ${BUILD_DIR}/lite.js ${JQ} ${JQ_LITE}
- @@echo ${JQ_LITE} "built.";
+ @@cat ${MODULES} | \
+ sed 's/.function..jQuery...{//' | \
+ sed 's/}...jQuery..;//' | \
+ sed 's/@DATE/'"${DATE}"'/' | \
+ ${VER} > ${JQ};
-pack: ${JQ_PACK}
+${SRC_DIR}/selector.js: ${SIZZLE_DIR}/sizzle.js
+ @@echo "Building selector code from Sizzle"
+ @@sed '/EXPOSE/r src/sizzle-jquery.js' ${SIZZLE_DIR}/sizzle.js | grep -v window.Sizzle > ${SRC_DIR}/selector.js
-${JQ_PACK}: ${JQ}
- @@echo "Building" ${JQ_PACK};
- java -jar ${BUILD_DIR}/js.jar ${BUILD_DIR}/build.js ${JQ} ${JQ_PACK}
- @@echo ${JQ_PACK} "built.";
+lint: jquery
+ @@if test ! -z ${JS_ENGINE}; then \
+ echo "Checking jQuery against JSLint..."; \
+ ${JS_ENGINE} build/jslint-check.js; \
+ else \
+ echo "You must have NodeJS installed in order to test jQuery against JSLint."; \
+ fi
-test:
+min: ${JQ_MIN}
-docs: ${JQ}
- @@echo "Building Documentation";
- java -jar ${BUILD_DIR}/js.jar ${BUILD_DIR}/docs.js ${JQ} ${DOCS_DIR}
- @@echo "Documentation built.";
+${JQ_MIN}: jquery
+ @@if test ! -z ${JS_ENGINE}; then \
+ echo "Minifying jQuery" ${JQ_MIN}; \
+ ${COMPILER} ${JQ} > ${JQ_MIN}.tmp; \
+ ${POST_COMPILER} ${JQ_MIN}.tmp > ${JQ_MIN}; \
+ rm -f ${JQ_MIN}.tmp; \
+ else \
+ echo "You must have NodeJS installed in order to minify jQuery."; \
+ fi
+
clean:
- rm -rf ${DIST_DIR}
- rm -f ${DOCS_DIR}/index.xml
- rm -f ${DOCS_DIR}/data/*
+ @@echo "Removing Distribution directory:" ${DIST_DIR}
+ @@rm -rf ${DIST_DIR}
+
+ @@echo "Removing built copy of Sizzle"
+ @@rm -f src/selector.js
+
+distclean: clean
+ @@echo "Removing submodules"
+ @@rm -rf test/qunit src/sizzle
+
+# update the submodules to the latest at the most logical branch
+pull_submodules:
+ @@git submodule foreach "git pull origin \$$(git branch --no-color --contains \$$(git rev-parse HEAD) | grep -v \( | head -1)"
+ @@git submodule summary
+
+pull: pull_submodules
+ @@git pull ${REMOTE} ${BRANCH}
+
+.PHONY: all jquery lint min init jq clean