Contributions are welcome and appreciated! Every little bit helps, and credit will always be given.
If you are new to DeltaCode and want to find easy tickets to work on, check easy issues
When contributing to DeltaCode (such as code, bugs, documentation, etc.) you agree to the Developer Certificate of Origin and the DeltaCode license (see the NOTICE file). The same approach is used by the Linux Kernel developers and several other projects.
For commits, it is best to simply add a line like this to your commit message, with your name and email:
Signed-off-by: Jane Doe <[email protected]>
Please try to write a good commit message, see good commit message wiki for details. In particular use the imperative for your commit subject: think that you are giving an order to the codebase to update itself.
To send feedback or ask a question, `file an issue <issues_>`_
If you are proposing a feature:
- Explain how it would work.
- Keep the scope simple possible to make it easier to implement.
- Remember that your contributions are welcomed to implement this feature!
For other questions, discussions, and chats, we have:
- an official Gitter channel at https://gitter.im/aboutcode-org/discuss Gitter also has an IRC bridge at https://irc.gitter.im/ This is the main place where we chat and meet.
- an official #aboutcode IRC channel on liberachat (server web.libera.chat) for DeltaCode and other related tools. You can use your favorite IRC client or use the web chat at https://web.libera.chat/?#aboutcode . This is a busy place with a lot of CI and commit notifications that makes actual chat sometimes difficult!
- a mailing list at sourceforge
When reporting a bug please include:
- Your operating system name, version and architecture (32 or 64 bits).
- Your Python version.
- Your DeltaCode version.
- Any additional details about your local setup that might be helpful to diagnose this bug.
- Detailed steps to reproduce the bug, such as the commands you ran and a link to the code you are scanning.
- The errors messages or failure trace if any.
- If helpful, you can add a screenshot as an issue attachment when relevant or some extra file as a link to a Gist.
Documentation can come in the form of wiki pages, docstrings, blog posts, articles, etc. Even a minor typo fix is welcomed. See also extra documentation on the Wiki.
To set up DeltaCode for local development:
Fork the deltacode on GitHub, click fork button
Clone your fork locally:
Use SSH:
git clone [email protected]:your_name_here/deltacode.git
Or use HTTPS:
git clone https://github.com/your_name_here/deltacode.git
See also GitHub docs dor SSH or HTTPS
If you want to change the connection type, do following
SSH to HTTPS
git remote set-url <repository-alias-name> https://github.com/your_name_here/deltacode.git
HTTPS to SSH
git remote set-url <repository-alias-name> [email protected]:your_name_here/deltacode.git
Generally <repository-alias-name> is named origin, but in the case of multiple fetch/pull source of repository you can choose whatever name you want
Create a branch for local development:
git checkout -b name-of-your-bugfix-or-feature
To configure your local environment for development, locate to the main directory of the local repository, run the configure script. The configure script creates an isolated Python virtual environment in your checkout directory, the Python pip tool, and installs the thirdparty libraries (from the thirdparty/ directory), setup the paths, etc. See https://virtualenv.pypa.io/en/latest/ for more details.
Run this command to configure DeltaCode:
./configure
On Windows use instead:
configure
Then run this: source bin/activate or . bin/activate (or run bin\activate on Windows)
When you create a new terminal/shell to work on DeltaCode rerun the activate step.
When you pull new code from git, rerun ./configure
Now you can make your code changes in your local clone. Please create new unit tests for your code. We love tests!
When you are done with your changes, run all the tests. Use this command:
py.test
Or use the -n6 option to run on 6 threads in parallel and run tests faster:
py.test -n6
Check the status of your local repository before commit, regarding files changed:
git status
Commit your changes and push your branch to your GitHub fork:
git add <file-changed-1> <file-changed-2> <file-changed-3> git commit -m "Your detailed description of your changes." --signoff git push <repository-alias-name> name-of-your-bugfix-or-feature
Submit a pull request through the GitHub website for this branch.
If you need a code review or feedback while you are developing the code just create a pull request. You can add new commits to your branch as needed.
For merging, your request would need to:
- Include unit tests that are passing (run
py.test
). - Update documentation as needed for new API, functionality etc.
- Add a note to
CHANGELOG.rst
about the changes. - Add your name to
AUTHORS.rst
.
To run a subset of test functions containing test_myfeature in their name use:
py.test -k test_myfeature
To run the tests from a single test file:
py.test tests/commoncode/test_fileutils.py
To run tests in parallel on eight processors:
py.test -n 8
To run tests verbosely, displaying all print statements to terminal:
py.test -vvs