Commit 5a602de9 authored by Íñigo Huguet's avatar Íñigo Huguet Committed by Masahiro Yamada

Add .editorconfig file for basic formatting

EditorConfig is a specification to define the most basic code formatting
stuff, and it's supported by many editors and IDEs, either directly or
via plugins, including VSCode/VSCodium, Vim, emacs and more.

It allows to define formatting style related to indentation, charset,
end of lines and trailing whitespaces. It also allows to apply different
formats for different files based on wildcards, so for example it is
possible to apply different configs to *.{c,h}, *.py and *.rs.

In linux project, defining a .editorconfig might help to those people
that work on different projects with different indentation styles, so
they cannot define a global style. Now they will directly see the
correct indentation on every fresh clone of the project.

See https://editorconfig.orgCo-developed-by: default avatarDanny Lin <danny@kdrag0n.dev>
Signed-off-by: default avatarDanny Lin <danny@kdrag0n.dev>
Signed-off-by: default avatarÍñigo Huguet <ihuguet@redhat.com>
Acked-by: default avatarMickaël Salaün <mic@digikod.net>
Reviewed-by: default avatarVincent Mailhol <mailhol.vincent@wanadoo.fr>
Tested-by: default avatarVincent Mailhol <mailhol.vincent@wanadoo.fr>
Signed-off-by: default avatarMasahiro Yamada <masahiroy@kernel.org>
parent ac14947c
# SPDX-License-Identifier: GPL-2.0-only
root = true
[{*.{awk,c,dts,dtsi,dtso,h,mk,s,S},Kconfig,Makefile,Makefile.*}]
charset = utf-8
end_of_line = lf
trim_trailing_whitespace = true
insert_final_newline = true
indent_style = tab
indent_size = 8
[*.{json,py,rs}]
charset = utf-8
end_of_line = lf
trim_trailing_whitespace = true
insert_final_newline = true
indent_style = space
indent_size = 4
# this must be below the general *.py to overwrite it
[tools/{perf,power,rcu,testing/kunit}/**.py,]
indent_style = tab
indent_size = 8
[*.yaml]
charset = utf-8
end_of_line = lf
trim_trailing_whitespace = unset
insert_final_newline = true
indent_style = space
indent_size = 2
...@@ -96,6 +96,7 @@ modules.order ...@@ -96,6 +96,7 @@ modules.order
# #
!.clang-format !.clang-format
!.cocciconfig !.cocciconfig
!.editorconfig
!.get_maintainer.ignore !.get_maintainer.ignore
!.gitattributes !.gitattributes
!.gitignore !.gitignore
......
...@@ -66,6 +66,10 @@ for aligning variables/macros, for reflowing text and other similar tasks. ...@@ -66,6 +66,10 @@ for aligning variables/macros, for reflowing text and other similar tasks.
See the file :ref:`Documentation/process/clang-format.rst <clangformat>` See the file :ref:`Documentation/process/clang-format.rst <clangformat>`
for more details. for more details.
Some basic editor settings, such as indentation and line endings, will be
set automatically if you are using an editor that is compatible with
EditorConfig. See the official EditorConfig website for more information:
https://editorconfig.org/
Abstraction layers Abstraction layers
****************** ******************
......
...@@ -735,6 +735,10 @@ for aligning variables/macros, for reflowing text and other similar tasks. ...@@ -735,6 +735,10 @@ for aligning variables/macros, for reflowing text and other similar tasks.
See the file :ref:`Documentation/process/clang-format.rst <clangformat>` See the file :ref:`Documentation/process/clang-format.rst <clangformat>`
for more details. for more details.
Some basic editor settings, such as indentation and line endings, will be
set automatically if you are using an editor that is compatible with
EditorConfig. See the official EditorConfig website for more information:
https://editorconfig.org/
10) Kconfig configuration files 10) Kconfig configuration files
------------------------------- -------------------------------
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment