Skip to content

Latest commit

 

History

History
34 lines (24 loc) · 2.01 KB

CONTRIBUTING.md

File metadata and controls

34 lines (24 loc) · 2.01 KB

Contributing

Important notes

Please don't edit files in the dist subdirectory as they are generated via Grunt. You'll find source code in the src subdirectory!

Code style

Regarding code style like indentation and whitespace, follow the conventions you see used in the source already.

PhantomJS

While Grunt can run the included unit tests via PhantomJS, this shouldn't be considered a substitute for the real thing. Please be sure to test the test/*.html unit test file(s) in actual browsers.

Modifying the code

First, ensure that you have the latest Node.js and npm installed.

Test that Grunt's CLI is installed by running grunt --version. If the command isn't found, run npm install -g grunt-cli. For more information about installing Grunt, see the getting started guide.

It also have used Bower for front-end dependencies. If you haven't got inslalled bower, than you need install it globally npm install -g bower.

  1. Fork and clone the repo.
  2. Run npm install to install all Node's dependencies (including Grunt).
  3. Run bower install to install all front-end dependencies.
  4. Run grunt to grunt this project. It will run sequentially JSHint, Qunit tests, concatenate source file and create minified version by UglifyJS and put output files to dist subdirectory.

Assuming that you don't see any red, you're ready to go. Just be sure to run grunt after making any changes, to ensure that nothing is broken.

Submitting pull requests

  1. Create a new branch, please don't work in your master branch directly.
  2. Add failing tests for the change you want to make. Run grunt to see the tests fail.
  3. Fix stuff.
  4. Run grunt to see if the tests pass. Repeat steps 2-4 until done.
  5. Open test/*.html unit test file(s) in actual browser to ensure tests pass everywhere.
  6. Update the documentation to reflect any changes.
  7. Push to your fork and submit a pull request.