Skip to content

Latest commit

 

History

History
73 lines (40 loc) · 5.04 KB

CONTRIBUTING.md

File metadata and controls

73 lines (40 loc) · 5.04 KB

中文 | English

Cherry Studio Contributor Guide

Welcome to the Cherry Studio contributor community! We are committed to making Cherry Studio a project that provides long-term value and hope to invite more developers to join us. Whether you are an experienced developer or a beginner just starting out, your contributions will help us better serve users and improve software quality.

How to Contribute

Here are several ways you can participate:

  1. Contribute Code: Help us develop new features or optimize existing code. Please ensure your code adheres to our coding standards and passes all tests.

  2. Fix Bugs: If you find a bug, you are welcome to submit a fix. Please confirm the issue is resolved before submitting and include relevant tests.

  3. Maintain Issues: Help us manage issues on GitHub by assisting with tagging, classifying, and resolving problems.

  4. Product Design: Participate in product design discussions to help us improve user experience and interface design.

  5. Write Documentation: Help us improve the user manual, API documentation, and developer guides.

  6. Community Maintenance: Participate in community discussions, help answer user questions, and promote community activity.

  7. Promote Usage: Promote Cherry Studio through blogs, social media, and other channels to attract more users and developers.

Before You Start

Please make sure you have read the Code of Conduct and the LICENSE.

Getting Started

To help you get familiar with the codebase, we recommend tackling issues tagged with one or more of the following labels: good-first-issue, help-wanted, or kind/bug. Any help is welcome.

Testing

Features without tests are considered non-existent. To ensure code is truly effective, relevant processes should be covered by unit tests and functional tests. Therefore, when considering contributions, please also consider testability. All tests can be run locally without dependency on CI. Please refer to the "Testing" section in the Developer Guide.

Automated Testing for Pull Requests

Automated tests are triggered on pull requests (PRs) opened by members of the Cherry Studio organization, except for draft PRs. PRs opened by new contributors will initially be marked with the needs-ok-to-test label and will not be automatically tested. Once a Cherry Studio organization member adds /ok-to-test to the PR, the test pipeline will be created.

Consider Opening Your Pull Request as a Draft

Not all pull requests are ready for review when created. This might be because the author wants to start a discussion, they are not entirely sure if the changes are heading in the right direction, or the changes are not yet complete. Please consider creating these PRs as draft pull requests. Draft PRs are skipped by CI, thus saving CI resources. This also means reviewers will not be automatically assigned, and the community will understand that this PR is not yet ready for review. Reviewers will be assigned after you mark the draft pull request as ready for review.

Contributor Compliance with Project Terms

We require every contributor to certify that they have the right to legally contribute to our project. Contributors express this by consciously signing their commits, thereby indicating their compliance with the LICENSE. A signed commit is one where the commit message includes the following:

You can generate a signed commit using the following command git commit --signoff:

git commit --signoff -m "Your commit message"

Getting Code Reviewed/Merged

Maintainers are here to help you implement your use case within a reasonable timeframe. They will do their best to review your code and provide constructive feedback promptly. However, if you get stuck during the review process or feel your Pull Request is not receiving the attention it deserves, please contact us via comments in the Issue or through the Community.

Other Suggestions

  • Contact Developers: Before submitting a PR, you can contact the developers first to discuss or get help.
  • Become a Core Developer: If you contribute to the project consistently, congratulations, you can become a core developer and gain project membership status. Please check our Membership Guide.

Contact Us

If you have any questions or suggestions, feel free to contact us through the following ways:

Thank you for your support and contributions! We look forward to working with you to make Cherry Studio a better product.