Contributing#
Thank you for considering contributing to opensg. We welcome contributions from the community in the form of bug fixes, feature enhancements, documentation updates, etc. All contributions are processed through pull-requests or issues on GitHub. Please follow these guidelines for contributing.
Reporting issues and bugs#
This section guides you through the process of submitting an issue for opensg. To report issues or bugs please create a new issue on GitHub.
Following these guidelines will help maintainers understand your issue, reproduce the behavior, and develop a fix in an expedient fashion. Before submitting your bug report, please perform a cursory search to see if the problem has been already reported. If it has been reported, and the issue is still open, add a comment to the existing issue instead of opening a new issue.
Tips for effective bug reporting#
Use a clear descriptive title for the issue
Describe the steps to reproduce the problem, the behavior you observed after following the steps, and the expected behavior
Provide the SHA ID of the git commit that you are using
For runtime errors, provide a function call stack
Submitting pull-requests#
Contributions can take the form of bug fixes, feature enhancements, documentation updates. All updates to the repository are managed via pull requests. One of the easiest ways to get started is by looking at open issues and contributing fixes, enhancements that address those issues. If your code contribution involves large changes or additions to the codebase, we recommend opening an issue first and discussing your proposed changes with the core development team to ensure that your efforts are well directed, and so that your submission can be reviewed and merged seamlessly by the maintenance team.
Guidelines for preparing and submitting pull-requests#
Use a clear descriptive title for your pull-requests
Describe if your submission is a bugfix, documentation update, or a feature enhancement. Provide a concise description of your proposed changes.
Provide references to open issues, if applicable, to provide the necessary context to understand your pull request
Make sure that your pull-request merges cleanly with the main branch of opensg. When working on a feature, always create your feature branch off of the latest main commit
Ensure that the code compiles without warnings, (leave for later? the unit tests and regression tests all pass without errors, and the documentation builds properly with your modifications)
New physics models and code enhancements should be accompanied with relevant updates to the documentation, supported by necessary verification and validation, as well as unit tests and regression tests
Once a pull-request is submitted you will iterate with opensg maintainers until your changes are in an acceptable state and can be merged in. You can push addditional commits to the branch used to create the pull-request to reflect the feedback from maintainers and users of the code.
Stylistic conventions#
Please black your code. This enforces a standard style across the project with minimal thought and effort
Please use snake case for function and variable names.
Developer Installation#
To maintain a local installation, developers should use the following commands:
git clone https://github.com/wenbinyugroup/opensg
cd opensg
pip install -e .
Running Common Developer Tasks#
Many common developer tasks have been implemented through nox for convenient and consistent results. The following subsections describe the various tasks available through the nox task-runner.
Testing#
To run tests locally, run:
nox -s tests
at the root of the repository.
Formatting#
To check if your code complies to the black style run:
nox -s check_style
at the root of the repository. If you find it does not, please run:
nox -s enforce_style
Building Docs#
To build docs locally, navigate to opensg/docs
and run:
nox -s docs
After building, the static html files can be found in _build/html
.
Serving Docs#
To view the docs locally, navigate to opensg/docs
and run:
nox -s serve
Documentation#
Docstrings#
The documentation for opensg adheres to NumPy style docstrings. Not only does this help to keep a consistent style, but it is also necessary for the API documentation to be parsed and displayed correctly. For an example of what this should look like:
def func(arg1, arg2):
"""Summary line.
Extended description of function.
Parameters
----------
arg1 : int
Description of arg1
arg2 : str
Description of arg2
Returns
-------
bool
Description of return value
"""
return True
Additional examples can be found in the napoleon documentation. The following boilerplate can be copy-pasted into the top of a function definition to help get things started:
"""Summary line.
Extended description of function.
Parameters
----------
Returns
-------
"""
Extending opensg#
Below we explain what to do when adding a top level directory
in the opensg source called new_mod/
which contains a submodule called
new_file.py
.
Exposing New Functionality to Users#
By default, any functions in new_file.py
would not be automatically
available to users operating outside of the source directory. This is
to enforce a distinction between internal and external functionality.
Any functionality you wish to be accessed externally needs to be imported
inside the appropriate __init__.py
file. For example, the __init__.py
file inside of new_mod/
might look like:
from new_file import new_function
and the __init__.py
inside of src/
might look like:
import new_mod
This would allow a user to access the functionality by importing opensg
and then running opensg.new_mod.new_function
. If you wanted the call
to be accessed with opensg.new_mod.new_file.new_function
, you would
replace from new_file import new_function
with import new_file
. If
you are extending an already existing module, please follow the
existing convention within the corresponding __init__.py
.
Expanding the API Documentation#
New functionality for opensg should be properly documented
in the API documentation. A new folder-level module named new_mod/
would
require the creation of the file docs/apidoc/opensg.new_mod
with
the contents recording any submodules that should be captured by the
API documentation. A new file named new_file.py
added to an existing folder would
need the following code to capture its functionality in the auto api documentation:
.. automodule:: opensg.new_mod.new_file
:members:
:no-undoc-members:
:show-inheritance:
This will automatically capture all functions (internal and external) in new_file.py
.