/* Type information for objc/objc-act.cc.
Copyright (C) 2004-2022 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_hashed_entry (void *x_p)
{
struct hashed_entry * const x = (struct hashed_entry *)x_p;
if (ggc_test_and_set_mark (x))
{
gt_ggc_m_16hashed_attribute ((*x).list);
gt_ggc_m_12hashed_entry ((*x).next);
gt_ggc_m_9tree_node ((*x).key);
}
}
void
gt_ggc_mx_hashed_attribute (void *x_p)
{
struct hashed_attribute * const x = (struct hashed_attribute *)x_p;
if (ggc_test_and_set_mark (x))
{
gt_ggc_m_16hashed_attribute ((*x).next);
gt_ggc_m_9tree_node ((*x).value);
}
}
void
gt_ggc_mx_imp_entry (void *x_p)
{
struct imp_entry * const x = (struct imp_entry *)x_p;
if (ggc_test_and_set_mark (x))
{
gt_ggc_m_9imp_entry ((*x).next);
gt_ggc_m_9tree_node ((*x).imp_context);
gt_ggc_m_9tree_node ((*x).imp_template);
gt_ggc_m_9tree_node ((*x).class_decl);
gt_ggc_m_9tree_node ((*x).meta_decl);
}
}
void
gt_ggc_mx_string_descriptor (void *x_p)
{
struct string_descriptor * const x = (struct string_descriptor *)x_p;
if (ggc_test_and_set_mark (x))
{
gt_ggc_m_9tree_node ((*x).literal);
gt_ggc_m_9tree_node ((*x).constructor);
}
}
void
gt_ggc_mx (struct string_descriptor& x_r ATTRIBUTE_UNUSED)
{
struct string_descriptor * ATTRIBUTE_UNUSED x = &x_r;
gt_ggc_m_9tree_node ((*x).literal);
gt_ggc_m_9tree_node ((*x).constructor);
}
void
gt_ggc_mx (struct string_descriptor *& x)
{
if (x)
gt_ggc_mx_string_descriptor ((void *) x);
}
void
gt_ggc_mx_hash_table_objc_string_hasher_ (void *x_p)
{
hash_table * const x = (hash_table *)x_p;
if (ggc_test_and_set_mark (x))
{
gt_ggc_mx (x);
}
}
void
gt_ggc_mx (struct objc_string_hasher& x_r ATTRIBUTE_UNUSED)
{
struct objc_string_hasher * ATTRIBUTE_UNUSED x = &x_r;
}
void
gt_pch_nx_hashed_entry (void *x_p)
{
struct hashed_entry * const x = (struct hashed_entry *)x_p;
if (gt_pch_note_object (x, x, gt_pch_p_12hashed_entry))
{
gt_pch_n_16hashed_attribute ((*x).list);
gt_pch_n_12hashed_entry ((*x).next);
gt_pch_n_9tree_node ((*x).key);
}
}
void
gt_pch_nx_hashed_attribute (void *x_p)
{
struct hashed_attribute * const x = (struct hashed_attribute *)x_p;
if (gt_pch_note_object (x, x, gt_pch_p_16hashed_attribute))
{
gt_pch_n_16hashed_attribute ((*x).next);
gt_pch_n_9tree_node ((*x).value);
}
}
void
gt_pch_nx_imp_entry (void *x_p)
{
struct imp_entry * const x = (struct imp_entry *)x_p;
if (gt_pch_note_object (x, x, gt_pch_p_9imp_entry))
{
gt_pch_n_9imp_entry ((*x).next);
gt_pch_n_9tree_node ((*x).imp_context);
gt_pch_n_9tree_node ((*x).imp_template);
gt_pch_n_9tree_node ((*x).class_decl);
gt_pch_n_9tree_node ((*x).meta_decl);
}
}
void
gt_pch_nx_string_descriptor (void *x_p)
{
struct string_descriptor * const x = (struct string_descriptor *)x_p;
if (gt_pch_note_object (x, x, gt_pch_p_17string_descriptor))
{
gt_pch_n_9tree_node ((*x).literal);
gt_pch_n_9tree_node ((*x).constructor);
}
}
void
gt_pch_nx (struct string_descriptor& x_r ATTRIBUTE_UNUSED)
{
struct string_descriptor * ATTRIBUTE_UNUSED x = &x_r;
gt_pch_n_9tree_node ((*x).literal);
gt_pch_n_9tree_node ((*x).constructor);
}
void
gt_pch_nx (struct string_descriptor *& x)
{
if (x)
gt_pch_nx_string_descriptor ((void *) x);
}
void
gt_pch_nx_hash_table_objc_string_hasher_ (void *x_p)
{
hash_table * const x = (hash_table *)x_p;
if (gt_pch_note_object (x, x, gt_pch_p_30hash_table_objc_string_hasher_))
{
gt_pch_nx (x);
}
}
void
gt_pch_nx (struct objc_string_hasher& x_r ATTRIBUTE_UNUSED)
{
struct objc_string_hasher * ATTRIBUTE_UNUSED x = &x_r;
}
void
gt_pch_p_12hashed_entry (ATTRIBUTE_UNUSED void *this_obj,
void *x_p,
ATTRIBUTE_UNUSED gt_pointer_operator op,
ATTRIBUTE_UNUSED void *cookie)
{
struct hashed_entry * x ATTRIBUTE_UNUSED = (struct hashed_entry *)x_p;
if ((void *)(x) == this_obj)
op (&((*x).list), NULL, cookie);
if ((void *)(x) == this_obj)
op (&((*x).next), NULL, cookie);
if ((void *)(x) == this_obj)
op (&((*x).key), NULL, cookie);
}
void
gt_pch_p_16hashed_attribute (ATTRIBUTE_UNUSED void *this_obj,
void *x_p,
ATTRIBUTE_UNUSED gt_pointer_operator op,
ATTRIBUTE_UNUSED void *cookie)
{
struct hashed_attribute * x ATTRIBUTE_UNUSED = (struct hashed_attribute *)x_p;
if ((void *)(x) == this_obj)
op (&((*x).next), NULL, cookie);
if ((void *)(x) == this_obj)
op (&((*x).value), NULL, cookie);
}
void
gt_pch_p_9imp_entry (ATTRIBUTE_UNUSED void *this_obj,
void *x_p,
ATTRIBUTE_UNUSED gt_pointer_operator op,
ATTRIBUTE_UNUSED void *cookie)
{
struct imp_entry * x ATTRIBUTE_UNUSED = (struct imp_entry *)x_p;
if ((void *)(x) == this_obj)
op (&((*x).next), NULL, cookie);
if ((void *)(x) == this_obj)
op (&((*x).imp_context), NULL, cookie);
if ((void *)(x) == this_obj)
op (&((*x).imp_template), NULL, cookie);
if ((void *)(x) == this_obj)
op (&((*x).class_decl), NULL, cookie);
if ((void *)(x) == this_obj)
op (&((*x).meta_decl), NULL, cookie);
}
void
gt_pch_p_17string_descriptor (ATTRIBUTE_UNUSED void *this_obj,
void *x_p,
ATTRIBUTE_UNUSED gt_pointer_operator op,
ATTRIBUTE_UNUSED void *cookie)
{
struct string_descriptor * x ATTRIBUTE_UNUSED = (struct string_descriptor *)x_p;
if ((void *)(x) == this_obj)
op (&((*x).literal), NULL, cookie);
if ((void *)(x) == this_obj)
op (&((*x).constructor), NULL, cookie);
}
void
gt_pch_nx (struct string_descriptor* x ATTRIBUTE_UNUSED,
ATTRIBUTE_UNUSED gt_pointer_operator op,
ATTRIBUTE_UNUSED void *cookie)
{
op (&((*x).literal), NULL, cookie);
op (&((*x).constructor), NULL, cookie);
}
void
gt_pch_p_30hash_table_objc_string_hasher_ (ATTRIBUTE_UNUSED void *this_obj,
void *x_p,
ATTRIBUTE_UNUSED gt_pointer_operator op,
ATTRIBUTE_UNUSED void *cookie)
{
struct hash_table * x ATTRIBUTE_UNUSED = (struct hash_table *)x_p;
if ((void *)(x) == this_obj)
gt_pch_nx (&((*x)), op, cookie);
}
void
gt_pch_nx (struct objc_string_hasher* x ATTRIBUTE_UNUSED,
ATTRIBUTE_UNUSED gt_pointer_operator op,
ATTRIBUTE_UNUSED void *cookie)
{
}
/* GC roots. */
EXPORTED_CONST struct ggc_root_tab gt_ggc_r_gt_objc_objc_act_h[] = {
{
&objc_parmlist,
1,
sizeof (objc_parmlist),
>_ggc_mx_tree_node,
>_pch_nx_tree_node
},
{
&interface_map,
1,
sizeof (interface_map),
>_ggc_mx_objc_map_private,
>_pch_nx_objc_map_private
},
{
&string_htab,
1,
sizeof (string_htab),
>_ggc_mx_hash_table_objc_string_hasher_,
>_pch_nx_hash_table_objc_string_hasher_
},
{
&alias_name_map,
1,
sizeof (alias_name_map),
>_ggc_mx_objc_map_private,
>_pch_nx_objc_map_private
},
{
&class_name_map,
1,
sizeof (class_name_map),
>_ggc_mx_objc_map_private,
>_pch_nx_objc_map_private
},
{
&class_method_map,
1,
sizeof (class_method_map),
>_ggc_mx_objc_map_private,
>_pch_nx_objc_map_private
},
{
&instance_method_map,
1,
sizeof (instance_method_map),
>_ggc_mx_objc_map_private,
>_pch_nx_objc_map_private
},
{
&objc_global_trees[0],
1 * (OCTI_MAX),
sizeof (objc_global_trees[0]),
>_ggc_mx_tree_node,
>_pch_nx_tree_node
},
{
&imp_list,
1,
sizeof (imp_list),
>_ggc_mx_imp_entry,
>_pch_nx_imp_entry
},
{
&local_variables_to_volatilize,
1,
sizeof (local_variables_to_volatilize),
>_ggc_mx_vec_tree_va_gc_,
>_pch_nx_vec_tree_va_gc_
},
LAST_GGC_ROOT_TAB
};
EXPORTED_CONST struct ggc_root_tab gt_pch_rs_gt_objc_objc_act_h[] = {
{ &string_layout_checked, 1, sizeof (string_layout_checked), NULL, NULL },
{ &objc_ivar_visibility, 1, sizeof (objc_ivar_visibility), NULL, NULL },
{ &cat_count, 1, sizeof (cat_count), NULL, NULL },
{ &imp_count, 1, sizeof (imp_count), NULL, NULL },
LAST_GGC_ROOT_TAB
};