Skip to content

Latest commit

 

History

History
144 lines (97 loc) · 9.56 KB

CONTRIBUTING.md

File metadata and controls

144 lines (97 loc) · 9.56 KB

Contributing to Extenject (Zenject extended).

👍🎉 First off, thank you for considering contributing to Extenject. 🎉👍

The following is a set of guidelines for contributing to Extenject and its packages, which are hosted in Extenject on GitHub. These are mostly guidelines, not rules. Use your best judgment, and feel free to propose changes to this document in a pull request.

Table of Contents

I don't want to read this whole thing I just have a question

How Can I Contribute?

I don't want to read this whole thing I just have a question!!

Note: Please don't file an issue to ask a question. You'll get faster results by using the resources below.

🚀 Chat (recommended):

🐌 Websites/forums:

How Can I Contribute?

🔬 Testing

We have a handful of unit tests, but most of our testbed consists of running it with existing projects. Try our builds and pull requests in your own projects and communicate how it goes.

🪲 Reporting Bugs

Before creating bug reports, please check the existing bug reports as you might find out that you don't need to create one. When you are creating a bug report, please include as many details as possible.

How Do I Submit A (Good) Bug Report?

Create an issue on the project's repository and provide the following information.

Explain the problem and include additional details to help maintainers reproduce the problem:

  • Use a clear and descriptive title for the issue to identify the problem.
  • Provide a simplified project that reproduces the issue whenever possible.
  • Describe the exact steps which reproduce the problem in as many details as possible. For example, start by explaining how you used the project. When listing steps, don't just say what you did, but explain how you did it.
  • Provide specific examples to demonstrate the steps. It's always better to get more information. You can include links to files or GitHub projects, copy/pasteable snippets or even print screens or animated GIFS. If you're providing snippets in the issue, use Markdown code blocks.
  • Describe the behavior you observed after following the steps and point out what exactly is the problem with that behavior.
  • Explain which behavior you expected to see instead and why.
  • If the problem wasn't triggered by a specific action, describe what you were doing before the problem happened and share more information using the guidelines below.

Provide more context by answering these questions:

  • Did the problem start happening recently (e.g. after updating to a new version) or was this always a problem?
  • If the problem started happening recently, can you reproduce the problem in an older version? What's the most recent version in which the problem doesn't happen?
  • Can you reliably reproduce the issue? If not, provide details about how often the problem happens and under which conditions it normally happens.

Include details about your configuration and environment:

  • Which version of the project are you using?
  • What's the name and version of the OS you're using?
  • Any other information that could be useful about you environment

💪 Suggesting Enhancements / Feature Requests

This section guides you through submitting an enhancement suggestion for this project, including completely new features and minor improvements to existing functionality. Following these guidelines helps maintainers and the community understand your suggestion and find related suggestions.

Before creating enhancement suggestions, please check the list of enhancements suggestions in the issue tracker as you might find out that you don't need to create one. When you are creating an enhancement suggestion, please include as many details as possible.

How Do I Submit A (Good) Enhancement Suggestion?

Create an issue on the project's repository and provide the following information:

  • Use a clear and descriptive title for the issue to identify the suggestion.
  • Provide a step-by-step description of the suggested enhancement in as many details as possible.
  • Provide specific examples to demonstrate the steps. It's always better to get more information. You can include links to files or GitHub projects, copy/pasteable snippets or even print screens or animated GIFS. If you're providing snippets in the issue, use Markdown code blocks.
  • Describe the current behavior and explain which behavior you expected to see instead and why.
  • List some other similar projects where this enhancement exists.
  • Specify which version of the project you're using.
  • Specify the current environment you're using. if this is a useful information.
  • Provide a specific use case - Often we get requests for a feature not realizing there is already a way to fulfill their use case. In other words, don't just give us a solution, give us a problem.

🔁 Creating Pull Requests

How Do I Submit A (Good) Pull Request?

Please send a GitHub Pull Request with a clear list of what you've done (read more about pull requests). When you send a pull request, we will love you forever if you include unit tests. We can always use more test coverage.

  • Use a clear and descriptive title for the pull request to state the improvement you made to the code or the bug you solved.
  • Provide a link to the related issue if the pull request is a follow up of an existing bug report or enhancement suggestion.
  • Comment why this pull request represents an enhancement and give a rationale explaining why you did it that way and not another way.
  • Use the same coding style as the one used in this project.
  • Documentation: If your PR adds or changes any public properties or methods, you must retain the old versions preceded with [Obsolete("Describe what to do / use instead") attribute wherever possbile, and you must update any relevant pages in the /docs folder. It's not done until it's documented!
  • Welcome suggestions from the maintainers to improve your pull request.

Please follow our coding conventions (below) and make sure all of your commits are atomic (one feature per commit). Rebase your pull requests if necessary.

Always write a clear log message for your commits. One-line messages are fine for small changes, but bigger changes should look like this:

   $ git commit -m "A brief summary of the commit
>
>  A paragraph describing what changed and its impact."

Submit your pull requests to the right branch:

  • Submit against the 2018 branch when the change only applies to Unity 2018.2+
  • Submit against the master branch in all other cases

If your pull request breaks any test, it has no hope of being merged.

✅ Coding Conventions

Start reading our code and you'll get the hang of it. We optimize for readability:

  • We indent using 4 spaces (soft tabs)
  • We value simplicity. The code should be easy to read and avoid magic
  • KISS / Occam's Razor - always use the most simple solution.
  • No Premature Optimizations MMOs need to run for weeks without issues or exploits. Only do GC optimizations and caching in hot path. Avoid it everywhere else to keep the code simple.
  • Curly Braces { } Always use braces even for one line if's. Unity did this everywhere, and there is value in not accidentally missing a line in an if statement because there were no braces.
  • Naming Follow C# standard naming conventions. Also, be descriptive. `NetworkIdentity identity`, not `NetworkIdentity uv` or similar. If you need a comment to explain it, the name needs to be changed. For example, don't do msg = ... // the message, use message = ... without a comment instead. Avoid prefixes like m_, s_, or similar.
  • private Fields and methods in a class are private by default, no need to use the private keyword there.
  • This is open source software. Consider the people who will read your code, and make it look nice for them. It's sort of like driving a car: Perhaps you love doing donuts when you're alone, but with passengers the goal is to make the ride as smooth as possible.

♥️ Thanks!