X-Git-Url: http://git.asbjorn.biz/?p=jquery.git;a=blobdiff_plain;f=Makefile;h=c708db5a1455adfe4ee75dfc3bdba5bef1fbff41;hp=4ec8ad6286b8551b0f2947c222924bcadfa1588a;hb=9d306bd73bb47562cd52f0fc4cc158c534cfdfdf;hpb=297a450e05e80e930d53631bb9ae2c3fe09378b7 diff --git a/Makefile b/Makefile index 4ec8ad6..c708db5 100644 --- a/Makefile +++ b/Makefile @@ -1,159 +1,114 @@ +V ?= 0 + SRC_DIR = src +TEST_DIR = test BUILD_DIR = build PREFIX = . -DOCS_DIR = ${PREFIX}/docs -TEST_DIR = ${PREFIX}/test DIST_DIR = ${PREFIX}/dist -PLUG_DIR = ../plugins - -BASE_FILES = ${SRC_DIR}/jquery/jquery.js\ - ${SRC_DIR}/selector/selector.js\ - ${SRC_DIR}/event/event.js\ - ${SRC_DIR}/ajax/ajax.js\ - ${SRC_DIR}/fx/fx.js - -PLUGINS = ${PLUG_DIR}/button/*\ - ${PLUG_DIR}/center/*\ - ${PLUG_DIR}/cookie/*\ - ${PLUG_DIR}/dimensions/*\ - ${PLUG_DIR}/metadata/*\ - ${PLUG_DIR}/form/*\ - ${PLUG_DIR}/greybox/greybox.js\ - ${PLUG_DIR}/interface/*\ - ${PLUG_DIR}/pager/*\ - ${PLUG_DIR}/tablesorter/*\ - ${PLUG_DIR}/tabs/*\ - ${PLUG_DIR}/tooltip/jquery.tooltip.js\ - ${PLUG_DIR}/accordion/jquery.accordion.js -MODULES = ${SRC_DIR}/intro.js\ - ${BASE_FILES}\ - ${SRC_DIR}/outro.js +JS_ENGINE ?= `which node nodejs` +COMPILER = ${JS_ENGINE} ${BUILD_DIR}/uglify.js --unsafe + +BASE_FILES = ${SRC_DIR}/core.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_WITH_PLUGINS = ${SRC_DIR}/intro.js\ +MODULES = ${SRC_DIR}/intro.js\ ${BASE_FILES}\ - ${PLUGINS}\ ${SRC_DIR}/outro.js JQ = ${DIST_DIR}/jquery.js -JQ_LITE = ${DIST_DIR}/jquery.lite.js JQ_MIN = ${DIST_DIR}/jquery.min.js -JQ_PACK = ${DIST_DIR}/jquery.pack.js -JQ_VER = `cat version.txt` -VER = sed s/@VERSION/${JQ_VER}/ +SIZZLE_DIR = ${SRC_DIR}/sizzle +QUNIT_DIR = ${TEST_DIR}/qunit -JAR = java -jar ${BUILD_DIR}/js.jar +JQ_VER = $(shell cat version.txt) +VER = sed "s/@VERSION/${JQ_VER}/" -all: jquery lite pack docs test +DATE=$(shell git log -1 --pretty=format:%ad) + +all: init jquery min lint @@echo "jQuery build complete." ${DIST_DIR}: @@mkdir -p ${DIST_DIR} -jquery: ${DIST_DIR} ${JQ} - -${JQ}: ${MODULES} - @@echo "Building" ${JQ} - - @@mkdir -p ${DIST_DIR} - @@cat ${MODULES} | ${VER} > ${JQ}; - - @@echo ${JQ} "Built" - @@echo - -with_plugins: ${MODULES_WITH_PLUGINS} +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: + $(call clone_or_pull, ${QUNIT_DIR}, git://github.com/jquery/qunit.git) + $(call clone_or_pull, ${SIZZLE_DIR}, git://github.com/jeresig/sizzle.git) + +jquery: ${JQ} +jq: ${JQ} + +${JQ}: ${MODULES} | ${DIST_DIR} @@echo "Building" ${JQ} - @@mkdir -p ${DIST_DIR} - @@cat ${MODULES_WITH_PLUGINS} | ${VER} > ${JQ}; - - @@echo ${JQ} "Built" - @@echo - -lite: ${JQ_LITE} - -${JQ_LITE}: ${JQ} - @@echo "Building" ${JQ_LITE} - - @@echo " - Removing ScriptDoc from" ${JQ} - @@${JAR} ${BUILD_DIR}/build/lite.js ${JQ} ${JQ_LITE} - - @@echo ${JQ_LITE} "Built" - @@echo + @@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} - - @@echo " - Compressing using Packer" - @@${JAR} ${BUILD_DIR}/build/pack.js ${JQ} ${JQ_PACK} - - @@echo ${JQ_PACK} "Built" - @@echo +lint: ${JQ} + @@echo "Checking jQuery against JSLint..." + @@${JS_ENGINE} build/jslint-check.js min: ${JQ_MIN} ${JQ_MIN}: ${JQ} @@echo "Building" ${JQ_MIN} - - @@echo " - Compressing using Minifier" - @@${JAR} ${BUILD_DIR}/build/min.js ${JQ} ${JQ_MIN} - - @@echo ${JQ_MIN} "Built" - @@echo - -test: ${JQ} - @@echo "Building Test Suite" - - @@echo " - Making Test Suite Directory:" ${TEST_DIR} - @@mkdir -p ${TEST_DIR} - - @@echo " - Removing any old tests" - @@rm -f ${TEST_DIR}/tests/* - - @@echo " - Copying over script files." - @@cp -fR ${BUILD_DIR}/test/data ${TEST_DIR}/data - @@cp -f ${BUILD_DIR}/test/index.html ${TEST_DIR} - @@cp -f ${BUILD_DIR}/test/fx.html ${TEST_DIR} - @@cp -f ${BUILD_DIR}/test/cow.jpg ${TEST_DIR} - - @@echo " - Compiling Test Cases" - @@${JAR} ${BUILD_DIR}/test/test.js ${JQ} ${TEST_DIR} - - @@echo "Test Suite Built" - @@echo - -docs: ${JQ} - @@echo "Building Documentation" - - @@echo " - Making Documentation Directory:" ${DOCS_DIR} - @@mkdir -p ${DOCS_DIR} - @@mkdir -p ${DOCS_DIR}/data - - @@echo " - Copying over htaccess file." - @@cp -fR ${BUILD_DIR}/docs/.htaccess ${DOCS_DIR} - - @@echo " - Copying over script files." - @@cp -fR ${BUILD_DIR}/docs/js ${DOCS_DIR}/js - - @@echo " - Copying over style files." - @@cp -fR ${BUILD_DIR}/docs/style ${DOCS_DIR}/style - - @@echo " - Extracting ScriptDoc from" ${JQ} - @@${JAR} ${BUILD_DIR}/docs/docs.js ${JQ} ${DOCS_DIR} - - @@echo "Documentation Built" - @@echo + @@${COMPILER} ${JQ} > ${JQ_MIN}.tmp + @@echo ";" >> ${JQ_MIN}.tmp + @@sed 's/\*\/(/*\/Ê©(/' ${JQ_MIN}.tmp | tr "Ê©" "\n" > ${JQ_MIN} + @@rm -rf ${JQ_MIN}.tmp clean: @@echo "Removing Distribution directory:" ${DIST_DIR} @@rm -rf ${DIST_DIR} - @@echo "Removing Test Suite directory:" ${TEST_DIR} - @@rm -rf ${TEST_DIR} + @@echo "Removing built copy of Sizzle" + @@rm -f src/selector.js + + @@echo "Removing cloned directories" + @@rm -rf test/qunit src/sizzle - @@echo "Removing Documentation directory:" ${DOCS_DIR} - @@rm -rf ${DOCS_DIR} +.PHONY: all jquery lint min init jq clean