dir-locals: apply our C settings in C++ also

Message ID 20240731153438.42540-1-arsen@aarsen.me
State Committed
Commit ebf4f095568e8e4af042f3e5a8cb6558888d9172
Headers
Series dir-locals: apply our C settings in C++ also |

Checks

Context Check Description
linaro-tcwg-bot/tcwg_gcc_build--master-aarch64 success Build passed
linaro-tcwg-bot/tcwg_gcc_build--master-arm warning Patch is already merged

Commit Message

Arsen Arsenović July 31, 2024, 3:21 p.m. UTC
  We haven't been applying our settings to our C++.  This patch fixes
that.

Sadly, it seems that the only documented way to apply settings to
multiple modes is to repeat them.  I thought that we can provide a list
of modes to apply, but that seems to not be the case (even thought it
happened to work on my machine).

As a result, C-h C-v fill-column now shows:

  This variable’s value is directory-local, set by the file
  ‘/home/arsen/gcc/pristine/.dir-locals.el’.

As this could affect peoples workflows, I'm posting as a heads-up and
sanity check.

OK for trunk?

TIA, have a lovely day.
---------- >8 ----------
This also works with Emacs 30 Tree-Sitter C and C++ modes, as they are
submodes.

ChangeLog:

	* .dir-locals.el: Change c-mode to a list of C, C++ and ObjC
	modes that Emacs currently provides.
---
 .dir-locals.el | 6 +++++-
 1 file changed, 5 insertions(+), 1 deletion(-)
  

Comments

Richard Sandiford July 31, 2024, 6:11 p.m. UTC | #1
Arsen Arsenović <arsen@aarsen.me> writes:
> We haven't been applying our settings to our C++.  This patch fixes
> that.
>
> Sadly, it seems that the only documented way to apply settings to
> multiple modes is to repeat them.  I thought that we can provide a list
> of modes to apply, but that seems to not be the case (even thought it
> happened to work on my machine).
>
> As a result, C-h C-v fill-column now shows:
>
>   This variable’s value is directory-local, set by the file
>   ‘/home/arsen/gcc/pristine/.dir-locals.el’.
>
> As this could affect peoples workflows, I'm posting as a heads-up and
> sanity check.
>
> OK for trunk?
>
> TIA, have a lovely day.
> ---------- >8 ----------
> This also works with Emacs 30 Tree-Sitter C and C++ modes, as they are
> submodes.
>
> ChangeLog:
>
> 	* .dir-locals.el: Change c-mode to a list of C, C++ and ObjC
> 	modes that Emacs currently provides.

OK, thanks.

Richard

> ---
>  .dir-locals.el | 6 +++++-
>  1 file changed, 5 insertions(+), 1 deletion(-)
>
> diff --git a/.dir-locals.el b/.dir-locals.el
> index fa031cbded99..2c12b3866633 100644
> --- a/.dir-locals.el
> +++ b/.dir-locals.el
> @@ -18,6 +18,10 @@
>  	      (tcl-continued-indent-level . 4)
>  	      (indent-tabs-mode . t)))
>   (nil . ((bug-reference-url-format . "https://gcc.gnu.org/PR%s")))
> + ;; Please keep C and C++ in sync.
>   (c-mode . ((c-file-style . "GNU")
>  	    (indent-tabs-mode . t)
> -	    (fill-column . 79))))
> +	    (fill-column . 79)))
> + (c++-mode . ((c-file-style . "GNU")
> +	      (indent-tabs-mode . t)
> +	      (fill-column . 79))))
  

Patch

diff --git a/.dir-locals.el b/.dir-locals.el
index fa031cbded99..2c12b3866633 100644
--- a/.dir-locals.el
+++ b/.dir-locals.el
@@ -18,6 +18,10 @@ 
 	      (tcl-continued-indent-level . 4)
 	      (indent-tabs-mode . t)))
  (nil . ((bug-reference-url-format . "https://gcc.gnu.org/PR%s")))
+ ;; Please keep C and C++ in sync.
  (c-mode . ((c-file-style . "GNU")
 	    (indent-tabs-mode . t)
-	    (fill-column . 79))))
+	    (fill-column . 79)))
+ (c++-mode . ((c-file-style . "GNU")
+	      (indent-tabs-mode . t)
+	      (fill-column . 79))))