Contributing
This is a quick guide on how to follow best practice and contribute smoothly to ElementEmbeddings
.
Code contributions
We are always looking for ways to make ElementEmbeddings
better and a more useful to a wider community. For making contributions, use the "Fork and Pull" workflow to make contributions and stick as closely as possible to the following:
- Code style should comply with PEP8 where possible. Google's house style is also helpful, including a good model for docstrings.
- Please use comments liberally when adding nontrivial features, and take the chance to clean up other people's code while looking at it.
- Add tests wherever possible, and use the test suite to check if you broke anything.
Add an embedding scheme
The steps required to add a new representation scheme are:
- Add data file to data/element_representations.
- Edit docstring table in core.py.
- Edit utils/config.py to include the representation in
DEFAULT_ELEMENT_EMBEDDINGS
andCITATIONS
. - Update the documentation reference.md and README.md.
Workflow
We follow the [GitHub flow] (https://guides.github.com/introduction/flow/index.html), using branches for new work and pull requests for verifying the work.
The steps for a new piece of work can be summarised as follows:
- Push up or create an issue.
- Create a branch from main, with a sensible name that relates to the issue.
- Do the work and commit changes to the branch. Push the branch regularly to GitHub to make sure no work is accidentally lost.
- Write or update unit tests for the code you work on.
- When you are finished with the work, ensure that all of the unit tests pass on your own machine.
- Open a pull request on the pull request page.
- If nobody acknowledges your pull request promptly, feel free to poke one of the main developers into action.
Pull requests
For a general overview of using pull requests on GitHub look in the GitHub docs.
When creating a pull request you should:
- Ensure that the title succinctly describes the changes so it is easy to read on the overview page
- Reference the issue which the pull request is closing
Recommended reading: How to Write the Perfect Pull Request
Dev requirements
When developing locally, it is recommended to install the python packages in requirements-dev.txt
.
This will allow you to run the tests locally with pytest as described in the main README, as well as run pre-commit hooks to automatically format python files with isort and black. To install the pre-commit hooks (only needs to be done once):
Pre-commit hooks will check all files when you commit changes, automatically fixing any files which are not formatted correctly. Those files will need to be staged again before re-attempting the commit.
Bug reports, feature requests and questions
Please use the Issue Tracker to report bugs or request features in the first instance. Contributions are always welcome.