service/vendor/github.com/bytedance/sonic/CONTRIBUTING.md

3.6 KiB
Raw Blame History

How to Contribute

Your First Pull Request

We use GitHub for our codebase. You can start by reading How To Pull Request.

Without Semantic Versioning

We keep the stable code in branch main like golang.org/x. Development base on branch develop. We promise the Forward Compatibility by adding new package directory with suffix v2/v3 when code has break changes.

Branch Organization

We use git-flow as our branch organization, as known as FDD

Bugs

1. How to Find Known Issues

We are using Github Issues for our public bugs. We keep a close eye on this and try to make it clear when we have an internal fix in progress. Before filing a new task, try to make sure your problem doesnt already exist.

2. Reporting New Issues

Providing a reduced test code is a recommended way for reporting issues. Then can be placed in:

3. Security Bugs

Please do not report the safe disclosure of bugs to public issues. Contact us by Support Email

How to Get in Touch

Submit a Pull Request

Before you submit your Pull Request (PR) consider the following guidelines:

  1. Search GitHub for an open or closed PR that relates to your submission. You don't want to duplicate existing efforts.
  2. Be sure that an issue describes the problem you're fixing, or documents the design for the feature you'd like to add. Discussing the design upfront helps to ensure that we're ready to accept your work.
  3. Fork the bytedance/sonic repo.
  4. In your forked repository, make your changes in a new git branch:
    git checkout -b bugfix/security_bug develop
    
  5. Create your patch, including appropriate test cases.
  6. Follow our Style Guides.
  7. Commit your changes using a descriptive commit message that follows AngularJS Git Commit Message Conventions. Adherence to these conventions is necessary because release notes will be automatically generated from these messages.
  8. Push your branch to GitHub:
    git push origin bugfix/security_bug
    
  9. In GitHub, send a pull request to sonic:main

Note: you must use one of optimize/feature/bugfix/doc/ci/test/refactor following a slash(/) as the branch prefix.

Your pr title and commit message should follow https://www.conventionalcommits.org/.

Contribution Prerequisites

  • Our development environment keeps up with Go Official.
  • You need fully checking with lint tools before submit your pull request. gofmt & golangci-lint
  • You are familiar with Github
  • Maybe you need familiar with Actions(our default workflow tool).

Code Style Guides

See Go Code Review Comments.

Good resources: