* Initial split of README into legacy and contributing * Update contributing steps
3.6 KiB
Contributing Guidelines
Looking to contribute something? Here's how you can help.
Bugs reports
A bug is a demonstrable problem that is caused by the code in the repository. Good bug reports are extremely helpful - thank you!
Guidelines for bug reports:
-
Use the GitHub issue search — check if the issue has already been reported.
-
Check if the issue has been fixed — try to reproduce it using the latest
master
or development branch in the repository. -
Isolate the problem — ideally create a reduced test case and a live example.
-
Please try to be as detailed as possible in your report. Include specific information about the environment - operating system and version, browser and version... and steps required to reproduce the issue.
Feature requests & contribution enquiries
Feature requests are welcome. But take a moment to find out whether your idea fits with the scope and aims of the project. It's up to you to make a strong case for the inclusion of your feature. Please provide as much detail and context as possible.
Contribution enquiries should take place before any significant pull request, otherwise you risk spending a lot of time working on something that we might have good reasons for rejecting.
Making Changes
If you'd like to test and/or contribute please follow these instructions.
Setup
# clone your fork
git clone -b master https://github.com/$YOUR_USERNAME/twemoji.git/
cd twemoji
# install dependencies
yarn install
# Build and test your installation
yarn build
yarn test
Making changes
Make sure to adhere to the coding conventions used throughout the codebase (indentation, accurate comments, etc.) and any other requirements (such as test coverage).
Please follow this process; it's the best way to get your work included in the project:
- Create a new topic branch to contain your feature, change, or fix:
If you'd like to test and/or propose some changes to the latest library version please change the
./scripts/generate
file at its end so that everything will be generated properly once launched.
-
Commit your changes in logical chunks. Provide clear and explanatory commit messages. Use git's interactive rebase feature to tidy up your commits before making them public.
-
Run
yarn prepublish
. This will do several things:- Ask for the version number (See: SemVer)
- Build the project and put the built assets in
dist/
- Run the tests
- Move the contents of the
dist/
directory to thegh-pages
branch - Place the contents of the
dist/
directory in its correspoding versioned folder. - Commit the changes and push them to the
gh-pages
branch of your fork.
Pull requests
Good pull requests - patches, improvements, new features - are a fantastic help. They should remain focused in scope and avoid containing unrelated commits.
-
Push your topic branch up to your fork:
git push origin my-feature-branch
-
Open a Pull Request with a clear title and description. One for your changes in
master
and another one for your changes ingh-pages
.
License
By contributing your code:
You agree to license your contribution under the terms of the MIT (for code) and CC-BY (for graphics) licenses https://github.com/twitter/twemoji/blob/gh-pages/LICENSE https://github.com/twitter/twemoji/blob/gh-pages/LICENSE-GRAPHICS