unofficial mirror of emacs-devel@gnu.org 
 help / color / mirror / code / Atom feed
From: Alan Mackenzie <acm@muc.de>
To: "Vincent Belaïche" <vincent.b.1@hotmail.fr>
Cc: bug-cc-mode@gnu.org, emacs-devel@gnu.org
Subject: Re: progmodes cc: addition of builtin def-const
Date: Wed, 19 Dec 2012 20:17:03 +0000	[thread overview]
Message-ID: <20121219201703.GA3618@acm.acm> (raw)
In-Reply-To: <80boeaaor1.fsf@gmail.com>

Hi, Vincent.

Sorry for the delay in answering your proposal.  I've been swithering a
fair bit over it.

On Mon, Dec 03, 2012 at 09:01:54PM +0100, Vincent Belaïche wrote:
> Hello,

> DXL has a number of language specific functions which I think would be
> better to fontify like builtins, similar to what is done in AWK.

As a matter of interest, what is DXL?  All I found on the web was a
language based on XML, not C-like at all.

> On the other hand DXL is more typed than AWK, so the 3 level
> fontification of cc-fonts.el is better to use than do a specific
> fontification like in AWK mode.

OK.

> In order to achieve this goal of reusing cc-fonts, I propose the
> addition of a new lang constant c-builtin-kwds. This allows the
> dxl-mode.el which I am elaborating to plug more readily on EMACS CC
> progmode.

> If nobody objects I would commit the change the patch thereof is herein
> attached.

My first reaction was negative - do we really want extensive use of
c-preprocessor-face-name for builtin functions?  I know AWK Mode does
precisely this, but is it a good thing to encourage?

Then, on the other hand, the new code does nothing which isn't already
inside CC Mode.

To answer my own question, I don't feel we really should encourage this
use of c-preprocessor-face-name.  As a matter of interest, have you tried
using font-lock-add-keywords to get the new keywords fontified?  If so,
how easy/neat is it to do this?  Could you try to persuade me a new
general facility is better than a one-off for DXL Mode?

There were one or two little things about the patch which weren't quite
optimal, see below.

> VBR,
>   Vincent.


> === modified file 'lisp/ChangeLog'
> --- lisp/ChangeLog	2012-12-03 17:23:42 +0000
> +++ lisp/ChangeLog	2012-12-03 19:55:20 +0000
> @@ -1,3 +1,12 @@
> +2012-12-03  Vincent Belaïche  <vincentb1@users.sourceforge.net>
> +
> +	* progmodes/cc-fonts.el (c-basic-matchers-before): Use new lang
> +	constant `c-builtin-kwds' for handling language specific keyword
> +	fontification.
> +
> +	* progmodes/cc-langs.el (c-builtin-kwds): New lang constant for
> +	handling language specific keyword fontification.
> +
>  2012-12-03  Agustín Martín Domingo  <agustin.martin@hispalinux.es>

>  	* textmodes/ispell.el (ispell-init-process)

> === modified file 'lisp/progmodes/cc-langs.el'
> --- lisp/progmodes/cc-langs.el	2012-09-13 18:41:21 +0000
> +++ lisp/progmodes/cc-langs.el	2012-12-03 17:24:59 +0000
> @@ -649,6 +649,15 @@
>  	 (prefix "::")
>  	 (left-assoc ".")))

> +(c-lang-defconst c-builtin-kwds
> +  "Keywords for builtin keywords constants."
> +  ;; This is for functions that are not part of a library but builtin in the
> +  ;; language. AWK mode does not use this constant but could have done
> +  ;; so. Currently this is used only as a hook for languages not yes part of
> +  ;; cc-xxx progmode, like DXL.
> +  t       nil
> +  )
> +
>  (c-lang-defconst c-opt-identifier-concat-key
>    ;; Appendable adorned regexp matching the operators that join
>    ;; symbols to fully qualified identifiers, or nil in languages that

c-builtin-kwds really needs a fuller doc string, since unlike
c-constant-kwds, it doesn't have examples to guide other hackers in its
use.  The comment is really too vague - nowhere does it say what is done
with the supplied functions.  I don't think the offhand remark about AWK
is really helpful.  Something like the following would be better:

"A list of keywords which will get fontified with c-preprocessor-face-name."
;; This is intended for built-in function names in modes derived from CC
;; Mode.

> === modified file 'lisp/progmodes/cc-fonts.el'
> --- lisp/progmodes/cc-fonts.el	2012-01-19 07:21:25 +0000
> +++ lisp/progmodes/cc-fonts.el	2012-12-03 17:26:28 +0000
> @@ -763,6 +763,12 @@
>  	      `((eval . (list ,(concat "\\<\\(" re "\\)\\>")
>  			      1 c-constant-face-name))))))

> +      ;; Fontify builtins keyword constants.
> +      ,@(when (c-lang-const c-builtin-kwds)
> +	  (let ((re (c-make-keywords-re nil (c-lang-const c-builtin-kwds))))
> +	      `((eval . (list ,(concat "\\<\\(" re "\\)\\>")
> +			      1 c-preprocessor-face-name)))))
> +
>        ;; Fontify all keywords except the primitive types.
>        ,(if (c-major-mode-is 'pike-mode)
>  	   ;; No symbol is a keyword after "->" in Pike.

But as I said, I'm not quite convinced that the general facility you've
implemented is a good idea, as compared with each mode (how many are
therre?) which needs it implementing it specially.  What is your feeling
about how many derived modes would benefit from it?

-- 
Alan Mackenzie (Nuremberg, Germany).



  parent reply	other threads:[~2012-12-19 20:17 UTC|newest]

Thread overview: 5+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2012-12-03 20:01 progmodes cc: addition of builtin def-const Vincent Belaïche
2012-12-10  6:24 ` Vincent Belaïche
2012-12-18  6:51   ` Vincent Belaïche
2012-12-19 20:17 ` Alan Mackenzie [this message]
2012-12-22 22:15   ` Vincent Belaïche

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

  List information: https://www.gnu.org/software/emacs/

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=20121219201703.GA3618@acm.acm \
    --to=acm@muc.de \
    --cc=bug-cc-mode@gnu.org \
    --cc=emacs-devel@gnu.org \
    --cc=vincent.b.1@hotmail.fr \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
Code repositories for project(s) associated with this public inbox

	https://git.savannah.gnu.org/cgit/emacs.git

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for read-only IMAP folder(s) and NNTP newsgroup(s).