diff options
author | Egor Tensin <Egor.Tensin@gmail.com> | 2021-05-29 01:24:29 +0300 |
---|---|---|
committer | Egor Tensin <Egor.Tensin@gmail.com> | 2021-05-29 01:27:53 +0300 |
commit | e162f2a21632e3f7b1c7ab9dd7b530beb1f2d4a8 (patch) | |
tree | 65199bce3779ff1800821c6b1c6bc0bc4592e66c /src/post_mortem.cpp | |
parent | namespace pdb -> namespace winapi (diff) | |
download | winapi-debug-e162f2a21632e3f7b1c7ab9dd7b530beb1f2d4a8.tar.gz winapi-debug-e162f2a21632e3f7b1c7ab9dd7b530beb1f2d4a8.zip |
rename class Repo to PostMortem
Diffstat (limited to '')
-rw-r--r-- | src/post_mortem.cpp (renamed from src/repo.cpp) | 30 |
1 files changed, 15 insertions, 15 deletions
diff --git a/src/repo.cpp b/src/post_mortem.cpp index 24d9e59..d365b02 100644 --- a/src/repo.cpp +++ b/src/post_mortem.cpp @@ -86,7 +86,7 @@ const Module& guess_module(const std::map<Address, Value>& modules, Address pivo } // namespace -Address Repo::add_pdb(Address online_base, const std::string& path) { +Address PostMortem::add_pdb(Address online_base, const std::string& path) { if (online_bases.find(online_base) != online_bases.cend()) throw std::runtime_error{pdb_already_loaded(online_base, path)}; @@ -107,64 +107,64 @@ Address Repo::add_pdb(Address online_base, const std::string& path) { return offline_base; } -void Repo::enum_symbols(const OnSymbol& callback) const { +void PostMortem::enum_symbols(const OnSymbol& callback) const { for (const auto& it : offline_bases) enum_symbols(it.second, callback); } -void Repo::enum_symbols(Address offline_base, const OnSymbol& callback) const { +void PostMortem::enum_symbols(Address offline_base, const OnSymbol& callback) const { const auto it = offline_bases.find(offline_base); if (it == offline_bases.cend()) throw std::runtime_error{"unknown module"}; enum_symbols(it->second, callback); } -void Repo::enum_symbols(const Module& module, const OnSymbol& callback) const { +void PostMortem::enum_symbols(const Module& module, const OnSymbol& callback) const { dbghelp.enum_symbols( module, [&](const SymbolInfo& impl) { callback(symbol_from_buffer(module, impl)); }); } -Symbol Repo::resolve_symbol(Address online) const { +Symbol PostMortem::resolve_symbol(Address online) const { return symbol_from_buffer(dbghelp.resolve_symbol(address_online_to_offline(online))); } -Symbol Repo::resolve_symbol(const std::string& name) const { +Symbol PostMortem::resolve_symbol(const std::string& name) const { return symbol_from_buffer(dbghelp.resolve_symbol(name)); } -LineInfo Repo::resolve_line(Address online) const { +LineInfo PostMortem::resolve_line(Address online) const { return dbghelp.resolve_line(address_online_to_offline(online)); } -const Module& Repo::module_with_online_base(Address base) const { +const Module& PostMortem::module_with_online_base(Address base) const { return lookup_module(online_bases, base); } -const Module& Repo::module_with_offline_base(Address base) const { +const Module& PostMortem::module_with_offline_base(Address base) const { return lookup_module(offline_bases, base); } -Symbol Repo::symbol_from_buffer(const SymbolInfo& impl) const { +Symbol PostMortem::symbol_from_buffer(const SymbolInfo& impl) const { return symbol_from_buffer(module_with_offline_base(impl.get_offline_base()), impl); } -Symbol Repo::symbol_from_buffer(const Module& module, const SymbolInfo& impl) { +Symbol PostMortem::symbol_from_buffer(const Module& module, const SymbolInfo& impl) { return {module.translate_offline_address(impl.get_offline_address()), impl}; } -Address Repo::address_online_to_offline(Address online) const { +Address PostMortem::address_online_to_offline(Address online) const { return module_from_online_address(online).translate_online_address(online); } -Address Repo::address_offline_to_online(Address offline) const { +Address PostMortem::address_offline_to_online(Address offline) const { return module_from_offline_address(offline).translate_offline_address(offline); } -const Module& Repo::module_from_online_address(Address online) const { +const Module& PostMortem::module_from_online_address(Address online) const { return guess_module(online_bases, online); } -const Module& Repo::module_from_offline_address(Address offline) const { +const Module& PostMortem::module_from_offline_address(Address offline) const { return guess_module(offline_bases, offline); } |