LIEF/api/python/Abstract/objects/pyParser.cpp
2020-04-21 16:54:23 +03:00

112 lines
3.3 KiB
C++

/* Copyright 2017 R. Thomas
* Copyright 2017 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 "pyAbstract.hpp"
#include "LIEF/Abstract/Parser.hpp"
#include <string>
namespace LIEF {
template<>
void create<Parser>(py::module& m) {
m.def("parse",
[] (py::bytes bytes, const std::string& name) {
std::string raw_str = bytes;
std::vector<uint8_t> raw = {
std::make_move_iterator(std::begin(raw_str)),
std::make_move_iterator(std::end(raw_str))
};
std::unique_ptr<Binary> binary;
Py_BEGIN_ALLOW_THREADS
binary = Parser::parse(std::move(raw), name);
Py_END_ALLOW_THREADS
return binary;
},
"Parse the given binary and return a " RST_CLASS_REF(lief.Binary) " object",
"raw"_a, "name"_a = "",
py::return_value_policy::take_ownership);
m.def("parse",
[] (const std::string& name) {
std::unique_ptr<Binary> binary;
Py_BEGIN_ALLOW_THREADS
binary = Parser::parse(name);
Py_END_ALLOW_THREADS
return binary;
},
"Parse the given binary and return a " RST_CLASS_REF(lief.Binary) " object",
"filepath"_a,
py::return_value_policy::take_ownership);
m.def("parse",
[](const std::vector<uint8_t>& raw, const std::string& name) {
std::unique_ptr<Binary> binary;
Py_BEGIN_ALLOW_THREADS
binary = Parser::parse(raw, name);
Py_END_ALLOW_THREADS
return binary;
},
"Parse the given binary and return a " RST_CLASS_REF(lief.Binary) " object",
"raw"_a, "name"_a = "",
py::return_value_policy::take_ownership);
m.def("parse",
[] (py::object byteio, const std::string& name) {
auto&& io = py::module::import("io");
auto&& RawIOBase = io.attr("RawIOBase");
auto&& BufferedIOBase = io.attr("BufferedIOBase");
auto&& TextIOBase = io.attr("TextIOBase");
py::object rawio;
if (py::isinstance(byteio, RawIOBase)) {
rawio = byteio;
}
else if (py::isinstance(byteio, BufferedIOBase)) {
rawio = byteio.attr("raw");
}
else if (py::isinstance(byteio, TextIOBase)) {
rawio = byteio.attr("buffer").attr("raw");
}
else {
throw py::type_error(py::repr(byteio).cast<std::string>().c_str());
}
std::string raw_str = static_cast<py::bytes>(rawio.attr("readall")());
std::vector<uint8_t> raw = {
std::make_move_iterator(std::begin(raw_str)),
std::make_move_iterator(std::end(raw_str))
};
std::unique_ptr<Binary> binary;
Py_BEGIN_ALLOW_THREADS
binary = Parser::parse(std::move(raw), name);
Py_END_ALLOW_THREADS
return binary;
},
"io"_a,
"name"_a = "",
py::return_value_policy::take_ownership);
}
}