20#include <unordered_map>
24#include "abg-internal.h"
26ABG_BEGIN_EXPORT_DECLARATIONS
33ABG_END_EXPORT_DECLARATIONS
68using std::unordered_map;
69using std::dynamic_pointer_cast;
70using std::static_pointer_cast;
77struct interned_string_pool::priv
97{
return priv_->map.find(s) != priv_->map.end();}
108 unordered_map<string, string*>::const_iterator i =
110 if (i == priv_->map.end())
113 return i->second->c_str();
125 string*& result = priv_->map[str_value];
126 if (!result && !str_value.empty())
127 result =
new string(str_value);
134 for (pool_map_type::iterator i = priv_->map.begin();
135 i != priv_->map.end();
152{
return r.operator==(l);}
155operator!=(
const std::string& l,
const interned_string& r)
170 o << static_cast<std::string>(s);
186{
return static_cast<std::string
>(s1) + s2;}
200{
return s1 +
static_cast<std::string
>(s2);}
206hash_as_canonical_type_or_constant(
const type_base *t);
209has_generic_anonymous_internal_type_name(
const decl_base *d);
211static interned_string
212get_generic_anonymous_internal_type_name(
const decl_base *d);
215get_internal_real_type_name(
const type_base*);
218update_qualified_name(decl_base * d);
221update_qualified_name(decl_base_sptr d);
223static interned_string
224pointer_declaration_name(
const type_base* ptr,
225 const string& variable_name,
226 bool qualified,
bool internal);
228static interned_string
229pointer_declaration_name(
const type_base_sptr& ptr,
230 const string& variable_name,
231 bool qualified,
bool internal);
233static interned_string
234ptr_to_mbr_declaration_name(
const ptr_to_mbr_type* ptr,
235 const string& variable_name,
236 bool qualified,
bool internal);
238static interned_string
240 const string& variable_name,
241 bool qualified,
bool internal);
243static interned_string
244array_declaration_name(
const array_type_def* array,
245 const string& variable_name,
246 bool qualified,
bool internal);
248static interned_string
250 const string& variable_name,
251 bool qualified,
bool internal);
254stream_pretty_representation_of_fn_parms(
const function_type& fn_type,
255 ostream& o,
bool qualified,
258add_outer_pointer_to_fn_type_expr(
const type_base* pointer_to_fn,
259 const string& input,
bool qualified,
263add_outer_pointer_to_fn_type_expr(
const type_base_sptr& pointer_to_fn,
264 const string& input,
bool qualified,
268add_outer_pointer_to_array_type_expr(
const type_base* pointer_to_ar,
269 const string& input,
bool qualified,
273add_outer_pointer_to_array_type_expr(
const type_base_sptr& pointer_to_ar,
274 const string& input,
bool qualified,
278add_outer_ptr_to_mbr_type_expr(
const ptr_to_mbr_type* p,
279 const string& input,
bool qualified,
284 const string& input,
bool qualified,
288add_outer_pointer_to_ptr_to_mbr_type_expr(
const type_base* p,
290 bool qualified,
bool internal);
294 const type_base& right);
298 const type_base& right);
315 env.priv_->push_composite_type_comparison_operands(&left, &right);
336 env.priv_->pop_composite_type_comparison_operands(&left, &right);
346{
return t.priv_->canonical_type_index;}
381 if (c && t->get_corpus())
386 if (t->get_corpus()->get_group() == g.get())
391 if (t->get_corpus() == c.get())
400class expanded_location
412 expanded_location(
const string& path,
unsigned line,
unsigned column)
413 : path_(path), line_(line), column_(column)
417 operator==(
const expanded_location& l)
const
419 return (path_ == l.path_
421 && column_ && l.column_);
425 operator<(
const expanded_location& l)
const
429 else if (path_ > l.path_)
434 else if (line_ > l.line_)
437 return column_ < l.column_;
454 if (!get_location_manager())
475 unsigned line = 0, column = 0;
476 expand(path, line, column);
478 std::ostringstream o;
479 o << path <<
":" << line <<
":" << column;
483struct location_manager::priv
489 std::vector<expanded_location> locs;
492location_manager::location_manager()
496location_manager::~location_manager() =
default;
511 expanded_location l(file_path, line, col);
515 priv_->locs.push_back(l);
516 return location(priv_->locs.size(),
this);
533 unsigned& column)
const
537 expanded_location &l = priv_->locs[
location.value_ - 1];
550struct type_maps::priv
564 mutable vector<type_base_wptr> sorted_types_;
567type_maps::type_maps()
571type_maps::~type_maps() =
default;
596{
return priv_->basic_types_;}
603{
return priv_->basic_types_;}
610{
return priv_->class_types_;}
617{
return priv_->class_types_;}
624{
return priv_->union_types_;}
631{
return priv_->union_types_;}
638{
return priv_->enum_types_;}
645{
return priv_->enum_types_;}
652{
return priv_->typedef_types_;}
659{
return priv_->typedef_types_;}
665{
return priv_->qualified_types_;}
671{
return priv_->qualified_types_;}
678{
return priv_->pointer_types_;}
685{
return priv_->ptr_to_mbr_types_;}
692{
return priv_->ptr_to_mbr_types_;}
699{
return priv_->pointer_types_;}
706{
return priv_->reference_types_;}
713{
return priv_->reference_types_;}
720{
return priv_->array_types_;}
727{
return priv_->array_types_;}
734{
return priv_->subrange_types_;}
741{
return priv_->subrange_types_;}
748{
return priv_->function_types_;}
755{
return priv_->function_types_;}
774 if (l == 0 && r == 0)
779 return l_repr < r_repr;
793 operator()(
const type_base_sptr &l,
const type_base_sptr &r)
const
794 {
return operator()(l.get(), r.get());}
808 {
return operator()(type_base_sptr(l), type_base_sptr(r));}
811#ifdef WITH_DEBUG_SELF_COMPARISON
827notify_equality_failed(
const type_or_decl_base &l __attribute__((unused)),
828 const type_or_decl_base &r __attribute__((unused)))
845notify_equality_failed(
const type_or_decl_base *l __attribute__((unused)),
846 const type_or_decl_base *r __attribute__((unused)))
849#define ABG_RETURN_EQUAL(l, r) \
853 notify_equality_failed(l, r); \
859#define ABG_RETURN_FALSE \
862 notify_equality_failed(l, r); \
866#define ABG_RETURN(value) \
869 if (value == false) \
870 notify_equality_failed(l, r); \
876#define ABG_RETURN_FALSE return false
877#define ABG_RETURN(value) return (value)
878#define ABG_RETURN_EQUAL(l, r) return ((l) == (r));
899 return dynamic_cast<T*
>(type);
916#if WITH_DEBUG_TYPE_CANONICALIZATION
936 if (env.priv_->use_canonical_type_comparison_)
940 ABG_RETURN_EQUAL(lc, rc);
949 if (l_hash != r_hash)
960 ABG_RETURN_EQUAL(lc, rc);
968 if (l_hash != r_hash)
991 bool result = l.priv_->comparison_started(l, r);
1031#define RETURN_TRUE_IF_COMPARISON_CYCLE_DETECTED(l, r) \
1034 if (is_comparison_cycle_detected(l, r)) \
1052 l.priv_->mark_as_being_compared(l, r);
1087 l.priv_->unmark_as_being_compared(l, r);
1133#define CACHE_AND_RETURN_COMPARISON_RESULT(value) \
1136 bool res = return_comparison_result(l, r, value); \
1137 l.get_environment().priv_->cache_type_comparison_result(l, r, res); \
1145#define CACHE_COMPARISON_RESULT_AND_RETURN(value) \
1148 l.get_environment().priv_->cache_type_comparison_result(l, r, value); \
1156const vector<type_base_wptr>&
1159 if (priv_->sorted_types_.empty())
1161 istring_type_base_wptrs_map_type::const_iterator i;
1162 vector<type_base_wptr>::const_iterator j;
1165 for (j = i->second.begin(); j != i->second.end(); ++j)
1166 priv_->sorted_types_.push_back(*j);
1169 for (j = i->second.begin(); j != i->second.end(); ++j)
1170 priv_->sorted_types_.push_back(*j);
1173 for (j = i->second.begin(); j != i->second.end(); ++j)
1174 priv_->sorted_types_.push_back(*j);
1177 for (j = i->second.begin(); j != i->second.end(); ++j)
1178 priv_->sorted_types_.push_back(*j);
1181 for (j = i->second.begin(); j != i->second.end(); ++j)
1182 priv_->sorted_types_.push_back(*j);
1184 type_name_comp comp;
1185 sort(priv_->sorted_types_.begin(), priv_->sorted_types_.end(), comp);
1188 return priv_->sorted_types_;
1207 const std::string& path,
1209 : priv_(new
priv(env))
1211 priv_->path_ = path;
1212 priv_->address_size_ = address_size;
1234 if (!priv_->global_scope_)
1236 priv_->global_scope_.reset
1238 priv_->global_scope_->set_translation_unit
1241 return priv_->global_scope_;
1249{
return priv_->types_;}
1256{
return priv_->types_;}
1263const vector<function_type_sptr>&
1265{
return priv_->live_fn_types_;}
1272{
return priv_->env_;}
1279{
return priv_->language_;}
1286{priv_->language_ = l;}
1299{
return priv_->path_;}
1310{priv_->path_ = a_path;}
1323{
return priv_->comp_dir_path_;}
1334{priv_->comp_dir_path_ = d;}
1343 if (priv_->abs_path_.empty())
1346 if (!priv_->path_.empty())
1348 if (!priv_->comp_dir_path_.empty())
1350 path = priv_->comp_dir_path_;
1353 path += priv_->path_;
1355 priv_->abs_path_ = path;
1358 return priv_->abs_path_;
1377{
return priv_->corp;}
1393{
return priv_->loc_mgr_;}
1401{
return priv_->loc_mgr_;}
1410 if (!priv_->global_scope_)
1420{
return priv_->address_size_;}
1427{priv_->address_size_= a;}
1443{
return priv_->is_constructed_;}
1459{priv_->is_constructed_ = f;}
1498 const_cast<translation_unit*
>(
this)->priv_->live_fn_types_.push_back(ftype);
1531translation_unit::~translation_unit()
1544 case translation_unit::LANG_UNKNOWN:
1545 return "LANG_UNKNOWN";
1546 case translation_unit::LANG_Cobol74:
1547 return "LANG_Cobol74";
1548 case translation_unit::LANG_Cobol85:
1549 return "LANG_Cobol85";
1550 case translation_unit::LANG_C89:
1552 case translation_unit::LANG_C99:
1554 case translation_unit::LANG_C11:
1556 case translation_unit::LANG_C17:
1558 case translation_unit::LANG_C23:
1560 case translation_unit::LANG_C:
1562 case translation_unit::LANG_C_plus_plus_03:
1563 return "LANG_C_plus_plus_03";
1564 case translation_unit::LANG_C_plus_plus_11:
1565 return "LANG_C_plus_plus_11";
1566 case translation_unit::LANG_C_plus_plus_14:
1567 return "LANG_C_plus_plus_14";
1568 case translation_unit::LANG_C_plus_plus_17:
1569 return "LANG_C_plus_plus_17";
1570 case translation_unit::LANG_C_plus_plus_20:
1571 return "LANG_C_plus_plus_20";
1572 case translation_unit::LANG_C_plus_plus_23:
1573 return "LANG_C_plus_plus_23";
1574 case translation_unit::LANG_C_plus_plus:
1575 return "LANG_C_plus_plus";
1576 case translation_unit::LANG_OCaml:
1577 return "LANG_OCaml";
1578 case translation_unit::LANG_Zig:
1580 case translation_unit::LANG_ObjC:
1582 case translation_unit::LANG_ObjC_plus_plus:
1583 return "LANG_ObjC_plus_plus";
1584 case translation_unit::LANG_D:
1586 case translation_unit::LANG_Go:
1588 case translation_unit::LANG_Rust:
1590 case translation_unit::LANG_Fortran77:
1591 return "LANG_Fortran77";
1592 case translation_unit::LANG_Fortran90:
1593 return "LANG_Fortran90";
1594 case translation_unit::LANG_Fortran95:
1595 return "LANG_Fortran95";
1596 case translation_unit::LANG_Fortran18:
1597 return "LANG_Fortran18";
1598 case translation_unit::LANG_Fortran23:
1599 return "LANG_Fortran23";
1600 case translation_unit::LANG_Ada83:
1601 return "LANG_Ada83";
1602 case translation_unit::LANG_Ada95:
1603 return "LANG_Ada95";
1604 case translation_unit::LANG_Ada2005:
1605 return "LANG_Ada2005";
1606 case translation_unit::LANG_Ada2012:
1607 return "LANG_Ada2012";
1608 case translation_unit::LANG_Pascal83:
1609 return "LANG_Pascal83";
1610 case translation_unit::LANG_Modula2:
1611 return "LANG_Modula2";
1612 case translation_unit::LANG_Java:
1614 case translation_unit::LANG_Kotlin:
1615 return "LANG_Kotlin";
1616 case translation_unit::LANG_C_sharp:
1617 return "LANG_C_sharp";
1618 case translation_unit::LANG_Python:
1619 return "LANG_Python";
1620 case translation_unit::LANG_Ruby:
1622 case translation_unit::LANG_PLI:
1624 case translation_unit::LANG_UPC:
1626 case translation_unit::LANG_Mips_Assembler:
1627 return "LANG_Mips_Assembler";
1628 case translation_unit::LANG_Assembly:
1629 return "LANG_Assembly";
1630 case translation_unit::LANG_Crystal:
1631 return "LANG_Crystal";
1632 case translation_unit::LANG_HIP:
1634 case translation_unit::LANG_Mojo:
1636 case translation_unit::LANG_GLSL:
1638 case translation_unit::LANG_GLSL_ES:
1639 return "LANG_GLSL_ES";
1640 case translation_unit::LANG_HLSL:
1642 case translation_unit::LANG_OpenCL_CPP:
1643 return "LANG_OpenCL_CPP";
1644 case translation_unit::LANG_CPP_for_OpenCL:
1645 return "LANG_CPP_for_OpenCL";
1646 case translation_unit::LANG_SYCL:
1648 case translation_unit::LANG_Odin:
1650 case translation_unit::LANG_P4:
1652 case translation_unit::LANG_Metal:
1653 return "LANG_Metal";
1654 case translation_unit::LANG_Move:
1656 case translation_unit::LANG_Hylo:
1660 return "LANG_UNKNOWN";
1672 if (l ==
"LANG_Cobol74")
1673 return translation_unit::LANG_Cobol74;
1674 else if (l ==
"LANG_Cobol85")
1675 return translation_unit::LANG_Cobol85;
1676 else if (l ==
"LANG_C89")
1677 return translation_unit::LANG_C89;
1678 else if (l ==
"LANG_C99")
1679 return translation_unit::LANG_C99;
1680 else if (l ==
"LANG_C11")
1681 return translation_unit::LANG_C11;
1682 else if (l ==
"LANG_C17")
1683 return translation_unit::LANG_C17;
1684 else if (l ==
"LANG_C23")
1685 return translation_unit::LANG_C23;
1686 else if (l ==
"LANG_C")
1687 return translation_unit::LANG_C;
1688 else if (l ==
"LANG_C_plus_plus_03")
1689 return translation_unit::LANG_C_plus_plus_03;
1690 else if (l ==
"LANG_C_plus_plus_11")
1691 return translation_unit::LANG_C_plus_plus_11;
1692 else if (l ==
"LANG_C_plus_plus_14")
1693 return translation_unit::LANG_C_plus_plus_14;
1694 else if (l ==
"LANG_C_plus_plus_17")
1695 return translation_unit::LANG_C_plus_plus_17;
1696 else if (l ==
"LANG_C_plus_plus_20")
1697 return translation_unit::LANG_C_plus_plus_20;
1698 else if (l ==
"LANG_C_plus_plus_23")
1699 return translation_unit::LANG_C_plus_plus_23;
1700 else if (l ==
"LANG_C_plus_plus")
1701 return translation_unit::LANG_C_plus_plus;
1702 else if (l ==
"LANG_OCaml")
1703 return translation_unit::LANG_OCaml;
1704 else if (l ==
"LANG_ObjC")
1705 return translation_unit::LANG_ObjC;
1706 else if (l ==
"LANG_ObjC_plus_plus")
1707 return translation_unit::LANG_ObjC_plus_plus;
1708 else if (l ==
"LANG_Zig")
1709 return translation_unit::LANG_Zig;
1710 else if (l ==
"LANG_Metal")
1711 return translation_unit::LANG_Metal;
1712 else if (l ==
"LANG_Fortran77")
1713 return translation_unit::LANG_Fortran77;
1714 else if (l ==
"LANG_Fortran90")
1715 return translation_unit::LANG_Fortran90;
1716 else if (l ==
"LANG_Fortran95")
1717 return translation_unit::LANG_Fortran95;
1718 else if (l ==
"LANG_Fortran18")
1719 return translation_unit::LANG_Fortran23;
1720 else if (l ==
"LANG_Ada83")
1721 return translation_unit::LANG_Ada83;
1722 else if (l ==
"LANG_Ada95")
1723 return translation_unit::LANG_Ada95;
1724 else if (l ==
"LANG_Ada2005")
1725 return translation_unit::LANG_Ada2005;
1726 else if (l ==
"LANG_Ada2012")
1727 return translation_unit::LANG_Ada2012;
1728 else if (l ==
"LANG_Pascal83")
1729 return translation_unit::LANG_Pascal83;
1730 else if (l ==
"LANG_Modula2")
1731 return translation_unit::LANG_Modula2;
1732 else if (l ==
"LANG_Java")
1733 return translation_unit::LANG_Java;
1734 else if (l ==
"LANG_Kotlin")
1735 return translation_unit::LANG_Kotlin;
1736 else if (l ==
"LANG_PLI")
1737 return translation_unit::LANG_PLI;
1738 else if (l ==
"LANG_UPC")
1739 return translation_unit::LANG_UPC;
1740 else if (l ==
"LANG_D")
1741 return translation_unit::LANG_D;
1742 else if (l ==
"LANG_Go")
1743 return translation_unit::LANG_Go;
1744 else if (l ==
"LANG_Rust")
1745 return translation_unit::LANG_Rust;
1746 else if (l ==
"LANG_Python")
1747 return translation_unit::LANG_Python;
1748 else if (l ==
"LANG_Ruby")
1749 return translation_unit::LANG_Ruby;
1750 else if (l ==
"LANG_Mips_Assembler")
1751 return translation_unit::LANG_Mips_Assembler;
1752 else if (l ==
"LANG_Assembly")
1753 return translation_unit::LANG_Assembly;
1754 else if (l ==
"LANG_Crystal")
1755 return translation_unit::LANG_Crystal;
1756 else if (l ==
"LANG_HIP")
1757 return translation_unit::LANG_HIP;
1758 else if (l ==
"LANG_C_sharp")
1759 return translation_unit::LANG_C_sharp;
1760 else if (l ==
"LANG_Mojo")
1761 return translation_unit::LANG_Mojo;
1762 else if (l ==
"LANG_GLSL")
1763 return translation_unit::LANG_GLSL;
1764 else if (l ==
"LANG_GLSL_ES")
1765 return translation_unit::LANG_GLSL_ES;
1766 else if (l ==
"LANG_HLSL")
1767 return translation_unit::LANG_HLSL;
1768 else if (l ==
"LANG_OpenCL_CPP")
1769 return translation_unit::LANG_OpenCL_CPP;
1770 else if (l ==
"LANG_CPP_for_OpenCL")
1771 return translation_unit::LANG_CPP_for_OpenCL;
1772 else if (l ==
"LANG_SYCL")
1773 return translation_unit::LANG_SYCL;
1774 else if (l ==
"LANG_Odin")
1775 return translation_unit::LANG_Odin;
1776 else if (l ==
"LANG_P4")
1777 return translation_unit::LANG_P4;
1778 else if (l ==
"LANG_Move")
1779 return translation_unit::LANG_Move;
1780 else if (l ==
"LANG_Hylo")
1781 return translation_unit::LANG_Hylo;
1783 return translation_unit::LANG_UNKNOWN;
1794 return (l == translation_unit::LANG_C89
1795 || l == translation_unit::LANG_C99
1796 || l == translation_unit::LANG_C11
1797 || l == translation_unit::LANG_C17
1798 || l == translation_unit::LANG_C23
1799 || l == translation_unit::LANG_C);
1810 return (l == translation_unit::LANG_C_plus_plus_03
1811 || l == translation_unit::LANG_C_plus_plus_11
1812 || l == translation_unit::LANG_C_plus_plus_14
1813 || l == translation_unit::LANG_C_plus_plus_20
1814 || l == translation_unit::LANG_C_plus_plus_23
1815 || l == translation_unit::LANG_C_plus_plus);
1825{
return l == translation_unit::LANG_Java;}
1835 return (l == translation_unit::LANG_Ada83
1836 || l == translation_unit::LANG_Ada95
1837 || l == translation_unit::LANG_Ada2005
1838 || l == translation_unit::LANG_Ada2012);
1851 if (l.get() == r.get())
1874struct elf_symbol::priv
1914 bool is_in_ksymtab_;
1917 bool is_suppressed_;
1932 is_in_ksymtab_(false),
1935 is_suppressed_(false)
1938 priv(
const environment& e,
1946 const elf_symbol::version& ve,
1968 is_common_ = type_ == COMMON_TYPE;
2002elf_symbol::elf_symbol(
const environment& e,
2078 elf_symbol_sptr sym(
new elf_symbol(e, i, s, n, t, b, d, c, ve, vi,
2080 sym->priv_->main_symbol_ = sym;
2139{
return priv_->env_;}
2146{
return priv_->index_;}
2160{
return priv_->name_;}
2169 priv_->id_string_.clear();
2177{
return priv_->type_;}
2191{
return priv_->size_;}
2198{priv_->size_ = size;}
2205{
return priv_->binding_;}
2212{priv_->binding_ = b;}
2219{
return priv_->version_;}
2227 priv_->version_ = v;
2228 priv_->id_string_.clear();
2237{priv_->visibility_ = v;}
2245{
return priv_->visibility_;}
2253{
return priv_->is_defined_;}
2261{priv_->is_defined_ = d;}
2314{
return priv_->is_in_ksymtab_;}
2329{
return priv_->crc_;}
2343{
return priv_->namespace_;}
2350{priv_->namespace_ = ns;}
2359{
return priv_->is_suppressed_;}
2398{
return priv_->main_symbol_.lock();}
2405{
return priv_->main_symbol_.lock();}
2419{
return priv_->next_alias_.lock();}
2439 a = a->get_next_alias())
2462 a && !a->is_main_symbol();
2463 a = a->get_next_alias())
2465 if (a->get_next_alias()->is_main_symbol())
2473 last_alias->priv_->next_alias_ = alias;
2476 priv_->next_alias_ = alias;
2506 a = a->get_next_alias())
2507 if (a->get_name() == name)
2517 priv_->main_symbol_ = new_main;
2519 a = a->get_next_alias())
2520 a->priv_->main_symbol_ = new_main;
2530{
return priv_->is_common_;}
2561{
return priv_->next_common_instance_.lock();}
2576 ABG_ASSERT(!common->has_other_common_instances());
2585 c = c->get_next_common_instance())
2590 last_common_instance = c;
2595 last_common_instance->priv_->next_common_instance_ = common;
2598 priv_->next_common_instance_ = common;
2618 if (priv_->id_string_.empty())
2630 priv_->id_string_ = s;
2633 return priv_->id_string_;
2650 a = a->get_next_alias())
2651 if (a->get_name() == name)
2668 a && a.get() != a->get_main_symbol().get();
2669 a = a->get_next_alias())
2670 if (textually_equals(*
this, *a))
2687 bool include_symbol_itself)
const
2691 if (include_symbol_itself)
2694 vector<elf_symbol_sptr> aliases;
2695 compute_aliases_for_elf_symbol(*
this, syms, aliases);
2696 if (!aliases.empty() && include_symbol_itself)
2699 for (vector<elf_symbol_sptr>::const_iterator i = aliases.begin();
2703 if (i != aliases.begin())
2705 result += (*i)->get_id_string();
2720 vector<elf_symbol_sptr> aliases;
2721 if (include_symbol_itself)
2726 a = a->get_next_alias())
2727 aliases.push_back(a);
2730 for (vector<elf_symbol_sptr>::const_iterator i = aliases.begin();
2734 if (i != aliases.begin())
2736 result += (*i)->get_id_string();
2756 name.clear(), ver.clear();
2758 string::size_type i =
id.find(
'@');
2759 if (i == string::npos)
2765 name =
id.substr(0, i);
2771 string::size_type j =
id.find(
'@', i);
2772 if (j == string::npos)
2799 bool are_equal = textually_equals(*
this, other);
2820 a && !a->is_main_symbol();
2821 a = a->get_next_alias())
2845 return *lhs == *rhs;
2871compute_aliases_for_elf_symbol(
const elf_symbol& sym,
2873 vector<elf_symbol_sptr>& aliases)
2877 for (; a && !a->is_main_symbol(); a = a->get_next_alias())
2878 aliases.push_back(a);
2884 string_elf_symbols_map_type::const_iterator i =
2886 if (i == symtab.end())
2889 for (elf_symbols::const_iterator j = i->second.begin();
2890 j != i->second.end();
2895 s && !s->is_main_symbol();
2896 s = s->get_next_alias())
2897 aliases.push_back(s);
2900 s && !s->is_main_symbol();
2901 s = s->get_next_alias())
2903 aliases.push_back(*j);
2949 case elf_symbol::NOTYPE_TYPE:
2950 repr =
"unspecified symbol type";
2952 case elf_symbol::OBJECT_TYPE:
2953 repr =
"variable symbol type";
2955 case elf_symbol::FUNC_TYPE:
2956 repr =
"function symbol type";
2958 case elf_symbol::SECTION_TYPE:
2959 repr =
"section symbol type";
2961 case elf_symbol::FILE_TYPE:
2962 repr =
"file symbol type";
2964 case elf_symbol::COMMON_TYPE:
2965 repr =
"common data object symbol type";
2967 case elf_symbol::TLS_TYPE:
2968 repr =
"thread local data object symbol type";
2970 case elf_symbol::GNU_IFUNC_TYPE:
2971 repr =
"indirect function symbol type";
2975 std::ostringstream s;
2976 s <<
"unknown symbol type (" << (char)t <<
')';
2999 case elf_symbol::LOCAL_BINDING:
3000 repr =
"local binding";
3002 case elf_symbol::GLOBAL_BINDING:
3003 repr =
"global binding";
3005 case elf_symbol::WEAK_BINDING:
3006 repr =
"weak binding";
3008 case elf_symbol::GNU_UNIQUE_BINDING:
3009 repr =
"GNU unique binding";
3013 std::ostringstream s;
3014 s <<
"unknown binding (" << (
unsigned char) b <<
")";
3037 case elf_symbol::DEFAULT_VISIBILITY:
3038 repr =
"default visibility";
3040 case elf_symbol::PROTECTED_VISIBILITY:
3041 repr =
"protected visibility";
3043 case elf_symbol::HIDDEN_VISIBILITY:
3044 repr =
"hidden visibility";
3046 case elf_symbol::INTERNAL_VISIBILITY:
3047 repr =
"internal visibility";
3051 std::ostringstream s;
3052 s <<
"unknown visibility (" << (
unsigned char) v <<
")";
3074 t = elf_symbol::NOTYPE_TYPE;
3075 else if (s ==
"object-type")
3076 t = elf_symbol::OBJECT_TYPE;
3077 else if (s ==
"func-type")
3078 t = elf_symbol::FUNC_TYPE;
3079 else if (s ==
"section-type")
3080 t = elf_symbol::SECTION_TYPE;
3081 else if (s ==
"file-type")
3082 t = elf_symbol::FILE_TYPE;
3083 else if (s ==
"common-type")
3084 t = elf_symbol::COMMON_TYPE;
3085 else if (s ==
"tls-type")
3086 t = elf_symbol::TLS_TYPE;
3087 else if (s ==
"gnu-ifunc-type")
3088 t = elf_symbol::GNU_IFUNC_TYPE;
3106 if (s ==
"local-binding")
3107 b = elf_symbol::LOCAL_BINDING;
3108 else if (s ==
"global-binding")
3109 b = elf_symbol::GLOBAL_BINDING;
3110 else if (s ==
"weak-binding")
3111 b = elf_symbol::WEAK_BINDING;
3112 else if (s ==
"gnu-unique-binding")
3113 b = elf_symbol::GNU_UNIQUE_BINDING;
3131 if (s ==
"default-visibility")
3132 v = elf_symbol::DEFAULT_VISIBILITY;
3133 else if (s ==
"protected-visibility")
3134 v = elf_symbol::PROTECTED_VISIBILITY;
3135 else if (s ==
"hidden-visibility")
3136 v = elf_symbol::HIDDEN_VISIBILITY;
3137 else if (s ==
"internal-visibility")
3138 v = elf_symbol::INTERNAL_VISIBILITY;
3153{
return t == elf_symbol::FUNC_TYPE;}
3163{
return t == elf_symbol::OBJECT_TYPE;}
3167struct elf_symbol::version::priv
3173 : is_default_(false)
3176 priv(
const string& v,
3183elf_symbol::version::version()
3190elf_symbol::version::version(
const string& v,
3192 : priv_(new priv(v, is_default))
3196 : priv_(new priv(v.str(), v.is_default()))
3200elf_symbol::version::~version() =
default;
3205elf_symbol::version::operator
const string&()
const
3206{
return priv_->version_;}
3213{
return priv_->version_;}
3220{priv_->version_ = s;}
3227{
return priv_->is_default_;}
3234{priv_->is_default_ = f;}
3237elf_symbol::version::is_empty()
const
3238{
return str().empty();}
3247{
return str() == o.
str();}
3276struct dm_context_rel::priv
3279 size_t offset_in_bits_;
3282 priv(
bool is_static =
false)
3283 : is_laid_out_(!is_static),
3285 anonymous_data_member_()
3288 priv(
bool is_laid_out,
size_t offset_in_bits)
3289 : is_laid_out_(is_laid_out),
3290 offset_in_bits_(offset_in_bits),
3291 anonymous_data_member_()
3295dm_context_rel::dm_context_rel()
3300dm_context_rel::dm_context_rel(scope_decl* s,
3302 size_t offset_in_bits,
3305 : context_rel(s, a, is_static),
3306 priv_(new priv(is_laid_out, offset_in_bits))
3309dm_context_rel::dm_context_rel(scope_decl* s)
3315dm_context_rel::get_is_laid_out()
const
3316{
return priv_->is_laid_out_;}
3319dm_context_rel::set_is_laid_out(
bool f)
3320{priv_->is_laid_out_ = f;}
3323dm_context_rel::get_offset_in_bits()
const
3324{
return priv_->offset_in_bits_;}
3327dm_context_rel::set_offset_in_bits(
size_t o)
3328{priv_->offset_in_bits_ = o;}
3331dm_context_rel::operator==(
const dm_context_rel& o)
const
3333 if (!context_rel::operator==(o))
3336 return (priv_->is_laid_out_ == o.priv_->is_laid_out_
3337 && priv_->offset_in_bits_ == o.priv_->offset_in_bits_);
3341dm_context_rel::operator!=(
const dm_context_rel& o)
const
3352{
return priv_->anonymous_data_member_;}
3362{priv_->anonymous_data_member_ = anon_dm;}
3364dm_context_rel::~dm_context_rel()
3390{
return priv_->canonical_types_;}
3434 unsigned l1 = 0, l2 = 0, c1 = 0, c2 = 0;
3456 vector<type_base_sptr>& result)
3459 result.push_back(t);
3462 std::stable_sort(result.begin(), result.end(), comp);
3474const type_base_sptr&
3477 if (!priv_->void_type_)
3478 priv_->void_type_.reset(
new type_decl(*
this,
3481 return priv_->void_type_;
3493const type_base_sptr&
3496 if (!priv_->void_pointer_type_)
3499 return priv_->void_pointer_type_;
3512const type_base_sptr&
3515 if (!priv_->variadic_marker_type_)
3516 priv_->variadic_marker_type_.
3519 return priv_->variadic_marker_type_;
3528 static string variadic_parameter_type_name =
"variadic parameter type";
3529 return variadic_parameter_type_name;
3539{
return priv_->canonicalization_is_done_;}
3554 priv_->canonicalization_is_done_ = f;
3555 if (priv_->canonicalization_is_done_)
3566{
return priv_->canonicalization_started_;}
3575{priv_->canonicalization_started_ = f;}
3599{
return priv_->decl_only_class_equals_definition_;}
3624{priv_->decl_only_class_equals_definition_ = f;}
3729{
return const_cast<environment*
>(
this)->priv_->string_pool_.create_string(s);}
3736{
return priv_->config_;}
3746{
return priv_->analyze_exported_interfaces_only_.has_value();}
3759{priv_->analyze_exported_interfaces_only_ = f;}
3772{
return priv_->analyze_exported_interfaces_only_.value_or(
false);}
3774#ifdef WITH_DEBUG_SELF_COMPARISON
3787environment::set_self_comparison_debug_input(
const corpus_sptr& c)
3789 self_comparison_debug_is_on(
true);
3790 if (priv_->first_self_comparison_corpus_.expired())
3791 priv_->first_self_comparison_corpus_ = c;
3792 else if (priv_->second_self_comparison_corpus_.expired()
3793 && c.get() != corpus_sptr(priv_->first_self_comparison_corpus_).get())
3794 priv_->second_self_comparison_corpus_ = c;
3807environment::get_self_comparison_debug_inputs(corpus_sptr& first_corpus,
3808 corpus_sptr& second_corpus)
3810 first_corpus = priv_->first_self_comparison_corpus_.lock();
3811 second_corpus = priv_->second_self_comparison_corpus_.lock();
3818environment::self_comparison_debug_is_on(
bool f)
3819{priv_->self_comparison_debug_on_ = f;}
3826environment::self_comparison_debug_is_on()
const
3827{
return priv_->self_comparison_debug_on_;}
3830#ifdef WITH_DEBUG_TYPE_CANONICALIZATION
3837environment::debug_type_canonicalization_is_on(
bool flag)
3838{priv_->debug_type_canonicalization_ = flag;}
3846environment::debug_type_canonicalization_is_on()
const
3847{
return priv_->debug_type_canonicalization_;}
3855environment::debug_die_canonicalization_is_on(
bool flag)
3856{priv_->debug_die_canonicalization_ = flag;}
3864environment::debug_die_canonicalization_is_on()
const
3865{
return priv_->debug_die_canonicalization_;}
3881const vector<type_base_sptr>*
3908 if (!types ||index >= types->size())
3910 return (*types)[index].get();
3913#ifdef WITH_DEBUG_SELF_COMPARISON
3923const unordered_map<string, uintptr_t>&
3924environment::get_type_id_canonical_type_map()
const
3925{
return priv_->get_type_id_canonical_type_map();}
3936unordered_map<string, uintptr_t>&
3937environment::get_type_id_canonical_type_map()
3938{
return priv_->get_type_id_canonical_type_map();}
3953const unordered_map<uintptr_t, string>&
3954environment::get_pointer_type_id_map()
const
3955{
return priv_->get_pointer_type_id_map();}
3970unordered_map<uintptr_t, string>&
3971environment::get_pointer_type_id_map()
3972{
return priv_->get_pointer_type_id_map();}
3990environment::get_type_id_from_pointer(uintptr_t ptr)
const
3991{
return priv_->get_type_id_from_pointer(ptr);}
4009environment::get_type_id_from_type(
const type_base *t)
const
4010{
return priv_->get_type_id_from_type(t);}
4027environment::get_canonical_type_from_type_id(
const char* type_id)
const
4028{
return priv_->get_canonical_type_from_type_id(type_id);}
4042 (
static_cast<unsigned>(l) |
static_cast<unsigned>(r));
4062 (
static_cast<unsigned>(l) &
static_cast<unsigned>(r));
4083 :priv_(new
priv(e, k))
4099{
return priv_->is_artificial_;}
4111{priv_->is_artificial_ = f;}
4122{
return priv_->kind();}
4142{
return priv_->rtti_;}
4151{
return priv_->rtti_;}
4163 priv_->type_or_decl_ptr_ = t;
4165 priv_->type_or_decl_ptr_ = d;
4188{
return priv_->type_or_decl_ptr_;}
4199{
return priv_->hash_value_;}
4202type_or_decl_base::set_hash_value(
hash_t h)
const
4203{priv_->set_hash_value(h);}
4210{
return priv_->env_;}
4228{priv_->artificial_location_ = l;}
4246{
return priv_->artificial_location_;}
4254 return (priv_->artificial_location_
4255 && priv_->artificial_location_.get_is_artificial());
4286{priv_->translation_unit_ = tu;}
4295{
return priv_->translation_unit_;}
4327 *dr =
dynamic_cast<const decl_base*
>(r);
4336 *tr =
dynamic_cast<const type_base*
>(r);
4381struct decl_base::priv
4383 bool in_pub_sym_tab_;
4411 decl_base_sptr declaration_;
4413 decl_base* naked_definition_of_declaration_;
4414 bool is_declaration_only_;
4418 : in_pub_sym_tab_(false),
4419 is_anonymous_(true),
4421 visibility_(VISIBILITY_DEFAULT),
4422 naked_definition_of_declaration_(),
4423 is_declaration_only_(false)
4426 priv(interned_string name, interned_string linkage_name,
visibility vis)
4427 : in_pub_sym_tab_(false),
4430 qualified_name_(name),
4431 linkage_name_(linkage_name),
4433 naked_definition_of_declaration_(),
4434 is_declaration_only_(false)
4436 is_anonymous_ = name_.
empty();
4461 const string& linkage_name,
4464 priv_(new priv(e.intern(name), e.intern(linkage_name), vis))
4488 priv_(new priv(name, linkage_name, vis))
4515{
return priv_->qualified_name_;}
4524{priv_->qualified_name_.clear();}
4531{priv_->qualified_name_ = n;}
4544{
return priv_->temporary_qualified_name_;}
4558{priv_->temporary_qualified_name_ = n;}
4565{
return priv_->context_;}
4572{
return priv_->context_;}
4576{priv_->context_ = c;}
4585{
return priv_->in_pub_sym_tab_;}
4593{priv_->in_pub_sym_tab_ = f;}
4613{
return priv_->location_;}
4655 priv_->location_ = l;
4665 priv_->is_anonymous_ = n.empty();
4676{
return priv_->is_anonymous_;}
4686{priv_->is_anonymous_ = f;}
4723{
return priv_->naming_typedef_;}
4751 &&
is_type(
this)->get_naked_canonical_type() ==
nullptr);
4753 priv_->naming_typedef_ = t;
4760 update_qualified_name(
this);
4768{
return priv_->linkage_name_;}
4777 priv_->linkage_name_ = env.
intern(m);
4785{
return priv_->visibility_;}
4792{priv_->visibility_ = v;}
4801 if (priv_->context_)
4802 return priv_->context_->get_scope();
4812{
return priv_->qualified_parent_name_;}
4819{
return priv_->name_;}
4854 bool qualified_name)
const
4858 && has_generic_anonymous_internal_type_name(
this))
4869 string name = get_generic_anonymous_internal_type_name(
this);
4905 if (priv_->internal_cached_repr_.empty())
4910 return priv_->internal_cached_repr_;
4913 if (priv_->cached_repr_.empty())
4919 return priv_->cached_repr_;
4939{
return priv_->qualified_name_;}
4953{
return priv_->scoped_name_;}
4961{
return priv_->declaration_;}
4970 if (d && d->get_is_declaration_only())
4971 priv_->declaration_ = d;
4981{
return priv_->definition_of_declaration_.lock();}
4997{
return priv_->naked_definition_of_declaration_;}
5004{
return priv_->is_declaration_only_;}
5014 bool update_types_lookup_map = !f && priv_->is_declaration_only_;
5016 priv_->is_declaration_only_ = f;
5018 if (update_types_lookup_map)
5021 scope_decl::declarations::iterator i;
5022 if (s->find_iterator_for_member(
this, i))
5032 return static_cast<change_kind>(
static_cast<unsigned>(l)
5033 |
static_cast<unsigned>(r));
5039 return static_cast<change_kind>(
static_cast<unsigned>(l)
5040 &
static_cast<unsigned>(r));
5087 bool member_types_or_functions =
5091 if (member_types_or_functions)
5100 la = r1->get_access_specifier();
5101 ra = r2->get_access_specifier();
5102 r1->set_access_specifier(no_access);
5103 r2->set_access_specifier(no_access);
5106 bool rels_are_different = *r1 != *r2;
5108 if (member_types_or_functions)
5111 r1->set_access_specifier(la);
5112 r2->set_access_specifier(ra);
5115 if (rels_are_different)
5150 if (!l_linkage_name.
empty() && !r_linkage_name.
empty())
5152 if (l_linkage_name != r_linkage_name)
5192 bool decls_are_same = (ln == rn);
5194 if (!decls_are_same)
5217{
return equals(*
this, other, 0);}
5256 if (!priv_->context_)
5259 priv_->context_->set_scope(scope);
5277 case decl_base::VISIBILITY_NONE:
5280 case decl_base::VISIBILITY_DEFAULT:
5283 case decl_base::VISIBILITY_PROTECTED:
5286 case decl_base::VISIBILITY_HIDDEN:
5289 case decl_base::VISIBILITY_INTERNAL:
5309 case decl_base::BINDING_NONE:
5312 case decl_base::BINDING_LOCAL:
5315 case decl_base::BINDING_GLOBAL:
5318 case decl_base::BINDING_WEAK:
5341 if (l.get() == r.get())
5377 if (l.get() == r.get())
5463{
return dynamic_pointer_cast<scope_decl>(d);}
5529 return c->get_access_specifier();
5559 c->set_access_specifier(a);
5589 return c->get_is_static();
5731 var_decl_sptr first = *klass->get_non_static_data_members().begin();
5752 if (!klass ||!data_member)
5755 for (class_or_union::data_members::const_iterator it =
5759 if (**it == *data_member)
5828 bool result =
false;
5846 dms[member->get_name()] = member;
6055 return class_or_union_sptr();
6064const class_or_union_sptr
6069 if (cou->get_is_anonymous())
6072 return class_or_union_sptr();
6081const class_or_union_sptr
6086 return class_or_union_sptr();
6095const class_or_union_sptr
6110 return class_or_union_sptr();
6135 for (
auto anon_dm_m : cl->get_non_static_data_members())
6182 ctxt_rel->set_offset_in_bits(o);
6197 return ctxt_rel->get_offset_in_bits();
6287 const var_decl *containing_anonymous_data_member =
6290 uint64_t containing_anonymous_data_member_offset = 0;
6291 if (containing_anonymous_data_member)
6292 containing_anonymous_data_member_offset =
6295 return (ctxt_rel->get_offset_in_bits()
6297 containing_anonymous_data_member_offset);
6325 type_base_sptr t = v->get_type();
6328 return t->get_size_in_bits();
6342 ctxt_rel->set_is_laid_out(l);
6357 return ctxt_rel->get_is_laid_out();
6618set_member_function_vtable_offset(
function_decl& f, ssize_t s)
6640{
return set_member_function_vtable_offset(*f, s);}
6659 return ctxt->is_virtual();
6686set_member_function_is_virtual(
function_decl& f,
bool is_virtual)
6696 ctxt->is_virtual(is_virtual);
6709 set_member_function_is_virtual(*fn, is_virtual);
6728 set_member_function_vtable_offset(fn, voffset);
6729 set_member_function_is_virtual(fn, is_virtual);
6760 set_member_function_vtable_offset(fn, voffset);
6761 set_member_function_is_virtual(fn, is_virtual);
6798 if (!cl->get_canonical_type())
6804 type_base_sptr t = type;
6815 ty->get_size_in_bits(),
6816 ty->get_alignment_in_bits(),
6817 ty->get_location()));
6825 ty->get_size_in_bits(),
6826 ty->get_alignment_in_bits(),
6827 ty->get_location()));
6836 ty->get_location()));
6842 t.reset(
new array_type_def(p, ty->get_subranges(), ty->get_location()));
6847 for (function_decl::parameters::const_iterator i =
6848 ty->get_parameters().begin();
6849 i != ty->get_parameters().end();
6860 p->get_variadic_marker(),
6861 p->get_is_artificial()));
6862 parm.push_back(stripped);
6867 parm, ty->get_is_const(),
6868 ty->get_size_in_bits(),
6869 ty->get_alignment_in_bits()));
6874 for (function_decl::parameters::const_iterator i =
6875 ty->get_parameters().begin();
6876 i != ty->get_parameters().end();
6887 p->get_variadic_marker(),
6888 p->get_is_artificial()));
6889 parm.push_back(stripped);
6894 ty->get_size_in_bits(),
6895 ty->get_alignment_in_bits()));
6898 if (!t->get_translation_unit())
6899 t->set_translation_unit(type->get_translation_unit());
6904 return t->get_canonical_type() ? t->get_canonical_type() : t;
6927 decl_base_sptr result = t;
6928 type_base_sptr u = t->get_underlying_type();
6931 if ((t->get_cv_quals() & qualified_type_def::CV_CONST
6933 || (t->get_cv_quals() & qualified_type_def::CV_CONST
6935 || t->get_cv_quals() == qualified_type_def::CV_NONE)
6981static qualified_type_def_sptr
6982strip_redundant_quals_from_underyling_types(
const qualified_type_def_sptr& t,
6991 qualified_type_def_sptr underlying_qualified_type =
6999 currated_quals &= ~redundant_quals;
7000 t->set_cv_quals(currated_quals);
7004 redundant_quals |= currated_quals;
7006 qualified_type_def_sptr result = t;
7007 if (underlying_qualified_type)
7011 strip_redundant_quals_from_underyling_types(underlying_qualified_type,
7045strip_redundant_quals_from_underyling_types(
const qualified_type_def_sptr& t)
7051 strip_redundant_quals_from_underyling_types(t, redundant_quals);
7078 return t->get_underlying_type();
7132 return t->get_pointed_to_type();
7188 return t->get_pointed_to_type();
7313 if (t->get_cv_quals() == qualified_type_def::CV_CONST)
7346 return q->get_underlying_type();
7395 type_base_sptr type = t;
7418 type_base_sptr typ = type;
7480 bool peel_qual_type)
7519 bool peel_qual_type)
7557 vector<array_type_def::subrange_sptr> subranges;
7559 for (vector<array_type_def::subrange_sptr>::const_iterator i =
7560 array->get_subranges().begin();
7561 i != array->get_subranges().end();
7567 (*i)->get_lower_bound(),
7568 (*i)->get_upper_bound(),
7569 (*i)->get_underlying_type(),
7570 (*i)->get_location(),
7571 (*i)->get_language()));
7572 subrange->is_non_finite((*i)->is_non_finite());
7575 subranges.push_back(subrange);
7580 subranges, array->get_location()));
7603 (
new typedef_decl(t->get_name(), t->get_underlying_type(),
7604 t->get_location(), t->get_linkage_name(),
7605 t->get_visibility()));
7621qualified_type_def_sptr
7627 qualified_type_def_sptr result
7629 t->get_cv_quals(), t->get_location()));
7641static type_base_sptr
7642clone_typedef_array_qualified_type(type_base_sptr type)
7648 type_base_sptr result;
7657 return type_base_sptr();
7680 type_base_sptr result = clone_typedef_array_qualified_type(t);
7683 type_base_sptr subtree;
7687 clone_typedef_array_qualified_type(type->get_underlying_type());
7691 type->set_underlying_type(subtree);
7697 clone_typedef_array_qualified_type(type->get_element_type());
7701 type->set_element_type(subtree);
7711 clone_typedef_array_qualified_type(t->get_underlying_type());
7718 t->set_underlying_type (s);
7727 clone_typedef_array_qualified_type(t->get_underlying_type());
7734 t->set_underlying_type(s);
7742 type_base_sptr e = t->get_element_type();
7746 clone_typedef_array_qualified_type(e);
7752 t->set_element_type(s);
7771 ::qualified_name_setter setter;
7779update_qualified_name(decl_base_sptr d)
7780{
return update_qualified_name(d.get());}
7800{
return reinterpret_cast<size_t>(l);}
7802struct scope_decl::priv
7811 bool clear_sorted_member_types_cache_ =
false;
7848{
return priv_->canonical_types_;}
7866 if (priv_->sorted_canonical_types_.empty())
7868 for (canonical_type_sptr_set_type::const_iterator e =
7872 priv_->sorted_canonical_types_.push_back(*e);
7875 std::stable_sort(priv_->sorted_canonical_types_.begin(),
7876 priv_->sorted_canonical_types_.end(),
7879 return priv_->sorted_canonical_types_;
7889{
return priv_->members_;}
7898{
return priv_->members_;}
7909 if (priv_->sorted_members_.empty())
7914 priv_->sorted_members_.push_back(*i);
7916 std::stable_sort(priv_->sorted_members_.begin(),
7917 priv_->sorted_members_.end(),
7920 return priv_->sorted_members_;
7935 if (t->get_is_anonymous())
7953 if (t->get_is_anonymous())
7971 if (t->get_is_anonymous())
7982{
return priv_->member_scopes_;}
7989{
return priv_->member_scopes_;}
8011maybe_set_translation_unit(
const decl_base_sptr& decl,
8028 decl->set_translation_unit(tu);
8045 member->set_scope(
this);
8046 priv_->members_.push_back(member);
8049 priv_->member_types_.push_back(
is_type(member));
8050 priv_->clear_sorted_member_types_cache_ =
true;
8054 priv_->member_scopes_.push_back(m);
8056 update_qualified_name(member);
8059 maybe_set_translation_unit(member, tu);
8071{
return priv_->member_types_;}
8086 return type_base_sptr();
8096 declarations::iterator before)
8102 priv_->member_types_.push_back(t);
8103 priv_->clear_sorted_member_types_cache_=
true;
8139 for (
auto i = priv_->member_types_.begin();
8140 i != priv_->member_types_.end();
8145 priv_->member_types_.erase(i);
8158 if (priv_->clear_sorted_member_types_cache_)
8160 priv_->sorted_member_types_.clear();
8161 priv_->clear_sorted_member_types_cache_ =
false;
8164 if (priv_->sorted_member_types_.empty())
8166 unordered_set<type_base_sptr> canonical_pointer_types;
8170 priv_->sorted_member_types_.push_back(t);
8171 else if (
auto c = t->get_canonical_type())
8172 canonical_pointer_types.insert(c);
8174 canonical_pointer_types.insert(t);
8177 for (
auto t : canonical_pointer_types)
8178 priv_->sorted_member_types_.push_back(t);
8181 std::stable_sort(priv_->sorted_member_types_.begin(),
8182 priv_->sorted_member_types_.end(),
8188 priv_->clear_sorted_member_types_cache_ =
true;
8190 return priv_->sorted_member_types_;
8206 declarations::iterator before)
8210 member->set_scope(
this);
8211 priv_->members_.insert(before, member);
8214 priv_-> member_scopes_.push_back(m);
8216 update_qualified_name(member);
8219 maybe_set_translation_unit(member, tu);
8232 for (declarations::iterator i = priv_->members_.begin();
8233 i != priv_->members_.end();
8238 priv_->members_.erase(i);
8248 for (scopes::iterator i = priv_->member_scopes_.begin();
8249 i != priv_->member_scopes_.end();
8254 priv_->member_scopes_.erase(i);
8260 member->set_scope(
nullptr);
8261 member->set_translation_unit(
nullptr);
8288 if (!l.decl_base::operator==(r))
8297 scope_decl::declarations::const_iterator i, j;
8339 return equals(*
this, *other, 0);
8354 if (l.get() == r.get())
8380 declarations::iterator& i)
8395 if ((*it).get() == decl)
8415 declarations::iterator& i)
8432 if (v.visit_begin(
this))
8435 for (scope_decl::declarations::const_iterator i =
8439 if (!(*i)->traverse(v))
8443 return v.visit_end(
this);
8446scope_decl::~scope_decl()
8462 if (scope && decl && !decl->
get_scope())
8502 scope_decl::declarations::iterator before,
8505 if (scope && decl && !decl->
get_scope())
8524 scope_decl::declarations::iterator before,
8534 | ABSTRACT_DECL_BASE
8535 | ABSTRACT_SCOPE_DECL),
8538 translation_unit_(tu)
8540 runtime_type_instance(
this);
8559 return scope ?
dynamic_cast<global_scope*
> (scope) : 0;
8666 if (cv_quals & qualified_type_def::CV_RESTRICT)
8668 if (cv_quals & qualified_type_def::CV_CONST)
8674 if (cv_quals & qualified_type_def::CV_VOLATILE)
8726{
return get_name(tod.get(), qualified);}
8744 string qualified_name;
8748 if (qualified_name.empty())
8749 qualified_name = name;
8751 qualified_name = qualified_name +
"::" + name;
8753 return qualified_name;
8788 location loc = decl->get_location();
8792 if (c->get_is_declaration_only() && c->get_definition_of_declaration())
8795 loc = c->get_location();
8853has_generic_anonymous_internal_type_name(
const decl_base *d)
8870static interned_string
8871get_generic_anonymous_internal_type_name(
const decl_base *d)
8873 ABG_ASSERT(has_generic_anonymous_internal_type_name(d));
8875 const environment&env = d->get_environment();
8877 interned_string result;
8910get_internal_real_type_name(
const type_base* t)
8920 name = int_type.to_string(
true);
8945 return empty_string;
8952 return empty_string;
8969 r += get_generic_anonymous_internal_type_name(d);
8979 return env.
intern(get_internal_real_type_name(t));
8988 internal, qualified));
9027 bool qualified,
bool internal)
9030 string tn =
get_type_name(pointed_to_type, qualified, internal);
9049 bool lvalue_reference,
9050 bool qualified,
bool internal)
9054 string name =
get_type_name(pointed_to_type, qualified, internal);
9055 if (lvalue_reference)
9080 bool qualified,
bool internal)
9082 const environment& env = underlying_type->get_environment();
9085 string name =
get_type_name(underlying_type, qualified, internal);
9087 if (quals_repr.empty() && internal)
9099 if (!quals_repr.empty())
9108 name = quals_repr +
" " + name;
9165 std::ostringstream o;
9174 stream_pretty_representation_of_fn_parms(fn_type, o,
9177 return env.
intern(o.str());
9196 c->get_exported_decls_builder();
9197 if (b->fn_id_maps_to_several_fns(fn))
9253 std::ostringstream o;
9272 o <<
" (" << class_type->get_qualified_name(internal) <<
"::*) ";
9273 stream_pretty_representation_of_fn_parms(fn_type, o,
9277 return env.
intern(o.str());
9443 std::ostringstream o;
9461 std::ostringstream o;
9516 const string& indent,
9519 bool qualified_names)
9522 string local_indent =
" ";
9527 if (!internal && clazz->is_struct())
9533 repr = indent +
"union";
9566 for (class_or_union::data_members::const_iterator dm = dmems.begin();
9570 if (dm != dmems.begin())
9575 real_indent =
"\n" + indent + local_indent;
9582 real_indent, one_line, internal, qualified_names);
9587 if (dm != dmems.begin())
9588 repr += real_indent;
9589 repr += (*dm)->get_pretty_representation(internal,
9594 real_indent+ (*dm)->get_pretty_representation(internal,
9603 repr += indent +
"}";
9631 const string& indent,
9634 bool qualified_names)
9638 internal, qualified_names);
9660 const string& indent,
9663 bool qualified_names)
9692 const string& indent,
bool one_line,
9693 bool qualified_names)
9696 std::ostringstream o;
9697 string local_indent =
" ";
9699 repr = indent +
"enum ";
9702 o << (qualified_names
9716 o << enumerator.get_name() +
"=" << enumerator.get_value() <<
", ";
9720 o <<
"\n" + indent <<
"}";
9751 const string& indent,
bool one_line,
9752 bool qualified_names)
9758 one_line, qualified_names);
9783 const string& indent,
bool one_line,
9784 bool qualified_names)
9813 const string& indent,
9816 bool qualified_name)
9822 internal, qualified_name);
9851 std::ostringstream o;
9866 o <<
" :" << std::endl;
9870 if (b->get_is_virtual())
9872 o << b->get_base_class()->get_qualified_name()
9876 o << std::hex << *h << std::dec;
9887 <<
" // translation unit: "
9892 <<
" // @: " << std::hex <<
is_type(c)
9898 o << std::hex << *h << std::dec;
9908 << member_type->get_pretty_representation(
false,
9911 if (member_type->get_canonical_type())
9913 o <<
" // uses canonical type: '@"
9914 << std::hex << member_type->get_canonical_type().get() <<
"'";
9917 o << std::hex << *h << std::dec;
9937 if (t && t->get_canonical_type())
9938 o <<
" // uses canonical type '@"
9939 << std::hex << t->get_canonical_type().get() <<
"'";
9944 o << std::hex << *h << std::dec;
9955 o <<
" // virtual member functions\n\n";
9964 o << std::hex << *h << std::dec;
9967 o <<
";" << std::endl;
9971 o <<
"};" << std::endl;
9977 string name = e->get_qualified_name();
9978 std::ostringstream o;
9979 o <<
"enum " << name
9981 << e->get_underlying_type()->get_pretty_representation(
false,
9985 <<
" // size in bits: " << e->get_size_in_bits() <<
"\n"
9986 <<
" // is-declaration-only: " << e->get_is_declaration_only() <<
"\n"
9988 <<
" // translation unit: "
9989 << e->get_translation_unit()->get_absolute_path() <<
"\n"
9990 <<
" // @: " << std::hex <<
is_type(e)
9991 <<
", @canonical: " << e->get_canonical_type().get() << std::dec <<
"\n"
9996 o << std::hex << *h << std::dec;
10002 for (
const auto &enom : e->get_enumerators())
10003 o <<
" " << enom.get_name() <<
" = " << enom.get_value() <<
",\n";
10011 std::ostringstream o;
10012 o << t->get_pretty_representation(
true,
10019 return artifact->get_pretty_representation(
true,
10118 return const_cast<type_base*
>(artifact);
10135 return const_cast<decl_base*
>(artifact);
10165debug_comp_vec(
const vector<const type_base*>& vect, std::ostringstream& o)
10167 for (
auto t : vect)
10169 o <<
"|" << t->get_pretty_representation()
10170 <<
"@" << std::hex << t << std::dec;
10182print_comp_stack(
const environment& env)
10184 std::ostringstream o;
10185 o <<
"left-operands: ";
10186 debug_comp_vec(env.priv_->left_type_comp_operands_, o);
10187 o <<
"\n" <<
"right-operands: ";
10188 debug_comp_vec(env.priv_->right_type_comp_operands_, o);
10201 std::cerr << print_comp_stack(env);
10202 std::cerr << std::endl;
10237{
return dynamic_cast<const decl_base*
>(t);}
10255{
return dynamic_pointer_cast<decl_base>(t);}
10271#ifdef RETURN_FROM_CLASSES_HAVE_SAME_LAYOUT
10272#undef RETURN_FROM_CLASSES_HAVE_SAME_LAYOUT
10275#ifdef ENSURE_NO_ENDLESS_LOOP
10276#undef ENSURE_NO_ENDLESS_LOOP
10279#define RETURN_FROM_CLASSES_HAVE_SAME_LAYOUT(VALUE) \
10282 auto t1 = is_class_or_union_type(f); \
10283 auto t2 = is_class_or_union_type(s); \
10284 t1->priv_->comparing_class_layouts_.erase(t2.get()); \
10285 t2->priv_->comparing_class_layouts_.erase(t1.get()); \
10289#define ENSURE_NO_ENDLESS_LOOP \
10292 auto t1 = is_class_or_union_type(f); \
10293 auto t2 = is_class_or_union_type(s); \
10294 const auto& END = t1->priv_->comparing_class_layouts_.end(); \
10295 if (t1->priv_->comparing_class_layouts_.find(t2.get()) != END \
10296 || t2->priv_->comparing_class_layouts_.find(t1.get()) != END) \
10298 t1->priv_->comparing_class_layouts_.insert(t2.get()); \
10299 t2->priv_->comparing_class_layouts_.insert(t1.get()); \
10307 || (fc->get_qualified_name() != sc->get_qualified_name())
10308 || (fc->get_size_in_bits() != sc->get_size_in_bits())
10309 || (fc->get_data_members().size() != sc->get_data_members().size()))
10313 RETURN_FROM_CLASSES_HAVE_SAME_LAYOUT(
true);
10316 for (
auto f_decl_it = fc->get_data_members().begin(),
10317 s_decl_it = sc->get_data_members().begin();
10318 (f_decl_it != fc->get_data_members().end()
10319 && s_decl_it != sc->get_data_members().end());
10320 ++f_decl_it, ++s_decl_it)
10323 type_base_sptr dm1_type = dm1->get_type(), dm2_type = dm2->get_type();
10325 if (*dm1_type != *dm2_type
10327 RETURN_FROM_CLASSES_HAVE_SAME_LAYOUT(
false);
10331 for (
auto f_bs_it = fc->get_base_specifiers().begin(),
10332 s_bs_it = sc->get_base_specifiers().end();
10333 (f_bs_it != fc->get_base_specifiers().end()
10334 && s_bs_it != sc->get_base_specifiers().end());
10335 ++f_bs_it, ++s_bs_it)
10338 if ((f_bs->get_is_virtual() != s_bs->get_is_virtual())
10339 || (f_bs->get_offset_in_bits() != s_bs->get_offset_in_bits()))
10340 RETURN_FROM_CLASSES_HAVE_SAME_LAYOUT(
false);
10342 class_decl_sptr fb = f_bs->get_base_class(), sb = s_bs->get_base_class();
10344 RETURN_FROM_CLASSES_HAVE_SAME_LAYOUT(
false);
10347 if (fc->has_vtable() != sc->has_vtable())
10348 RETURN_FROM_CLASSES_HAVE_SAME_LAYOUT(
false);
10351 ENSURE_NO_ENDLESS_LOOP;
10352 if (fc->has_vtable())
10354 if (fc->get_virtual_mem_fns().size() > sc->get_virtual_mem_fns().size())
10356 RETURN_FROM_CLASSES_HAVE_SAME_LAYOUT(
false);
10358 for (
auto it1 = fc->get_virtual_mem_fns().begin(),
10359 it2 = sc->get_virtual_mem_fns().begin();
10360 (it1 != fc->get_virtual_mem_fns().end()
10361 && it2 != sc->get_virtual_mem_fns().end());
10364 method_decl_sptr method1 = *it1;
10365 method_decl_sptr method2 = *it2;
10370 method2->get_type()))
10371 RETURN_FROM_CLASSES_HAVE_SAME_LAYOUT(
false);
10375 RETURN_FROM_CLASSES_HAVE_SAME_LAYOUT(
true);
10377#ifdef RETURN_FROM_CLASSES_HAVE_SAME_LAYOUT
10378#undef RETURN_FROM_CLASSES_HAVE_SAME_LAYOUT
10381#ifdef ENSURE_NO_ENDLESS_LOOP
10382#undef ENSURE_NO_ENDLESS_LOOP
10406 if (!type1 || !type2)
10409 if (type1 == type2 || *type1 == *type2)
10415 if (t1 && t2 && *t1 == *t2)
10439 type_base_sptr e1 = a1->get_element_type();
10440 type_base_sptr e2 = a2->get_element_type();
10444 if ((a1->get_size_in_bits() != a2->get_size_in_bits())
10445 || (a1->get_dimension_count() != a2->get_dimension_count())
10457 fn_type2->get_return_type()))
10464 if (fn_type1->get_parameters().size()
10465 != fn_type2->get_parameters().size())
10468 for (
auto p1 = fn_type1->get_first_non_implicit_parm(),
10469 p2 = fn_type2->get_first_non_implicit_parm();
10470 (p1 != fn_type1->get_parameters().end()
10471 && p2 != fn_type2->get_parameters().end());
10474 (*p2)->get_type()))
10500 const decl_base_sptr d2)
10658 const string& name)
10663 if (!containing_class_or_union)
10680{
return (decl &&
dynamic_cast<template_decl*
>(decl->get_scope()));}
10690 return (decl && (dynamic_pointer_cast<type_tparameter>(decl)
10691 || dynamic_pointer_cast<non_type_tparameter>(decl)
10692 || dynamic_pointer_cast<template_tparameter>(decl)));
10722{
return dynamic_pointer_cast<function_decl>(d);}
10745{
return dynamic_pointer_cast<function_decl::parameter>(tod);}
10756 if (d && (d->
kind() & type_or_decl_base::ABSTRACT_DECL_BASE))
10758 if (!(d->
kind() & type_or_decl_base::ABSTRACT_TYPE_BASE))
10784{
return dynamic_pointer_cast<decl_base>(d);}
10806{
return dynamic_pointer_cast<decl_base>(t);}
10816 if (
dynamic_cast<const type_base*
>(&tod))
10829 if (t && (t->
kind() & type_or_decl_base::ABSTRACT_TYPE_BASE))
10843{
return dynamic_pointer_cast<type_base>(tod);}
10875 if (!cou->get_naming_typedef())
10917{
return dynamic_cast<const type_decl*
>(t);}
10925{
return dynamic_pointer_cast<type_decl>(t);}
11019{
return dynamic_pointer_cast<typedef_decl>(t);}
11117{
return dynamic_pointer_cast<enum_type_decl>(d);}
11186 if (t->
kind() & type_or_decl_base::CLASS_TYPE)
11200{
return dynamic_pointer_cast<class_decl>(d);}
11222 if (array->is_non_finite())
11292 if (array->get_subranges().size() == 1
11293 && array->get_subranges()[0]->get_length() == 1)
11363 return klass->get_is_declaration_only();
11412shared_ptr<class_or_union>
11414{
return dynamic_pointer_cast<class_or_union>(t);}
11443 const class_or_union_sptr& second)
11473{
return dynamic_pointer_cast<union_decl>(t);}
11487 bool look_through_qualifiers)
11493 if (look_through_qualifiers)
11511 bool look_through_qualifiers)
11513 type_base_sptr type =
is_type(t);
11514 if (look_through_qualifiers)
11516 return dynamic_pointer_cast<pointer_type_def>(type);
11659 bool look_through_qualifiers)
11665 if (look_through_qualifiers)
11682 bool look_through_qualifiers)
11686 if (look_through_qualifiers)
11703 bool look_through_qualifiers)
11705 type_base_sptr type =
is_type(t);
11706 if (look_through_qualifiers)
11708 return dynamic_pointer_cast<reference_type_def>(type);
11719 bool look_through_qualifiers)
11722 if (look_through_qualifiers)
11739 bool look_through_qualifiers)
11741 type_base_sptr type =
is_type(t);
11742 if (look_through_qualifiers)
11744 return dynamic_pointer_cast<ptr_to_mbr_type>(type);
11818const type_base_sptr
11821 type_base_sptr nil;
11825 if (t->get_environment().get_void_pointer_type().get() == t.get())
11854qualified_type_def_sptr
11856{
return dynamic_pointer_cast<qualified_type_def>(t);}
11866{
return dynamic_pointer_cast<function_type>(t);}
11896{
return dynamic_pointer_cast<method_type>(t);}
11976 decl_base_sptr decl;
11983 while (decl->get_is_declaration_only()
11984 && decl->get_definition_of_declaration())
11985 decl = decl->get_definition_of_declaration();
12052 decl_base_sptr d =
is_decl(t);
12077{
return dynamic_pointer_cast<var_decl>(decl);}
12086{
return dynamic_pointer_cast<namespace_decl>(d);}
12120 && dynamic_pointer_cast<function_decl>(decl)
12131 bool look_through_qualifiers)
12135 if (look_through_qualifiers)
12147 bool look_through_qualifiers)
12149 type_base_sptr t =
is_type(type);
12151 if (look_through_qualifiers)
12153 return dynamic_pointer_cast<array_type_def>(t);
12162qualified_type_def_sptr
12166 return qualified_type_def_sptr();
12236{
return dynamic_pointer_cast<array_type_def::subrange_type>(type);}
12246{
return decl && dynamic_pointer_cast<template_decl>(decl);}
12252 LOOKUP_ENTITY_TYPE,
12284find_next_delim_in_cplus_type(
const string& fqn,
12288 int angle_count = 0;
12289 bool found =
false;
12291 for (; i < fqn.size(); ++i)
12295 else if (fqn[i] ==
'>')
12297 else if (i + 1 < fqn.size()
12300 && fqn[i+1] ==
':')
12317 list<string>& comps)
12319 string::size_type fqn_size = fqn.size(), comp_begin = 0, comp_end = fqn_size;
12322 if (!find_next_delim_in_cplus_type(fqn, comp_begin, comp_end))
12323 comp_end = fqn_size;
12325 string comp = fqn.substr(comp_begin, comp_end - comp_begin);
12326 comps.push_back(comp);
12328 comp_begin = comp_end + 2;
12329 if (comp_begin >= fqn_size)
12345 for (list<string>::const_iterator c = comps.begin();
12348 if (c == comps.begin())
12351 result +=
"::" + *c;
12366template<
typename T>
12368iterator_is_last(T& container,
12369 typename T::const_iterator i)
12371 typename T::const_iterator next = i;
12373 return (next == container.end());
12390lookup_types_in_map(
const interned_string& type_name,
12393 istring_type_base_wptrs_map_type::const_iterator i = type_map.find(type_name);
12394 if (i != type_map.end())
12415template <
class TypeKind>
12416static shared_ptr<TypeKind>
12417lookup_type_in_map(
const interned_string& type_name,
12420 istring_type_base_wptrs_map_type::const_iterator i = type_map.find(type_name);
12421 if (i != type_map.end())
12425 for (
auto j : i->second)
12427 type_base_sptr t(j);
12428 decl_base_sptr d =
is_decl(t);
12429 if (d && !d->get_is_declaration_only())
12430 return dynamic_pointer_cast<TypeKind>(type_base_sptr(j));
12435 return dynamic_pointer_cast<TypeKind>(type_base_sptr(i->second.back()));
12437 return shared_ptr<TypeKind>();
12454 return lookup_type_in_map<type_decl>(type_name,
12513 return lookup_type_in_map<class_decl>(type_name,
12531 return lookup_type_in_map<union_decl>(type_name,
12566 union_decl_sptr result = lookup_type_in_map<union_decl>(loc, m);
12599 return lookup_type_in_map<enum_type_decl>(type_name,
12638 return lookup_type_in_map<typedef_decl>(type_name,
12674qualified_type_def_sptr
12679 return lookup_type_in_map<qualified_type_def>(type_name,
12698qualified_type_def_sptr
12725 return lookup_type_in_map<pointer_type_def>(type_name,
12787 return lookup_type_in_map<reference_type_def>(type_name,
12806 bool lvalue_reference,
12831 return lookup_type_in_map<array_type_def>(type_name,
12851 return lookup_type_in_map<function_type>(type_name,
12897const type_base_sptr
12901 type_base_sptr result;
12940const type_base_sptr
12964const type_base_sptr
12968 list<string> comps;
12981const decl_base_sptr
12985 list<string> comps;
13001template<
typename NodeKind>
13003get_node_name(shared_ptr<NodeKind> node);
13013{
return node->get_name();}
13022get_node_name(type_base_sptr node)
13033{
return node->get_name();}
13042template<
typename NodeKind>
13043static decl_base_sptr
13044convert_node_to_decl(shared_ptr<NodeKind> node);
13057template<
typename NodeKind>
13059lookup_node_in_scope(
const list<string>& fqn,
13063 shared_ptr<NodeKind> node;
13064 bool it_is_last =
false;
13067 for (list<string>::const_iterator c = fqn.begin(); c != fqn.end(); ++c)
13070 it_is_last = iterator_is_last(fqn, c);
13071 for (scope_decl::declarations::const_iterator m =
13072 cur_scope->get_member_decls().begin();
13073 m != cur_scope->get_member_decls().end();
13079 scope = dynamic_pointer_cast<scope_decl>(*m);
13080 if (scope && scope->get_name() == *c)
13089 node = dynamic_pointer_cast<NodeKind>(*m);
13090 if (node && get_node_name(node) == *c)
13093 dynamic_pointer_cast<class_decl>(node))
13094 if (cl->get_is_declaration_only()
13095 && !cl->get_definition_of_declaration())
13097 resulting_decl = node;
13102 if (!new_scope && !resulting_decl)
13103 return decl_base_sptr();
13104 cur_scope = new_scope;
13107 return resulting_decl;
13128const type_base_sptr
13131{
return is_type(lookup_node_in_scope<type_base>(comps, scope));}
13155static const type_base_sptr
13157 const vector<scope_decl*>& access_path,
13160 vector<scope_decl*> a = access_path;
13161 type_base_sptr result;
13166 first_scope = a.back();
13174 for (scope_decl::declarations::const_iterator i =
13178 if (
is_type(*i) && (*i)->get_name() == n)
13186 first_scope = a.back();
13187 interned_string scope_name, cur_scope_name = first_scope->
get_name();
13188 for (scope_decl::scopes::const_iterator i =
13193 scope_name = (*i)->get_name();
13194 if (scope_name == cur_scope_name)
13220static const type_base_sptr
13222 const scope_decl* scope)
13225 return type_base_sptr();
13229 vector<scope_decl*> access_path;
13230 for (scope_decl* s = type_decl->get_scope(); s != 0; s = s->get_scope())
13232 access_path.push_back(s);
13258const type_base_sptr
13273const decl_base_sptr
13276{
return is_var_decl(lookup_node_in_scope<var_decl>(comps, skope));}
13289template<
typename NodeKind>
13291lookup_node_in_translation_unit(
const list<string>& fqn,
13309{
return is_type(lookup_node_in_translation_unit<type_base>(fqn, tu));}
13329{
return is_class_type(lookup_node_in_translation_unit<class_decl>(fqn, tu));}
13342lookup_basic_type_through_translation_units(
const interned_string& type_name,
13343 const corpus& abi_corpus)
13347 for (translation_units::const_iterator tu =
13367static union_decl_sptr
13368lookup_union_type_through_translation_units(
const interned_string& type_name,
13369 const corpus & abi_corpus)
13371 union_decl_sptr result;
13373 for (translation_units::const_iterator tu =
13374 abi_corpus.get_translation_units().begin();
13375 tu != abi_corpus.get_translation_units().end();
13394lookup_enum_type_through_translation_units(
const interned_string& type_name,
13395 const corpus & abi_corpus)
13399 for (translation_units::const_iterator tu =
13400 abi_corpus.get_translation_units().begin();
13401 tu != abi_corpus.get_translation_units().end();
13418lookup_typedef_type_through_translation_units(
const interned_string& type_name,
13419 const corpus & abi_corpus)
13423 for (translation_units::const_iterator tu =
13424 abi_corpus.get_translation_units().begin();
13425 tu != abi_corpus.get_translation_units().end();
13442static qualified_type_def_sptr
13443lookup_qualified_type_through_translation_units(
const interned_string& t_name,
13444 const corpus & abi_corpus)
13446 qualified_type_def_sptr result;
13448 for (translation_units::const_iterator tu =
13449 abi_corpus.get_translation_units().begin();
13450 tu != abi_corpus.get_translation_units().end();
13468lookup_pointer_type_through_translation_units(
const interned_string& type_name,
13469 const corpus & abi_corpus)
13473 for (translation_units::const_iterator tu =
13474 abi_corpus.get_translation_units().begin();
13475 tu != abi_corpus.get_translation_units().end();
13493lookup_reference_type_through_translation_units(
const interned_string& t_name,
13494 const corpus & abi_corpus)
13498 for (translation_units::const_iterator tu =
13499 abi_corpus.get_translation_units().begin();
13500 tu != abi_corpus.get_translation_units().end();
13518lookup_array_type_through_translation_units(
const interned_string& type_name,
13519 const corpus & abi_corpus)
13523 for (translation_units::const_iterator tu =
13524 abi_corpus.get_translation_units().begin();
13525 tu != abi_corpus.get_translation_units().end();
13543lookup_function_type_through_translation_units(
const interned_string& type_name,
13544 const corpus & abi_corpus)
13548 for (translation_units::const_iterator tu =
13549 abi_corpus.get_translation_units().begin();
13550 tu != abi_corpus.get_translation_units().end();
13568 const corpus& abi_corpus)
13570 type_base_sptr result;
13572 for (translation_units::const_iterator tu =
13593 const string& tu_path,
13596 string_tu_map_type::const_iterator i = corp.priv_->path_tu_map.find(tu_path);
13597 if (i == corp.priv_->path_tu_map.end())
13598 return type_base_sptr();
13627 for (translation_units::const_iterator i =
13673 result = lookup_type_in_map<type_decl>(qualified_name, m);
13675 result = lookup_basic_type_through_translation_units(qualified_name, corp);
13695 result = lookup_type_in_map<type_decl>(loc, m);
13786 class_decl_sptr result = lookup_type_in_map<class_decl>(qualified_name, m);
13804 return lookup_types_in_map(qualified_name, m);
13830 for (
auto type : *v)
13832 type_base_sptr t(type);
13834 if (c->get_is_declaration_only()
13835 && !c->get_definition_of_declaration())
13836 result.push_back(type);
13839 return !result.empty();
13855 return lookup_types_in_map(qualified_name, m);
13936 union_decl_sptr result = lookup_type_in_map<union_decl>(type_name, m);
13938 result = lookup_union_type_through_translation_units(type_name, corp);
14017 lookup_type_in_map<enum_type_decl>(qualified_name, m);
14019 result = lookup_enum_type_through_translation_units(qualified_name, corp);
14037 return lookup_types_in_map(qualified_name, m);
14142 lookup_type_in_map<typedef_decl>(qualified_name, m);
14144 result = lookup_typedef_type_through_translation_units(qualified_name,
14239qualified_type_def_sptr
14254qualified_type_def_sptr
14260 qualified_type_def_sptr result =
14261 lookup_type_in_map<qualified_type_def>(qualified_name, m);
14264 result = lookup_qualified_type_through_translation_units(qualified_name,
14306 lookup_type_in_map<pointer_type_def>(qualified_name, m);
14308 result = lookup_pointer_type_through_translation_units(qualified_name,
14356 lookup_type_in_map<reference_type_def>(qualified_name, m);
14358 result = lookup_reference_type_through_translation_units(qualified_name,
14405 lookup_type_in_map<array_type_def>(qualified_name, m);
14407 result = lookup_array_type_through_translation_units(qualified_name, corp);
14476 lookup_type_in_map<function_type>(qualified_name, m);
14478 result = lookup_function_type_through_translation_units(qualified_name,
14501 type_base_sptr result;
14534 type_base_sptr result;
14582 return type_base_sptr();
14599template<
typename TypeKind>
14603 bool use_type_name_as_key =
true)
14607 if (use_type_name_as_key)
14609 else if (
location l = type->get_location())
14611 string str = l.expand();
14612 s = type->get_environment().intern(str);
14615 istring_type_base_wptrs_map_type::iterator i = types_map.find(s);
14616 bool result =
false;
14618 if (i == types_map.end())
14620 types_map[s].push_back(type);
14624 i->second.push_back(type);
14645 bool use_type_name_as_key)
14649 bool update_qname_map =
true;
14650 if (type->get_is_declaration_only())
14656 is_class_type(class_type->get_definition_of_declaration()))
14660 if (!update_qname_map)
14664 if (use_type_name_as_key)
14666 string qname = type->get_qualified_name();
14667 s = type->get_environment().intern(qname);
14669 else if (
location l = type->get_location())
14671 string str = l.expand();
14672 s = type->get_environment().intern(str);
14675 bool result =
false;
14676 istring_type_base_wptrs_map_type::iterator i = map.find(s);
14677 if (i == map.end())
14679 map[s].push_back(type);
14683 i->second.push_back(type);
14709 bool result =
false;
14711 istring_type_base_wptrs_map_type::iterator i = types_map.find(s);
14712 if (i == types_map.end())
14714 types_map[s].push_back(type);
14718 i->second.push_back(type);
14738 maybe_update_types_lookup_map<type_decl>
14741 if (
corpus *type_corpus = basic_type->get_corpus())
14743 maybe_update_types_lookup_map<type_decl>
14745 type_corpus->priv_->get_types().basic_types());
14747 maybe_update_types_lookup_map<type_decl>
14749 type_corpus->get_type_per_loc_map().basic_types(),
14754 maybe_update_types_lookup_map<type_decl>
14756 group->priv_->get_types().basic_types());
14758 maybe_update_types_lookup_map<type_decl>
14760 group->get_type_per_loc_map().basic_types(),
14785 if (
corpus *type_corpus = class_type->get_corpus())
14789 type_corpus->priv_->get_types().class_types());
14793 type_corpus->get_type_per_loc_map().class_types(),
14800 group->priv_->get_types().class_types());
14804 group->get_type_per_loc_map().class_types(),
14825 maybe_update_types_lookup_map<union_decl>
14828 if (
corpus *type_corpus = union_type->get_corpus())
14830 maybe_update_types_lookup_map<union_decl>
14832 type_corpus->priv_->get_types().union_types());
14834 maybe_update_types_lookup_map<union_decl>
14836 type_corpus->get_type_per_loc_map().union_types(),
14841 maybe_update_types_lookup_map<union_decl>
14843 group->priv_->get_types().union_types());
14845 maybe_update_types_lookup_map<union_decl>
14847 group->get_type_per_loc_map().union_types(),
14868 maybe_update_types_lookup_map<enum_type_decl>
14871 if (
corpus *type_corpus = enum_type->get_corpus())
14873 maybe_update_types_lookup_map<enum_type_decl>
14875 type_corpus->priv_->get_types().enum_types());
14877 maybe_update_types_lookup_map<enum_type_decl>
14879 type_corpus->get_type_per_loc_map().enum_types(),
14884 maybe_update_types_lookup_map<enum_type_decl>
14886 group->priv_->get_types().enum_types());
14888 maybe_update_types_lookup_map<enum_type_decl>
14890 group->get_type_per_loc_map().enum_types(),
14912 maybe_update_types_lookup_map<typedef_decl>
14915 if (
corpus *type_corpus = typedef_type->get_corpus())
14917 maybe_update_types_lookup_map<typedef_decl>
14919 type_corpus->priv_->get_types().typedef_types());
14921 maybe_update_types_lookup_map<typedef_decl>
14923 type_corpus->get_type_per_loc_map().typedef_types(),
14928 maybe_update_types_lookup_map<typedef_decl>
14930 group->priv_->get_types().typedef_types());
14932 maybe_update_types_lookup_map<typedef_decl>
14934 group->get_type_per_loc_map().typedef_types(),
14955 maybe_update_types_lookup_map<qualified_type_def>
14958 if (
corpus *type_corpus = qualified_type->get_corpus())
14960 maybe_update_types_lookup_map<qualified_type_def>
14962 type_corpus->priv_->get_types().qualified_types());
14966 maybe_update_types_lookup_map<qualified_type_def>
14968 group->priv_->get_types().qualified_types());
14988 maybe_update_types_lookup_map<pointer_type_def>
14991 if (
corpus *type_corpus = pointer_type->get_corpus())
14993 maybe_update_types_lookup_map<pointer_type_def>
14995 type_corpus->priv_->get_types().pointer_types());
14999 maybe_update_types_lookup_map<pointer_type_def>
15001 group->priv_->get_types().pointer_types());
15021 maybe_update_types_lookup_map<ptr_to_mbr_type>
15024 if (
corpus *type_corpus = ptr_to_member->get_corpus())
15026 maybe_update_types_lookup_map<ptr_to_mbr_type>
15028 type_corpus->priv_->get_types().ptr_to_mbr_types());
15032 maybe_update_types_lookup_map<ptr_to_mbr_type>
15034 group->priv_->get_types().ptr_to_mbr_types());
15054 maybe_update_types_lookup_map<reference_type_def>
15057 if (
corpus *type_corpus = reference_type->get_corpus())
15059 maybe_update_types_lookup_map<reference_type_def>
15061 type_corpus->priv_->get_types().reference_types());
15065 maybe_update_types_lookup_map<reference_type_def>
15067 group->priv_->get_types().reference_types());
15087 maybe_update_types_lookup_map<array_type_def>
15090 if (
corpus *type_corpus = array_type->get_corpus())
15092 maybe_update_types_lookup_map<array_type_def>
15094 type_corpus->priv_->get_types().array_types());
15096 maybe_update_types_lookup_map<array_type_def>
15098 type_corpus->get_type_per_loc_map().array_types(),
15103 maybe_update_types_lookup_map<array_type_def>
15105 group->priv_->get_types().array_types());
15107 maybe_update_types_lookup_map<array_type_def>
15109 group->get_type_per_loc_map().array_types(),
15131 maybe_update_types_lookup_map<array_type_def::subrange_type>
15134 if (
corpus *type_corpus = subrange_type->get_corpus())
15136 maybe_update_types_lookup_map<array_type_def::subrange_type>
15138 type_corpus->priv_->get_types().subrange_types());
15140 maybe_update_types_lookup_map<array_type_def::subrange_type>
15142 type_corpus->get_type_per_loc_map().subrange_types(),
15145 if (
corpus *group = subrange_type->get_corpus())
15147 maybe_update_types_lookup_map<array_type_def::subrange_type>
15149 group->priv_->get_types().subrange_types());
15151 maybe_update_types_lookup_map<array_type_def::subrange_type>
15153 group->get_type_per_loc_map().subrange_types(),
15178 if (
corpus *type_corpus = fn_type->get_corpus())
15182 type_corpus->priv_->get_types().function_types());
15184 if (
corpus *group = fn_type->get_corpus())
15188 group->priv_->get_types().function_types());
15281 type_base_sptr result;
15289 type_base_sptr underlying_type =
15292 if (underlying_type)
15295 qual->get_cv_quals(),
15296 qual->get_location()));
15301 type_base_sptr pointed_to_type =
15304 if (pointed_to_type)
15307 p->get_size_in_bits(),
15308 p->get_alignment_in_bits(),
15309 p->get_location()));
15314 type_base_sptr pointed_to_type =
15316 if (pointed_to_type)
15320 r->get_size_in_bits(),
15321 r->get_alignment_in_bits(),
15322 r->get_location()));
15336 tu.priv_->synthesized_types_.push_back(result);
15369 type_base_sptr result_return_type;
15374 if (!result_return_type)
15378 type_base_sptr parm_type;
15380 for (function_type::parameters::const_iterator i =
15385 type_base_sptr t = (*i)->get_type();
15392 (*i)->get_location(),
15393 (*i)->get_variadic_marker(),
15394 (*i)->get_is_artificial()));
15395 parms.push_back(parm);
15398 class_or_union_sptr class_type;
15410 result_fn_type.reset(
new method_type(result_return_type,
15422 tu.priv_->synthesized_types_.push_back(result_fn_type);
15426 return result_fn_type;
15437 if (mangled_name.empty())
15442 char * str = abi::__cxa_demangle(mangled_name.c_str(),
15443 NULL, &l, &status);
15444 string demangled_name = mangled_name;
15448 demangled_name = str;
15452 return demangled_name;
15477global_scope::~global_scope()
15498types_defined_same_linux_kernel_corpus_public(
const type_base& t1,
15499 const type_base& t2)
15501 const corpus *t1_corpus = t1.get_corpus(), *t2_corpus = t2.get_corpus();
15502 string t1_file_path, t2_file_path;
15506 if (!(t1_corpus && t2_corpus
15507 && t1_corpus == t2_corpus
15508 && (t1_corpus->get_origin() & corpus::LINUX_KERNEL_BINARY_ORIGIN)
15513 class_or_union *c1 = 0, *c2 = 0;
15519 if ((c1 && c1->get_is_anonymous() && !c1->get_naming_typedef())
15520 || (c2 && c2->get_is_anonymous() && !c2->get_naming_typedef()))
15527 && c1->get_is_anonymous() && c1->get_naming_typedef()
15528 && c2->get_is_anonymous() && c2->get_naming_typedef())
15529 if (c1->get_naming_typedef()->get_name()
15530 != c2->get_naming_typedef()->get_name())
15536 if (e1->get_is_anonymous() || e2->get_is_anonymous())
15546 if (c1->get_is_declaration_only() != c2->get_is_declaration_only())
15548 if (c1->get_environment().decl_only_class_equals_definition())
15558 if (t1.get_size_in_bits() != t2.get_size_in_bits())
15567 l = c1->get_location();
15569 l =
dynamic_cast<const decl_base&
>(t1).
get_location();
15571 unsigned line = 0, col = 0;
15573 l.
expand(t1_file_path, line, col);
15575 l = c2->get_location();
15577 l =
dynamic_cast<const decl_base&
>(t2).
get_location();
15579 l.
expand(t2_file_path, line, col);
15582 if (t1_file_path.empty() || t2_file_path.empty())
15585 if (t1_file_path == t2_file_path)
15621compare_types_during_canonicalization(
const type_base& canonical_type,
15622 const type_base& candidate_type)
15624#ifdef WITH_DEBUG_TYPE_CANONICALIZATION
15625 const environment& env = canonical_type.get_environment();
15626 if (env.debug_type_canonicalization_is_on())
15628 bool canonical_equality =
false, structural_equality =
false;
15629 env.priv_->allow_type_comparison_results_caching(
false);
15630 env.priv_->use_canonical_type_comparison_ =
false;
15631 structural_equality = canonical_type == candidate_type;
15632 env.priv_->use_canonical_type_comparison_ =
true;
15633 canonical_equality = canonical_type == candidate_type;
15634 env.priv_->allow_type_comparison_results_caching(
true);
15635 if (canonical_equality != structural_equality)
15637 std::cerr <<
"structural & canonical equality different for type: "
15638 << canonical_type.get_pretty_representation(
true,
true)
15642 return structural_equality;
15645 return canonical_type == candidate_type;
15669compare_canonical_type_against_candidate(
const type_base& canonical_type,
15670 const type_base& candidate_type)
15672 environment& env =
const_cast<environment&
>(canonical_type.get_environment());
15690 bool saved_decl_only_class_equals_definition =
15691 env.decl_only_class_equals_definition();
15695 env.decl_only_class_equals_definition(
false);
15696 env.priv_->allow_type_comparison_results_caching(
true);
15697 bool equal = (types_defined_same_linux_kernel_corpus_public(canonical_type,
15699 || compare_types_during_canonicalization(canonical_type,
15704 env.priv_->clear_type_comparison_results_cache();
15705 env.priv_->allow_type_comparison_results_caching(
false);
15706 env.decl_only_class_equals_definition
15707 (saved_decl_only_class_equals_definition);
15732compare_canonical_type_against_candidate(
const type_base* canonical_type,
15733 const type_base* candidate_type)
15735 return compare_canonical_type_against_candidate(*canonical_type,
15760compare_canonical_type_against_candidate(
const type_base_sptr& canonical_type,
15761 const type_base_sptr& candidate_type)
15763 return compare_canonical_type_against_candidate(canonical_type.get(),
15764 candidate_type.get());
15784static type_base_sptr
15785candidate_matches_a_canonical_type_hash(
const vector<type_base_sptr>& cncls,
15788 if (type.get_corpus()
15789 && type.get_corpus()->get_origin() == corpus::NATIVE_XML_ORIGIN
15798 for (
const auto& c : cncls)
15804 if (compare_canonical_type_against_candidate(*c, type))
15808 for (
const auto& c : cncls)
15813 if (compare_canonical_type_against_candidate(*c, type))
15863type_base::get_canonical_type_for(type_base_sptr t)
15872 return type_base_sptr();
15878 bool decl_only_class_equals_definition =
15891 if (decl_only_class_equals_definition)
15894 return type_base_sptr();
15897 if (t->get_canonical_type())
15898 return t->get_canonical_type();
15919 string repr = t->get_cached_pretty_representation(
true);
15924 type_base_sptr canonical_type_present_in_corpus;
15928 type_base_sptr result;
15929 environment::canonical_types_map_type::iterator i = types.find(repr);
15931 if (i == types.end())
15933 vector<type_base_sptr> v;
15940 vector<type_base_sptr> &v = i->second;
15945 result = candidate_matches_a_canonical_type_hash(v, *t);
15953 for (vector<type_base_sptr>::const_reverse_iterator it = v.rbegin();
15954 !result && it != v.rend();
15957 bool equal = compare_canonical_type_against_candidate(*it, t);
15964#ifdef WITH_DEBUG_SELF_COMPARISON
15965 if (env.self_comparison_debug_is_on())
15969 corpus_sptr corp1, corp2;
15970 env.get_self_comparison_debug_inputs(corp1, corp2);
15972 && corp1->get_origin() != corp2->get_origin()
15973 && corp2->get_origin() & corpus::NATIVE_XML_ORIGIN)
15984 check_canonical_type_from_abixml_during_self_comp(t,
15990 uintptr_t should_have_canonical_type = 0;
15991 string type_id = env.get_type_id_from_type(t.get());
15992 if (type_id.empty())
15993 type_id =
"type-id-<not-found>";
15995 should_have_canonical_type =
15996 env.get_canonical_type_from_type_id(type_id.c_str());
15997 std::cerr <<
"error: wrong canonical type for '"
16006 <<
"'. Should have had canonical type: "
16008 << should_have_canonical_type
16015 uintptr_t ptr_val =
reinterpret_cast<uintptr_t
>(t.get());
16016 string type_id = env.get_type_id_from_pointer(ptr_val);
16017 if (type_id.empty())
16018 type_id =
"type-id-<not-found>";
16035 std::cerr <<
"error: wrong induced canonical type for '"
16037 <<
"' from second corpus"
16038 <<
", ptr: " << std::hex << t.get()
16039 <<
" type-id: " << type_id
16041 << *t->hash_value()
16051 if (t_hash != result_hash)
16053 std::cerr <<
"error: type hash mismatch"
16054 <<
" between type: '"
16060 << *t->hash_value()
16061 <<
" and its computed canonical type @"
16066 << *result->hash_value()
16081 t->priv_->canonical_type_index = v.size();
16110maybe_adjust_canonical_type(
const type_base_sptr& canonical,
16111 const type_base_sptr& type)
16113 if (type->get_naked_canonical_type())
16121 if (canonical_class
16122 && canonical_class.get() != cl.get())
16126 for (class_decl::member_functions::const_iterator i =
16127 cl->get_member_functions().begin();
16128 i != cl->get_member_functions().end();
16130 if ((*i)->get_symbol())
16133 find_member_function((*i)->get_linkage_name()))
16144 && canonical_class->get_corpus()
16145 && cl->get_corpus()
16146 && (cl->get_corpus() == canonical_class->get_corpus()))
16160 for (
const auto& data_member : cl->get_data_members())
16167 const auto& canonical_data_member =
16168 canonical_class->find_data_member(data_member->get_name());
16169 if (!canonical_data_member)
16177 && canonical_class->get_corpus()
16178 && cl->get_corpus()
16179 && canonical_class->get_corpus() == cl->get_corpus())
16185 if (!canonical_data_member->get_symbol())
16186 canonical_data_member->set_symbol(sym);
16202 canonical_class = cl;
16205 if (canonical_class)
16207 if (
auto abi_corpus = canonical_class->get_corpus())
16209 for (
auto& fn : canonical_class->get_member_functions())
16213 if (sym->is_defined() && sym->is_public())
16215 fn->set_is_in_public_symbol_table(
true);
16216 auto b = abi_corpus->get_exported_decls_builder();
16217 b->maybe_add_fn_to_exported_fns(fn.get());
16219 else if (!sym->is_defined())
16220 abi_corpus->get_undefined_functions().insert(fn.get());
16232 if (type->get_is_artificial() != canonical->get_is_artificial())
16233 canonical->set_is_artificial(
false);
16263 if (t->get_canonical_type())
16264 return t->get_canonical_type();
16266 if (do_log && show_stats)
16267 std::cerr <<
"Canonicalization of type '"
16268 << t->get_pretty_representation(
true,
true)
16269 <<
"/@#" << std::hex << t.get() <<
": ";
16273 if (do_log && show_stats)
16275 type_base_sptr canonical = type_base::get_canonical_type_for(t);
16277 if (do_log && show_stats)
16280 if (do_log && show_stats)
16281 std::cerr << tmr <<
"\n";
16283 maybe_adjust_canonical_type(canonical, t);
16285 t->priv_->canonical_type = canonical;
16286 t->priv_->naked_canonical_type = canonical.get();
16289 if (!t->priv_->canonical_type_index)
16290 t->priv_->canonical_type_index = canonical->priv_->canonical_type_index;
16293 if (type_base_sptr d =
is_type(cl->get_earlier_declaration()))
16294 if ((canonical = d->get_canonical_type()))
16296 d->priv_->canonical_type = canonical;
16297 d->priv_->naked_canonical_type = canonical.get();
16314 if (type_base_sptr c =
is_type(scope)->get_canonical_type())
16329 t->on_canonical_type_set();
16340 priv_->definition_of_declaration_ = d;
16342 if (type_base_sptr canonical_type =
is_type(d)->get_canonical_type())
16343 t->priv_->canonical_type = canonical_type;
16345 priv_->naked_definition_of_declaration_ =
const_cast<decl_base*
>(d.get());
16355 priv_(new
priv(s, a))
16369 return do_hash(
this);
16381{
return priv_->canonical_type.lock();}
16397{
return priv_->naked_canonical_type;}
16424 if (priv_->internal_cached_repr_.
empty())
16429 return priv_->internal_cached_repr_;
16432 if (priv_->cached_repr_.
empty())
16438 return priv_->cached_repr_;
16476{
return equals(*
this, other, 0);}
16493{priv_->size_in_bits = s;}
16500{
return priv_->size_in_bits;}
16507{priv_->alignment_in_bits = a;}
16514{
return priv_->alignment_in_bits;}
16530 v.visit_begin(
this);
16531 bool result = v.visit_end(
this);
16537type_base::~type_base()
16556 static_cast<unsigned>(r));
16571 static_cast<unsigned>(r));
16628parse_real_type_modifier(
const string& word,
16631 if (word ==
"signed")
16633 else if (word ==
"unsigned")
16635 else if (word ==
"short")
16637 else if (word ==
"long")
16639 else if (word ==
"long long")
16657parse_base_real_type(
const string& type_name,
16660 if (type_name ==
"int")
16662 else if (type_name ==
"char")
16664 else if (type_name ==
"bool" || type_name ==
"_Bool")
16666 else if (type_name ==
"double")
16668 else if (type_name ==
"float")
16670 else if (type_name ==
"char16_t")
16672 else if (type_name ==
"char32_t")
16674 else if (type_name ==
"wchar_t")
16676 else if (type_name ==
"__ARRAY_SIZE_TYPE__")
16678 else if (type_name ==
"sizetype")
16679 base = real_type::SIZE_BASE_TYPE;
16680 else if (type_name ==
"ssizetype")
16681 base = real_type::SSIZE_BASE_TYPE;
16682 else if (type_name ==
"bitsizetype")
16683 base = real_type::BIT_SIZE_BASE_TYPE;
16684 else if (type_name ==
"sbitsizetype")
16685 base = real_type::SBIT_SIZE_BASE_TYPE;
16709 string input = type_name;
16710 string::size_type len = input.length();
16711 string::size_type cur_pos = 0, prev_pos = 0;
16712 string cur_word, prev_word;
16715 while (cur_pos < len)
16717 if (cur_pos < len && isspace(input[cur_pos]))
16720 while (cur_pos < len && isspace(input[cur_pos]));
16722 prev_pos = cur_pos;
16723 cur_pos = input.find(
' ', prev_pos);
16724 prev_word = cur_word;
16725 cur_word = input.substr(prev_pos, cur_pos - prev_pos);
16728 && cur_word ==
"long"
16729 && prev_word !=
"long")
16731 if (cur_pos < len && isspace(input[cur_pos]))
16734 while (cur_pos < len && isspace(input[cur_pos]));
16735 prev_pos = cur_pos;
16737 cur_pos = input.find(
' ', prev_pos);
16738 string saved_prev_word = prev_word;
16739 prev_word = cur_word;
16740 cur_word = input.substr(prev_pos, cur_pos - prev_pos);
16741 if (cur_word ==
"long")
16742 cur_word =
"long long";
16745 cur_pos = prev_pos;
16746 cur_word = prev_word;
16747 prev_word = saved_prev_word;
16751 if (!parse_real_type_modifier(cur_word, modifiers))
16753 if (!parse_base_real_type(cur_word, base))
16784 real_type int_type(base_type, modifiers);
16791 : base_(INT_BASE_TYPE),
16792 modifiers_(NO_MODIFIER)
16801 : base_(b), modifiers_(m)
16809 : base_(INT_BASE_TYPE),
16810 modifiers_(NO_MODIFIER)
16828{
return modifiers_;}
16845{
return base_ == other.base_ && modifiers_ == other.modifiers_;}
16863 result +=
"signed ";
16865 result +=
"unsigned ";
16876 result +=
"short ";
16880 result +=
"long long ";
16891 result +=
"double";
16895 result +=
"char16_t";
16897 result +=
"char32_t";
16899 result +=
"wchar_t";
16901 result +=
"__ARRAY_SIZE_TYPE__";
16902 else if (base_ == SIZE_BASE_TYPE)
16903 result +=
"sizetype";
16904 else if (base_ == SSIZE_BASE_TYPE)
16905 result +=
"ssizetype";
16906 else if (base_ == BIT_SIZE_BASE_TYPE)
16907 result +=
"bitsizetype";
16908 else if (base_ == SBIT_SIZE_BASE_TYPE)
16909 result +=
"sbitsizetype";
16918real_type::operator string()
const
16919{
return to_string();}
16942 const string& name,
16943 size_t size_in_bits,
16944 size_t alignment_in_bits,
16946 const string& linkage_name,
16951 | ABSTRACT_TYPE_BASE
16952 | ABSTRACT_DECL_BASE),
16953 decl_base(env, name, locus, linkage_name, vis),
16954 type_base(env, size_in_bits, alignment_in_bits)
16960 real_type int_type(base_type, modifiers);
16965 string real_type_name = int_type;
17013 bool result =
false;
17044 return *
this == *other;
17072 return *
this == other;
17118 if (l.get() == r.get())
17146 bool internal)
const
17170 if (decl_base::priv_->internal_qualified_name_.
empty())
17171 decl_base::priv_->internal_qualified_name_ =
17172 env.
intern(get_internal_real_type_name(
this));
17173 return decl_base::priv_->internal_qualified_name_;
17177 decl_base::priv_->temporary_internal_qualified_name_ =
17178 env.
intern(get_internal_real_type_name(
this));
17179 return decl_base::priv_->temporary_internal_qualified_name_;
17205 bool qualified_name)
const
17209 return get_internal_real_type_name(
this);
17211 if (qualified_name)
17229 v.visit_begin(
this);
17230 bool result = v.visit_end(
this);
17236type_decl::~type_decl()
17256 const string& name,
17257 size_t size_in_bits,
17258 size_t alignment_in_bits,
17262 ABSTRACT_SCOPE_TYPE_DECL
17263 | ABSTRACT_TYPE_BASE
17264 | ABSTRACT_DECL_BASE),
17266 type_base(env, size_in_bits, alignment_in_bits),
17335 return *
this == *other;
17359 if (v.visit_begin(
this))
17362 for (scope_decl::declarations::const_iterator i =
17366 if (!(*i)->traverse(v))
17371 bool result = v.visit_end(
this);
17377scope_type_decl::~scope_type_decl()
17393 const string& name,
17404 | ABSTRACT_DECL_BASE
17405 | ABSTRACT_SCOPE_DECL),
17431 bool qualified_name)
const
17434 "namespace " + scope_decl::get_pretty_representation(internal,
17473 if (!ns->is_empty_or_has_empty_sub_namespaces())
17494 if (v.visit_begin(
this))
17497 scope_decl::declarations::const_iterator i;
17503 dynamic_pointer_cast<ir_traversable_base>(*i);
17505 if (!t->traverse (v))
17510 return v.visit_end(
this);
17513namespace_decl::~namespace_decl()
17522class qualified_type_def::priv
17533 weak_ptr<type_base> underlying_type_;
17536 : cv_quals_(CV_NONE)
17541 : cv_quals_(quals),
17542 underlying_type_(t)
17594qualified_type_def::qualified_type_def(type_base_sptr type,
17599 | ABSTRACT_TYPE_BASE
17600 | ABSTRACT_DECL_BASE),
17601 type_base(type->get_environment(), type->get_size_in_bits(),
17602 type->get_alignment_in_bits()),
17603 decl_base(type->get_environment(),
"", locus,
"",
17604 dynamic_pointer_cast<
decl_base>(type)->get_visibility()),
17605 priv_(new priv(quals, type))
17624 | ABSTRACT_TYPE_BASE
17625 | ABSTRACT_DECL_BASE),
17629 priv_(new priv(quals))
17666 s = ut->get_size_in_bits();
17695 bool result =
true;
17762 return *
this == *other;
17780 return *
this == *other;
17795 bool internal)
const
17823 if (priv_->temporary_internal_name_.empty())
17824 priv_->temporary_internal_name_ =
17826 return priv_->temporary_internal_name_;
17842 if (priv_->internal_name_.empty())
17843 priv_->internal_name_ =
17846 return priv_->internal_name_;
17875 if (v.visit_begin(
this))
17882 bool result = v.visit_end(
this);
17887qualified_type_def::~qualified_type_def()
17894{
return priv_->cv_quals_;}
17899{priv_->cv_quals_ = cv_quals;}
17913{
return priv_->underlying_type_.lock();}
17922 priv_->underlying_type_ = t;
17932 scope_decl::declarations::iterator i;
17933 if (s->find_iterator_for_member(
this, i))
17948operator==(
const qualified_type_def_sptr& l,
const qualified_type_def_sptr& r)
17950 if (l.get() == r.get())
17966operator!=(
const qualified_type_def_sptr& l,
const qualified_type_def_sptr& r)
17974 (
static_cast<unsigned>(lhs) |
static_cast<unsigned>(rhs));
17998 (
static_cast<unsigned>(lhs) &
static_cast<unsigned>(rhs));
18020 case qualified_type_def::CV_NONE:
18023 case qualified_type_def::CV_CONST:
18026 case qualified_type_def::CV_VOLATILE:
18029 case qualified_type_def::CV_RESTRICT:
18043struct pointer_type_def::priv
18050 priv(
const type_base_sptr& t)
18052 naked_pointed_to_type_(t.get())
18056 : naked_pointed_to_type_()
18081pointer_type_def::pointer_type_def(
const type_base_sptr& pointed_to,
18082 size_t size_in_bits,
18083 size_t align_in_bits,
18087 | ABSTRACT_TYPE_BASE
18088 | ABSTRACT_DECL_BASE),
18089 type_base(pointed_to->get_environment(), size_in_bits, align_in_bits),
18090 decl_base(pointed_to->get_environment(),
"", locus,
""),
18091 priv_(new priv(pointed_to))
18097 const environment& env = pointed_to->get_environment();
18098 decl_base_sptr pto = dynamic_pointer_cast<decl_base>(pointed_to);
18099 string name = (pto ? pto->get_name() : string(
"void")) +
"*";
18117pointer_type_def::pointer_type_def(
const environment& env,
size_t size_in_bits,
18118 size_t alignment_in_bits,
18122 | ABSTRACT_TYPE_BASE
18123 | ABSTRACT_DECL_BASE),
18124 type_base(env, size_in_bits, alignment_in_bits),
18129 string name = string(
"void") +
"*";
18154 priv_->pointed_to_type_ = t;
18155 priv_->naked_pointed_to_type_ = t.get();
18160 decl_base_sptr pto = dynamic_pointer_cast<decl_base>(t);
18161 string name = (pto ? pto->get_name() : string(
"void")) +
"*";
18193 bool result = p1 == p2;
18235 return *
this == *o;
18256const type_base_sptr
18258{
return priv_->pointed_to_type_.lock();}
18265{
return priv_->naked_pointed_to_type_;}
18303 if (priv_->internal_qualified_name_.empty())
18304 if (pointed_to_type)
18305 priv_->internal_qualified_name_ =
18306 pointer_declaration_name(
this,
18313 return priv_->internal_qualified_name_;
18321 if (pointed_to_type)
18322 if (priv_->temp_internal_qualified_name_.empty())
18323 priv_->temp_internal_qualified_name_ =
18324 pointer_declaration_name(
this,
18331 return priv_->temp_internal_qualified_name_;
18340 (pointer_declaration_name(
this,
18352 if (pointed_to_type)
18354 (pointer_declaration_name(
this,
18379 if (v.visit_begin(
this))
18387 bool result = v.visit_end(
this);
18392pointer_type_def::~pointer_type_def()
18409 if (l.get() == r.get())
18437struct reference_type_def::priv
18445 priv(
const type_base_sptr& t,
bool is_lvalue)
18447 is_lvalue_(is_lvalue)
18450 priv(
bool is_lvalue)
18451 : is_lvalue_(is_lvalue)
18480reference_type_def::reference_type_def(
const type_base_sptr pointed_to,
18482 size_t size_in_bits,
18483 size_t align_in_bits,
18487 | ABSTRACT_TYPE_BASE
18488 | ABSTRACT_DECL_BASE),
18489 type_base(pointed_to->get_environment(), size_in_bits, align_in_bits),
18490 decl_base(pointed_to->get_environment(),
"", locus,
""),
18491 priv_(new priv(pointed_to, lvalue))
18497 decl_base_sptr pto = dynamic_pointer_cast<decl_base>(pointed_to);
18502 name = string(pto->get_name()) +
"&";
18510 const environment& env = pointed_to->get_environment();
18534reference_type_def::reference_type_def(
const environment& env,
bool lvalue,
18535 size_t size_in_bits,
18536 size_t alignment_in_bits,
18540 | ABSTRACT_TYPE_BASE
18541 | ABSTRACT_DECL_BASE),
18542 type_base(env, size_in_bits, alignment_in_bits),
18544 priv_(new priv(lvalue))
18547 string name =
"void&";
18576 priv_->pointed_to_type_ = pointed_to_type;
18578 decl_base_sptr pto;
18580 {pto = dynamic_pointer_cast<decl_base>(pointed_to_type);}
18587 string name = string(pto->get_name()) +
"&";
18617 if (l.is_lvalue() != r.is_lvalue())
18623 type_base_sptr p1 = l.get_pointed_to_type(), p2 = r.get_pointed_to_type();
18624 bool result = p1 == p2;
18663 return *
this == *other;
18678 return *
this == *other;
18682reference_type_def::get_pointed_to_type()
const
18683{
return priv_->pointed_to_type_.lock();}
18686reference_type_def::is_lvalue()
const
18687{
return priv_->is_lvalue_;}
18717 type_base_sptr pointed_to_type = get_pointed_to_type();
18724 if (priv_->internal_qualified_name_.empty())
18725 if (pointed_to_type)
18726 priv_->internal_qualified_name_ =
18734 return priv_->internal_qualified_name_;
18742 if (pointed_to_type)
18743 if (priv_->temp_internal_qualified_name_.empty())
18744 priv_->temp_internal_qualified_name_ =
18752 return priv_->temp_internal_qualified_name_;
18772 if (pointed_to_type)
18802 bool qualified_name)
const
18806 (get_pointed_to_type()),
18830 if (v.visit_begin(
this))
18833 if (type_base_sptr t = get_pointed_to_type())
18838 bool result = v.visit_end(
this);
18843reference_type_def::~reference_type_def()
18860 if (l.get() == r.get())
18888struct ptr_to_mbr_type::priv
18892 type_base_sptr dm_type_;
18895 type_base_sptr containing_type_;
18902 priv(
const type_base_sptr& dm_type,
const type_base_sptr& containing_type)
18903 : dm_type_(dm_type),
18904 containing_type_(containing_type)
18926 const type_base_sptr& member_type,
18927 const type_base_sptr& containing_type,
18928 size_t size_in_bits,
18929 size_t alignment_in_bits,
18932 POINTER_TO_MEMBER_TYPE
18933 | ABSTRACT_TYPE_BASE
18934 | ABSTRACT_DECL_BASE),
18935 type_base(env, size_in_bits, alignment_in_bits),
18937 priv_(new priv(member_type, containing_type))
18974const type_base_sptr&
18976{
return priv_->dm_type_;}
18983const type_base_sptr&
18985{
return priv_->containing_type_;}
19015 return *
this == *other;
19030 return *
this == *other;
19042 bool internal)
const
19061 if (priv_->internal_qualified_name_.empty())
19062 priv_->internal_qualified_name_ =
19063 ptr_to_mbr_declaration_name(
this,
"",
19066 return priv_->internal_qualified_name_;
19070 priv_->temp_internal_qualified_name_ =
19071 ptr_to_mbr_declaration_name(
this,
"",
true, internal);
19072 return priv_->temp_internal_qualified_name_;
19078 (ptr_to_mbr_declaration_name(
this,
"",
true,
19100 if (v.visit_begin(
this))
19111 bool result = v.visit_end(
this);
19143 bool result =
true;
19145 if (!(l.decl_base::operator==(r)))
19184array_type_def::subrange_type::~subrange_type() =
default;
19193 : s_(UNSIGNED_SIGNEDNESS)
19202 : s_(UNSIGNED_SIGNEDNESS)
19211 : s_(SIGNED_SIGNEDNESS)
19219enum array_type_def::subrange_type::bound_value::signedness
19243{
return v_.unsigned_;}
19251 s_ = UNSIGNED_SIGNEDNESS;
19261 s_ = SIGNED_SIGNEDNESS;
19273 return s_ == v.s_ && v_.unsigned_ == v.v_.unsigned_;
19278struct array_type_def::subrange_type::priv
19288 : upper_bound_(ub), language_(l), infinite_(false)
19291 priv(bound_value lb, bound_value ub,
19293 : lower_bound_(lb), upper_bound_(ub),
19294 language_(l), infinite_(false)
19297 priv(bound_value lb, bound_value ub,
const type_base_sptr &u,
19299 : lower_bound_(lb), upper_bound_(ub), underlying_type_(u),
19300 language_(l), infinite_(false)
19319 const string& name,
19322 const type_base_sptr& utype,
19325 :
type_or_decl_base(env, SUBRANGE_TYPE | ABSTRACT_TYPE_BASE | ABSTRACT_DECL_BASE),
19332 priv_(new priv(lower_bound, upper_bound, utype, l))
19352 const string& name,
19357 :
type_or_decl_base(env, SUBRANGE_TYPE | ABSTRACT_TYPE_BASE | ABSTRACT_DECL_BASE),
19360 priv_(new priv(lower_bound, upper_bound, l))
19378 const string& name,
19382 :
type_or_decl_base(env, SUBRANGE_TYPE | ABSTRACT_TYPE_BASE | ABSTRACT_DECL_BASE),
19383 type_base(env, upper_bound.get_unsigned_value(), 0),
19385 priv_(new priv(upper_bound, l))
19410{
return priv_->underlying_type_.lock();}
19419 ABG_ASSERT(priv_->underlying_type_.expired());
19420 priv_->underlying_type_ = u;
19430{
return priv_->upper_bound_.get_signed_value();}
19437{
return priv_->lower_bound_.get_signed_value();}
19444{priv_->upper_bound_ = ub;}
19451{priv_->lower_bound_ = lb;}
19468 if (get_upper_bound() >= get_lower_bound())
19469 return get_upper_bound() - get_lower_bound() + 1;
19478{
return priv_->infinite_;}
19486{priv_->infinite_ = f;}
19493{
return priv_->language_;}
19501 std::ostringstream o;
19505 type_base_sptr underlying_type = get_underlying_type();
19506 if (underlying_type)
19508 o <<
"range "<< get_lower_bound() <<
" .. " << get_upper_bound();
19513 o <<
"[" << get_length() <<
"]";
19528 for (vector<subrange_sptr>::const_iterator i = v.begin();
19531 r += (*i)->as_string();
19560 bool result =
true;
19615 return *
this == *other;
19683 repr +=
"<anonymous range>";
19685 repr +=
"<range " +
get_name() +
">";
19686 repr += as_string();
19704 if (v.visit_begin(
this))
19707 if (type_base_sptr u = get_underlying_type())
19712 bool result = v.visit_end(
this);
19719struct array_type_def::priv
19726 priv(type_base_sptr t)
19730 priv(type_base_sptr t, subranges_type subs)
19731 : element_type_(t), subranges_(subs)
19751array_type_def::array_type_def(
const type_base_sptr e_type,
19752 const std::vector<subrange_sptr>& subs,
19756 | ABSTRACT_TYPE_BASE
19757 | ABSTRACT_DECL_BASE),
19760 priv_(new priv(e_type))
19784 const std::vector<subrange_sptr>& subs,
19788 | ABSTRACT_TYPE_BASE
19789 | ABSTRACT_DECL_BASE),
19817array_type_def::update_size()
19819 type_base_sptr e = priv_->element_type_.lock();
19822 size_t s = e->get_size_in_bits();
19826 s *= sub->get_length();
19834array_type_def::get_subrange_representation()
const
19860 bool qualified_name)
const
19862 return array_declaration_name(
this,
"",
19863 qualified_name, internal);
19888 std::vector<array_type_def::subrange_sptr > this_subs = l.
get_subranges();
19889 std::vector<array_type_def::subrange_sptr > other_subs = r.
get_subranges();
19891 bool result =
true;
19892 if (this_subs.size() != other_subs.size())
19901 std::vector<array_type_def::subrange_sptr >::const_iterator i,j;
19902 for (i = this_subs.begin(), j = other_subs.begin();
19903 i != this_subs.end() && j != other_subs.end();
19950 std::vector<array_type_def::subrange_sptr > this_subs = l->
get_subranges();
19951 std::vector<array_type_def::subrange_sptr > other_subs = r->
get_subranges();
19953 if (this_subs.size() != other_subs.size())
19956 std::vector<array_type_def::subrange_sptr >::const_iterator i,j;
19957 for (i = this_subs.begin(), j = other_subs.begin();
19958 i != this_subs.end() && j != other_subs.end();
19968 if (*first_element_type != *second_element_type)
20024 return *l_ptt == *r_ptt;
20046 const std::vector<subrange_sptr>& subranges =
20049 if (subranges.empty())
20050 return translation_unit::LANG_C11;
20051 return subranges.front()->get_language();
20070 return *
this == *other;
20076const type_base_sptr
20078{
return priv_->element_type_.lock();}
20094 priv_->element_type_ = element_type;
20105 for (
const auto &sub : subs)
20106 priv_->subranges_.push_back(sub);
20118 if (priv_->subranges_.empty())
20121 for (std::vector<shared_ptr<subrange_type> >::const_iterator i =
20122 priv_->subranges_.begin();
20123 i != priv_->subranges_.end();
20125 if ((*i)->is_non_finite())
20132array_type_def::get_dimension_count()
const
20133{
return priv_->subranges_.size();}
20164 if (priv_->internal_qualified_name_.empty())
20165 priv_->internal_qualified_name_ =
20166 array_declaration_name(
this,
"",
20169 return priv_->internal_qualified_name_;
20173 priv_->temp_internal_qualified_name_ =
20174 array_declaration_name(
this,
"",
20176 return priv_->temp_internal_qualified_name_;
20193 (array_declaration_name(
this,
"",
20217 if (v.visit_begin(
this))
20225 bool result = v.visit_end(
this);
20231array_type_def::get_location()
const
20235const std::vector<array_type_def::subrange_sptr>&
20237{
return priv_->subranges_;}
20239array_type_def::~array_type_def()
20246class enum_type_decl::priv
20248 type_base_sptr underlying_type_;
20257 priv(type_base_sptr underlying_type,
20259 : underlying_type_(underlying_type),
20277enum_type_decl::enum_type_decl(
const string& name,
20279 type_base_sptr underlying_type,
20281 const string& linkage_name,
20285 | ABSTRACT_TYPE_BASE
20286 | ABSTRACT_DECL_BASE),
20287 type_base(underlying_type->get_environment(),
20288 underlying_type->get_size_in_bits(),
20289 underlying_type->get_alignment_in_bits()),
20290 decl_base(underlying_type->get_environment(),
20291 name, locus, linkage_name, vis),
20292 priv_(new priv(underlying_type, enums))
20298 e->set_enum_type(
this);
20318{
return priv_->underlying_type_;}
20323{
return priv_->enumerators_;}
20328{
return priv_->enumerators_;}
20336 if (priv_->sorted_enumerators_.empty())
20341 priv_->sorted_enumerators_.push_back(*e);
20343 std::sort(priv_->sorted_enumerators_.begin(),
20344 priv_->sorted_enumerators_.end(),
20348 if (l.get_name() == r.get_name())
20349 return l.get_value() < r.get_value();
20350 return (l.get_name() < r.get_name());
20354 return priv_->sorted_enumerators_;
20369 enum_type_decl:: enumerator& result)
20372 if (e.get_value() == value)
20396 if (e.get_name() == name)
20424 bool qualified_name)
const
20426 string r =
"enum ";
20456 if (v.visit_begin(
this))
20464 bool result = v.visit_end(
this);
20486 bool result =
false;
20496 enum_type_decl::enumerators::const_iterator i, j;
20529 if (!(l.decl_base::operator==(r) && l.type_base::operator==(r)))
20534 if (!l.decl_base::operator==(r))
20536 if (!l.type_base::operator==(r))
20608is_enumerator_value_present_in_enum(
const enum_type_decl::enumerator &enr,
20609 const enum_type_decl &enom,
20610 vector<enum_type_decl::enumerator>& redundant_enrs)
20612 bool found =
false;
20613 for (
const auto &e : enom.get_enumerators())
20614 if (enumerators_values_are_equal(e, enr))
20618 redundant_enrs.push_back(e);
20636is_enumerator_value_redundant(
const enum_type_decl::enumerator &enr,
20637 const enum_type_decl &enom)
20639 vector<enum_type_decl::enumerator> redundant_enrs;
20640 if (is_enumerator_value_present_in_enum(enr, enom, redundant_enrs))
20642 if (!redundant_enrs.empty())
20670 bool result =
true;
20686 if (!!def1 != !!def2)
20716 if (!(def1->decl_base::operator==(*def2)
20717 && def1->type_base::operator==(*def2)))
20722 if (!def1->decl_base::operator==(*def2))
20724 if (!def1->type_base::operator==(*def2))
20802 && (!is_enumerator_value_redundant(e, *def2)
20803 || !is_enumerator_value_redundant(e, *def1)))
20817 && (!is_enumerator_value_redundant(e, *def1)
20818 || !is_enumerator_value_redundant(e, *def2)))
20860 return *
this == *other;
20875 if (l.get() == r.get())
20877 decl_base_sptr o = r;
20894class enum_type_decl::enumerator::priv
20898 string qualified_name_;
20909 priv(
const string& name,
20911 enum_type_decl* e = 0)
20923enum_type_decl::enumerator::~enumerator() =
default;
20934 : priv_(new priv(name, value))
20941 : priv_(new priv(other.
get_name(),
20943 other.get_enum_type()))
20968 bool names_equal =
true;
20970 return names_equal && (get_value() == other.
get_value());
20989{
return priv_->name_;}
21007 if (priv_->qualified_name_.empty())
21009 priv_->qualified_name_ =
21010 get_enum_type()->get_qualified_name(internal)
21014 return priv_->qualified_name_;
21030{
return priv_->value_;}
21044{
return priv_->enum_type_;}
21051{priv_->enum_type_ = e;}
21057struct typedef_decl::priv
21061 priv(
const type_base_sptr& t)
21062 : underlying_type_(t)
21077typedef_decl::typedef_decl(
const string& name,
21078 const type_base_sptr underlying_type,
21080 const string& linkage_name,
21084 | ABSTRACT_TYPE_BASE
21085 | ABSTRACT_DECL_BASE),
21090 name, locus, linkage_name, vis),
21091 priv_(new priv(underlying_type))
21107typedef_decl::typedef_decl(
const string& name,
21110 const string& mangled_name,
21114 | ABSTRACT_TYPE_BASE
21115 | ABSTRACT_DECL_BASE),
21118 decl_base(env, name, locus, mangled_name, vis),
21119 priv_(new priv(nullptr))
21194 bool result =
true;
21198 if (!(l.decl_base::operator==(r)))
21245 return *
this == *other;
21267 bool qualified_name)
const
21270 string result =
"typedef ";
21271 if (qualified_name)
21284{
return priv_->underlying_type_.lock();}
21292 priv_->underlying_type_ = t;
21306 bool internal)
const
21324 return decl_base::priv_->internal_qualified_name_;
21326 return decl_base::priv_->qualified_name_;
21345 if (v.visit_begin(
this))
21353 bool result = v.visit_end(
this);
21358typedef_decl::~typedef_decl()
21364struct var_decl::priv
21377 priv(type_base_sptr t,
21380 naked_type_(t.get()),
21388 set_type(type_base_sptr t)
21391 naked_type_ = t.get();
21408var_decl::var_decl(
const string& name,
21409 type_base_sptr type,
21411 const string& linkage_name,
21415 VAR_DECL | ABSTRACT_DECL_BASE),
21416 decl_base(type->get_environment(), name, locus, linkage_name, vis),
21417 priv_(new priv(type, bind))
21425const type_base_sptr
21427{
return priv_->type_.lock();}
21434{priv_->set_type(t);}
21445{
return priv_->naked_type_;}
21452{
return priv_->binding_;}
21459{priv_->binding_ = b;}
21475 priv_->symbol_ = sym;
21490{
return priv_->symbol_;}
21559 bool result =
true;
21572 else if (s0 && !textually_equals(*s0, *s1, k))
21578 bool symbols_are_equal = (s0 && s1 && result);
21580 if (symbols_are_equal)
21589 bool decl_bases_different = !l.decl_base::operator==(r);
21590 const_cast<var_decl&
>(l).set_qualified_name(n1);
21591 const_cast<var_decl&
>(r).set_qualified_name(n2);
21593 if (decl_bases_different)
21603 if (!l.decl_base::operator==(r))
21652 bool result =
true;
21688 return equals(*
this, *other, 0);
21703 if (priv_->id_.empty())
21708 sym_str = s->get_id_string();
21713 priv_->id_ = env.
intern(repr);
21714 if (!sym_str.empty())
21715 priv_->id_ = env.
intern(priv_->id_ +
"{" + sym_str +
"}");
21782 result =
"static ";
21786 bool member_of_anonymous_class =
false;
21789 member_of_anonymous_class =
true;
21798 if (member_of_anonymous_class || !qualified_name)
21805 string quals_repr =
21807 if (!quals_repr.empty())
21808 name = quals_repr +
" " + name;
21812 name = string(
" ") + name;
21814 result += array_declaration_name(t, name, qualified_name, internal);
21816 result += pointer_declaration_name(t, name, qualified_name, internal);
21818 result += pointer_declaration_name(t, name, qualified_name, internal);
21820 result += ptr_to_mbr_declaration_name(t, name,
21835 "",
true, internal);
21841 "",
true, internal);
21844 && (member_of_anonymous_class || !qualified_name))
21860 && (member_of_anonymous_class || !qualified_name))
21914 if (v.visit_begin(
this))
21917 if (type_base_sptr t =
get_type())
21921 return v.visit_end(
this);
21924var_decl::~var_decl()
21939 priv_->cached_name_.clear();
21940 priv_->internal_cached_name_.clear();
21960function_type::function_type(type_base_sptr return_type,
21962 size_t size_in_bits,
21963 size_t alignment_in_bits)
21965 FUNCTION_TYPE | ABSTRACT_TYPE_BASE),
21966 type_base(return_type->get_environment(), size_in_bits, alignment_in_bits),
21967 priv_(new
priv(parms, return_type))
21971 for (parameters::size_type i = 0, j = 1;
21972 i < priv_->parms_.size();
21975 if (i == 0 && priv_->parms_[i]->get_is_artificial())
21982 priv_->parms_[i]->set_index(j);
21993function_type::function_type(type_base_sptr return_type,
21994 size_t size_in_bits,
size_t alignment_in_bits)
21996 FUNCTION_TYPE | ABSTRACT_TYPE_BASE),
21997 type_base(return_type->get_environment(), size_in_bits, alignment_in_bits),
21998 priv_(new
priv(return_type))
22013 size_t size_in_bits,
22014 size_t alignment_in_bits)
22016 type_base(env, size_in_bits, alignment_in_bits),
22042{
return priv_->return_type_.lock();}
22050{priv_->return_type_ = t;}
22059{
return priv_->parms_;}
22102 for (parameters::size_type i = 0, j = 1;
22103 i < priv_->parms_.size();
22106 if (i == 0 && priv_->parms_[i]->get_is_artificial())
22113 priv_->parms_[i]->set_index(j);
22124 parm->set_index(priv_->parms_.size());
22125 priv_->parms_.push_back(parm);
22139 return (!priv_->parms_.empty()
22140 && priv_->parms_.back()->get_variadic_marker());
22172#define RETURN(value) CACHE_AND_RETURN_COMPARISON_RESULT(value)
22181 bool cached_result =
false;
22189 bool result =
true;
22191 if (!l.type_base::operator==(r))
22202 l_class = m->get_class_type().get();
22205 r_class = m->get_class_type().get();
22209 if (!!l_class != !!r_class)
22219 != r_class->get_qualified_name()))
22236 bool compare_result_types =
true;
22237 string l_rt_name = l_return_type_decl
22240 string r_rt_name = r_return_type_decl
22246 (r_class && (r_class->get_qualified_name() == r_rt_name)))
22247 compare_result_types =
false;
22249 if (compare_result_types)
22273 if (l_rt_name != r_rt_name)
22282 vector<shared_ptr<function_decl::parameter> >::const_iterator i,j;
22323function_type::parameters::const_iterator
22329 bool is_method =
dynamic_cast<const method_type*
>(
this);
22333 if (is_method && (*i)->get_is_artificial())
22345function_type::parameters::const_iterator
22372 if (priv_->internal_cached_name_.empty())
22373 priv_->internal_cached_name_ =
22375 return priv_->internal_cached_name_;
22379 priv_->temp_internal_cached_name_ =
22381 return priv_->temp_internal_cached_name_;
22388 if (priv_->cached_name_.empty())
22389 priv_->cached_name_ =
22391 return priv_->cached_name_;
22395 priv_->cached_name_ =
22397 return priv_->cached_name_;
22458 if (v.visit_begin(
this))
22461 bool keep_going =
true;
22465 if (!t->traverse(v))
22466 keep_going =
false;
22473 if (type_base_sptr parm_type = (*i)->get_type())
22474 if (!parm_type->traverse(v))
22479 return v.visit_end(
this);
22482function_type::~function_type()
22488struct method_type::priv
22490 class_or_union_wptr class_type_;
22518method_type::method_type (type_base_sptr return_type,
22519 class_or_union_sptr class_type,
22520 const std::vector<function_decl::parameter_sptr>& p,
22522 size_t size_in_bits,
22523 size_t alignment_in_bits)
22525 METHOD_TYPE | ABSTRACT_TYPE_BASE | FUNCTION_TYPE),
22526 type_base(class_type->get_environment(), size_in_bits, alignment_in_bits),
22527 function_type(return_type, p, size_in_bits, alignment_in_bits),
22558method_type::method_type(type_base_sptr return_type,
22559 type_base_sptr class_type,
22560 const std::vector<function_decl::parameter_sptr>& p,
22562 size_t size_in_bits,
22563 size_t alignment_in_bits)
22565 METHOD_TYPE | ABSTRACT_TYPE_BASE | FUNCTION_TYPE),
22566 type_base(class_type->get_environment(), size_in_bits, alignment_in_bits),
22567 function_type(return_type, p, size_in_bits, alignment_in_bits),
22583 size_t size_in_bits,
22584 size_t alignment_in_bits)
22586 type_base(env, size_in_bits, alignment_in_bits),
22606method_type::method_type(class_or_union_sptr class_type,
22608 size_t size_in_bits,
22609 size_t alignment_in_bits)
22611 METHOD_TYPE | ABSTRACT_TYPE_BASE | FUNCTION_TYPE),
22612 type_base(class_type->get_environment(), size_in_bits, alignment_in_bits),
22615 alignment_in_bits),
22642{
return class_or_union_sptr(priv_->class_type_);}
22655 priv_->class_type_ = t;
22683{priv_->is_const = f;}
22690{
return priv_->is_const;}
22706 if (!first_parm->get_is_artificial())
22709 type_base_sptr this_ptr_type = first_parm->get_type();
22717 type_base_sptr candidate_class_type =
22737struct function_decl::priv
22739 bool declared_inline_;
22747 : declared_inline_(false),
22753 bool declared_inline,
22755 : declared_inline_(declared_inline),
22758 naked_type_(t.get())
22762 bool declared_inline,
22765 : declared_inline_(declared_inline),
22768 naked_type_(t.get()),
22790 bool declared_inline,
22792 const string& mangled_name,
22796 FUNCTION_DECL | ABSTRACT_DECL_BASE),
22827 type_base_sptr fn_type,
22828 bool declared_inline,
22830 const string& linkage_name,
22834 FUNCTION_DECL | ABSTRACT_DECL_BASE),
22835 decl_base(fn_type->get_environment(), name, locus, linkage_name, vis),
22836 priv_(new priv(dynamic_pointer_cast<
function_type>(fn_type),
22858 bool qualified_name)
const
22863 string fn_prefix = mem_fn ?
"method ":
"function ";
22869 fn_prefix +=
"virtual ";
22871 decl_base_sptr return_type;
22878 return_type = mem_fn
22889 internal) +
" " + result;
22892 result = add_outer_pointer_to_fn_type_expr(p, result,
22897 result = add_outer_pointer_to_array_type_expr(p, result,
22904 return fn_prefix + result;
22934 result += mem_fn->
get_type()->get_class_type()->get_qualified_name()
22940 std::ostringstream fn_parms;
22941 stream_pretty_representation_of_fn_parms(*
get_type(),
22945 result += fn_parms.str();
22950 result +=
" const";
22961function_decl::parameters::const_iterator
22967 bool is_method =
dynamic_cast<const method_decl*
>(
this);
22980const shared_ptr<function_type>
22982{
return priv_->type_.lock();}
22997{
return priv_->naked_type_;}
23002 priv_->type_ = fn_type;
23003 priv_->naked_type_ = fn_type.get();
23020 priv_->symbol_ = sym;
23035{
return priv_->symbol_;}
23042{
return priv_->declared_inline_;}
23049{priv_->declared_inline_ = value;}
23052function_decl::get_binding()
const
23053{
return priv_->binding_;}
23056const shared_ptr<type_base>
23058{
return get_type()->get_return_type();}
23061const std::vector<shared_ptr<function_decl::parameter> >&
23063{
return get_type()->get_parameters();}
23070{
get_type()->append_parameter(parm);}
23078 for (std::vector<shared_ptr<parameter> >::const_iterator i = parms.begin();
23151 bool result =
true;
23155 if (t0 == t1 || *t0 == *t1)
23181 else if (s0 && s0 != s1)
23192 bool symbols_are_equal = (s0 && s1 && result);
23194 if (symbols_are_equal)
23206 bool decl_bases_different = !l.decl_base::operator==(r);
23213 if (decl_bases_different)
23223 if (!l.decl_base::operator==(r))
23235 if (l.get_binding() != r.get_binding())
23292 return equals(*
this, *o, 0);
23319 if (priv_->id_.empty())
23324 string virtual_member_suffix;
23334 virtual_member_suffix +=
"/o";
23337 if (s->has_aliases())
23344 priv_->id_ = env.
intern(s->get_id_string());
23346 if (!virtual_member_suffix.empty())
23347 priv_->id_ = env.
intern(priv_->id_ + virtual_member_suffix);
23391 if (v.visit_begin(
this))
23394 if (type_base_sptr t =
get_type())
23398 return v.visit_end(
this);
23420 if (l.get() == r.get())
23443struct function_decl::parameter::priv
23447 bool variadic_marker_;
23454 priv(type_base_sptr type,
23456 bool variadic_marker)
23459 variadic_marker_(variadic_marker)
23463function_decl::parameter::parameter(
const type_base_sptr type,
23465 const string& name,
23466 const location& loc,
23468 : type_or_decl_base(type->get_environment(),
23469 FUNCTION_PARAMETER_DECL | ABSTRACT_DECL_BASE),
23470 decl_base(type->get_environment(), name, loc),
23471 priv_(new priv(type, index, is_variadic))
23473 runtime_type_instance(
this);
23476function_decl::parameter::parameter(
const type_base_sptr type,
23478 const string& name,
23479 const location& loc,
23481 bool is_artificial)
23482 : type_or_decl_base(type->get_environment(),
23483 FUNCTION_PARAMETER_DECL | ABSTRACT_DECL_BASE),
23484 decl_base(type->get_environment(), name, loc),
23485 priv_(new priv(type, index, is_variadic))
23487 runtime_type_instance(
this);
23488 set_is_artificial(is_artificial);
23491function_decl::parameter::parameter(
const type_base_sptr type,
23492 const string& name,
23493 const location& loc,
23495 bool is_artificial)
23496 : type_or_decl_base(type->get_environment(),
23497 FUNCTION_PARAMETER_DECL | ABSTRACT_DECL_BASE),
23498 decl_base(type->get_environment(), name, loc),
23499 priv_(new priv(type, 0, is_variadic))
23501 runtime_type_instance(
this);
23502 set_is_artificial(is_artificial);
23505function_decl::parameter::parameter(
const type_base_sptr type,
23508 : type_or_decl_base(type->get_environment(),
23509 FUNCTION_PARAMETER_DECL | ABSTRACT_DECL_BASE),
23510 decl_base(type->get_environment(),
"", location()),
23511 priv_(new priv(type, index, variad))
23513 runtime_type_instance(
this);
23516function_decl::parameter::~parameter() =
default;
23518const type_base_sptr
23519function_decl::parameter::get_type()
const
23520{
return priv_->type_.lock();}
23547 if (get_variadic_marker()
23567 std::ostringstream o;
23568 o <<
"parameter-" << get_index();
23570 return env.
intern(o.str());
23574function_decl::parameter::get_index()
const
23575{
return priv_->index_;}
23578function_decl::parameter::set_index(
unsigned i)
23579{priv_->index_ = i;}
23583function_decl::parameter::get_variadic_marker()
const
23584{
return priv_->variadic_marker_;}
23610 bool result =
true;
23612 if ((l.get_variadic_marker() != r.get_variadic_marker())
23613 || (l.get_index() != r.get_index())
23614 || (!!l.get_type() != !!r.get_type()))
23619 if (l.get_index() != r.get_index())
23621 if (l.get_variadic_marker() != r.get_variadic_marker()
23622 || !!l.get_type() != !!r.get_type())
23629 type_base_sptr l_type = l.get_type();
23630 type_base_sptr r_type = r.get_type();
23632 if (l_type != r_type)
23650function_decl::parameter::operator==(
const parameter& o)
const
23651{
return equals(*
this, o, 0);}
23660 return function_decl::parameter::operator==(*p);
23706 if (v.visit_begin(
this))
23709 if (type_base_sptr t =
get_type())
23713 return v.visit_end(
this);
23746 bool qualified_name)
const
23753 type_repr =
"void";
23759 string result = type_repr;
23760 string parm_name = get_name_id();
23762 if (!parm_name.empty())
23763 result +=
" " + parm_name;
23797 size_t size_in_bits,
size_t align_in_bits,
23804 | ABSTRACT_DECL_BASE
23805 | ABSTRACT_SCOPE_TYPE_DECL
23806 | ABSTRACT_SCOPE_DECL),
23807 decl_base(env, name, locus, name, vis),
23808 type_base(env, size_in_bits, align_in_bits),
23812 for (member_types::iterator i = mem_types.begin();
23813 i != mem_types.end();
23824 for (member_functions::iterator i = member_fns.begin();
23825 i != member_fns.end();
23827 if (!
has_scope(static_pointer_cast<decl_base>(*i)))
23847 size_t size_in_bits,
size_t align_in_bits,
23851 | ABSTRACT_DECL_BASE
23852 | ABSTRACT_SCOPE_TYPE_DECL
23853 | ABSTRACT_SCOPE_DECL),
23854 decl_base(env, name, locus, name, vis),
23855 type_base(env, size_in_bits, align_in_bits),
23869 bool is_declaration_only)
23872 | ABSTRACT_DECL_BASE
23873 | ABSTRACT_SCOPE_TYPE_DECL
23874 | ABSTRACT_SCOPE_DECL),
23894 hash_t h = do_hash(
this);
23915 if (v.visit_begin(
this))
23924 if (!(*i)->traverse(v))
23934 if (!(*i)->traverse(v))
23944 if (!(*i)->traverse(v))
23951 for (member_function_templates::const_iterator i =
23955 if (!(*i)->traverse(v))
23962 for (member_class_templates::const_iterator i =
23966 if (!(*i)->traverse(v))
23974 bool result = v.visit_end(
this);
24003 type_base_sptr t =
is_type(decl);
24033 for (class_or_union::data_members::const_iterator it =
24122 if (t->get_is_anonymous())
24140 if (t->get_is_anonymous())
24158 if (t->get_is_anonymous())
24183 bool is_laid_out,
bool is_static,
24184 size_t offset_in_bits)
24188 priv_->data_members_.push_back(v);
24197 bool is_already_in =
false;
24200 for (
const auto& s_dm: priv_->static_data_members_)
24204 is_already_in =
true;
24208 if (!is_already_in)
24209 priv_->static_data_members_.push_back(v);
24215 for (data_members::const_iterator i =
24216 priv_->non_static_data_members_.begin();
24217 i != priv_->non_static_data_members_.end();
24221 is_already_in =
true;
24224 if (!is_already_in)
24225 priv_->non_static_data_members_.push_back(v);
24241{
return priv_->data_members_;}
24256 if ((*i)->get_name() == name)
24268 if (
var_decl_sptr data_member = type->find_data_member(name))
24269 return data_member;
24283 if (!v->get_name().empty())
24291 if ((*it)->get_pretty_representation(
false,
true)
24292 == v->get_pretty_representation(
false,
true))
24319 if (v->get_name().empty())
24332{
return priv_->non_static_data_members_;}
24340{
return priv_->static_data_members_;}
24358 bool is_static,
bool is_ctor,
24359 bool is_dtor,
bool is_const)
24371 priv_->member_functions_.push_back(f);
24375 if (!f->get_linkage_name().empty())
24376 priv_->mem_fns_map_[f->get_linkage_name()] = f;
24385{
return priv_->member_functions_;}
24406 string_mem_fn_sptr_map_type::const_iterator i =
24407 priv_->mem_fns_map_.find(linkage_name);
24408 if (i == priv_->mem_fns_map_.end())
24410 return i->second.get();
24421 string_mem_fn_sptr_map_type::const_iterator i =
24422 priv_->mem_fns_map_.find(linkage_name);
24423 if (i == priv_->mem_fns_map_.end())
24449 string_mem_fn_ptr_map_type::const_iterator i =
24450 priv_->signature_2_mem_fn_map_.find(s);
24451 if (i == priv_->signature_2_mem_fn_map_.end())
24459const member_function_templates&
24461{
return priv_->member_function_templates_;}
24466const member_class_templates&
24468{
return priv_->member_class_templates_;}
24479 priv_->member_function_templates_.push_back(m);
24494 priv_->member_class_templates_.push_back(m);
24504 && priv_->data_members_.empty()
24505 && priv_->member_functions_.empty()
24506 && priv_->member_function_templates_.empty()
24507 && priv_->member_class_templates_.empty());
24526 else if (method_decl_sptr f = dynamic_pointer_cast<method_decl>(d))
24532 else if (member_function_template_sptr f =
24533 dynamic_pointer_cast<member_function_template>(d))
24535 else if (member_class_template_sptr c =
24536 dynamic_pointer_cast<member_class_template>(d))
24585 return *
this == *o;
24626 if (l_is_decl_only || r_is_decl_only)
24636 if (!def1 || !def2)
24640 && l_is_decl_only && r_is_decl_only
24679 if (!!def1 != !!def2)
24687 if (!(l.decl_base::operator==(r)
24688 && l.type_base::operator==(r)))
24699 bool val = *def1 == *def2;
24708 if (!(l.decl_base::operator==(r) && l.type_base::operator==(r)))
24715 if (types_defined_same_linux_kernel_corpus_public(l, r))
24723#define RETURN(value) \
24724 return return_comparison_result(l, r, value);
24730 bool result =
true;
24744 for (class_or_union::data_members::const_iterator
24758 || (*d0)->get_type() == (*d1)->get_type())
24785 for (member_function_templates::const_iterator
24790 ++fn_tmpl_it0, ++fn_tmpl_it1)
24791 if (**fn_tmpl_it0 != **fn_tmpl_it1)
24816 for (member_class_templates::const_iterator
24821 ++cl_tmpl_it0, ++cl_tmpl_it1)
24822 if (**cl_tmpl_it0 != **cl_tmpl_it1)
24850 const method_decl_sptr& method)
24872 old_type->get_parameters(),
24873 old_type->get_is_const(),
24874 old_type->get_size_in_bits(),
24875 old_type->get_alignment_in_bits()));
24876 t->get_translation_unit()->bind_function_type_life_time(new_type);
24885 method->get_binding()));
24886 new_method->set_symbol(method->
get_symbol());
24889 class_type->add_member_function(new_method,
24898 t->add_member_function(new_method,
24924 type_base_sptr old_type = variable->
get_type();
24933 size_t offset_in_bits = 0;
24937 t->add_data_member(new_variable,
24943 return new_variable;
24979struct class_decl::priv
24982 unordered_map<string, base_spec_sptr> bases_map_;
24988 : is_struct_(false)
25029 size_t size_in_bits,
size_t align_in_bits,
25030 bool is_struct,
const location& locus,
25037 | ABSTRACT_TYPE_BASE
25038 | ABSTRACT_DECL_BASE
25039 | ABSTRACT_SCOPE_TYPE_DECL
25040 | ABSTRACT_SCOPE_DECL),
25041 decl_base(env, name, locus, name, vis),
25042 type_base(env, size_in_bits, align_in_bits),
25044 locus, vis, mbr_types, data_mbrs, mbr_fns),
25045 priv_(new priv(is_struct, bases))
25080 size_t size_in_bits,
size_t align_in_bits,
25081 bool is_struct,
const location& locus,
25087 | ABSTRACT_TYPE_BASE
25088 | ABSTRACT_DECL_BASE
25089 | ABSTRACT_SCOPE_TYPE_DECL
25090 | ABSTRACT_SCOPE_DECL),
25099 is_anonymous ? string() : name,
25101 type_base(env, size_in_bits, align_in_bits),
25103 locus, vis, mbr_types, data_mbrs, mbr_fns),
25104 priv_(new priv(is_struct, bases))
25126 size_t size_in_bits,
size_t align_in_bits,
25127 bool is_struct,
const location& locus,
25131 | ABSTRACT_TYPE_BASE
25132 | ABSTRACT_DECL_BASE
25133 | ABSTRACT_SCOPE_TYPE_DECL
25134 | ABSTRACT_SCOPE_DECL),
25135 decl_base(env, name, locus, name, vis),
25136 type_base(env, size_in_bits, align_in_bits),
25139 priv_(new priv(is_struct))
25163 size_t size_in_bits,
size_t align_in_bits,
25164 bool is_struct,
const location& locus,
25168 | ABSTRACT_TYPE_BASE
25169 | ABSTRACT_DECL_BASE
25170 | ABSTRACT_SCOPE_TYPE_DECL
25171 | ABSTRACT_SCOPE_DECL),
25180 is_anonymous ? string() : name,
25182 type_base(env, size_in_bits, align_in_bits),
25185 priv_(new priv(is_struct))
25201 bool is_struct,
bool is_declaration_only)
25204 | ABSTRACT_TYPE_BASE
25205 | ABSTRACT_DECL_BASE
25206 | ABSTRACT_SCOPE_TYPE_DECL
25207 | ABSTRACT_SCOPE_DECL),
25211 priv_(new priv(is_struct))
25226 for (class_decl::virtual_mem_fn_map_type::iterator i =
25227 priv_->virtual_mem_fns_map_.begin();
25228 i != priv_->virtual_mem_fns_map_.end();
25230 sort_virtual_member_functions(i->second);
25238{priv_->is_struct_ = f;}
25245{
return priv_->is_struct_;}
25253 priv_->bases_.push_back(b);
25254 priv_->bases_map_[b->get_base_class()->get_qualified_name()] = b;
25262{
return priv_->bases_;}
25273 unordered_map<string, base_spec_sptr>::iterator i =
25274 priv_->bases_map_.find(qualified_name);
25276 if (i != priv_->bases_map_.end())
25277 return i->second->get_base_class();
25288{
return priv_->virtual_mem_fns_;}
25307{
return priv_->virtual_mem_fns_map_;}
25312{sort_virtual_member_functions(priv_->virtual_mem_fns_);}
25333 bool qualified_name)
const
25335 string cl =
"class ";
25344 if (internal && !
get_name().empty())
25352 string result = cl;
25353 if (qualified_name)
25362class_decl::insert_member_decl(decl_base_sptr d)
25364 if (method_decl_sptr f = dynamic_pointer_cast<method_decl>(d))
25379struct class_decl::base_spec::priv
25382 long offset_in_bits_;
25386 long offset_in_bits,
25389 offset_in_bits_(offset_in_bits),
25390 is_virtual_(is_virtual)
25408 long offset_in_bits,
25411 ABSTRACT_DECL_BASE),
25413 base->get_linkage_name(), base->get_visibility()),
25415 priv_(new priv(base, offset_in_bits, is_virtual))
25441{
return priv_->base_class_.lock();}
25448{
return priv_->is_virtual_;}
25455{
return priv_->offset_in_bits_;}
25475 if (v.visit_begin(
this))
25478 get_base_class()->traverse(v);
25482 return v.visit_end(
this);
25502class_decl::base_spec::base_spec(
const type_base_sptr& base,
25504 long offset_in_bits,
25507 ABSTRACT_DECL_BASE),
25513 priv_(new priv(dynamic_pointer_cast<
class_decl>(base),
25520class_decl::base_spec::~base_spec() =
default;
25546 if (!l.member_base::operator==(r))
25572 return equals(*
this, *o, 0);
25593mem_fn_context_rel::~mem_fn_context_rel()
25613method_decl::method_decl(
const string& name,
25615 bool declared_inline,
25617 const string& linkage_name,
25622 | ABSTRACT_DECL_BASE
25626 declared_inline, locus, linkage_name, vis, bind)
25650method_decl::method_decl(
const string& name,
25652 bool declared_inline,
25654 const string& linkage_name,
25659 | ABSTRACT_DECL_BASE
25661 decl_base(type->get_environment(), name, locus, linkage_name, vis),
25664 declared_inline, locus, linkage_name, vis, bind)
25687method_decl::method_decl(
const string& name,
25688 type_base_sptr type,
25689 bool declared_inline,
25691 const string& linkage_name,
25696 | ABSTRACT_DECL_BASE
25698 decl_base(type->get_environment(), name, locus, linkage_name, vis),
25701 declared_inline, locus, linkage_name, vis, bind)
25720 class_or_union_sptr cl = t->get_class_type();
25722 cl->priv_->mem_fns_map_[l] = m;
25723 if (!old_lname.empty() && l != old_lname)
25725 if (method_decl_sptr m = cl->find_member_function_sptr(old_lname))
25728 cl->priv_->mem_fns_map_.erase(old_lname);
25734method_decl::~method_decl()
25771 if (l.get() == r.get())
25824{
return dynamic_pointer_cast<method_decl>(d);}
25828struct virtual_member_function_less_than
25852 if (f_offset != s_offset)
return f_offset < s_offset;
25858 if (fn != sn)
return fn < sn;
25864 if ((!f_sym) != (!s_sym))
return !f_sym;
25865 if (f_sym && s_sym)
25867 fn = f_sym->get_id_string();
25868 sn = s_sym->get_id_string();
25869 if (fn != sn)
return fn < sn;
25876 if (fn != sn)
return fn < sn;
25880 string fn_filepath, sn_filepath;
25881 unsigned line = 0, column = 0;
25884 fn_loc.
expand(fn_filepath, line, column);
25886 sn_loc.expand(sn_filepath, line, column);
25887 return fn_filepath < sn_filepath;
25902 operator()(
const method_decl_sptr f,
25903 const method_decl_sptr s)
25904 {
return operator()(*f, *s);}
25913 virtual_member_function_less_than lt;
25914 std::stable_sort(mem_fns.begin(), mem_fns.end(), lt);
25943 size_t vtable_offset,
25944 bool is_static,
bool is_ctor,
25945 bool is_dtor,
bool is_const)
25948 is_dtor, is_const);
25955 sort_virtual_member_functions(klass->priv_->virtual_mem_fns_);
25974 class_decl::member_functions::const_iterator m;
25975 for (m = klass->priv_->virtual_mem_fns_.begin();
25976 m != klass->priv_->virtual_mem_fns_.end();
25978 if (m->get() == method.get()
25979 || (*m)->get_linkage_name() == method->get_linkage_name())
25981 if (m == klass->priv_->virtual_mem_fns_.end())
25982 klass->priv_->virtual_mem_fns_.push_back(method);
25990 class_decl::virtual_mem_fn_map_type::iterator i =
25991 klass->priv_->virtual_mem_fns_map_.find(voffset);
25992 if (i == klass->priv_->virtual_mem_fns_map_.end())
25995 virtual_mem_fns_at_voffset.push_back(method);
25996 klass->priv_->virtual_mem_fns_map_[voffset] = virtual_mem_fns_at_voffset;
26000 for (m = i->second.begin() ; m != i->second.end(); ++m)
26001 if (m->get() == method.get()
26002 || (*m)->get_linkage_name() == method->get_linkage_name())
26004 if (m == i->second.end())
26005 i->second.push_back(method);
26034 if ((*b)->get_is_virtual()
26035 || (*b)->get_base_class()->has_virtual_bases())
26064 ssize_t offset = -1;
26065 for (class_decl::virtual_mem_fn_map_type::const_iterator e =
26069 if (e->first > offset)
26099methods_equal_modulo_elf_symbol(
const method_decl_sptr& f,
26100 const method_decl_sptr& s)
26102 method_decl_sptr first = f, second = s;
26104 first->get_symbol();
26106 second->get_symbol();
26108 first->get_linkage_name();
26110 second->get_linkage_name();
26113 first->set_linkage_name(
"");
26115 second->set_linkage_name(
"");
26117 bool equal = *first == *second;
26119 first->set_symbol(saved_first_elf_symbol);
26120 first->set_linkage_name(saved_first_linkage_name);
26121 second->set_symbol(saved_second_elf_symbol);
26122 second->set_linkage_name(saved_second_linkage_name);
26143method_matches_at_least_one_in_vector(
const method_decl_sptr& method,
26146 for (class_decl::member_functions::const_iterator i = fns.begin();
26155 if (methods_equal_modulo_elf_symbol(method, *i))
26188 bool result =
false;
26189 if (l.
get_environment().priv_->is_type_comparison_cached(l, r, result))
26200 bool result =
true;
26214#define RETURN(value) CACHE_AND_RETURN_COMPARISON_RESULT(value)
26226 for (class_decl::base_specs::const_iterator
26238 (*b1)->get_base_class().get()))
26284 for (class_decl::virtual_mem_fn_map_type::const_iterator first_v_fn_entry =
26287 ++first_v_fn_entry)
26289 unsigned voffset = first_v_fn_entry->first;
26291 first_v_fn_entry->second;
26293 const class_decl::virtual_mem_fn_map_type::const_iterator
26305 second_v_fn_entry->second;
26307 bool matches =
false;
26308 for (class_decl::member_functions::const_iterator i =
26309 first_vfns.begin();
26310 i != first_vfns.end();
26312 if (method_matches_at_least_one_in_vector(*i, second_vfns))
26406 return *
this == *o;
26450 if (l.get() == r.get())
26482operator==(
const class_or_union_sptr& l,
const class_or_union_sptr& r)
26484 if (l.get() == r.get())
26501operator!=(
const class_or_union_sptr& l,
const class_or_union_sptr& r)
26521 if (v.visit_begin(
this))
26530 if (!(*i)->traverse(v))
26541 if (!(*i)->traverse(v))
26551 if (!(*i)->traverse(v))
26561 if (!(*i)->traverse(v))
26568 for (member_function_templates::const_iterator i =
26572 if (!(*i)->traverse(v))
26579 for (member_class_templates::const_iterator i =
26583 if (!(*i)->traverse(v))
26591 bool result = v.visit_end(
this);
26600context_rel::~context_rel()
26604member_base::operator==(
const member_base& o)
const
26624 if (l.get() == r.get())
26629 return *l ==
static_cast<const decl_base&
>(*r);
26668{
return dynamic_pointer_cast<class_decl::base_spec>(tod);}
26671member_function_template::operator==(
const member_base& other)
const
26678 if (!(is_constructor() == o.is_constructor()
26679 && is_const() == o.is_const()
26680 && member_base::operator==(o)))
26687 return ftdecl->function_tdecl::operator==(*other_ftdecl);
26706 const member_function_template_sptr& r)
26708 if (l.get() == r.get())
26727 const member_function_template_sptr& r)
26744 if (v.visit_begin(
this))
26751 return v.visit_end(
this);
26767 if (!member_base::operator==(o))
26770 return as_class_tdecl()->class_tdecl::operator==(o);
26784 if (!decl_base::operator==(other))
26786 return as_class_tdecl()->class_tdecl::operator==(other);
26800 return *
this == *o;
26813 const member_class_template_sptr& r)
26815 if (l.get() == r.get())
26833 const member_class_template_sptr& r)
26850 if (v.visit_begin(
this))
26857 return v.visit_end(
this);
26877 case private_access:
26880 case protected_access:
26883 case public_access:
26907 c->set_is_static(s);
26917 for (
const auto& dm : cl->get_data_members())
26918 if (dm->get_name() == v->get_name())
26929 for (class_decl::data_members::iterator i =
26930 cl->priv_->non_static_data_members_.begin();
26931 i != cl->priv_->non_static_data_members_.end();
26934 if ((*i)->get_name() == v->get_name())
26936 cl->priv_->non_static_data_members_.erase(i);
26943 bool already_in_static_dms =
false;
26944 for (
const auto& s_dm : cl->priv_->static_data_members_)
26945 if (s_dm->get_name() == v->get_name())
26947 already_in_static_dms =
true;
26950 if (!already_in_static_dms)
26951 cl->priv_->static_data_members_.push_back(var);
26956 for (class_or_union::data_members::iterator i =
26957 cl->priv_->static_data_members_.begin();
26958 i != cl->priv_->static_data_members_.end();
26960 if ((*i)->get_name() == v->get_name())
26962 cl->priv_->static_data_members_.erase(i);
26968 bool is_already_in_non_static_data_members =
false;
26969 for (
const auto& ns_dm : cl->priv_->non_static_data_members_)
26970 if (ns_dm->get_name() == v->get_name())
26972 is_already_in_non_static_data_members =
true;
26975 if (!is_already_in_non_static_data_members)
26976 cl->priv_->non_static_data_members_.push_back(var);
27016 size_t size_in_bits,
const location& locus,
27021 | ABSTRACT_TYPE_BASE
27022 | ABSTRACT_DECL_BASE),
27023 decl_base(env, name, locus, name, vis),
27026 locus, vis, mbr_types, data_mbrs, member_fns)
27052 size_t size_in_bits,
const location& locus,
27058 | ABSTRACT_TYPE_BASE
27059 | ABSTRACT_DECL_BASE),
27068 is_anonymous ? string() : name,
27072 locus, vis, mbr_types, data_mbrs, member_fns)
27090 size_t size_in_bits,
const location& locus,
27094 | ABSTRACT_TYPE_BASE
27095 | ABSTRACT_DECL_BASE
27096 | ABSTRACT_SCOPE_TYPE_DECL
27097 | ABSTRACT_SCOPE_DECL),
27098 decl_base(env, name, locus, name, vis),
27121 size_t size_in_bits,
const location& locus,
27125 | ABSTRACT_TYPE_BASE
27126 | ABSTRACT_DECL_BASE
27127 | ABSTRACT_SCOPE_TYPE_DECL
27128 | ABSTRACT_SCOPE_DECL),
27137 is_anonymous ? string() : name,
27156 const string& name,
27157 bool is_declaration_only)
27160 | ABSTRACT_TYPE_BASE
27161 | ABSTRACT_DECL_BASE
27162 | ABSTRACT_SCOPE_TYPE_DECL
27163 | ABSTRACT_SCOPE_DECL),
27204 bool qualified_name)
const
27209 if (internal && !
get_name().empty())
27210 repr = string(
"union ") +
27220 if (qualified_name)
27257 return *
this == *o;
27271 return *
this == *o;
27304 if (v.visit_begin(
this))
27313 if (!(*i)->traverse(v))
27323 if (!(*i)->traverse(v))
27333 if (!(*i)->traverse(v))
27340 for (member_function_templates::const_iterator i =
27344 if (!(*i)->traverse(v))
27351 for (member_class_templates::const_iterator i =
27355 if (!(*i)->traverse(v))
27363 bool result = v.visit_end(
this);
27402 bool result =
false;
27403 if (l.
get_environment().priv_->is_type_comparison_cached(l, r, result))
27424 const method_decl_sptr& f)
27439 const class_or_union_sptr t = union_type;
27454 if (l.get() == r.get())
27478class template_decl::priv
27482 std::list<template_parameter_sptr> parms_;
27495{priv_->parms_.push_back(p);}
27501const std::list<template_parameter_sptr>&
27503{
return priv_->parms_;}
27516 const string& name,
27541 return *
this == *other;
27554 list<shared_ptr<template_parameter> >::const_iterator t0, t1;
27580class template_parameter::priv
27586 mutable bool hashing_started_;
27587 mutable bool comparison_started_;
27595 template_decl_(enclosing_template_decl),
27596 hashing_started_(),
27597 comparison_started_()
27601template_parameter::template_parameter(
unsigned index,
27603 : priv_(new priv(index, enclosing_template))
27607template_parameter::get_index()
const
27608{
return priv_->index_;}
27611template_parameter::get_enclosing_template_decl()
const
27612{
return priv_->template_decl_.lock();}
27616template_parameter::operator==(
const template_parameter& o)
const
27618 if (get_index() != o.get_index())
27621 if (priv_->comparison_started_)
27624 bool result =
false;
27629 priv_->comparison_started_ =
true;
27631 if (!!get_enclosing_template_decl() != !!o.get_enclosing_template_decl())
27633 else if (get_enclosing_template_decl()
27634 && (*get_enclosing_template_decl()
27635 != *o.get_enclosing_template_decl()))
27640 priv_->comparison_started_ =
false;
27653{
return !operator==(other);}
27660class type_tparameter::priv
27675type_tparameter::type_tparameter(
unsigned index,
27677 const string& name,
27681 | ABSTRACT_TYPE_BASE
27683 decl_base(enclosing_tdecl->get_environment(), name, locus),
27684 type_base(enclosing_tdecl->get_environment(), 0, 0),
27685 type_decl(enclosing_tdecl->get_environment(), name, 0, 0, locus),
27700 if (!type_decl::operator==(other))
27706 return template_parameter::operator==(o);
27720 if (!type_decl::operator==(other))
27726 return template_parameter::operator==(o);
27740 if (!decl_base::operator==(other))
27746 return template_parameter::operator==(o);
27776{
return *
this ==
static_cast<const type_base&
>(other);}
27778type_tparameter::~type_tparameter()
27782class non_type_tparameter::priv
27792 priv(type_base_sptr type)
27810non_type_tparameter::non_type_tparameter(
unsigned index,
27812 const string& name,
27813 type_base_sptr type,
27816 decl_base(type->get_environment(), name, locus,
""),
27818 priv_(new priv(type))
27826const type_base_sptr
27828{
return priv_->type_.lock();}
27834 if (!decl_base::operator==(other))
27841 return (template_parameter::operator==(o)
27860non_type_tparameter::~non_type_tparameter()
27866class template_tparameter::priv
27880template_tparameter::template_tparameter(
unsigned index,
27882 const string& name,
27886 | ABSTRACT_TYPE_BASE
27888 decl_base(enclosing_tdecl->get_environment(), name, locus),
27889 type_base(enclosing_tdecl->get_environment(), 0, 0),
27890 type_decl(enclosing_tdecl->get_environment(), name,
27891 0, 0, locus, name, VISIBILITY_DEFAULT),
27893 template_decl(enclosing_tdecl->get_environment(), name, locus),
27911 return (type_tparameter::operator==(o)
27930 return (type_tparameter::operator==(o)
27944 return *
this ==
static_cast<const type_base&
>(other);
27963template_tparameter::~template_tparameter()
27971class type_composition::priv
27995type_composition::type_composition(
unsigned index,
27999 ABSTRACT_DECL_BASE),
28010const type_base_sptr
28012{
return priv_->type_.lock();}
28021type_composition::~type_composition()
28030class function_tdecl::priv
28042 : pattern_(pattern), binding_(bind)
28069 | ABSTRACT_SCOPE_DECL),
28073 priv_(new priv(bind))
28097 | ABSTRACT_SCOPE_DECL),
28102 priv_(new priv(pattern, bind))
28113 priv_->pattern_ = p;
28123{
return priv_->pattern_;}
28130{
return priv_->binding_;}
28142 return *
this == *o;
28156 return *
this == *o;
28169 && template_decl::operator==(o)
28170 && scope_decl::operator==(o)
28194 if (!v.visit_begin(
this))
28201 return v.visit_end(
this);
28204function_tdecl::~function_tdecl()
28212class class_tdecl::priv
28223 : pattern_(pattern)
28242 | ABSTRACT_SCOPE_DECL),
28267 | ABSTRACT_SCOPE_DECL),
28272 priv_(new priv(pattern))
28283 priv_->pattern_ = p;
28293{
return priv_->pattern_;}
28302 if (!(template_decl::operator==(o)
28303 && scope_decl::operator==(o)
28322 return *
this ==
static_cast<const decl_base&
>(o);
28330{
return *
this ==
static_cast<const decl_base&
>(o);}
28346 if (v.visit_begin(
this))
28350 pattern->traverse(v);
28353 return v.visit_end(
this);
28356class_tdecl::~class_tdecl()
28367 non_canonicalized_subtype_detector();
28370 non_canonicalized_subtype_detector(
type_base* type)
28372 has_non_canonical_type_()
28381 has_non_canonical_type()
const
28382 {
return has_non_canonical_type_;}
28387 visit_begin(function_decl* f)
28405 visit_begin(type_base* t)
28409 if (!t->get_canonical_type())
28413 has_non_canonical_type_ = t;
28428 visit_end(type_base* )
28430 if (has_non_canonical_type_)
28447 non_canonicalized_subtype_detector v(t.get());
28449 return v.has_non_canonical_type();
28465 const type_base_sptr t_v2)
28472 return (t1 != t2 && repr1 == repr2);
28483 env.priv_->extra_live_types_.push_back(t);
28518 result =
reinterpret_cast<size_t>(g);
28520 result =
reinterpret_cast<size_t>(s);
28526 string repr = v->get_pretty_representation(
true);
28527 std::hash<string> hash_string;
28535 string repr = f->get_pretty_representation(
true);
28536 std::hash<string> hash_string;
28542 type_base_sptr parm_type = p->get_type();
28544 std::hash<bool> hash_bool;
28545 std::hash<unsigned> hash_unsigned;
28554 std::hash<size_t> hash_size;
28555 std::hash<bool> hash_bool;
28556 type_base_sptr type = bs->get_base_class();
28593{
return hash_as_canonical_type_or_constant(t);}
28620 if (d->type_or_decl_base::priv_->get_hashing_state()
28622 return d->type_or_decl_base::priv_->hash_value_;
28625 return artefact.priv_->hash_value_;
28727 exemplar =
const_cast<type_base*
>(type);
28756hash_as_canonical_type_or_constant(
const type_base *t)
28763 if (!canonical_type)
28781 if (canonical_type)
28782 return reinterpret_cast<size_t>(canonical_type);
28857 const type_base_sptr& second,
28858 bool indirect_type)
28890 bool indirect_type)
28892 if (!!first != !!second)
28904 if (
typeid(*first) !=
typeid(*second))
28920 if (ty1->is_lvalue() != ty2->is_lvalue())
28923 ty2->get_pointed_to_type(),
28942 if (!indirect_type)
28946 return ty1->get_name() == ty2->
get_name();
28952 if (!indirect_type)
28956 return (
get_name(ty1->get_underlying_type())
28964 && ty1->get_name() != ty2->
get_name())
28967 if (!indirect_type)
28970 || (ty1->get_non_static_data_members().size()
28974 for (class_or_union::data_members::const_iterator
28975 i = ty1->get_non_static_data_members().begin(),
28977 (i != ty1->get_non_static_data_members().end()
28984 dm2->get_type().get(),
28997 && ty1->get_name() != ty2->
get_name())
29000 if (!indirect_type)
29009 if (!indirect_type)
29012 || ty1->get_dimension_count() != ty2->get_dimension_count())
29032 for (
auto r1 = ty1->get_subranges().begin(),
29033 r2 = ty1->get_subranges().begin();
29034 (r1 != ty1->get_subranges().end()
29037 if ((*r1)->get_length() != (*r2)->get_length())
29072 if (ty1->get_parameters().size() != ty2->
get_parameters().size())
29075 for (function_type::parameters::const_iterator
29076 i = ty1->get_parameters().begin(),
29078 (i != ty1->get_parameters().end()
29108 const char* dm_name)
29136 return cou->find_data_member(dm);
29151 unsigned parm_index)
29158 if (parms.size() <= parm_index)
29161 return parms[parm_index].get();
29176 std::ostringstream o;
29179 o <<
"unnamed-enum";
29181 o <<
"enum-" << base_name;
29183 o <<
"-underlying-type-" << size;
29203 return data_member;
29223 for (; d != e; ++d)
29244stream_pretty_representation_of_fn_parms(
const function_type& fn_type,
29245 ostream& o,
bool qualified,
29253 type_base_sptr type;
29260 if (i != first_parm)
29263 type = parm->get_type();
29326add_outer_pointer_to_fn_type_expr(
const type_base* p,
29327 const string& input,
29328 bool qualified,
bool internal)
29334 string star_or_ref;
29347 if (!pointed_to_fn)
29350 if (pointed_to_fn->priv_->is_pretty_printing())
29360 pointed_to_fn->priv_->set_is_pretty_printing();
29362 std::ostringstream left, right, inner;
29364 inner <<
"(" << star_or_ref << input <<
")";
29366 type_base_sptr type;
29367 stream_pretty_representation_of_fn_parms(*pointed_to_fn, right,
29368 qualified, internal);
29370 type_base_sptr return_type = pointed_to_fn->get_return_type();
29379 result = left.str() +
" " + inner.str() + right.str();
29383 string inner_string = inner.str() + right.str();
29384 result = add_outer_pointer_to_fn_type_expr(p, inner_string,
29385 qualified, internal);
29389 string inner_string = inner.str() + right.str();
29390 result = add_outer_pointer_to_array_type_expr(p, inner_string,
29391 qualified, internal);
29399 pointed_to_fn->priv_->unset_is_pretty_printing();
29450add_outer_pointer_to_fn_type_expr(
const type_base_sptr& p,
29451 const string& input,
29452 bool qualified,
bool internal)
29453{
return add_outer_pointer_to_fn_type_expr(p.get(), input, qualified, internal);}
29506add_outer_pointer_to_array_type_expr(
const type_base* p,
29507 const string& input,
bool qualified,
29513 string star_or_ref;
29514 type_base_sptr pointed_to_type;
29518 pointed_to_type = ptr->get_pointed_to_type();
29523 pointed_to_type = ref->get_pointed_to_type();
29531 std::ostringstream left, right, inner;
29532 inner <<
"(" << star_or_ref << input <<
")";
29533 right << array->get_subrange_representation();
29536 type_base_sptr array_element_type = array->get_element_type();
29542 left <<
get_type_name(array_element_type, qualified, internal);
29543 result = left.str() + inner.str() + right.str();
29548 string r = inner.str() + right.str();
29549 result = add_outer_pointer_to_fn_type_expr(p, r, qualified, internal);
29554 string inner_string = inner.str() + right.str();
29555 result = add_outer_pointer_to_array_type_expr(p, inner_string,
29556 qualified, internal);
29615add_outer_pointer_to_array_type_expr(
const type_base_sptr& pointer_to_ar,
29616 const string& input,
bool qualified,
29618{
return add_outer_pointer_to_array_type_expr(pointer_to_ar.get(),
29619 input, qualified, internal);}
29667add_outer_ptr_to_mbr_type_expr(
const ptr_to_mbr_type* p,
29668 const string& input,
bool qualified,
29674 std::ostringstream left, right, inner;
29675 type_base_sptr void_type = p->get_environment().get_void_type();
29676 string containing_type_name =
get_type_name(p->get_containing_type(),
29677 qualified, internal);
29678 type_base_sptr mbr_type = p->get_member_type();
29682 inner <<
"(" << containing_type_name <<
"::*" << input <<
")";
29683 stream_pretty_representation_of_fn_parms(*fn_type, right,
29684 qualified, internal);
29687 return_type = void_type;
29694 left <<
get_type_name(return_type, qualified, internal) <<
" ";;
29695 result = left.str() + inner.str() + right.str();
29699 string inner_str = inner.str() + right.str();
29700 result = pointer_declaration_name(p, inner_str, qualified, internal);
29704 string inner_str = inner.str() + right.str();
29705 result = add_outer_ptr_to_mbr_type_expr(p, inner_str,
29706 qualified, internal);
29713 inner <<
"(" << containing_type_name <<
"::*" << input <<
")";
29714 stream_pretty_representation_of_fn_parms(*fn_type, right,
29715 qualified, internal);
29716 string inner_str = inner.str() + right.str();
29717 result = add_outer_ptr_to_mbr_type_expr(ptr_mbr_type, inner_str,
29718 qualified, internal);
29722 left <<
get_type_name(p->get_member_type(), qualified, internal) <<
" ";
29723 inner << containing_type_name <<
"::*" << input;
29724 result = left.str()+ inner.str();
29744 string d1_name, d2_name;
29761 return d1_name != d2_name;
29784 const type_base_sptr& s)
29796 && (f->get_size_in_bits() == s->get_size_in_bits())
29797 && (f->get_alignment_in_bits() == s->get_alignment_in_bits()))
29811 const decl_base_sptr& s)
29862 const string& input,
bool qualified,
29864{
return add_outer_ptr_to_mbr_type_expr(p.get(), input, qualified, internal);}
29884add_outer_pointer_to_ptr_to_mbr_type_expr(
const type_base* p,
29885 const string& input,
bool qualified,
29891 string star_or_ref;
29892 type_base_sptr pointed_to_type;
29896 pointed_to_type = ptr->get_pointed_to_type();
29901 pointed_to_type= ref->get_pointed_to_type();
29905 if (!pointed_to_type)
29910 if (!pointed_to_ptr_to_mbr)
29913 std::ostringstream inner;
29914 inner << star_or_ref << input;
29915 string result = add_outer_ptr_to_mbr_type_expr(pointed_to_ptr_to_mbr,
29917 qualified, internal);
29934static interned_string
29935pointer_declaration_name(
const type_base* ptr,
29936 const string& idname,
29937 bool qualified,
bool internal)
29940 return interned_string();
29942 type_base_sptr pointed_to_type;
29943 string star_or_ref;
29946 pointed_to_type = p->get_pointed_to_type();
29951 pointed_to_type = p->get_pointed_to_type();
29955 if (!pointed_to_type)
29956 return interned_string();
29969 if (!idname.empty())
29976 result = add_outer_pointer_to_fn_type_expr(ptr, idname,
29977 qualified, internal);
29979 result = add_outer_pointer_to_array_type_expr(ptr, idname,
29980 qualified, internal);
29982 result = add_outer_pointer_to_ptr_to_mbr_type_expr(ptr, idname,
29983 qualified, internal);
29987 return ptr->get_environment().intern(result);
30004static interned_string
30005pointer_declaration_name(
const type_base_sptr& ptr,
30006 const string& variable_name,
30007 bool qualified,
bool internal)
30008{
return pointer_declaration_name(ptr.get(), variable_name,
30009 qualified, internal);}
30024static interned_string
30025array_declaration_name(
const array_type_def* array,
30026 const string& variable_name,
30027 bool qualified,
bool internal)
30030 return interned_string();
30032 type_base_sptr e_type = array->get_element_type();
30033 string e_type_repr =
30041 std::ostringstream o;
30042 if (!variable_name.empty())
30043 o << variable_name <<
" is ";
30045 << array->get_subrange_representation()
30046 <<
") of " << e_type_repr;
30057 result = e_type_repr;
30058 if (!variable_name.empty())
30059 result += variable_name;
30060 result += array->get_subrange_representation();
30064 string s = variable_name + array->get_subrange_representation();
30065 result = pointer_declaration_name(p, s, qualified, internal);
30069 string s = variable_name + array->get_subrange_representation();
30070 result = ptr_to_mbr_declaration_name(p, s, qualified, internal);
30075 return array->get_environment().intern(result);
30091static interned_string
30093 const string& variable_name,
30094 bool qualified,
bool internal)
30095{
return array_declaration_name(array.get(), variable_name,
30096 qualified, internal);}
30111static interned_string
30112ptr_to_mbr_declaration_name(
const ptr_to_mbr_type* ptr,
30113 const string& variable_name,
30114 bool qualified,
bool internal)
30117 return interned_string();
30119 string input = variable_name;
30120 string result = add_outer_ptr_to_mbr_type_expr(ptr, input,
30121 qualified, internal);
30122 return ptr->get_environment().intern(result);
30138static interned_string
30140 const string& variable_name,
30141 bool qualified,
bool internal)
30143 return ptr_to_mbr_declaration_name(ptr.get(), variable_name,
30144 qualified, internal);
30163struct ir_node_visitor::priv
30166 bool allow_visiting_already_visited_type_node;
30169 : allow_visiting_already_visited_type_node(true)
30178ir_node_visitor::~ir_node_visitor() =
default;
30187{priv_->allow_visiting_already_visited_type_node = f;}
30196{
return priv_->allow_visiting_already_visited_type_node;}
30217 canonical_type = p;
30221 size_t canonical_ptr_value =
reinterpret_cast<size_t>(canonical_type);
30222 priv_->visited_ir_nodes.insert(canonical_ptr_value);
30235{priv_->visited_ir_nodes.clear();}
30256 canonical_type = p;
30260 size_t ptr_value =
reinterpret_cast<size_t>(canonical_type);
30261 pointer_set::iterator it = priv_->visited_ir_nodes.find(ptr_value);
30262 if (it == priv_->visited_ir_nodes.end())
30269ir_node_visitor::visit_begin(
decl_base*)
30277ir_node_visitor::visit_begin(scope_decl*)
30281ir_node_visitor::visit_end(scope_decl*)
30285ir_node_visitor::visit_begin(type_base*)
30289ir_node_visitor::visit_end(type_base*)
30293ir_node_visitor::visit_begin(scope_type_decl* t)
30294{
return visit_begin(
static_cast<type_base*
>(t));}
30297ir_node_visitor::visit_end(scope_type_decl* t)
30298{
return visit_end(
static_cast<type_base*
>(t));}
30301ir_node_visitor::visit_begin(type_decl* t)
30302{
return visit_begin(
static_cast<type_base*
>(t));}
30305ir_node_visitor::visit_end(type_decl* t)
30306{
return visit_end(
static_cast<type_base*
>(t));}
30309ir_node_visitor::visit_begin(namespace_decl* d)
30310{
return visit_begin(
static_cast<decl_base*
>(d));}
30313ir_node_visitor::visit_end(namespace_decl* d)
30314{
return visit_end(
static_cast<decl_base*
>(d));}
30317ir_node_visitor::visit_begin(qualified_type_def* t)
30318{
return visit_begin(
static_cast<type_base*
>(t));}
30321ir_node_visitor::visit_end(qualified_type_def* t)
30322{
return visit_end(
static_cast<type_base*
>(t));}
30325ir_node_visitor::visit_begin(pointer_type_def* t)
30326{
return visit_begin(
static_cast<type_base*
>(t));}
30329ir_node_visitor::visit_end(pointer_type_def* t)
30330{
return visit_end(
static_cast<type_base*
>(t));}
30333ir_node_visitor::visit_begin(reference_type_def* t)
30334{
return visit_begin(
static_cast<type_base*
>(t));}
30337ir_node_visitor::visit_end(reference_type_def* t)
30338{
return visit_end(
static_cast<type_base*
>(t));}
30341ir_node_visitor::visit_begin(ptr_to_mbr_type* t)
30342{
return visit_begin(
static_cast<type_base*
>(t));}
30345ir_node_visitor::visit_end(ptr_to_mbr_type* t)
30346{
return visit_end(
static_cast<type_base*
>(t));}
30349ir_node_visitor::visit_begin(array_type_def* t)
30350{
return visit_begin(
static_cast<type_base*
>(t));}
30353ir_node_visitor::visit_end(array_type_def* t)
30354{
return visit_end(
static_cast<type_base*
>(t));}
30357ir_node_visitor::visit_begin(array_type_def::subrange_type* t)
30358{
return visit_begin(
static_cast<type_base*
>(t));}
30361ir_node_visitor::visit_end(array_type_def::subrange_type* t)
30362{
return visit_end(
static_cast<type_base*
>(t));}
30365ir_node_visitor::visit_begin(enum_type_decl* t)
30366{
return visit_begin(
static_cast<type_base*
>(t));}
30369ir_node_visitor::visit_end(enum_type_decl* t)
30370{
return visit_end(
static_cast<type_base*
>(t));}
30373ir_node_visitor::visit_begin(typedef_decl* t)
30374{
return visit_begin(
static_cast<type_base*
>(t));}
30377ir_node_visitor::visit_end(typedef_decl* t)
30378{
return visit_end(
static_cast<type_base*
>(t));}
30381ir_node_visitor::visit_begin(function_type* t)
30382{
return visit_begin(
static_cast<type_base*
>(t));}
30385ir_node_visitor::visit_end(function_type* t)
30386{
return visit_end(
static_cast<type_base*
>(t));}
30389ir_node_visitor::visit_begin(var_decl* d)
30390{
return visit_begin(
static_cast<decl_base*
>(d));}
30393ir_node_visitor::visit_end(var_decl* d)
30394{
return visit_end(
static_cast<decl_base*
>(d));}
30397ir_node_visitor::visit_begin(function_decl* d)
30398{
return visit_begin(
static_cast<decl_base*
>(d));}
30401ir_node_visitor::visit_end(function_decl* d)
30402{
return visit_end(
static_cast<decl_base*
>(d));}
30405ir_node_visitor::visit_begin(function_decl::parameter* d)
30406{
return visit_begin(
static_cast<decl_base*
>(d));}
30409ir_node_visitor::visit_end(function_decl::parameter* d)
30410{
return visit_end(
static_cast<decl_base*
>(d));}
30413ir_node_visitor::visit_begin(function_tdecl* d)
30414{
return visit_begin(
static_cast<decl_base*
>(d));}
30417ir_node_visitor::visit_end(function_tdecl* d)
30418{
return visit_end(
static_cast<decl_base*
>(d));}
30421ir_node_visitor::visit_begin(class_tdecl* d)
30422{
return visit_begin(
static_cast<decl_base*
>(d));}
30425ir_node_visitor::visit_end(class_tdecl* d)
30426{
return visit_end(
static_cast<decl_base*
>(d));}
30429ir_node_visitor::visit_begin(class_or_union* t)
30430{
return visit_begin(
static_cast<type_base*
>(t));}
30433ir_node_visitor::visit_end(class_or_union* t)
30434{
return visit_end(
static_cast<type_base*
>(t));}
30437ir_node_visitor::visit_begin(class_decl* t)
30438{
return visit_begin(
static_cast<type_base*
>(t));}
30441ir_node_visitor::visit_end(class_decl* t)
30442{
return visit_end(
static_cast<type_base*
>(t));}
30445ir_node_visitor::visit_begin(union_decl* t)
30446{
return visit_begin(
static_cast<type_base*
>(t));}
30449ir_node_visitor::visit_end(union_decl* t)
30450{
return visit_end(
static_cast<type_base*
>(t));}
30453ir_node_visitor::visit_begin(class_decl::base_spec* d)
30454{
return visit_begin(
static_cast<decl_base*
>(d));}
30457ir_node_visitor::visit_end(class_decl::base_spec* d)
30458{
return visit_end(
static_cast<decl_base*
>(d));}
30461ir_node_visitor::visit_begin(member_function_template* d)
30462{
return visit_begin(
static_cast<decl_base*
>(d));}
30465ir_node_visitor::visit_end(member_function_template* d)
30466{
return visit_end(
static_cast<decl_base*
>(d));}
30469ir_node_visitor::visit_begin(member_class_template* d)
30470{
return visit_begin(
static_cast<decl_base*
>(d));}
30473ir_node_visitor::visit_end(member_class_template* d)
30474{
return visit_end(
static_cast<decl_base*
>(d));}
30486 static __thread
size_t counter;
30488 std::ostringstream o;
30494struct function_decl_hash
30496 size_t operator()(
const function_decl* f)
const
30497 {
return reinterpret_cast<size_t>(f);}
30500 {
return operator()(f.get());}
30505typedef unordered_map<
const function_decl*, string,
30506 function_decl_hash,
30525static const string&
30529 fns_to_str_map_type::const_iterator i = m.find(fn);
30532 string s = get_next_string();
30553fns_to_str(vector<function_decl*>::const_iterator begin,
30554 vector<function_decl*>::const_iterator end,
30558 vector<function_decl*>::const_iterator i;
30559 for (i = begin; i != end; ++i)
30560 o <<
"'" << fn_to_str(*i, m) <<
"' ";
30586fns_to_str(vector<function_decl*>::const_iterator a_begin,
30587 vector<function_decl*>::const_iterator a_end,
30588 vector<function_decl*>::const_iterator b_begin,
30589 vector<function_decl*>::const_iterator b_end,
30593 fns_to_str(a_begin, a_end, m, o);
30595 fns_to_str(b_begin, b_end, m, o);
30619fns_to_str(vector<function_decl*>::const_iterator a_begin,
30620 vector<function_decl*>::const_iterator a_end,
30621 vector<function_decl*>::const_iterator b_begin,
30622 vector<function_decl*>::const_iterator b_end,
30626 fns_to_str(a_begin, a_end, b_begin, b_end, m, o);
30648 std::string parent_qualified_name;
30657 if (!d->priv_->qualified_parent_name_.empty())
30663 d->priv_->qualified_name_ =
30664 env.
intern(d->priv_->qualified_parent_name_ +
"::" + d->
get_name());
30672 d->priv_->internal_qualified_name_ = d->priv_->qualified_name_;
30674 if (d->priv_->scoped_name_.empty())
30679 d->priv_->scoped_name_ =
30682 d->priv_->scoped_name_ =
30700{
return do_update(d);}
30712 return do_update(d);
This header declares filters for the diff trees resulting from comparing ABI Corpora.
The private data and functions of the abigail::ir::corpus type.
#define ABG_RETURN_FALSE
A macro used to return the "false" boolean from DIE comparison routines.
#define ABG_RETURN(value)
A macro used to return from DIE comparison routines.
#define ABG_ASSERT(cond)
This is a wrapper around the 'assert' glibc call. It allows for its argument to have side effects,...
Declaration of types pertaining to the interned string pool used throughout Libabigail,...
This contains the private implementation of the suppression engine of libabigail.
#define CACHE_COMPARISON_RESULT_AND_RETURN(value)
Cache the result of a comparison between too artifacts (l & r) and return immediately.
#define RETURN_TRUE_IF_COMPARISON_CYCLE_DETECTED(l, r)
This macro is to be used while comparing composite types that might recursively refer to themselves....
Types of the main internal representation of libabigail.
Wrappers around regex types and functions.
This type abstracts the configuration information of the library.
bool has_string(const char *s) const
Test if the interned string pool already contains a string with a given value.
const char * get_string(const char *s) const
Get a pointer to the interned string which has a given value.
interned_string create_string(const std::string &)
Create an interned string with a given value.
interned_string_pool()
Default constructor.
~interned_string_pool()
Destructor.
The abstraction of an interned string.
bool empty() const
Test if the current instance of interned_string is empty.
This class is to hold the value of the bound of a subrange. The value can be either signed or unsigne...
void set_signed(int64_t v)
Setter of the bound value as signed.
void set_signedness(enum signedness s)
Setter of the signedness (unsigned VS signed) of the bound value.
enum signedness get_signedness() const
Getter of the signedness (unsigned VS signed) of the bound value.
int64_t get_signed_value() const
Getter of the bound value as a signed value.
bool operator==(const bound_value &) const
Equality operator of the bound value.
uint64_t get_unsigned_value()
Getter of the bound value as an unsigned value.
bound_value()
Default constructor of the array_type_def::subrange_type::bound_value class.
void set_unsigned(uint64_t v)
Setter of the bound value as unsigned.
Abstraction for an array range type, like in Ada, or just for an array dimension like in C or C++.
void set_lower_bound(int64_t lb)
Setter of the lower bound.
bool is_non_finite() const
Test if the length of the subrange type is infinite.
void set_upper_bound(int64_t ub)
Setter of the upper bound of the subrange type.
void set_underlying_type(const type_base_sptr &)
Setter of the underlying type of the subrange, that is, the type that defines the range.
string as_string() const
Return a string representation of the sub range.
virtual hash_t hash_value() const
Return the hash value of the current IR node.
virtual bool traverse(ir_node_visitor &)
This implements the ir_traversable_base::traverse pure virtual function.
bool operator!=(const decl_base &o) const
Equality operator.
int64_t get_upper_bound() const
Getter of the upper bound of the subrange type.
type_base_sptr get_underlying_type() const
Getter of the underlying type of the subrange, that is, the type that defines the range.
virtual bool operator==(const decl_base &) const
Equality operator.
int64_t get_lower_bound() const
Getter of the lower bound of the subrange type.
virtual string get_pretty_representation(bool internal=false, bool qualified_name=true) const
Build a pretty representation for an array_type_def::subrange_type.
static string vector_as_string(const vector< subrange_sptr > &)
Return a string representation of a vector of subranges.
uint64_t get_length() const
Getter of the length of the subrange type.
translation_unit::language get_language() const
Getter of the language that generated this type.
The abstraction of an array type.
virtual bool is_non_finite() const
virtual void get_qualified_name(interned_string &qualified_name, bool internal=false) const
Build and return the qualified name of the current instance of the array_type_def.
virtual hash_t hash_value() const
Return the hash value of the current IR node.
const type_base_sptr get_element_type() const
Getter of the type of an array element.
void set_element_type(const type_base_sptr &element_type)
Setter of the type of array element.
shared_ptr< subrange_type > subrange_sptr
Convenience typedef for a shared pointer on a function_decl::subrange.
virtual bool traverse(ir_node_visitor &v)
This implements the ir_traversable_base::traverse pure virtual function.
const std::vector< subrange_sptr > & get_subranges() const
Get the array's subranges.
virtual bool operator==(const decl_base &) const
Return true iff the two decls have the same name.
std::vector< subrange_sptr > subranges_type
Convenience typedef for a vector of subrange_sptr.
virtual string get_pretty_representation(bool internal=false, bool qualified_name=true) const
Get the pretty representation of the current instance of array_type_def.
translation_unit::language get_language() const
Get the language of the array.
virtual void append_subranges(const std::vector< subrange_sptr > &subs)
Append subranges from the vector.
Abstraction of a base specifier in a class declaration.
class_decl_sptr get_base_class() const
Get the base class referred to by the current base class specifier.
bool get_is_virtual() const
Getter of the "is-virtual" proprerty of the base class specifier.
long get_offset_in_bits() const
Getter of the offset of the base.
virtual hash_t hash_value() const
Return the hash value of the current IR node.
virtual bool traverse(ir_node_visitor &)
Traverses an instance of class_decl::base_spec, visiting all the sub-types and decls that it might co...
virtual bool operator==(const decl_base &) const
Comparison operator for class_decl::base_spec.
Abstracts a class declaration.
void is_struct(bool f)
Set the "is-struct" flag of the class.
bool has_virtual_member_functions() const
Test if the current instance of class_decl has virtual member functions.
const virtual_mem_fn_map_type & get_virtual_mem_fns_map() const
Get the map that associates a virtual table offset to the virtual member functions with that virtual ...
bool is_struct() const
Test if the class is a struct.
virtual hash_t hash_value() const
Return the hash value of the current IR node.
const base_specs & get_base_specifiers() const
Get the base specifiers for this class.
virtual ~class_decl()
Destructor of the class_decl type.
virtual void on_canonical_type_set()
This method is invoked automatically right after the current instance of class_decl has been canonica...
bool has_vtable() const
Test if the current instance has a vtable.
ssize_t get_biggest_vtable_offset() const
Get the highest vtable offset of all the virtual methods of the class.
bool has_virtual_bases() const
Test if the current instance of class_decl has at least one virtual base.
virtual bool traverse(ir_node_visitor &v)
This implements the ir_traversable_base::traverse pure virtual function.
shared_ptr< base_spec > base_spec_sptr
Convenience typedef.
void add_base_specifier(shared_ptr< base_spec > b)
Add a base specifier to this class.
const member_functions & get_virtual_mem_fns() const
Get the virtual member functions of this class.
void sort_virtual_mem_fns()
Sort the virtual member functions by their virtual index.
friend bool equals(const class_decl &, const class_decl &, change_kind *)
Compares two instances of class_decl.
virtual bool operator==(const decl_base &) const
Comparison operator for class_decl.
class_decl_sptr find_base_class(const string &qualified_name) const
Find a base class of a given qualified name for the current class.
bool has_no_base_nor_member() const
Return true iff the class has no entity in its scope.
vector< base_spec_sptr > base_specs
Convenience typedef.
virtual string get_pretty_representation(bool internal=false, bool qualified_name=true) const
Getter of the pretty representation of the current instance of class_decl.
The base type of class_decl and union_decl.
virtual size_t get_num_anonymous_member_classes() const
Get the number of anonymous member classes contained in this class.
void add_member_function(method_decl_sptr f, access_specifier a, bool is_static, bool is_ctor, bool is_dtor, bool is_const)
Add a member function.
const var_decl_sptr find_anonymous_data_member(const var_decl_sptr &) const
Find an anonymous data member in the class.
const member_functions & get_member_functions() const
Get the member functions of this class_or_union.
virtual void remove_member_decl(decl_base_sptr)
Remove a given decl from the current class_or_union scope.
const member_function_templates & get_member_function_templates() const
Get the member function templates of this class.
virtual size_t get_size_in_bits() const
Getter of the size of the class_or_union type.
virtual size_t get_num_anonymous_member_unions() const
Get the number of anonymous member unions contained in this class.
void add_member_function_template(member_function_template_sptr)
Append a member function template to the class_or_union.
unordered_map< ssize_t, member_functions > virtual_mem_fn_map_type
Convenience typedef.
vector< method_decl_sptr > member_functions
Convenience typedef.
const data_members & get_data_members() const
Get the data members of this class_or_union.
virtual hash_t hash_value() const
Return the hash value of the current IR node.
void add_data_member(var_decl_sptr v, access_specifier a, bool is_laid_out, bool is_static, size_t offset_in_bits)
Add a data member to the current instance of class_or_union.
const method_decl * find_member_function_from_signature(const string &s) const
Find a method (member function) using its signature (pretty representation) as a key.
method_decl_sptr find_member_function_sptr(const string &mangled_name)
Find a method, using its linkage name as a key.
virtual void set_size_in_bits(size_t)
Setter of the size of the class_or_union type.
decl_base_sptr insert_member_decl(decl_base_sptr member)
Insert a data member to this class_or_union type.
virtual decl_base_sptr add_member_decl(const decl_base_sptr &)
Add a member declaration to the current instance of class_or_union. The member declaration can be eit...
virtual bool traverse(ir_node_visitor &v)
This implements the ir_traversable_base::traverse pure virtual function.
void add_member_class_template(member_class_template_sptr m)
Append a member class template to the class_or_union.
const data_members & get_non_static_data_members() const
Get the non-static data members of this class_or_union.
const method_decl * find_member_function(const string &mangled_name) const
Find a method, using its linkage name as a key.
const data_members & get_static_data_members() const
Get the static data memebers of this class_or_union.
void maybe_fixup_members_of_anon_data_member(var_decl_sptr &anon_dm)
Fixup the members of the type of an anonymous data member.
vector< var_decl_sptr > data_members
Convenience typedef.
virtual ~class_or_union()
Destrcutor of the class_or_union type.
bool has_no_member() const
virtual bool operator==(const decl_base &) const
Equality operator.
friend void set_member_is_static(decl_base &d, bool s)
Sets the static-ness property of a class member.
virtual size_t get_alignment_in_bits() const
Getter of the alignment of the class_or_union type.
const member_class_templates & get_member_class_templates() const
Get the member class templates of this class.
virtual void set_alignment_in_bits(size_t)
Setter of the alignment of the class type.
vector< type_base_sptr > member_types
Convenience typedef.
virtual size_t get_num_anonymous_member_enums() const
Get the number of anonymous member enums contained in this class.
const var_decl_sptr find_data_member(const string &) const
Find a data member of a given name in the current class_or_union.
Abstract a class template.
shared_ptr< class_decl > get_pattern() const
Getter of the pattern of the template.
void set_pattern(class_decl_sptr p)
Setter of the pattern of the template.
virtual bool traverse(ir_node_visitor &v)
This implements the ir_traversable_base::traverse pure virtual function.
virtual bool operator==(const decl_base &) const
Equality operator.
The abstraction of the relationship between an entity and its containing scope (its context)....
This is the abstraction of a set of translation units (themselves seen as bundles of unitary abi arte...
shared_ptr< exported_decls_builder > exported_decls_builder_sptr
Convenience typedef for shared_ptr<exported_decls_builder>.
const translation_units & get_translation_units() const
Return the list of translation units of the current corpus.
origin get_origin() const
Getter for the origin of the corpus.
type_maps & get_types()
Get the maps that associate a name to a certain kind of type.
type_maps & get_type_per_loc_map()
Get the maps that associate a location string to a certain kind of type.
const corpus_group * get_group() const
Getter of the group this corpus is a member of.
const environment & get_environment() const
Getter of the enviroment of the corpus.
The base type of all declarations.
void set_definition_of_declaration(const decl_base_sptr &)
Set the definition of this declaration-only decl_base.
void set_is_declaration_only(bool f)
Set a flag saying if the enum_type_decl is a declaration-only enum_type_decl.
virtual bool operator!=(const decl_base &) const
Inequality operator.
const interned_string & get_cached_pretty_representation(bool internal=false) const
Get the pretty representation of the current decl.
scope_decl * get_scope() const
Return the type containing the current decl, if any.
void set_qualified_name(const interned_string &) const
Setter for the qualified name.
void set_is_in_public_symbol_table(bool)
Set the flag saying if this decl is from a symbol that is in a public symbols table,...
friend bool get_member_is_static(const decl_base &d)
Gets a flag saying if a class member is static or not.
const decl_base_sptr get_earlier_declaration() const
If this decl_base is a definition, get its earlier declaration.
virtual void set_linkage_name(const string &m)
Setter for the linkage name.
const decl_base * get_naked_definition_of_declaration() const
If this decl_base is declaration-only, get its definition, if any.
virtual void get_qualified_name(interned_string &qualified_name, bool internal=false) const
Compute the qualified name of the decl.
void clear_qualified_name()
Clear the qualified name of this decl.
virtual void set_name(const string &n)
Setter for the name of the decl.
const location & get_location() const
Get the location of a given declaration.
typedef_decl_sptr get_naming_typedef() const
Getter for the naming typedef of the current decl.
virtual const interned_string & get_name() const
Getter for the name of the current decl.
virtual void set_scope(scope_decl *)
Setter of the scope of the current decl.
const interned_string & peek_qualified_name() const
Getter for the qualified name.
const context_rel * get_context_rel() const
Getter for the context relationship.
bool get_is_anonymous() const
Test if the current declaration is anonymous.
friend decl_base_sptr add_decl_to_scope(decl_base_sptr decl, scope_decl *scpe)
Appends a declaration to a given scope, if the declaration doesn't already belong to one and if the d...
virtual const interned_string & get_scoped_name() const
Return the scoped name of the decl.
const decl_base_sptr get_definition_of_declaration() const
If this decl_base is declaration-only, get its definition, if any.
friend void set_member_access_specifier(decl_base &d, access_specifier a)
Sets the access specifier for a class member.
void set_naming_typedef(const typedef_decl_sptr &)
Set the naming typedef of the current instance of decl_base.
void set_location(const location &l)
Set the location for a given declaration.
void set_is_anonymous(bool)
Set the "is_anonymous" flag of the current declaration.
void set_visibility(visibility v)
Setter for the visibility of the decl.
void set_temporary_qualified_name(const interned_string &) const
Setter for the temporary qualified name of the current declaration.
visibility get_visibility() const
Getter for the visibility of the decl.
visibility
ELF visibility.
bool get_is_declaration_only() const
Test if a decl_base is a declaration-only decl.
virtual bool traverse(ir_node_visitor &v)
This implements the ir_traversable_base::traverse pure virtual function.
void set_earlier_declaration(const decl_base_sptr &)
set the earlier declaration of this decl_base definition.
const interned_string & get_linkage_name() const
Getter for the mangled name.
friend enum access_specifier get_member_access_specifier(const decl_base &d)
Gets the access specifier for a class member.
friend bool get_member_function_is_virtual(const function_decl &f)
Test if a given member function is virtual.
virtual ~decl_base()
Destructor of the decl_base type.
virtual bool operator==(const decl_base &) const
Return true iff the two decls have the same name.
const interned_string & get_qualified_parent_name() const
Return a copy of the qualified name of the parent of the current decl.
bool get_is_anonymous_or_has_anonymous_parent() const
bool get_has_anonymous_parent() const
Get the "has_anonymous_parent" flag of the current declaration.
bool get_is_in_public_symbol_table() const
Test if the decl is defined in a ELF symbol table as a public symbol.
friend bool equals(const decl_base &, const decl_base &, change_kind *)
Compares two instances of decl_base.
const interned_string & peek_temporary_qualified_name() const
Getter of the temporary qualified name of the current declaration.
virtual string get_pretty_representation(bool internal=false, bool qualified_name=true) const
Get the pretty representatin of the current declaration.
The abstraction for a data member context relationship. This relates a data member to its parent clas...
const var_decl * get_anonymous_data_member() const
Return a non-nil value if this data member context relationship has an anonymous data member....
void set_anonymous_data_member(var_decl *)
Set the containing anonymous data member of this data member context relationship....
The abstraction of the version of an ELF symbol.
version & operator=(const version &o)
Assign a version to the current one.
bool operator==(const version &o) const
Compares the current version against another one.
bool is_default() const
Getter for the 'is_default' property of the version.
const string & str() const
Getter for the version name.
bool operator!=(const version &o) const
Inequality operator.
Abstraction of an elf symbol.
const abg_compat::optional< std::string > & get_namespace() const
Getter of the 'namespace' property.
elf_symbol_sptr get_alias_which_equals(const elf_symbol &other) const
In the list of aliases of a given elf symbol, get the alias that equals this current symbol.
elf_symbol_sptr get_next_common_instance() const
Get the next common instance of the current common symbol.
type get_type() const
Getter for the type of the current instance of elf_symbol.
const elf_symbol_sptr get_main_symbol() const
Get the main symbol of an alias chain.
void set_is_in_ksymtab(bool is_in_ksymtab)
Setter of the 'is-in-ksymtab' property.
bool has_aliases() const
Check if the current elf_symbol has an alias.
void set_name(const string &n)
Setter for the name of the current intance of elf_symbol.
bool is_suppressed() const
Getter for the 'is-suppressed' property.
binding
The binding of a symbol.
int get_number_of_aliases() const
Get the number of aliases to this elf symbol.
string get_aliases_id_string(const string_elf_symbols_map_type &symtab, bool include_symbol_itself=true) const
Return a comma separated list of the id of the current symbol as well as the id string of its aliases...
void set_binding(binding b)
Setter for the binding of the current instance of elf_symbol.
void add_common_instance(const elf_symbol_sptr &)
Add a common instance to the current common elf symbol.
void add_alias(const elf_symbol_sptr &)
Add an alias to the current elf symbol.
void set_is_suppressed(bool is_suppressed)
Setter for the 'is-suppressed' property.
bool is_variable() const
Test if the current instance of elf_symbol is a variable symbol or not.
elf_symbol_sptr update_main_symbol(const std::string &)
Update the main symbol for a group of aliased symbols.
void set_size(size_t)
Setter of the size of the symbol.
const string & get_name() const
Getter for the name of the elf_symbol.
binding get_binding() const
Getter for the binding of the current instance of elf_symbol.
static bool get_name_and_version_from_id(const string &id, string &name, string &ver)
Given the ID of a symbol, get the name and the version of said symbol.
bool is_function() const
Test if the current instance of elf_symbol is a function symbol or not.
type
The type of a symbol.
void set_version(const version &v)
Setter for the version of the current instance of elf_symbol.
const abg_compat::optional< uint32_t > & get_crc() const
Getter of the 'crc' property.
void set_visibility(visibility v)
Setter of the visibility of the current instance of elf_symbol.
bool does_alias(const elf_symbol &) const
Test if the current symbol aliases another one.
bool is_main_symbol() const
Tests whether this symbol is the main symbol.
void set_crc(const abg_compat::optional< uint32_t > &crc)
Setter of the 'crc' property.
static elf_symbol_sptr create(const environment &e, size_t i, size_t s, const string &n, type t, binding b, bool d, bool c, const version &ve, visibility vi, bool is_in_ksymtab=false, const abg_compat::optional< uint32_t > &crc={}, const abg_compat::optional< std::string > &ns={}, bool is_suppressed=false)
Factory of instances of elf_symbol.
visibility
The visibility of the symbol.
version & get_version() const
Getter for the version of the current instanc of elf_symbol.
bool is_common_symbol() const
Return true if the symbol is a common one.
void set_index(size_t)
Setter for the index.
visibility get_visibility() const
Getter of the visibility of the current instance of elf_symbol.
bool has_other_common_instances() const
Return true if this common common symbol has other common instances.
size_t get_index() const
Getter for the index.
const string & get_id_string() const
Get a string that is representative of a given elf_symbol.
elf_symbol_sptr get_alias_from_name(const string &name) const
From the aliases of the current symbol, lookup one with a given name.
const environment & get_environment() const
Getter of the environment used by the current instance of elf_symbol.
void set_type(type t)
Setter for the type of the current instance of elf_symbol.
bool is_public() const
Test if the current instance of elf_symbol is public or not.
bool is_in_ksymtab() const
Getter of the 'is-in-ksymtab' property.
size_t get_size() const
Getter of the size of the symbol.
bool is_defined() const
Test if the current instance of elf_symbol is defined or not.
void set_namespace(const abg_compat::optional< std::string > &ns)
Setter of the 'namespace' property.
elf_symbol_sptr get_next_alias() const
Get the next alias of the current symbol.
bool operator==(const elf_symbol &) const
Test if two main symbols are textually equal, or, if they have aliases that are textually equal.
The abstraction of an enumerator.
enumerator()
Default constructor of the enum_type_decl::enumerator type.
bool operator!=(const enumerator &other) const
Inequality operator.
void set_name(const string &n)
Setter for the name of enum_type_decl::enumerator.
enum_type_decl * get_enum_type() const
Getter for the enum type that this enumerator is for.
const string & get_name() const
Getter for the name of the current instance of enum_type_decl::enumerator.
void set_enum_type(enum_type_decl *)
Setter for the enum type that this enumerator is for.
void set_value(int64_t v)
Setter for the value of enum_type_decl::enumerator.
const string & get_qualified_name(bool internal=false) const
Getter for the qualified name of the current instance of enum_type_decl::enumerator....
int64_t get_value() const
Getter for the value of enum_type_decl::enumerator.
bool operator==(const enumerator &other) const
Equality operator.
enumerator & operator=(const enumerator &)
Assignment operator of the enum_type_decl::enumerator type.
Abstracts a declaration for an enum type.
std::vector< enumerator > enumerators
Convenience typedef for a list of enumerator.
virtual hash_t hash_value() const
Return the hash value of the current IR node.
virtual ~enum_type_decl()
Destructor for the enum type declaration.
const enumerators & get_enumerators() const
bool find_enumerator_by_value(int64_t value, enum_type_decl::enumerator &result)
Find an enumerator by its value.
const enumerators & get_sorted_enumerators() const
Get the lexicographically sorted vector of enumerators.
virtual bool traverse(ir_node_visitor &v)
This implements the ir_traversable_base::traverse pure virtual function.
type_base_sptr get_underlying_type() const
Return the underlying type of the enum.
bool find_enumerator_by_name(const string &name, enum_type_decl::enumerator &result)
Find an enumerator by its name.
virtual bool operator==(const decl_base &) const
Equality operator.
virtual string get_pretty_representation(bool internal=false, bool qualified_name=true) const
Get the pretty representation of the current instance of enum_type_decl.
This is an abstraction of the set of resources necessary to manage several aspects of the internal re...
bool decl_only_class_equals_definition() const
Getter of the "decl-only-class-equals-definition" flag.
bool is_void_pointer_type(const type_base_sptr &) const
Test if a given type is the same as the void pointer type of the environment.
std::unordered_map< string, std::vector< type_base_sptr > > canonical_types_map_type
A convenience typedef for a map of canonical types. The key is the pretty representation string of a ...
bool user_set_analyze_exported_interfaces_only() const
Getter for a property that says if the user actually did set the analyze_exported_interfaces_only() p...
const vector< type_base_sptr > * get_canonical_types(const char *name) const
Get the vector of canonical types which have a given "string representation".
const type_base_sptr & get_void_type() const
Get the unique type_decl that represents a "void" type for the current environment....
bool is_variadic_parameter_type(const type_base *) const
Test if a type is a variadic parameter type as defined in the current environment.
static string & get_variadic_parameter_type_name()
Getter of the name of the variadic parameter type.
const type_base_sptr & get_void_pointer_type() const
Getter of the "pointer-to-void" IR node that is shared across the ABI corpus. This node must be the o...
const config & get_config() const
Getter of the general configuration object.
environment()
Default constructor of the environment type.
bool canonicalization_is_done() const
Test if the canonicalization of types created out of the current environment is done.
type_base * get_canonical_type(const char *name, unsigned index)
Get a given canonical type which has a given "string representation".
const type_base_sptr & get_variadic_parameter_type() const
Get a type_decl instance that represents a the type of a variadic function parameter....
bool is_void_type(const type_base_sptr &) const
Test if a given type is a void type as defined in the current environment.
virtual ~environment()
Destructor for the environment type.
bool canonicalization_started() const
Getter of a flag saying if the canonicalization process has started or not.
interned_string intern(const string &) const
Do intern a string.
bool analyze_exported_interfaces_only() const
Getter for the property that controls if we are to restrict the analysis to the types that are only r...
canonical_types_map_type & get_canonical_types_map()
Getter the map of canonical types.
Abstraction of a function parameter.
virtual void get_qualified_name(interned_string &qualified_name, bool internal=false) const
Compute the qualified name of the parameter.
interned_string get_type_name() const
interned_string get_name_id() const
Get a name uniquely identifying the parameter in the function.
const string get_type_pretty_representation() const
virtual bool traverse(ir_node_visitor &v)
Traverse the diff sub-tree under the current instance function_decl.
virtual string get_pretty_representation(bool internal=false, bool qualified_name=true) const
Compute and return a copy of the pretty representation of the current function parameter.
Abstraction for a function declaration.
shared_ptr< parameter > parameter_sptr
Convenience typedef for a shared pointer on a function_decl::parameter.
string get_pretty_representation_of_declarator(bool internal=false) const
Compute and return the pretty representation for the part of the function declaration that starts at ...
const function_type * get_naked_type() const
Fast getter of the type of the current instance of function_decl.
virtual bool traverse(ir_node_visitor &)
This implements the ir_traversable_base::traverse pure virtual function.
void append_parameters(std::vector< parameter_sptr > &parms)
Append a vector of parameters to the type of this function.
bool is_variadic() const
Return true iff the function takes a variable number of parameters.
parameters::const_iterator get_first_non_implicit_parm() const
Getter for the first non-implicit parameter of a function decl.
const function_type_sptr get_type() const
Return the type of the current instance of function_decl.
function_decl(const string &name, function_type_sptr function_type, bool declared_inline, const location &locus, const string &mangled_name, visibility vis, binding bind)
Constructor of the function_decl.
const type_base_sptr get_return_type() const
function_decl_sptr clone() const
Create a new instance of function_decl that is a clone of the current one.
const std::vector< parameter_sptr > & get_parameters() const
void append_parameter(parameter_sptr parm)
Append a parameter to the type of this function.
void set_symbol(const elf_symbol_sptr &sym)
This sets the underlying ELF symbol for the current function decl.
virtual ~function_decl()
Destructor of the function_decl type.
const elf_symbol_sptr & get_symbol() const
Gets the the underlying ELF symbol for the current variable, that was set using function_decl::set_sy...
virtual bool operator==(const decl_base &o) const
Comparison operator for function_decl.
std::vector< parameter_sptr > parameters
Convenience typedef for a vector of parameter_sptr.
bool is_declared_inline() const
Test if the function was declared inline.
virtual string get_pretty_representation(bool internal=false, bool qualified_name=true) const
Get the pretty representation of the current instance of function_decl.
interned_string get_id() const
Return an ID that tries to uniquely identify the function inside a program or a library.
Abstract a function template declaration.
binding get_binding() const
Get the binding of the function template.
void set_pattern(shared_ptr< function_decl > p)
Set a new pattern to the function template.
shared_ptr< function_decl > get_pattern() const
Get the pattern of the function template.
virtual bool traverse(ir_node_visitor &v)
This implements the ir_traversable_base::traverse pure virtual function.
virtual bool operator==(const decl_base &) const
Comparison operator for the function_tdecl type.
Abstraction of a function type.
shared_ptr< function_decl::parameter > parameter_sptr
Convenience typedef for a shared pointer on a function_decl::parameter.
virtual hash_t hash_value() const
Return the hash value of the current IR node.
virtual bool traverse(ir_node_visitor &)
Traverses an instance of function_type, visiting all the sub-types and decls that it might contain.
bool is_variadic() const
Test if the current instance of function_type is for a variadic function.
parameters::const_iterator get_first_parm() const
Get the first parameter of the function.
virtual void on_canonical_type_set()
This function is automatically invoked whenever an instance of this type is canonicalized.
virtual bool operator==(const type_base &) const
Equality operator for function_type.
void append_parameter(parameter_sptr parm)
Append a new parameter to the vector of parameters of the current instance of function_type.
void set_parameters(const parameters &p)
Setter for the parameters of the current instance of function_type.
const interned_string & get_cached_name(bool internal=false) const
Get the name of the current function_type.
const parameter_sptr get_parm_at_index_from_first_non_implicit_parm(size_t) const
Get the Ith parameter of the vector of parameters of the current instance of function_type.
type_base_sptr get_return_type() const
Getter for the return type of the current instance of function_type.
void set_return_type(type_base_sptr t)
Setter of the return type of the current instance of function_type.
parameters::const_iterator get_first_non_implicit_parm() const
Get the first parameter of the function.
const parameters & get_parameters() const
Getter for the set of parameters of the current intance of function_type.
std::vector< parameter_sptr > parameters
Convenience typedef for a vector of parameter_sptr.
virtual string get_pretty_representation(bool internal=false, bool qualified_name=true) const
Return a copy of the pretty representation of the current function_type.
This abstracts the global scope of a given translation unit.
The base class for the visitor type hierarchy used for traversing a translation unit.
bool allow_visiting_already_visited_type_node() const
Get if the walker using this visitor is allowed to re-visit a type node that was previously visited o...
bool type_node_has_been_visited(type_base *) const
Test if a given type node has been marked as visited.
void forget_visited_type_nodes()
Un-mark all visited type nodes.
ir_node_visitor()
Default Constructor of the ir_node_visitor type.
void mark_type_node_as_visited(type_base *)
Mark a given type node as having been visited.
The entry point to manage locations.
location create_new_location(const std::string &fle, size_t lne, size_t col)
Insert the triplet representing a source locus into our internal vector of location triplet....
void expand_location(const location &location, std::string &path, unsigned &line, unsigned &column) const
Given an instance of location type, return the triplet {path,line,column} that represents the source ...
The source location of a token.
bool get_is_artificial() const
Test if the location is artificial.
unsigned get_value() const
Get the value of the location.
string expand(void) const
Expand the location into a string.
void expand(std::string &path, unsigned &line, unsigned &column) const
Expand the current location into a tripplet file path, line and column number.
Abstraction of a member function context relationship. This relates a member function to its parent c...
bool is_constructor() const
Getter for the 'is-constructor' property.
bool is_const() const
Getter for the 'is-const' property.
size_t vtable_offset() const
Getter for the vtable offset property.
bool is_destructor() const
Getter for the 'is-destructor' property.
The base class for member types, data members and member functions. Its purpose is mainly to carry th...
access_specifier get_access_specifier() const
Getter for the access specifier of this member.
bool get_is_static() const
Abstracts a member class template template.
virtual bool operator==(const member_base &o) const
Equality operator of the the member_class_template class.
virtual bool traverse(ir_node_visitor &v)
This implements the ir_traversable_base::traverse pure virtual function.
Abstract a member function template.
virtual bool traverse(ir_node_visitor &)
This implements the ir_traversable_base::traverse pure virtual function.
Abstraction of the declaration of a method.
friend void set_member_function_is_const(function_decl &, bool)
set the const-ness property of a member function.
virtual void set_linkage_name(const string &)
Set the linkage name of the method.
const method_type_sptr get_type() const
Abstracts the type of a class member function.
void set_class_type(const class_or_union_sptr &t)
Sets the class type of the current instance of method_type.
virtual hash_t hash_value() const
Return the hash value of the current IR node.
void set_is_const(bool)
Setter of the "is-const" property of method_type.
bool get_is_for_static_method() const
Test if the current method type is for a static method or not.
virtual ~method_type()
The destructor of method_type.
virtual string get_pretty_representation(bool internal=false, bool qualified_name=true) const
Return a copy of the pretty representation of the current method_type.
class_or_union_sptr get_class_type() const
Get the class type this method belongs to.
bool get_is_const() const
Getter of the "is-const" property of method_type.
The abstraction of a namespace declaration.
bool is_empty_or_has_empty_sub_namespaces() const
Test if the current namespace_decl is empty or contains empty namespaces itself.
virtual bool traverse(ir_node_visitor &)
This implements the ir_traversable_base::traverse pure virtual function.
namespace_decl(const environment &env, const string &name, const location &locus, visibility vis=VISIBILITY_DEFAULT)
Constructor.
virtual bool operator==(const decl_base &) const
Return true iff both namespaces and their members are equal.
virtual string get_pretty_representation(bool internal=false, bool qualified_name=true) const
Build and return a copy of the pretty representation of the namespace.
Abstracts non type template parameters.
const type_base_sptr get_type() const
Getter for the type of the template parameter.
virtual bool operator==(const decl_base &) const
Return true iff the two decls have the same name.
The abstraction of a pointer type.
void set_pointed_to_type(const type_base_sptr &)
Set the pointed-to type of the pointer.
virtual void get_qualified_name(interned_string &, bool internal=false) const
Build and return the qualified name of the current instance of pointer_type_def.
virtual hash_t hash_value() const
Return the hash value of the current IR node.
virtual void on_canonical_type_set()
This function is automatically invoked whenever an instance of this type is canonicalized.
virtual bool traverse(ir_node_visitor &v)
This implements the ir_traversable_base::traverse pure virtual function.
virtual bool operator==(const decl_base &) const
Return true iff both instances of pointer_type_def are equal.
const type_base_sptr get_pointed_to_type() const
Getter of the pointed-to type.
type_base * get_naked_pointed_to_type() const
Getter of a naked pointer to the pointed-to type.
The abstraction of a pointer-to-member type.
virtual void get_qualified_name(interned_string &qualified_name, bool internal=false) const
Get the qualified name for the current ptr_to_mbr_type.
virtual const interned_string & get_name() const
Getter of the name of the current ptr-to-mbr-type.
virtual hash_t hash_value() const
Return the hash value of the current IR node.
const type_base_sptr & get_containing_type() const
Getter of the type containing the member pointed-to by the current ptr_to_mbr_type.
bool operator==(const ptr_to_mbr_type &) const
Equality operator for the current ptr_to_mbr_type.
virtual bool traverse(ir_node_visitor &v)
This implements the ir_traversable_base::traverse pure virtual function for ptr_to_mbr_type.
const type_base_sptr & get_member_type() const
Getter of the member type of the current ptr_to_mbr_type.
virtual ~ptr_to_mbr_type()
Desctructor for ptr_to_mbr_type.
The abstraction of a qualified type.
virtual void get_qualified_name(interned_string &qualified_name, bool internal=false) const
Implementation for the virtual qualified name builder for qualified_type_def.
void set_underlying_type(const type_base_sptr &)
Setter of the underlying type.
virtual size_t get_size_in_bits() const
Get the size of the qualified type def.
virtual hash_t hash_value() const
Return the hash value of the current IR node.
string get_cv_quals_string_prefix() const
Compute and return the string prefix or suffix representing the qualifiers hold by the current instan...
CV
Bit field values representing the cv qualifiers of the underlying type.
virtual void on_canonical_type_set()
This function is automatically invoked whenever an instance of this type is canonicalized.
void set_cv_quals(CV cv_quals)
Setter of the const/value qualifiers bit field.
virtual bool traverse(ir_node_visitor &v)
This implements the ir_traversable_base::traverse pure virtual function.
CV get_cv_quals() const
Getter of the const/volatile qualifier bit field.
type_base_sptr get_underlying_type() const
Getter of the underlying type.
virtual bool operator==(const decl_base &) const
Equality operator for qualified types.
string build_name(bool, bool internal=false) const
Build the name of the current instance of qualified type.
The internal representation of an integral type.
void set_modifiers(modifiers_type)
Setter of the modifiers bitmap of the real_type.
string to_string(bool internal=false) const
Return the string representation of the current instance of real_type.
base_type get_base_type() const
Getter of the base type of the real_type.
bool operator==(const real_type &) const
Equality operator for the real_type.
real_type()
Default constructor of the real_type.
modifiers_type
The modifiers of the base types above. Several modifiers can be combined for a given base type....
@ LONG_LONG_MODIFIER
The "long long" modifier.
@ LONG_MODIFIER
The "long" modifier.
@ SIGNED_MODIFIER
The "signed" modifier.
@ UNSIGNED_MODIFIER
The "unsigned" modier.
@ SHORT_MODIFIER
The "short" modifier.
base_type
The possible base types of integral types. We might have forgotten many of these, so do not hesitate ...
@ WCHAR_T_BASE_TYPE
The "wchar_t" base type.
@ CHAR32_T_BASE_TYPE
The "char32_t" base type.
@ FLOAT_BASE_TYPE
The "float" base type.
@ BOOL_BASE_TYPE
The "bool" base type in C++ or "_Bool" in C11.
@ CHAR_BASE_TYPE
The "char" base type.
@ CHAR16_T_BASE_TYPE
The "char16_t base type.
@ INT_BASE_TYPE
The "int" base type.
@ ARRAY_SIZE_BASE_TYPE
The aray size type used by Clang.
@ DOUBLE_BASE_TYPE
The "double" base type.
modifiers_type get_modifiers() const
Getter of the modifiers bitmap of the real_type.
Abstracts a reference type.
virtual void get_qualified_name(interned_string &qualified_name, bool internal=false) const
Build and return the qualified name of the current instance of the reference_type_def.
virtual hash_t hash_value() const
Return the hash value of the current IR node.
virtual void on_canonical_type_set()
This function is automatically invoked whenever an instance of this type is canonicalized.
virtual bool traverse(ir_node_visitor &v)
This implements the ir_traversable_base::traverse pure virtual function.
void set_pointed_to_type(type_base_sptr &pointed_to_type)
Setter of the pointed_to type of the current reference type.
virtual bool operator==(const decl_base &) const
Equality operator of the reference_type_def type.
virtual string get_pretty_representation(bool internal=false, bool qualified_name=true) const
Get the pretty representation of the current instance of reference_type_def.
A declaration that introduces a scope.
virtual size_t get_num_anonymous_member_classes() const
Getter for the number of anonymous classes contained in this scope.
void remove_member_type(type_base_sptr t)
Remove a member type from the current class_or_union scope.
void insert_member_type(type_base_sptr t, declarations::iterator before)
Insert a member type.
void add_member_type(type_base_sptr t)
Add a member type to the current instance of class_or_union.
virtual size_t get_num_anonymous_member_unions() const
Getter for the number of anonymous unions contained in this scope.
scopes & get_member_scopes()
Getter for the scopes carried by the current scope.
std::vector< scope_decl_sptr > scopes
Convenience typedef for a vector of scope_decl_sptr.
bool is_empty() const
Test if the current scope is empty.
virtual bool traverse(ir_node_visitor &)
This implements the ir_traversable_base::traverse pure virtual function.
const type_base_sptrs_type & get_member_types() const
Get the member types of this scope_decl.
decl_base_sptr insert_member_decl(decl_base_sptr member, declarations::iterator before)
Insert a member decl to this scope, right before an element pointed to by a given iterator....
std::vector< decl_base_sptr > declarations
Convenience typedef for a vector of decl_base_sptr.
const type_base_sptrs_type & get_sorted_canonical_types() const
Return a vector of sorted canonical types of the current scope.
bool find_iterator_for_member(const decl_base *, declarations::iterator &)
Find a member of the current scope and return an iterator on it.
virtual void remove_member_decl(decl_base_sptr member)
Remove a declaration from the current scope.
virtual decl_base_sptr add_member_decl(const decl_base_sptr &member)
Add a member decl to this scope. Note that user code should not use this, but rather use add_decl_to_...
type_base_sptr find_member_type(const string &name) const
Find a member type of a given name, inside the current scope_decl.
const declarations & get_member_decls() const
Getter for the member declarations carried by the current scope_decl.
const canonical_type_sptr_set_type & get_canonical_types() const
@eturn the set of canonical types of the the current scope.
const type_base_sptrs_type & get_sorted_member_types() const
Get the sorted member types of this scope_decl.
friend decl_base_sptr add_decl_to_scope(decl_base_sptr decl, scope_decl *scope)
Appends a declaration to a given scope, if the declaration doesn't already belong to one and if the d...
virtual bool operator==(const decl_base &) const
Return true iff both scopes have the same names and have the same member decls.
const declarations & get_sorted_member_decls() const
Getter for the sorted member declarations carried by the current scope_decl.
virtual size_t get_num_anonymous_member_enums() const
Getter for the number of anonymous enums contained in this scope.
A type that introduces a scope.
virtual bool traverse(ir_node_visitor &)
Traverses an instance of scope_type_decl, visiting all the sub-types and decls that it might contain.
virtual bool operator==(const decl_base &) const
Equality operator between two scope_type_decl.
The base class of templates.
const std::list< template_parameter_sptr > & get_template_parameters() const
Get the list of template parameters of the current instance of template_decl.
virtual ~template_decl()
Destructor.
void add_template_parameter(const template_parameter_sptr p)
Add a new template parameter to the current instance of template_decl.
virtual bool operator==(const decl_base &o) const
Equality operator.
Base class for a template parameter. Client code should use the more specialized type_template_parame...
virtual ~template_parameter()
Destructor.
bool operator!=(const template_parameter &) const
Inequality operator.
Abstracts a template template parameter.
virtual bool operator==(const type_base &) const
Equality operator.
This is the abstraction of the set of relevant artefacts (types, variable declarations,...
void set_address_size(char)
Setter of the address size in this translation unit.
const std::string & get_absolute_path() const
Get the concatenation of the build directory and the relative path of the translation unit.
void set_is_constructed(bool)
Setter of the 'is_constructed" flag. It says if the translation unit is fully constructed or not.
bool operator==(const translation_unit &) const
Compare the current translation unit against another one.
const corpus * get_corpus() const
Get the corpus this translation unit is a member of.
char get_address_size() const
Getter of the address size in this translation unit.
const std::string & get_compilation_dir_path() const
Get the path of the directory that was 'current' when the translation unit was compiled.
void set_corpus(corpus *)
Set the corpus this translation unit is a member of.
void set_language(language l)
Setter of the language of the source code of the translation unit.
void bind_function_type_life_time(function_type_sptr) const
Ensure that the life time of a function type is bound to the life time of the current translation uni...
const scope_decl_sptr & get_global_scope() const
Getter of the the global scope of the translation unit.
bool is_empty() const
Tests whether if the current translation unit contains ABI artifacts or not.
bool is_constructed() const
Getter of the 'is_constructed" flag. It says if the translation unit is fully constructed or not.
const std::string & get_path() const
Get the path of the current translation unit.
void set_compilation_dir_path(const std::string &)
Set the path of the directory that was 'current' when the translation unit was compiled.
location_manager & get_loc_mgr()
Getter of the location manager for the current translation unit.
void set_path(const string &)
Set the path associated to the current instance of translation_unit.
virtual bool traverse(ir_node_visitor &v)
This implements the ir_traversable_base::traverse virtual function.
language
The language of the translation unit.
bool operator!=(const translation_unit &) const
Inequality operator.
const vector< function_type_sptr > & get_live_fn_types() const
Get the vector of function types that are used in the current translation unit.
const environment & get_environment() const
Getter of the environment of the current translation_unit.
const type_maps & get_types() const
Getter of the types of the current translation_unit.
language get_language() const
Getter of the language of the source code of the translation unit.
bool visiting() const
This should returns false before and after the node has been visiting. During the visiting of the nod...
An abstraction helper for type declarations.
const interned_string & get_cached_pretty_representation(bool internal=false) const
Get the pretty representation of the current type.
type_base * get_naked_canonical_type() const
Getter of the canonical type pointer.
virtual size_t get_size_in_bits() const
Getter for the size of the type.
virtual hash_t hash_value() const
Return the hash value of the current IR node.
virtual bool traverse(ir_node_visitor &)
Default implementation of traversal for types. This function does nothing. It must be implemented by ...
virtual void on_canonical_type_set()
This method is invoked automatically right after the current instance of class_decl has been canonica...
virtual void set_size_in_bits(size_t)
Setter for the size of the type.
virtual bool operator!=(const type_base &) const
Inequality operator.
virtual bool operator==(const type_base &) const
Return true iff both type declarations are equal.
virtual size_t get_alignment_in_bits() const
Getter for the alignment of the type.
virtual void set_alignment_in_bits(size_t)
Setter for the alignment of the type.
type_base_sptr get_canonical_type() const
Getter of the canonical type of the current instance of type_base.
This abstracts a composition of types based on template type parameters. The result of the compositio...
const type_base_sptr get_composed_type() const
Getter for the resulting composed type.
void set_composed_type(type_base_sptr t)
Setter for the resulting composed type.
A basic type declaration that introduces no scope.
virtual void get_qualified_name(interned_string &qualified_name, bool internal=false) const
Implementation for the virtual qualified name builder for type_decl.
virtual hash_t hash_value() const
Return the hash value of the current IR node.
virtual bool traverse(ir_node_visitor &)
This implements the ir_traversable_base::traverse pure virtual function.
virtual bool operator!=(const type_base &) const
Return true if both types equals.
virtual bool operator==(const type_base &) const
Return true if both types equals.
virtual string get_pretty_representation(bool internal=false, bool qualified_name=true) const
Get the pretty representation of the current instance of type_decl.
This is a type that aggregates maps of all the kinds of types that are supported by libabigail.
istring_type_base_wptrs_map_type & typedef_types()
Getter for the map that associates the name of a typedef to the vector of instances of typedef_decl_s...
istring_type_base_wptrs_map_type & function_types()
Getter for the map that associates the name of a function type to the vector of instances of function...
istring_type_base_wptrs_map_type & reference_types()
Getter for the map that associates the name of a reference type to the vector of instances of referen...
const istring_type_base_wptrs_map_type & class_types() const
Getter for the map that associates the name of a class type to the vector of instances of class_decl_...
istring_type_base_wptrs_map_type & union_types()
Getter for the map that associates the name of a union type to the vector of instances of union_decl_...
istring_type_base_wptrs_map_type & array_types()
Getter for the map that associates the name of an array type to the vector of instances of array_type...
istring_type_base_wptrs_map_type & enum_types()
Getter for the map that associates the name of an enum type to the vector of instances of enum_type_d...
bool empty() const
Test if the type_maps is empty.
istring_type_base_wptrs_map_type & qualified_types()
Getter for the map that associates the name of a qualified type to the vector of instances of qualifi...
istring_type_base_wptrs_map_type & ptr_to_mbr_types()
Getter for the map that associates the name of a pointer-to-member type to the vector of instances of...
const vector< type_base_wptr > & get_types_sorted_by_name() const
Getter of all types types sorted by their pretty representation.
istring_type_base_wptrs_map_type & pointer_types()
Getter for the map that associates the name of a pointer type to the vector of instances of pointer_t...
const istring_type_base_wptrs_map_type & basic_types() const
Getter for the map that associates the name of a basic type to the vector instances of type_decl_sptr...
const istring_type_base_wptrs_map_type & subrange_types() const
Getter for the map that associates the name of a subrange type to the vector of instances of array_ty...
The base class of both types and declarations.
void set_translation_unit(translation_unit *)
Set the translation_unit this ABI artifact belongs to.
bool get_is_artificial() const
Getter of the flag that says if the artefact is artificial.
virtual ~type_or_decl_base()
The destructor of the type_or_decl_base type.
location & get_artificial_location() const
Getter of the artificial location of the artifact.
bool has_artificial_location() const
Test if the current ABI artifact carries an artificial location.
const corpus * get_corpus() const
Get the corpus this ABI artifact belongs to.
friend hash_t set_or_get_cached_hash_value(const T &type_or_decl)
Set the hash value of an IR node and return it.
virtual hash_t hash_value() const
Return the hash value of the current IR node.
enum type_or_decl_kind kind() const
Getter for the "kind" property of type_or_decl_base type.
void set_is_artificial(bool)
Setter of the flag that says if the artefact is artificial.
virtual bool traverse(ir_node_visitor &)
Traverse the the ABI artifact.
const void * runtime_type_instance() const
Getter of the pointer to the runtime type sub-object of the current instance.
friend class_decl * is_class_type(const type_or_decl_base *)
Test whether a type is a class.
friend hash_t peek_hash_value(const type_or_decl_base &)
Get the hash value associated to an IR node.
const void * type_or_decl_base_pointer() const
Getter of the pointer to either the type_base sub-object of the current instance if it's a type,...
friend decl_base * is_decl(const type_or_decl_base *d)
Test if an ABI artifact is a declaration.
void set_artificial_location(const location &)
Setter of the artificial location of the artificat.
type_or_decl_kind
This is a bitmap type which instance is meant to contain the runtime type of a given ABI artifact....
const environment & get_environment() const
Getter of the environment of the current ABI artifact.
friend type_base * is_type(const type_or_decl_base *)
Test whether a declaration is a type.
const translation_unit * get_translation_unit() const
Get the translation_unit this ABI artifact belongs to.
Abstracts a type template parameter.
virtual bool operator==(const type_base &) const
Equality operator.
The abstraction of a typedef declaration.
virtual void get_qualified_name(interned_string &qualified_name, bool internal=false) const
Implementation of the virtual "get_qualified_name" method.
void set_underlying_type(const type_base_sptr &)
Setter ofthe underlying type of the typedef.
virtual size_t get_size_in_bits() const
Return the size of the typedef.
virtual hash_t hash_value() const
Return the hash value of the current IR node.
virtual bool traverse(ir_node_visitor &)
This implements the ir_traversable_base::traverse pure virtual function.
type_base_sptr get_underlying_type() const
Getter of the underlying type of the typedef.
virtual bool operator==(const decl_base &) const
Equality operator.
virtual size_t get_alignment_in_bits() const
Return the alignment of the typedef.
virtual string get_pretty_representation(bool internal=false, bool qualified_name=true) const
Build a pretty representation for a typedef_decl.
Abstracts a union type declaration.
virtual hash_t hash_value() const
Return the hash value of the current IR node.
virtual bool traverse(ir_node_visitor &v)
This implements the ir_traversable_base::traverse pure virtual function.
virtual bool operator==(const decl_base &) const
Comparison operator for union_decl.
virtual ~union_decl()
Destructor of the union_decl type.
virtual string get_pretty_representation(bool internal=false, bool qualified_name=true) const
Getter of the pretty representation of the current instance of union_decl.
Abstracts a variable declaration.
binding get_binding() const
Getter of the binding of the variable.
void set_type(type_base_sptr &)
Setter of the type of the variable.
void set_binding(binding b)
Setter of the binding of the variable.
friend uint64_t get_data_member_offset(const var_decl_sptr m)
Get the offset of a data member.
var_decl_sptr clone() const
Create a new var_decl that is a clone of the current one.
virtual const interned_string & get_qualified_name(bool internal=false) const
Get the qualified name of a given variable or data member.
const type_base * get_naked_type() const
Getter of the type of the variable.
friend bool get_data_member_is_laid_out(const var_decl &m)
Test whether a data member is laid out.
const type_base_sptr get_type() const
Getter of the type of the variable.
virtual bool traverse(ir_node_visitor &v)
This implements the ir_traversable_base::traverse pure virtual function.
string get_anon_dm_reliable_name(bool qualified=true) const
Get a name that is valid even for an anonymous data member.
void set_symbol(const elf_symbol_sptr &sym)
Sets the underlying ELF symbol for the current variable.
const elf_symbol_sptr & get_symbol() const
Gets the the underlying ELF symbol for the current variable, that was set using var_decl::set_symbol(...
virtual bool operator==(const decl_base &) const
Comparison operator of var_decl.
virtual string get_pretty_representation(bool internal=false, bool qualified_name=true) const
Build and return the pretty representation of this variable.
interned_string get_id() const
Return an ID that tries to uniquely identify the variable inside a program or a library.
bool is_decl_only_class_with_size_change(const class_or_union &first, const class_or_union &second)
Test if two classes that are decl-only (have the decl-only flag and carry no data members) but are di...
string get_pretty_representation(diff *d)
Get a copy of the pretty representation of a diff node.
ostream & operator<<(ostream &o, diff_category c)
Serialize an instance of diff_category to an output stream.
hash_t combine_hashes(hash_t val1, hash_t val2)
Combine two hash values to produce a third hash value.
@ HASHING_FINISHED_STATE
Hashing of given IR node started and is now done. If an ABI artifact is in this state,...
real_type::modifiers_type operator~(real_type::modifiers_type l)
Bitwise one's complement operator for real_type::modifiers_type.
shared_ptr< reference_type_def > reference_type_def_sptr
Convenience typedef for a shared pointer on a reference_type_def.
bool enum_has_non_name_change(const enum_type_decl &l, const enum_type_decl &r, change_kind *k)
Test if two enums differ, but not by a name change.
const type_base_sptr lookup_type_in_scope(const string &fqn, const scope_decl_sptr &skope)
Lookup a type in a scope.
bool is_non_canonicalized_type(const type_base *t)
Test if a given type is allowed to be non canonicalized.
bool get_member_function_is_dtor(const function_decl &f)
Test whether a member function is a destructor.
const type_base * peel_qualified_type(const type_base *type)
Return the leaf underlying type of a qualified type.
hash_t peek_hash_value(const type_or_decl_base &artefact)
Get the hash value associated to an IR node.
type_decl_sptr lookup_basic_type(const interned_string &type_name, const translation_unit &tu)
Lookup a basic type from a translation unit.
shared_ptr< method_type > method_type_sptr
Convenience typedef for shared pointer to method_type.
size_t hash_type(const type_base *t)
Hash an ABI artifact that is a type.
void fqn_to_components(const string &fqn, list< string > &comps)
Decompose a fully qualified name into the list of its components.
var_decl_sptr get_last_data_member(const class_or_union &klass)
Get the last data member of a class type.
bool is_anonymous_or_typedef_named(const decl_base &d)
Test if a given decl is anonymous or has a naming typedef.
bool is_template_parm_composition_type(const shared_ptr< decl_base > decl)
Tests whether a decl is a template parameter composition type.
type_base_sptr canonicalize(type_base_sptr t, bool do_log, bool show_stats)
Compute the canonical type of a given type.
bool get_member_is_static(const decl_base &d)
Gets a flag saying if a class member is static or not.
pointer_type_def_sptr is_pointer_to_npaf_type(const type_base_sptr &t)
Test if we are looking at a pointer to a neither-a-pointer-to-an-array-nor-a-function type.
bool debug_equals(const type_or_decl_base *l, const type_or_decl_base *r)
Test if two ABI artifacts are equal.
shared_ptr< function_decl > function_decl_sptr
Convenience typedef for a shared pointer on a function_decl.
access_specifier
Access specifier for class members.
size_t get_canonical_type_index(const type_base &t)
Getter of the canonical type index of a given type.
const type_base_wptrs_type * lookup_enum_types(const interned_string &qualified_name, const corpus &corp)
Look into a given corpus to find the enum type*s* that have a given qualified name.
bool function_decls_alias(const function_decl &f1, const function_decl &f2)
Test if two function declarations are aliases.
pointer_type_def_sptr is_pointer_to_array_type(const type_base_sptr &t)
Test if a type is a pointer to array type.
bool type_is_suitable_for_hash_computing(const type_base &)
Test if we should attempt to compute a hash value for a given type.
shared_ptr< class_tdecl > class_tdecl_sptr
Convenience typedef for a shared pointer on a class_tdecl.
bool maybe_update_types_lookup_map< function_type >(const function_type_sptr &type, istring_type_base_wptrs_map_type &types_map, bool)
This is the specialization for type function_type of the function template:
weak_ptr< function_type > function_type_wptr
Convenience typedef for a weak pointer on a function_type.
type_base_sptr lookup_class_or_typedef_type(const string &qualified_name, const corpus &corp)
Look into a corpus to find a class, union or typedef type which has a given qualified name.
ssize_t get_member_function_vtable_offset(const function_decl &f)
Get the vtable offset of a member function.
corpus::origin operator|=(corpus::origin &l, corpus::origin r)
Bitwise |= operator for the corpus::origin type.
vector< type_base_wptr > type_base_wptrs_type
A convenience typedef for a vector of type_base_wptr.
scope_decl * get_type_scope(type_base *t)
Get the scope of a given type.
void fixup_virtual_member_function(method_decl_sptr method)
When a virtual member function has seen its virtualness set by set_member_function_is_virtual(),...
void pop_composite_type_comparison_operands(const type_base &left, const type_base &right)
Pop a pair of operands from the stack of operands to the current type comparison.
bool equals_modulo_cv_qualifier(const array_type_def *l, const array_type_def *r)
Test if two array types are equals modulo CV qualifiers.
const scope_decl * is_scope_decl(const decl_base *d)
Test if a declaration is a scope_decl.
qualified_type_def_sptr clone_qualified_type(const qualified_type_def_sptr &t)
Clone a qualifiend type.
const type_base * is_void_pointer_type(const type_base *t)
Test if a type is a pointer to void type.
bool is_type(const type_or_decl_base &tod)
Test whether a declaration is a type.
bool is_anonymous_data_member(const decl_base &d)
Test if a decl is an anonymous data member.
bool is_template_parameter(const shared_ptr< decl_base > decl)
Tests whether a decl is a template parameter.
string translation_unit_language_to_string(translation_unit::language l)
Converts a translation_unit::language enumerator into a string.
weak_ptr< type_base > type_base_wptr
Convenience typedef for a weak pointer on a type_base.
type_base_sptr peel_reference_type(const type_base_sptr &type)
Return the leaf pointed-to type node of a reference_type_def node.
class_decl::base_spec * is_class_base_spec(const type_or_decl_base *tod)
Test if an ABI artifact is a class base specifier.
bool has_scope(const decl_base &d)
Tests if a declaration has got a scope.
array_type_def::subrange_type * is_subrange_type(const type_or_decl_base *type)
Test if a type is an array_type_def::subrange_type.
T * maybe_get_canonical_type(T *t)
Get the canonical type of a given type T* as a T*.
shared_ptr< elf_symbol > elf_symbol_sptr
A convenience typedef for a shared pointer to elf_symbol.
type_base_sptr lookup_type_from_translation_unit(const string &type_name, const string &tu_path, const corpus &corp)
Lookup a type from a given translation unit present in a give corpus.
type_base * get_exemplar_type(const type_base *type)
For a given type, return its exemplar type.
bool type_originates_from_corpus(type_base_sptr t, corpus_sptr &c)
Test if a type originates from a corpus.
bool parse_real_type(const string &type_name, real_type &type)
Parse a real type from a string.
void remove_decl_from_scope(decl_base_sptr decl)
Remove a given decl from its scope.
bool odr_is_relevant(const type_or_decl_base &artifact)
By looking at the language of the TU a given ABI artifact belongs to, test if the ONE Definition Rule...
array_type_def_sptr clone_array(const array_type_def_sptr &array)
Clone an array type.
change_kind
A bitfield that gives callers of abigail::ir::equals() some insight about how different two internal ...
@ LOCAL_TYPE_CHANGE_KIND
This means that a given IR artifact has a local type change.
@ SUBTYPE_CHANGE_KIND
This means that a given IR artifact has changes in some of its sub-types, with respect to the other a...
@ LOCAL_NON_TYPE_CHANGE_KIND
This means that a given IR artifact has a local non-type change. That is a change that is carried by ...
var_decl_sptr find_last_data_member_matching_regexp(const class_or_union &t, const regex::regex_t_sptr ®ex)
Find the last data member of a class or union which name matches a regular expression.
const ptr_to_mbr_type * is_ptr_to_mbr_type(const type_or_decl_base *t, bool look_through_qualifiers)
Test whether a type is a ptr_to_mbr_type.
const var_decl_sptr get_first_non_anonymous_data_member(const var_decl_sptr anon_dm)
Get the first non-anonymous data member of a given anonymous data member.
class_decl_sptr lookup_class_type_through_scopes(const list< string > &fqn, const translation_unit &tu)
Lookup a class type from a translation unit by walking its scopes in sequence and by looking into the...
string get_enum_flat_representation(const enum_type_decl &enum_type, const string &indent, bool one_line, bool qualified_names)
Get the flat representation of an instance of enum_type_decl type.
bool is_user_defined_type(const type_base *t)
Test if a type is user-defined.
bool operator==(const translation_unit_sptr &l, const translation_unit_sptr &r)
A deep comparison operator for pointers to translation units.
weak_ptr< class_decl > class_decl_wptr
Convenience typedef for a weak pointer on a class_decl.
string components_to_type_name(const list< string > &comps)
Turn a set of qualified name components (that name a type) into a qualified name string.
void unmark_types_as_being_compared(T &l, T &r)
Mark a pair of types as being not compared anymore.
vector< type_base_sptr > type_base_sptrs_type
Helper typedef for a vector of shared pointer to a type_base.
void debug_comp_stack(const environment &env)
Emit a trace of the two comparison operands stack on the standard error stream.
bool collect_non_anonymous_data_members(const class_or_union *cou, string_decl_base_sptr_map &dms)
Collect all the non-anonymous data members of a class or union type.
bool is_class_type(const type_or_decl_base &t)
Test whether a type is a class.
type_base_sptr synthesize_type_from_translation_unit(const type_base_sptr &type, translation_unit &tu)
In a translation unit, lookup a given type or synthesize it if it's a qualified type.
void set_member_function_virtuality(function_decl &fn, bool is_virtual, ssize_t voffset)
Set the virtual-ness of a member fcuntion.
shared_ptr< array_type_def > array_type_def_sptr
Convenience typedef for a shared pointer on a array_type_def.
function_type_sptr lookup_or_synthesize_fn_type(const function_type_sptr &fn_t, const corpus &corpus)
Look into an ABI corpus for a function type.
bool is_declaration_only_class_or_union_type(const type_base *t, bool look_through_decl_only)
Test wheter a type is a declaration-only class.
string get_pretty_representation(const type_or_decl_base *tod, bool internal)
Build and return a copy of the pretty representation of an ABI artifact that could be either a type o...
bool is_anonymous_type(const type_base *t)
Test whether a declaration is a type.
type_base_sptr lookup_class_typedef_or_enum_type(const string &qualified_name, const corpus &corp)
Look into a corpus to find a class, typedef or enum type which has a given qualified name.
type_base_sptr peel_const_qualified_type(const qualified_type_def_sptr &q)
If a qualified type is const, then return its underlying type.
const class_or_union_sptr data_member_has_anonymous_type(const var_decl &d)
Test if a data member has annonymous type or not.
type_decl * is_integral_type(const type_or_decl_base *t)
Test if a type is an integral type.
bool anonymous_data_member_exists_in_class(const var_decl &anon_dm, const class_or_union &clazz)
Test if a given anonymous data member exists in a class or union.
class_decl_sptr lookup_class_type_per_location(const interned_string &loc, const corpus &corp)
Look up a class_decl from a given corpus by its location.
void set_member_function_is_dtor(function_decl &f, bool d)
Set the destructor-ness property of a member function.
const type_base_sptr peel_array_type(const type_base_sptr &type)
Return the leaf element type of an array.
reference_type_def_sptr lookup_reference_type(const interned_string &type_name, const translation_unit &tu)
Lookup a reference type from a translation unit.
bool types_have_similar_structure(const type_base_sptr &first, const type_base_sptr &second, bool indirect_type)
Test if two types have similar structures, even though they are (or can be) different.
corpus_group_sptr is_corpus_group(const corpus_sptr &corpus)
Test if a corpus is a corpus_group.
shared_ptr< template_parameter > template_parameter_sptr
Convenience typedef for shared pointer to template parameter.
class_or_union * is_class_or_union_type(const type_or_decl_base *t)
Test if a type is a class_or_union.
var_decl_sptr get_data_member(class_or_union *clazz, const char *member_name)
Get a given data member, referred to by its name, of a class type.
type_base * look_through_decl_only_type(type_base *t)
If a type is is decl-only, then get its definition. Otherwise, just return the initial type.
const var_decl_sptr get_next_data_member(const class_or_union *klass, const var_decl_sptr &data_member)
In the context of a given class or union, this function returns the data member that is located after...
shared_ptr< class_decl > class_decl_sptr
Convenience typedef for a shared pointer on a class_decl.
type_base_sptr peel_typedef_pointer_or_reference_type(const type_base_sptr type)
Return the leaf underlying or pointed-to type node of a typedef_decl, pointer_type_def,...
void set_member_function_is_const(function_decl &f, bool is_const)
set the const-ness property of a member function.
decl_base_sptr strip_useless_const_qualification(const qualified_type_def_sptr t)
Strip qualification from a qualified type, when it makes sense.
bool is_comparison_cycle_detected(T &l, T &r)
Detect if a recursive comparison cycle is detected while structurally comparing two types (a....
bool string_to_elf_symbol_type(const string &s, elf_symbol::type &t)
Convert a string representing a symbol type into an elf_symbol::type.
namespace_decl_sptr is_namespace(const decl_base_sptr &d)
Tests if a declaration is a namespace declaration.
const type_decl * is_type_decl(const type_or_decl_base *t)
Test whether a type is a type_decl (a builtin type).
decl_base * is_decl_slow(const type_or_decl_base *t)
Test if an ABI artifact is a declaration.
decl_base_sptr look_through_decl_only(const decl_base &d)
If a decl is decl-only get its definition. Otherwise, just return nil.
function_type_sptr is_function_type(const type_or_decl_base_sptr &t)
Test whether a type is a function_type.
string get_name(const type_or_decl_base *tod, bool qualified)
Build and return a copy of the name of an ABI artifact that is either a type or a decl.
void set_member_access_specifier(decl_base &d, access_specifier a)
Sets the access specifier for a class member.
const class_decl * is_compatible_with_class_type(const type_base *t)
Test if a type is a class. This function looks through typedefs.
typedef_decl_sptr is_typedef(const type_or_decl_base_sptr t)
Test whether a type is a typedef.
abg_compat::optional< uint64_t > hash_t
The abstraction for an 8 bytes hash value.
uint64_t get_var_size_in_bits(const var_decl_sptr &v)
Get the size of a given variable.
enum_type_decl_sptr lookup_enum_type_per_location(const interned_string &loc, const corpus &corp)
Look up an enum_type_decl from a given corpus, by its location.
string get_debug_representation(const type_or_decl_base *artifact)
Get the textual representation of a type for debugging purposes.
shared_ptr< function_type > function_type_sptr
Convenience typedef for a shared pointer on a function_type.
shared_ptr< typedef_decl > typedef_decl_sptr
Convenience typedef for a shared pointer on a typedef_decl.
function_type_sptr synthesize_function_type_from_translation_unit(const function_type &fn_type, translation_unit &tu)
In a translation unit, lookup the sub-types that make up a given function type and if the sub-types a...
std::ostream & operator<<(std::ostream &o, elf_symbol::type t)
Serialize an instance of symbol_type and stream it to a given output stream.
type_base_sptr peel_pointer_type(const type_base_sptr &type)
Return the leaf pointed-to type node of a pointer_type_def node.
bool var_equals_modulo_types(const var_decl &l, const var_decl &r, change_kind *k)
Compares two instances of var_decl without taking their type into account.
class_decl_sptr lookup_class_type(const string &fqn, const translation_unit &tu)
Lookup a class type from a translation unit.
type_base_sptr lookup_type_through_translation_units(const string &qn, const corpus &abi_corpus)
Lookup a type definition in all the translation units of a given ABI corpus.
qualified_type_def_sptr is_array_of_qualified_element(const array_type_def_sptr &array)
Tests if the element of a given array is a qualified type.
void sort_types(const canonical_type_sptr_set_type &types, vector< type_base_sptr > &result)
Sort types in a hopefully stable manner.
bool is_typedef_of_maybe_qualified_class_or_union_type(const type_base *t)
Test if a type is a typedef of a class or union type, or a typedef of a qualified class or union type...
type_base * peel_pointer_or_reference_type(const type_base *type, bool peel_qual_type)
Return the leaf underlying or pointed-to type node of a, pointer_type_def, reference_type_def or qual...
reference_type_def * is_reference_type(type_or_decl_base *t, bool look_through_qualifiers)
Test whether a type is a reference_type_def.
corpus::origin operator|(corpus::origin l, corpus::origin r)
Bitwise | operator for the corpus::origin type.
bool elf_symbol_is_function(elf_symbol::type t)
Test if the type of an ELF symbol denotes a function symbol.
bool is_cplus_plus_language(translation_unit::language l)
Test if a language enumerator designates the C++ language.
bool lookup_decl_only_class_types(const interned_string &qualified_name, const corpus &corp, type_base_wptrs_type &result)
Look into a given corpus to find the class type*s* that have a given qualified name and that are decl...
bool member_function_has_vtable_offset(const function_decl &f)
Test if a virtual member function has a vtable offset set.
decl_base_sptr insert_decl_into_scope(decl_base_sptr decl, scope_decl::declarations::iterator before, scope_decl *scope)
Inserts a declaration into a given scope, before a given IR child node of the scope.
unordered_map< interned_string, bool, hash_interned_string > interned_string_bool_map_type
Convenience typedef for a map of interned_string -> bool.
const enum_type_decl * is_enum_type(const type_or_decl_base *d)
Test if a decl is an enum_type_decl.
unordered_map< interned_string, type_base_wptrs_type, hash_interned_string > istring_type_base_wptrs_map_type
A convenience typedef for a map which key is an interned_string and which value is a vector of type_b...
bool function_decl_is_less_than(const function_decl &f, const function_decl &s)
Test if the pretty representation of a given function_decl is lexicographically less then the pretty ...
bool elf_symbols_alias(const elf_symbol &s1, const elf_symbol &s2)
Test if two symbols alias.
var_decl_sptr find_data_member_from_anonymous_data_member(const var_decl_sptr &anon_dm, const string &name)
Find a data member inside an anonymous data member.
const global_scope * get_global_scope(const decl_base &decl)
return the global scope as seen by a given declaration.
shared_ptr< var_decl > var_decl_sptr
Convenience typedef for a shared pointer on a var_decl.
shared_ptr< ptr_to_mbr_type > ptr_to_mbr_type_sptr
Convenience typedef for a shared pointer to a ptr_to_mbr_type.
const location & get_natural_or_artificial_location(const decl_base *decl)
Get the non-artificial (natural) location of a decl.
size_t hash_type_or_decl(const type_or_decl_base *tod)
Hash an ABI artifact that is either a type or a decl.
method_decl_sptr copy_member_function(class_or_union_sptr t, const method_decl_sptr &method)
Copy a method of a class_or_union into a new class_or_union.
corpus::origin operator&(corpus::origin l, corpus::origin r)
Bitwise & operator for the corpus::origin type.
bool is_template_decl(const decl_base_sptr &decl)
Tests whether a decl is a template.
shared_ptr< scope_decl > scope_decl_sptr
Convenience typedef for a shared pointer on a scope_decl.
bool string_to_elf_symbol_binding(const string &s, elf_symbol::binding &b)
Convert a string representing a an elf symbol binding into an elf_symbol::binding.
shared_ptr< type_or_decl_base > type_or_decl_base_sptr
A convenience typedef for a shared_ptr to type_or_decl_base.
pointer_type_def_sptr lookup_pointer_type(const interned_string &type_name, const translation_unit &tu)
Lookup a pointer type from a translation unit.
shared_ptr< translation_unit > translation_unit_sptr
Convenience typedef for a shared pointer on a translation_unit type.
bool is_data_member_of_anonymous_class_or_union(const var_decl &d)
Test if a var_decl is a data member belonging to an anonymous type.
bool integral_type_has_harmless_name_change(const type_base_sptr &f, const type_base_sptr &s)
Test if a diff node carries a change whereby two integral types have different names in a harmless wa...
const type_base * is_void_pointer_type_equivalent(const type_base *type)
Test if a type is equivalent to a pointer to void type.
unordered_map< const function_decl *, string, function_decl_hash, function_decl::ptr_equal > fns_to_str_map_type
Convenience typedef for a hash map of pointer to function_decl and string.
lookup_entity_kind
This enum describe the kind of entity to lookup, while using the lookup API.
bool try_canonical_compare(const T *l, const T *r)
Compare two types by comparing their canonical types if present.
const decl_base_sptr lookup_var_decl_in_scope(const string &fqn, const scope_decl_sptr &skope)
Lookup a var_decl in a scope.
type_base * type_has_non_canonicalized_subtype(type_base_sptr t)
Test if a type has sub-types that are non-canonicalized.
unordered_map< string, decl_base_sptr > string_decl_base_sptr_map
Convenience typedef for a map which key is a string and which value is a decl_base_sptr.
qualified_type_def_sptr lookup_qualified_type(const interned_string &type_name, const translation_unit &tu)
Lookup a qualified type from a translation unit.
void push_composite_type_comparison_operands(const type_base &left, const type_base &right)
Push a pair of operands on the stack of operands of the current type comparison, during type canonica...
const type_base_sptr lookup_type(const interned_string &fqn, const translation_unit &tu)
Lookup a type in a translation unit.
bool is_java_language(translation_unit::language l)
Test if a language enumerator designates the Java language.
function_decl::parameter * is_function_parameter(const type_or_decl_base *tod)
Test whether a declaration is a function_decl.
bool equals(const decl_base &l, const decl_base &r, change_kind *k)
Compares two instances of decl_base.
bool get_data_member_is_laid_out(const var_decl &m)
Test whether a data member is laid out.
union_decl_sptr lookup_union_type(const interned_string &type_name, const translation_unit &tu)
Lookup a union type from a translation unit.
bool string_to_elf_symbol_visibility(const string &s, elf_symbol::visibility &v)
Convert a string representing a an elf symbol visibility into an elf_symbol::visibility.
const enum_type_decl * is_compatible_with_enum_type(const type_base *t)
Test if a type is an enum. This function looks through typedefs.
weak_ptr< elf_symbol > elf_symbol_wptr
A convenience typedef for a weak pointer to elf_symbol.
bool get_member_function_is_const(const function_decl &f)
Test whether a member function is const.
interned_string get_name_of_reference_to_type(const type_base &pointed_to_type, bool lvalue_reference, bool qualified, bool internal)
Get the name of the reference to a given type.
shared_ptr< pointer_type_def > pointer_type_def_sptr
Convenience typedef for a shared pointer on a pointer_type_def.
void maybe_update_types_lookup_map(const type_decl_sptr &basic_type)
Update the map that associates the fully qualified name of a basic type with the type itself.
bool is_enumerator_present_in_enum(const enum_type_decl::enumerator &enr, const enum_type_decl &enom)
Test if a given enumerator is found present in an enum.
bool is_const_qualified_type(const qualified_type_def_sptr &t)
Test if a given qualified type is const.
translation_unit::language string_to_translation_unit_language(const string &l)
Parse a string representing a language into a translation_unit::language enumerator into a string.
type_base_sptr lookup_type_per_location(const interned_string &loc, const corpus &corp)
Lookup a type from a corpus, by its location.
bool get_next_data_member_offset(const class_or_union *klass, const var_decl_sptr &dm, uint64_t &offset)
Get the offset of the non-static data member that comes after a given one.
uint64_t get_absolute_data_member_offset(const var_decl &m)
Get the absolute offset of a data member.
shared_ptr< ir_traversable_base > ir_traversable_base_sptr
Convenience typedef for a shared pointer to ir_traversable_base.
bool is_member_function(const function_decl &f)
Test whether a function_decl is a member function.
const function_decl::parameter * get_function_parameter(const decl_base *fun, unsigned parm_index)
Get the function parameter designated by its index.
var_decl * is_var_decl(const type_or_decl_base *tod)
Tests if a declaration is a variable declaration.
bool is_c_language(translation_unit::language l)
Test if a language enumerator designates the C language.
decl_base * is_decl(const type_or_decl_base *d)
Test if an ABI artifact is a declaration.
void keep_type_alive(type_base_sptr t)
Make sure that the life time of a given (smart pointer to a) type is the same as the life time of the...
method_decl * is_method_decl(const type_or_decl_base *d)
Test if a function_decl is actually a method_decl.
array_type_def_sptr lookup_array_type(const interned_string &type_name, const translation_unit &tu)
Lookup an array type from a translation unit.
bool is_member_type(const type_base_sptr &t)
Tests if a type is a class member.
string get_class_or_union_flat_representation(const class_or_union &cou, const string &indent, bool one_line, bool internal, bool qualified_names)
Get the flat representation of an instance of class_or_union type.
decl_base_sptr add_decl_to_scope(decl_base_sptr decl, scope_decl *scope)
Appends a declaration to a given scope, if the declaration doesn't already belong to one and if the d...
string build_internal_underlying_enum_type_name(const string &base_name, bool is_anonymous, uint64_t size)
Build the internal name of the underlying type of an enum.
bool is_npaf_type(const type_base_sptr &t)
Test if a type is a neither a pointer, an array nor a function type.
access_specifier get_member_access_specifier(const decl_base &d)
Gets the access specifier for a class member.
shared_ptr< enum_type_decl > enum_type_decl_sptr
Convenience typedef for shared pointer to a enum_type_decl.
void set_data_member_offset(var_decl_sptr m, uint64_t o)
Set the offset of a data member into its containing class.
type_base_sptr strip_typedef(const type_base_sptr type)
Recursively returns the the underlying type of a typedef. The return type should not be a typedef of ...
uint64_t get_data_member_offset(const var_decl &m)
Get the offset of a data member.
unordered_set< uintptr_t > pointer_set
A convenience typedef for an unordered set of pointer values.
void sort_types_for_hash_computing_and_c14n(IteratorType begin, IteratorType end)
Sort types before hashing (and then canonicalizing) them.
class_or_union * is_at_class_scope(const decl_base_sptr decl)
Tests whether a given decl is at class scope.
bool get_member_function_is_virtual(const function_decl &f)
Test if a given member function is virtual.
const pointer_type_def * is_pointer_type(const type_or_decl_base *t, bool look_through_qualifiers)
Test whether a type is a pointer_type_def.
string get_class_or_enum_flat_representation(const type_base &coe, const string &indent, bool one_line, bool internal, bool qualified_name)
Get the flat representation of an instance of enum_type_decl type.
class_or_union * anonymous_data_member_to_class_or_union(const var_decl *d)
Get the class_or_union type of a given anonymous data member.
location get_location(const type_base_sptr &type)
Get the location of the declaration of a given type.
pointer_type_def_sptr is_pointer_to_function_type(const type_base_sptr &t)
Test if a type is a pointer to function type.
translation_unit * get_translation_unit(const type_or_decl_base &t)
Return the translation unit a declaration belongs to.
weak_ptr< decl_base > decl_base_wptr
Convenience typedef for a weak pointer to a decl_base.
var_decl_sptr has_fake_flexible_array_data_member(const class_decl &klass)
Test if the last data member of a class is an array with one element.
interned_string get_function_type_name(const function_type_sptr &fn_type, bool internal)
Get the name of a given function type and return a copy of it.
bool is_function_template_pattern(const shared_ptr< decl_base > decl)
Test whether a decl is the pattern of a function template.
class_or_union * look_through_decl_only_class(class_or_union *the_class)
If a class (or union) is a decl-only class, get its definition. Otherwise, just return the initial cl...
bool is_union_type(const type_or_decl_base &t)
Test if a type is a union_decl.
const location & get_artificial_or_natural_location(const decl_base *decl)
Get the artificial location of a decl.
enum_type_decl_sptr lookup_enum_type(const interned_string &type_name, const translation_unit &tu)
Lookup an enum type from a translation unit.
type_base_sptr peel_typedef_type(const type_base_sptr &type)
Return the leaf underlying type node of a typedef_decl node.
const type_base_wptrs_type * lookup_union_types(const interned_string &qualified_name, const corpus &corp)
Look into a given corpus to find the union type*s* that have a given qualified name.
var_decl_sptr copy_member_variable(class_or_union_sptr t, const var_decl *variable)
Copy a data member of a class_or_union into a new class_or_union.
interned_string get_name_of_qualified_type(const type_base_sptr &underlying_type, qualified_type_def::CV quals, bool qualified, bool internal)
Get the name of a qualified type, given the underlying type and its qualifiers.
shared_ptr< template_decl > template_decl_sptr
Convenience typedef for a shared pointer to template_decl.
array_type_def_sptr is_typedef_of_array(const type_base_sptr &t)
Test if a type is a typedef of an array.
function_type_sptr lookup_function_type(const interned_string &type_name, const translation_unit &tu)
Lookup a function type from a translation unit.
bool is_global_scope(const scope_decl &scope)
Tests whether if a given scope is the global scope.
string get_string_representation_of_cv_quals(const qualified_type_def::CV cv_quals)
Get the string representation of a CV qualifier bitmap.
void set_data_member_is_laid_out(var_decl_sptr m, bool l)
Set a flag saying if a data member is laid out.
pointer_type_def_sptr is_pointer_to_ptr_to_mbr_type(const type_base_sptr &t)
Test if we are looking at a pointer to pointer to member type.
bool is_data_member(const var_decl &v)
Test if a var_decl is a data member.
var_decl_sptr find_first_data_member_matching_regexp(const class_or_union &t, const regex::regex_t_sptr &r)
Find the first data member of a class or union which name matches a regular expression.
const type_base_wptrs_type * lookup_class_types(const interned_string &qualified_name, const corpus &corp)
Look into a given corpus to find the class type*s* that have a given qualified name.
const decl_base * get_type_declaration(const type_base *t)
Get the declaration for a given type.
var_decl_sptr has_flexible_array_data_member(const class_decl &klass)
Test if the last data member of a class is an array with non-finite data member.
void set_member_is_static(decl_base &d, bool s)
Sets the static-ness property of a class member.
array_type_def * is_array_type(const type_or_decl_base *type, bool look_through_qualifiers)
Test if a type is an array_type_def.
interned_string get_method_type_name(const method_type_sptr fn_type, bool internal)
Get the name of a given method type and return a copy of it.
weak_ptr< template_decl > template_decl_wptr
Convenience typedef for a weak pointer to template_decl.
const var_decl * lookup_data_member(const type_base *type, const char *dm_name)
Look for a data member of a given class, struct or union type and return it.
interned_string get_function_id_or_pretty_representation(const function_decl *fn)
Get the ID of a function, or, if the ID can designate several different functions,...
shared_ptr< type_decl > type_decl_sptr
Convenience typedef for a shared pointer on a type_decl.
typedef_decl_sptr clone_typedef(const typedef_decl_sptr &t)
Clone a typedef type.
type_decl_sptr lookup_basic_type_per_location(const interned_string &loc, const corpus &corp)
Lookup a type_decl type from a given corpus, by its location.
bool compare_using_locations(const decl_base *f, const decl_base *s)
Compare decls using their locations.
bool classes_have_same_layout(const type_base_sptr &f, const type_base_sptr &s)
Test if two classes have the same layout.
const type_base_sptr lookup_type_through_scopes(const type_base_sptr type, const translation_unit &tu)
Lookup a type from a translation unit by walking the scopes of the translation unit in sequence and l...
type_or_decl_base * debug(const type_or_decl_base *artifact)
Emit a textual representation of an artifact to std error stream for debugging purposes.
unordered_set< type_base_sptr, canonical_type_hash > canonical_type_sptr_set_type
Helper typedef for an unordered set of type_base_sptr which uses pointer value to tell its members ap...
bool return_comparison_result(T &l, T &r, bool value)
Return the result of the comparison of two (sub) types.
shared_ptr< namespace_decl > namespace_decl_sptr
Convenience typedef for a shared pointer on namespace_decl.
bool is_ada_language(translation_unit::language l)
Test if a language enumerator designates the Ada language.
string demangle_cplus_mangled_name(const string &mangled_name)
Demangle a C++ mangled name and return the resulting string.
bool is_unique_type(const type_base_sptr &t)
Test if a type is unique in the entire environment.
bool types_are_compatible(const type_base_sptr type1, const type_base_sptr type2)
Test if two types are equal modulo a typedef or CV qualifiers.
void mark_types_as_being_compared(T &l, T &r)
Mark a pair of types as being compared.
interned_string get_type_name(const type_base_sptr &t, bool qualified, bool internal)
Get the name of a given type and return a copy of it.
const scope_decl * get_top_most_scope_under(const decl_base *decl, const scope_decl *scope)
Return the a scope S containing a given declaration and that is right under a given scope P.
corpus::origin operator&=(corpus::origin &l, corpus::origin r)
Bitwise &= operator for the corpus::origin type.
type_base_sptr clone_array_tree(const type_base_sptr t)
Clone a type tree made of an array or a typedef of array.
bool operator!=(const translation_unit_sptr &l, const translation_unit_sptr &r)
A deep inequality operator for pointers to translation units.
interned_string get_name_of_pointer_to_type(const type_base &pointed_to_type, bool qualified, bool internal)
Get the name of the pointer to a given type.
bool decl_name_changed(const type_or_decl_base *a1, const type_or_decl_base *a2)
Test if two decls have different names.
bool is_at_template_scope(const shared_ptr< decl_base > decl)
Tests whether a given decl is at template scope.
typedef_decl_sptr lookup_typedef_type_per_location(const interned_string &loc, const corpus &corp)
Lookup a typedef_decl from a corpus, by its location.
function_decl * is_function_decl(const type_or_decl_base *d)
Test whether a declaration is a function_decl.
bool elf_symbol_is_variable(elf_symbol::type t)
Test if the type of an ELF symbol denotes a function symbol.
bool type_has_sub_type_changes(const type_base_sptr t_v1, const type_base_sptr t_v2)
Tests if the change of a given type effectively comes from just its sub-types. That is,...
bool maybe_update_types_lookup_map< class_decl >(const class_decl_sptr &class_type, istring_type_base_wptrs_map_type &map, bool use_type_name_as_key)
This is the specialization for type class_decl of the function template:
method_type_sptr is_method_type(const type_or_decl_base_sptr &t)
Test whether a type is a method_type.
qualified_type_def * is_qualified_type(const type_or_decl_base *t)
Test whether a type is a reference_type_def.
typedef_decl_sptr lookup_typedef_type(const interned_string &type_name, const translation_unit &tu)
Lookup a typedef type from a translation unit.
bool is_typedef_ptr_or_ref_to_decl_only_class_or_union_type(const type_base *t)
Test if a type is a typedef, pointer or reference to a decl-only class/union.
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.
union_decl_sptr lookup_union_type_per_location(const interned_string &loc, const corpus &corp)
Lookup a union type in a given corpus, from its location.
bool class_or_union_types_of_same_kind(const class_or_union *first, const class_or_union *second)
Test if two class or union types are of the same kind.
string build_qualified_name(const scope_decl *scope, const string &name)
Build and return a qualified name from a name and its scope.
bool is_ptr_ref_or_qual_type(const type_base *t)
Helper to detect if a type is either a reference, a pointer, or a qualified type.
enum_type_decl_sptr look_through_decl_only_enum(const enum_type_decl &the_enum)
If an enum is a decl-only enum, get its definition. Otherwise, just return the initial enum.
shared_ptr< function_tdecl > function_tdecl_sptr
Convenience typedef for a shared pointer on a function_tdecl.
type_base * peel_qualified_or_typedef_type(const type_base *type)
Return the leaf underlying type of a qualified or typedef type.
type_base_sptr type_or_void(const type_base_sptr t, const environment &env)
Return either the type given in parameter if it's non-null, or the void type.
bool is_at_global_scope(const decl_base &decl)
Tests whether a given declaration is at global scope.
type_decl * is_real_type(const type_or_decl_base *t)
Test if a type is a real type.
bool is_member_decl(const decl_base_sptr d)
Tests if a declaration is a class member.
bool maybe_compare_as_member_decls(const decl_base &l, const decl_base &r, change_kind *k)
Compare the properties that belong to the "is-a-member-relation" of a decl.
bool get_member_function_is_ctor(const function_decl &f)
Test whether a member function is a constructor.
void set_member_function_is_ctor(function_decl &f, bool c)
Setter for the is_ctor property of the member function.
bool is_declaration_only_class_type(const type_base_sptr &t, bool look_through_decl_only)
Test wheter a type is a declaration-only class.
bool match(const regex_t_sptr &r, const std::string &str)
See if a string matches a regex.
std::shared_ptr< regex_t > regex_t_sptr
A convenience typedef for a shared pointer of regex_t.
Toplevel namespace for libabigail.
bool operator==(const std::string &l, const interned_string &r)
Equality operator.
std::string operator+(const interned_string &s1, const std::string &s2)
Concatenation operator.
unordered_map< string, string * > pool_map_type
Convenience typedef for a map of string -> string*.
A functor to hash instances of interned_string.
size_t operator()(const type_base_sptr &l) const
Hash a type by returning the pointer value of its canonical type.
Hasher for the class_or_union type.
bool is_printing_flat_representation() const
Getter of the 'is_printing_flat_representation_' boolean.
void unset_printing_flat_representation()
Set the 'is_printing_flat_representation_' boolean to false.
void set_printing_flat_representation()
Set the 'is_printing_flat_representation_' boolean to true.
A functor to sort decls somewhat topologically. That is, types are sorted in a way that makes the one...
The private data of the environment type.
Equality functor for instances of function_decl.
The hashing functor for function_type.
The type of the private data of the function_type type.
virtual bool traverse(ir_node_visitor &v)
Traverse a given IR node and its children, calling an visitor on each node.
The hashing functor for member_base.
Private type to hold private members of translation_unit.
Hash functor for instances of type_base.
Definition of the private data of type_base.
The private data of type_or_decl_base.
A predicate for deep equality of instances of shared_ptr<type_base>
A functor to sort types somewhat topologically. That is, types are sorted in a way that makes the one...
A deleter for shared pointers that ... doesn't delete the object managed by the shared pointer.