blob: dad53001bd32ae5d0b937e2ba1a340662724f603 (
plain) (
tree)
|
|
// Copyright (c) 2017 Egor Tensin <Egor.Tensin@gmail.com>
// This file is part of the "PDB repository" project.
// For details, see https://github.com/egor-tensin/pdb-repo.
// Distributed under the MIT License.
#include "command_line.hpp"
#include "pdb/all.hpp"
#include "pdb_descr.hpp"
#include <boost/program_options.hpp>
#include <exception>
#include <iostream>
#include <string>
#include <vector>
namespace {
class EnumSymbols : public SettingsParser {
public:
explicit EnumSymbols(const std::string& argv0) : SettingsParser{argv0} {
namespace po = boost::program_options;
visible.add_options()(
"pdb", po::value<std::vector<PDB>>(&pdbs)->value_name("ADDR,PATH"), "load a PDB file");
visible.add_options()(
"functions",
po::value<pdb::symbol::Tag>(&tag)->implicit_value(function_tag)->zero_tokens(),
"only list functions");
}
const char* get_short_description() const override {
return "[-h|--help] [--pdb ADDR,PATH]... [--functions]";
}
std::vector<PDB> pdbs;
bool type_specified() const { return tag != reserved_tag; }
pdb::Symbol::Type get_type() const { return static_cast<pdb::Symbol::Type>(tag); }
private:
static constexpr auto reserved_tag = static_cast<pdb::symbol::Tag>(pdb::Symbol::Type::RESERVED);
static constexpr auto function_tag = static_cast<pdb::symbol::Tag>(pdb::Symbol::Type::Function);
pdb::symbol::Tag tag = reserved_tag;
};
constexpr pdb::symbol::Tag EnumSymbols::reserved_tag;
constexpr pdb::symbol::Tag EnumSymbols::function_tag;
} // namespace
int main(int argc, char* argv[]) {
try {
EnumSymbols settings{argv[0]};
try {
settings.parse(argc, argv);
} catch (const boost::program_options::error& e) {
settings.usage_error(e);
return 1;
}
if (settings.exit_with_usage) {
settings.usage();
return 0;
}
pdb::Repo repo;
for (const auto& pdb : settings.pdbs) {
const auto id = repo.add_pdb(pdb.online_base, pdb.path);
repo.enum_symbols(id, [&](const pdb::Symbol& symbol) {
if (!settings.type_specified() || settings.get_type() == symbol.get_type())
std::cout << symbol.get_name() << '\n';
});
}
} catch (const std::exception& e) {
std::cerr << "error: " << e.what() << '\n';
return 1;
}
return 0;
}
|