Skip to content

Latest commit

 

History

History
73 lines (52 loc) · 3.64 KB

CONTRIBUTING.md

File metadata and controls

73 lines (52 loc) · 3.64 KB

Contribution Guidelines

Thank you for your interest in contributing to Unity Robotics! To facilitate your contributions, we've outlined a brief set of guidelines to ensure that your extensions can be easily integrated.

Communication

First, please read through our code of conduct, as we expect all our contributors to follow it.

Second, before starting on a project that you intend to contribute to any of our Unity Robotics packages or tutorials, we strongly recommend posting on the repository's Issues page and briefly outlining the changes you plan to make. This will enable us to provide some context that may be helpful for you. This could range from advice and feedback on how to optimally perform your changes or reasons for not doing it.

Git Branches

The main branch corresponds to the most recent stable version of the project. The dev branch contains changes that are staged to be merged into main as the team sees fit.

When contributing to the project, please make sure that your Pull Request (PR) does the following:

  • Is up-to-date with and targets the dev branch
  • Contains a detailed description of the changes performed
  • Has corresponding changes to documentation, unit tests and sample environments (if applicable)
  • Contains a summary of the tests performed to validate your changes
  • Updates the Changelog and describes changes in the Unreleased section
  • Links to issue numbers that the PR resolves (if any)

Workflow

This project is provided as a package to be imported into a Unity project. In order to avoid common issues regarding version control and unmanaged files, the suggested workflow for contributing to the package is as follows:

  1. Clone this repository to a known location on your local machine (e.g. Documents).
  2. Git checkout the dev branch to ensure you have the latest staged changes.
  3. In a development Unity project (e.g. a new project created from the Unity Hub of the minimum Unity version or above), open the Window > Package Manager.
  4. Click the + in the top-left of the Package Manager window and select Add package from disk....
  5. Navigate to the cloned repository, and select the com.unity.<package>/package.json file. Click Open.
  6. The local version of the package is now added to your Unity project! Changes made to your cloned directory will update in your Unity project.

Code style

All Python code should follow the PEP 8 style guidelines.

All C# code should follow the Microsoft C# Coding Conventions. (Code may be reformatted to Unity coding standards where applicable.)

Please note that even if the code you are changing does not follow these conventions, we expect your submissions to do so.

Contributor License Agreements

When you open a pull request, you will be asked to acknowledge our Contributor License Agreement. We allow both individual contributions and contributions made on behalf of companies. We use an open source tool called CLA assistant. If you have any questions on our CLA, please submit an issue or email us at [email protected].

Contribution review

Once you have a change ready following the above ground rules, simply make a pull request in GitHub.