BUILD_DIR = build
PREFIX = .
-DOCS_DIR = ${PREFIX}/docs
-TEST_DIR = ${PREFIX}/test
DIST_DIR = ${PREFIX}/dist
-MODULES = jquery event fx ajax
-JQ = ${DIST_DIR}/jquery.js
-JQ_LITE = ${DIST_DIR}/jquery.lite.js
-JQ_PACK = ${DIST_DIR}/jquery.pack.js
-
-all: jquery lite pack docs
- @@echo "jQuery build complete."
+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}/effects.js\
+ ${SRC_DIR}/offset.js\
+ ${SRC_DIR}/dimensions.js
+
+MODULES = ${SRC_DIR}/intro.js\
+ ${BASE_FILES}\
+ ${SRC_DIR}/outro.js
-${DIST_DIR}:
- @@mkdir -p ${DIST_DIR}
+JQ = ${DIST_DIR}/jquery.js
+JQ_MIN = ${DIST_DIR}/jquery.min.js
-jquery: ${DIST_DIR} ${JQ}
+JQ_VER = `cat version.txt`
+VER = sed s/@VERSION/${JQ_VER}/
-${JQ}:
- @@echo "Building" ${JQ}
+RHINO = java -jar ${BUILD_DIR}/js.jar
+MINJAR = java -jar ${BUILD_DIR}/google-compiler-20091218.jar
- @@for f in ${MODULES}; do \
- echo " - Adding module:" $$f;\
- cat ${SRC_DIR}/$$f/$$f.js >> ${JQ};\
- done
+DATE=`git log -1 --pretty=format:%ad`
- @@echo ${JQ} "built."
- @@echo
+all: jquery lint min
+ @@echo "jQuery build complete."
-lite: ${JQ_LITE}
+${DIST_DIR}:
+ @@mkdir -p ${DIST_DIR}
-${JQ_LITE}: jquery
- @@echo "Building" ${JQ_LITE}
- @@echo " - Removing ScriptDoc from" ${JQ}
- @@java -jar ${BUILD_DIR}/js.jar ${BUILD_DIR}/lite.js ${JQ} ${JQ_LITE}
- @@echo ${JQ_LITE} "built."
- @@echo
+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
-pack: ${JQ_PACK}
+jquery: ${DIST_DIR} selector ${JQ}
+jq: ${DIST_DIR} ${JQ}
-${JQ_PACK}: jquery
- @@echo "Building" ${JQ_PACK}
- @@echo " - Compressing using Packer"
- @@java -jar ${BUILD_DIR}/js.jar ${BUILD_DIR}/build.js ${JQ} ${JQ_PACK}
- @@echo ${JQ_PACK} "built."
- @@echo
+${JQ}: selector ${MODULES}
+ @@echo "Building" ${JQ}
-test: ${JQ}
+ @@mkdir -p ${DIST_DIR}
-docs: ${JQ}
- @@echo "Building Documentation"
+ @@cat ${MODULES} | \
+ sed 's/.function..jQuery...{//' | \
+ sed 's/}...jQuery..;//' | \
+ sed 's/Date:./&'"${DATE}"'/' | \
+ ${VER} > ${JQ};
- @@echo " - Making Documentation Directory:" ${DOCS_DIR}
- @@mkdir -p ${DOCS_DIR}
- @@mkdir -p ${DOCS_DIR}/data
+selector: ${DIST_DIR} init
+ @@echo "Building selector code from Sizzle"
+ @@sed '/EXPOSE/r src/sizzle-jquery.js' src/sizzle/sizzle.js | grep -v window.Sizzle > src/selector.js
- @@echo " - Copying over script files."
- @@cp -R ${BUILD_DIR}/docs/js ${DOCS_DIR}/js
+lint: ${JQ}
+ @@echo "Checking jQuery against JSLint..."
+ @@${RHINO} build/jslint-check.js
- @@echo " - Copying over style files."
- @@cp -R ${BUILD_DIR}/docs/style ${DOCS_DIR}/style
+min: ${JQ_MIN}
- @@echo " - Extracting ScriptDoc from" ${JQ}
- @@java -jar ${BUILD_DIR}/js.jar ${BUILD_DIR}/docs.js ${JQ} ${DOCS_DIR}
+${JQ_MIN}: ${JQ}
+ @@echo "Building" ${JQ_MIN}
- @@echo "Documentation 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}
- @@rm -rf ${DOCS_DIR}
+
+ @@echo "Removing built copy of Sizzle"
+ @@rm -f src/selector.js
+
+ @@echo "Removing cloned directories"
+ @@rm -rf test/qunit src/sizzle