File: asis_ul-global_state-cg-conditions.ads

package info (click to toggle)
asis 2019-5
  • links: PTS, VCS
  • area: main
  • in suites: bullseye
  • size: 13,848 kB
  • sloc: ada: 156,772; makefile: 296; sh: 81; xml: 48; csh: 10
file content (77 lines) | stat: -rw-r--r-- 4,129 bytes parent folder | download | duplicates (5)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
------------------------------------------------------------------------------
--                                                                          --
--                          GNATCHECK COMPONENTS                            --
--                                                                          --
--   A S I S _ U L . G L O B A L _ S T A T E . C G. C O N D I T I O N S     --
--                                                                          --
--                                 S p e c                                  --
--                                                                          --
--                       Copyright (C) 2009, AdaCore                        --
--                                                                          --
-- Asis Utility Library (ASIS UL) is free software; you can redistribute it --
-- and/or  modify  it  under  terms  of  the  GNU General Public License as --
-- published by the Free Software Foundation; either version 2, or (at your --
-- option)  any later version.  ASIS UL  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  distributed with GNAT; see file --
-- COPYING. If not,  write  to the  Free Software Foundation,  51 Franklin  --
-- Street, Fifth Floor, Boston, MA 02110-1301, USA.                         --
--                                                                          --
-- ASIS UL is maintained by AdaCore (http://www.adacore.com).               --
--                                                                          --
------------------------------------------------------------------------------

--  This package defines the condions that allows to build some specific
--  versions of call graph. For example, the call graph that contains only
--  inlined subpograms. Or a call graph that contains only dispatching
--  operations

package ASIS_UL.Global_State.CG.Conditions is

   --  When creating the call graph, we may either represent in this graph all
   --  possible calling nodes (unconditional mode), or we can represent only
   --  nodes (and links?) with specific properties. By defaul unconditional
   --  mode is ON.
   --
   --  Artificial type initialization procedures and type discriminant
   --  initialization procedures are included in the call graph
   --  inconditionally.

   function Unconditional_Call_Graph return Boolean;
   --  Checks if all possible nodes and calls should be included in the call
   --  graph.

   procedure Set_Unconditional_Call_Graph (On : Boolean);
   --  If the parameter is True, sets the unconditional call graph mode ON,
   --  otherwise set it OFF.

   ---------------------------
   -- Specifying conditions --
   ---------------------------

   --  For now, we use a rather simple-minded approach to specifying the
   --  conditions: all possible conditions are enumerated, and if a new
   --  condition is needed, the corresponding value should be added to the
   --  enumeration type below, the corresponding test function should be
   --  provided, and the corresponding item should be added to the check
   --  look-up table (see the body for full details).

   type Check_Kinds is
     (Inlined_Subprograms  --  If a node represents an inlined subprogram,
                           --  it should be represented in the call graph
     );

   procedure Set_Condition (Cond : Check_Kinds);
   --  Activate the specified condition.

   function Should_Be_In_CG (E : Asis.Element) return Boolean;
   --  Checks if the node corresponding to E should be represented in the call
   --  graph. If the call link points to tne node that corresponds to the
   --  Element for that this function returns False, this link is not included
   --  in the call graph.
   --
   --  Always returns True if Unconditional_Call_Graph returns True.

end ASIS_UL.Global_State.CG.Conditions;