aboutsummaryrefslogtreecommitdiffstats
path: root/mpm/python/converters.hpp
diff options
context:
space:
mode:
authorBrent Stapleton <brent.stapleton@ettus.com>2018-04-17 13:48:29 -0700
committerMartin Braun <martin.braun@ettus.com>2018-04-18 15:34:51 -0700
commit13b45a08c90912e8baa33b618b152cf41293bb9d (patch)
tree71d45d03b9f231fea305d493984d05194a5bb8fc /mpm/python/converters.hpp
parent7dcd16f5a6980cb1183bf1a10812c952d92c4ddb (diff)
downloaduhd-13b45a08c90912e8baa33b618b152cf41293bb9d.tar.gz
uhd-13b45a08c90912e8baa33b618b152cf41293bb9d.tar.bz2
uhd-13b45a08c90912e8baa33b618b152cf41293bb9d.zip
mpm: add device-specific Boost.Python bindings
Separating Boost.Python bindings into device-specific files. N3XX code now lives in n3xx/pyusrp_periphs. Only one src file should be added for pyusrp_periphs.so by CMake.
Diffstat (limited to 'mpm/python/converters.hpp')
-rw-r--r--mpm/python/converters.hpp94
1 files changed, 0 insertions, 94 deletions
diff --git a/mpm/python/converters.hpp b/mpm/python/converters.hpp
deleted file mode 100644
index ede9507a9..000000000
--- a/mpm/python/converters.hpp
+++ /dev/null
@@ -1,94 +0,0 @@
-//
-// Copyright 2017 Ettus Research, a National Instruments Company
-//
-// SPDX-License-Identifier: GPL-3.0-or-later
-//
-
-#pragma once
-
-#include <boost/python.hpp>
-#include <boost/python/stl_iterator.hpp>
-#include <vector>
-#include <string>
-
-namespace bp = boost::python;
-
-template<typename MapType>
-struct map_to_python_dict
-{
- static PyObject* convert(MapType const& input_map)
- {
- bp::dict py_dict;
- for (const auto& element: input_map){
- py_dict[element.first] = element.second;
- }
- return bp::incref(py_dict.ptr());
- }
-
-};
-
-template<typename Container>
-struct iterable_to_python_list
-{
- static PyObject* convert(Container const& input)
- {
- bp::list py_list;
- for (const auto& element: input){
- py_list.append(element);
- }
- return bp::incref(py_list.ptr());
- }
-};
-
-// Converter for std::vector / std::list arguments from python iterables
-struct iterable_converter
-{
- template <typename Container>
- iterable_converter&
- from_python()
- {
- bp::converter::registry::push_back(
- &iterable_converter::convertible,
- &iterable_converter::construct<Container>,
- bp::type_id<Container>());
- return *this;
- }
-
- static void* convertible(PyObject* object)
- {
- return PyObject_GetIter(object) ? object : NULL;
- }
-
- template <typename Container>
- static void construct(
- PyObject* object,
- bp::converter::rvalue_from_python_stage1_data* data)
- {
- // Object is a borrowed reference, so create a handle indicting it is
- // borrowed for proper reference counting.
- bp::handle<> handle(bp::borrowed(object));
-
- // Obtain a handle to the memory block that the converter has allocated
- // for the C++ type.
- typedef bp::converter::rvalue_from_python_storage<Container>
- storage_type;
- void* storage = reinterpret_cast<storage_type*>(data)->storage.bytes;
-
- typedef bp::stl_input_iterator<typename Container::value_type>
- iterator;
-
- // Allocate the C++ type into the converter's memory block, and assign
- // its handle to the converter's convertible variable. The C++
- // container is populated by passing the begin and end iterators of
- // the python object to the container's constructor.
- new (storage) Container(
- iterator(bp::object(handle)), // begin
- iterator()); // end
- data->convertible = storage;
- }
-};
-
-void export_converter(){
- // LIBMPM_BOOST_PREAMBLE("helper")
- bp::to_python_converter<std::vector< std::string >, iterable_to_python_list<std::vector< std::string > >, false>();
-}