| 1 | #!/bin/bash |
| 2 | # This script generates the combined JS file, pushes all content to a web site |
| 3 | # and then reverts the combined file. |
| 4 | |
| 5 | if [ "$1" == "" ] ; then |
| 6 | echo "usage: $0 destination" |
| 7 | exit 1 |
| 8 | fi |
| 9 | |
| 10 | set -x |
| 11 | site=$1 |
| 12 | |
| 13 | # Produce dygraph-combined.js. |
| 14 | ./generate-combined.sh |
| 15 | |
| 16 | # Generate documentation. |
| 17 | ./generate-documentation.py > docs/options.html |
| 18 | chmod a+r docs/options.html |
| 19 | if [ -s docs/options.html ] ; then |
| 20 | ./generate-jsdoc.sh |
| 21 | |
| 22 | # Make sure everything will be readable on the web. |
| 23 | # This is like "chmod -R a+rX", but excludes the .git directory. |
| 24 | find . -path ./.git -prune -o -print | xargs chmod a+rX |
| 25 | |
| 26 | # Copy everything to the site. |
| 27 | rsync -avzr gallery strftime rgbcolor common tests jsdoc experimental plugins $site \ |
| 28 | && \ |
| 29 | rsync -avzr dashed-canvas.js stacktrace.js dygraph*.js gadget.xml excanvas.js thumbnail.png screenshot.png docs/* $site/ |
| 30 | else |
| 31 | echo "generate-documentation.py failed" |
| 32 | fi |
| 33 | |
| 34 | # Revert changes to dygraph-combined.js and docs/options.html |
| 35 | git checkout dygraph-combined.js |
| 36 | rm docs/options.html |