summaryrefslogtreecommitdiff
blob: ba39e74df9cf5f90e374dfa32a16814fee9f3c7c (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
--- a/src/c-parser.c
+++ b/src/c-parser.c
@@ -1667,14 +1667,25 @@
 ScmObj Scm_ParseMacroCode(ScmObj in, ScmObj macro_list)
 {
     static ScmObj trigger_line = SCM_FALSE;
+    static ScmObj is_gcc = SCM_TRUE;
     ScmObj line_str;
     ScmObj rx;
+    int n = 0;
+    int i;
 
     /* skip the first line '# 1 "<stdin>"' */
     Scm_ReadLineUnsafe(SCM_PORT(in));
 
     if (SCM_FALSEP(trigger_line)) {
-        trigger_line = SCM_MAKE_STR_IMMUTABLE("# 1 \"<stdin>\"");
+        ScmObj gcc = Scm_GlobalVariableRef(SCM_FIND_MODULE(CPARSER_MODULE_NAME, TRUE), SCM_SYMBOL(SCM_INTERN("GCC")), 0);
+        if (SCM_INTP(Scm_StringScanRight(SCM_STRING(gcc), SCM_STRING(SCM_MAKE_STR_IMMUTABLE("gcc")), SCM_STRING_SCAN_INDEX))) {
+            trigger_line = SCM_MAKE_STR_IMMUTABLE("# 1 \"<stdin>\"");
+        } else if (SCM_INTP(Scm_StringScanRight(SCM_STRING(gcc), SCM_STRING(SCM_MAKE_STR_IMMUTABLE("clang")), SCM_STRING_SCAN_INDEX))) {
+            trigger_line = SCM_MAKE_STR_IMMUTABLE("# 1 \"<stdin>\" 2");
+            is_gcc = SCM_FALSE;
+        } else {
+            Scm_Error("unknown compiler");
+        }
     }
     
     while (!SCM_EOFP(line_str = Scm_ReadLineUnsafe(SCM_PORT(in)))) {
@@ -1683,22 +1694,33 @@
         }
     }
 
-    rx = Scm_RegComp(SCM_STRING(SCM_MAKE_STR_IMMUTABLE("^#\\s+\\d+\\s+\"<stdin>\"")), 0);
+    rx = Scm_RegComp(SCM_STRING(SCM_MAKE_STR_IMMUTABLE("^#\\s+(\\d+)\\s+\"<stdin>\"")), 0);
     line_str = Scm_ReadLineUnsafe(SCM_PORT(in));
-    while (!SCM_EOFP(line_str)) {
-        ScmObj body_str = line_str;
+    for (i = 1; !SCM_EOFP(line_str); i++) {
+        ScmObj body_str;
+        ScmObj rm;
+        if (i < n) {
+            body_str = SCM_MAKE_STR_IMMUTABLE("");
+            goto parse;
+        }
+        body_str = line_str;
         while (!SCM_EOFP(line_str = Scm_ReadLineUnsafe(SCM_PORT(in)))
                && SCM_STRING_LENGTH(line_str) >= 13
 #ifdef SCM_REGEXP_MULTI_LINE
-               && SCM_REGMATCHP(Scm_RegExec(SCM_REGEXP(rx), SCM_STRING(line_str), SCM_UNDEFINED, SCM_UNDEFINED))) {
+               && SCM_REGMATCHP(rm = Scm_RegExec(SCM_REGEXP(rx), SCM_STRING(line_str), SCM_UNDEFINED, SCM_UNDEFINED))) {
 #else
-               && SCM_REGMATCHP(Scm_RegExec(SCM_REGEXP(rx), SCM_STRING(line_str)))) {
+               && SCM_REGMATCHP(rm = Scm_RegExec(SCM_REGEXP(rx), SCM_STRING(line_str)))) {
 #endif
-            if (SCM_EOFP(line_str = Scm_ReadLineUnsafe(SCM_PORT(in)))) {
-                Scm_Error("[bug] unexpected EOF while parsing macro body");
+            if (SCM_TRUEP(is_gcc)) {
+                if (SCM_EOFP(line_str = Scm_ReadLineUnsafe(SCM_PORT(in)))) {
+                    Scm_Error("[bug] unexpected EOF while parsing macro body");
+                }
+                body_str = Scm_StringAppend2(SCM_STRING(body_str), SCM_STRING(line_str));
+            } else {
+                n = SCM_INT_VALUE(Scm_StringToNumber(SCM_STRING(Scm_RegMatchSubstr(SCM_REGMATCH(rm), SCM_MAKE_INT(1))), 10, 0));
             }
-            body_str = Scm_StringAppend2(SCM_STRING(body_str), SCM_STRING(line_str));
         }
+parse:
         if (SCM_NULLP(macro_list)) {
             Scm_Error("[bug] lost macro body");
         } else {