| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107 | /*  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_WITH_HOLES_DATA_HPP#define BOOST_POLYGON_POLYGON_WITH_HOLES_DATA_HPP#include "isotropy.hpp"#include "polygon_data.hpp"namespace boost { namespace polygon{  struct polygon_with_holes_concept;  template <typename T>  class polygon_with_holes_data {public:  typedef polygon_with_holes_concept geometry_type;  typedef T coordinate_type;  typedef typename polygon_data<T>::iterator_type iterator_type;  typedef typename std::list<polygon_data<coordinate_type> >::const_iterator iterator_holes_type;  typedef polygon_data<coordinate_type> hole_type;  typedef typename coordinate_traits<T>::coordinate_distance area_type;  typedef point_data<T> point_type;  // default constructor of point does not initialize x and y  inline polygon_with_holes_data() : self_(), holes_() {} //do nothing default constructor  template<class iT>  inline polygon_with_holes_data(iT input_begin, iT input_end) : self_(), holes_() {    set(input_begin, input_end);  }  template<class iT, typename hiT>  inline polygon_with_holes_data(iT input_begin, iT input_end, hiT holes_begin, hiT holes_end) : self_(), holes_() {    set(input_begin, input_end);    set_holes(holes_begin, holes_end);  }  template<class iT>  inline polygon_with_holes_data& set(iT input_begin, iT input_end) {    self_.set(input_begin, input_end);    return *this;  }  // initialize a polygon from x,y values, it is assumed that the first is an x  // and that the input is a well behaved polygon  template<class iT>  inline polygon_with_holes_data& set_holes(iT input_begin, iT input_end) {    holes_.clear();  //just in case there was some old data there    for( ; input_begin != input_end; ++ input_begin) {       holes_.push_back(hole_type());       holes_.back().set((*input_begin).begin(), (*input_begin).end());    }    return *this;  }  // copy constructor (since we have dynamic memory)  inline polygon_with_holes_data(const polygon_with_holes_data& that) : self_(that.self_),                                                                  holes_(that.holes_) {}  // assignment operator (since we have dynamic memory do a deep copy)  inline polygon_with_holes_data& operator=(const polygon_with_holes_data& that) {    self_ = that.self_;    holes_ = that.holes_;    return *this;  }  template <typename T2>  inline polygon_with_holes_data& operator=(const T2& rvalue);  // get begin iterator, returns a pointer to a const coordinate_type  inline const iterator_type begin() const {    return self_.begin();  }  // get end iterator, returns a pointer to a const coordinate_type  inline const iterator_type end() const {    return self_.end();  }  inline std::size_t size() const {    return self_.size();  }  // get begin iterator, returns a pointer to a const polygon  inline const iterator_holes_type begin_holes() const {    return holes_.begin();  }  // get end iterator, returns a pointer to a const polygon  inline const iterator_holes_type end_holes() const {    return holes_.end();  }  inline std::size_t size_holes() const {    return holes_.size();  }public:  polygon_data<coordinate_type> self_;  std::list<hole_type> holes_;  };}}#endif
 |