/* Type information for cp/decl.c.
Copyright (C) 2004-2014 Free Software Foundation, Inc.
This file is part of GCC.
GCC is free software; you can redistribute it and/or modify it under
the terms of the GNU General Public License as published by the Free
Software Foundation; either version 3, or (at your option) any later
version.
GCC is distributed in the hope that it will be useful, but WITHOUT ANY
WARRANTY; without even the implied warranty of MERCHANTABILITY or
FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
for more details.
You should have received a copy of the GNU General Public License
along with GCC; see the file COPYING3. If not see
. */
/* This file is machine generated. Do not edit. */
void
gt_ggc_mx_vec_incomplete_var_va_gc_ (void *x_p)
{
vec * const x = (vec *)x_p;
if (ggc_test_and_set_mark (x))
{
gt_ggc_mx (x);
}
}
void
gt_ggc_mx (struct incomplete_var_d& x_r ATTRIBUTE_UNUSED)
{
struct incomplete_var_d * ATTRIBUTE_UNUSED x = &x_r;
gt_ggc_m_9tree_node ((*x).decl);
gt_ggc_m_9tree_node ((*x).incomplete_type);
}
void
gt_ggc_mx_named_label_use_entry (void *x_p)
{
struct named_label_use_entry * x = (struct named_label_use_entry *)x_p;
struct named_label_use_entry * xlimit = x;
while (ggc_test_and_set_mark (xlimit))
xlimit = ((*xlimit).next);
while (x != xlimit)
{
gt_ggc_m_21named_label_use_entry ((*x).next);
gt_ggc_m_16cp_binding_level ((*x).binding_level);
gt_ggc_m_9tree_node ((*x).names_in_scope);
x = ((*x).next);
}
}
void
gt_ggc_mx_named_label_entry (void *x_p)
{
struct named_label_entry * const x = (struct named_label_entry *)x_p;
if (ggc_test_and_set_mark (x))
{
gt_ggc_m_9tree_node ((*x).label_decl);
gt_ggc_m_16cp_binding_level ((*x).binding_level);
gt_ggc_m_9tree_node ((*x).names_in_scope);
gt_ggc_m_15vec_tree_va_gc_ ((*x).bad_decls);
gt_ggc_m_21named_label_use_entry ((*x).uses);
}
}
void
gt_ggc_m_P17named_label_entry4htab (void *x_p)
{
struct htab * const x = (struct htab *)x_p;
if (ggc_test_and_set_mark (x))
{
{
size_t l0 = (size_t)(((*x)).size);
if ((*x).entries != NULL) {
size_t i0;
for (i0 = 0; i0 != (size_t)(l0); i0++) {
gt_ggc_m_17named_label_entry ((*x).entries[i0]);
}
ggc_mark ((*x).entries);
}
}
}
}
void
gt_pch_nx_vec_incomplete_var_va_gc_ (void *x_p)
{
vec * const x = (vec *)x_p;
if (gt_pch_note_object (x, x, gt_pch_p_25vec_incomplete_var_va_gc_))
{
gt_pch_nx (x);
}
}
void
gt_pch_nx (struct incomplete_var_d& x_r ATTRIBUTE_UNUSED)
{
struct incomplete_var_d * ATTRIBUTE_UNUSED x = &x_r;
gt_pch_n_9tree_node ((*x).decl);
gt_pch_n_9tree_node ((*x).incomplete_type);
}
void
gt_pch_nx_named_label_use_entry (void *x_p)
{
struct named_label_use_entry * x = (struct named_label_use_entry *)x_p;
struct named_label_use_entry * xlimit = x;
while (gt_pch_note_object (xlimit, xlimit, gt_pch_p_21named_label_use_entry))
xlimit = ((*xlimit).next);
while (x != xlimit)
{
gt_pch_n_21named_label_use_entry ((*x).next);
gt_pch_n_16cp_binding_level ((*x).binding_level);
gt_pch_n_9tree_node ((*x).names_in_scope);
x = ((*x).next);
}
}
void
gt_pch_nx_named_label_entry (void *x_p)
{
struct named_label_entry * const x = (struct named_label_entry *)x_p;
if (gt_pch_note_object (x, x, gt_pch_p_17named_label_entry))
{
gt_pch_n_9tree_node ((*x).label_decl);
gt_pch_n_16cp_binding_level ((*x).binding_level);
gt_pch_n_9tree_node ((*x).names_in_scope);
gt_pch_n_15vec_tree_va_gc_ ((*x).bad_decls);
gt_pch_n_21named_label_use_entry ((*x).uses);
}
}
void
gt_pch_n_P17named_label_entry4htab (void *x_p)
{
struct htab * const x = (struct htab *)x_p;
if (gt_pch_note_object (x, x, gt_pch_p_P17named_label_entry4htab))
{
{
size_t l0 = (size_t)(((*x)).size);
if ((*x).entries != NULL) {
size_t i0;
for (i0 = 0; i0 != (size_t)(l0); i0++) {
gt_pch_n_17named_label_entry ((*x).entries[i0]);
}
gt_pch_note_object ((*x).entries, x, gt_pch_p_P17named_label_entry4htab);
}
}
}
}
void
gt_pch_p_25vec_incomplete_var_va_gc_ (ATTRIBUTE_UNUSED void *this_obj,
void *x_p,
ATTRIBUTE_UNUSED gt_pointer_operator op,
ATTRIBUTE_UNUSED void *cookie)
{
struct vec * x ATTRIBUTE_UNUSED = (struct vec *)x_p;
if ((void *)(x) == this_obj)
gt_pch_nx (&((*x)), op, cookie);
}
void
gt_pch_nx (struct incomplete_var_d* x ATTRIBUTE_UNUSED,
ATTRIBUTE_UNUSED gt_pointer_operator op,
ATTRIBUTE_UNUSED void *cookie)
{
op (&((*x).decl), cookie);
op (&((*x).incomplete_type), cookie);
}
void
gt_pch_p_21named_label_use_entry (ATTRIBUTE_UNUSED void *this_obj,
void *x_p,
ATTRIBUTE_UNUSED gt_pointer_operator op,
ATTRIBUTE_UNUSED void *cookie)
{
struct named_label_use_entry * x ATTRIBUTE_UNUSED = (struct named_label_use_entry *)x_p;
if ((void *)(x) == this_obj)
op (&((*x).next), cookie);
if ((void *)(x) == this_obj)
op (&((*x).binding_level), cookie);
if ((void *)(x) == this_obj)
op (&((*x).names_in_scope), cookie);
}
void
gt_pch_p_17named_label_entry (ATTRIBUTE_UNUSED void *this_obj,
void *x_p,
ATTRIBUTE_UNUSED gt_pointer_operator op,
ATTRIBUTE_UNUSED void *cookie)
{
struct named_label_entry * x ATTRIBUTE_UNUSED = (struct named_label_entry *)x_p;
if ((void *)(x) == this_obj)
op (&((*x).label_decl), cookie);
if ((void *)(x) == this_obj)
op (&((*x).binding_level), cookie);
if ((void *)(x) == this_obj)
op (&((*x).names_in_scope), cookie);
if ((void *)(x) == this_obj)
op (&((*x).bad_decls), cookie);
if ((void *)(x) == this_obj)
op (&((*x).uses), cookie);
}
void
gt_pch_p_P17named_label_entry4htab (ATTRIBUTE_UNUSED void *this_obj,
void *x_p,
ATTRIBUTE_UNUSED gt_pointer_operator op,
ATTRIBUTE_UNUSED void *cookie)
{
struct htab * x ATTRIBUTE_UNUSED = (struct htab *)x_p;
{
size_t l0 = (size_t)(((*x)).size);
if ((*x).entries != NULL) {
size_t i0;
for (i0 = 0; i0 != (size_t)(l0) && ((void *)(*x).entries == this_obj); i0++) {
if ((void *)((*x).entries) == this_obj)
op (&((*x).entries[i0]), cookie);
}
if ((void *)(x) == this_obj)
op (&((*x).entries), cookie);
}
}
}
/* GC roots. */
EXPORTED_CONST struct ggc_root_tab gt_ggc_r_gt_cp_decl_h[] = {
{
&typename_htab,
1,
sizeof (typename_htab),
>_ggc_m_P9tree_node4htab,
>_pch_n_P9tree_node4htab
},
{
&incomplete_vars,
1,
sizeof (incomplete_vars),
>_ggc_mx_vec_incomplete_var_va_gc_,
>_pch_nx_vec_incomplete_var_va_gc_
},
LAST_GGC_ROOT_TAB
};
EXPORTED_CONST struct ggc_root_tab gt_pch_rs_gt_cp_decl_h[] = {
{ &start_cleanup_cnt, 1, sizeof (start_cleanup_cnt), NULL, NULL },
LAST_GGC_ROOT_TAB
};