Added in integrated JSLint checking against the jQuery source. Just run 'make lint...
[jquery.git] / Makefile
index 3ca4c3b..e026d9e 100644 (file)
--- a/Makefile
+++ b/Makefile
@@ -2,165 +2,85 @@ SRC_DIR = src
 BUILD_DIR = build
 
 PREFIX = .
-DOCS_DIR = ${PREFIX}/docs
-TEST_DIR = ${PREFIX}/test
 DIST_DIR = ${PREFIX}/dist
-SPEED_DIR = ${PREFIX}/speed
-PLUG_DIR = ../plugins
 
 BASE_FILES = ${SRC_DIR}/core.js\
-       ${SRC_DIR}/selector.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}/fx.js\
-       ${SRC_DIR}/offset.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
+       ${SRC_DIR}/effects.js\
+       ${SRC_DIR}/offset.js\
+       ${SRC_DIR}/dimensions.js
 
 MODULES = ${SRC_DIR}/intro.js\
        ${BASE_FILES}\
        ${SRC_DIR}/outro.js
 
-MODULES_WITH_PLUGINS = ${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}/
 
-JAR = java -jar ${BUILD_DIR}/js.jar
+RHINO = java -jar ${BUILD_DIR}/js.jar
+MINJAR = java -jar ${BUILD_DIR}/google-compiler-20091218.jar
+
+DATE=`git log -1 | grep Date: | sed 's/[^:]*: *//'`
 
-all: jquery lite min pack speed
+all: jquery lint min
        @@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};
+init:
+       @@echo "Grabbing external dependencies..."
+       @@if test ! -d test/qunit/.git; then git clone git://github.com/jquery/qunit.git test/qunit; fi
+       @@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
 
-       @@echo ${JQ} "Built"
-       @@echo
+jquery: ${DIST_DIR} selector ${JQ}
+jq: ${DIST_DIR} ${JQ}
 
-with_plugins: ${MODULES_WITH_PLUGINS}
+${JQ}: selector ${MODULES}
        @@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}
-
-       @@cp ${JQ} ${JQ_LITE}
-
-       @@echo ${JQ_LITE} "Built"
-       @@echo
-
-pack: ${JQ_PACK}
 
-${JQ_PACK}: ${JQ}
-       @@echo "Building" ${JQ_PACK}
+       @@cat ${MODULES} | \
+               sed 's/Date:./&'"${DATE}"'/' | \
+               ${VER} > ${JQ};
 
-       @@echo " - Compressing using Packer"
-       @@${JAR} ${BUILD_DIR}/build/pack.js ${JQ} ${JQ_PACK}
+selector: ${DIST_DIR} init
+       @@echo "Building selector code from Sizzle"
+       @@sed '/EXPOSE/r src/sizzle-jquery.js' src/sizzle/sizzle.js > src/selector.js
 
-       @@echo ${JQ_PACK} "Built"
-       @@echo
+lint: ${JQ}
+       @@echo "Checking jQuery against JSLint..."
+       @@${RHINO} 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 "Test Suite Built"
-       @@echo
-
-runtest: ${JQ} test
-       @@echo "Running Automated Test Suite"
-       @@${JAR} ${BUILD_DIR}/runtest/test.js
-
-       @@echo "Test Suite Finished"
-       @@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
-
-speed: ${JQ}
-       @@echo "Building Speed Test Suite"
-
-       @@echo " - Making Speed Test Suite Directory:" ${SPEED_DIR}
-       @@mkdir -p ${SPEED_DIR}
-
-       @@echo " - Copying over script files."
-       @@cp -f ${BUILD_DIR}/speed/index.html ${SPEED_DIR}
-       @@cp -f ${BUILD_DIR}/speed/benchmarker.css ${SPEED_DIR}
-       @@cp -f ${BUILD_DIR}/speed/benchmarker.js ${SPEED_DIR}
-       @@cp -f ${BUILD_DIR}/speed/jquery-basis.js ${SPEED_DIR}
-
-       @@echo "Speed Test Suite Built"
-       @@echo
+       @@head -15 ${JQ} > ${JQ_MIN}
+       @@${MINJAR} --js ${JQ} --warning_level QUIET >> ${JQ_MIN}
 
 clean:
        @@echo "Removing Distribution directory:" ${DIST_DIR}
        @@rm -rf ${DIST_DIR}
 
-       @@echo "Removing Documentation directory:" ${DOCS_DIR}
-       @@rm -rf ${DOCS_DIR}
+       @@echo "Removing built copy of Sizzle"
+       @@rm src/selector.js
 
-       @@echo "Removing Speed Test Suite directory:" ${SPEED_DIR}
-       @@rm -rf ${SPEED_DIR}
+       @@echo "Removing cloned directories"
+       @@rm -rf test/qunit src/sizzle