]> git.eshelyaron.com Git - emacs.git/commitdiff
Expand preprocessor to handle macros which open or close scope.
authorDavid Engster <dengste@eml.cc>
Sun, 27 Oct 2013 21:13:46 +0000 (22:13 +0100)
committerEdward John Steere <edward.steere@gmail.com>
Wed, 25 Jan 2017 15:59:25 +0000 (17:59 +0200)
* semantic/lex-spp.el (semantic-c-end-of-macro): Declare.
(semantic-lex-spp-token-macro-to-macro-stream): Deal with macros which
open/close a scope.  For this, leave an overlay if we encounter a
single open paren and return a semantic-list in the lexer.  When this
list gets expanded, retrieve the old position from the overlay.  See
the comments in the function for further details.
(semantic-lex-spp-find-closing-macro): New function to find the next
macro which closes scope (i.e., has a closing paren).
(semantic-lex-spp-replace-or-symbol-or-keyword): Go to end of closing
macro if necessary.
(semantic-lex-spp-paren-or-list): New lexer to specially deal with
parens in macro definitions.

* bovine/c.el (semantic-cpp-lexer): Use new
`semantic-lex-spp-paren-or-list'.

* tests/cedet/semantic/test/manual/cedet/testsppreplace.c:
* tests/cedet/semantic/test/manual/cedet/testsppreplaced.c: Add tests for the
above.

test/manual/cedet/cedet/semantic/tests/testsppreplaced.c

index 105d6ac9cff0f1d28517e992249d436f4d888a62..ca8703024c7720418f81abc08e0dd15ff3b0152e 100644 (file)
@@ -99,6 +99,24 @@ int MACROA () {
 /* TEST: Fancy concat/recursive macros */
 int ABtest;
 
+/* TEST: Macros which open a scope which is closed by another macro */
+namespace foo {
+  struct inside_foo {};
+  struct inside_foo_as_well {};
+}
+
+namespace foo {
+  namespace bar {
+    struct inside_foo_bar {};
+  }
+}
+
+namespace one {
+  namespace two {
+    struct inside_one_two ();
+  }
+}
+
 /* TEST: Macro Recursion limits in arguments to a macro.
  * This code is from ALSA, noticed by Yupeng. */
 /* See commentary in testsppreplace.c. This test is broken.