This is an archive of the discontinued LLVM Phabricator instance.

Add .editorconfig file
AcceptedPublic

Authored by beanz on Oct 12 2022, 9:43 AM.

Details

Summary

EditorConfig is a pretty simple format that is supported by a bunch of
common code editors (including Visual Studio). This file allows setting
some of the editor settings to match LLVM coding style guidelines which
will hopefully make it so contributors using those editors write code
closer to LLVM style without fighting their editors.

Diff Detail

Event Timeline

beanz created this revision.Oct 12 2022, 9:43 AM
Herald added a project: Restricted Project. · View Herald TranscriptOct 12 2022, 9:43 AM
Herald added a subscriber: StephenFan. · View Herald Transcript
beanz requested review of this revision.Oct 12 2022, 9:43 AM
Herald added a project: Restricted Project. · View Herald TranscriptOct 12 2022, 9:43 AM
beanz added a comment.Oct 12 2022, 9:46 AM

Just to add some extra context. Adding this to the root of the repo will get these settings set for Visual Studio, so anyone contributing to any LLVM sub-project using Visual Studio will have their editor obey these settings unless they specifically disable the default-on option to follow the project's coding style.

mgorny added a subscriber: mgorny.Oct 12 2022, 11:58 AM
mgorny added inline comments.
.editorconfig
10

Does it have some key not to add empty trailing lines? ;-)

beanz added inline comments.Oct 12 2022, 2:12 PM
.editorconfig
10

The insert_final_newline adds that line, which is generally what we want because strict C states that all files should end with a newline. Both GCC and Clang have warnings for that.

MaskRay added a comment.EditedOct 12 2022, 4:52 PM

This seems useful as it does apply to a lot of editors. If it were Visual Studio alone I would be unsure whether this passed the bar :)

A lot of .py files use 4 space indentation, will indent_size = 2 be problematic?
For CMake files I don't know a commonly used indentation. Will indent_size = 2 be problematic?
Consider whether indent_size = 2 should only be applied to C/C++ files.

.editorconfig
10

Remove the trailing blank line.

10

Do we need end_of_line = lf?

mgorny added inline comments.Oct 12 2022, 9:35 PM
.editorconfig
10

The insert_final_newline adds that line, which is generally what we want because strict C states that all files should end with a newline. Both GCC and Clang have warnings for that.

But there are *two* newlines at the end of the file now.

beanz updated this revision to Diff 467465.Oct 13 2022, 7:25 AM

Removing extra newline :(

Do we want to add .editorconfig to .gitignore so users are free to modify their local copy for additional options supported by their editor without accidentally committing the changes for everyone else? Or is that a bad idea?

.editorconfig
8

Do these settings apply to the whole file when it is saved, or only to the modifications in the file as they're being made?

I ask because of trim_trailing_whitespace specifically -- I have a text editor that does that automatically already when saving a file and I have to configure it to *not* do that because of how often it ends up making unrelated changes in a file when saving; especially our older test cases in Clang.

beanz added inline comments.Oct 13 2022, 12:34 PM
.editorconfig
8

Do these settings apply to the whole file when it is saved, or only to the modifications in the file as they're being made?

I ask because of trim_trailing_whitespace specifically -- I have a text editor that does that automatically already when saving a file and I have to configure it to *not* do that because of how often it ends up making unrelated changes in a file when saving; especially our older test cases in Clang.

That's a really good point. The documentation on https://editorconfig.org doesn't specify, so it might be editor dependent, but probably impacts the whole file.

10

Do we need end_of_line = lf?

We could. I think at some point I'd like to get LLVM & Clang building and passing tests with autocrlf enabled at which point that would become a potential problem.

beanz updated this revision to Diff 467574.Oct 13 2022, 12:43 PM

Adding end_of_line, removing trim_trailing_whitespace

aaron.ballman added inline comments.Oct 13 2022, 12:45 PM
.editorconfig
8

That's a really good point. The documentation on https://editorconfig.org doesn't specify, so it might be editor dependent, but probably impacts the whole file.

If these impact the whole file, that's... troublesome for the trailing whitespace and the indentation fields because both of those will likely lead to unrelated edits in files. Perhaps we should see what supported editors do currently? If they all mostly agree and don't modify the whole file, maybe we can get away with it?

We could. I think at some point I'd like to get LLVM & Clang building and passing tests with autocrlf enabled at which point that would become a potential problem.

Can we opt specific files out of autocrlf (Clang has a handful of test cases that are line ending sensitive)?

This seems useful as it does apply to a lot of editors. If it were Visual Studio alone I would be unsure whether this passed the bar :)

A lot of .py files use 4 space indentation, will indent_size = 2 be problematic?

We have a mix here. Some python files are 2 and some are 4. I think having the editor formalize on 2 really just means that we set the same default as for C/C++ source, and I think that's probably good.

For CMake files I don't know a commonly used indentation. Will indent_size = 2 be problematic?

For CMake we definitely prefer 2-space indent, if there is CMake code differing from that it probably has more to do with unintentional editor wonkiness than anything else.

Consider whether indent_size = 2 should only be applied to C/C++ files.

beanz added inline comments.Oct 13 2022, 12:52 PM
.editorconfig
8

Can we opt specific files out of autocrlf (Clang has a handful of test cases that are line ending sensitive)?

We can, and we already do in some cases. We have a couple .gitattributes files around the repo that specify specific line ending behaviors for certain files.

Clang has a lot of tests that are line ending sensitive, and my to-do list includes reviewing those to see which ones _should_ be line ending sensitive and if we can address them. Last year (or maybe it was earlier this year) I made a bunch of tests not line-ending sensitive by making column and file-offset values fuzzy-matched.

MaskRay accepted this revision.Nov 1 2022, 7:13 PM

LGTM. I think this is good but this patch needs more opinions and ideally some manual verification.

This revision is now accepted and ready to land.Nov 1 2022, 7:13 PM