/* Type information for cp/pt.cc.
Copyright (C) 2004-2023 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_tinst_level (void *x_p)
{
struct tinst_level * x = (struct tinst_level *)x_p;
struct tinst_level * xlimit = x;
while (ggc_test_and_set_mark (xlimit))
xlimit = ((*xlimit).next);
while (x != xlimit)
{
gt_ggc_m_11tinst_level ((*x).next);
gt_ggc_m_9tree_node ((*x).tldcl);
gt_ggc_m_9tree_node ((*x).targs);
gt_ggc_m_11bitmap_head ((*x).path);
gt_ggc_m_11bitmap_head ((*x).visible);
x = ((*x).next);
}
}
void
gt_ggc_mx_pending_template (void *x_p)
{
struct pending_template * x = (struct pending_template *)x_p;
struct pending_template * xlimit = x;
while (ggc_test_and_set_mark (xlimit))
xlimit = ((*xlimit).next);
while (x != xlimit)
{
gt_ggc_m_16pending_template ((*x).next);
gt_ggc_m_11tinst_level ((*x).tinst);
x = ((*x).next);
}
}
void
gt_ggc_mx_hash_table_spec_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 spec_hasher& x_r ATTRIBUTE_UNUSED)
{
struct spec_hasher * ATTRIBUTE_UNUSED x = &x_r;
}
void
gt_ggc_mx_hash_table_ctp_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 ctp_hasher& x_r ATTRIBUTE_UNUSED)
{
struct ctp_hasher * ATTRIBUTE_UNUSED x = &x_r;
}
void
gt_ggc_mx_hash_map_tree_tree_pair_p_ (void *x_p)
{
hash_map * const x = (hash_map *)x_p;
if (ggc_test_and_set_mark (x))
{
gt_ggc_mx (x);
}
}
void
gt_ggc_mx (struct tree_pair_s *& x)
{
if (x)
gt_ggc_mx_tree_pair_s ((void *) x);
}
void
gt_pch_nx_tinst_level (void *x_p)
{
struct tinst_level * x = (struct tinst_level *)x_p;
struct tinst_level * xlimit = x;
while (gt_pch_note_object (xlimit, xlimit, gt_pch_p_11tinst_level))
xlimit = ((*xlimit).next);
while (x != xlimit)
{
gt_pch_n_11tinst_level ((*x).next);
gt_pch_n_9tree_node ((*x).tldcl);
gt_pch_n_9tree_node ((*x).targs);
gt_pch_n_11bitmap_head ((*x).path);
gt_pch_n_11bitmap_head ((*x).visible);
x = ((*x).next);
}
}
void
gt_pch_nx_pending_template (void *x_p)
{
struct pending_template * x = (struct pending_template *)x_p;
struct pending_template * xlimit = x;
while (gt_pch_note_object (xlimit, xlimit, gt_pch_p_16pending_template))
xlimit = ((*xlimit).next);
while (x != xlimit)
{
gt_pch_n_16pending_template ((*x).next);
gt_pch_n_11tinst_level ((*x).tinst);
x = ((*x).next);
}
}
void
gt_pch_nx_hash_table_spec_hasher_ (void *x_p)
{
hash_table * const x = (hash_table *)x_p;
if (gt_pch_note_object (x, x, gt_pch_p_23hash_table_spec_hasher_))
{
gt_pch_nx (x);
}
}
void
gt_pch_nx (struct spec_hasher& x_r ATTRIBUTE_UNUSED)
{
struct spec_hasher * ATTRIBUTE_UNUSED x = &x_r;
}
void
gt_pch_nx_hash_table_ctp_hasher_ (void *x_p)
{
hash_table * const x = (hash_table *)x_p;
if (gt_pch_note_object (x, x, gt_pch_p_22hash_table_ctp_hasher_))
{
gt_pch_nx (x);
}
}
void
gt_pch_nx (struct ctp_hasher& x_r ATTRIBUTE_UNUSED)
{
struct ctp_hasher * ATTRIBUTE_UNUSED x = &x_r;
}
void
gt_pch_nx_hash_map_tree_tree_pair_p_ (void *x_p)
{
hash_map * const x = (hash_map *)x_p;
if (gt_pch_note_object (x, x, gt_pch_p_26hash_map_tree_tree_pair_p_))
{
gt_pch_nx (x);
}
}
void
gt_pch_nx (struct tree_pair_s *& x)
{
if (x)
gt_pch_nx_tree_pair_s ((void *) x);
}
void
gt_pch_p_11tinst_level (ATTRIBUTE_UNUSED void *this_obj,
void *x_p,
ATTRIBUTE_UNUSED gt_pointer_operator op,
ATTRIBUTE_UNUSED void *cookie)
{
struct tinst_level * x ATTRIBUTE_UNUSED = (struct tinst_level *)x_p;
if ((void *)(x) == this_obj)
op (&((*x).next), NULL, cookie);
if ((void *)(x) == this_obj)
op (&((*x).tldcl), NULL, cookie);
if ((void *)(x) == this_obj)
op (&((*x).targs), NULL, cookie);
if ((void *)(x) == this_obj)
op (&((*x).path), NULL, cookie);
if ((void *)(x) == this_obj)
op (&((*x).visible), NULL, cookie);
}
void
gt_pch_p_16pending_template (ATTRIBUTE_UNUSED void *this_obj,
void *x_p,
ATTRIBUTE_UNUSED gt_pointer_operator op,
ATTRIBUTE_UNUSED void *cookie)
{
struct pending_template * x ATTRIBUTE_UNUSED = (struct pending_template *)x_p;
if ((void *)(x) == this_obj)
op (&((*x).next), NULL, cookie);
if ((void *)(x) == this_obj)
op (&((*x).tinst), NULL, cookie);
}
void
gt_pch_p_23hash_table_spec_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 spec_hasher* x ATTRIBUTE_UNUSED,
ATTRIBUTE_UNUSED gt_pointer_operator op,
ATTRIBUTE_UNUSED void *cookie)
{
}
void
gt_pch_p_22hash_table_ctp_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 ctp_hasher* x ATTRIBUTE_UNUSED,
ATTRIBUTE_UNUSED gt_pointer_operator op,
ATTRIBUTE_UNUSED void *cookie)
{
}
void
gt_pch_p_26hash_map_tree_tree_pair_p_ (ATTRIBUTE_UNUSED void *this_obj,
void *x_p,
ATTRIBUTE_UNUSED gt_pointer_operator op,
ATTRIBUTE_UNUSED void *cookie)
{
struct hash_map * x ATTRIBUTE_UNUSED = (struct hash_map *)x_p;
if ((void *)(x) == this_obj)
gt_pch_nx (&((*x)), op, cookie);
}
/* GC roots. */
EXPORTED_CONST struct ggc_root_tab gt_ggc_r_gt_cp_pt_h[] = {
{
&explicit_specifier_map,
1,
sizeof (explicit_specifier_map),
>_ggc_mx_hash_map_tree_tree_decl_tree_cache_traits_,
>_pch_nx_hash_map_tree_tree_decl_tree_cache_traits_
},
{
&defarg_inst,
1,
sizeof (defarg_inst),
>_ggc_mx_hash_table_tree_vec_map_cache_hasher_,
>_pch_nx_hash_table_tree_vec_map_cache_hasher_
},
{
&last_error_tinst_level,
1,
sizeof (last_error_tinst_level),
>_ggc_mx_tinst_level,
>_pch_nx_tinst_level
},
{
&tparm_obj_values,
1,
sizeof (tparm_obj_values),
>_ggc_mx_hash_map_tree_tree_,
>_pch_nx_hash_map_tree_tree_
},
{
&ctp_table,
1,
sizeof (ctp_table),
>_ggc_mx_hash_table_ctp_hasher_,
>_pch_nx_hash_table_ctp_hasher_
},
{
&canonical_template_parms,
1,
sizeof (canonical_template_parms),
>_ggc_mx_vec_tree_va_gc_,
>_pch_nx_vec_tree_va_gc_
},
{
&type_specializations,
1,
sizeof (type_specializations),
>_ggc_mx_hash_table_spec_hasher_,
>_pch_nx_hash_table_spec_hasher_
},
{
&decl_specializations,
1,
sizeof (decl_specializations),
>_ggc_mx_hash_table_spec_hasher_,
>_pch_nx_hash_table_spec_hasher_
},
{
&saved_access_scope,
1,
sizeof (saved_access_scope),
>_ggc_mx_vec_tree_va_gc_,
>_pch_nx_vec_tree_va_gc_
},
{
¤t_tinst_level,
1,
sizeof (current_tinst_level),
>_ggc_mx_tinst_level,
>_pch_nx_tinst_level
},
{
&last_pending_template,
1,
sizeof (last_pending_template),
>_ggc_mx_pending_template,
>_pch_nx_pending_template
},
{
&pending_templates,
1,
sizeof (pending_templates),
>_ggc_mx_pending_template,
>_pch_nx_pending_template
},
LAST_GGC_ROOT_TAB
};
EXPORTED_CONST struct ggc_root_tab gt_ggc_rd_gt_cp_pt_h[] = {
{ &dguide_cache, 1, sizeof (dguide_cache), NULL, NULL },
{ &pending_template_freelist_head, 1, sizeof (pending_template_freelist_head), NULL, NULL },
{ &tinst_level_freelist_head, 1, sizeof (tinst_level_freelist_head), NULL, NULL },
{ &tree_list_freelist_head, 1, sizeof (tree_list_freelist_head), NULL, NULL },
{ &defaulted_ttp_cache, 1, sizeof (defaulted_ttp_cache), NULL, NULL },
LAST_GGC_ROOT_TAB
};
void
gt_clear_caches_gt_cp_pt_h ()
{
gt_cleare_cache (explicit_specifier_map);
gt_cleare_cache (defarg_inst);
}