Server IP : 172.67.216.182 / Your IP : 162.158.88.58 Web Server : Apache System : Linux krdc-ubuntu-s-2vcpu-4gb-amd-blr1-01.localdomain 5.15.0-142-generic #152-Ubuntu SMP Mon May 19 10:54:31 UTC 2025 x86_64 User : www ( 1000) PHP Version : 7.4.33 Disable Function : passthru,exec,system,putenv,chroot,chgrp,chown,shell_exec,popen,proc_open,pcntl_exec,ini_alter,ini_restore,dl,openlog,syslog,readlink,symlink,popepassthru,pcntl_alarm,pcntl_fork,pcntl_waitpid,pcntl_wait,pcntl_wifexited,pcntl_wifstopped,pcntl_wifsignaled,pcntl_wifcontinued,pcntl_wexitstatus,pcntl_wtermsig,pcntl_wstopsig,pcntl_signal,pcntl_signal_dispatch,pcntl_get_last_error,pcntl_strerror,pcntl_sigprocmask,pcntl_sigwaitinfo,pcntl_sigtimedwait,pcntl_exec,pcntl_getpriority,pcntl_setpriority,imap_open,apache_setenv MySQL : OFF | cURL : ON | WGET : ON | Perl : ON | Python : OFF | Sudo : ON | Pkexec : ON Directory : /www/server/mysql/src/boost/boost_1_59_0/boost/geometry/algorithms/ |
Upload File : |
// Boost.Geometry (aka GGL, Generic Geometry Library) // Copyright (c) 2007-2012 Barend Gehrels, Amsterdam, the Netherlands. // Copyright (c) 2008-2012 Bruno Lalande, Paris, France. // Copyright (c) 2009-2012 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_ALGORITHMS_CLEAR_HPP #define BOOST_GEOMETRY_ALGORITHMS_CLEAR_HPP #include <boost/type_traits/remove_const.hpp> #include <boost/variant/apply_visitor.hpp> #include <boost/variant/static_visitor.hpp> #include <boost/variant/variant_fwd.hpp> #include <boost/geometry/algorithms/not_implemented.hpp> #include <boost/geometry/core/access.hpp> #include <boost/geometry/core/exterior_ring.hpp> #include <boost/geometry/core/interior_rings.hpp> #include <boost/geometry/core/mutable_range.hpp> #include <boost/geometry/core/tag_cast.hpp> #include <boost/geometry/core/tags.hpp> #include <boost/geometry/geometries/concepts/check.hpp> namespace boost { namespace geometry { #ifndef DOXYGEN_NO_DETAIL namespace detail { namespace clear { template <typename Geometry> struct collection_clear { static inline void apply(Geometry& geometry) { traits::clear<Geometry>::apply(geometry); } }; template <typename Polygon> struct polygon_clear { static inline void apply(Polygon& polygon) { traits::clear < typename boost::remove_reference < typename traits::interior_mutable_type<Polygon>::type >::type >::apply(interior_rings(polygon)); traits::clear < typename boost::remove_reference < typename traits::ring_mutable_type<Polygon>::type >::type >::apply(exterior_ring(polygon)); } }; template <typename Geometry> struct no_action { static inline void apply(Geometry& ) { } }; }} // namespace detail::clear #endif // DOXYGEN_NO_DETAIL #ifndef DOXYGEN_NO_DISPATCH namespace dispatch { template < typename Geometry, typename Tag = typename tag_cast<typename tag<Geometry>::type, multi_tag>::type > struct clear: not_implemented<Tag> {}; // Point/box/segment do not have clear. So specialize to do nothing. template <typename Geometry> struct clear<Geometry, point_tag> : detail::clear::no_action<Geometry> {}; template <typename Geometry> struct clear<Geometry, box_tag> : detail::clear::no_action<Geometry> {}; template <typename Geometry> struct clear<Geometry, segment_tag> : detail::clear::no_action<Geometry> {}; template <typename Geometry> struct clear<Geometry, linestring_tag> : detail::clear::collection_clear<Geometry> {}; template <typename Geometry> struct clear<Geometry, ring_tag> : detail::clear::collection_clear<Geometry> {}; // Polygon can (indirectly) use std for clear template <typename Polygon> struct clear<Polygon, polygon_tag> : detail::clear::polygon_clear<Polygon> {}; template <typename Geometry> struct clear<Geometry, multi_tag> : detail::clear::collection_clear<Geometry> {}; } // namespace dispatch #endif // DOXYGEN_NO_DISPATCH namespace resolve_variant { template <typename Geometry> struct clear { static inline void apply(Geometry& geometry) { dispatch::clear<Geometry>::apply(geometry); } }; template <BOOST_VARIANT_ENUM_PARAMS(typename T)> struct clear<variant<BOOST_VARIANT_ENUM_PARAMS(T)> > { struct visitor: static_visitor<void> { template <typename Geometry> inline void operator()(Geometry& geometry) const { clear<Geometry>::apply(geometry); } }; static inline void apply(variant<BOOST_VARIANT_ENUM_PARAMS(T)>& geometry) { boost::apply_visitor(visitor(), geometry); } }; } // namespace resolve_variant /*! \brief Clears a linestring, ring or polygon (exterior+interiors) or multi* \details Generic function to clear a geometry. All points will be removed from the collection or collections making up the geometry. In most cases this is equivalent to the .clear() method of a std::vector<...>. In the case of a polygon, this clear functionality is automatically called for the exterior ring, and for the interior ring collection. In the case of a point, boxes and segments, nothing will happen. \ingroup clear \tparam Geometry \tparam_geometry \param geometry \param_geometry which will be cleared \note points and boxes cannot be cleared, instead they can be set to zero by "assign_zero" \qbk{[include reference/algorithms/clear.qbk]} */ template <typename Geometry> inline void clear(Geometry& geometry) { concept::check<Geometry>(); resolve_variant::clear<Geometry>::apply(geometry); } }} // namespace boost::geometry #endif // BOOST_GEOMETRY_ALGORITHMS_CLEAR_HPP