diff options
author | Basile Starynkevitch <basile@starynkevitch.net> | 2012-10-04 17:22:15 +0000 |
---|---|---|
committer | Basile Starynkevitch <basile@starynkevitch.net> | 2012-10-04 17:22:15 +0000 |
commit | 5694515ac615f8b056605bf5fe379f6913253ac0 (patch) | |
tree | 9ca6aed283ac36761501be69e2e70a114c305e9c /gcc/gengtype.c | |
parent | 0b15935ddee2d095be4b9e5b534a59bcb926a086 (diff) |
Basile Starynkevitch <basile@starynkevitch.net>
* gengtype.c (walk_type): Emit mark_hook when inside a
struct of a union member.
git-svn-id: https://gcc.gnu.org/svn/gcc/trunk@192092 138bc75d-0d04-0410-961f-82ee72b054a4
Diffstat (limited to 'gcc/gengtype.c')
-rw-r--r-- | gcc/gengtype.c | 8 |
1 files changed, 8 insertions, 0 deletions
diff --git a/gcc/gengtype.c b/gcc/gengtype.c index 2ae43726b59..d872b4ea78a 100644 --- a/gcc/gengtype.c +++ b/gcc/gengtype.c @@ -2810,6 +2810,7 @@ walk_type (type_p t, struct walk_type_data *d) const char *oldval = d->val; const char *oldprevval1 = d->prev_val[1]; const char *oldprevval2 = d->prev_val[2]; + const char *struct_mark_hook = NULL; const int union_p = t->kind == TYPE_UNION; int seen_default_p = 0; options_p o; @@ -2833,6 +2834,13 @@ walk_type (type_p t, struct walk_type_data *d) if (!desc && strcmp (o->name, "desc") == 0 && o->kind == OPTION_STRING) desc = o->info.string; + else if (!struct_mark_hook && strcmp (o->name, "mark_hook") == 0 + && o->kind == OPTION_STRING) + struct_mark_hook = o->info.string; + + if (struct_mark_hook) + oprintf (d->of, "%*s%s (&%s));\n", + d->indent, "", struct_mark_hook, oldval); d->prev_val[2] = oldval; d->prev_val[1] = oldprevval2; |