Now have accurate version information built into jquery.js - will build it into the...
[jquery.git] / Makefile
index f949811..a906d0b 100644 (file)
--- a/Makefile
+++ b/Makefile
 SRC_DIR = src
 BUILD_DIR = build
 
-DOCS_DIR = docs
-DIST_DIR = dist
+PREFIX = .
+DOCS_DIR = ${PREFIX}/docs
+TEST_DIR = ${PREFIX}/test
+DIST_DIR = ${PREFIX}/dist
+
+MODULES = ${SRC_DIR}/intro.js\
+       ${SRC_DIR}/jquery/*\
+       ${SRC_DIR}/event/*\
+       ${SRC_DIR}/fx/*\
+       ${SRC_DIR}/ajax/*\
+       ${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
 
-all: jquery lite pack docs
+JQ_VER = `cat version.txt`
+VER = sed s/@VERSION/${JQ_VER}/
+
+JAR = java -jar ${BUILD_DIR}/js.jar
+
+all: jquery lite pack docs test
+       @@echo "jQuery build complete."
 
 ${DIST_DIR}:
-       mkdir -p ${DIST_DIR}
+       @@mkdir -p ${DIST_DIR}
 
 jquery: ${DIST_DIR} ${JQ}
 
-${JQ}:
-       @@echo "Building" ${JQ};
+${JQ}: ${MODULES}
+       @@echo "Building" ${JQ}
 
-       @@for f in ${MODULES}; do \
-               echo "Adding module:" $$f;\
-               cat ${SRC_DIR}/$$f/$$f.js >> ${JQ};\
-       done
+       @@mkdir -p ${DIST_DIR}
+       @@cat ${MODULES} | ${VER} > ${JQ};
 
-       @@echo ${JQ} "built.";
+       @@echo ${JQ} "Built"
+       @@echo
 
 lite: ${JQ_LITE}
 
 ${JQ_LITE}: ${JQ}
-       @@echo "Building" ${JQ_LITE};
-       java -jar ${BUILD_DIR}/js.jar ${BUILD_DIR}/lite.js ${JQ} ${JQ_LITE}
-       @@echo ${JQ_LITE} "built.";
+       @@echo "Building" ${JQ_LITE}
+
+       @@echo " - Removing ScriptDoc from" ${JQ}
+       @@${JAR} ${BUILD_DIR}/build/lite.js ${JQ} ${JQ_LITE}
+
+       @@echo ${JQ_LITE} "Built"
+       @@echo
 
 pack: ${JQ_PACK}
 
 ${JQ_PACK}: ${JQ}
-       @@echo "Building" ${JQ_PACK};
-       java -jar ${BUILD_DIR}/js.jar ${BUILD_DIR}/build.js ${JQ} ${JQ_PACK}
-       @@echo ${JQ_PACK} "built.";
+       @@echo "Building" ${JQ_PACK}
+
+       @@echo " - Compressing using Packer"
+       @@${JAR} ${BUILD_DIR}/build/pack.js ${JQ} ${JQ_PACK}
+
+       @@echo ${JQ_PACK} "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/*
 
-test:
+       @@echo " - Copying over script files."
+       @@cp -fR ${BUILD_DIR}/test/data ${TEST_DIR}/data
+       @@cp -f ${BUILD_DIR}/test/index.html ${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";
-       java -jar ${BUILD_DIR}/js.jar ${BUILD_DIR}/docs.js ${JQ} ${DOCS_DIR}
-       @@echo "Documentation built.";
+       @@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
 
 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 Test Suite directory:" ${TEST_DIR}
+       @@rm -rf ${TEST_DIR}
+
+       @@echo "Removing Documentation directory:" ${DOCS_DIR}
+       @@rm -rf ${DOCS_DIR}