symbol_t *res = XMALLOC (symbol_t, 1);
res->tag = xstrdup (tag);
- res->type_name = NULL;
res->location = location;
+
+ res->type_name = NULL;
+ res->destructor = NULL;
+
res->number = NUMBER_UNDEFINED;
res->prec = 0;
res->assoc = right_assoc;
`------------------------------------------------------------------*/
void
-symbol_type_set (symbol_t *symbol, location_t location, char *type_name)
+symbol_type_set (symbol_t *symbol, char *type_name, location_t location)
{
if (type_name)
{
}
+/*-------------------------------------------------------------------.
+| Set the DESTRUCTOR associated to SYMBOL. Do nothing if passed 0. |
+`-------------------------------------------------------------------*/
+
+void
+symbol_destructor_set (symbol_t *symbol, char *destructor, location_t location)
+{
+ if (destructor)
+ {
+ if (symbol->destructor)
+ complain_at (location,
+ _("%s redeclaration for %s"),
+ "%destructor", symbol_tag_get (symbol));
+ symbol->destructor = destructor;
+ symbol->destructor_location = location;
+ }
+}
+
+
+/*----------------------------------------------------------------.
+| Set the PRITNER associated to SYMBOL. Do nothing if passed 0. |
+`----------------------------------------------------------------*/
+
+void
+symbol_printer_set (symbol_t *symbol, char *printer, location_t location)
+{
+ if (printer)
+ {
+ if (symbol->printer)
+ complain_at (location,
+ _("%s redeclaration for %s"),
+ "%printer", symbol_tag_get (symbol));
+ symbol->printer = printer;
+ symbol->printer_location = location;
+ }
+}
+
+
/*------------------------------------------------------------------.
| Set the PRECEDENCE associated to SYMBOL. Does nothing if invoked |
| with UNDEF_ASSOC as ASSOC. |
`------------------------------------------------------------------*/
void
-symbol_precedence_set (symbol_t *symbol, location_t location,
- int prec, associativity assoc)
+symbol_precedence_set (symbol_t *symbol,
+ int prec, associativity assoc, location_t location)
{
if (assoc != undef_assoc)
{
}
/* Only terminals have a precedence. */
- symbol_class_set (symbol, token_sym);
+ symbol_class_set (symbol, token_sym, location);
}
`-------------------------------------*/
void
-symbol_class_set (symbol_t *symbol, symbol_class class)
+symbol_class_set (symbol_t *symbol, symbol_class class, location_t location)
{
if (symbol->class != unknown_sym && symbol->class != class)
- complain (_("symbol %s redefined"), symbol_tag_get (symbol));
+ complain_at (location, _("symbol %s redefined"), symbol_tag_get (symbol));
if (class == nterm_sym && symbol->class != nterm_sym)
symbol->number = nvars++;
`-------------------------------------------------*/
void
-symbol_user_token_number_set (symbol_t *symbol, int user_token_number)
+symbol_user_token_number_set (symbol_t *symbol,
+ int user_token_number, location_t location)
{
assert (symbol->class == token_sym);
if (symbol->user_token_number != USER_NUMBER_UNDEFINED
&& symbol->user_token_number != user_token_number)
- complain (_("redefining user token number of %s"),
- symbol_tag_get (symbol));
+ complain_at (location, _("redefining user token number of %s"),
+ symbol_tag_get (symbol));
symbol->user_token_number = user_token_number;
/* User defined EOF token? */