/* Copyright 2017 - 2021 R. Thomas * Copyright 2017 - 2021 Quarkslab * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ #include "pyPE.hpp" #include "LIEF/PE/hash.hpp" #include "LIEF/PE/Import.hpp" #include #include namespace LIEF { namespace PE { template using getter_t = T (Import::*)(void) const; template using setter_t = void (Import::*)(T); template using no_const_getter = T (Import::*)(void); template using no_const_func = T (Import::*)(P); template<> void create(py::module& m) { py::class_(m, "Import") .def(py::init<>(), "Default constructor with a library name") .def(py::init(), "Constructor with a library name", "library_name"_a) .def_property_readonly("entries", static_cast>(&Import::entries), "Iterator to the imported " RST_CLASS_REF(lief.PE.ImportEntry) " (functions)", py::return_value_policy::reference) .def_property("name", [] (const Import& obj) { return safe_string_converter(obj.name()); }, static_cast>(&Import::name), "Library name (e.g. ``kernel32.dll``)", py::return_value_policy::reference) .def_property_readonly("directory", static_cast>(&Import::directory), "" RST_CLASS_REF(lief.PE.DataDirectory) " associated with the import table", py::return_value_policy::reference) .def_property_readonly("iat_directory", static_cast>(&Import::iat_directory), "" RST_CLASS_REF(lief.PE.DataDirectory) " associated with the ``IAT`` table", py::return_value_policy::reference) .def_property("import_address_table_rva", static_cast>(&Import::import_address_table_rva), static_cast>(&Import::import_address_table_rva), "The RVA of the import address table. The contents of " "this table are **identical** to the contents of the import " "lookup table until the image is bound.") .def_property("import_lookup_table_rva", static_cast>(&Import::import_lookup_table_rva), static_cast>(&Import::import_lookup_table_rva), "The RVA of the import lookup table. This table " "contains a :attr:`~lief.PE.ImportEntry.name` or :attr:`~lief.PE.ImportEntry.ordinal` for each import.") .def("get_function_rva_from_iat", &Import::get_function_rva_from_iat, "Return the relative virtual address of the given function within the *Import Address Table*" "function_name"_a) .def("add_entry", static_cast(&Import::add_entry), "Add an " RST_CLASS_REF(lief.PE.ImportEntry) " (function) to the current import", "entry"_a, py::return_value_policy::reference) .def("add_entry", static_cast(&Import::add_entry), "Add an " RST_CLASS_REF(lief.PE.ImportEntry) " (function) to the current import", "function_name"_a, py::return_value_policy::reference) .def("get_entry", static_cast>(&Import::get_entry), "Return " RST_CLASS_REF(lief.PE.ImportEntry) " with the given name", "function_name"_a, py::return_value_policy::reference) .def("__eq__", &Import::operator==) .def("__ne__", &Import::operator!=) .def("__hash__", [] (const Import& import) { return Hash::hash(import); }) .def("__str__", [] (const Import& import) { std::ostringstream stream; stream << import; std::string str = stream.str(); return str; }); } } }