annotate gcc/diagnostic-path.h @ 158:494b0b89df80 default tip

...
author Shinji KONO <kono@ie.u-ryukyu.ac.jp>
date Mon, 25 May 2020 18:13:55 +0900
parents 1830386684a0
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
145
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
1 /* Paths through the code associated with a diagnostic.
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
2 Copyright (C) 2019-2020 Free Software Foundation, Inc.
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
3 Contributed by David Malcolm <dmalcolm@redhat.com>
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
4
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
5 This file is part of GCC.
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
6
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
7 GCC is free software; you can redistribute it and/or modify it under
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
8 the terms of the GNU General Public License as published by the Free
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
9 Software Foundation; either version 3, or (at your option) any later
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
10 version.
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
11
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
12 GCC is distributed in the hope that it will be useful, but WITHOUT ANY
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
13 WARRANTY; without even the implied warranty of MERCHANTABILITY or
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
14 FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
15 for more details.
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
16
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
17 You should have received a copy of the GNU General Public License
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
18 along with GCC; see the file COPYING3. If not see
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
19 <http://www.gnu.org/licenses/>. */
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
20
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
21 #ifndef GCC_DIAGNOSTIC_PATH_H
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
22 #define GCC_DIAGNOSTIC_PATH_H
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
23
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
24 #include "diagnostic.h" /* for ATTRIBUTE_GCC_DIAG. */
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
25 #include "diagnostic-event-id.h"
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
26
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
27 /* A diagnostic_path is an optional additional piece of metadata associated
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
28 with a diagnostic (via its rich_location).
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
29
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
30 It describes a sequence of events predicted by the compiler that
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
31 lead to the problem occurring, with their locations in the user's source,
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
32 and text descriptions.
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
33
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
34 For example, the following error has a 3-event path:
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
35
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
36 test.c: In function 'demo':
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
37 test.c:29:5: error: passing NULL as argument 1 to 'PyList_Append' which
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
38 requires a non-NULL parameter
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
39 29 | PyList_Append(list, item);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
40 | ^~~~~~~~~~~~~~~~~~~~~~~~~
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
41 'demo': events 1-3
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
42 |
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
43 | 25 | list = PyList_New(0);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
44 | | ^~~~~~~~~~~~~
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
45 | | |
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
46 | | (1) when 'PyList_New' fails, returning NULL
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
47 | 26 |
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
48 | 27 | for (i = 0; i < count; i++) {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
49 | | ~~~
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
50 | | |
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
51 | | (2) when 'i < count'
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
52 | 28 | item = PyLong_FromLong(random());
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
53 | 29 | PyList_Append(list, item);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
54 | | ~~~~~~~~~~~~~~~~~~~~~~~~~
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
55 | | |
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
56 | | (3) when calling 'PyList_Append', passing NULL from (1) as argument 1
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
57 |
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
58
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
59 The diagnostic-printing code has consolidated the path into a single
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
60 run of events, since all the events are near each other and within the same
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
61 function; more complicated examples (such as interprocedural paths)
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
62 might be printed as multiple runs of events. */
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
63
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
64 /* Abstract base classes, describing events within a path, and the paths
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
65 themselves. */
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
66
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
67 /* One event within a diagnostic_path. */
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
68
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
69 class diagnostic_event
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
70 {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
71 public:
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
72 virtual ~diagnostic_event () {}
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
73
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
74 virtual location_t get_location () const = 0;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
75
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
76 virtual tree get_fndecl () const = 0;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
77
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
78 /* Stack depth, so that consumers can visualizes the interprocedural
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
79 calls, returns, and frame nesting. */
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
80 virtual int get_stack_depth () const = 0;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
81
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
82 /* Get a localized (and possibly colorized) description of this event. */
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
83 virtual label_text get_desc (bool can_colorize) const = 0;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
84 };
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
85
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
86 /* Abstract base class for getting at a sequence of events. */
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
87
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
88 class diagnostic_path
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
89 {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
90 public:
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
91 virtual ~diagnostic_path () {}
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
92 virtual unsigned num_events () const = 0;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
93 virtual const diagnostic_event & get_event (int idx) const = 0;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
94
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
95 bool interprocedural_p () const;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
96 };
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
97
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
98 /* Concrete subclasses. */
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
99
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
100 /* A simple implementation of diagnostic_event. */
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
101
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
102 class simple_diagnostic_event : public diagnostic_event
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
103 {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
104 public:
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
105 simple_diagnostic_event (location_t loc, tree fndecl, int depth,
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
106 const char *desc);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
107 ~simple_diagnostic_event ();
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
108
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
109 location_t get_location () const FINAL OVERRIDE { return m_loc; }
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
110 tree get_fndecl () const FINAL OVERRIDE { return m_fndecl; }
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
111 int get_stack_depth () const FINAL OVERRIDE { return m_depth; }
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
112 label_text get_desc (bool) const FINAL OVERRIDE
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
113 {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
114 return label_text::borrow (m_desc);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
115 }
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
116
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
117 private:
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
118 location_t m_loc;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
119 tree m_fndecl;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
120 int m_depth;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
121 char *m_desc; // has been i18n-ed and formatted
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
122 };
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
123
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
124 /* A simple implementation of diagnostic_path, as a vector of
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
125 simple_diagnostic_event instances. */
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
126
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
127 class simple_diagnostic_path : public diagnostic_path
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
128 {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
129 public:
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
130 simple_diagnostic_path (pretty_printer *event_pp)
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
131 : m_event_pp (event_pp) {}
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
132
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
133 unsigned num_events () const FINAL OVERRIDE;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
134 const diagnostic_event & get_event (int idx) const FINAL OVERRIDE;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
135
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
136 diagnostic_event_id_t add_event (location_t loc, tree fndecl, int depth,
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
137 const char *fmt, ...)
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
138 ATTRIBUTE_GCC_DIAG(5,6);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
139
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
140 private:
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
141 auto_delete_vec<simple_diagnostic_event> m_events;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
142
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
143 /* (for use by add_event). */
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
144 pretty_printer *m_event_pp;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
145 };
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
146
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
147 extern void debug (diagnostic_path *path);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
148
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
149 #endif /* ! GCC_DIAGNOSTIC_PATH_H */