Added boost header
This commit is contained in:
120
test/external/boost/geometry/geometries/adapted/boost_array.hpp
vendored
Normal file
120
test/external/boost/geometry/geometries/adapted/boost_array.hpp
vendored
Normal file
@@ -0,0 +1,120 @@
|
||||
// Boost.Geometry (aka GGL, Generic Geometry Library)
|
||||
|
||||
// Copyright (c) 2010 Alfredo Correa
|
||||
// Copyright (c) 2010-2011 Barend Gehrels, Amsterdam, the Netherlands.
|
||||
|
||||
// Use, modification and distribution is subject to the Boost Software License,
|
||||
// Version 1.0. (See accompanying file LICENSE_1_0.txt or copy at
|
||||
// http://www.boost.org/LICENSE_1_0.txt)
|
||||
|
||||
#ifndef BOOST_GEOMETRY_GEOMETRIES_ADAPTED_BOOST_ARRAY_HPP
|
||||
#define BOOST_GEOMETRY_GEOMETRIES_ADAPTED_BOOST_ARRAY_HPP
|
||||
|
||||
|
||||
#ifdef BOOST_GEOMETRY_ADAPTED_BOOST_ARRAY_TAG_DEFINED
|
||||
#error Include either "boost_array_as_point" or \
|
||||
"boost_array_as_linestring" or "boost_array_as_ring" \
|
||||
or "boost_array_as_multi_point" to adapt a boost_array
|
||||
#endif
|
||||
|
||||
#define BOOST_GEOMETRY_ADAPTED_BOOST_ARRAY_TAG_DEFINED
|
||||
|
||||
|
||||
#include <cstddef>
|
||||
|
||||
#include <boost/type_traits/is_arithmetic.hpp>
|
||||
|
||||
#include <boost/geometry/core/access.hpp>
|
||||
#include <boost/geometry/core/cs.hpp>
|
||||
#include <boost/geometry/core/coordinate_dimension.hpp>
|
||||
#include <boost/geometry/core/coordinate_type.hpp>
|
||||
#include <boost/geometry/core/tags.hpp>
|
||||
|
||||
#include <boost/array.hpp>
|
||||
|
||||
namespace boost { namespace geometry
|
||||
{
|
||||
|
||||
|
||||
#ifndef DOXYGEN_NO_TRAITS_SPECIALIZATIONS
|
||||
namespace traits
|
||||
{
|
||||
|
||||
|
||||
#ifndef DOXYGEN_NO_DETAIL
|
||||
namespace detail
|
||||
{
|
||||
|
||||
|
||||
// Create class and specialization to indicate the tag
|
||||
// for normal cases and the case that the type of the c-array is arithmetic
|
||||
template <bool>
|
||||
struct boost_array_tag
|
||||
{
|
||||
typedef geometry_not_recognized_tag type;
|
||||
};
|
||||
|
||||
|
||||
template <>
|
||||
struct boost_array_tag<true>
|
||||
{
|
||||
typedef point_tag type;
|
||||
};
|
||||
|
||||
|
||||
} // namespace detail
|
||||
#endif // DOXYGEN_NO_DETAIL
|
||||
|
||||
|
||||
// Assign the point-tag, preventing arrays of points getting a point-tag
|
||||
template <typename CoordinateType, std::size_t DimensionCount>
|
||||
struct tag<boost::array<CoordinateType, DimensionCount> >
|
||||
: detail::boost_array_tag<boost::is_arithmetic<CoordinateType>::value> {};
|
||||
|
||||
|
||||
template <typename CoordinateType, std::size_t DimensionCount>
|
||||
struct coordinate_type<boost::array<CoordinateType, DimensionCount> >
|
||||
{
|
||||
typedef CoordinateType type;
|
||||
};
|
||||
|
||||
|
||||
template <typename CoordinateType, std::size_t DimensionCount>
|
||||
struct dimension<boost::array<CoordinateType, DimensionCount> >: boost::mpl::int_<DimensionCount> {};
|
||||
|
||||
|
||||
template <typename CoordinateType, std::size_t DimensionCount, std::size_t Dimension>
|
||||
struct access<boost::array<CoordinateType, DimensionCount>, Dimension>
|
||||
{
|
||||
static inline CoordinateType get(boost::array<CoordinateType, DimensionCount> const& a)
|
||||
{
|
||||
return a[Dimension];
|
||||
}
|
||||
|
||||
static inline void set(boost::array<CoordinateType, DimensionCount>& a,
|
||||
CoordinateType const& value)
|
||||
{
|
||||
a[Dimension] = value;
|
||||
}
|
||||
};
|
||||
|
||||
|
||||
} // namespace traits
|
||||
#endif // DOXYGEN_NO_TRAITS_SPECIALIZATIONS
|
||||
|
||||
|
||||
}} // namespace boost::geometry
|
||||
|
||||
|
||||
#define BOOST_GEOMETRY_REGISTER_BOOST_ARRAY_CS(CoordinateSystem) \
|
||||
namespace boost { namespace geometry { namespace traits { \
|
||||
template <class T, std::size_t N> \
|
||||
struct coordinate_system<boost::array<T, N> > \
|
||||
{ \
|
||||
typedef CoordinateSystem type; \
|
||||
}; \
|
||||
}}}
|
||||
|
||||
|
||||
#endif // BOOST_GEOMETRY_GEOMETRIES_ADAPTED_BOOST_ARRAY_HPP
|
||||
|
||||
172
test/external/boost/geometry/geometries/adapted/boost_fusion.hpp
vendored
Normal file
172
test/external/boost/geometry/geometries/adapted/boost_fusion.hpp
vendored
Normal file
@@ -0,0 +1,172 @@
|
||||
// Boost.Geometry (aka GGL, Generic Geometry Library)
|
||||
|
||||
// Copyright (c) 2011 Akira Takahashi
|
||||
// Copyright (c) 2011 Barend Gehrels, Amsterdam, the Netherlands.
|
||||
|
||||
// Use, modification and distribution is subject to the Boost Software License,
|
||||
// Version 1.0. (See accompanying file LICENSE_1_0.txt or copy at
|
||||
// http://www.boost.org/LICENSE_1_0.txt)
|
||||
|
||||
#ifndef BOOST_GEOMETRY_GEOMETRIES_ADAPTED_FUSION_HPP
|
||||
#define BOOST_GEOMETRY_GEOMETRIES_ADAPTED_FUSION_HPP
|
||||
|
||||
|
||||
#include <cstddef>
|
||||
|
||||
#include <boost/fusion/include/is_sequence.hpp>
|
||||
#include <boost/fusion/include/size.hpp>
|
||||
#include <boost/fusion/include/tag_of.hpp>
|
||||
#include <boost/fusion/include/front.hpp>
|
||||
#include <boost/fusion/include/at.hpp>
|
||||
#include <boost/utility/enable_if.hpp>
|
||||
|
||||
#include <boost/fusion/mpl.hpp>
|
||||
#include <boost/mpl/front.hpp>
|
||||
#include <boost/mpl/count_if.hpp>
|
||||
#include <boost/mpl/pop_front.hpp>
|
||||
#include <boost/mpl/size.hpp>
|
||||
#include <boost/type_traits/is_same.hpp>
|
||||
#include <boost/type_traits/remove_reference.hpp>
|
||||
#include <boost/mpl/placeholders.hpp>
|
||||
#include <boost/mpl/and.hpp>
|
||||
#include <boost/mpl/front.hpp>
|
||||
|
||||
#include <boost/geometry/core/access.hpp>
|
||||
#include <boost/geometry/core/coordinate_dimension.hpp>
|
||||
#include <boost/geometry/core/coordinate_system.hpp>
|
||||
#include <boost/geometry/core/coordinate_type.hpp>
|
||||
#include <boost/geometry/core/point_type.hpp>
|
||||
#include <boost/geometry/core/tags.hpp>
|
||||
|
||||
|
||||
namespace boost { namespace geometry
|
||||
{
|
||||
|
||||
namespace fusion_adapt_detail
|
||||
{
|
||||
|
||||
template <class Sequence>
|
||||
struct all_same :
|
||||
boost::mpl::bool_<
|
||||
boost::mpl::count_if<
|
||||
Sequence,
|
||||
boost::is_same<
|
||||
typename boost::mpl::front<Sequence>::type,
|
||||
boost::mpl::_
|
||||
>
|
||||
>::value == boost::mpl::size<Sequence>::value
|
||||
>
|
||||
{};
|
||||
|
||||
template <class Sequence>
|
||||
struct is_coordinate_size : boost::mpl::bool_<
|
||||
boost::fusion::result_of::size<Sequence>::value == 2 ||
|
||||
boost::fusion::result_of::size<Sequence>::value == 3> {};
|
||||
|
||||
template<typename Sequence>
|
||||
struct is_fusion_sequence
|
||||
: mpl::and_<boost::fusion::traits::is_sequence<Sequence>,
|
||||
fusion_adapt_detail::is_coordinate_size<Sequence>,
|
||||
fusion_adapt_detail::all_same<Sequence> >
|
||||
{};
|
||||
|
||||
|
||||
} // namespace fusion_adapt_detail
|
||||
|
||||
|
||||
#ifndef DOXYGEN_NO_TRAITS_SPECIALIZATIONS
|
||||
namespace traits
|
||||
{
|
||||
|
||||
// Boost Fusion Sequence, 2D or 3D
|
||||
template <typename Sequence>
|
||||
struct coordinate_type
|
||||
<
|
||||
Sequence,
|
||||
typename boost::enable_if
|
||||
<
|
||||
fusion_adapt_detail::is_fusion_sequence<Sequence>
|
||||
>::type
|
||||
>
|
||||
{
|
||||
typedef typename boost::mpl::front<Sequence>::type type;
|
||||
};
|
||||
|
||||
|
||||
template <typename Sequence>
|
||||
struct dimension
|
||||
<
|
||||
Sequence,
|
||||
typename boost::enable_if
|
||||
<
|
||||
fusion_adapt_detail::is_fusion_sequence<Sequence>
|
||||
>::type
|
||||
> : boost::mpl::size<Sequence>
|
||||
{};
|
||||
|
||||
|
||||
template <typename Sequence, std::size_t Dimension>
|
||||
struct access
|
||||
<
|
||||
Sequence,
|
||||
Dimension,
|
||||
typename boost::enable_if
|
||||
<
|
||||
fusion_adapt_detail::is_fusion_sequence<Sequence>
|
||||
>::type
|
||||
>
|
||||
{
|
||||
typedef typename coordinate_type<Sequence>::type ctype;
|
||||
|
||||
static inline ctype get(Sequence const& point)
|
||||
{
|
||||
return boost::fusion::at_c<Dimension>(point);
|
||||
}
|
||||
|
||||
template <class CoordinateType>
|
||||
static inline void set(Sequence& point, CoordinateType const& value)
|
||||
{
|
||||
boost::fusion::at_c<Dimension>(point) = value;
|
||||
}
|
||||
};
|
||||
|
||||
|
||||
template <typename Sequence>
|
||||
struct tag
|
||||
<
|
||||
Sequence,
|
||||
typename boost::enable_if
|
||||
<
|
||||
fusion_adapt_detail::is_fusion_sequence<Sequence>
|
||||
>::type
|
||||
>
|
||||
{
|
||||
typedef point_tag type;
|
||||
};
|
||||
|
||||
|
||||
} // namespace traits
|
||||
|
||||
#endif // DOXYGEN_NO_TRAITS_SPECIALIZATIONS
|
||||
|
||||
|
||||
}} // namespace boost::geometry
|
||||
|
||||
|
||||
// Convenience registration macro to bind a Fusion sequence to a CS
|
||||
#define BOOST_GEOMETRY_REGISTER_BOOST_FUSION_CS(CoordinateSystem) \
|
||||
namespace boost { namespace geometry { namespace traits { \
|
||||
template <typename Sequence> \
|
||||
struct coordinate_system \
|
||||
< \
|
||||
Sequence, \
|
||||
typename boost::enable_if \
|
||||
< \
|
||||
fusion_adapt_detail::is_fusion_sequence<Sequence> \
|
||||
>::type \
|
||||
> \
|
||||
{ typedef CoordinateSystem type; }; \
|
||||
}}}
|
||||
|
||||
|
||||
#endif // BOOST_GEOMETRY_GEOMETRIES_ADAPTED_FUSION_HPP
|
||||
18
test/external/boost/geometry/geometries/adapted/boost_polygon.hpp
vendored
Normal file
18
test/external/boost/geometry/geometries/adapted/boost_polygon.hpp
vendored
Normal file
@@ -0,0 +1,18 @@
|
||||
// Boost.Geometry (aka GGL, Generic Geometry Library)
|
||||
|
||||
// Copyright (c) 2010-2011 Barend Gehrels, Amsterdam, the Netherlands.
|
||||
|
||||
// Use, modification and distribution is subject to the Boost Software License,
|
||||
// Version 1.0. (See accompanying file LICENSE_1_0.txt or copy at
|
||||
// http://www.boost.org/LICENSE_1_0.txt)
|
||||
|
||||
#ifndef BOOST_GEOMETRY_GEOMETRIES_ADAPTED_BOOST_POLYGON_HPP
|
||||
#define BOOST_GEOMETRY_GEOMETRIES_ADAPTED_BOOST_POLYGON_HPP
|
||||
|
||||
#include <boost/geometry/geometries/adapted/boost_polygon/point.hpp>
|
||||
#include <boost/geometry/geometries/adapted/boost_polygon/box.hpp>
|
||||
#include <boost/geometry/geometries/adapted/boost_polygon/ring.hpp>
|
||||
#include <boost/geometry/geometries/adapted/boost_polygon/polygon.hpp>
|
||||
|
||||
#endif // BOOST_GEOMETRY_GEOMETRIES_ADAPTED_BOOST_POLYGON_HPP
|
||||
|
||||
141
test/external/boost/geometry/geometries/adapted/boost_polygon/box.hpp
vendored
Normal file
141
test/external/boost/geometry/geometries/adapted/boost_polygon/box.hpp
vendored
Normal file
@@ -0,0 +1,141 @@
|
||||
// Boost.Geometry (aka GGL, Generic Geometry Library)
|
||||
|
||||
// Copyright (c) 2010-2011 Barend Gehrels, Amsterdam, the Netherlands.
|
||||
|
||||
// Use, modification and distribution is subject to the Boost Software License,
|
||||
// Version 1.0. (See accompanying file LICENSE_1_0.txt or copy at
|
||||
// http://www.boost.org/LICENSE_1_0.txt)
|
||||
|
||||
#ifndef BOOST_GEOMETRY_GEOMETRIES_ADAPTED_BOOST_POLYGON_BOX_HPP
|
||||
#define BOOST_GEOMETRY_GEOMETRIES_ADAPTED_BOOST_POLYGON_BOX_HPP
|
||||
|
||||
// Adapts Geometries from Boost.Polygon for usage in Boost.Geometry
|
||||
// boost::polygon::rectangle_data -> boost::geometry::box
|
||||
|
||||
|
||||
#include <boost/polygon/polygon.hpp>
|
||||
|
||||
#include <boost/geometry/core/access.hpp>
|
||||
#include <boost/geometry/core/cs.hpp>
|
||||
#include <boost/geometry/core/coordinate_dimension.hpp>
|
||||
#include <boost/geometry/core/coordinate_type.hpp>
|
||||
#include <boost/geometry/core/tags.hpp>
|
||||
|
||||
|
||||
namespace boost { namespace geometry
|
||||
{
|
||||
|
||||
|
||||
#ifndef DOXYGEN_NO_TRAITS_SPECIALIZATIONS
|
||||
namespace traits
|
||||
{
|
||||
|
||||
|
||||
template <typename CoordinateType>
|
||||
struct tag<boost::polygon::rectangle_data<CoordinateType> >
|
||||
{
|
||||
typedef box_tag type;
|
||||
};
|
||||
|
||||
|
||||
template <typename CoordinateType>
|
||||
struct point_type<boost::polygon::rectangle_data<CoordinateType> >
|
||||
{
|
||||
// Not sure what to do here. Boost.Polygon's rectangle does NOT define its
|
||||
// point_type (but uses it...)
|
||||
typedef boost::polygon::point_data<CoordinateType> type;
|
||||
};
|
||||
|
||||
|
||||
template <typename CoordinateType>
|
||||
struct indexed_access
|
||||
<
|
||||
boost::polygon::rectangle_data<CoordinateType>,
|
||||
min_corner, 0
|
||||
>
|
||||
{
|
||||
typedef boost::polygon::rectangle_data<CoordinateType> box_type;
|
||||
|
||||
static inline CoordinateType get(box_type const& b)
|
||||
{
|
||||
return boost::polygon::xl(b);
|
||||
}
|
||||
|
||||
static inline void set(box_type& b, CoordinateType const& value)
|
||||
{
|
||||
boost::polygon::xl(b, value);
|
||||
}
|
||||
};
|
||||
|
||||
|
||||
template <typename CoordinateType>
|
||||
struct indexed_access
|
||||
<
|
||||
boost::polygon::rectangle_data<CoordinateType>,
|
||||
min_corner, 1
|
||||
>
|
||||
{
|
||||
typedef boost::polygon::rectangle_data<CoordinateType> box_type;
|
||||
|
||||
static inline CoordinateType get(box_type const& b)
|
||||
{
|
||||
return boost::polygon::yl(b);
|
||||
}
|
||||
|
||||
static inline void set(box_type& b, CoordinateType const& value)
|
||||
{
|
||||
boost::polygon::yl(b, value);
|
||||
}
|
||||
};
|
||||
|
||||
|
||||
template <typename CoordinateType>
|
||||
struct indexed_access
|
||||
<
|
||||
boost::polygon::rectangle_data<CoordinateType>,
|
||||
max_corner, 0
|
||||
>
|
||||
{
|
||||
typedef boost::polygon::rectangle_data<CoordinateType> box_type;
|
||||
|
||||
static inline CoordinateType get(box_type const& b)
|
||||
{
|
||||
return boost::polygon::xh(b);
|
||||
}
|
||||
|
||||
static inline void set(box_type& b, CoordinateType const& value)
|
||||
{
|
||||
boost::polygon::xh(b, value);
|
||||
}
|
||||
};
|
||||
|
||||
|
||||
template <typename CoordinateType>
|
||||
struct indexed_access
|
||||
<
|
||||
boost::polygon::rectangle_data<CoordinateType>,
|
||||
max_corner, 1
|
||||
>
|
||||
{
|
||||
typedef boost::polygon::rectangle_data<CoordinateType> box_type;
|
||||
|
||||
static inline CoordinateType get(box_type const& b)
|
||||
{
|
||||
return boost::polygon::yh(b);
|
||||
}
|
||||
|
||||
static inline void set(box_type& b, CoordinateType const& value)
|
||||
{
|
||||
boost::polygon::yh(b, value);
|
||||
}
|
||||
};
|
||||
|
||||
|
||||
} // namespace traits
|
||||
#endif // DOXYGEN_NO_TRAITS_SPECIALIZATIONS
|
||||
|
||||
|
||||
}} // namespace boost::geometry
|
||||
|
||||
|
||||
#endif // BOOST_GEOMETRY_GEOMETRIES_ADAPTED_BOOST_POLYGON_BOX_HPP
|
||||
84
test/external/boost/geometry/geometries/adapted/boost_polygon/hole_iterator.hpp
vendored
Normal file
84
test/external/boost/geometry/geometries/adapted/boost_polygon/hole_iterator.hpp
vendored
Normal file
@@ -0,0 +1,84 @@
|
||||
// Boost.Geometry (aka GGL, Generic Geometry Library)
|
||||
|
||||
// Copyright (c) 2010-2011 Barend Gehrels, Amsterdam, the Netherlands.
|
||||
|
||||
// Use, modification and distribution is subject to the Boost Software License,
|
||||
// Version 1.0. (See accompanying file LICENSE_1_0.txt or copy at
|
||||
// http://www.boost.org/LICENSE_1_0.txt)
|
||||
|
||||
#ifndef BOOST_GEOMETRY_GEOMETRIES_ADAPTED_BOOST_POLYGON_HOLE_ITERATOR_HPP
|
||||
#define BOOST_GEOMETRY_GEOMETRIES_ADAPTED_BOOST_POLYGON_HOLE_ITERATOR_HPP
|
||||
|
||||
// Adapts Geometries from Boost.Polygon for usage in Boost.Geometry
|
||||
// boost::polygon::polygon_with_holes_data -> boost::geometry::polygon
|
||||
// hole_iterator -> returning ring_proxy's instead of normal polygon_data
|
||||
|
||||
#include <boost/polygon/polygon.hpp>
|
||||
|
||||
#include <boost/iterator.hpp>
|
||||
#include <boost/iterator/iterator_facade.hpp>
|
||||
|
||||
|
||||
namespace boost { namespace geometry
|
||||
{
|
||||
|
||||
namespace adapt { namespace bp
|
||||
{
|
||||
|
||||
|
||||
template <typename Polygon, typename RingProxy>
|
||||
class hole_iterator
|
||||
: public ::boost::iterator_facade
|
||||
<
|
||||
hole_iterator<Polygon, RingProxy>,
|
||||
RingProxy, // value type
|
||||
boost::forward_traversal_tag,
|
||||
RingProxy // reference type
|
||||
>
|
||||
{
|
||||
public :
|
||||
typedef typename boost::polygon::polygon_with_holes_traits
|
||||
<
|
||||
Polygon
|
||||
>::iterator_holes_type ith_type;
|
||||
|
||||
explicit inline hole_iterator(Polygon& polygon, ith_type const it)
|
||||
: m_polygon(polygon)
|
||||
, m_base(it)
|
||||
{
|
||||
}
|
||||
|
||||
typedef std::ptrdiff_t difference_type;
|
||||
|
||||
private:
|
||||
friend class boost::iterator_core_access;
|
||||
|
||||
inline RingProxy dereference() const
|
||||
{
|
||||
return RingProxy(m_polygon, this->m_base);
|
||||
}
|
||||
|
||||
inline void increment() { ++m_base; }
|
||||
inline void decrement() { --m_base; }
|
||||
inline void advance(difference_type n)
|
||||
{
|
||||
for (int i = 0; i < n; i++)
|
||||
{
|
||||
++m_base;
|
||||
}
|
||||
}
|
||||
|
||||
inline bool equal(hole_iterator<Polygon, RingProxy> const& other) const
|
||||
{
|
||||
return this->m_base == other.m_base;
|
||||
}
|
||||
|
||||
Polygon& m_polygon;
|
||||
ith_type m_base;
|
||||
};
|
||||
|
||||
|
||||
}}}}
|
||||
|
||||
#endif // BOOST_GEOMETRY_GEOMETRIES_ADAPTED_BOOST_POLYGON_HOLE_ITERATOR_HPP
|
||||
|
||||
204
test/external/boost/geometry/geometries/adapted/boost_polygon/holes_proxy.hpp
vendored
Normal file
204
test/external/boost/geometry/geometries/adapted/boost_polygon/holes_proxy.hpp
vendored
Normal file
@@ -0,0 +1,204 @@
|
||||
// Boost.Geometry (aka GGL, Generic Geometry Library)
|
||||
|
||||
// Copyright (c) 2010-2011 Barend Gehrels, Amsterdam, the Netherlands.
|
||||
|
||||
// Use, modification and distribution is subject to the Boost Software License,
|
||||
// Version 1.0. (See accompanying file LICENSE_1_0.txt or copy at
|
||||
// http://www.boost.org/LICENSE_1_0.txt)
|
||||
|
||||
#ifndef BOOST_GEOMETRY_GEOMETRIES_ADAPTED_BOOST_POLYGON_HOLES_PROXY_HPP
|
||||
#define BOOST_GEOMETRY_GEOMETRIES_ADAPTED_BOOST_POLYGON_HOLES_PROXY_HPP
|
||||
|
||||
// Adapts Geometries from Boost.Polygon for usage in Boost.Geometry
|
||||
// boost::polygon::polygon_with_holes_data -> boost::geometry::polygon
|
||||
// pair{begin_holes, begin_holes} -> interior_proxy
|
||||
|
||||
#include <boost/polygon/polygon.hpp>
|
||||
|
||||
#include <boost/geometry/geometries/adapted/boost_polygon/hole_iterator.hpp>
|
||||
#include <boost/geometry/geometries/adapted/boost_polygon/ring_proxy.hpp>
|
||||
|
||||
|
||||
namespace boost { namespace geometry
|
||||
{
|
||||
|
||||
namespace adapt { namespace bp
|
||||
{
|
||||
|
||||
|
||||
// Polygon should implement the boost::polygon::polygon_with_holes_concept
|
||||
// Specify constness in the template parameter if necessary
|
||||
template<typename Polygon>
|
||||
struct holes_proxy
|
||||
{
|
||||
typedef ring_proxy
|
||||
<
|
||||
typename boost::mpl::if_
|
||||
<
|
||||
typename boost::is_const<Polygon>,
|
||||
Polygon const,
|
||||
Polygon
|
||||
>::type
|
||||
> proxy_type;
|
||||
typedef hole_iterator<Polygon, proxy_type> iterator_type;
|
||||
|
||||
// The next line does not work probably because coordinate_type is part of the
|
||||
// polygon_traits, but not of the polygon_with_holes_traits
|
||||
// typedef typename boost::polygon::polygon_traits<Polygon>::coordinate_type coordinate_type;
|
||||
|
||||
// So we use:
|
||||
typedef typename Polygon::coordinate_type coordinate_type;
|
||||
|
||||
inline holes_proxy(Polygon& p)
|
||||
: polygon(p)
|
||||
{}
|
||||
|
||||
inline void clear()
|
||||
{
|
||||
Polygon empty;
|
||||
// Clear the holes
|
||||
polygon.set_holes
|
||||
(
|
||||
boost::polygon::begin_holes(empty),
|
||||
boost::polygon::end_holes(empty)
|
||||
);
|
||||
}
|
||||
|
||||
inline void resize(std::size_t new_size)
|
||||
{
|
||||
std::vector<boost::polygon::polygon_data<coordinate_type> > temporary_copy
|
||||
(
|
||||
boost::polygon::begin_holes(polygon),
|
||||
boost::polygon::end_holes(polygon)
|
||||
);
|
||||
temporary_copy.resize(new_size);
|
||||
polygon.set_holes(temporary_copy.begin(), temporary_copy.end());
|
||||
}
|
||||
|
||||
template <typename Ring>
|
||||
inline void push_back(Ring const& ring)
|
||||
{
|
||||
std::vector<boost::polygon::polygon_data<coordinate_type> > temporary_copy
|
||||
(
|
||||
boost::polygon::begin_holes(polygon),
|
||||
boost::polygon::end_holes(polygon)
|
||||
);
|
||||
boost::polygon::polygon_data<coordinate_type> added;
|
||||
boost::polygon::set_points(added, ring.begin(), ring.end());
|
||||
temporary_copy.push_back(added);
|
||||
polygon.set_holes(temporary_copy.begin(), temporary_copy.end());
|
||||
}
|
||||
|
||||
|
||||
Polygon& polygon;
|
||||
};
|
||||
|
||||
|
||||
// Support holes_proxy for Boost.Range ADP
|
||||
|
||||
// Const versions
|
||||
template<typename Polygon>
|
||||
inline typename boost::geometry::adapt::bp::holes_proxy<Polygon const>::iterator_type
|
||||
range_begin(boost::geometry::adapt::bp::holes_proxy<Polygon const> const& proxy)
|
||||
{
|
||||
typename boost::geometry::adapt::bp::holes_proxy<Polygon const>::iterator_type
|
||||
begin(proxy.polygon, boost::polygon::begin_holes(proxy.polygon));
|
||||
return begin;
|
||||
}
|
||||
|
||||
template<typename Polygon>
|
||||
inline typename boost::geometry::adapt::bp::holes_proxy<Polygon const>::iterator_type
|
||||
range_end(boost::geometry::adapt::bp::holes_proxy<Polygon const> const& proxy)
|
||||
{
|
||||
typename boost::geometry::adapt::bp::holes_proxy<Polygon const>::iterator_type
|
||||
end(proxy.polygon, boost::polygon::end_holes(proxy.polygon));
|
||||
return end;
|
||||
}
|
||||
|
||||
// Mutable versions
|
||||
template<typename Polygon>
|
||||
inline typename boost::geometry::adapt::bp::holes_proxy<Polygon>::iterator_type
|
||||
range_begin(boost::geometry::adapt::bp::holes_proxy<Polygon>& proxy)
|
||||
{
|
||||
typename boost::geometry::adapt::bp::holes_proxy<Polygon>::iterator_type
|
||||
begin(proxy.polygon, boost::polygon::begin_holes(proxy.polygon));
|
||||
return begin;
|
||||
}
|
||||
|
||||
template<typename Polygon>
|
||||
inline typename boost::geometry::adapt::bp::holes_proxy<Polygon>::iterator_type
|
||||
range_end(boost::geometry::adapt::bp::holes_proxy<Polygon>& proxy)
|
||||
{
|
||||
typename boost::geometry::adapt::bp::holes_proxy<Polygon>::iterator_type
|
||||
end(proxy.polygon, boost::polygon::end_holes(proxy.polygon));
|
||||
return end;
|
||||
}
|
||||
|
||||
|
||||
}}
|
||||
|
||||
namespace traits
|
||||
{
|
||||
|
||||
template <typename Polygon>
|
||||
struct rvalue_type<adapt::bp::holes_proxy<Polygon> >
|
||||
{
|
||||
typedef adapt::bp::holes_proxy<Polygon> type;
|
||||
};
|
||||
|
||||
|
||||
template <typename Polygon>
|
||||
struct clear<adapt::bp::holes_proxy<Polygon> >
|
||||
{
|
||||
static inline void apply(adapt::bp::holes_proxy<Polygon> proxy)
|
||||
{
|
||||
proxy.clear();
|
||||
}
|
||||
};
|
||||
|
||||
template <typename Polygon>
|
||||
struct resize<adapt::bp::holes_proxy<Polygon> >
|
||||
{
|
||||
static inline void apply(adapt::bp::holes_proxy<Polygon> proxy, std::size_t new_size)
|
||||
{
|
||||
proxy.resize(new_size);
|
||||
}
|
||||
};
|
||||
|
||||
template <typename Polygon>
|
||||
struct push_back<adapt::bp::holes_proxy<Polygon> >
|
||||
{
|
||||
template <typename Ring>
|
||||
static inline void apply(adapt::bp::holes_proxy<Polygon> proxy, Ring const& ring)
|
||||
{
|
||||
proxy.push_back(ring);
|
||||
}
|
||||
};
|
||||
|
||||
|
||||
|
||||
} // namespace traits
|
||||
|
||||
|
||||
}}
|
||||
|
||||
|
||||
// Specialize holes_proxy for Boost.Range
|
||||
namespace boost
|
||||
{
|
||||
template<typename Polygon>
|
||||
struct range_mutable_iterator<geometry::adapt::bp::holes_proxy<Polygon> >
|
||||
{
|
||||
typedef typename geometry::adapt::bp::holes_proxy<Polygon>::iterator_type type;
|
||||
};
|
||||
|
||||
template<typename Polygon>
|
||||
struct range_const_iterator<geometry::adapt::bp::holes_proxy<Polygon> >
|
||||
{
|
||||
typedef typename geometry::adapt::bp::holes_proxy<Polygon const>::iterator_type type;
|
||||
};
|
||||
|
||||
} // namespace boost
|
||||
|
||||
|
||||
#endif // BOOST_GEOMETRY_GEOMETRIES_ADAPTED_BOOST_POLYGON_HOLES_PROXY_HPP
|
||||
102
test/external/boost/geometry/geometries/adapted/boost_polygon/point.hpp
vendored
Normal file
102
test/external/boost/geometry/geometries/adapted/boost_polygon/point.hpp
vendored
Normal file
@@ -0,0 +1,102 @@
|
||||
// Boost.Geometry (aka GGL, Generic Geometry Library)
|
||||
|
||||
// Copyright (c) 2010-2011 Barend Gehrels, Amsterdam, the Netherlands.
|
||||
|
||||
// Use, modification and distribution is subject to the Boost Software License,
|
||||
// Version 1.0. (See accompanying file LICENSE_1_0.txt or copy at
|
||||
// http://www.boost.org/LICENSE_1_0.txt)
|
||||
|
||||
#ifndef BOOST_GEOMETRY_GEOMETRIES_ADAPTED_BOOST_POLYGON_POINT_HPP
|
||||
#define BOOST_GEOMETRY_GEOMETRIES_ADAPTED_BOOST_POLYGON_POINT_HPP
|
||||
|
||||
// Adapts Geometries from Boost.Polygon for usage in Boost.Geometry
|
||||
// boost::polygon::point_data -> boost::geometry::point
|
||||
|
||||
|
||||
#include <boost/polygon/polygon.hpp>
|
||||
|
||||
#include <boost/geometry/core/access.hpp>
|
||||
#include <boost/geometry/core/cs.hpp>
|
||||
#include <boost/geometry/core/coordinate_dimension.hpp>
|
||||
#include <boost/geometry/core/coordinate_type.hpp>
|
||||
#include <boost/geometry/core/tags.hpp>
|
||||
|
||||
|
||||
namespace boost { namespace geometry
|
||||
{
|
||||
|
||||
|
||||
#ifndef DOXYGEN_NO_TRAITS_SPECIALIZATIONS
|
||||
namespace traits
|
||||
{
|
||||
|
||||
|
||||
template <typename CoordinateType>
|
||||
struct tag<boost::polygon::point_data<CoordinateType> >
|
||||
{
|
||||
typedef point_tag type;
|
||||
};
|
||||
|
||||
|
||||
template <typename CoordinateType>
|
||||
struct coordinate_type<boost::polygon::point_data<CoordinateType> >
|
||||
{
|
||||
typedef CoordinateType type;
|
||||
};
|
||||
|
||||
|
||||
template <typename CoordinateType>
|
||||
struct coordinate_system<boost::polygon::point_data<CoordinateType> >
|
||||
{
|
||||
typedef cs::cartesian type;
|
||||
};
|
||||
|
||||
|
||||
template <typename CoordinateType>
|
||||
struct dimension<boost::polygon::point_data<CoordinateType> >
|
||||
: boost::mpl::int_<2>
|
||||
{};
|
||||
|
||||
|
||||
template <typename CoordinateType>
|
||||
struct access<boost::polygon::point_data<CoordinateType>, 0>
|
||||
{
|
||||
typedef boost::polygon::point_data<CoordinateType> point_type;
|
||||
|
||||
static inline CoordinateType get(point_type const& p)
|
||||
{
|
||||
return p.x();
|
||||
}
|
||||
|
||||
static inline void set(point_type& p, CoordinateType const& value)
|
||||
{
|
||||
p.x(value);
|
||||
}
|
||||
};
|
||||
|
||||
|
||||
template <typename CoordinateType>
|
||||
struct access<boost::polygon::point_data<CoordinateType>, 1>
|
||||
{
|
||||
typedef boost::polygon::point_data<CoordinateType> point_type;
|
||||
|
||||
static inline CoordinateType get(point_type const& p)
|
||||
{
|
||||
return p.y();
|
||||
}
|
||||
|
||||
static inline void set(point_type& p, CoordinateType const& value)
|
||||
{
|
||||
p.y(value);
|
||||
}
|
||||
};
|
||||
|
||||
|
||||
} // namespace traits
|
||||
#endif // DOXYGEN_NO_TRAITS_SPECIALIZATIONS
|
||||
|
||||
|
||||
}} // namespace boost::geometry
|
||||
|
||||
|
||||
#endif // BOOST_GEOMETRY_GEOMETRIES_ADAPTED_BOOST_POLYGON_POINT_HPP
|
||||
111
test/external/boost/geometry/geometries/adapted/boost_polygon/polygon.hpp
vendored
Normal file
111
test/external/boost/geometry/geometries/adapted/boost_polygon/polygon.hpp
vendored
Normal file
@@ -0,0 +1,111 @@
|
||||
// Boost.Geometry (aka GGL, Generic Geometry Library)
|
||||
|
||||
// Copyright (c) 2010-2011 Barend Gehrels, Amsterdam, the Netherlands.
|
||||
|
||||
// Use, modification and distribution is subject to the Boost Software License,
|
||||
// Version 1.0. (See accompanying file LICENSE_1_0.txt or copy at
|
||||
// http://www.boost.org/LICENSE_1_0.txt)
|
||||
|
||||
#ifndef BOOST_GEOMETRY_GEOMETRIES_ADAPTED_BOOST_POLYGON_POLYGON_HPP
|
||||
#define BOOST_GEOMETRY_GEOMETRIES_ADAPTED_BOOST_POLYGON_POLYGON_HPP
|
||||
|
||||
// Adapts Geometries from Boost.Polygon for usage in Boost.Geometry
|
||||
// boost::polygon::polygon_with_holes_data -> boost::geometry::polygon
|
||||
|
||||
#include <boost/polygon/polygon.hpp>
|
||||
|
||||
#include <boost/geometry/core/tags.hpp>
|
||||
#include <boost/geometry/core/ring_type.hpp>
|
||||
#include <boost/geometry/core/exterior_ring.hpp>
|
||||
#include <boost/geometry/core/interior_rings.hpp>
|
||||
|
||||
#include <boost/geometry/geometries/adapted/boost_polygon/ring_proxy.hpp>
|
||||
#include <boost/geometry/geometries/adapted/boost_polygon/hole_iterator.hpp>
|
||||
#include <boost/geometry/geometries/adapted/boost_polygon/holes_proxy.hpp>
|
||||
|
||||
|
||||
namespace boost { namespace geometry
|
||||
{
|
||||
|
||||
|
||||
#ifndef DOXYGEN_NO_TRAITS_SPECIALIZATIONS
|
||||
namespace traits
|
||||
{
|
||||
|
||||
template <typename CoordinateType>
|
||||
struct tag<boost::polygon::polygon_with_holes_data<CoordinateType> >
|
||||
{
|
||||
typedef polygon_tag type;
|
||||
};
|
||||
|
||||
template <typename CoordinateType>
|
||||
struct ring_const_type<boost::polygon::polygon_with_holes_data<CoordinateType> >
|
||||
{
|
||||
typedef adapt::bp::ring_proxy<boost::polygon::polygon_with_holes_data<CoordinateType> const> type;
|
||||
};
|
||||
|
||||
template <typename CoordinateType>
|
||||
struct ring_mutable_type<boost::polygon::polygon_with_holes_data<CoordinateType> >
|
||||
{
|
||||
typedef adapt::bp::ring_proxy<boost::polygon::polygon_with_holes_data<CoordinateType> > type;
|
||||
};
|
||||
|
||||
template <typename CoordinateType>
|
||||
struct interior_const_type<boost::polygon::polygon_with_holes_data<CoordinateType> >
|
||||
{
|
||||
typedef adapt::bp::holes_proxy<boost::polygon::polygon_with_holes_data<CoordinateType> const> type;
|
||||
};
|
||||
|
||||
template <typename CoordinateType>
|
||||
struct interior_mutable_type<boost::polygon::polygon_with_holes_data<CoordinateType> >
|
||||
{
|
||||
typedef adapt::bp::holes_proxy<boost::polygon::polygon_with_holes_data<CoordinateType> > type;
|
||||
};
|
||||
|
||||
|
||||
template <typename CoordinateType>
|
||||
struct exterior_ring<boost::polygon::polygon_with_holes_data<CoordinateType> >
|
||||
{
|
||||
typedef boost::polygon::polygon_with_holes_data<CoordinateType> polygon_type;
|
||||
typedef adapt::bp::ring_proxy<polygon_type> proxy;
|
||||
typedef adapt::bp::ring_proxy<polygon_type const> const_proxy;
|
||||
|
||||
static inline proxy get(polygon_type& p)
|
||||
{
|
||||
return proxy(p);
|
||||
}
|
||||
|
||||
static inline const_proxy get(polygon_type const& p)
|
||||
{
|
||||
return const_proxy(p);
|
||||
}
|
||||
};
|
||||
|
||||
template <typename CoordinateType>
|
||||
struct interior_rings<boost::polygon::polygon_with_holes_data<CoordinateType> >
|
||||
{
|
||||
typedef boost::polygon::polygon_with_holes_data<CoordinateType> polygon_type;
|
||||
typedef adapt::bp::holes_proxy<polygon_type> proxy;
|
||||
typedef adapt::bp::holes_proxy<polygon_type const> const_proxy;
|
||||
|
||||
static inline proxy get(polygon_type& p)
|
||||
{
|
||||
return proxy(p);
|
||||
}
|
||||
|
||||
static inline const_proxy get(polygon_type const& p)
|
||||
{
|
||||
return const_proxy(p);
|
||||
}
|
||||
};
|
||||
|
||||
|
||||
|
||||
} // namespace traits
|
||||
#endif // DOXYGEN_NO_TRAITS_SPECIALIZATIONS
|
||||
|
||||
}} // namespace boost::geometry
|
||||
|
||||
|
||||
#endif // BOOST_GEOMETRY_GEOMETRIES_ADAPTED_BOOST_POLYGON_POLYGON_HPP
|
||||
|
||||
163
test/external/boost/geometry/geometries/adapted/boost_polygon/ring.hpp
vendored
Normal file
163
test/external/boost/geometry/geometries/adapted/boost_polygon/ring.hpp
vendored
Normal file
@@ -0,0 +1,163 @@
|
||||
// Boost.Geometry (aka GGL, Generic Geometry Library)
|
||||
|
||||
// Copyright (c) 2010-2011 Barend Gehrels, Amsterdam, the Netherlands.
|
||||
|
||||
// Use, modification and distribution is subject to the Boost Software License,
|
||||
// Version 1.0. (See accompanying file LICENSE_1_0.txt or copy at
|
||||
// http://www.boost.org/LICENSE_1_0.txt)
|
||||
|
||||
#ifndef BOOST_GEOMETRY_GEOMETRIES_ADAPTED_BOOST_POLYGON_RING_HPP
|
||||
#define BOOST_GEOMETRY_GEOMETRIES_ADAPTED_BOOST_POLYGON_RING_HPP
|
||||
|
||||
// Adapts Geometries from Boost.Polygon for usage in Boost.Geometry
|
||||
// boost::polygon::polygon_data -> boost::geometry::ring
|
||||
|
||||
#include <cstddef>
|
||||
#include <boost/polygon/polygon.hpp>
|
||||
|
||||
#include <boost/geometry/core/access.hpp>
|
||||
#include <boost/geometry/core/cs.hpp>
|
||||
#include <boost/geometry/core/coordinate_dimension.hpp>
|
||||
#include <boost/geometry/core/coordinate_type.hpp>
|
||||
#include <boost/geometry/core/mutable_range.hpp>
|
||||
#include <boost/geometry/core/tags.hpp>
|
||||
|
||||
|
||||
#ifndef DOXYGEN_NO_TRAITS_SPECIALIZATIONS
|
||||
|
||||
namespace boost { namespace geometry
|
||||
{
|
||||
|
||||
namespace traits
|
||||
{
|
||||
|
||||
template <typename CoordinateType>
|
||||
struct tag<boost::polygon::polygon_data<CoordinateType> >
|
||||
{
|
||||
typedef ring_tag type;
|
||||
};
|
||||
|
||||
template <typename CoordinateType>
|
||||
struct clear<boost::polygon::polygon_data<CoordinateType> >
|
||||
{
|
||||
static inline void apply(boost::polygon::polygon_data<CoordinateType>& data)
|
||||
{
|
||||
// There is no "clear" function but we can assign
|
||||
// a newly (and therefore empty) constructed polygon
|
||||
boost::polygon::assign(data, boost::polygon::polygon_data<CoordinateType>());
|
||||
}
|
||||
};
|
||||
|
||||
template <typename CoordinateType>
|
||||
struct push_back<boost::polygon::polygon_data<CoordinateType> >
|
||||
{
|
||||
typedef boost::polygon::point_data<CoordinateType> point_type;
|
||||
|
||||
static inline void apply(boost::polygon::polygon_data<CoordinateType>& data,
|
||||
point_type const& point)
|
||||
{
|
||||
// Boost.Polygon's polygons are not appendable. So create a temporary vector,
|
||||
// add a record and set it to the original. Of course: this is not efficient.
|
||||
// But there seems no other way (without using a wrapper)
|
||||
std::vector<point_type> temporary_vector
|
||||
(
|
||||
boost::polygon::begin_points(data),
|
||||
boost::polygon::end_points(data)
|
||||
);
|
||||
temporary_vector.push_back(point);
|
||||
data.set(temporary_vector.begin(), temporary_vector.end());
|
||||
}
|
||||
};
|
||||
|
||||
|
||||
|
||||
|
||||
} // namespace traits
|
||||
|
||||
}} // namespace boost::geometry
|
||||
|
||||
|
||||
// Adapt Boost.Polygon's polygon_data to Boost.Range
|
||||
// This just translates to
|
||||
// polygon_data.begin() and polygon_data.end()
|
||||
namespace boost
|
||||
{
|
||||
template<typename CoordinateType>
|
||||
struct range_mutable_iterator<boost::polygon::polygon_data<CoordinateType> >
|
||||
{
|
||||
typedef typename boost::polygon::polygon_traits
|
||||
<
|
||||
boost::polygon::polygon_data<CoordinateType>
|
||||
>::iterator_type type;
|
||||
};
|
||||
|
||||
template<typename CoordinateType>
|
||||
struct range_const_iterator<boost::polygon::polygon_data<CoordinateType> >
|
||||
{
|
||||
typedef typename boost::polygon::polygon_traits
|
||||
<
|
||||
boost::polygon::polygon_data<CoordinateType>
|
||||
>::iterator_type type;
|
||||
};
|
||||
|
||||
template<typename CoordinateType>
|
||||
struct range_size<boost::polygon::polygon_data<CoordinateType> >
|
||||
{
|
||||
typedef std::size_t type;
|
||||
};
|
||||
|
||||
} // namespace boost
|
||||
|
||||
|
||||
// Support Boost.Polygon's polygon_data for Boost.Range ADP
|
||||
namespace boost { namespace polygon
|
||||
{
|
||||
|
||||
template<typename CoordinateType>
|
||||
inline typename polygon_traits
|
||||
<
|
||||
polygon_data<CoordinateType>
|
||||
>::iterator_type range_begin(polygon_data<CoordinateType>& polygon)
|
||||
{
|
||||
return polygon.begin();
|
||||
}
|
||||
|
||||
template<typename CoordinateType>
|
||||
inline typename polygon_traits
|
||||
<
|
||||
polygon_data<CoordinateType>
|
||||
>::iterator_type range_begin(polygon_data<CoordinateType> const& polygon)
|
||||
{
|
||||
return polygon.begin();
|
||||
}
|
||||
|
||||
template<typename CoordinateType>
|
||||
inline typename polygon_traits
|
||||
<
|
||||
polygon_data<CoordinateType>
|
||||
>::iterator_type range_end(polygon_data<CoordinateType>& polygon)
|
||||
{
|
||||
return polygon.end();
|
||||
}
|
||||
|
||||
template<typename CoordinateType>
|
||||
inline typename polygon_traits
|
||||
<
|
||||
polygon_data<CoordinateType>
|
||||
>::iterator_type range_end(polygon_data<CoordinateType> const& polygon)
|
||||
{
|
||||
return polygon.end();
|
||||
}
|
||||
|
||||
template<typename CoordinateType>
|
||||
inline std::size_t range_calculate_size(polygon_data<CoordinateType> const& polygon)
|
||||
{
|
||||
return polygon.size();
|
||||
}
|
||||
|
||||
}}
|
||||
|
||||
#endif // DOXYGEN_NO_TRAITS_SPECIALIZATIONS
|
||||
|
||||
|
||||
#endif // BOOST_GEOMETRY_GEOMETRIES_ADAPTED_BOOST_POLYGON_RING_HPP
|
||||
301
test/external/boost/geometry/geometries/adapted/boost_polygon/ring_proxy.hpp
vendored
Normal file
301
test/external/boost/geometry/geometries/adapted/boost_polygon/ring_proxy.hpp
vendored
Normal file
@@ -0,0 +1,301 @@
|
||||
// Boost.Geometry (aka GGL, Generic Geometry Library)
|
||||
|
||||
// Copyright (c) 2010-2011 Barend Gehrels, Amsterdam, the Netherlands.
|
||||
|
||||
// Use, modification and distribution is subject to the Boost Software License,
|
||||
// Version 1.0. (See accompanying file LICENSE_1_0.txt or copy at
|
||||
// http://www.boost.org/LICENSE_1_0.txt)
|
||||
|
||||
#ifndef BOOST_GEOMETRY_GEOMETRIES_ADAPTED_BOOST_POLYGON_RING_PROXY_HPP
|
||||
#define BOOST_GEOMETRY_GEOMETRIES_ADAPTED_BOOST_POLYGON_RING_PROXY_HPP
|
||||
|
||||
// Adapts Geometries from Boost.Polygon for usage in Boost.Geometry
|
||||
// boost::polygon::polygon_with_holes_data -> boost::geometry::polygon
|
||||
// pair{begin_points, end_points} -> ring_proxy
|
||||
|
||||
#include <boost/polygon/polygon.hpp>
|
||||
#include <boost/range.hpp>
|
||||
|
||||
|
||||
|
||||
namespace boost { namespace geometry
|
||||
{
|
||||
|
||||
namespace adapt { namespace bp
|
||||
{
|
||||
|
||||
namespace detail
|
||||
{
|
||||
|
||||
template <bool Mutable>
|
||||
struct modify
|
||||
{};
|
||||
|
||||
template <>
|
||||
struct modify<true>
|
||||
{
|
||||
template <typename Ring, typename Point>
|
||||
static inline void push_back(Ring& ring, Point const& point)
|
||||
{
|
||||
// Boost.Polygon's polygons are not appendable. So create a temporary vector,
|
||||
// add a record and set it to the original. Of course: this is not efficient.
|
||||
// But there seems no other way (without using a wrapper)
|
||||
std::vector<Point> temporary_vector
|
||||
(
|
||||
boost::polygon::begin_points(ring),
|
||||
boost::polygon::end_points(ring)
|
||||
);
|
||||
temporary_vector.push_back(point);
|
||||
boost::polygon::set_points(ring, temporary_vector.begin(), temporary_vector.end());
|
||||
}
|
||||
|
||||
};
|
||||
|
||||
template <>
|
||||
struct modify<false>
|
||||
{
|
||||
template <typename Ring, typename Point>
|
||||
static inline void push_back(Ring& ring, Point const& point)
|
||||
{
|
||||
}
|
||||
|
||||
};
|
||||
|
||||
|
||||
}
|
||||
|
||||
|
||||
// Polygon should implement the boost::polygon::polygon_with_holes_concept
|
||||
// Specify constness in the template parameter if necessary
|
||||
template<typename Polygon>
|
||||
class ring_proxy
|
||||
{
|
||||
public :
|
||||
typedef typename boost::polygon::polygon_traits
|
||||
<
|
||||
typename boost::remove_const<Polygon>::type
|
||||
>::iterator_type iterator_type;
|
||||
|
||||
typedef typename boost::polygon::polygon_with_holes_traits
|
||||
<
|
||||
typename boost::remove_const<Polygon>::type
|
||||
>::iterator_holes_type hole_iterator_type;
|
||||
|
||||
static const bool is_mutable = !boost::is_const<Polygon>::type::value;
|
||||
|
||||
inline ring_proxy(Polygon& p)
|
||||
: m_polygon_pointer(&p)
|
||||
, m_do_hole(false)
|
||||
{}
|
||||
|
||||
// Constructor used from hole_iterator
|
||||
inline ring_proxy(Polygon& p, hole_iterator_type hole_it)
|
||||
: m_polygon_pointer(&p)
|
||||
, m_do_hole(true)
|
||||
, m_hole_it(hole_it)
|
||||
{}
|
||||
|
||||
// Default constructor, for mutable polygons / appending (interior) rings
|
||||
inline ring_proxy()
|
||||
: m_polygon_pointer(&m_polygon_for_default_constructor)
|
||||
, m_do_hole(false)
|
||||
{}
|
||||
|
||||
|
||||
iterator_type begin() const
|
||||
{
|
||||
return m_do_hole
|
||||
? boost::polygon::begin_points(*m_hole_it)
|
||||
: boost::polygon::begin_points(*m_polygon_pointer)
|
||||
;
|
||||
}
|
||||
|
||||
iterator_type begin()
|
||||
{
|
||||
return m_do_hole
|
||||
? boost::polygon::begin_points(*m_hole_it)
|
||||
: boost::polygon::begin_points(*m_polygon_pointer)
|
||||
;
|
||||
}
|
||||
|
||||
iterator_type end() const
|
||||
{
|
||||
return m_do_hole
|
||||
? boost::polygon::end_points(*m_hole_it)
|
||||
: boost::polygon::end_points(*m_polygon_pointer)
|
||||
;
|
||||
}
|
||||
|
||||
iterator_type end()
|
||||
{
|
||||
return m_do_hole
|
||||
? boost::polygon::end_points(*m_hole_it)
|
||||
: boost::polygon::end_points(*m_polygon_pointer)
|
||||
;
|
||||
}
|
||||
|
||||
// Mutable
|
||||
void clear()
|
||||
{
|
||||
Polygon p;
|
||||
if (m_do_hole)
|
||||
{
|
||||
// Does NOT work see comment above
|
||||
}
|
||||
else
|
||||
{
|
||||
boost::polygon::set_points(*m_polygon_pointer,
|
||||
boost::polygon::begin_points(p),
|
||||
boost::polygon::end_points(p));
|
||||
}
|
||||
}
|
||||
|
||||
void resize(std::size_t new_size)
|
||||
{
|
||||
if (m_do_hole)
|
||||
{
|
||||
// Does NOT work see comment above
|
||||
}
|
||||
else
|
||||
{
|
||||
// TODO: implement this by resizing the container
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
|
||||
template <typename Point>
|
||||
void push_back(Point const& point)
|
||||
{
|
||||
if (m_do_hole)
|
||||
{
|
||||
//detail::modify<is_mutable>::push_back(*m_hole_it, point);
|
||||
//std::cout << "HOLE: " << typeid(*m_hole_it).name() << std::endl;
|
||||
//std::cout << "HOLE: " << typeid(m_hole_it).name() << std::endl;
|
||||
//std::cout << "HOLE: " << typeid(hole_iterator_type).name() << std::endl;
|
||||
|
||||
// Note, ths does NOT work because hole_iterator_type is defined
|
||||
// as a const_iterator by Boost.Polygon
|
||||
|
||||
}
|
||||
else
|
||||
{
|
||||
detail::modify<is_mutable>::push_back(*m_polygon_pointer, point);
|
||||
}
|
||||
}
|
||||
|
||||
private :
|
||||
Polygon* m_polygon_pointer;
|
||||
bool m_do_hole;
|
||||
hole_iterator_type m_hole_it;
|
||||
|
||||
Polygon m_polygon_for_default_constructor;
|
||||
};
|
||||
|
||||
|
||||
|
||||
|
||||
// Support geometry::adapt::bp::ring_proxy for Boost.Range ADP
|
||||
template<typename Polygon>
|
||||
inline typename boost::geometry::adapt::bp::ring_proxy<Polygon>::iterator_type
|
||||
range_begin(boost::geometry::adapt::bp::ring_proxy<Polygon>& proxy)
|
||||
{
|
||||
return proxy.begin();
|
||||
}
|
||||
|
||||
template<typename Polygon>
|
||||
inline typename boost::geometry::adapt::bp::ring_proxy<Polygon const>::iterator_type
|
||||
range_begin(boost::geometry::adapt::bp::ring_proxy<Polygon const> const& proxy)
|
||||
{
|
||||
return proxy.begin();
|
||||
}
|
||||
|
||||
template<typename Polygon>
|
||||
inline typename boost::geometry::adapt::bp::ring_proxy<Polygon>::iterator_type
|
||||
range_end(boost::geometry::adapt::bp::ring_proxy<Polygon>& proxy)
|
||||
{
|
||||
return proxy.end();
|
||||
}
|
||||
|
||||
template<typename Polygon>
|
||||
inline typename boost::geometry::adapt::bp::ring_proxy<Polygon const>::iterator_type
|
||||
range_end(boost::geometry::adapt::bp::ring_proxy<Polygon const> const& proxy)
|
||||
{
|
||||
return proxy.end();
|
||||
}
|
||||
|
||||
|
||||
|
||||
|
||||
}} // namespace adapt::bp
|
||||
|
||||
|
||||
namespace traits
|
||||
{
|
||||
|
||||
template <typename Polygon>
|
||||
struct tag<adapt::bp::ring_proxy<Polygon> >
|
||||
{
|
||||
typedef ring_tag type;
|
||||
};
|
||||
|
||||
|
||||
template <typename Polygon>
|
||||
struct rvalue_type<adapt::bp::ring_proxy<Polygon> >
|
||||
{
|
||||
typedef adapt::bp::ring_proxy<Polygon> type;
|
||||
};
|
||||
|
||||
template <typename Polygon>
|
||||
struct clear<adapt::bp::ring_proxy<Polygon> >
|
||||
{
|
||||
static inline void apply(adapt::bp::ring_proxy<Polygon> proxy)
|
||||
{
|
||||
proxy.clear();
|
||||
}
|
||||
};
|
||||
|
||||
|
||||
template <typename Polygon>
|
||||
struct resize<adapt::bp::ring_proxy<Polygon> >
|
||||
{
|
||||
static inline void apply(adapt::bp::ring_proxy<Polygon> proxy, std::size_t new_size)
|
||||
{
|
||||
proxy.resize(new_size);
|
||||
}
|
||||
};
|
||||
|
||||
template <typename Polygon>
|
||||
struct push_back<adapt::bp::ring_proxy<Polygon> >
|
||||
{
|
||||
static inline void apply(adapt::bp::ring_proxy<Polygon> proxy,
|
||||
typename boost::polygon::polygon_traits<Polygon>::point_type const& point)
|
||||
{
|
||||
proxy.push_back(point);
|
||||
}
|
||||
};
|
||||
|
||||
|
||||
} // namespace traits
|
||||
|
||||
}} // namespace boost::geometry
|
||||
|
||||
// Specialize ring_proxy for Boost.Range
|
||||
namespace boost
|
||||
{
|
||||
template<typename Polygon>
|
||||
struct range_mutable_iterator<geometry::adapt::bp::ring_proxy<Polygon> >
|
||||
{
|
||||
typedef typename geometry::adapt::bp::ring_proxy<Polygon>::iterator_type type;
|
||||
};
|
||||
|
||||
template<typename Polygon>
|
||||
struct range_const_iterator<geometry::adapt::bp::ring_proxy<Polygon> >
|
||||
{
|
||||
typedef typename geometry::adapt::bp::ring_proxy<Polygon const>::iterator_type type;
|
||||
};
|
||||
|
||||
} // namespace boost
|
||||
|
||||
|
||||
#endif // BOOST_GEOMETRY_GEOMETRIES_ADAPTED_BOOST_POLYGON_RING_PROXY_HPP
|
||||
40
test/external/boost/geometry/geometries/adapted/boost_range/adjacent_filtered.hpp
vendored
Normal file
40
test/external/boost/geometry/geometries/adapted/boost_range/adjacent_filtered.hpp
vendored
Normal file
@@ -0,0 +1,40 @@
|
||||
// Boost.Geometry (aka GGL, Generic Geometry Library)
|
||||
|
||||
// Copyright (c) 2010-2011 Barend Gehrels, Amsterdam, the Netherlands.
|
||||
|
||||
// Use, modification and distribution is subject to the Boost Software License,
|
||||
// Version 1.0. (See accompanying file LICENSE_1_0.txt or copy at
|
||||
// http://www.boost.org/LICENSE_1_0.txt)
|
||||
|
||||
#ifndef BOOST_GEOMETRY_GEOMETRIES_ADAPTED_BOOST_RANGE_ADJACENT_FILTERED_HPP
|
||||
#define BOOST_GEOMETRY_GEOMETRIES_ADAPTED_BOOST_RANGE_ADJACENT_FILTERED_HPP
|
||||
|
||||
|
||||
#include <boost/range/adaptor/adjacent_filtered.hpp>
|
||||
|
||||
#include <boost/geometry/core/tag.hpp>
|
||||
#include <boost/geometry/core/tags.hpp>
|
||||
|
||||
|
||||
namespace boost { namespace geometry
|
||||
{
|
||||
|
||||
namespace traits
|
||||
{
|
||||
|
||||
template<typename Filter, typename Geometry, bool DefaultPass>
|
||||
#if BOOST_VERSION > 104500
|
||||
struct tag<boost::adjacent_filtered_range<Filter, Geometry, DefaultPass> >
|
||||
#else
|
||||
struct tag<boost::range_detail::adjacent_filter_range<Filter, Geometry, DefaultPass> >
|
||||
#endif
|
||||
{
|
||||
typedef typename geometry::tag<Geometry>::type type;
|
||||
};
|
||||
|
||||
}
|
||||
|
||||
}} // namespace boost::geometry
|
||||
|
||||
#endif // BOOST_GEOMETRY_GEOMETRIES_ADAPTED_BOOST_RANGE_ADJACENT_FILTERED_HPP
|
||||
|
||||
40
test/external/boost/geometry/geometries/adapted/boost_range/filtered.hpp
vendored
Normal file
40
test/external/boost/geometry/geometries/adapted/boost_range/filtered.hpp
vendored
Normal file
@@ -0,0 +1,40 @@
|
||||
// Boost.Geometry (aka GGL, Generic Geometry Library)
|
||||
|
||||
// Copyright (c) 2010-2011 Barend Gehrels, Amsterdam, the Netherlands.
|
||||
|
||||
// Use, modification and distribution is subject to the Boost Software License,
|
||||
// Version 1.0. (See accompanying file LICENSE_1_0.txt or copy at
|
||||
// http://www.boost.org/LICENSE_1_0.txt)
|
||||
|
||||
#ifndef BOOST_GEOMETRY_GEOMETRIES_ADAPTED_BOOST_RANGE_FILTERED_HPP
|
||||
#define BOOST_GEOMETRY_GEOMETRIES_ADAPTED_BOOST_RANGE_FILTERED_HPP
|
||||
|
||||
|
||||
#include <boost/range/adaptor/filtered.hpp>
|
||||
|
||||
#include <boost/geometry/core/tag.hpp>
|
||||
#include <boost/geometry/core/tags.hpp>
|
||||
|
||||
|
||||
namespace boost { namespace geometry
|
||||
{
|
||||
|
||||
namespace traits
|
||||
{
|
||||
|
||||
template<typename Filter, typename Geometry>
|
||||
#if BOOST_VERSION > 104500
|
||||
struct tag<boost::filtered_range<Filter, Geometry> >
|
||||
#else
|
||||
struct tag<boost::range_detail::filter_range<Filter, Geometry> >
|
||||
#endif
|
||||
{
|
||||
typedef typename geometry::tag<Geometry>::type type;
|
||||
};
|
||||
|
||||
}
|
||||
|
||||
}} // namespace boost::geometry
|
||||
|
||||
#endif // BOOST_GEOMETRY_GEOMETRIES_ADAPTED_BOOST_RANGE_FILTERED_HPP
|
||||
|
||||
40
test/external/boost/geometry/geometries/adapted/boost_range/reversed.hpp
vendored
Normal file
40
test/external/boost/geometry/geometries/adapted/boost_range/reversed.hpp
vendored
Normal file
@@ -0,0 +1,40 @@
|
||||
// Boost.Geometry (aka GGL, Generic Geometry Library)
|
||||
|
||||
// Copyright (c) 2010-2011 Barend Gehrels, Amsterdam, the Netherlands.
|
||||
|
||||
// Use, modification and distribution is subject to the Boost Software License,
|
||||
// Version 1.0. (See accompanying file LICENSE_1_0.txt or copy at
|
||||
// http://www.boost.org/LICENSE_1_0.txt)
|
||||
|
||||
#ifndef BOOST_GEOMETRY_GEOMETRIES_ADAPTED_BOOST_RANGE_REVERSED_HPP
|
||||
#define BOOST_GEOMETRY_GEOMETRIES_ADAPTED_BOOST_RANGE_REVERSED_HPP
|
||||
|
||||
|
||||
#include <boost/range/adaptor/reversed.hpp>
|
||||
|
||||
#include <boost/geometry/core/tag.hpp>
|
||||
#include <boost/geometry/core/tags.hpp>
|
||||
|
||||
|
||||
namespace boost { namespace geometry
|
||||
{
|
||||
|
||||
namespace traits
|
||||
{
|
||||
|
||||
template<typename Geometry>
|
||||
#if BOOST_VERSION > 104500
|
||||
struct tag<boost::reversed_range<Geometry> >
|
||||
#else
|
||||
struct tag<boost::range_detail::reverse_range<Geometry> >
|
||||
#endif
|
||||
{
|
||||
typedef typename geometry::tag<Geometry>::type type;
|
||||
};
|
||||
|
||||
}
|
||||
|
||||
}} // namespace boost::geometry
|
||||
|
||||
#endif // BOOST_GEOMETRY_GEOMETRIES_ADAPTED_BOOST_RANGE_REVERSED_HPP
|
||||
|
||||
36
test/external/boost/geometry/geometries/adapted/boost_range/sliced.hpp
vendored
Normal file
36
test/external/boost/geometry/geometries/adapted/boost_range/sliced.hpp
vendored
Normal file
@@ -0,0 +1,36 @@
|
||||
// Boost.Geometry (aka GGL, Generic Geometry Library)
|
||||
|
||||
// Copyright (c) 2010-2011 Barend Gehrels, Amsterdam, the Netherlands.
|
||||
|
||||
// Use, modification and distribution is subject to the Boost Software License,
|
||||
// Version 1.0. (See accompanying file LICENSE_1_0.txt or copy at
|
||||
// http://www.boost.org/LICENSE_1_0.txt)
|
||||
|
||||
#ifndef BOOST_GEOMETRY_GEOMETRIES_ADAPTED_BOOST_RANGE_SLICED_HPP
|
||||
#define BOOST_GEOMETRY_GEOMETRIES_ADAPTED_BOOST_RANGE_SLICED_HPP
|
||||
|
||||
|
||||
#include <boost/range/adaptor/sliced.hpp>
|
||||
|
||||
#include <boost/geometry/core/tag.hpp>
|
||||
#include <boost/geometry/core/tags.hpp>
|
||||
|
||||
|
||||
namespace boost { namespace geometry
|
||||
{
|
||||
|
||||
namespace traits
|
||||
{
|
||||
|
||||
template<typename Geometry>
|
||||
struct tag<boost::adaptors::sliced_range<Geometry> >
|
||||
{
|
||||
typedef typename geometry::tag<Geometry>::type type;
|
||||
};
|
||||
|
||||
}
|
||||
|
||||
}} // namespace boost::geometry
|
||||
|
||||
#endif // BOOST_GEOMETRY_GEOMETRIES_ADAPTED_BOOST_RANGE_SLICED_HPP
|
||||
|
||||
36
test/external/boost/geometry/geometries/adapted/boost_range/strided.hpp
vendored
Normal file
36
test/external/boost/geometry/geometries/adapted/boost_range/strided.hpp
vendored
Normal file
@@ -0,0 +1,36 @@
|
||||
// Boost.Geometry (aka GGL, Generic Geometry Library)
|
||||
|
||||
// Copyright (c) 2010-2011 Barend Gehrels, Amsterdam, the Netherlands.
|
||||
|
||||
// Use, modification and distribution is subject to the Boost Software License,
|
||||
// Version 1.0. (See accompanying file LICENSE_1_0.txt or copy at
|
||||
// http://www.boost.org/LICENSE_1_0.txt)
|
||||
|
||||
#ifndef BOOST_GEOMETRY_GEOMETRIES_ADAPTED_BOOST_RANGE_STRIDED_HPP
|
||||
#define BOOST_GEOMETRY_GEOMETRIES_ADAPTED_BOOST_RANGE_STRIDED_HPP
|
||||
|
||||
|
||||
#include <boost/range/adaptor/strided.hpp>
|
||||
|
||||
#include <boost/geometry/core/tag.hpp>
|
||||
#include <boost/geometry/core/tags.hpp>
|
||||
|
||||
|
||||
namespace boost { namespace geometry
|
||||
{
|
||||
|
||||
namespace traits
|
||||
{
|
||||
|
||||
template<typename Geometry>
|
||||
struct tag<boost::strided_range<Geometry> >
|
||||
{
|
||||
typedef typename geometry::tag<Geometry>::type type;
|
||||
};
|
||||
|
||||
}
|
||||
|
||||
}} // namespace boost::geometry
|
||||
|
||||
#endif // BOOST_GEOMETRY_GEOMETRIES_ADAPTED_BOOST_RANGE_STRIDED_HPP
|
||||
|
||||
40
test/external/boost/geometry/geometries/adapted/boost_range/uniqued.hpp
vendored
Normal file
40
test/external/boost/geometry/geometries/adapted/boost_range/uniqued.hpp
vendored
Normal file
@@ -0,0 +1,40 @@
|
||||
// Boost.Geometry (aka GGL, Generic Geometry Library)
|
||||
|
||||
// Copyright (c) 2010-2011 Barend Gehrels, Amsterdam, the Netherlands.
|
||||
|
||||
// Use, modification and distribution is subject to the Boost Software License,
|
||||
// Version 1.0. (See accompanying file LICENSE_1_0.txt or copy at
|
||||
// http://www.boost.org/LICENSE_1_0.txt)
|
||||
|
||||
#ifndef BOOST_GEOMETRY_GEOMETRIES_ADAPTED_BOOST_RANGE_UNIQUED_HPP
|
||||
#define BOOST_GEOMETRY_GEOMETRIES_ADAPTED_BOOST_RANGE_UNIQUED_HPP
|
||||
|
||||
|
||||
#include <boost/range/adaptor/uniqued.hpp>
|
||||
|
||||
#include <boost/geometry/core/tag.hpp>
|
||||
#include <boost/geometry/core/tags.hpp>
|
||||
|
||||
|
||||
namespace boost { namespace geometry
|
||||
{
|
||||
|
||||
namespace traits
|
||||
{
|
||||
|
||||
template<typename Geometry>
|
||||
#if BOOST_VERSION > 104500
|
||||
struct tag<boost::uniqued_range<Geometry> >
|
||||
#else
|
||||
struct tag<boost::range_detail::unique_range<Geometry> >
|
||||
#endif
|
||||
{
|
||||
typedef typename geometry::tag<Geometry>::type type;
|
||||
};
|
||||
|
||||
}
|
||||
|
||||
}} // namespace boost::geometry
|
||||
|
||||
#endif // BOOST_GEOMETRY_GEOMETRIES_ADAPTED_BOOST_RANGE_UNIQUED_HPP
|
||||
|
||||
109
test/external/boost/geometry/geometries/adapted/boost_tuple.hpp
vendored
Normal file
109
test/external/boost/geometry/geometries/adapted/boost_tuple.hpp
vendored
Normal file
@@ -0,0 +1,109 @@
|
||||
// Boost.Geometry (aka GGL, Generic Geometry Library)
|
||||
|
||||
// Copyright (c) 2008-2011 Bruno Lalande, Paris, France.
|
||||
// Copyright (c) 2008-2011 Barend Gehrels, Amsterdam, the Netherlands.
|
||||
// Copyright (c) 2009-2011 Mateusz Loskot, London, UK.
|
||||
|
||||
// Parts of Boost.Geometry are redesigned from Geodan's Geographic Library
|
||||
// (geolib/GGL), copyright (c) 1995-2010 Geodan, Amsterdam, the Netherlands.
|
||||
|
||||
// Use, modification and distribution is subject to the Boost Software License,
|
||||
// Version 1.0. (See accompanying file LICENSE_1_0.txt or copy at
|
||||
// http://www.boost.org/LICENSE_1_0.txt)
|
||||
|
||||
#ifndef BOOST_GEOMETRY_GEOMETRIES_ADAPTED_BOOST_TUPLE_HPP
|
||||
#define BOOST_GEOMETRY_GEOMETRIES_ADAPTED_BOOST_TUPLE_HPP
|
||||
|
||||
|
||||
#include <cstddef>
|
||||
|
||||
#include <boost/tuple/tuple.hpp>
|
||||
|
||||
#include <boost/geometry/core/coordinate_dimension.hpp>
|
||||
#include <boost/geometry/core/coordinate_type.hpp>
|
||||
#include <boost/geometry/core/point_type.hpp>
|
||||
#include <boost/geometry/core/tags.hpp>
|
||||
|
||||
|
||||
namespace boost { namespace geometry
|
||||
{
|
||||
|
||||
|
||||
#ifndef DOXYGEN_NO_TRAITS_SPECIALIZATIONS
|
||||
namespace traits
|
||||
{
|
||||
|
||||
|
||||
template <typename T1, typename T2, typename T3, typename T4, typename T5,
|
||||
typename T6, typename T7, typename T8, typename T9, typename T10>
|
||||
struct tag<boost::tuple<T1, T2, T3, T4, T5, T6, T7, T8, T9, T10> >
|
||||
{
|
||||
typedef point_tag type;
|
||||
};
|
||||
|
||||
|
||||
template <typename T1, typename T2, typename T3, typename T4, typename T5,
|
||||
typename T6, typename T7, typename T8, typename T9, typename T10>
|
||||
struct coordinate_type<boost::tuple<T1, T2, T3, T4, T5, T6, T7, T8, T9, T10> >
|
||||
{
|
||||
typedef T1 type;
|
||||
};
|
||||
|
||||
|
||||
template <typename T1, typename T2, typename T3, typename T4, typename T5,
|
||||
typename T6, typename T7, typename T8, typename T9, typename T10>
|
||||
struct dimension<boost::tuple<T1, T2, T3, T4, T5, T6, T7, T8, T9, T10> >
|
||||
: boost::mpl::int_
|
||||
<
|
||||
boost::tuples::length
|
||||
<
|
||||
boost::tuple<T1, T2, T3, T4, T5, T6, T7, T8, T9, T10>
|
||||
>::value
|
||||
>
|
||||
{};
|
||||
|
||||
|
||||
template <typename T1, typename T2, typename T3, typename T4, typename T5,
|
||||
typename T6, typename T7, typename T8, typename T9, typename T10,
|
||||
std::size_t Dimension>
|
||||
struct access
|
||||
<
|
||||
boost::tuple<T1, T2, T3, T4, T5, T6, T7, T8, T9, T10>,
|
||||
Dimension
|
||||
>
|
||||
{
|
||||
static inline T1 get(
|
||||
boost::tuple<T1, T2, T3, T4, T5, T6, T7, T8, T9, T10> const& point)
|
||||
{
|
||||
return point.template get<Dimension>();
|
||||
}
|
||||
|
||||
static inline void set(
|
||||
boost::tuple<T1, T2, T3, T4, T5, T6, T7, T8, T9, T10>& point,
|
||||
T1 const& value)
|
||||
{
|
||||
point.template get<Dimension>() = value;
|
||||
}
|
||||
};
|
||||
|
||||
|
||||
} // namespace traits
|
||||
#endif // DOXYGEN_NO_TRAITS_SPECIALIZATIONS
|
||||
|
||||
|
||||
}} // namespace boost::geometry
|
||||
|
||||
|
||||
// Convenience registration macro to bind boost::tuple to a CS
|
||||
#define BOOST_GEOMETRY_REGISTER_BOOST_TUPLE_CS(CoordinateSystem) \
|
||||
namespace boost { namespace geometry { namespace traits { \
|
||||
template <typename T1, typename T2, typename T3, typename T4, typename T5, \
|
||||
typename T6, typename T7, typename T8, typename T9, typename T10> \
|
||||
struct coordinate_system<boost::tuple<T1, T2, T3, T4, T5, T6, T7, T8, T9, T10> > \
|
||||
{ \
|
||||
typedef CoordinateSystem type; \
|
||||
}; \
|
||||
}}}
|
||||
|
||||
|
||||
#endif // BOOST_GEOMETRY_GEOMETRIES_ADAPTED_TUPLE_HPP
|
||||
111
test/external/boost/geometry/geometries/adapted/c_array.hpp
vendored
Normal file
111
test/external/boost/geometry/geometries/adapted/c_array.hpp
vendored
Normal file
@@ -0,0 +1,111 @@
|
||||
// Boost.Geometry (aka GGL, Generic Geometry Library)
|
||||
|
||||
// Copyright (c) 2008-2011 Bruno Lalande, Paris, France.
|
||||
// Copyright (c) 2007-2011 Barend Gehrels, Amsterdam, the Netherlands.
|
||||
// Copyright (c) 2009-2011 Mateusz Loskot, London, UK.
|
||||
|
||||
// Parts of Boost.Geometry are redesigned from Geodan's Geographic Library
|
||||
// (geolib/GGL), copyright (c) 1995-2010 Geodan, Amsterdam, the Netherlands.
|
||||
|
||||
// Use, modification and distribution is subject to the Boost Software License,
|
||||
// Version 1.0. (See accompanying file LICENSE_1_0.txt or copy at
|
||||
// http://www.boost.org/LICENSE_1_0.txt)
|
||||
|
||||
#ifndef BOOST_GEOMETRY_GEOMETRIES_ADAPTED_C_ARRAY_HPP
|
||||
#define BOOST_GEOMETRY_GEOMETRIES_ADAPTED_C_ARRAY_HPP
|
||||
|
||||
#include <cstddef>
|
||||
|
||||
#include <boost/type_traits/is_arithmetic.hpp>
|
||||
|
||||
#include <boost/geometry/core/access.hpp>
|
||||
#include <boost/geometry/core/cs.hpp>
|
||||
#include <boost/geometry/core/coordinate_dimension.hpp>
|
||||
#include <boost/geometry/core/coordinate_type.hpp>
|
||||
#include <boost/geometry/core/tags.hpp>
|
||||
|
||||
namespace boost { namespace geometry
|
||||
{
|
||||
|
||||
|
||||
#ifndef DOXYGEN_NO_TRAITS_SPECIALIZATIONS
|
||||
namespace traits
|
||||
{
|
||||
|
||||
|
||||
#ifndef DOXYGEN_NO_DETAIL
|
||||
namespace detail
|
||||
{
|
||||
|
||||
|
||||
// Create class and specialization to indicate the tag
|
||||
// for normal cases and the case that the type of the c-array is arithmetic
|
||||
template <bool>
|
||||
struct c_array_tag
|
||||
{
|
||||
typedef geometry_not_recognized_tag type;
|
||||
};
|
||||
|
||||
|
||||
template <>
|
||||
struct c_array_tag<true>
|
||||
{
|
||||
typedef point_tag type;
|
||||
};
|
||||
|
||||
|
||||
} // namespace detail
|
||||
#endif // DOXYGEN_NO_DETAIL
|
||||
|
||||
|
||||
// Assign the point-tag, preventing arrays of points getting a point-tag
|
||||
template <typename CoordinateType, std::size_t DimensionCount>
|
||||
struct tag<CoordinateType[DimensionCount]>
|
||||
: detail::c_array_tag<boost::is_arithmetic<CoordinateType>::value> {};
|
||||
|
||||
|
||||
template <typename CoordinateType, std::size_t DimensionCount>
|
||||
struct coordinate_type<CoordinateType[DimensionCount]>
|
||||
{
|
||||
typedef CoordinateType type;
|
||||
};
|
||||
|
||||
|
||||
template <typename CoordinateType, std::size_t DimensionCount>
|
||||
struct dimension<CoordinateType[DimensionCount]>: boost::mpl::int_<DimensionCount> {};
|
||||
|
||||
|
||||
template <typename CoordinateType, std::size_t DimensionCount, std::size_t Dimension>
|
||||
struct access<CoordinateType[DimensionCount], Dimension>
|
||||
{
|
||||
static inline CoordinateType get(CoordinateType const p[DimensionCount])
|
||||
{
|
||||
return p[Dimension];
|
||||
}
|
||||
|
||||
static inline void set(CoordinateType p[DimensionCount],
|
||||
CoordinateType const& value)
|
||||
{
|
||||
p[Dimension] = value;
|
||||
}
|
||||
};
|
||||
|
||||
|
||||
} // namespace traits
|
||||
#endif // DOXYGEN_NO_TRAITS_SPECIALIZATIONS
|
||||
|
||||
|
||||
}} // namespace boost::geometry
|
||||
|
||||
|
||||
#define BOOST_GEOMETRY_REGISTER_C_ARRAY_CS(CoordinateSystem) \
|
||||
namespace boost { namespace geometry { namespace traits { \
|
||||
template <typename T, std::size_t N> \
|
||||
struct coordinate_system<T[N]> \
|
||||
{ \
|
||||
typedef CoordinateSystem type; \
|
||||
}; \
|
||||
}}}
|
||||
|
||||
|
||||
#endif // BOOST_GEOMETRY_GEOMETRIES_ADAPTED_C_ARRAY_HPP
|
||||
98
test/external/boost/geometry/geometries/adapted/std_pair_as_segment.hpp
vendored
Normal file
98
test/external/boost/geometry/geometries/adapted/std_pair_as_segment.hpp
vendored
Normal file
@@ -0,0 +1,98 @@
|
||||
// Boost.Geometry (aka GGL, Generic Geometry Library)
|
||||
|
||||
// Copyright (c) 2008-2011 Bruno Lalande, Paris, France.
|
||||
// Copyright (c) 2008-2011 Barend Gehrels, Amsterdam, the Netherlands.
|
||||
// Copyright (c) 2009-2011 Mateusz Loskot, London, UK.
|
||||
|
||||
// Parts of Boost.Geometry are redesigned from Geodan's Geographic Library
|
||||
// (geolib/GGL), copyright (c) 1995-2010 Geodan, Amsterdam, the Netherlands.
|
||||
|
||||
// Use, modification and distribution is subject to the Boost Software License,
|
||||
// Version 1.0. (See accompanying file LICENSE_1_0.txt or copy at
|
||||
// http://www.boost.org/LICENSE_1_0.txt)
|
||||
|
||||
#ifndef BOOST_GEOMETRY_GEOMETRIES_ADAPTED_STD_PAIR_AS_SEGMENT_HPP
|
||||
#define BOOST_GEOMETRY_GEOMETRIES_ADAPTED_STD_PAIR_AS_SEGMENT_HPP
|
||||
|
||||
// Only possible if the std::pair is not used for iterator/pair
|
||||
// (maybe it is possible to avoid that by detecting in the other file
|
||||
// if an iterator was used in the pair)
|
||||
|
||||
#ifdef BOOST_GEOMETRY_ADAPTED_STD_RANGE_TAG_DEFINED
|
||||
#error Include only one headerfile to register tag for adapted std:: containers or iterator pair
|
||||
#endif
|
||||
|
||||
#define BOOST_GEOMETRY_ADAPTED_STD_RANGE_TAG_DEFINED
|
||||
|
||||
|
||||
#include <cstddef>
|
||||
|
||||
|
||||
#include <boost/geometry/core/access.hpp>
|
||||
#include <boost/geometry/core/tag.hpp>
|
||||
#include <boost/geometry/core/tags.hpp>
|
||||
|
||||
|
||||
namespace boost { namespace geometry
|
||||
{
|
||||
|
||||
|
||||
#ifndef DOXYGEN_NO_TRAITS_SPECIALIZATIONS
|
||||
namespace traits
|
||||
{
|
||||
|
||||
|
||||
template <typename Point>
|
||||
struct tag<std::pair<Point, Point> >
|
||||
{
|
||||
typedef segment_tag type;
|
||||
};
|
||||
|
||||
template <typename Point>
|
||||
struct point_type<std::pair<Point, Point> >
|
||||
{
|
||||
typedef Point type;
|
||||
};
|
||||
|
||||
template <typename Point, std::size_t Dimension>
|
||||
struct indexed_access<std::pair<Point, Point>, 0, Dimension>
|
||||
{
|
||||
typedef typename geometry::coordinate_type<Point>::type coordinate_type;
|
||||
|
||||
static inline coordinate_type get(std::pair<Point, Point> const& s)
|
||||
{
|
||||
return geometry::get<Dimension>(s.first);
|
||||
}
|
||||
|
||||
static inline void set(std::pair<Point, Point>& s, coordinate_type const& value)
|
||||
{
|
||||
geometry::set<Dimension>(s.first, value);
|
||||
}
|
||||
};
|
||||
|
||||
|
||||
template <typename Point, std::size_t Dimension>
|
||||
struct indexed_access<std::pair<Point, Point>, 1, Dimension>
|
||||
{
|
||||
typedef typename geometry::coordinate_type<Point>::type coordinate_type;
|
||||
|
||||
static inline coordinate_type get(std::pair<Point, Point> const& s)
|
||||
{
|
||||
return geometry::get<Dimension>(s.second);
|
||||
}
|
||||
|
||||
static inline void set(std::pair<Point, Point>& s, coordinate_type const& value)
|
||||
{
|
||||
geometry::set<Dimension>(s.second, value);
|
||||
}
|
||||
};
|
||||
|
||||
|
||||
} // namespace traits
|
||||
#endif // DOXYGEN_NO_TRAITS_SPECIALIZATIONS
|
||||
|
||||
|
||||
}} // namespace boost::geometry
|
||||
|
||||
|
||||
#endif // BOOST_GEOMETRY_GEOMETRIES_ADAPTED_STD_PAIR_AS_SEGMENT_HPP
|
||||
Reference in New Issue
Block a user