Go to the documentation of this file.
15#ifndef LIEF_DWARF_FUNCTION_H
16#define LIEF_DWARF_FUNCTION_H
46 using iterator_category = std::bidirectional_iterator_tag;
47 using value_type = std::unique_ptr<Function>;
48 using difference_type = std::ptrdiff_t;
49 using pointer = Function*;
50 using reference = std::unique_ptr<Function>&;
51 using implementation = details::FunctionIt;
55 friend class Iterator;
62 template <
typename RefT>
63 PointerProxy(RefT &&R) : R(std::forward<RefT>(R)) {}
68 Iterator(std::unique_ptr<details::FunctionIt> impl);
71 friend
LIEF_API bool operator==(const Iterator& LHS, const Iterator& RHS);
73 friend
LIEF_API bool operator!=(const Iterator& LHS, const Iterator& RHS) {
81 Iterator tmp = *
static_cast<Iterator*
>(
this);
82 --*
static_cast<Iterator *
>(
this);
87 Iterator tmp = *
static_cast<Iterator*
>(
this);
88 ++*
static_cast<Iterator *
>(
this);
95 return static_cast<const Iterator*
>(
this)->
operator*();
99 std::unique_ptr<details::FunctionIt> impl_;
101 using vars_it = iterator_range<Variable::Iterator>;
104 using parameters_t = std::vector<std::unique_ptr<Parameter>>;
105 using thrown_types_t = std::vector<std::unique_ptr<Type>>;
107 using instructions_it = iterator_range<assembly::Instruction::Iterator>;
110 std::string
name()
const;
119 result<uint64_t>
address()
const;
135 uint64_t
size()
const;
138 std::vector<range_t>
ranges()
const;
144 std::unique_ptr<Type>
type()
const;
165 std::unique_ptr<Scope>
scope()
const;
175 std::unique_ptr<details::Function> impl_;
pointer operator->() const
Definition DWARF/Function.hpp:57
Iterator operator++(int)
Definition DWARF/Function.hpp:86
std::unique_ptr< Function > operator*() const
Iterator(Iterator &&) noexcept
Iterator operator--(int)
Definition DWARF/Function.hpp:80
PointerProxy operator->() const
Definition DWARF/Function.hpp:94
Iterator(const Iterator &)
This class represents a DWARF function which can be associated with either: DW_TAG_subprogram or DW_T...
Definition DWARF/Function.hpp:42
instructions_it instructions() const
Disassemble the current function by returning an iterator over the assembly::Instruction.
vars_it variables() const
Return an iterator of variables (DW_TAG_variable) defined within the scope of this function....
thrown_types_t thrown_types() const
List of exceptions (types) that can be thrown by the function.
std::unique_ptr< Type > type() const
Return the dwarf::Type associated with the return type of this function.
std::unique_ptr< Scope > scope() const
Return the scope in which this function is defined.
Function(std::unique_ptr< details::Function > impl)
std::string name() const
The name of the function (DW_AT_name)
bool is_external() const
Whether the function is defined outside the current compilation unit (DW_AT_external).
result< uint64_t > address() const
Return the address of the function (DW_AT_entry_pc or DW_AT_low_pc).
debug_location_t debug_location() const
Original source code location.
std::vector< range_t > ranges() const
Ranges of virtual addresses owned by this function.
parameters_t parameters() const
Return the function's parameters (including any template parameter)
uint64_t size() const
Return the size taken by this function in the binary.
std::string linkage_name() const
The name of the function which is used for linking (DW_AT_linkage_name).
bool is_artificial() const
Whether this function is created by the compiler and not present in the original source code.
This class represents a DWARF parameter which can be either:
Definition Parameter.hpp:36
This class materializes a scope in which Function, Variable, Type, ... can be defined.
Definition Scope.hpp:32
Definition DWARF/CompilationUnit.hpp:30
Namespace for the DWARF debug format.
Definition DWARF/CompilationUnit.hpp:28
LIEF namespace.
Definition Abstract/Binary.hpp:36
#define LIEF_API
Definition visibility.h:41