The following lists the guidelines for contributing to the Disseminate community and for contributing source code to the project.
Do you want to contribute to Disseminate, but you're unsure where to start? Here are a few suggestions:
-
Code Contributions. We welcome Pull Requests for the following:
-
Documentation. We aim to have documentation that is easy to read, complete and accurate.
-
Templates. Our templates should be clean, easy to use and follow good typographical style.
-
UI. The User Interface should be simple, clean and easy to use.
-
Core Code. New features are implemented by coding them.
-
-
Sponsorship
Members of the community are expected to follow the Disseminate Code of Conduct, which is modeled against the Contributor Code of Conduct v2.0. Please report unacceptable behavior to codeofconduct {at} dissemia {dot} org.
-
master
. Themaster
branch is used for releases. It should always be in a stable state and pass all tests. -
development
. Thedevelopment
branch is used for pre-releases. It should always pass all pytest, tox and CI tests.
Additional branches should follow the git flow branching model with
feature/
, release/
and hotfix
prefixes. When all new and old
tests pass, these may be merged into the development
branch before being
merged to the master
branch.
The community is open to all feature requests. However, the following considerations will be evaluated in deciding whether a feature is integrated into the project.
-
Dependencies. Disseminate has many external dependencies. The following factors impact their inclusion:
-
Javascript. Javascript should not be required to view and properly render documents. Do not expect users to have javascript enabled. Javacript can be used to enhance functionality on rendered webpages.
-
Accessible. The external dependency should be easy to install with Disseminate or small enough to be statically linked or included in Disseminate packages.
3, Open. External dependencies should use an open source license.
-
-
Typesetting. A major objective for Disseminate products is to follow proper typographic style and to produce highly readable and clean rendered documents. For template authors and contributors, we recommend reading Elements of Typographic Style.
General guidelines:
-
No auto-play animations or graphics
-
The document UI must be unobtrusively. The objective is to have all UI elements contained within the menu so that the document only presents information pertinent to the document.
-
Maintain the vertical phase within text sections--i.e. do not change the line height within a text section
-
Maintain line lengths of 70-90 characters and line heights of 120-140% the font height
-
Font families and sizes should not change within a text. Exceptions include headings, captions, equations, code blocks and quotes.
-
Indentation should by consistent and use a consistent typographical unit--e.g. 2_em_.
-
Paragraphs can be indented if there is no line spacing between paragraphs. Otherwise, a line spacing of 1 line height is placed between paragraphs.
-
Multicolumn formats are outdated. These formats were developed to generate a high print density on pages that were expensive to print while only moderately compromising on readability. In the digital age, print density is no longer an issue.
-
-
Consistency. A major objective of the Disseminate language is to make usage intuitive, simple and powerful.
-
Documents headers impact the document's metadata or the rendering elements of a document and its subdocuments
-
If a feature can be implemented as a tag, it should be
-
All tags follow the
@tag
format with an optional attribute--e.g.@tag[attr=True]{My Tag}
-
Tag contents dictate what is displayed
-
Tag attributes dictate how something is displayed
-
-
Static Content. Vector graphics and formats (
.svg
,.pdf
) are more desirable than raster formats (.png
,.jpg
,.gif
). This is because these can be rendered at arbitrary resolutions. -
Secure. Code should not introduce vulnerabilities to users or to consumers--i.e. those that read documents produced by disseminate.
-
Fast. Compilation times for disseminate documents should be fast enough to quickly view changes in a rendered document.
Feature requests, usability enhancements and bug reports should be reported on the Github issue tracker. We have provided the following issue templates to speed up the resolution of issues:
Usage questions should be posted on the disseminate-usage group.
Pull requests are the mechanism used to integrate changes into the Disseminate code.
-
Make pull requests from forks of the Disseminate source code
-
Pull requests should be implemented on a new branch with a unique name
-
Pull requests that close issues should reference the issue in the commit message. e.g. Closes #42
-
Commit messages should include actions words in the present tense. e.g. Implement tag aliases and closes #42
-
Pull requests should include new tests for new features or changes to tests. Pull requests that break tests will not be merged into development if they break tests.
-
Pull requests should follow the coding style guidelines
-
PEP8 and flake8. Code should follow the PEP8 style guide and pass flake8 tests (
tox -e flake8
) -
Line length. Line length is limited to a maximum of 79 characters
-
Numpy docstrings. Docstrings follow the numpy docstring format with docstring types written using Python 3 annotations.
Tests follow the same guidelines but the following exceptions are allowed:
-
Line length. Line length may be longer than 79 characters if needed. This is helpful for checking against output strings in formats like html (Flake8 E501 error)
-
Code Complexity. Code complexity is limited to a value of 10 by default. Some tests may have an increased complexity from this limit (Flake8 C901 error)
Disseminate uses 3 kinds of tests:
-
pytest. A pytest of all the tests can be executed from the root project directory. It is recommended to develop disseminate in a virtual environment.
$ pytest
-
tox. Tox is used to test against multiple versions of python. Tox tests are also run the the root project directory.
$ tox
-
CI. Pushes to
development
andmaster
will trigger a github action to test on different platforms (linux) with tox. This occurs automatically on pushes.
Releases are identified using semantic versioning with the format
MAJOR.MINOR.PATCH[.dev#|a#|b#|rc#]
. Version updates includes the following
steps:
-
Update the
VERSION
variable insrc/__version__.py
-
Tag a commit with the new version. e.g. v2.3