This project aims at providing a NodeJS service to build bundles out of AMD projects in a git repository. This was developed to help jQuery Mobile build the bundle builder. Initial checkout as well as workspace creation have to be done manually.
Fetch the latest version of the repo from the default remote.
Force checkout the ref into the {project}/{ref}/{repo} workspace if it exists.
Traces 1st level dependencies.
URL arguments are:
baseUrl
: The baseUrl for module name to file resolutionnames
: An optional comma separated list of modules to include in the dependency map. If it's not specified, the service will compute the dependency map for all the .js files in thebaseUrl
directory.
name
is the name of the file generated it defaults to repo
.js
name
has extension .js (default) calls require.js to build the js bundlename
has extension .css will resolve css dependencies through the//css:
metadata and return a css bundlename
has extension .zip will do all of the above in both optimize and non-optimized and return a zip file with 4 files in it
Builds a bundle for this repository's ref
URL arguments are:
baseUrl
: The baseUrl for module name to file resolutioninclude
: A comma separated list of modules to include in the bundleexclude
: A comma separated list of modules to exclude from the bundleoptimize
: true or false
- Clone a bare repo of your project:
mkdir <basedir>/repos
cd <basedir>/repos
git clone --bare git://github.com/yourname/yourproject.git
- Now create the staging directory:
mkdir <basedir>/staging
-
Install the dependencies with
npm install
-
Start the service:
node server.js -r <basedir>/repos -s <basedir>/staging
- Add a post_receive hook to the your GitHub repo pointing at
http://instance:3000/post_receive
- Ghislain Seguin - @gseguin
Thanks to:
- Jive Software - my employer - for letting me work on cool projects like this