case PSI_T_NAME:
dump_decl_var(fd, exp->u.dvar);
break;
+ case PSI_T_ENUM:
+ dprintf(fd, "%s", exp->u.enm->name);
+ break;
EMPTY_SWITCH_DEFAULT_CASE();
}
if (exp->operand) {
}
}
-static inline void dump_typedef(int fd, decl_typedef *tdef) {
+static inline void dump_typedef(int fd, decl_arg *tdef) {
dprintf(fd, "typedef ");
+ dump_decl_arg(fd, tdef);
+ /*
dump_decl_type(fd, tdef->type);
dprintf(fd, " %s%s;", tdef->type->type == PSI_T_POINTER ? "*":"",
tdef->alias);
+ */
}
static inline void dump_typedefs(int fd, decl_typedefs *defs) {
size_t i;
for (i = 0; i < defs->count; ++i) {
- decl_typedef *tdef = defs->list[i];
+ decl_arg *tdef = defs->list[i];
dump_typedef(fd, tdef);
dprintf(fd, "\n");
dprintf(fd, ";");
}
}
+
static inline void dump_structs(int fd, decl_structs *structs) {
size_t i;
}
}
+static inline void dump_enum(int fd, decl_enum *e) {
+ size_t j;
+
+ dprintf(fd, "enum %s {\n", e->name);
+ for (j = 0; j < e->items->count; ++j) {
+ decl_enum_item *i = e->items->list[j];
+
+ if (j) {
+ dprintf(fd, ",\n");
+ }
+ dprintf(fd, "\t%s", i->name);
+ if (i->num && i->num != &i->inc) {
+ dprintf(fd, " = ");
+ dump_num_exp(fd, i->num);
+ }
+ }
+ dprintf(fd, "\n}");
+}
+
+static inline void dump_enums(int fd, decl_enums *enums) {
+ size_t i;
+
+ for (i = 0; i < enums->count; ++i) {
+ decl_enum *e = enums->list[i];
+
+ dump_enum(fd, e);
+ dprintf(fd, "\n");
+ }
+}
static inline void dump_constant(int fd, constant *cnst) {
dprintf(fd, "const %s %s = ", cnst->type->name, cnst->name);
if (cnst->val->type == PSI_T_QUOTED_STRING) {
dump_structs(fd, C->structs);
dprintf(fd, "\n");
}
+ if (C->enums) {
+ dump_enums(fd, C->enums);
+ dprintf(fd, "\n");
+ }
if (C->consts) {
dump_constants(fd, C->consts);
dprintf(fd, "\n");