Files
cariflex/tools/EVerest-main/docs/source/project/contributing.rst
Eric F d398a6ced2 Add extracted tools: CitrineOS, OpenOCPP, ShapeShifter
- CitrineOS core extracted (CSMS OCPP 2.0.1)
- OpenOCPP extracted (firmware OCPP 1.6J/2.0.1)
- ShapeShifter library installed (pip install -e)
- ShapeShifter specification extracted
- EVerest extracted

TODO updated with progress
2026-06-08 00:38:27 -04:00

140 lines
6.4 KiB
ReStructuredText

.. _project-contributing:
#######################
Contributing to EVerest
#######################
Thank you for your interest in contributing to EVerest.
This document explains our contribution process and how to contribute a bug fix
or change in source code. In case you want to contribute to the EVerest
documentation, please see :doc:`Documenting EVerest </explanation/the-everest-documentation>`.
For a description of the roles and responsibilities of the various members of
the EVerest community, see the :doc:`Governance Policy </project/governance/governance>`, and for further details,
see the project's `Technical Charter <https://github.com/lf-energy/foundation/blob/main/project_charters/everest_charter.pdf>`_.
Briefly, Contributors are anyone who submits content to the project, Committers
review and approve such submissions, and the Technical Steering Committee
provides general project oversight.
If you just need help or have a question, refer to the :doc:`Community Channels </project/community>`.
To contribute code to the project, first read over the :doc:`Governance Policy </project/governance/governance>`
page to understand the roles involved.
Discussing and Communication
-----------------------------
We encourage contributors to engage in discussions, whether it's about
proposing new features, reporting bugs, contributing to the documentation or
seeking clarification on project-related matters.
While GitHub issues are a valuable tool for tracking tasks and issues, we find
that real-time communication often leads to faster resolution and clearer
understanding.
To facilitate such discussions, we utilize Zulip chat as our primary
communication platform. Zulip offers a threaded chat experience that helps
keep conversations organized and searchable, making it easier to follow
discussions even if you join midway.
If a discussion leads to actionable tasks or decisions, summarize the outcome
and create a corresponding GitHub issue. This allows for clear tracking and
enables contributors to start working on the agreed-upon tasks.
Join the Zulip chat here:
`EVerest channel on LF Energy Zulip <https://lfenergy.zulipchat.com/>`_
Issues
------
If you find a bug or want to request a new feature, please create an issue
in the GitHub repository. Make sure to provide a clear and concise description
of the problem or feature request, along with any relevant details or
steps to reproduce the issue.
The repository provides issue templates for bugs and feature requests to help you
provide all necessary information.
Pull requests
-------------
Each code contribution must include:
- Tests and documentation to explain the functionality.
- Any new files have `Copyright and license headers <https://github.com/lf-energy/tac/blob/main/process/contribution_guidelines.md#license>`_
- A `Developer Certificate of Origin signoff <https://github.com/lf-energy/tac/blob/main/process/contribution_guidelines.md#contribution-sign-off>`_.
- Submitted to the project as a pull request.
The contributions must be made by a human who is responsible for the quality and
correctness of their submission. All submitted code must be fully understood by
the contributor, who should be able to justify the technical approach and explain
any change during review.
Pull requests should be well-scoped and limited to a single logical
change. This keeps reviews focused and the commit history clean.
Each commit message and pull request description should have enough information
in it so that other contributors can understand what has been changed and
eventually which impact the change will have. Issue and pull request templates
of the repositories of the EVerest organization support a proper format
of code contributions.
Every pull request for a feature request must link an issue. Pull requests for
bugfixes do not necessarily need to link an issue, but they should contain a
proper description of the bug that is fixed.
You can use draft pull requests if you want to share your current state
and start a discussion about your changes. As soon as a draft pull request
is converted to be ready for review, the CODEOWNERS will be automatically
notified and start the review process.
If reviewers require changes to your PR, please keep the commit history clean
and do not rebase and force push to your branch, so that the changes can be
tracked and reviewers can quickly identify if the required changes have been
addressed.
Project committers will review the contribution in a timely manner, and advise
of any changes needed to merge the request.
AI-generated Contributions
---------------------------
EVerest aligns with the Linux Foundation's position on the use of generative AI
tools in open source development. See the `Linux Foundation guidance on
generative AI <https://www.linuxfoundation.org/legal/generative-ai>`_ for
details. Every contribution must be reviewed and verified by a human
contributor prior to submission.
Labels
------
GitHub labels help organize issues and pull requests. EVerest does not yet have
a standardized label system. When contributing:
- Browse existing labels in the repository and use them consistently
- Common labels to look for: ``bug``, ``enhancement``, ``documentation``,
``help-wanted``, ``good-first-issue``
- Backport workflow: Use ``backport-candidate`` to mark PRs that should be
considered for backporting to stable releases. To trigger the automated
backport workflow, maintainers can add a label in the format ``backport <branch>`` (e.g. ``backport stable/2026.02``). This will automatically create
a cherry-pick PR targeting the specified branch once the original PR is merged. If the cherry-pick does not apply cleanly, the workflow will comment on the
original PR and the backport must be performed manually.
If you need a label that doesn't exist, discuss with maintainers before creating it.
Coding Style
------------
Each contribution must meet the `Javascript <https://github.com/EVerest/EVerest/blob/main/.eslintrc.json>`_ or
`C++ <https://github.com/EVerest/EVerest/blob/main/.clang-format>`_ *coding style* (part of every repository).
License
-------
EVerest is licensed under the `Apache License 2.0 <https://github.com/EVerest/EVerest/blob/main/LICENSE>`_ license.
Contributions should abide by that standard license. Contributors are
responsible for ensuring that any third-party content included in their
submission does not introduce conflicting license obligations or copyright
infringement.