![]() System : Linux absol.cf 5.4.0-198-generic #218-Ubuntu SMP Fri Sep 27 20:18:53 UTC 2024 x86_64 User : www-data ( 33) PHP Version : 7.4.33 Disable Function : 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_get_handler,pcntl_signal_dispatch,pcntl_get_last_error,pcntl_strerror,pcntl_sigprocmask,pcntl_sigwaitinfo,pcntl_sigtimedwait,pcntl_exec,pcntl_getpriority,pcntl_setpriority,pcntl_async_signals,pcntl_unshare, Directory : /usr/include/boost/spirit/home/support/char_set/ |
Upload File : |
/*============================================================================= Copyright (c) 2001-2011 Joel de Guzman Distributed under 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) ==============================================================================*/ #if !defined(BOOST_SPIRIT_RANGE_RUN_MAY_16_2006_0801_PM) #define BOOST_SPIRIT_RANGE_RUN_MAY_16_2006_0801_PM #if defined(_MSC_VER) #pragma once #endif #include <boost/spirit/home/support/char_set/range.hpp> #include <vector> namespace boost { namespace spirit { namespace support { namespace detail { /////////////////////////////////////////////////////////////////////////// // range_run // // An implementation of a sparse bit (boolean) set. The set uses // a sorted vector of disjoint ranges. This class implements the // bare minimum essentials from which the full range of set // operators can be implemented. The set is constructed from // ranges. Internally, adjacent or overlapping ranges are // coalesced. // // range_runs are very space-economical in situations where there // are lots of ranges and a few individual disjoint values. // Searching is O(log n) where n is the number of ranges. // // { Low level interface } /////////////////////////////////////////////////////////////////////////// template <typename Char> class range_run { public: typedef range<Char> range_type; typedef std::vector<range_type> storage_type; void swap(range_run& other); bool test(Char v) const; void set(range_type const& range); void clear(range_type const& range); void clear(); private: storage_type run; }; }}}} #include <boost/spirit/home/support/char_set/range_run_impl.hpp> #endif