annotate DEPENDENCIES/generic/include/boost/icl/left_open_interval.hpp @ 133:4acb5d8d80b6 tip

Don't fail environmental check if README.md exists (but .txt and no-suffix don't)
author Chris Cannam
date Tue, 30 Jul 2019 12:25:44 +0100
parents 2665513ce2d3
children
rev   line source
Chris@16 1 /*-----------------------------------------------------------------------------+
Chris@16 2 Copyright (c) 2010-2010: Joachim Faulhaber
Chris@16 3 +------------------------------------------------------------------------------+
Chris@16 4 Distributed under the Boost Software License, Version 1.0.
Chris@16 5 (See accompanying file LICENCE.txt or copy at
Chris@16 6 http://www.boost.org/LICENSE_1_0.txt)
Chris@16 7 +-----------------------------------------------------------------------------*/
Chris@16 8 #ifndef BOOST_ICL_LEFT_OPEN_INTERVAL_HPP_JOFA_100930
Chris@16 9 #define BOOST_ICL_LEFT_OPEN_INTERVAL_HPP_JOFA_100930
Chris@16 10
Chris@16 11 #include <functional>
Chris@16 12 #include <boost/concept/assert.hpp>
Chris@16 13 #include <boost/icl/concept/interval.hpp>
Chris@16 14 #include <boost/icl/type_traits/value_size.hpp>
Chris@16 15 #include <boost/icl/type_traits/type_to_string.hpp>
Chris@16 16
Chris@16 17 namespace boost{namespace icl
Chris@16 18 {
Chris@16 19
Chris@16 20 template <class DomainT,
Chris@16 21 ICL_COMPARE Compare = ICL_COMPARE_INSTANCE(ICL_COMPARE_DEFAULT, DomainT)>
Chris@16 22 class left_open_interval
Chris@16 23 {
Chris@16 24 public:
Chris@16 25 typedef left_open_interval<DomainT,Compare> type;
Chris@16 26 typedef DomainT domain_type;
Chris@16 27 typedef ICL_COMPARE_DOMAIN(Compare,DomainT) domain_compare;
Chris@16 28
Chris@16 29 public:
Chris@16 30 //==========================================================================
Chris@16 31 //= Construct, copy, destruct
Chris@16 32 //==========================================================================
Chris@16 33 /** Default constructor; yields an empty interval <tt>(0,0]</tt>. */
Chris@16 34 left_open_interval()
Chris@16 35 : _lwb(identity_element<DomainT>::value()), _upb(identity_element<DomainT>::value())
Chris@16 36 {
Chris@16 37 BOOST_CONCEPT_ASSERT((DefaultConstructibleConcept<DomainT>));
Chris@16 38 BOOST_CONCEPT_ASSERT((LessThanComparableConcept<DomainT>));
Chris@16 39 }
Chris@16 40
Chris@16 41 //NOTE: Compiler generated copy constructor is used
Chris@16 42
Chris@16 43 /** Constructor for a left-open singleton interval <tt>(val-1,val]</tt> */
Chris@16 44 explicit left_open_interval(const DomainT& val)
Chris@16 45 : _lwb(predecessor<DomainT,domain_compare>::apply(val)), _upb(val)
Chris@16 46 {
Chris@16 47 BOOST_CONCEPT_ASSERT((DefaultConstructibleConcept<DomainT>));
Chris@16 48 BOOST_CONCEPT_ASSERT((LessThanComparableConcept<DomainT>));
Chris@16 49 // Only for discrete types this ctor creates an interval containing
Chris@16 50 // a single element only.
Chris@16 51 BOOST_STATIC_ASSERT((icl::is_discrete<DomainT>::value));
Chris@16 52 BOOST_ASSERT((numeric_minimum<DomainT, domain_compare, is_numeric<DomainT>::value >
Chris@16 53 ::is_less_than(val) ));
Chris@16 54 }
Chris@16 55
Chris@16 56 /** Interval from <tt>low</tt> to <tt>up</tt> with bounds <tt>bounds</tt> */
Chris@16 57 left_open_interval(const DomainT& low, const DomainT& up) :
Chris@16 58 _lwb(low), _upb(up)
Chris@16 59 {
Chris@16 60 BOOST_CONCEPT_ASSERT((DefaultConstructibleConcept<DomainT>));
Chris@16 61 BOOST_CONCEPT_ASSERT((LessThanComparableConcept<DomainT>));
Chris@16 62 }
Chris@16 63
Chris@16 64 DomainT lower()const{ return _lwb; }
Chris@16 65 DomainT upper()const{ return _upb; }
Chris@16 66
Chris@16 67 private:
Chris@16 68 DomainT _lwb;
Chris@16 69 DomainT _upb;
Chris@16 70 };
Chris@16 71
Chris@16 72 //==============================================================================
Chris@16 73 //=T left_open_interval -> concept intervals
Chris@16 74 //==============================================================================
Chris@16 75 template<class DomainT, ICL_COMPARE Compare>
Chris@16 76 struct interval_traits< icl::left_open_interval<DomainT, Compare> >
Chris@16 77 {
Chris@16 78 typedef DomainT domain_type;
Chris@16 79 typedef ICL_COMPARE_DOMAIN(Compare,DomainT) domain_compare;
Chris@16 80 typedef icl::left_open_interval<DomainT, Compare> interval_type;
Chris@16 81
Chris@16 82 static interval_type construct(const domain_type& lo, const domain_type& up)
Chris@16 83 {
Chris@16 84 return interval_type(lo, up);
Chris@16 85 }
Chris@16 86
Chris@16 87 static domain_type lower(const interval_type& inter_val){ return inter_val.lower(); };
Chris@16 88 static domain_type upper(const interval_type& inter_val){ return inter_val.upper(); };
Chris@16 89 };
Chris@16 90
Chris@16 91
Chris@16 92 //==============================================================================
Chris@16 93 //= Type traits
Chris@16 94 //==============================================================================
Chris@16 95 template <class DomainT, ICL_COMPARE Compare>
Chris@16 96 struct interval_bound_type< left_open_interval<DomainT,Compare> >
Chris@16 97 {
Chris@16 98 typedef interval_bound_type type;
Chris@16 99 BOOST_STATIC_CONSTANT(bound_type, value = interval_bounds::static_left_open);
Chris@16 100 };
Chris@16 101
Chris@16 102 template <class DomainT, ICL_COMPARE Compare>
Chris@16 103 struct type_to_string<icl::left_open_interval<DomainT,Compare> >
Chris@16 104 {
Chris@16 105 static std::string apply()
Chris@16 106 { return "(I]<"+ type_to_string<DomainT>::apply() +">"; }
Chris@16 107 };
Chris@16 108
Chris@16 109 template<class DomainT, ICL_COMPARE Compare>
Chris@16 110 struct value_size<icl::left_open_interval<DomainT,Compare> >
Chris@16 111 {
Chris@16 112 static std::size_t apply(const icl::left_open_interval<DomainT>&)
Chris@16 113 { return 2; }
Chris@16 114 };
Chris@16 115
Chris@16 116 }} // namespace icl boost
Chris@16 117
Chris@16 118 #endif
Chris@16 119