/* Trimming an exploded graph to a subset of nodes and edges. Copyright (C) 2021-2024 Free Software Foundation, Inc. Contributed by David Malcolm . 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 . */ #ifndef GCC_ANALYZER_TRIMMED_GRAPH_H #define GCC_ANALYZER_TRIMMED_GRAPH_H namespace ana { /* Forward decls. */ class trimmed_node; class trimmed_edge; class trimmed_graph; class trimmed_cluster; /* A traits class for trimming a digraph to a subset of nodes and edges. */ struct tg_traits { typedef trimmed_node node_t; typedef trimmed_edge edge_t; typedef trimmed_graph graph_t; struct dump_args_t { typedef typename eg_traits::dump_args_t inner_args_t; dump_args_t (const inner_args_t &inner_args) : m_inner_args (inner_args) { } const inner_args_t &m_inner_args; }; typedef trimmed_cluster cluster_t; }; /* A node within the trimmed_graph, corresponding to an "inner node" within the original exploded_graph. */ class trimmed_node : public dnode { public: trimmed_node (const exploded_node *inner_node) : m_inner_node (inner_node) {} void dump_dot (graphviz_out *gv, const dump_args_t &args) const final override; private: const exploded_node *m_inner_node; }; /* An edge within the trimmed_graph, corresponding to an "inner edge" within the original exploded_graph. */ class trimmed_edge : public dedge { public: trimmed_edge (trimmed_node *src, trimmed_node *dest, const exploded_edge *inner_edge); void dump_dot (graphviz_out *gv, const dump_args_t &args) const final override; private: const exploded_edge *m_inner_edge; }; /* A digraph for trimming an exploded_graph to the subset of nodes and edges from which paths reach INNER_DST_NODE (along with a precanned way to print these in .dot form). */ class trimmed_graph : public digraph { public: trimmed_graph (const exploded_graph &inner_graph, const exploded_node *inner_dst_node); bool contains_p (const exploded_edge *eedge) const { hash_set & mut = const_cast &> (m_eedges); return mut.contains (eedge); } void log_stats (logger *logger) const; private: /* The subset of nodes in the inner graph that are in the trimmed graph. */ hash_set m_enodes; /* Likewise for edges. */ hash_set m_eedges; typedef hash_map map_t; map_t m_map_from_enode_to_tnode; }; class trimmed_cluster : public cluster { }; } // namespace ana #endif /* GCC_ANALYZER_TRIMMED_GRAPH_H */