|
|
# Contributing Guidelines
## Code of Conduct
This is probably way overkill, but this is by far my most active project in terms of contributions, and somewhere along the way I was convinced that it was a good idea to have this in place sooner rather than later:
I want to provide a safe, healthy environment for all contributors/participants regardless of gender, sexual orientation, disability, race, religion, etc. As such, I don't tolerate harassment of participants in any form. In particular this applies to my issues tracker, but also to any other means of communication associated with this project that might come up. Anyone who violates these basic rules may be sanctioned/banned/have-their-comments-deleted/etc by my discretion.
Glad we cleared that up.
## Branching
Before working on your fix/feature/whatever, you should create a new branch to work on. Do something like:
```sh $ git checkout -b 'my-sweet-new-pull-request' ```
## Please Please Please Start With A Test
ecstatic has some pretty gnarly branching/logic underneath. Tests are extremely important because they (a) prove that your feature/fix works, and (b) avoid regressions in the future. Even if your patch is problematic enough to not be merged, a test will still be very helpful for confirming any future fix.
I won't reject your patch outright if it's missing new tests, but it sure helps!
## Code Style
Ecstatic's code base follows a relatively consistent style. The closer your patch blends in with the status quo, the better.
A few PROTIPS off the top of my head:
1. Variables don't need to all be declared at the top, BUT variable *blocks* should do the whole one-var, tons-of-commas thing. 2. Look at how spacing is done around conditionals and functions. Do it like that. 3. `else`'s and similar should be on the line *after* the preceding bracket.
We can refine this as the need arises.
## A Few Other Minor Guidelines
1. Keep your pull requests on-topic. A pull request purporting to tackle A shouldn't also have commits changing B and C. Feel free to make separate pull requests. For instance: A pull request should generally only update dependencies when doing so is required to add the feature or fix the bug. This feature can, of course, consist of updating dependencies. 2. I prefer maintaining the changelog and package.json version myself. This is because I try to make a single commit for a tagged release contain all changelog additions and the version bump, and this breaks down when there are interstitial commits making updates to either. 3. In case you were wondering about dependencies, you may find this helpful: [![dependencies status](https://david-dm.org/jfhbrook/node-ecstatic.svg)](https://david-dm.org/jfhbrook/node-ecstatic) 4. Please add yourself to CONTRIBUTORS.md if you haven't done so! Fill in as much as makes you comfortable.
## Pull Request
Make a pull request against master with your new branch. Explain briefly what the patch does to the code, along with any concerns.
(If you don't have a description, it's hard for me to put the changes in context. That makes it more difficult for me to merge!)
## Keep It Moving
I don't always notice new PRs, and sometimes I will forget to follow up on them. If this happens to you, you can bump the PR thread or find me on IRC or twitter.
## LAST RULE
HAVE FUN :v :v
|