summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorCarl Worth <cworth@cworth.org>2010-05-20 14:29:43 -0700
committerCarl Worth <cworth@cworth.org>2010-05-20 14:29:43 -0700
commit5a6b9a27fdb2ac66aaadd90b15b1889fea8f08d0 (patch)
tree1a0b226c9abf5be1280eddf66af93b1f7e895c46
parent005b32061f77008530a290ed991980a579095002 (diff)
Avoid printing a space at the beginning of lines in the output.
This fixes more differences compared to "gcc -E" so removes several cases of erroneously failing test cases. The implementation isn't very elegant, but it is functional.
-rw-r--r--glcpp-lex.l5
-rw-r--r--glcpp-parse.y18
-rw-r--r--glcpp.h1
3 files changed, 17 insertions, 7 deletions
diff --git a/glcpp-lex.l b/glcpp-lex.l
index 8e3ab66..13e4d6f 100644
--- a/glcpp-lex.l
+++ b/glcpp-lex.l
@@ -173,7 +173,12 @@ TOKEN [^[:space:](),]+
}
\n {
+ /* XXX: Printing here (rather than in a parser production)
+ * *and* frobbing a bit of the parser state here are both ugly
+ * things. But all my attempts to avoid this by returning a
+ * NEWLINE token here have led to even more ugly things. */
printf ("\n");
+ yyextra->just_printed_separator = 1;
}
{HSPACE}+
diff --git a/glcpp-parse.y b/glcpp-parse.y
index c6d6417..93713a3 100644
--- a/glcpp-parse.y
+++ b/glcpp-parse.y
@@ -114,7 +114,7 @@ glcpp_parser_lex (glcpp_parser_t *parser);
%lex-param {glcpp_parser_t *parser}
%token DEFINE FUNC_MACRO IDENTIFIER IDENTIFIER_FINALIZED OBJ_MACRO NEWLINE SEPARATOR SPACE TOKEN UNDEF
-%type <ival> input punctuator
+%type <ival> punctuator
%type <str> content FUNC_MACRO IDENTIFIER IDENTIFIER_FINALIZED OBJ_MACRO
%type <argument_list> argument_list
%type <string_list> macro parameter_list
@@ -144,7 +144,7 @@ glcpp_parser_lex (glcpp_parser_t *parser);
* character between any two. */
input:
/* empty */ {
- $$ = SEPARATOR;
+ parser->just_printed_separator = 1;
}
| input content {
int is_token;
@@ -157,16 +157,18 @@ input:
(c >= '0' && c <= '9') ||
(c == '_'));
- if ($1 == TOKEN && is_not_separator)
+ if (! parser->just_printed_separator && is_not_separator)
+ {
printf (" ");
+ }
printf ("%s", $2);
+
if (is_not_separator)
- $$ = TOKEN;
+ parser->just_printed_separator = 0;
else
- $$ = SEPARATOR;
- } else {
- $$ = $1;
+ parser->just_printed_separator = 1;
}
+
if ($2)
talloc_free ($2);
}
@@ -561,6 +563,8 @@ glcpp_parser_create (void)
hash_table_string_compare);
parser->expansions = NULL;
+ parser->just_printed_separator = 1;
+
return parser;
}
diff --git a/glcpp.h b/glcpp.h
index 5432a31..c25e29c 100644
--- a/glcpp.h
+++ b/glcpp.h
@@ -101,6 +101,7 @@ struct glcpp_parser {
yyscan_t scanner;
struct hash_table *defines;
expansion_node_t *expansions;
+ int just_printed_separator;
};
void