/* Type information for cp/decl.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_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).name); gt_ggc_m_9tree_node ((*x).label_decl); gt_ggc_m_17named_label_entry ((*x).outer); 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_mx (struct named_label_entry& x_r ATTRIBUTE_UNUSED) { struct named_label_entry * ATTRIBUTE_UNUSED x = &x_r; gt_ggc_m_9tree_node ((*x).name); gt_ggc_m_9tree_node ((*x).label_decl); gt_ggc_m_17named_label_entry ((*x).outer); 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_mx (struct named_label_entry *& x) { if (x) gt_ggc_mx_named_label_entry ((void *) x); } 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_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& x_r ATTRIBUTE_UNUSED) { struct incomplete_var * ATTRIBUTE_UNUSED x = &x_r; gt_ggc_m_9tree_node ((*x).decl); gt_ggc_m_9tree_node ((*x).incomplete_type); } void gt_ggc_mx_hash_table_typename_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 typename_hasher& x_r ATTRIBUTE_UNUSED) { struct typename_hasher * ATTRIBUTE_UNUSED x = &x_r; } 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).name); gt_pch_n_9tree_node ((*x).label_decl); gt_pch_n_17named_label_entry ((*x).outer); 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_nx (struct named_label_entry& x_r ATTRIBUTE_UNUSED) { struct named_label_entry * ATTRIBUTE_UNUSED x = &x_r; gt_pch_n_9tree_node ((*x).name); gt_pch_n_9tree_node ((*x).label_decl); gt_pch_n_17named_label_entry ((*x).outer); 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_nx (struct named_label_entry *& x) { if (x) gt_pch_nx_named_label_entry ((void *) x); } 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_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& x_r ATTRIBUTE_UNUSED) { struct incomplete_var * ATTRIBUTE_UNUSED x = &x_r; gt_pch_n_9tree_node ((*x).decl); gt_pch_n_9tree_node ((*x).incomplete_type); } void gt_pch_nx_hash_table_typename_hasher_ (void *x_p) { hash_table * const x = (hash_table *)x_p; if (gt_pch_note_object (x, x, gt_pch_p_27hash_table_typename_hasher_)) { gt_pch_nx (x); } } void gt_pch_nx (struct typename_hasher& x_r ATTRIBUTE_UNUSED) { struct typename_hasher * ATTRIBUTE_UNUSED x = &x_r; } 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).name), NULL, cookie); if ((void *)(x) == this_obj) op (&((*x).label_decl), NULL, cookie); if ((void *)(x) == this_obj) op (&((*x).outer), NULL, cookie); if ((void *)(x) == this_obj) op (&((*x).binding_level), NULL, cookie); if ((void *)(x) == this_obj) op (&((*x).names_in_scope), NULL, cookie); if ((void *)(x) == this_obj) op (&((*x).bad_decls), NULL, cookie); if ((void *)(x) == this_obj) op (&((*x).uses), NULL, cookie); } void gt_pch_nx (struct named_label_entry* x ATTRIBUTE_UNUSED, ATTRIBUTE_UNUSED gt_pointer_operator op, ATTRIBUTE_UNUSED void *cookie) { op (&((*x).name), NULL, cookie); op (&((*x).label_decl), NULL, cookie); op (&((*x).outer), NULL, cookie); op (&((*x).binding_level), NULL, cookie); op (&((*x).names_in_scope), NULL, cookie); op (&((*x).bad_decls), NULL, cookie); op (&((*x).uses), NULL, 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), NULL, cookie); if ((void *)(x) == this_obj) op (&((*x).binding_level), NULL, cookie); if ((void *)(x) == this_obj) op (&((*x).names_in_scope), NULL, cookie); } 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* x ATTRIBUTE_UNUSED, ATTRIBUTE_UNUSED gt_pointer_operator op, ATTRIBUTE_UNUSED void *cookie) { op (&((*x).decl), NULL, cookie); op (&((*x).incomplete_type), NULL, cookie); } void gt_pch_p_27hash_table_typename_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 typename_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_cp_decl_h[] = { { &decomp_type_table, 1, sizeof (decomp_type_table), >_ggc_mx_hash_map_tree_tree_decl_tree_cache_traits_, >_pch_nx_hash_map_tree_tree_decl_tree_cache_traits_ }, { &typename_htab, 1, sizeof (typename_htab), >_ggc_mx_hash_table_typename_hasher_, >_pch_nx_hash_table_typename_hasher_ }, { &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_ggc_rd_gt_cp_decl_h[] = { { &local_entities, 1, sizeof (local_entities), NULL, NULL }, LAST_GGC_ROOT_TAB }; void gt_clear_caches_gt_cp_decl_h () { gt_cleare_cache (decomp_type_table); } 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 };