Thanks for your interest in this project. Do you have something you'd like to contribute? We welcome pull requests, but ask that you read this document first to understand how best to submit them and what kind of changes are likely to be accepted.
Please refer back to this document as a checklist before issuing any pull request; this will save time for everyone!
Not sure what a pull request (PR) is? Or how to submit one? Take a look at GitHub's excellent help documentation first.
Is there already an issue that addresses your concern? Do a bit of searching in our issue tracker to see if you can find something similar. If not, consider creating a new issue for discussion before submitting a pull request unless the change is truly trivial, e.g. typo fixes, etc.
- This package is intentionally tiny. If you want to add more than a few lines of code, you should probably create a new package! :)
- Feel free to work off the master branch. This project is tiny.
Please carefully follow the whitespace and formatting conventions already present in the framework.
- Tabs, not spaces
- Unix (LF), not DOS (CRLF) line endings
- Eliminate trailing whitespace and leave one blank line at the end of a file
- Wrap JSDoc and other comments at 80 characters
- Aim to wrap code at 80 characters, but favor readability over wrapping
- Preserve existing formatting; i.e. do not reformat code for its own sake
- No cuddling of
else
,catch
, etc. - Keep one space on each side of the parameter list in function declarations
- utf8 encoding for JS sources, escape special characters
Add @author JSDoc, if you've added significant code. Always check the date range in the license header.
/** @license MIT License (c) copyright 2014 original authors */
/** @author FirstName LastName <OptionalEmailAddress> */
If you are uncomfortable making the contribution under the MIT license, please contact us before making a contribution.
Search the codebase to find related unit tests and add additional test methods. Create new test cases for new modules.
See the building from source section of the README for instructions. Make sure that all tests pass prior to submitting your pull request.
Subject line:
Follow the same conventions for pull request subject lines as mentioned above for commit message subject lines. In the body:
- Explain your use case. What led you to submit this change? Why were existing mechanisms in the framework insufficient? Make a case that this is a general-purpose problem and that yours is a general-purpose solution, etc.
- Add any additional information and ask questions; start a conversation, or continue one from an existing issue
- Mention the issue ID
Note that for pull requests containing a single commit, GitHub will default the subject line and body of the pull request to match the subject line and body of the commit message. This is fine, but please also include the items above in the body of the request.
Add a comment to the associated issue(s) linking to your new pull request.
Expect to have to make a few changes before your PR is accepted. We are picky.
Note that you can always force push (git push -f
) reworked / rebased commits
against the branch used to submit your pull request. i.e. you do not need to
issue a new pull request when asked to make changes.