[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[nongnu] elpa/d-mode c22a8c1 309/346: Fontify variables in foreach loops
From: |
ELPA Syncer |
Subject: |
[nongnu] elpa/d-mode c22a8c1 309/346: Fontify variables in foreach loops |
Date: |
Sun, 29 Aug 2021 11:00:50 -0400 (EDT) |
branch: elpa/d-mode
commit c22a8c1f5c4b6042e8673210f45fcd39807af9d2
Author: Vladimir Panteleev <git@thecybershadow.net>
Commit: Vladimir Panteleev <git@thecybershadow.net>
Fontify variables in foreach loops
---
d-mode.el | 22 ++++++++++++++--------
tests/fonts_lambda_params.d | 8 ++++++++
tests/fonts_lambda_params.d.html | 8 ++++++++
3 files changed, 30 insertions(+), 8 deletions(-)
diff --git a/d-mode.el b/d-mode.el
index cdd8d79..2752529 100644
--- a/d-mode.el
+++ b/d-mode.el
@@ -7,7 +7,7 @@
;; Maintainer: Russel Winder <russel@winder.org.uk>
;; Vladimir Panteleev <vladimir@thecybershadow.net>
;; Created: March 2007
-;; Version: 201911112314
+;; Version: 201911112326
;; Keywords: D programming language emacs cc-mode
;; Package-Requires: ((emacs "25.1"))
@@ -619,7 +619,7 @@ Evaluate OLD-FORM if the Emacs version is older than
MIN-VERSION,
(setq id-start (point))
(cond
;; Type or name only
- ((looking-at "[,=)]")
+ ((looking-at "[,=);]")
(when (eq context 'varlist)
(setq id-start type-start)
(setq type-start nil))
@@ -627,7 +627,7 @@ Evaluate OLD-FORM if the Emacs version is older than
MIN-VERSION,
;; Parameter name
((d-forward-identifier)
(c-forward-syntactic-ws)
- (looking-at "[,=)]")))))
+ (looking-at "[,=);]")))))
;; Valid declaration, process it.
@@ -760,12 +760,18 @@ CONTEXT is as in `c-forward-decl-or-cast-1'."
(eq (char-before) ?\())
(progn
(backward-char)
- (c-forward-sexp)
- (c-forward-syntactic-ws)
- (while (d-forward-attribute-or-storage-class 'top))
(or
- (eq (char-after) ?\{)
- (looking-at "=>"))))))
+ (save-excursion
+ (and
+ (c-backward-token-2)
+ (looking-at (d-make-keywords-re t '("foreach")))))
+ (progn
+ (c-forward-sexp)
+ (c-forward-syntactic-ws)
+ (while (d-forward-attribute-or-storage-class 'top))
+ (or
+ (eq (char-after) ?\{)
+ (looking-at "=>"))))))))
(setq res (cons 'varlist t))
;; (message " patching -> %S" res)
diff --git a/tests/fonts_lambda_params.d b/tests/fonts_lambda_params.d
index bc79b40..45f3902 100644
--- a/tests/fonts_lambda_params.d
+++ b/tests/fonts_lambda_params.d
@@ -3,3 +3,11 @@
auto dg = (Object a, Object b) {};
alias dg2 = (a, b) {};
+
+void fun()
+{
+ foreach (a; c) foo();
+ foreach (a, b; c) foo();
+ foreach (a; c) {}
+ foreach (a, b; c) {}
+}
diff --git a/tests/fonts_lambda_params.d.html b/tests/fonts_lambda_params.d.html
index cc8e711..3bddb49 100644
--- a/tests/fonts_lambda_params.d.html
+++ b/tests/fonts_lambda_params.d.html
@@ -3,3 +3,11 @@
</span>
<span class="keyword">auto</span> <span class="variable-name">dg</span> =
(<span class="type">Object</span> <span class="variable-name">a</span>, <span
class="type">Object</span> <span class="variable-name">b</span>) {};
<span class="keyword">alias</span> <span class="variable-name">dg2</span> =
(<span class="variable-name">a</span>, <span class="variable-name">b</span>) {};
+
+<span class="type">void</span> <span class="function-name">fun</span>()
+{
+ <span class="keyword">foreach</span> (<span
class="variable-name">a</span>; c) foo();
+ <span class="keyword">foreach</span> (<span
class="variable-name">a</span>, <span class="variable-name">b</span>; c) foo();
+ <span class="keyword">foreach</span> (<span
class="variable-name">a</span>; c) {}
+ <span class="keyword">foreach</span> (<span
class="variable-name">a</span>, <span class="variable-name">b</span>; c) {}
+}
- [nongnu] elpa/d-mode ea32e73 264/346: Makefile: Test byte-compiled version, too, (continued)
- [nongnu] elpa/d-mode ea32e73 264/346: Makefile: Test byte-compiled version, too, ELPA Syncer, 2021/08/29
- [nongnu] elpa/d-mode 979c946 256/346: Fix testing multiple nested imenu entries, ELPA Syncer, 2021/08/29
- [nongnu] elpa/d-mode 8ffe5ac 265/346: Remove doxygen-font-lock-*, ELPA Syncer, 2021/08/29
- [nongnu] elpa/d-mode 80f2019 261/346: Don't nest imenu to arbitrary depths, ELPA Syncer, 2021/08/29
- [nongnu] elpa/d-mode bdd5d78 281/346: Replace d-forward-decl-or-cast-1 implementation with a custom one, ELPA Syncer, 2021/08/29
- [nongnu] elpa/d-mode 02d1c7f 290/346: tests: Add more binary operation tests, ELPA Syncer, 2021/08/29
- [nongnu] elpa/d-mode 09ecdaa 303/346: Add "make coverage", ELPA Syncer, 2021/08/29
- [nongnu] elpa/d-mode 166fac8 313/346: Fix fontification of second foreach variable, ELPA Syncer, 2021/08/29
- [nongnu] elpa/d-mode 0d45ab2 315/346: Fix brace stack logic creating unbalanced stacks, ELPA Syncer, 2021/08/29
- [nongnu] elpa/d-mode 55c8cb0 306/346: Fontify types in function parameter lists, ELPA Syncer, 2021/08/29
- [nongnu] elpa/d-mode c22a8c1 309/346: Fontify variables in foreach loops,
ELPA Syncer <=
- [nongnu] elpa/d-mode 3731f1b 316/346: Fontify built-in @-keywords as keywords, ELPA Syncer, 2021/08/29
- [nongnu] elpa/d-mode e70d89f 312/346: Fix fontification of catch statements, ELPA Syncer, 2021/08/29
- [nongnu] elpa/d-mode 2f7adb1 319/346: Fontify sole lambda params, ELPA Syncer, 2021/08/29
- [nongnu] elpa/d-mode b40a7ab 328/346: Unbundle undercover.el, ELPA Syncer, 2021/08/29
- [nongnu] elpa/d-mode a9c05fd 331/346: tests/I0102: Remove #min-version, ELPA Syncer, 2021/08/29
- [nongnu] elpa/d-mode 32446a7 338/346: Merge pull request #107 from CyberShadow/github-actions, ELPA Syncer, 2021/08/29
- [nongnu] elpa/d-mode c3be102 344/346: Cask: Fetch undercover.el directly from git, ELPA Syncer, 2021/08/29
- [nongnu] elpa/d-mode 7fdd7b2 343/346: .github/workflows/test.yml: Add final step to call the Coveralls webhook, ELPA Syncer, 2021/08/29
- [nongnu] elpa/d-mode 505022e 341/346: tests: New testcase, ELPA Syncer, 2021/08/29
- [nongnu] elpa/d-mode 199743d 346/346: tests/I0021: Update condition, ELPA Syncer, 2021/08/29