Using EditorConfig to Maintain a Consistent Coding Style
Have you ever tried to work on someone else’s code and realized that they have completely different code formatting than you are used to? Maybe they use tabs, 2 spaces, or 4 spaces for indentation. Maybe they use underscore prefixed private member variables such as private string _name;
Wouldn’t it be nice if when you pulled down the project from source control, it also brought all of the code formatting styles with it? That’s what EditorConfig is meant for.
Not long ago I added an .editorconfig
file to RogueSharp. I recently mapped all of the ReSharper settings to the config as both Visual Studio and ReSharper come bundled with native support for EditorConfig.
Download
First you’ll need to download the file. I created a public Github Gist which is available here:
- https://gist.github.com/FaronBracy/155d8d7ad98b4ceeb526b9f47543db1b
Add to Solution
- Copy the downloaded file to the root of your solution where the .sln file lives.
- Make sure that the name is
.editorconfig
- Create a new Solution Items folder in Visual Studio if it doesn’t already exist
- Add
.editorconfig
to the Solution Items folder
data:image/s3,"s3://crabby-images/8fe62/8fe627d97554a03e4add233a95b49d6460f12cef" alt="Add .editorconfig to Solution Items folder alt text"
Modify Settings
Although the .editorconfig
will work as is, you’ll likely want to make some modifications to it, to match your coding style.
Common Settings
- tabs vs spaces
- indent size
- trim trailing whitespace
data:image/s3,"s3://crabby-images/0a687/0a687ecfc3e1fa722bf4ee4242066920782738b4" alt="sample settings alt text"
You’ll likely want to change the indent size at a minimum. At TechSmith where I am currently employed we use 3 spaces, but 2 or 4 is more typical.
.NET Language Conventions
data:image/s3,"s3://crabby-images/fd5c4/fd5c414ffb41f5b219562b9b2565690a8784db7c" alt=".NET naming settings alt text"
Microsoft Documentation For .NET Language Conventions
data:image/s3,"s3://crabby-images/8a583/8a58360c64468b7b76a991d5bb0fe112ad406f9c" alt=".NET formatting settings alt text"
Microsoft Documentation For .NET Formatting Conventions
.NET Naming Conventions
data:image/s3,"s3://crabby-images/fd5c4/fd5c414ffb41f5b219562b9b2565690a8784db7c" alt=".NET naming settings alt text"
Microsoft Documentation For .NET Naming Conventions
ReSharper Settings
data:image/s3,"s3://crabby-images/ed929/ed92977cf9414809613db02fbcab506650a34f5c" alt="Resharper settings alt text"
JetBrains Documentation For ReSharper EditorConfig Settings
Note: I organized the ReSharper settings according to how they appear in the menus. There should be a 1-1 relationship between each .editorconfig
setting and it’s corresponding ReSharper menu entry.
data:image/s3,"s3://crabby-images/86e56/86e56670cde4c1b963584b7eac3b196459775ec7" alt="How the settings file maps to Resharper in-app formatting settings alt text"
About Faron
Faron Bracy is a husband, father, and TechSmith employee. He maintains the open source library RogueSharp as a hobby project. Other hobbies include painting fantasy miniatures, playing board games, and playing retro video games with his family.