libabigail
abg-corpus.h
Go to the documentation of this file.
1 // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
2 // -*- mode: C++ -*-
3 //
4 // Copyright (C) 2013-2023 Red Hat, Inc.
5 
6 /// @file
7 
8 #ifndef __ABG_CORPUS_H__
9 #define __ABG_CORPUS_H__
10 
11 #include <abg-ir.h>
12 
13 namespace abigail
14 {
15 
16 namespace ir
17 {
18 
19 /// This is the abstraction of a set of translation units (themselves
20 /// seen as bundles of unitary abi artefacts like types and decls)
21 /// bundled together as a corpus. A corpus is thus the Application
22 /// binary interface of a program, a library or just a set of modules
23 /// put together.
24 class corpus
25 {
26 public:
27  /// A convenience typedef for std::vector<string>.
28  typedef vector<string> strings_type;
29 
30  /// Convenience typedef for std::vector<abigail::ir::function_decl*>
31  typedef vector<const function_decl*> functions;
32 
33  /// Convenience typedef for std::unordered_set<const function_decl*>
34  typedef std::unordered_set<const function_decl*> functions_set;
35 
36  ///Convenience typedef for std::vector<abigail::ir::var_decl*>
37  typedef vector<const var_decl*> variables;
38 
39  /// Convenience typedef for std::unordered_set<const var_decl*>.
40  typedef std::unordered_set<const var_decl*> variables_set;
41 
43 
44  /// Convenience typedef for shared_ptr<exported_decls_builder>.
45  typedef shared_ptr<exported_decls_builder> exported_decls_builder_sptr;
46 
47  /// This abstracts where the corpus comes from. That is, either it
48  /// has been read from the native xml format, from DWARF or built
49  /// artificially using the library's API.
50  enum origin
51  {
52  ARTIFICIAL_ORIGIN = 0,
53  NATIVE_XML_ORIGIN = 1,
54  ELF_ORIGIN = 1 << 1,
55  DWARF_ORIGIN = 1 << 2,
56  CTF_ORIGIN = 1 << 3,
57  BTF_ORIGIN = 1 << 4,
58  LINUX_KERNEL_BINARY_ORIGIN = 1 << 5
59  };
60 
61 private:
62  corpus();
63 
64  void set_group(corpus_group*);
65  void init_format_version();
66 
67 public:
68  struct priv;
69  std::unique_ptr<priv> priv_;
70 
71  corpus(const ir::environment&, const string& path= "");
72 
73  virtual ~corpus();
74 
75  const environment&
76  get_environment() const;
77 
78  bool
79  do_log() const;
80 
81  void
82  do_log(bool);
83 
84  void
85  add(const translation_unit_sptr&);
86 
87  const translation_units&
88  get_translation_units() const;
89 
91  find_translation_unit(const string &path) const;
92 
93  void
95 
96  type_maps&
97  get_types();
98 
99  const type_maps&
100  get_types() const;
101 
102  type_maps&
104 
105  const type_maps&
106  get_type_per_loc_map() const;
107 
108  virtual bool
110 
111  void
113 
114  bool
116 
117  const vector<type_base_wptr>&
119 
120  const corpus_group*
121  get_group() const;
122 
123  corpus_group*
124  get_group();
125 
126  origin
127  get_origin() const;
128 
129  void
131 
132  string&
134 
135  void
136  set_format_major_version_number(const string&);
137 
138  string&
140 
141  void
142  set_format_minor_version_number(const string&);
143 
144  string&
145  get_path() const;
146 
147  void
148  set_path(const string&);
149 
150  const vector<string>&
151  get_needed() const;
152 
153  void
154  set_needed(const vector<string>&);
155 
156  const string&
157  get_soname();
158 
159  void
160  set_soname(const string&);
161 
162  const string&
163  get_architecture_name() const;
164 
165  void
166  set_architecture_name(const string&);
167 
168  virtual bool
169  is_empty() const;
170 
171  bool
172  operator==(const corpus&) const;
173 
174  void
176 
178  get_symtab() const;
179 
180  virtual const string_elf_symbols_map_type&
181  get_fun_symbol_map() const;
182 
185 
186  virtual const elf_symbols&
187  get_sorted_fun_symbols() const;
188 
189  const elf_symbols&
191 
192  virtual const string_elf_symbols_map_type&
193  get_var_symbol_map() const;
194 
197 
198  virtual const elf_symbols&
199  get_sorted_var_symbols() const;
200 
201  const elf_symbols&
203 
204  const elf_symbol_sptr
205  lookup_function_symbol(const string& n) const;
206 
207  const elf_symbol_sptr
208  lookup_function_symbol(const string& symbol_name,
209  const elf_symbol::version& version) const;
210 
211  const elf_symbol_sptr
212  lookup_function_symbol(const elf_symbol& symbol) const;
213 
214  const elf_symbol_sptr
215  lookup_variable_symbol(const string& n) const;
216 
217  const elf_symbol_sptr
218  lookup_variable_symbol(const string& symbol_name,
219  const elf_symbol::version& version) const;
220 
221  const elf_symbol_sptr
222  lookup_variable_symbol(const elf_symbol& symbol) const;
223 
224  virtual const functions&
225  get_functions() const;
226 
227  const std::unordered_set<function_decl*>*
228  lookup_functions(const interned_string& id) const;
229 
230  const std::unordered_set<function_decl*>*
231  lookup_functions(const char* id) const;
232 
233  const var_decl*
234  lookup_variable(const interned_string& id) const;
235 
236  void
237  sort_functions();
238 
239  virtual const variables&
240  get_variables() const;
241 
242  const functions_set&
243  get_undefined_functions() const;
244 
247 
248  const functions&
250 
251  const variables_set&
252  get_undefined_variables() const;
253 
256 
257  const variables&
259 
260  void
261  sort_variables();
262 
263  virtual const elf_symbols&
265 
266  virtual const elf_symbols&
268 
269  vector<string>&
271 
272  const vector<string>&
274 
275  vector<string>&
277 
278  const vector<string>&
280 
281  vector<string>&
283 
284  const vector<string>&
286 
287  vector<string>&
289 
290  const vector<string>&
292 
293  vector<string>&
295 
296  const vector<string>&
298 
299  vector<string>&
301 
302  const vector<string>&
304 
305  void
307 
310 
311  friend class type_base;
312  friend class corpus_group;
313 };// end class corpus.
314 
317 
320 
323 
326 
327 /// Abstracts the building of the set of exported variables and
328 /// functions.
329 ///
330 /// Given a function or variable, this type can decide if it belongs
331 /// to the list of exported functions and variables based on all the
332 /// parameters needed.
334 {
335  // Forbid default construction.
337 
338 public:
339  class priv;
340  std::unique_ptr<priv> priv_;
341 
342  friend class corpus;
343 
345  variables& vars,
346  strings_type& fns_suppress_regexps,
347  strings_type& vars_suppress_regexps,
348  strings_type& fns_keep_regexps,
349  strings_type& vars_keep_regexps,
350  strings_type& sym_id_of_fns_to_keep,
351  strings_type& sym_id_of_vars_to_keep);
352 
353 
354  const functions&
355  exported_functions() const;
356 
357  functions&
359 
360  std::unordered_set<function_decl*>*
362 
363  const variables&
364  exported_variables() const;
365 
366  variables&
368 
369  bool
371 
372  bool
374 }; //corpus::exported_decls_builder
375 
376 /// Abstraction of a group of corpora.
377 ///
378 /// A corpus group is a union of corpora. It provides a unified view
379 /// of a set of corpora. It lets you get the set of functions,
380 /// variables and symbols that are defined and exported by a set of
381 /// corpora.
382 class corpus_group : public corpus
383 {
384  struct priv;
385  std::unique_ptr<priv> priv_;
386 
387  // Forbid copy
388  corpus_group(const corpus_group&);
389 
390 public:
391  typedef vector<corpus_sptr> corpora_type;
392 
393  corpus_group(const ir::environment&, const string&);
394 
395  virtual ~corpus_group();
396 
397  void add_corpus(const corpus_sptr&);
398 
399  bool has_corpus(const string&);
400 
401  const corpora_type&
402  get_corpora() const;
403 
404  const corpus_sptr
405  get_main_corpus() const;
406 
407  corpus_sptr
408  get_main_corpus();
409 
410  virtual bool
411  is_empty() const;
412 
413  virtual const corpus::functions&
414  get_functions() const;
415 
416  virtual const corpus::variables&
417  get_variables() const;
418 
419  virtual const string_elf_symbols_map_type&
420  get_var_symbol_map() const;
421 
422  virtual const string_elf_symbols_map_type&
423  get_fun_symbol_map() const;
424 
425  virtual const elf_symbols&
426  get_sorted_fun_symbols() const;
427 
428  virtual const elf_symbols&
429  get_sorted_var_symbols() const;
430 
431  virtual const elf_symbols&
433 
434  virtual const elf_symbols&
436 
437  unordered_set<interned_string, hash_interned_string>*
439 
440  virtual bool
442 
443  bool
444  operator==(const corpus_group&) const;
445 }; // end class corpus_group
446 
447 }// end namespace ir
448 }//end namespace abigail
449 #endif //__ABG_CORPUS_H__
std::shared_ptr< symtab > symtab_sptr
Convenience typedef for a shared pointer to a symtab.
Definition: abg-fwd.h:1665
Types of the main internal representation of libabigail.
The abstraction of an interned string.
The type of the private data of corpus::exported_decls_builder type.
Abstracts the building of the set of exported variables and functions.
Definition: abg-corpus.h:334
const functions & exported_functions() const
Getter for the reference to the vector of exported functions. This vector is shared with with the cor...
Definition: abg-corpus.cc:101
bool maybe_add_fn_to_exported_fns(function_decl *)
Consider at all the tunables that control wether a function should be added to the set of exported fu...
Definition: abg-corpus.cc:162
bool maybe_add_var_to_exported_vars(const var_decl *)
Consider at all the tunables that control wether a variable should be added to the set of exported va...
Definition: abg-corpus.cc:192
std::unordered_set< function_decl * > * fn_id_maps_to_several_fns(const function_decl *)
Test if a given function ID maps to several functions in the same corpus.
Definition: abg-corpus.cc:125
const variables & exported_variables() const
Getter for the reference to the vector of exported variables. This vector is shared with with the cor...
Definition: abg-corpus.cc:141
Abstraction of a group of corpora.
Definition: abg-corpus.h:383
virtual const elf_symbols & get_sorted_var_symbols() const
Get a sorted vector of the symbols of the variables exported by the corpora of the current group.
Definition: abg-corpus.cc:2123
bool has_corpus(const string &)
Test if a corpus of a given path has been added to the group.
Definition: abg-corpus.cc:1935
const corpora_type & get_corpora() const
Getter of the vector of corpora held by the current corpus_group.
Definition: abg-corpus.cc:1947
unordered_set< interned_string, hash_interned_string > * get_public_types_pretty_representations()
Getter of a pointer to the set of types reachable from public interfaces of a given corpus group.
Definition: abg-corpus.cc:2239
virtual const string_elf_symbols_map_type & get_var_symbol_map() const
Get the symbols of the global variables exported by the corpora of the current corpus_group.
Definition: abg-corpus.cc:2057
virtual const elf_symbols & get_sorted_fun_symbols() const
Get a sorted vector of the symbols of the functions exported by the corpora of the current group.
Definition: abg-corpus.cc:2091
virtual bool is_empty() const
Test if the current corpus group is empty.
Definition: abg-corpus.cc:1972
virtual const string_elf_symbols_map_type & get_fun_symbol_map() const
Get the symbols of the global functions exported by the corpora of the current corpus_group.
Definition: abg-corpus.cc:2074
const corpus_sptr get_main_corpus() const
Getter of the first corpus added to this Group.
Definition: abg-corpus.cc:1954
virtual const elf_symbols & get_unreferenced_function_symbols() const
Get the set of function symbols not referenced by any debug info, from all the corpora of the current...
Definition: abg-corpus.cc:2162
virtual const elf_symbols & get_unreferenced_variable_symbols() const
Get the set of variable symbols not referenced by any debug info, from all the corpora of the current...
Definition: abg-corpus.cc:2205
virtual bool recording_types_reachable_from_public_interface_supported()
Test if the recording of reachable types (and thus, indirectly, the recording of non-reachable types)...
Definition: abg-corpus.cc:2249
virtual const corpus::variables & get_variables() const
Get the global variables exported by the corpora of the current corpus group.
Definition: abg-corpus.cc:2023
virtual ~corpus_group()
Desctructor of the corpus_group type.
Definition: abg-corpus.cc:1889
void add_corpus(const corpus_sptr &)
Add a new corpus to the current instance of corpus_group.
Definition: abg-corpus.cc:1896
virtual const corpus::functions & get_functions() const
Get the functions exported by the corpora of the current corpus group.
Definition: abg-corpus.cc:1985
This is the abstraction of a set of translation units (themselves seen as bundles of unitary abi arte...
Definition: abg-corpus.h:25
virtual const elf_symbols & get_sorted_var_symbols() const
Getter for the sorted vector of variable symbols for this corpus.
Definition: abg-corpus.cc:1174
const elf_symbol_sptr lookup_function_symbol(const string &n) const
Look in the function symbols map for a symbol with a given name.
Definition: abg-corpus.cc:1209
origin
This abstracts where the corpus comes from. That is, either it has been read from the native xml form...
Definition: abg-corpus.h:51
void sort_functions()
Sort the set of functions exported by this corpus.
Definition: abg-corpus.cc:1431
void set_soname(const string &)
Setter for the soname property of the corpus.
Definition: abg-corpus.cc:1038
vector< const var_decl * > variables
Convenience typedef for std::vector<abigail::ir::var_decl*>
Definition: abg-corpus.h:37
const functions_set & get_undefined_functions() const
Getter of the undefined functions of the corpus.
Definition: abg-corpus.cc:1489
const vector< type_base_wptr > & get_types_not_reachable_from_public_interfaces() const
Getter of a sorted vector of the types that are *NOT* reachable from public interfaces.
Definition: abg-corpus.cc:855
void record_type_as_reachable_from_public_interfaces(const type_base &)
Record a type as being reachable from public interfaces (global functions and variables).
Definition: abg-corpus.cc:817
const vector< string > & get_needed() const
Getter of the needed property of the corpus.
Definition: abg-corpus.cc:1004
exported_decls_builder_sptr get_exported_decls_builder() const
Getter for the object that is responsible for determining what decls ought to be in the set of export...
Definition: abg-corpus.cc:1731
void maybe_drop_some_exported_decls()
After the set of exported functions and variables have been built, consider all the tunables that con...
Definition: abg-corpus.cc:1694
const string_elf_symbols_map_type & get_undefined_var_symbol_map() const
Getter for the map of variable symbols that are undefined in this corpus.
Definition: abg-corpus.cc:1200
void add(const translation_unit_sptr &)
Add a translation unit to the current ABI Corpus.
Definition: abg-corpus.cc:723
std::unordered_set< const function_decl * > functions_set
Convenience typedef for std::unordered_set<const function_decl*>
Definition: abg-corpus.h:34
virtual const string_elf_symbols_map_type & get_var_symbol_map() const
Getter for the variable symbols map.
Definition: abg-corpus.cc:1190
shared_ptr< exported_decls_builder > exported_decls_builder_sptr
Convenience typedef for shared_ptr<exported_decls_builder>.
Definition: abg-corpus.h:42
const variables & get_sorted_undefined_variables() const
Getter of the sorted vector of undefined variables of the corpus.
Definition: abg-corpus.cc:1537
const elf_symbol_sptr lookup_variable_symbol(const string &n) const
Look in the variable symbols map for a symbol with a given name.
Definition: abg-corpus.cc:1312
std::unordered_set< const var_decl * > variables_set
Convenience typedef for std::unordered_set<const var_decl*>.
Definition: abg-corpus.h:40
virtual const elf_symbols & get_sorted_fun_symbols() const
Return a sorted vector of function symbols for this corpus.
Definition: abg-corpus.cc:1154
const string & get_soname()
Getter for the soname property of the corpus.
Definition: abg-corpus.cc:1027
const translation_units & get_translation_units() const
Return the list of translation units of the current corpus.
Definition: abg-corpus.cc:743
const symtab_reader::symtab_sptr & get_symtab() const
Getter for the symtab object.
Definition: abg-corpus.cc:1126
const variables_set & get_undefined_variables() const
Getter of the undefined variables of the corpus.
Definition: abg-corpus.cc:1521
origin get_origin() const
Getter for the origin of the corpus.
Definition: abg-corpus.cc:928
const var_decl * lookup_variable(const interned_string &id) const
Lookup the exported variable which has a given variable ID.
Definition: abg-corpus.cc:1417
virtual bool is_empty() const
Tests if the corpus is empty from an ABI surface perspective. I.e. if all of these criteria are true:
Definition: abg-corpus.cc:1073
type_maps & get_types()
Get the maps that associate a name to a certain kind of type.
Definition: abg-corpus.cc:775
vector< string > & get_sym_ids_of_vars_to_keep()
Getter for the vector of variable symbol IDs to keep.
Definition: abg-corpus.cc:1677
bool do_log() const
Test if logging was requested.
Definition: abg-corpus.cc:705
const translation_unit_sptr find_translation_unit(const string &path) const
Find the translation unit that has a given path.
Definition: abg-corpus.cc:753
const elf_symbols & get_sorted_undefined_fun_symbols() const
Getter for a sorted vector of the function symbols undefined in this corpus.
Definition: abg-corpus.cc:1163
string & get_path() const
Get the file path associated to the corpus file.
Definition: abg-corpus.cc:981
const string_elf_symbols_map_type & get_undefined_fun_symbol_map() const
Getter for the map of function symbols that are undefined in this corpus.
Definition: abg-corpus.cc:1143
void set_origin(origin)
Setter for the origin of the corpus.
Definition: abg-corpus.cc:935
virtual const string_elf_symbols_map_type & get_fun_symbol_map() const
Getter for the function symbols map.
Definition: abg-corpus.cc:1133
bool operator==(const corpus &) const
Compare the current corpus against another one.
Definition: abg-corpus.cc:1100
type_maps & get_type_per_loc_map()
Get the maps that associate a location string to a certain kind of type.
Definition: abg-corpus.cc:884
void drop_translation_units()
Erase the translation units contained in this in-memory object.
Definition: abg-corpus.cc:768
void sort_variables()
Sort the set of variables exported by this corpus.
Definition: abg-corpus.cc:1469
vector< string > & get_regex_patterns_of_vars_to_keep()
Accessor for the regex patterns describing the variables to keep into the public decl table....
Definition: abg-corpus.cc:1657
vector< string > & get_regex_patterns_of_vars_to_suppress()
Accessor for the regex patterns describing the variables to drop from the public decl table.
Definition: abg-corpus.cc:1598
const corpus_group * get_group() const
Getter of the group this corpus is a member of.
Definition: abg-corpus.cc:892
vector< string > & get_regex_patterns_of_fns_to_suppress()
Accessor for the regex patterns describing the functions to drop from the public decl table.
Definition: abg-corpus.cc:1580
const functions & get_sorted_undefined_functions() const
Getter of the sorted vector of undefined functions of the corpus.
Definition: abg-corpus.cc:1505
virtual const elf_symbols & get_unreferenced_function_symbols() const
Getter of the set of function symbols that are not referenced by any function exported by the current...
Definition: abg-corpus.cc:1558
void set_path(const string &)
Set the file path associated to the corpus file.
Definition: abg-corpus.cc:993
virtual const elf_symbols & get_unreferenced_variable_symbols() const
Getter of the set of variable symbols that are not referenced by any variable exported by the current...
Definition: abg-corpus.cc:1571
bool type_is_reachable_from_public_interfaces(const type_base &) const
Test if a type is reachable from public interfaces (global functions and variables).
Definition: abg-corpus.cc:835
virtual bool recording_types_reachable_from_public_interface_supported()
Test if the recording of reachable types (and thus, indirectly, the recording of non-reachable types)...
Definition: abg-corpus.cc:806
virtual const variables & get_variables() const
Return the public decl table of the global variables of the current corpus.
Definition: abg-corpus.cc:1461
const elf_symbols & get_sorted_undefined_var_symbols() const
Getter for a sorted vector of the variable symbols undefined in this corpus.
Definition: abg-corpus.cc:1183
void set_needed(const vector< string > &)
Setter of the needed property of the corpus.
Definition: abg-corpus.cc:1016
vector< string > & get_sym_ids_of_fns_to_keep()
Getter for the vector of function symbol IDs to keep.
Definition: abg-corpus.cc:1637
vector< const function_decl * > functions
Convenience typedef for std::vector<abigail::ir::function_decl*>
Definition: abg-corpus.h:31
void set_architecture_name(const string &)
Setter for the architecture name of the corpus.
Definition: abg-corpus.cc:1060
void set_symtab(symtab_reader::symtab_sptr)
Setter for the symtab object.
Definition: abg-corpus.cc:1119
void set_format_major_version_number(const string &)
Setter of the major version number of the abixml serialization format.
Definition: abg-corpus.cc:951
const string & get_architecture_name() const
Getter for the architecture name of the corpus.
Definition: abg-corpus.cc:1049
vector< string > strings_type
A convenience typedef for std::vector<string>.
Definition: abg-corpus.h:28
const environment & get_environment() const
Getter of the enviroment of the corpus.
Definition: abg-corpus.cc:698
vector< string > & get_regex_patterns_of_fns_to_keep()
Accessor for the regex patterns describing the functions to keep into the public decl table....
Definition: abg-corpus.cc:1617
void set_format_minor_version_number(const string &)
Setter of the minor version number of the abixml serialization format.
Definition: abg-corpus.cc:969
string & get_format_minor_version_number() const
Getter of the minor version number of the abixml serialization format.
Definition: abg-corpus.cc:960
const std::unordered_set< function_decl * > * lookup_functions(const interned_string &id) const
Lookup the function which has a given function ID.
Definition: abg-corpus.cc:1397
virtual const functions & get_functions() const
Return the functions public decl table of the current corpus.
Definition: abg-corpus.cc:1379
string & get_format_major_version_number() const
Getter of the major version number of the abixml serialization format.
Definition: abg-corpus.cc:943
The abstraction of the version of an ELF symbol.
Definition: abg-ir.h:1194
Abstraction of an elf symbol.
Definition: abg-ir.h:923
This is an abstraction of the set of resources necessary to manage several aspects of the internal re...
Definition: abg-ir.h:140
Abstraction for a function declaration.
Definition: abg-ir.h:3111
An abstraction helper for type declarations.
Definition: abg-ir.h:1973
This is a type that aggregates maps of all the kinds of types that are supported by libabigail.
Definition: abg-ir.h:593
Abstracts a variable declaration.
Definition: abg-ir.h:3008
corpus::origin operator|=(corpus::origin &l, corpus::origin r)
Bitwise |= operator for the corpus::origin type.
Definition: abg-corpus.cc:1770
shared_ptr< elf_symbol > elf_symbol_sptr
A convenience typedef for a shared pointer to elf_symbol.
Definition: abg-ir.h:886
std::vector< elf_symbol_sptr > elf_symbols
Convenience typedef for a vector of elf_symbol.
Definition: abg-ir.h:904
corpus::origin operator|(corpus::origin l, corpus::origin r)
Bitwise | operator for the corpus::origin type.
Definition: abg-corpus.cc:1756
corpus::origin operator&(corpus::origin l, corpus::origin r)
Bitwise & operator for the corpus::origin type.
Definition: abg-corpus.cc:1784
shared_ptr< translation_unit > translation_unit_sptr
Convenience typedef for a shared pointer on a translation_unit type.
Definition: abg-fwd.h:134
std::set< translation_unit_sptr, shared_translation_unit_comp > translation_units
Convenience typedef for an ordered set of translation_unit_sptr.
Definition: abg-ir.h:851
corpus::origin operator&=(corpus::origin &l, corpus::origin r)
Bitwise &= operator for the corpus::origin type.
Definition: abg-corpus.cc:1798
std::unordered_map< string, elf_symbols > string_elf_symbols_map_type
Convenience typedef for a map which key is a string and which value is a vector of elf_symbol.
Definition: abg-ir.h:909
Toplevel namespace for libabigail.
bool operator==(const std::string &l, const interned_string &r)
Equality operator.
Definition: abg-ir.cc:153