Please do not remove [PROPOSAL] modifier until the proposal is complete. Until this these guidelines are not mandatory.
Currently the entire CodeJam team are native Russian speakers so almost all discussions are located on RSDN project forum.
For English speakers: please, use the GitHub issues.
All in English.
Feel free to fix all typos, misphrases, obvious errors in text and so on. However, please take time to open an issue before making more significant changes. Thanks!
The project should support clone, restore packages and build routine. However, there are some third-party tools assumed to be used by the contributors.
We include ReSharper (8.0 and higher) settings file (.\CodeJam.sln.DotSettings
) to make it easier to follow the guidelines.
- If you have ReSharper installed, please try to fix all code issues with severity higher than Hint before pushing the changes.
- If using the ReSharper is not suitable for you, consider to use the ReSharper Command Line Tools.
- If ReSharper recommendation is obviously wrong, please suppress it using the "Disable once with comment" command.
- In all other cases please try to follow the ReSharper recommendations. This helps to maintain the same code style over all code files in the project. Thank you in advance for understanding.
- If you think that some recommendation is obviously wrong and should be changed, please file an issue first.
TBD
TBD
You can use any editor or extension (such as Markdown Mode or Web Extensions) to edit .md files.
However, please do not use features that are not supported by GitHub Flavored Markdown format.
The coding conventions are based on the guidelines from a .Net core project. With a few exceptions (most notable one - use tabs, not spaces) these should be compatible with each other.
The rules that differs highlighted in bold.
TODO: Valid authorship/copyright on this section? The following rules based on text from here and we are not going to hide the origin:)
- We use Allman style braces, where each brace begins on a new line. Single line blocks should not use braces.
- Use tabs for indentation.
- We use
_camelCase
for internal and private fields and usereadonly
where possible. Prefix the fields with_
. When used on static fields,readonly
should come afterstatic
(i.e.static readonly
notreadonly static
). - We avoid
this.
unless absolutely necessary. - We always specify the visibility, even if it's the default (i.e.
private string _foo
notstring _foo
). Visibility should be the first modifier (i.e.public abstract
notabstract public
). - Namespace imports should be specified at the top of the file, outside of
namespace
declarations and should be sorted alphabetically. - Avoid more than one empty line at any time. For example, do not have two blank lines between members of a type.
- Avoid spurious free spaces.
For example avoid
if (someVar == 0)...
, where the dots mark the spurious free spaces. Consider enabling "View White Space (Ctrl+E, S)" if using Visual Studio, to aid detection. (leave existing style if no reasons to change). Does not apply.- Use var when possible.
- We use language keywords instead of BCL types (i.e.
int, string, float
instead ofInt32, String, Single
, etc.) for both type references as well as method calls (i.e.int.Parse
instead ofInt32.Parse
). - We use PascalCasing to name constant fields, camelCasing to name constant local variables. The only exception is for interop code where the constant value should exactly match the name and value of the code you are calling via interop.
- We use
nameof(...)
instead of"..."
whenever possible and relevant.
TBD