// Boost.Geometry (aka GGL, Generic Geometry Library) // // Copyright Alfredo Correa 2010 // Copyright Bruno Lalande 2008, 2009 // Copyright Barend Gehrels 2007-2009, 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_ARRAY_HPP #define BOOST_GEOMETRY_GEOMETRIES_ADAPTED_BOOST_ARRAY_HPP #include #include #include #include #include #include #include #include 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 struct boost_array_tag { typedef geometry_not_recognized_tag type; }; template <> struct boost_array_tag { typedef point_tag type; }; } // namespace detail #endif // DOXYGEN_NO_DETAIL // Assign the point-tag, preventing arrays of points getting a point-tag template struct tag > : detail::boost_array_tag::value> {}; template struct coordinate_type > { typedef CoordinateType type; }; template struct dimension >: boost::mpl::int_ {}; template struct access, Dimension> { static inline CoordinateType get(boost::array const& a) { return a[Dimension]; } static inline void set(boost::array& a, CoordinateType const& value) { a[Dimension] = value; } }; // The library user has // 1) either to specify the coordinate system // 2) or include where @=cartesian,geographic,... } // namespace traits #endif // DOXYGEN_NO_TRAITS_SPECIALIZATIONS }} // namespace boost::geometry #endif // BOOST_GEOMETRY_GEOMETRIES_ADAPTED_BOOST_ARRAY_HPP