You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
133 lines
4.1 KiB
133 lines
4.1 KiB
11 years ago
|
#include <boost/python.hpp>
|
||
|
#include <boost/python/stl_iterator.hpp>
|
||
|
#include <Python.h>
|
||
|
#include <libserpent/funcs.h>
|
||
|
|
||
|
// Provide a python wrapper for the C++ functions
|
||
|
|
||
|
using namespace boost::python;
|
||
|
|
||
|
//std::vector to python list converter
|
||
|
//http://stackoverflow.com/questions/5314319/how-to-export-stdvector
|
||
|
template<class T>
|
||
|
struct VecToList
|
||
|
{
|
||
|
static PyObject* convert(const std::vector<T>& vec)
|
||
|
{
|
||
|
boost::python::list* l = new boost::python::list();
|
||
|
for(size_t i = 0; i < vec.size(); i++)
|
||
|
(*l).append(vec[i]);
|
||
|
|
||
|
return l->ptr();
|
||
|
}
|
||
|
};
|
||
|
|
||
|
// python list to std::vector converter
|
||
|
//http://code.activestate.com/lists/python-cplusplus-sig/16463/
|
||
|
template<typename T>
|
||
|
struct Vector_from_python_list
|
||
|
{
|
||
|
|
||
|
Vector_from_python_list()
|
||
|
{
|
||
|
using namespace boost::python;
|
||
|
using namespace boost::python::converter;
|
||
|
registry::push_back(&Vector_from_python_list<T>::convertible,
|
||
|
&Vector_from_python_list<T>::construct,
|
||
|
type_id<std::vector<T>
|
||
|
>());
|
||
|
|
||
|
}
|
||
|
|
||
|
// Determine if obj_ptr can be converted in a std::vector<T>
|
||
|
static void* convertible(PyObject* obj_ptr)
|
||
|
{
|
||
|
if (!PyList_Check(obj_ptr)){
|
||
|
return 0;
|
||
|
}
|
||
|
return obj_ptr;
|
||
|
}
|
||
|
|
||
|
// Convert obj_ptr into a std::vector<T>
|
||
|
static void construct(
|
||
|
PyObject* obj_ptr,
|
||
|
boost::python::converter::rvalue_from_python_stage1_data* data)
|
||
|
{
|
||
|
using namespace boost::python;
|
||
|
// Extract the character data from the python string
|
||
|
// const char* value = PyString_AsString(obj_ptr);
|
||
|
list l(handle<>(borrowed(obj_ptr)));
|
||
|
|
||
|
// // Verify that obj_ptr is a string (should be ensured by convertible())
|
||
|
// assert(value);
|
||
|
|
||
|
// Grab pointer to memory into which to construct the new std::vector<T>
|
||
|
void* storage = (
|
||
|
(boost::python::converter::rvalue_from_python_storage<std::vector<T>
|
||
|
>*)
|
||
|
|
||
|
data)->storage.bytes;
|
||
|
|
||
|
// in-place construct the new std::vector<T> using the character data
|
||
|
// extraced from the python object
|
||
|
std::vector<T>& v = *(new (storage) std::vector<T>());
|
||
|
|
||
|
// populate the vector from list contains !!!
|
||
|
int le = len(l);
|
||
|
v.resize(le);
|
||
|
for(int i = 0;i!=le;++i){
|
||
|
v[i] = extract<T>(l[i]);
|
||
|
}
|
||
|
|
||
|
// Stash the memory chunk pointer for later use by boost.python
|
||
|
data->convertible = storage;
|
||
|
}
|
||
|
};
|
||
|
|
||
|
std::string printMetadata(Metadata m) {
|
||
|
return "["+m.file+" "+intToDecimal(m.ln)+" "+intToDecimal(m.ch)+"]";
|
||
|
}
|
||
|
|
||
|
BOOST_PYTHON_FUNCTION_OVERLOADS(tokenize_overloads, tokenize, 1, 2);
|
||
|
BOOST_PYTHON_FUNCTION_OVERLOADS(printast_overloads, printAST, 1, 2);
|
||
|
BOOST_PYTHON_FUNCTION_OVERLOADS(parselll_overloads, parseLLL, 1, 2);
|
||
|
//BOOST_PYTHON_FUNCTION_OVERLOADS(metadata_overloads, Metadata, 0, 3);
|
||
|
BOOST_PYTHON_MODULE(pyserpent)
|
||
|
{
|
||
|
def("tokenize", tokenize, tokenize_overloads());
|
||
|
def("parse", parseSerpent);
|
||
|
def("parseLLL", parseLLL, parselll_overloads());
|
||
|
def("rewrite", rewrite);
|
||
|
def("compile_to_lll", compileToLLL);
|
||
|
def("encode_datalist", encodeDatalist);
|
||
|
def("decode_datalist", decodeDatalist);
|
||
|
def("compile_lll", compileLLL);
|
||
|
def("assemble", assemble);
|
||
|
def("deserialize", deserialize);
|
||
|
def("dereference", dereference);
|
||
|
def("flatten", flatten);
|
||
|
def("serialize", serialize);
|
||
|
def("compile", compile);
|
||
|
def("pretty_compile", prettyCompile);
|
||
|
def("pretty_assemble", prettyAssemble);
|
||
|
//class_<Node>("Node",init<>())
|
||
|
to_python_converter<std::vector<Node,class std::allocator<Node> >,
|
||
|
VecToList<Node> >();
|
||
|
to_python_converter<std::vector<std::string,class std::allocator<std::string> >,
|
||
|
VecToList<std::string> >();
|
||
|
Vector_from_python_list<Node>();
|
||
|
Vector_from_python_list<std::string>();
|
||
|
class_<Metadata>("Metadata",init<>())
|
||
|
.def(init<std::string, int, int>())
|
||
|
.def("__str__", printMetadata)
|
||
|
.def("__repr__", printMetadata)
|
||
|
;
|
||
|
class_<Node>("Node",init<>())
|
||
|
.def(init<>())
|
||
|
.def("__str__", printAST, printast_overloads())
|
||
|
.def("__repr__", printAST, printast_overloads())
|
||
|
;
|
||
|
//class_<Node>("Vector",init<>())
|
||
|
// .def(init<>());
|
||
|
}
|