Skip to content

Latest commit

 

History

History
108 lines (83 loc) · 4.17 KB

CONTRIBUTING.md

File metadata and controls

108 lines (83 loc) · 4.17 KB

Contributing to PROJECT

Thanks for wanting to contribute! There are many ways to contribute and we appreciate any level you're willing to do.

Feature Requests

Need some new functionality to help? You can let us know by opening an issue. It's helpful to look through all issues in case its already being talked about.

Bug Reports

Please let us know about what problems you run into, whether in behavior or ergonomics of API. You can do this by opening an issue. It's helpful to look through all issues in case its already being talked about.

Development

Suggest

  • with stable Rust:
    cargo check --tests
    cargo check --tests --release
    
    cargo check --tests --features alloc
    cargo check --tests --features alloc --release
  • with nightly Rust:
    cargo check --tests --features nightly_lazy_type_alias
    cargo check --tests --features nightly_lazy_type_alias --release
    
    cargo check --tests --features _internal_use_allocator_api
    cargo check --tests --features _internal_use_allocator_api --release
    
    cargo check --tests --features "nightly_strict_provenance nightly_guard_cross_alloc"
    cargo check --tests --features "nightly_strict_provenance nightly_guard_cross_alloc" --release
    
    cargo check --tests --features "nightly_strict_provenance nightly_guard_cross_cleanup"
    cargo check --tests --features "nightly_strict_provenance nightly_guard_cross_cleanup" --release
    
    cargo check --tests --features "nightly_strict_provenance nightly_accept_custom_alloc"
    cargo check --tests --features "nightly_strict_provenance nightly_accept_custom_alloc" --release
    
    #
    # Explicit "alloc" feature:
    #
    cargo check --tests --features "alloc nightly_lazy_type_alias"
    cargo check --tests --features "alloc nightly_lazy_type_alias --release
    #
    # No need to check/test 'alloc' feature with the rest of features, because they all turn on/depend
    # on 'alloc' features themselves.

Pull Requests

Looking for an idea? Check our issues. If it's look more open ended, it is probably best to post on the issue how you are thinking of resolving the issue so you can get feedback early in the process. We want you to be successful and it can be discouraging to find out a lot of re-work is needed.

Already have an idea? It might be good to first create an issue to propose it so we can make sure we are aligned and lower the risk of having to re-work some of it and the discouragement that goes along with that.

Process

Before posting a PR, we request that the commit history get cleaned up. However, we recommend avoiding this during the review to make it easier to check how feedback was handled. Once the PR is ready, we'll ask you to clean up the commit history from the review. Once you let us know this is done, we can move forward with merging! If you are uncomfortable with these parts of git, let us know and we can help.

For commit messages, we use Conventional style. If you already wrote your commits and don't feel comfortable changing them, don't worry and go ahead and create your PR. We'll work with you on the best route forward. You can check your branch locally with committed.

As a heads up, we'll be running your PR through the following gauntlet:

  • warnings turned to compile errors
  • cargo test
  • rustfmt
  • clippy
  • rustdoc
  • committed
  • typos

Releasing

Pre-requisites

  • Running cargo login
  • A member of ORG:Maintainers
  • Push permission to the repo
  • cargo-release

When we're ready to release, a project owner should do the following

  1. Update the changelog (see cargo release changes for ideas)
  2. Determine what the next version is, according to semver
  3. Run cargo release -x <level>