Discord.Net is an open-source project, and we appreciate any and all contributions made by our community. However, please conform to the following guidelines when possible:
We prefer all changes to the library to be discussed beforehand, either in a GitHub issue, or in a discussion in our Discord server
Issues that are tagged as "up for grabs" are free to be picked up by any member of the community.
We prefer pull-requests that are descriptive of the changes being made and highlight any potential benefits/drawbacks of the change, but these types of write-ups are not required. See this merge request for an example of a well-written description.
This project follows Semantic Versioning. When writing changes to this project, it is recommended to write changes that are SemVer compliant with the latest version of the library in development.
The working release should be the latest build off of the dev
branch,
but can also be found on the development board.
We follow the .NET Foundation's Breaking Change Rules when determining the SemVer compliance of a change.
Obsoleting a method is considered a minor increment.
We attempt to conform to the .NET Foundation's Coding Style where possible.
As a general rule, follow the coding style already set in the file you are editing, or look at a similar file if you are adding a new one.
When creating a new public member, the member must be annotated with sufficient documentation. This should include the following, but not limited to:
<summary>
summarizing the purpose of the method.<param>
or<typeparam>
explaining the parameter.<return>
explaining the type of the returned member and what it is.<exception>
if the method directly throws an exception.
The length of the documentation should also follow the ruler as suggested by our Visual Studio Code workspace.