blob: 94521881f82f9e7377736923fca5ac5805076472 [file] [log] [blame]
//===-- SBSymbol.h ----------------------------------------------*- C++ -*-===//
//
// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
// See https://llvm.org/LICENSE.txt for license information.
// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
//
//===----------------------------------------------------------------------===//
#ifndef LLDB_API_SBSYMBOL_H
#define LLDB_API_SBSYMBOL_H
#include "lldb/API/SBAddress.h"
#include "lldb/API/SBDefines.h"
#include "lldb/API/SBInstructionList.h"
#include "lldb/API/SBTarget.h"
namespace lldb {
class LLDB_API SBSymbol {
public:
SBSymbol();
~SBSymbol();
SBSymbol(const lldb::SBSymbol &rhs);
const lldb::SBSymbol &operator=(const lldb::SBSymbol &rhs);
explicit operator bool() const;
bool IsValid() const;
const char *GetName() const;
const char *GetDisplayName() const;
const char *GetMangledName() const;
lldb::SBInstructionList GetInstructions(lldb::SBTarget target);
lldb::SBInstructionList GetInstructions(lldb::SBTarget target,
const char *flavor_string);
/// Get the start address of this symbol
///
/// \returns
/// If the symbol's value is not an address, an invalid SBAddress object
/// will be returned. If the symbol's value is an address, a valid SBAddress
/// object will be returned.
SBAddress GetStartAddress();
/// Get the end address of this symbol
///
/// \returns
/// If the symbol's value is not an address, an invalid SBAddress object
/// will be returned. If the symbol's value is an address, a valid SBAddress
/// object will be returned.
SBAddress GetEndAddress();
/// Get the raw value of a symbol.
///
/// This accessor allows direct access to the symbol's value from the symbol
/// table regardless of what the value is. The value can be a file address or
/// it can be an integer value that depends on what the symbol's type is. Some
/// symbol values are not addresses, but absolute values or integer values
/// that can be mean different things. The GetStartAddress() accessor will
/// only return a valid SBAddress if the symbol's value is an address, so this
/// accessor provides a way to access the symbol's value when the value is
/// not an address.
///
/// \returns
/// Returns the raw integer value of a symbol from the symbol table.
uint64_t GetValue();
/// Get the size of the symbol.
///
/// This accessor allows direct access to the symbol's size from the symbol
/// table regardless of what the value is (address or integer value).
///
/// \returns
/// Returns the size of a symbol from the symbol table.
uint64_t GetSize();
uint32_t GetPrologueByteSize();
SymbolType GetType();
bool operator==(const lldb::SBSymbol &rhs) const;
bool operator!=(const lldb::SBSymbol &rhs) const;
bool GetDescription(lldb::SBStream &description);
// Returns true if the symbol is externally visible in the module that it is
// defined in
bool IsExternal();
// Returns true if the symbol was synthetically generated from something
// other than the actual symbol table itself in the object file.
bool IsSynthetic();
protected:
lldb_private::Symbol *get();
void reset(lldb_private::Symbol *);
private:
friend class SBAddress;
friend class SBFrame;
friend class SBModule;
friend class SBSymbolContext;
SBSymbol(lldb_private::Symbol *lldb_object_ptr);
void SetSymbol(lldb_private::Symbol *lldb_object_ptr);
lldb_private::Symbol *m_opaque_ptr = nullptr;
};
} // namespace lldb
#endif // LLDB_API_SBSYMBOL_H