X-Git-Url: http://git.asbjorn.biz/?a=blobdiff_plain;f=Makefile;h=d11d4e1ff36c0f013bc26d03248b07af47055a17;hb=1ed405176bfac58f35c3027006e152a4725fd63b;hp=f949811aa898e333286180b4d147b15685994d1a;hpb=51dd3736eb84b171b041f419f6fb8a7e8626b0f2;p=jquery.git diff --git a/Makefile b/Makefile index f949811..d11d4e1 100644 --- a/Makefile +++ b/Makefile @@ -1,53 +1,88 @@ SRC_DIR = src BUILD_DIR = build -DOCS_DIR = docs -DIST_DIR = dist +PREFIX = . +DIST_DIR = ${PREFIX}/dist + +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 -MODULES = jquery event fx ajax JQ = ${DIST_DIR}/jquery.js -JQ_LITE = ${DIST_DIR}/jquery.lite.js -JQ_PACK = ${DIST_DIR}/jquery.pack.js +JQ_MIN = ${DIST_DIR}/jquery.min.js + +JQ_VER = `cat version.txt` +VER = sed s/@VERSION/${JQ_VER}/ + +RHINO = java -jar ${BUILD_DIR}/js.jar +MINJAR = java -jar ${BUILD_DIR}/google-compiler-20091218.jar -all: jquery lite pack docs +DATE=`git log -1 --pretty=format:%ad` + +all: jquery lint min + @@echo "jQuery build complete." ${DIST_DIR}: - mkdir -p ${DIST_DIR} + @@mkdir -p ${DIST_DIR} -jquery: ${DIST_DIR} ${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 -${JQ}: - @@echo "Building" ${JQ}; +jquery: ${DIST_DIR} selector ${JQ} +jq: ${DIST_DIR} ${JQ} - @@for f in ${MODULES}; do \ - echo "Adding module:" $$f;\ - cat ${SRC_DIR}/$$f/$$f.js >> ${JQ};\ - done +${JQ}: selector ${MODULES} + @@echo "Building" ${JQ} - @@echo ${JQ} "built."; + @@mkdir -p ${DIST_DIR} -lite: ${JQ_LITE} + @@cat ${MODULES} | \ + sed 's/.function..jQuery...{//' | \ + sed 's/}...jQuery..;//' | \ + sed 's/Date:./&'"${DATE}"'/' | \ + ${VER} > ${JQ}; -${JQ_LITE}: ${JQ} - @@echo "Building" ${JQ_LITE}; - java -jar ${BUILD_DIR}/js.jar ${BUILD_DIR}/lite.js ${JQ} ${JQ_LITE} - @@echo ${JQ_LITE} "built."; +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 -pack: ${JQ_PACK} +lint: ${JQ} + @@echo "Checking jQuery against JSLint..." + @@${RHINO} build/jslint-check.js -${JQ_PACK}: ${JQ} - @@echo "Building" ${JQ_PACK}; - java -jar ${BUILD_DIR}/js.jar ${BUILD_DIR}/build.js ${JQ} ${JQ_PACK} - @@echo ${JQ_PACK} "built."; +min: ${JQ_MIN} -test: +${JQ_MIN}: ${JQ} + @@echo "Building" ${JQ_MIN} -docs: ${JQ} - @@echo "Building Documentation"; - java -jar ${BUILD_DIR}/js.jar ${BUILD_DIR}/docs.js ${JQ} ${DOCS_DIR} - @@echo "Documentation built."; + @@head -15 ${JQ} > ${JQ_MIN} + @@${MINJAR} --js ${JQ} --warning_level QUIET >> ${JQ_MIN} 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 built copy of Sizzle" + @@rm -f src/selector.js + + @@echo "Removing cloned directories" + @@rm -rf test/qunit src/sizzle