X-Git-Url: http://git.asbjorn.biz/?a=blobdiff_plain;f=Makefile;h=e0d1da716faeec80d347a9b76d5e0c46fd60dd4a;hb=150d3decb54971a7378fb48d0b6970d3fb50ff95;hp=94fa885b2d89fd20181ac42a10925169bb275f65;hpb=918cf68dfdaf057d6aa336be306b73eaede47a44;p=jquery.git diff --git a/Makefile b/Makefile index 94fa885..e0d1da7 100644 --- a/Makefile +++ b/Makefile @@ -1,20 +1,30 @@ SRC_DIR = src +TEST_DIR = test BUILD_DIR = build 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}/support.js\ ${SRC_DIR}/selector.js\ ${SRC_DIR}/traversing.js\ - ${SRC_DIR}/attributes.js\ ${SRC_DIR}/manipulation.js\ ${SRC_DIR}/css.js\ ${SRC_DIR}/ajax.js\ - ${SRC_DIR}/fx.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 @@ -25,58 +35,68 @@ MODULES = ${SRC_DIR}/intro.js\ JQ = ${DIST_DIR}/jquery.js JQ_MIN = ${DIST_DIR}/jquery.min.js -JQ_VER = `cat version.txt` -VER = sed s/@VERSION/${JQ_VER}/ +SIZZLE_DIR = ${SRC_DIR}/sizzle -MINJAR = java -jar ${BUILD_DIR}/yuicompressor-2.4.2.jar +JQ_VER = $(shell cat version.txt) +VER = sed "s/@VERSION/${JQ_VER}/" -DATE=`git log -1 | grep Date: | sed 's/[^:]*: *//'` +DATE=$(shell git log -1 --pretty=format:%ad) -all: jquery min +all: jquery min lint @@echo "jQuery build complete." ${DIST_DIR}: @@mkdir -p ${DIST_DIR} init: - @@echo "Grabbing external dependencies..." - @@git submodule init - @@git submodule update - @@cd src/sizzle && git pull origin master - @@cd test/qunit && git pull origin master + @@if [ -d .git ]; then git submodule update --init --recursive; fi -jquery: ${DIST_DIR} selector ${JQ} +jquery: init ${JQ} +jq: init ${JQ} -${JQ}: ${MODULES} +${JQ}: ${MODULES} | ${DIST_DIR} @@echo "Building" ${JQ} - @@mkdir -p ${DIST_DIR} - @@cat ${MODULES} | \ - sed 's/Date:./&'"${DATE}"'/' | \ + sed 's/.function..jQuery...{//' | \ + sed 's/}...jQuery..;//' | \ + sed 's/@DATE/'"${DATE}"'/' | \ ${VER} > ${JQ}; - @@echo ${JQ} "Built" - @@echo - -selector: init +${SRC_DIR}/selector.js: ${SIZZLE_DIR}/sizzle.js @@echo "Building selector code from Sizzle" - @@sed '/EXPOSE/r src/sizzle-jquery.js' src/sizzle/sizzle.js > src/selector.js - -min: ${JQ_MIN} + @@sed '/EXPOSE/r src/sizzle-jquery.js' ${SIZZLE_DIR}/sizzle.js | grep -v window.Sizzle > ${SRC_DIR}/selector.js -${JQ_MIN}: ${JQ} - @@echo "Building" ${JQ_MIN} +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 - @@echo " - Compressing using Minifier" - @@${MINJAR} ${JQ} > ${JQ_MIN} +min: ${JQ_MIN} - @@echo ${JQ_MIN} "Built" - @@echo +${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: @@echo "Removing Distribution directory:" ${DIST_DIR} @@rm -rf ${DIST_DIR} @@echo "Removing built copy of Sizzle" - @@rm src/selector.js + @@rm -f src/selector.js + +distclean: clean + @@echo "Removing submodules" + @@rm -rf test/qunit src/sizzle + +.PHONY: all jquery lint min init jq clean