2010-05-10 11:44:09 -07:00
|
|
|
%{
|
|
|
|
|
/*
|
|
|
|
|
* Copyright © 2010 Intel Corporation
|
|
|
|
|
*
|
|
|
|
|
* Permission is hereby granted, free of charge, to any person obtaining a
|
|
|
|
|
* copy of this software and associated documentation files (the "Software"),
|
|
|
|
|
* to deal in the Software without restriction, including without limitation
|
|
|
|
|
* the rights to use, copy, modify, merge, publish, distribute, sublicense,
|
|
|
|
|
* and/or sell copies of the Software, and to permit persons to whom the
|
|
|
|
|
* Software is furnished to do so, subject to the following conditions:
|
|
|
|
|
*
|
|
|
|
|
* The above copyright notice and this permission notice (including the next
|
|
|
|
|
* paragraph) shall be included in all copies or substantial portions of the
|
|
|
|
|
* Software.
|
|
|
|
|
*
|
|
|
|
|
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
|
|
|
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
|
|
|
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
|
|
|
|
|
* THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
|
|
|
|
* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
|
|
|
|
|
* FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
|
|
|
|
|
* DEALINGS IN THE SOFTWARE.
|
|
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
#include <stdio.h>
|
|
|
|
|
#include <stdlib.h>
|
|
|
|
|
|
2010-05-10 13:17:25 -07:00
|
|
|
#include "glcpp.h"
|
|
|
|
|
|
2010-05-10 16:16:06 -07:00
|
|
|
#define YYLEX_PARAM parser->scanner
|
2010-05-10 11:44:09 -07:00
|
|
|
|
|
|
|
|
void
|
2010-05-10 13:17:25 -07:00
|
|
|
yyerror (void *scanner, const char *error);
|
2010-05-10 11:44:09 -07:00
|
|
|
|
2010-05-11 12:30:09 -07:00
|
|
|
const char *
|
|
|
|
|
_resolve_token (glcpp_parser_t *parser, const char *token);
|
|
|
|
|
|
2010-05-10 11:44:09 -07:00
|
|
|
%}
|
|
|
|
|
|
2010-05-10 16:16:06 -07:00
|
|
|
%parse-param {glcpp_parser_t *parser}
|
2010-05-10 11:52:29 -07:00
|
|
|
%lex-param {void *scanner}
|
|
|
|
|
|
2010-05-10 16:16:06 -07:00
|
|
|
%token DEFINE
|
|
|
|
|
%token DEFVAL
|
|
|
|
|
%token IDENTIFIER
|
2010-05-10 11:44:09 -07:00
|
|
|
%token TOKEN
|
|
|
|
|
|
|
|
|
|
%%
|
|
|
|
|
|
|
|
|
|
input: /* empty */
|
2010-05-10 16:16:06 -07:00
|
|
|
| content
|
2010-05-10 11:44:09 -07:00
|
|
|
;
|
|
|
|
|
|
2010-05-10 16:16:06 -07:00
|
|
|
content: token
|
|
|
|
|
| directive
|
|
|
|
|
| content token
|
|
|
|
|
| content directive
|
|
|
|
|
;
|
2010-05-10 11:44:09 -07:00
|
|
|
|
2010-05-10 16:16:06 -07:00
|
|
|
directive: DEFINE IDENTIFIER DEFVAL {
|
|
|
|
|
hash_table_insert (parser->defines, $3, $2);
|
|
|
|
|
}
|
2010-05-10 11:44:09 -07:00
|
|
|
;
|
|
|
|
|
|
2010-05-11 12:30:09 -07:00
|
|
|
token: TOKEN { printf ("%s", _resolve_token (parser, $1)); free ($1); }
|
2010-05-10 11:44:09 -07:00
|
|
|
;
|
|
|
|
|
|
|
|
|
|
%%
|
|
|
|
|
|
|
|
|
|
void
|
2010-05-10 13:17:25 -07:00
|
|
|
yyerror (void *scanner, const char *error)
|
2010-05-10 11:44:09 -07:00
|
|
|
{
|
|
|
|
|
fprintf (stderr, "Parse error: %s\n", error);
|
|
|
|
|
}
|
2010-05-10 16:16:06 -07:00
|
|
|
|
|
|
|
|
void
|
|
|
|
|
glcpp_parser_init (glcpp_parser_t *parser)
|
|
|
|
|
{
|
|
|
|
|
yylex_init (&parser->scanner);
|
|
|
|
|
parser->defines = hash_table_ctor (32, hash_table_string_hash,
|
|
|
|
|
hash_table_string_compare);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
int
|
|
|
|
|
glcpp_parser_parse (glcpp_parser_t *parser)
|
|
|
|
|
{
|
|
|
|
|
return yyparse (parser);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void
|
|
|
|
|
glcpp_parser_fini (glcpp_parser_t *parser)
|
|
|
|
|
{
|
|
|
|
|
yylex_destroy (parser->scanner);
|
|
|
|
|
hash_table_dtor (parser->defines);
|
|
|
|
|
}
|
2010-05-11 12:30:09 -07:00
|
|
|
|
|
|
|
|
const char *
|
|
|
|
|
_resolve_token (glcpp_parser_t *parser, const char *token)
|
|
|
|
|
{
|
|
|
|
|
const char *orig = token;
|
|
|
|
|
const char *replacement;
|
|
|
|
|
|
|
|
|
|
while (1) {
|
|
|
|
|
replacement = hash_table_find (parser->defines, token);
|
|
|
|
|
if (replacement == NULL)
|
|
|
|
|
break;
|
|
|
|
|
token = replacement;
|
|
|
|
|
if (strcmp (token, orig) == 0)
|
|
|
|
|
break;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return token;
|
|
|
|
|
}
|
|
|
|
|
|