X-Git-Url: https://adrianiainlam.tk/git/?a=blobdiff_plain;f=generate-combined.sh;h=7cdc22aebf13aa017eb4c2d9280962fbfa6fe4c2;hb=99386b99835dfcc75053b4a9a4304b3d8a8546ad;hp=d39b9f407920ab2e339a6a27c272c7124d119d1b;hpb=3df0ccf0a09d28577e3a695302f1deb926ae8a83;p=dygraphs.git diff --git a/generate-combined.sh b/generate-combined.sh index d39b9f4..7cdc22a 100755 --- a/generate-combined.sh +++ b/generate-combined.sh @@ -1,26 +1,70 @@ #!/bin/bash # Generates a single JS file that's easier to include. -# This packed JS includes a partial copy of MochiKit and PlotKit. -# It winds up being 146k uncompressed and 37k gzipped. -# Do the same for MochiKit. This save another 77k. -cd mochikit_v14 -./scripts/pack.py \ -Base Iter DOM Style Color Signal \ -> /tmp/mochikit-packed.js -cd .. +GetSources () { + # This list needs to be kept in sync w/ the one in dygraph-dev.js + # and the one in jsTestDriver.conf. Order matters, except for the plugins. + for F in \ + dashed-canvas.js \ + dygraph-options.js \ + dygraph-layout.js \ + dygraph-canvas.js \ + dygraph.js \ + dygraph-utils.js \ + dygraph-gviz.js \ + dygraph-interaction-model.js \ + dygraph-tickers.js \ + dygraph-plugin-base.js \ + plugins/*.js \ + dygraph-plugin-install.js \ + datahandler/datahandler.js \ + datahandler/default.js \ + datahandler/default-fractions.js \ + datahandler/bars.js \ + datahandler/bars-custom.js \ + datahandler/bars-error.js \ + datahandler/bars-fractions.js + do + echo "$F" + done +} -# Pack the dygraphs JS. This saves another 22k. -cat \ -dygraph-canvas.js \ -dygraph.js \ -> /tmp/dygraph.js +# Pack all the JS together. +CatSources () { + GetSources \ + | xargs cat \ + | perl -ne 'print unless m,REMOVE_FOR_COMBINED,..m,/REMOVE_FOR_COMBINED,' +} -java -jar plotkit_v091/scripts/custom_rhino.jar -c /tmp/dygraph.js \ -> /tmp/dygraph-packed.js +Copyright () { + echo '/*! @license Copyright 2014 Dan Vanderkam (danvdk@gmail.com) MIT-licensed (http://opensource.org/licenses/MIT) */' +} -cat \ -/tmp/mochikit-packed.js \ -strftime/strftime-min.js \ -/tmp/dygraph-packed.js \ -> dygraph-combined.js +CatCompressed () { + Copyright + CatSources \ + | grep -v '"use strict";' \ + | node_modules/uglify-js/bin/uglifyjs -c warnings=false -m +} + +ACTION="${1:-update}" +case "$ACTION" in +ls) + GetSources + ;; +cat) + Copyright + CatSources + ;; +compress*|cat_compress*) + CatCompressed + ;; +update) + CatCompressed > dygraph-combined.js + chmod a+r dygraph-combined.js + ;; +*) + echo >&2 "Unknown action '$ACTION'" + exit 1 + ;; +esac