/* Copyright 2008 Intel Corporation Use, modification and distribution are 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_POLYGON_POLYGON_90_SET_TRAITS_HPP #define BOOST_POLYGON_POLYGON_90_SET_TRAITS_HPP namespace boost { namespace polygon{ struct polygon_90_set_concept {}; template struct traits_by_concept {}; template struct traits_by_concept { typedef coordinate_traits type; }; template struct traits_by_concept { typedef interval_traits type; }; template struct traits_by_concept { typedef point_traits type; }; template struct traits_by_concept { typedef point_3d_traits type; }; template struct traits_by_concept { typedef rectangle_traits type; }; template struct traits_by_concept { typedef polygon_traits type; }; template struct traits_by_concept { typedef polygon_traits type; }; template struct traits_by_concept { typedef polygon_traits type; }; template struct traits_by_concept { typedef polygon_traits type; }; template struct traits_by_concept { typedef polygon_traits type; }; template struct traits_by_concept { typedef polygon_traits type; }; struct polygon_45_set_concept; struct polygon_set_concept; template struct polygon_90_set_traits; template struct polygon_45_set_traits; template struct polygon_set_traits; template struct traits_by_concept { typedef polygon_90_set_traits type; }; template struct traits_by_concept { typedef polygon_45_set_traits type; }; template struct traits_by_concept { typedef polygon_set_traits type; }; template struct get_coordinate_type { typedef typename traits_by_concept::type traits_type; typedef typename traits_type::coordinate_type type; }; //want to prevent recursive template definition syntax errors, so duplicate get_coordinate_type template struct get_coordinate_type_2 { typedef typename traits_by_concept::type traits_type; typedef typename traits_type::coordinate_type type; }; template struct get_coordinate_type { typedef typename get_coordinate_type_2::value_type, typename geometry_concept::value_type>::type>::type type; }; template struct get_iterator_type_2 { typedef const T* type; static type begin(const T& t) { return &t; } static type end(const T& t) { const T* tp = &t; ++tp; return tp; } }; template struct get_iterator_type { typedef get_iterator_type_2::type> indirect_type; typedef typename indirect_type::type type; static type begin(const T& t) { return indirect_type::begin(t); } static type end(const T& t) { return indirect_type::end(t); } }; template struct get_iterator_type_2 { typedef typename T::const_iterator type; static type begin(const T& t) { return t.begin(); } static type end(const T& t) { return t.end(); } }; // //helpers for allowing polygon 45 and containers of polygon 45 to behave interchangably in polygon_45_set_traits // template // struct get_coordinate_type_45 {}; // template // struct get_coordinate_type_2_45 {}; // template // struct get_coordinate_type_45 { // typedef typename get_coordinate_type_2_45< typename T::value_type, typename geometry_concept::type >::type type; }; // template // struct get_coordinate_type_45 { typedef typename polygon_traits::coordinate_type type; }; // template // struct get_coordinate_type_45 { typedef typename polygon_traits::coordinate_type type; }; // template // struct get_coordinate_type_2_45 { typedef typename polygon_traits::coordinate_type type; }; // template // struct get_coordinate_type_2_45 { typedef typename polygon_traits::coordinate_type type; }; // template // struct get_iterator_type_45 {}; // template // struct get_iterator_type_45 { // typedef typename T::const_iterator type; // static type begin(const T& t) { return t.begin(); } // static type end(const T& t) { return t.end(); } // }; // template // struct get_iterator_type_45 { // typedef const T* type; // static type begin(const T& t) { return &t; } // static type end(const T& t) { const T* tp = &t; ++tp; return tp; } // }; // template // struct get_iterator_type_45 { // typedef const T* type; // static type begin(const T& t) { return &t; } // static type end(const T& t) { const T* tp = &t; ++tp; return tp; } // }; // template // struct get_iterator_type_45 { // typedef const T* type; // static type begin(const T& t) { return &t; } // static type end(const T& t) { const T* tp = &t; ++tp; return tp; } // }; template struct polygon_90_set_traits { typedef typename get_coordinate_type::type >::type coordinate_type; typedef get_iterator_type indirection_type; typedef typename get_iterator_type::type iterator_type; typedef T operator_arg_type; static inline iterator_type begin(const T& polygon_set) { return indirection_type::begin(polygon_set); } static inline iterator_type end(const T& polygon_set) { return indirection_type::end(polygon_set); } static inline orientation_2d orient(const T&) { return HORIZONTAL; } static inline bool clean(const T&) { return false; } static inline bool sorted(const T&) { return false; } }; template struct is_manhattan_polygonal_concept { typedef gtl_no type; }; template <> struct is_manhattan_polygonal_concept { typedef gtl_yes type; }; template <> struct is_manhattan_polygonal_concept { typedef gtl_yes type; }; template <> struct is_manhattan_polygonal_concept { typedef gtl_yes type; }; template <> struct is_manhattan_polygonal_concept { typedef gtl_yes type; }; template struct is_polygon_90_set_type { typedef typename is_manhattan_polygonal_concept::type>::type type; }; template struct is_polygon_90_set_type > { typedef typename gtl_or< typename is_manhattan_polygonal_concept >::type>::type, typename is_manhattan_polygonal_concept::value_type>::type>::type>::type type; }; template struct is_polygon_90_set_type > { typedef typename gtl_or< typename is_manhattan_polygonal_concept >::type>::type, typename is_manhattan_polygonal_concept::value_type>::type>::type>::type type; }; template struct is_mutable_polygon_90_set_type { typedef typename gtl_same_type::type>::type type; }; template struct is_mutable_polygon_90_set_type > { typedef typename gtl_or< typename gtl_same_type >::type>::type, typename is_manhattan_polygonal_concept::value_type>::type>::type>::type type; }; template struct is_mutable_polygon_90_set_type > { typedef typename gtl_or< typename gtl_same_type >::type>::type, typename is_manhattan_polygonal_concept::value_type>::type>::type>::type type; }; // //specialization for rectangle, polygon_90 and polygon_90_with_holes types // template // struct polygon_90_set_traits // typedef typename geometry_concept::type concept_type; // typedef typename get_coordinate_type::type coordinate_type; // typedef iterator_geometry_to_set iterator_type; // typedef T operator_arg_type; // static inline iterator_type begin(const T& polygon_set) { // return iterator_geometry_to_set(polygon_set, LOW, HORIZONTAL); // } // static inline iterator_type end(const T& polygon_set) { // return iterator_geometry_to_set(polygon_set, HIGH, HORIZONTAL); // } // static inline orientation_2d orient(const T& polygon_set) { return HORIZONTAL; } // static inline bool clean(const T& polygon_set) { return false; } // static inline bool sorted(const T& polygon_set) { return false; } // }; // //specialization for containers of recangle, polygon_90, polygon_90_with_holes // template // struct polygon_90_set_traits::value_type>::type> { // typedef typename std::iterator_traits::value_type geometry_type; // typedef typename geometry_concept::type concept_type; // typedef typename get_coordinate_type::type coordinate_type; // typedef iterator_geometry_range_to_set iterator_type; // typedef T operator_arg_type; // static inline iterator_type begin(const T& polygon_set) { // return iterator_type(polygon_set.begin(), HORIZONTAL); // } // static inline iterator_type end(const T& polygon_set) { // return iterator_type(polygon_set.end(), HORIZONTAL); // } // static inline orientation_2d orient(const T& polygon_set) { return HORIZONTAL; } // static inline bool clean(const T& polygon_set) { return false; } // static inline bool sorted(const T& polygon_set) { return false; } // }; //get dispatch functions template void get_90_dispatch(output_container_type& output, const pst& ps, orientation_2d orient, rectangle_concept ) { form_rectangles(output, ps.begin(), ps.end(), orient, rectangle_concept()); } template void get_90_dispatch(output_container_type& output, const pst& ps, orientation_2d orient, polygon_90_concept tag) { get_polygons(output, ps.begin(), ps.end(), orient, true, tag); } template void get_90_dispatch(output_container_type& output, const pst& ps, orientation_2d orient, polygon_90_with_holes_concept tag) { get_polygons(output, ps.begin(), ps.end(), orient, false, tag); } //by default works with containers of rectangle, polygon or polygon with holes //must be specialized to work with anything else template struct polygon_90_set_mutable_traits {}; template struct polygon_90_set_mutable_traits > { typedef typename geometry_concept::type concept_type; template static inline void set(std::list& polygon_set, input_iterator_type input_begin, input_iterator_type input_end, orientation_2d orient) { polygon_set.clear(); polygon_90_set_data >::coordinate_type> ps(orient); ps.insert(input_begin, input_end, orient); ps.clean(); get_90_dispatch(polygon_set, ps, orient, concept_type()); } }; template struct polygon_90_set_mutable_traits > { typedef typename geometry_concept::type concept_type; template static inline void set(std::vector& polygon_set, input_iterator_type input_begin, input_iterator_type input_end, orientation_2d orient) { polygon_set.clear(); polygon_90_set_data >::coordinate_type> ps(orient); ps.insert(input_begin, input_end, orient); ps.clean(); get_90_dispatch(polygon_set, ps, orient, concept_type()); } }; template struct polygon_90_set_mutable_traits > { template static inline void set(polygon_90_set_data& polygon_set, input_iterator_type input_begin, input_iterator_type input_end, orientation_2d orient) { polygon_set.clear(); polygon_set.insert(input_begin, input_end, orient); } }; template struct polygon_90_set_traits > { typedef typename polygon_90_set_data::coordinate_type coordinate_type; typedef typename polygon_90_set_data::iterator_type iterator_type; typedef typename polygon_90_set_data::operator_arg_type operator_arg_type; static inline iterator_type begin(const polygon_90_set_data& polygon_set) { return polygon_set.begin(); } static inline iterator_type end(const polygon_90_set_data& polygon_set) { return polygon_set.end(); } static inline orientation_2d orient(const polygon_90_set_data& polygon_set) { return polygon_set.orient(); } static inline bool clean(const polygon_90_set_data& polygon_set) { polygon_set.clean(); return true; } static inline bool sorted(const polygon_90_set_data& polygon_set) { polygon_set.sort(); return true; } }; template struct is_polygon_90_set_concept { }; template <> struct is_polygon_90_set_concept { typedef gtl_yes type; }; template <> struct is_polygon_90_set_concept { typedef gtl_yes type; }; template <> struct is_polygon_90_set_concept { typedef gtl_yes type; }; template <> struct is_polygon_90_set_concept { typedef gtl_yes type; }; template struct is_mutable_polygon_90_set_concept { typedef gtl_no type; }; template <> struct is_mutable_polygon_90_set_concept { typedef gtl_yes type; }; template struct geometry_concept > { typedef polygon_90_set_concept type; }; //template //typename enable_if::type, void>::type //print_is_polygon_90_set_concept(const T& t) { std::cout << "is polygon 90 set concept\n"; } //template //typename enable_if::type, void>::type //print_is_mutable_polygon_90_set_concept(const T& t) { std::cout << "is mutable polygon 90 set concept\n"; } } } #endif