Skip to content
Snippets Groups Projects
Commit 4359336c authored by Justin Carpentier's avatar Justin Carpentier Committed by GitHub
Browse files

Merge pull request #13 from jcarpent/devel

Correct warnings + introduce check or registration
parents 113671de 90ff656d
No related branches found
No related tags found
No related merge requests found
......@@ -81,6 +81,7 @@ SET(HEADERS
src/map.hpp
src/geometry.hpp
src/memory.hpp
src/registration.hpp
src/angle-axis.hpp
src/quaternion.hpp
)
......
......@@ -24,6 +24,7 @@
#include <iostream>
#include "eigenpy/eigenpy.hpp"
#include "eigenpy/registration.hpp"
#include "eigenpy/exception.hpp"
#include "eigenpy/map.hpp"
......@@ -190,7 +191,7 @@ namespace eigenpy
typename MapNumpy<EquivalentEigenType>::EigenMap numpyMap = MapNumpy<EquivalentEigenType>::map(pyArray);
void* storage = ((bp::converter::rvalue_from_python_storage<MatType>*)
(memory))->storage.bytes;
((void*)memory))->storage.bytes;
assert( (numpyMap.rows()<INT_MAX) && (numpyMap.cols()<INT_MAX)
&& "Map range larger than int ... can never happen." );
int r=(int)numpyMap.rows(),c=(int)numpyMap.cols();
......@@ -201,32 +202,16 @@ namespace eigenpy
eigenMatrix = numpyMap;
}
};
#define numpy_import_array() {if (_import_array() < 0) {PyErr_Print(); PyErr_SetString(PyExc_ImportError, "numpy.core.multiarray failed to import"); } }
template<typename MatType,typename EigenEquivalentType>
void enableEigenPySpecific()
{
import_array();
#ifdef EIGEN_DONT_VECTORIZE
boost::python::to_python_converter<MatType,
eigenpy::EigenToPy<MatType,MatType> >();
eigenpy::EigenFromPy<MatType,MatType>();
#else
boost::python::to_python_converter<MatType,
eigenpy::EigenToPy<MatType,MatType> >();
eigenpy::EigenFromPy<MatType,MatType>();
if(check_registration<MatType>()) return;
numpy_import_array();
typedef typename eigenpy::UnalignedEquivalent<MatType>::type MatTypeDontAlign;
#ifndef EIGENPY_ALIGNED
boost::python::to_python_converter<MatTypeDontAlign,
eigenpy::EigenToPy<MatTypeDontAlign,MatTypeDontAlign> >();
eigenpy::EigenFromPy<MatTypeDontAlign,MatTypeDontAlign>();
#endif
#endif
boost::python::to_python_converter<MatType,EigenToPy<MatType,MatType> >();
EigenFromPy<MatType,MatType>();
}
} // namespace eigenpy
......
/*
* Copyright (c) 2015 LAAS-CNRS
* Copyright (c) 2015-2016 LAAS-CNRS
*
* This file is part of eigenpy.
* eigenpy is free software: you can redistribute it and/or
......@@ -14,7 +14,8 @@
* with eigenpy. If not, see <http://www.gnu.org/licenses/>.
*/
#include <eigenpy/exception.hpp>
#include "eigenpy/exception.hpp"
#include "eigenpy/registration.hpp"
namespace eigenpy
......@@ -30,6 +31,8 @@ namespace eigenpy
void Exception::registerException()
{
if(check_registration<eigenpy::Exception>()) return;
pyType = boost::python::class_<eigenpy::Exception>
("Exception",boost::python::init<std::string>())
.add_property("message", &eigenpy::Exception::copyMessage)
......
......@@ -77,8 +77,8 @@ namespace boost { namespace python { namespace objects { \
Holder* holder = Derived::construct(&instance->storage, (PyObject*)instance, x); \
holder->install(raw_result); \
\
size_t holder_offset = reinterpret_cast<size_t>(holder) \
- reinterpret_cast<size_t>(&instance->storage) \
Py_ssize_t holder_offset = reinterpret_cast<Py_ssize_t>(holder) \
- reinterpret_cast<Py_ssize_t>(&instance->storage) \
+ offsetof(instance_t, storage); \
Py_SIZE(instance) = holder_offset; \
\
......
/*
* Copyright 2016, Justin Carpentier, LAAS-CNRS
*
* This file is part of eigenpy.
* eigenpy is free software: you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public License
* as published by the Free Software Foundation, either version 3 of
* the License, or (at your option) any later version.
* eigenpy is distributed in the hope that it will be
* useful, but WITHOUT ANY WARRANTY; without even the implied warranty
* of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU Lesser General Public License for more details. You should
* have received a copy of the GNU Lesser General Public License along
* with eigenpy. If not, see <http://www.gnu.org/licenses/>.
*/
#ifndef __eigenpy_registration_hpp__
#define __eigenpy_registration_hpp__
#include <boost/python.hpp>
namespace eigenpy
{
///
/// \brief Check at runtime the registration of the type T inside the boost python registry.
///
/// \tparam T The type to check the registration.
///
/// \returns true if the type T is already registered.
///
template<typename T>
inline bool check_registration()
{
namespace bp = boost::python;
const bp::type_info info = bp::type_id<T>();
const bp::converter::registration* reg = bp::converter::registry::query(info);
if (reg == NULL) return false;
else if ((*reg).m_to_python == NULL) return false;
return true;
}
}
#endif // ifndef __eigenpy_registration_hpp__
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment