made PLY parser C++11-compatible
parent
f995a91d4d
commit
c510050e0b
|
@ -22,24 +22,7 @@
|
||||||
#include <mitsuba/core/fstream.h>
|
#include <mitsuba/core/fstream.h>
|
||||||
#include <mitsuba/core/timer.h>
|
#include <mitsuba/core/timer.h>
|
||||||
#include <ply/ply_parser.hpp>
|
#include <ply/ply_parser.hpp>
|
||||||
|
|
||||||
#if MTS_USE_BOOST_TR1
|
|
||||||
#include <boost/tr1/functional.hpp>
|
|
||||||
#else
|
|
||||||
#if defined(_MSC_VER) && (_MSC_VER >= 1600)
|
|
||||||
#include <functional>
|
#include <functional>
|
||||||
#else
|
|
||||||
#include <tr1/functional>
|
|
||||||
#endif
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if !MTS_USE_BOOST_TR1 && defined(_MSC_VER) && (_MSC_VER >= 1600)
|
|
||||||
# define PLY_USE_NULLPTR 1
|
|
||||||
#else
|
|
||||||
# define PLY_USE_NULLPTR 0
|
|
||||||
#endif
|
|
||||||
|
|
||||||
using namespace std::tr1::placeholders;
|
|
||||||
|
|
||||||
MTS_NAMESPACE_BEGIN
|
MTS_NAMESPACE_BEGIN
|
||||||
|
|
||||||
|
@ -160,43 +143,37 @@ public:
|
||||||
message.c_str());
|
message.c_str());
|
||||||
}
|
}
|
||||||
|
|
||||||
template<typename ValueType> std::tr1::function <void (ValueType)>
|
template<typename ValueType> std::function <void (ValueType)>
|
||||||
scalar_property_definition_callback(const std::string& element_name,
|
scalar_property_definition_callback(const std::string& element_name,
|
||||||
const std::string& property_name);
|
const std::string& property_name);
|
||||||
|
|
||||||
template<typename SizeType, typename IndexType> std::tr1::tuple<std::tr1::function<void (SizeType)>,
|
template<typename SizeType, typename IndexType> std::tuple<std::function<void (SizeType)>,
|
||||||
std::tr1::function<void (IndexType)>, std::tr1::function<void ()> >
|
std::function<void (IndexType)>, std::function<void ()> >
|
||||||
list_property_definition_callback(const std::string& element_name,
|
list_property_definition_callback(const std::string& element_name,
|
||||||
const std::string& property_name);
|
const std::string& property_name);
|
||||||
|
|
||||||
std::tr1::tuple<std::tr1::function<void()>, std::tr1::function<void()> >
|
std::tuple<std::function<void()>, std::function<void()> >
|
||||||
element_definition_callback(const std::string& element_name, std::size_t count) {
|
element_definition_callback(const std::string& element_name, std::size_t count) {
|
||||||
if (element_name == "vertex") {
|
if (element_name == "vertex") {
|
||||||
m_vertexCount = count;
|
m_vertexCount = count;
|
||||||
m_positions = new Point[m_vertexCount];
|
m_positions = new Point[m_vertexCount];
|
||||||
return std::tr1::tuple<std::tr1::function<void()>,
|
return std::tuple<std::function<void()>,
|
||||||
std::tr1::function<void()> >(
|
std::function<void()> >(
|
||||||
std::tr1::bind(&PLYLoader::vertex_begin_callback, this),
|
std::bind(&PLYLoader::vertex_begin_callback, this),
|
||||||
std::tr1::bind(&PLYLoader::vertex_end_callback, this)
|
std::bind(&PLYLoader::vertex_end_callback, this)
|
||||||
);
|
);
|
||||||
} else if (element_name == "face") {
|
} else if (element_name == "face") {
|
||||||
m_faceCount = count;
|
m_faceCount = count;
|
||||||
m_triangles = new Triangle[m_faceCount*2];
|
m_triangles = new Triangle[m_faceCount*2];
|
||||||
return std::tr1::tuple<std::tr1::function<void()>,
|
return std::tuple<std::function<void()>,
|
||||||
std::tr1::function<void()> >(
|
std::function<void()> >(
|
||||||
std::tr1::bind(&PLYLoader::face_begin_callback, this),
|
std::bind(&PLYLoader::face_begin_callback, this),
|
||||||
std::tr1::bind(&PLYLoader::face_end_callback, this)
|
std::bind(&PLYLoader::face_end_callback, this)
|
||||||
);
|
);
|
||||||
} else {
|
} else {
|
||||||
#if PLY_USE_NULLPTR
|
|
||||||
return
|
return
|
||||||
std::tr1::tuple<std::tr1::function<void()>,
|
std::tuple<std::function<void()>,
|
||||||
std::tr1::function<void()> >(nullptr, nullptr);
|
std::function<void()> >(nullptr, nullptr);
|
||||||
#else
|
|
||||||
return
|
|
||||||
std::tr1::tuple<std::tr1::function<void()>,
|
|
||||||
std::tr1::function<void()> >(0, 0);
|
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -325,206 +302,174 @@ private:
|
||||||
bool m_sRGB;
|
bool m_sRGB;
|
||||||
};
|
};
|
||||||
|
|
||||||
template<> std::tr1::function <void (ply::float32)>
|
template<> std::function <void (ply::float32)>
|
||||||
PLYLoader::scalar_property_definition_callback(const std::string& element_name,
|
PLYLoader::scalar_property_definition_callback(const std::string& element_name,
|
||||||
const std::string& property_name) {
|
const std::string& property_name) {
|
||||||
if (element_name == "vertex") {
|
if (element_name == "vertex") {
|
||||||
if (property_name == "x") {
|
if (property_name == "x") {
|
||||||
return std::tr1::bind(&PLYLoader::vertex_x_callback, this, _1);
|
return std::bind(&PLYLoader::vertex_x_callback, this, _1);
|
||||||
} else if (property_name == "y") {
|
} else if (property_name == "y") {
|
||||||
return std::tr1::bind(&PLYLoader::vertex_y_callback, this, _1);
|
return std::bind(&PLYLoader::vertex_y_callback, this, _1);
|
||||||
} else if (property_name == "z") {
|
} else if (property_name == "z") {
|
||||||
return std::tr1::bind(&PLYLoader::vertex_z_callback, this, _1);
|
return std::bind(&PLYLoader::vertex_z_callback, this, _1);
|
||||||
} else if (property_name == "nx") {
|
} else if (property_name == "nx") {
|
||||||
m_hasNormals = true;
|
m_hasNormals = true;
|
||||||
return std::tr1::bind(&PLYLoader::normal_x_callback, this, _1);
|
return std::bind(&PLYLoader::normal_x_callback, this, _1);
|
||||||
} else if (property_name == "ny") {
|
} else if (property_name == "ny") {
|
||||||
return std::tr1::bind(&PLYLoader::normal_y_callback, this, _1);
|
return std::bind(&PLYLoader::normal_y_callback, this, _1);
|
||||||
} else if (property_name == "nz") {
|
} else if (property_name == "nz") {
|
||||||
return std::tr1::bind(&PLYLoader::normal_z_callback, this, _1);
|
return std::bind(&PLYLoader::normal_z_callback, this, _1);
|
||||||
} else if (property_name == "u" || property_name == "texture_u" || property_name == "s") {
|
} else if (property_name == "u" || property_name == "texture_u" || property_name == "s") {
|
||||||
m_hasTexCoords = true;
|
m_hasTexCoords = true;
|
||||||
return std::tr1::bind(&PLYLoader::texcoord_u_callback, this, _1);
|
return std::bind(&PLYLoader::texcoord_u_callback, this, _1);
|
||||||
} else if (property_name == "v" || property_name == "texture_v" || property_name == "t") {
|
} else if (property_name == "v" || property_name == "texture_v" || property_name == "t") {
|
||||||
return std::tr1::bind(&PLYLoader::texcoord_v_callback, this, _1);
|
return std::bind(&PLYLoader::texcoord_v_callback, this, _1);
|
||||||
} else if (property_name == "diffuse_red" || property_name == "red") {
|
} else if (property_name == "diffuse_red" || property_name == "red") {
|
||||||
return std::tr1::bind(&PLYLoader::red_callback, this, _1);
|
return std::bind(&PLYLoader::red_callback, this, _1);
|
||||||
} else if (property_name == "diffuse_green" || property_name == "green") {
|
} else if (property_name == "diffuse_green" || property_name == "green") {
|
||||||
return std::tr1::bind(&PLYLoader::green_callback, this, _1);
|
return std::bind(&PLYLoader::green_callback, this, _1);
|
||||||
} else if (property_name == "diffuse_blue" || property_name == "blue") {
|
} else if (property_name == "diffuse_blue" || property_name == "blue") {
|
||||||
return std::tr1::bind(&PLYLoader::blue_callback, this, _1);
|
return std::bind(&PLYLoader::blue_callback, this, _1);
|
||||||
}
|
}
|
||||||
} else if (element_name == "face") {
|
} else if (element_name == "face") {
|
||||||
if (property_name == "diffuse_red" || property_name == "red") {
|
if (property_name == "diffuse_red" || property_name == "red") {
|
||||||
return std::tr1::bind(&PLYLoader::face_red_callback, this, _1);
|
return std::bind(&PLYLoader::face_red_callback, this, _1);
|
||||||
} else if (property_name == "diffuse_green" || property_name == "green") {
|
} else if (property_name == "diffuse_green" || property_name == "green") {
|
||||||
return std::tr1::bind(&PLYLoader::face_green_callback, this, _1);
|
return std::bind(&PLYLoader::face_green_callback, this, _1);
|
||||||
} else if (property_name == "diffuse_blue" || property_name == "blue") {
|
} else if (property_name == "diffuse_blue" || property_name == "blue") {
|
||||||
return std::tr1::bind(&PLYLoader::face_blue_callback, this, _1);
|
return std::bind(&PLYLoader::face_blue_callback, this, _1);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
#if PLY_USE_NULLPTR
|
|
||||||
return nullptr;
|
return nullptr;
|
||||||
#else
|
|
||||||
return 0;
|
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
|
|
||||||
template<> std::tr1::function <void (ply::uint8)>
|
template<> std::function <void (ply::uint8)>
|
||||||
PLYLoader::scalar_property_definition_callback(const std::string& element_name,
|
PLYLoader::scalar_property_definition_callback(const std::string& element_name,
|
||||||
const std::string& property_name) {
|
const std::string& property_name) {
|
||||||
if (element_name == "vertex") {
|
if (element_name == "vertex") {
|
||||||
if (property_name == "diffuse_red" || property_name == "red") {
|
if (property_name == "diffuse_red" || property_name == "red") {
|
||||||
return std::tr1::bind(&PLYLoader::red_callback_uint8, this, _1);
|
return std::bind(&PLYLoader::red_callback_uint8, this, _1);
|
||||||
} else if (property_name == "diffuse_green" || property_name == "green") {
|
} else if (property_name == "diffuse_green" || property_name == "green") {
|
||||||
return std::tr1::bind(&PLYLoader::green_callback_uint8, this, _1);
|
return std::bind(&PLYLoader::green_callback_uint8, this, _1);
|
||||||
} else if (property_name == "diffuse_blue" || property_name == "blue") {
|
} else if (property_name == "diffuse_blue" || property_name == "blue") {
|
||||||
return std::tr1::bind(&PLYLoader::blue_callback_uint8, this, _1);
|
return std::bind(&PLYLoader::blue_callback_uint8, this, _1);
|
||||||
}
|
}
|
||||||
} else if (element_name == "face") {
|
} else if (element_name == "face") {
|
||||||
if (property_name == "diffuse_red" || property_name == "red") {
|
if (property_name == "diffuse_red" || property_name == "red") {
|
||||||
return std::tr1::bind(&PLYLoader::face_red_callback_uint8, this, _1);
|
return std::bind(&PLYLoader::face_red_callback_uint8, this, _1);
|
||||||
} else if (property_name == "diffuse_green" || property_name == "green") {
|
} else if (property_name == "diffuse_green" || property_name == "green") {
|
||||||
return std::tr1::bind(&PLYLoader::face_green_callback_uint8, this, _1);
|
return std::bind(&PLYLoader::face_green_callback_uint8, this, _1);
|
||||||
} else if (property_name == "diffuse_blue" || property_name == "blue") {
|
} else if (property_name == "diffuse_blue" || property_name == "blue") {
|
||||||
return std::tr1::bind(&PLYLoader::face_blue_callback_uint8, this, _1);
|
return std::bind(&PLYLoader::face_blue_callback_uint8, this, _1);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
#if PLY_USE_NULLPTR
|
|
||||||
return nullptr;
|
return nullptr;
|
||||||
#else
|
|
||||||
return 0;
|
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
|
|
||||||
template<> std::tr1::tuple<std::tr1::function<void (ply::uint8)>,
|
template<> std::tuple<std::function<void (ply::uint8)>,
|
||||||
std::tr1::function<void (ply::int32)>, std::tr1::function<void ()> >
|
std::function<void (ply::int32)>, std::function<void ()> >
|
||||||
PLYLoader::list_property_definition_callback(const std::string& element_name,
|
PLYLoader::list_property_definition_callback(const std::string& element_name,
|
||||||
const std::string& property_name) {
|
const std::string& property_name) {
|
||||||
if ((element_name == "face") && (property_name == "vertex_indices" || property_name == "vertex_index")) {
|
if ((element_name == "face") && (property_name == "vertex_indices" || property_name == "vertex_index")) {
|
||||||
return std::tr1::tuple<std::tr1::function<void (ply::uint8)>,
|
return std::tuple<std::function<void (ply::uint8)>,
|
||||||
std::tr1::function<void (ply::int32)>, std::tr1::function<void ()> >(
|
std::function<void (ply::int32)>, std::function<void ()> >(
|
||||||
std::tr1::bind(&PLYLoader::face_vertex_indices_begin_uint8, this, _1),
|
std::bind(&PLYLoader::face_vertex_indices_begin_uint8, this, _1),
|
||||||
std::tr1::bind(&PLYLoader::face_vertex_indices_element_int32, this, _1),
|
std::bind(&PLYLoader::face_vertex_indices_element_int32, this, _1),
|
||||||
std::tr1::bind(&PLYLoader::face_vertex_indices_end, this)
|
std::bind(&PLYLoader::face_vertex_indices_end, this)
|
||||||
);
|
);
|
||||||
} else {
|
} else {
|
||||||
#if PLY_USE_NULLPTR
|
return std::tuple<std::function<void (ply::uint8)>,
|
||||||
return std::tr1::tuple<std::tr1::function<void (ply::uint8)>,
|
std::function<void (ply::int32)>,
|
||||||
std::tr1::function<void (ply::int32)>,
|
std::function<void ()> >(nullptr, nullptr, nullptr);
|
||||||
std::tr1::function<void ()> >(nullptr, nullptr, nullptr);
|
|
||||||
#else
|
|
||||||
return std::tr1::tuple<std::tr1::function<void (ply::uint8)>,
|
|
||||||
std::tr1::function<void (ply::int32)>,
|
|
||||||
std::tr1::function<void ()> >(0, 0, 0);
|
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
template<> std::tr1::tuple<std::tr1::function<void (ply::uint32)>,
|
template<> std::tuple<std::function<void (ply::uint32)>,
|
||||||
std::tr1::function<void (ply::int32)>, std::tr1::function<void ()> >
|
std::function<void (ply::int32)>, std::function<void ()> >
|
||||||
PLYLoader::list_property_definition_callback(const std::string& element_name,
|
PLYLoader::list_property_definition_callback(const std::string& element_name,
|
||||||
const std::string& property_name) {
|
const std::string& property_name) {
|
||||||
if ((element_name == "face") && (property_name == "vertex_indices" || property_name == "vertex_index")) {
|
if ((element_name == "face") && (property_name == "vertex_indices" || property_name == "vertex_index")) {
|
||||||
return std::tr1::tuple<std::tr1::function<void (ply::uint32)>,
|
return std::tuple<std::function<void (ply::uint32)>,
|
||||||
std::tr1::function<void (ply::int32)>, std::tr1::function<void ()> >(
|
std::function<void (ply::int32)>, std::function<void ()> >(
|
||||||
std::tr1::bind(&PLYLoader::face_vertex_indices_begin_uint32, this, _1),
|
std::bind(&PLYLoader::face_vertex_indices_begin_uint32, this, _1),
|
||||||
std::tr1::bind(&PLYLoader::face_vertex_indices_element_int32, this, _1),
|
std::bind(&PLYLoader::face_vertex_indices_element_int32, this, _1),
|
||||||
std::tr1::bind(&PLYLoader::face_vertex_indices_end, this)
|
std::bind(&PLYLoader::face_vertex_indices_end, this)
|
||||||
);
|
);
|
||||||
} else {
|
} else {
|
||||||
#if PLY_USE_NULLPTR
|
return std::tuple<std::function<void (ply::uint32)>,
|
||||||
return std::tr1::tuple<std::tr1::function<void (ply::uint32)>,
|
std::function<void (ply::int32)>,
|
||||||
std::tr1::function<void (ply::int32)>,
|
std::function<void ()> >(0, 0, 0);
|
||||||
std::tr1::function<void ()> >(nullptr, nullptr, nullptr);
|
|
||||||
#else
|
|
||||||
return std::tr1::tuple<std::tr1::function<void (ply::uint32)>,
|
|
||||||
std::tr1::function<void (ply::int32)>,
|
|
||||||
std::tr1::function<void ()> >(0, 0, 0);
|
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
template<> std::tr1::tuple<std::tr1::function<void (ply::uint8)>,
|
template<> std::tuple<std::function<void (ply::uint8)>,
|
||||||
std::tr1::function<void (ply::uint32)>, std::tr1::function<void ()> >
|
std::function<void (ply::uint32)>, std::function<void ()> >
|
||||||
PLYLoader::list_property_definition_callback(const std::string& element_name,
|
PLYLoader::list_property_definition_callback(const std::string& element_name,
|
||||||
const std::string& property_name) {
|
const std::string& property_name) {
|
||||||
if ((element_name == "face") && (property_name == "vertex_indices" || property_name == "vertex_index")) {
|
if ((element_name == "face") && (property_name == "vertex_indices" || property_name == "vertex_index")) {
|
||||||
return std::tr1::tuple<std::tr1::function<void (ply::uint8)>,
|
return std::tuple<std::function<void (ply::uint8)>,
|
||||||
std::tr1::function<void (ply::uint32)>, std::tr1::function<void ()> >(
|
std::function<void (ply::uint32)>, std::function<void ()> >(
|
||||||
std::tr1::bind(&PLYLoader::face_vertex_indices_begin_uint8, this, _1),
|
std::bind(&PLYLoader::face_vertex_indices_begin_uint8, this, _1),
|
||||||
std::tr1::bind(&PLYLoader::face_vertex_indices_element_uint32, this, _1),
|
std::bind(&PLYLoader::face_vertex_indices_element_uint32, this, _1),
|
||||||
std::tr1::bind(&PLYLoader::face_vertex_indices_end, this)
|
std::bind(&PLYLoader::face_vertex_indices_end, this)
|
||||||
);
|
);
|
||||||
} else {
|
} else {
|
||||||
#if PLY_USE_NULLPTR
|
return std::tuple<std::function<void (ply::uint8)>,
|
||||||
return std::tr1::tuple<std::tr1::function<void (ply::uint8)>,
|
std::function<void (ply::uint32)>,
|
||||||
std::tr1::function<void (ply::uint32)>,
|
std::function<void ()> >(0, 0, 0);
|
||||||
std::tr1::function<void ()> >(nullptr, nullptr, nullptr);
|
|
||||||
#else
|
|
||||||
return std::tr1::tuple<std::tr1::function<void (ply::uint8)>,
|
|
||||||
std::tr1::function<void (ply::uint32)>,
|
|
||||||
std::tr1::function<void ()> >(0, 0, 0);
|
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
template<> std::tr1::tuple<std::tr1::function<void (ply::uint32)>,
|
template<> std::tuple<std::function<void (ply::uint32)>,
|
||||||
std::tr1::function<void (ply::uint32)>, std::tr1::function<void ()> >
|
std::function<void (ply::uint32)>, std::function<void ()> >
|
||||||
PLYLoader::list_property_definition_callback(const std::string& element_name,
|
PLYLoader::list_property_definition_callback(const std::string& element_name,
|
||||||
const std::string& property_name) {
|
const std::string& property_name) {
|
||||||
if ((element_name == "face") && (property_name == "vertex_indices" || property_name == "vertex_index")) {
|
if ((element_name == "face") && (property_name == "vertex_indices" || property_name == "vertex_index")) {
|
||||||
return std::tr1::tuple<std::tr1::function<void (ply::uint32)>,
|
return std::tuple<std::function<void (ply::uint32)>,
|
||||||
std::tr1::function<void (ply::uint32)>, std::tr1::function<void ()> >(
|
std::function<void (ply::uint32)>, std::function<void ()> >(
|
||||||
std::tr1::bind(&PLYLoader::face_vertex_indices_begin_uint32, this, _1),
|
std::bind(&PLYLoader::face_vertex_indices_begin_uint32, this, _1),
|
||||||
std::tr1::bind(&PLYLoader::face_vertex_indices_element_uint32, this, _1),
|
std::bind(&PLYLoader::face_vertex_indices_element_uint32, this, _1),
|
||||||
std::tr1::bind(&PLYLoader::face_vertex_indices_end, this)
|
std::bind(&PLYLoader::face_vertex_indices_end, this)
|
||||||
);
|
);
|
||||||
} else {
|
} else {
|
||||||
#if PLY_USE_NULLPTR
|
return std::tuple<std::function<void (ply::uint32)>,
|
||||||
return std::tr1::tuple<std::tr1::function<void (ply::uint32)>,
|
std::function<void (ply::uint32)>,
|
||||||
std::tr1::function<void (ply::uint32)>,
|
std::function<void ()> >(0, 0, 0);
|
||||||
std::tr1::function<void ()> >(nullptr, nullptr, nullptr);
|
|
||||||
#else
|
|
||||||
return std::tr1::tuple<std::tr1::function<void (ply::uint32)>,
|
|
||||||
std::tr1::function<void (ply::uint32)>,
|
|
||||||
std::tr1::function<void ()> >(0, 0, 0);
|
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
void PLYLoader::loadPLY(const fs::path &path) {
|
void PLYLoader::loadPLY(const fs::path &path) {
|
||||||
ply::ply_parser ply_parser;
|
ply::ply_parser ply_parser;
|
||||||
ply_parser.info_callback(std::tr1::bind(&PLYLoader::info_callback,
|
ply_parser.info_callback(std::bind(&PLYLoader::info_callback,
|
||||||
this, std::tr1::ref(m_name), _1, _2));
|
this, std::ref(m_name), _1, _2));
|
||||||
ply_parser.warning_callback(std::tr1::bind(&PLYLoader::warning_callback,
|
ply_parser.warning_callback(std::bind(&PLYLoader::warning_callback,
|
||||||
this, std::tr1::ref(m_name), _1, _2));
|
this, std::ref(m_name), _1, _2));
|
||||||
ply_parser.error_callback(std::tr1::bind(&PLYLoader::error_callback,
|
ply_parser.error_callback(std::bind(&PLYLoader::error_callback,
|
||||||
this, std::tr1::ref(m_name), _1, _2));
|
this, std::ref(m_name), _1, _2));
|
||||||
|
|
||||||
ply_parser.element_definition_callback(std::tr1::bind(&PLYLoader::element_definition_callback,
|
ply_parser.element_definition_callback(std::bind(&PLYLoader::element_definition_callback,
|
||||||
this, _1, _2));
|
this, _1, _2));
|
||||||
|
|
||||||
ply::ply_parser::scalar_property_definition_callbacks_type scalar_property_definition_callbacks;
|
ply::ply_parser::scalar_property_definition_callbacks_type scalar_property_definition_callbacks;
|
||||||
ply::ply_parser::list_property_definition_callbacks_type list_property_definition_callbacks;
|
ply::ply_parser::list_property_definition_callbacks_type list_property_definition_callbacks;
|
||||||
|
|
||||||
ply::at<ply::float32>(scalar_property_definition_callbacks) = std::tr1::bind(
|
ply::at<ply::float32>(scalar_property_definition_callbacks) = std::bind(
|
||||||
&PLYLoader::scalar_property_definition_callback<ply::float32>, this, _1, _2);
|
&PLYLoader::scalar_property_definition_callback<ply::float32>, this, _1, _2);
|
||||||
|
|
||||||
ply::at<ply::uint8>(scalar_property_definition_callbacks) = std::tr1::bind(
|
ply::at<ply::uint8>(scalar_property_definition_callbacks) = std::bind(
|
||||||
&PLYLoader::scalar_property_definition_callback<ply::uint8>, this, _1, _2);
|
&PLYLoader::scalar_property_definition_callback<ply::uint8>, this, _1, _2);
|
||||||
|
|
||||||
ply::at<ply::uint8, ply::int32>(list_property_definition_callbacks) = std::tr1::bind(
|
ply::at<ply::uint8, ply::int32>(list_property_definition_callbacks) = std::bind(
|
||||||
&PLYLoader::list_property_definition_callback<ply::uint8, ply::int32>, this, _1, _2);
|
&PLYLoader::list_property_definition_callback<ply::uint8, ply::int32>, this, _1, _2);
|
||||||
|
|
||||||
ply::at<ply::uint32, ply::int32>(list_property_definition_callbacks) = std::tr1::bind(
|
ply::at<ply::uint32, ply::int32>(list_property_definition_callbacks) = std::bind(
|
||||||
&PLYLoader::list_property_definition_callback<ply::uint32, ply::int32>, this, _1, _2);
|
&PLYLoader::list_property_definition_callback<ply::uint32, ply::int32>, this, _1, _2);
|
||||||
|
|
||||||
ply::at<ply::uint8, ply::uint32>(list_property_definition_callbacks) = std::tr1::bind(
|
ply::at<ply::uint8, ply::uint32>(list_property_definition_callbacks) = std::bind(
|
||||||
&PLYLoader::list_property_definition_callback<ply::uint8, ply::uint32>, this, _1, _2);
|
&PLYLoader::list_property_definition_callback<ply::uint8, ply::uint32>, this, _1, _2);
|
||||||
|
|
||||||
ply::at<ply::uint32, ply::uint32>(list_property_definition_callbacks) = std::tr1::bind(
|
ply::at<ply::uint32, ply::uint32>(list_property_definition_callbacks) = std::bind(
|
||||||
&PLYLoader::list_property_definition_callback<ply::uint32, ply::uint32>, this, _1, _2);
|
&PLYLoader::list_property_definition_callback<ply::uint32, ply::uint32>, this, _1, _2);
|
||||||
|
|
||||||
ply_parser.scalar_property_definition_callbacks(scalar_property_definition_callbacks);
|
ply_parser.scalar_property_definition_callbacks(scalar_property_definition_callbacks);
|
||||||
|
|
|
@ -9,7 +9,7 @@ bool ply::ply_parser::parse(std::istream& istream)
|
||||||
std::size_t number_of_format_statements = 0, number_of_element_statements = 0, number_of_property_statements = 0, number_of_obj_info_statements = 0, number_of_comment_statements = 0;
|
std::size_t number_of_format_statements = 0, number_of_element_statements = 0, number_of_property_statements = 0, number_of_obj_info_statements = 0, number_of_comment_statements = 0;
|
||||||
|
|
||||||
format_type format = ascii_format;
|
format_type format = ascii_format;
|
||||||
std::vector< std::tr1::shared_ptr<element> > elements;
|
std::vector< std::shared_ptr<element> > elements;
|
||||||
|
|
||||||
// magic
|
// magic
|
||||||
char magic[3];
|
char magic[3];
|
||||||
|
@ -103,7 +103,7 @@ bool ply::ply_parser::parse(std::istream& istream)
|
||||||
}
|
}
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
std::vector< std::tr1::shared_ptr<element> >::const_iterator iterator;
|
std::vector< std::shared_ptr<element> >::const_iterator iterator;
|
||||||
for (iterator = elements.begin(); iterator != elements.end(); ++iterator) {
|
for (iterator = elements.begin(); iterator != elements.end(); ++iterator) {
|
||||||
const struct element& element = *(iterator->get());
|
const struct element& element = *(iterator->get());
|
||||||
if (element.name == name) {
|
if (element.name == name) {
|
||||||
|
@ -121,8 +121,8 @@ bool ply::ply_parser::parse(std::istream& istream)
|
||||||
if (element_definition_callbacks_) {
|
if (element_definition_callbacks_) {
|
||||||
element_callbacks = element_definition_callbacks_(name, count);
|
element_callbacks = element_definition_callbacks_(name, count);
|
||||||
}
|
}
|
||||||
std::tr1::shared_ptr<element> element_ptr(new element(name, count, std::tr1::get<0>(element_callbacks), std::tr1::get<1>(element_callbacks)));
|
std::shared_ptr<element> element_ptr(new element(name, count, std::get<0>(element_callbacks), std::get<1>(element_callbacks)));
|
||||||
elements.push_back(std::tr1::shared_ptr<element>(element_ptr));
|
elements.push_back(std::shared_ptr<element>(element_ptr));
|
||||||
current_element_ = element_ptr.get();
|
current_element_ = element_ptr.get();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -154,7 +154,7 @@ bool ply::ply_parser::parse(std::istream& istream)
|
||||||
}
|
}
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
std::vector< std::tr1::shared_ptr<property> >::const_iterator iterator;
|
std::vector< std::shared_ptr<property> >::const_iterator iterator;
|
||||||
for (iterator = current_element_->properties.begin(); iterator != current_element_->properties.end(); ++iterator) {
|
for (iterator = current_element_->properties.begin(); iterator != current_element_->properties.end(); ++iterator) {
|
||||||
const struct property& property = *(iterator->get());
|
const struct property& property = *(iterator->get());
|
||||||
if (property.name == name) {
|
if (property.name == name) {
|
||||||
|
@ -216,7 +216,7 @@ bool ply::ply_parser::parse(std::istream& istream)
|
||||||
}
|
}
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
std::vector< std::tr1::shared_ptr<property> >::const_iterator iterator;
|
std::vector< std::shared_ptr<property> >::const_iterator iterator;
|
||||||
for (iterator = current_element_->properties.begin(); iterator != current_element_->properties.end(); ++iterator) {
|
for (iterator = current_element_->properties.begin(); iterator != current_element_->properties.end(); ++iterator) {
|
||||||
const struct property& property = *(iterator->get());
|
const struct property& property = *(iterator->get());
|
||||||
if (property.name == name) {
|
if (property.name == name) {
|
||||||
|
@ -392,7 +392,7 @@ bool ply::ply_parser::parse(std::istream& istream)
|
||||||
|
|
||||||
// ascii
|
// ascii
|
||||||
if (format == ascii_format) {
|
if (format == ascii_format) {
|
||||||
for (std::vector< std::tr1::shared_ptr<element> >::const_iterator element_iterator = elements.begin(); element_iterator != elements.end(); ++element_iterator) {
|
for (std::vector< std::shared_ptr<element> >::const_iterator element_iterator = elements.begin(); element_iterator != elements.end(); ++element_iterator) {
|
||||||
struct element& element = *(element_iterator->get());
|
struct element& element = *(element_iterator->get());
|
||||||
for (std::size_t element_index = 0; element_index < element.count; ++element_index) {
|
for (std::size_t element_index = 0; element_index < element.count; ++element_index) {
|
||||||
if (element.begin_element_callback) {
|
if (element.begin_element_callback) {
|
||||||
|
@ -408,7 +408,7 @@ bool ply::ply_parser::parse(std::istream& istream)
|
||||||
std::istringstream stringstream(line);
|
std::istringstream stringstream(line);
|
||||||
stringstream.unsetf(std::ios_base::skipws);
|
stringstream.unsetf(std::ios_base::skipws);
|
||||||
stringstream >> std::ws;
|
stringstream >> std::ws;
|
||||||
for (std::vector< std::tr1::shared_ptr<property> >::const_iterator property_iterator = element.properties.begin(); property_iterator != element.properties.end(); ++property_iterator) {
|
for (std::vector< std::shared_ptr<property> >::const_iterator property_iterator = element.properties.begin(); property_iterator != element.properties.end(); ++property_iterator) {
|
||||||
struct property& property = *(property_iterator->get());
|
struct property& property = *(property_iterator->get());
|
||||||
if (property.parse(*this, format, stringstream) == false) {
|
if (property.parse(*this, format, stringstream) == false) {
|
||||||
return false;
|
return false;
|
||||||
|
@ -437,13 +437,13 @@ bool ply::ply_parser::parse(std::istream& istream)
|
||||||
|
|
||||||
// binary
|
// binary
|
||||||
else {
|
else {
|
||||||
for (std::vector< std::tr1::shared_ptr<element> >::const_iterator element_iterator = elements.begin(); element_iterator != elements.end(); ++element_iterator) {
|
for (std::vector< std::shared_ptr<element> >::const_iterator element_iterator = elements.begin(); element_iterator != elements.end(); ++element_iterator) {
|
||||||
struct element& element = *(element_iterator->get());
|
struct element& element = *(element_iterator->get());
|
||||||
for (std::size_t element_index = 0; element_index < element.count; ++element_index) {
|
for (std::size_t element_index = 0; element_index < element.count; ++element_index) {
|
||||||
if (element.begin_element_callback) {
|
if (element.begin_element_callback) {
|
||||||
element.begin_element_callback();
|
element.begin_element_callback();
|
||||||
}
|
}
|
||||||
for (std::vector< std::tr1::shared_ptr<property> >::const_iterator property_iterator = element.properties.begin(); property_iterator != element.properties.end(); ++property_iterator) {
|
for (std::vector< std::shared_ptr<property> >::const_iterator property_iterator = element.properties.begin(); property_iterator != element.properties.end(); ++property_iterator) {
|
||||||
struct property& property = *(property_iterator->get());
|
struct property& property = *(property_iterator->get());
|
||||||
if (property.parse(*this, format, istream) == false) {
|
if (property.parse(*this, format, istream) == false) {
|
||||||
return false;
|
return false;
|
||||||
|
|
|
@ -9,42 +9,11 @@
|
||||||
#include <vector>
|
#include <vector>
|
||||||
#include <cctype>
|
#include <cctype>
|
||||||
|
|
||||||
#if defined(__clang__)
|
|
||||||
# define MTS_USE_BOOST_TR1 (!__has_feature(cxx_variadic_templates))
|
|
||||||
#define ADT_WORKAROUND 1
|
#define ADT_WORKAROUND 1
|
||||||
#else
|
|
||||||
# if defined(_MSC_VER)
|
|
||||||
# if _MSC_VER < 1600
|
|
||||||
# define MTS_USE_BOOST_TR1 1
|
|
||||||
# else
|
|
||||||
# define MTS_USE_BOOST_TR1 0
|
|
||||||
# define ADT_WORKAROUND 1
|
|
||||||
# endif
|
|
||||||
# elif defined(__INTEL_COMPILER) && !defined(__OSX__)
|
|
||||||
# define MTS_USE_BOOST_TR1 1
|
|
||||||
# else
|
|
||||||
# define MTS_USE_BOOST_TR1 0
|
|
||||||
# endif
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if !defined(ADT_WORKAROUND) && (defined(__INTEL_COMPILER) || defined(__INTELLISENSE__))
|
|
||||||
#define ADT_WORKAROUND 1
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if MTS_USE_BOOST_TR1
|
|
||||||
#include <boost/tr1/functional.hpp>
|
|
||||||
#include <boost/tr1/memory.hpp>
|
|
||||||
#include <boost/tr1/tuple.hpp>
|
|
||||||
#else
|
|
||||||
#if defined(_MSC_VER) && (_MSC_VER >= 1600)
|
|
||||||
#include <functional>
|
#include <functional>
|
||||||
#include <memory>
|
#include <memory>
|
||||||
#include <tuple>
|
#include <tuple>
|
||||||
#else
|
|
||||||
#include <tr1/functional>
|
|
||||||
#include <tr1/memory>
|
|
||||||
#endif
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#include <boost/mpl/fold.hpp>
|
#include <boost/mpl/fold.hpp>
|
||||||
#include <boost/mpl/inherit.hpp>
|
#include <boost/mpl/inherit.hpp>
|
||||||
|
@ -57,38 +26,40 @@
|
||||||
#include <ply/byte_order.hpp>
|
#include <ply/byte_order.hpp>
|
||||||
#include <ply/io_operators.hpp>
|
#include <ply/io_operators.hpp>
|
||||||
|
|
||||||
|
using namespace std::placeholders;
|
||||||
|
|
||||||
namespace ply {
|
namespace ply {
|
||||||
|
|
||||||
class ply_parser
|
class ply_parser
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
|
|
||||||
typedef std::tr1::function<void (std::size_t, const std::string&)> info_callback_type;
|
typedef std::function<void (std::size_t, const std::string&)> info_callback_type;
|
||||||
typedef std::tr1::function<void (std::size_t, const std::string&)> warning_callback_type;
|
typedef std::function<void (std::size_t, const std::string&)> warning_callback_type;
|
||||||
typedef std::tr1::function<void (std::size_t, const std::string&)> error_callback_type;
|
typedef std::function<void (std::size_t, const std::string&)> error_callback_type;
|
||||||
|
|
||||||
typedef std::tr1::function<void ()> magic_callback_type;
|
typedef std::function<void ()> magic_callback_type;
|
||||||
typedef std::tr1::function<void (format_type, const std::string&)> format_callback_type;
|
typedef std::function<void (format_type, const std::string&)> format_callback_type;
|
||||||
typedef std::tr1::function<void (const std::string&)> comment_callback_type;
|
typedef std::function<void (const std::string&)> comment_callback_type;
|
||||||
typedef std::tr1::function<void (const std::string&)> obj_info_callback_type;
|
typedef std::function<void (const std::string&)> obj_info_callback_type;
|
||||||
typedef std::tr1::function<bool ()> end_header_callback_type;
|
typedef std::function<bool ()> end_header_callback_type;
|
||||||
|
|
||||||
typedef std::tr1::function<void()> begin_element_callback_type;
|
typedef std::function<void()> begin_element_callback_type;
|
||||||
typedef std::tr1::function<void()> end_element_callback_type;
|
typedef std::function<void()> end_element_callback_type;
|
||||||
typedef std::tr1::tuple<begin_element_callback_type, end_element_callback_type> element_callbacks_type;
|
typedef std::tuple<begin_element_callback_type, end_element_callback_type> element_callbacks_type;
|
||||||
typedef std::tr1::function<element_callbacks_type (const std::string&, std::size_t)> element_definition_callback_type;
|
typedef std::function<element_callbacks_type (const std::string&, std::size_t)> element_definition_callback_type;
|
||||||
|
|
||||||
template <typename ScalarType>
|
template <typename ScalarType>
|
||||||
struct scalar_property_callback_type
|
struct scalar_property_callback_type
|
||||||
{
|
{
|
||||||
typedef std::tr1::function<void (ScalarType)> type;
|
typedef std::function<void (ScalarType)> type;
|
||||||
};
|
};
|
||||||
|
|
||||||
template <typename ScalarType>
|
template <typename ScalarType>
|
||||||
struct scalar_property_definition_callback_type
|
struct scalar_property_definition_callback_type
|
||||||
{
|
{
|
||||||
typedef typename scalar_property_callback_type<ScalarType>::type scalar_property_callback_type;
|
typedef typename scalar_property_callback_type<ScalarType>::type scalar_property_callback_type;
|
||||||
typedef std::tr1::function<scalar_property_callback_type (const std::string&, const std::string&)> type;
|
typedef std::function<scalar_property_callback_type (const std::string&, const std::string&)> type;
|
||||||
};
|
};
|
||||||
|
|
||||||
typedef boost::mpl::vector<int8, int16, int32, uint8, uint16, uint32, float32, float64> scalar_types;
|
typedef boost::mpl::vector<int8, int16, int32, uint8, uint16, uint32, float32, float64> scalar_types;
|
||||||
|
@ -138,19 +109,19 @@ public:
|
||||||
template <typename SizeType, typename ScalarType>
|
template <typename SizeType, typename ScalarType>
|
||||||
struct list_property_begin_callback_type
|
struct list_property_begin_callback_type
|
||||||
{
|
{
|
||||||
typedef std::tr1::function<void (SizeType)> type;
|
typedef std::function<void (SizeType)> type;
|
||||||
};
|
};
|
||||||
|
|
||||||
template <typename SizeType, typename ScalarType>
|
template <typename SizeType, typename ScalarType>
|
||||||
struct list_property_element_callback_type
|
struct list_property_element_callback_type
|
||||||
{
|
{
|
||||||
typedef std::tr1::function<void (ScalarType)> type;
|
typedef std::function<void (ScalarType)> type;
|
||||||
};
|
};
|
||||||
|
|
||||||
template <typename SizeType, typename ScalarType>
|
template <typename SizeType, typename ScalarType>
|
||||||
struct list_property_end_callback_type
|
struct list_property_end_callback_type
|
||||||
{
|
{
|
||||||
typedef std::tr1::function<void ()> type;
|
typedef std::function<void ()> type;
|
||||||
};
|
};
|
||||||
|
|
||||||
template <typename SizeType, typename ScalarType>
|
template <typename SizeType, typename ScalarType>
|
||||||
|
@ -159,8 +130,8 @@ public:
|
||||||
typedef typename list_property_begin_callback_type<SizeType, ScalarType>::type list_property_begin_callback_type;
|
typedef typename list_property_begin_callback_type<SizeType, ScalarType>::type list_property_begin_callback_type;
|
||||||
typedef typename list_property_element_callback_type<SizeType, ScalarType>::type list_property_element_callback_type;
|
typedef typename list_property_element_callback_type<SizeType, ScalarType>::type list_property_element_callback_type;
|
||||||
typedef typename list_property_end_callback_type<SizeType, ScalarType>::type list_property_end_callback_type;
|
typedef typename list_property_end_callback_type<SizeType, ScalarType>::type list_property_end_callback_type;
|
||||||
typedef std::tr1::function<
|
typedef std::function<
|
||||||
std::tr1::tuple<
|
std::tuple<
|
||||||
list_property_begin_callback_type,
|
list_property_begin_callback_type,
|
||||||
list_property_element_callback_type,
|
list_property_element_callback_type,
|
||||||
list_property_end_callback_type
|
list_property_end_callback_type
|
||||||
|
@ -288,7 +259,7 @@ private:
|
||||||
std::size_t count;
|
std::size_t count;
|
||||||
begin_element_callback_type begin_element_callback;
|
begin_element_callback_type begin_element_callback;
|
||||||
end_element_callback_type end_element_callback;
|
end_element_callback_type end_element_callback;
|
||||||
std::vector<std::tr1::shared_ptr<property> > properties;
|
std::vector<std::shared_ptr<property> > properties;
|
||||||
};
|
};
|
||||||
|
|
||||||
flags_type flags_;
|
flags_type flags_;
|
||||||
|
@ -398,7 +369,7 @@ inline void ply::ply_parser::parse_scalar_property_definition(const std::string&
|
||||||
warning_callback_(line_number_, "property '" + std::string(type_traits<scalar_type>::name()) + " " + property_name + "' of element '" + current_element_->name + "' is not handled");
|
warning_callback_(line_number_, "property '" + std::string(type_traits<scalar_type>::name()) + " " + property_name + "' of element '" + current_element_->name + "' is not handled");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
current_element_->properties.push_back(std::tr1::shared_ptr<property>(new scalar_property<scalar_type>(property_name, scalar_property_callback)));
|
current_element_->properties.push_back(std::shared_ptr<property>(new scalar_property<scalar_type>(property_name, scalar_property_callback)));
|
||||||
}
|
}
|
||||||
|
|
||||||
template <typename SizeType, typename ScalarType>
|
template <typename SizeType, typename ScalarType>
|
||||||
|
@ -414,16 +385,16 @@ inline void ply::ply_parser::parse_list_property_definition(const std::string& p
|
||||||
typedef typename list_property_begin_callback_type<size_type, scalar_type>::type list_property_begin_callback_type;
|
typedef typename list_property_begin_callback_type<size_type, scalar_type>::type list_property_begin_callback_type;
|
||||||
typedef typename list_property_element_callback_type<size_type, scalar_type>::type list_property_element_callback_type;
|
typedef typename list_property_element_callback_type<size_type, scalar_type>::type list_property_element_callback_type;
|
||||||
typedef typename list_property_end_callback_type<size_type, scalar_type>::type list_property_end_callback_type;
|
typedef typename list_property_end_callback_type<size_type, scalar_type>::type list_property_end_callback_type;
|
||||||
std::tr1::tuple<list_property_begin_callback_type, list_property_element_callback_type, list_property_end_callback_type> list_property_callbacks;
|
std::tuple<list_property_begin_callback_type, list_property_element_callback_type, list_property_end_callback_type> list_property_callbacks;
|
||||||
if (list_property_definition_callback) {
|
if (list_property_definition_callback) {
|
||||||
list_property_callbacks = list_property_definition_callback(current_element_->name, property_name);
|
list_property_callbacks = list_property_definition_callback(current_element_->name, property_name);
|
||||||
}
|
}
|
||||||
if (!std::tr1::get<0>(list_property_callbacks) || !std::tr1::get<1>(list_property_callbacks) || !std::tr1::get<2>(list_property_callbacks)) {
|
if (!std::get<0>(list_property_callbacks) || !std::get<1>(list_property_callbacks) || !std::get<2>(list_property_callbacks)) {
|
||||||
if (warning_callback_) {
|
if (warning_callback_) {
|
||||||
warning_callback_(line_number_, "property 'list " + std::string(type_traits<size_type>::name()) + " " + std::string(type_traits<scalar_type>::name()) + " " + property_name + "' of element '" + current_element_->name + "' is not handled");
|
warning_callback_(line_number_, "property 'list " + std::string(type_traits<size_type>::name()) + " " + std::string(type_traits<scalar_type>::name()) + " " + property_name + "' of element '" + current_element_->name + "' is not handled");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
current_element_->properties.push_back(std::tr1::shared_ptr<property>(new list_property<size_type, scalar_type>(property_name, std::tr1::get<0>(list_property_callbacks), std::tr1::get<1>(list_property_callbacks), std::tr1::get<2>(list_property_callbacks))));
|
current_element_->properties.push_back(std::shared_ptr<property>(new list_property<size_type, scalar_type>(property_name, std::get<0>(list_property_callbacks), std::get<1>(list_property_callbacks), std::get<2>(list_property_callbacks))));
|
||||||
}
|
}
|
||||||
|
|
||||||
template <typename ScalarType>
|
template <typename ScalarType>
|
||||||
|
|
Loading…
Reference in New Issue