/* Type information for objc/objc-next-runtime-abi-02.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_ivarref_entry_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 ivarref_entry& x_r ATTRIBUTE_UNUSED)
{
struct ivarref_entry * ATTRIBUTE_UNUSED x = &x_r;
gt_ggc_m_9tree_node ((*x).decl);
gt_ggc_m_9tree_node ((*x).offset);
}
void
gt_ggc_mx_vec_prot_list_entry_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 prot_list_entry& x_r ATTRIBUTE_UNUSED)
{
struct prot_list_entry * ATTRIBUTE_UNUSED x = &x_r;
gt_ggc_m_9tree_node ((*x).id);
gt_ggc_m_9tree_node ((*x).refdecl);
}
void
gt_ggc_mx_vec_msgref_entry_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 msgref_entry& x_r ATTRIBUTE_UNUSED)
{
struct msgref_entry * ATTRIBUTE_UNUSED x = &x_r;
gt_ggc_m_9tree_node ((*x).func);
gt_ggc_m_9tree_node ((*x).selname);
gt_ggc_m_9tree_node ((*x).refdecl);
}
void
gt_ggc_mx_vec_ident_data_tuple_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 ident_data_tuple& x_r ATTRIBUTE_UNUSED)
{
struct ident_data_tuple * ATTRIBUTE_UNUSED x = &x_r;
gt_ggc_m_9tree_node ((*x).ident);
gt_ggc_m_9tree_node ((*x).data);
}
void
gt_pch_nx_vec_ivarref_entry_va_gc_ (void *x_p)
{
vec * const x = (vec *)x_p;
if (gt_pch_note_object (x, x, gt_pch_p_24vec_ivarref_entry_va_gc_))
{
gt_pch_nx (x);
}
}
void
gt_pch_nx (struct ivarref_entry& x_r ATTRIBUTE_UNUSED)
{
struct ivarref_entry * ATTRIBUTE_UNUSED x = &x_r;
gt_pch_n_9tree_node ((*x).decl);
gt_pch_n_9tree_node ((*x).offset);
}
void
gt_pch_nx_vec_prot_list_entry_va_gc_ (void *x_p)
{
vec * const x = (vec *)x_p;
if (gt_pch_note_object (x, x, gt_pch_p_26vec_prot_list_entry_va_gc_))
{
gt_pch_nx (x);
}
}
void
gt_pch_nx (struct prot_list_entry& x_r ATTRIBUTE_UNUSED)
{
struct prot_list_entry * ATTRIBUTE_UNUSED x = &x_r;
gt_pch_n_9tree_node ((*x).id);
gt_pch_n_9tree_node ((*x).refdecl);
}
void
gt_pch_nx_vec_msgref_entry_va_gc_ (void *x_p)
{
vec * const x = (vec *)x_p;
if (gt_pch_note_object (x, x, gt_pch_p_23vec_msgref_entry_va_gc_))
{
gt_pch_nx (x);
}
}
void
gt_pch_nx (struct msgref_entry& x_r ATTRIBUTE_UNUSED)
{
struct msgref_entry * ATTRIBUTE_UNUSED x = &x_r;
gt_pch_n_9tree_node ((*x).func);
gt_pch_n_9tree_node ((*x).selname);
gt_pch_n_9tree_node ((*x).refdecl);
}
void
gt_pch_nx_vec_ident_data_tuple_va_gc_ (void *x_p)
{
vec * const x = (vec *)x_p;
if (gt_pch_note_object (x, x, gt_pch_p_27vec_ident_data_tuple_va_gc_))
{
gt_pch_nx (x);
}
}
void
gt_pch_nx (struct ident_data_tuple& x_r ATTRIBUTE_UNUSED)
{
struct ident_data_tuple * ATTRIBUTE_UNUSED x = &x_r;
gt_pch_n_9tree_node ((*x).ident);
gt_pch_n_9tree_node ((*x).data);
}
void
gt_pch_p_24vec_ivarref_entry_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 ivarref_entry* x ATTRIBUTE_UNUSED,
ATTRIBUTE_UNUSED gt_pointer_operator op,
ATTRIBUTE_UNUSED void *cookie)
{
op (&((*x).decl), cookie);
op (&((*x).offset), cookie);
}
void
gt_pch_p_26vec_prot_list_entry_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 prot_list_entry* x ATTRIBUTE_UNUSED,
ATTRIBUTE_UNUSED gt_pointer_operator op,
ATTRIBUTE_UNUSED void *cookie)
{
op (&((*x).id), cookie);
op (&((*x).refdecl), cookie);
}
void
gt_pch_p_23vec_msgref_entry_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 msgref_entry* x ATTRIBUTE_UNUSED,
ATTRIBUTE_UNUSED gt_pointer_operator op,
ATTRIBUTE_UNUSED void *cookie)
{
op (&((*x).func), cookie);
op (&((*x).selname), cookie);
op (&((*x).refdecl), cookie);
}
void
gt_pch_p_27vec_ident_data_tuple_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 ident_data_tuple* x ATTRIBUTE_UNUSED,
ATTRIBUTE_UNUSED gt_pointer_operator op,
ATTRIBUTE_UNUSED void *cookie)
{
op (&((*x).ident), cookie);
op (&((*x).data), cookie);
}
/* GC roots. */
static void gt_ggc_ma_extern_names (void *);
static void
gt_ggc_ma_extern_names (ATTRIBUTE_UNUSED void *x_p)
{
if (extern_names != NULL) {
size_t i0;
for (i0 = 0; i0 != (size_t)(SIZEHASHTABLE); i0++) {
gt_ggc_m_12hashed_entry (extern_names[i0]);
}
ggc_mark (extern_names);
}
}
static void gt_pch_pa_extern_names
(void *, void *, gt_pointer_operator, void *);
static void gt_pch_pa_extern_names (ATTRIBUTE_UNUSED void *this_obj,
ATTRIBUTE_UNUSED void *x_p,
ATTRIBUTE_UNUSED gt_pointer_operator op,
ATTRIBUTE_UNUSED void * cookie)
{
if (extern_names != NULL) {
size_t i0;
for (i0 = 0; i0 != (size_t)(SIZEHASHTABLE) && ((void *)extern_names == this_obj); i0++) {
if ((void *)(extern_names) == this_obj)
op (&(extern_names[i0]), cookie);
}
if ((void *)(&extern_names) == this_obj)
op (&(extern_names), cookie);
}
}
static void gt_pch_na_extern_names (void *);
static void
gt_pch_na_extern_names (ATTRIBUTE_UNUSED void *x_p)
{
if (extern_names != NULL) {
size_t i0;
for (i0 = 0; i0 != (size_t)(SIZEHASHTABLE); i0++) {
gt_pch_n_12hashed_entry (extern_names[i0]);
}
gt_pch_note_object (extern_names, &extern_names, gt_pch_pa_extern_names);
}
}
EXPORTED_CONST struct ggc_root_tab gt_ggc_r_gt_objc_objc_next_runtime_abi_02_h[] = {
{
&objc_eh_personality_decl,
1,
sizeof (objc_eh_personality_decl),
>_ggc_mx_tree_node,
>_pch_nx_tree_node
},
{
&next_v2_EHTYPE_id_decl,
1,
sizeof (next_v2_EHTYPE_id_decl),
>_ggc_mx_tree_node,
>_pch_nx_tree_node
},
{
&next_v2_ehvtable_decl,
1,
sizeof (next_v2_ehvtable_decl),
>_ggc_mx_tree_node,
>_pch_nx_tree_node
},
{
&objc_v2_ehtype_template,
1,
sizeof (objc_v2_ehtype_template),
>_ggc_mx_tree_node,
>_pch_nx_tree_node
},
{
&ehtype_list,
1,
sizeof (ehtype_list),
>_ggc_mx_vec_ident_data_tuple_va_gc_,
>_pch_nx_vec_ident_data_tuple_va_gc_
},
{
&ivar_offset_refs,
1,
sizeof (ivar_offset_refs),
>_ggc_mx_vec_ivarref_entry_va_gc_,
>_pch_nx_vec_ivarref_entry_va_gc_
},
{
&protlist,
1,
sizeof (protlist),
>_ggc_mx_vec_prot_list_entry_va_gc_,
>_pch_nx_vec_prot_list_entry_va_gc_
},
{
&nonlazy_category_list,
1,
sizeof (nonlazy_category_list),
>_ggc_mx_vec_tree_va_gc_,
>_pch_nx_vec_tree_va_gc_
},
{
&category_list,
1,
sizeof (category_list),
>_ggc_mx_vec_tree_va_gc_,
>_pch_nx_vec_tree_va_gc_
},
{
&nonlazy_class_list,
1,
sizeof (nonlazy_class_list),
>_ggc_mx_vec_tree_va_gc_,
>_pch_nx_vec_tree_va_gc_
},
{
&class_list,
1,
sizeof (class_list),
>_ggc_mx_vec_tree_va_gc_,
>_pch_nx_vec_tree_va_gc_
},
{
&metaclass_super_refs,
1,
sizeof (metaclass_super_refs),
>_ggc_mx_vec_ident_data_tuple_va_gc_,
>_pch_nx_vec_ident_data_tuple_va_gc_
},
{
&class_super_refs,
1,
sizeof (class_super_refs),
>_ggc_mx_vec_ident_data_tuple_va_gc_,
>_pch_nx_vec_ident_data_tuple_va_gc_
},
{
&protrefs,
1,
sizeof (protrefs),
>_ggc_mx_vec_prot_list_entry_va_gc_,
>_pch_nx_vec_prot_list_entry_va_gc_
},
{
&msgrefs,
1,
sizeof (msgrefs),
>_ggc_mx_vec_msgref_entry_va_gc_,
>_pch_nx_vec_msgref_entry_va_gc_
},
{
&classrefs,
1,
sizeof (classrefs),
>_ggc_mx_vec_ident_data_tuple_va_gc_,
>_pch_nx_vec_ident_data_tuple_va_gc_
},
{
&extern_names,
1,
sizeof (extern_names),
>_ggc_ma_extern_names,
>_pch_na_extern_names
},
{
&objc_v2_global_trees[0],
1 * (OCTI_V2_MAX),
sizeof (objc_v2_global_trees[0]),
>_ggc_mx_tree_node,
>_pch_nx_tree_node
},
{
&objc_rt_trees[0],
1 * (OCTI_RT_META_MAX),
sizeof (objc_rt_trees[0]),
>_ggc_mx_tree_node,
>_pch_nx_tree_node
},
LAST_GGC_ROOT_TAB
};