Boost C++ Libraries

...one of the most highly regarded and expertly designed C++ library projects in the world. Herb Sutter and Andrei Alexandrescu, C++ Coding Standards

This is the documentation for an old version of Boost. Click here to view this page for the latest version.
PrevUpHomeNext

Reference

Headers

Headers

namespace boost {
  namespace stl_interfaces {
    namespace v1 {
      enum element_layout;
      namespace v1_dtl {
        template<typename Range, typename  = void> struct decrementable_sentinel;

        template<typename Range> 
          struct decrementable_sentinel<Range, void_t< decltype(--std::declval< sentinel_t< Range > & >())>>;

        template<typename Range, typename  = void> struct iterator;

        template<typename Range> 
          struct iterator<Range, void_t< decltype(std::declval< Range & >().begin())>>;

        template<typename Range, typename  = void> struct sentinel;

        template<typename Range> 
          struct sentinel<Range, void_t< decltype(std::declval< Range & >().end())>>;

        typedef void void_t;
        typedef typename std::iterator_traits< Iter >::difference_type iter_difference_t;
        typedef typename iterator< Range >::type iterator_t;
        typedef typename sentinel< Range >::type sentinel_t;
        typedef iter_difference_t< iterator_t< Range > > range_difference_t;
        typedef std::is_same< iterator_t< Range >, sentinel_t< Range > > common_range;
      }
    }
  }
}

BOOST_STL_INTERFACES_STATIC_ASSERT_CONCEPT(type, concept_name)
BOOST_STL_INTERFACES_STATIC_ASSERT_ITERATOR_TRAITS(iter, category, concept, value_type, reference, pointer, difference_type)
namespace boost {
  namespace stl_interfaces {
    struct access;
    template<typename T> struct proxy_arrow_result;
    namespace v1 {
      template<typename Derived, typename IteratorConcept, typename ValueType, 
               typename Reference, typename Pointer, typename DifferenceType> 
        struct iterator_interface;
      typedef iterator_interface< Derived, IteratorConcept, ValueType, Reference, proxy_arrow_result< Reference >, DifferenceType > proxy_iterator_interface;
      template<typename IteratorInterface1, typename IteratorInterface2, 
               typename Enable = std::enable_if_t<!v1_dtl::ra_iter<IteratorInterface1>::value> > 
        constexpr auto operator==(IteratorInterface1, IteratorInterface2);
      template<typename IteratorInterface1, typename IteratorInterface2> 
        constexpr auto operator!=(IteratorInterface1, IteratorInterface2);
      template<typename IteratorInterface1, typename IteratorInterface2> 
        constexpr auto operator<(IteratorInterface1, IteratorInterface2);
      template<typename IteratorInterface1, typename IteratorInterface2> 
        constexpr auto operator<=(IteratorInterface1, IteratorInterface2);
      template<typename IteratorInterface1, typename IteratorInterface2> 
        constexpr auto operator>(IteratorInterface1, IteratorInterface2);
      template<typename IteratorInterface1, typename IteratorInterface2> 
        constexpr auto operator>=(IteratorInterface1, IteratorInterface2);
      namespace v1_dtl {
        template<typename Iterator, typename DifferenceType, typename  = void> 
          struct plus_eq;

        template<typename Iterator, typename DifferenceType> 
          struct plus_eq<Iterator, DifferenceType, void_t< decltype(std::declval< Iterator & >()+=std::declval< DifferenceType >())>>;

        template<typename Iterator, typename  = void> struct ra_iter;

        template<typename Iterator> 
          struct ra_iter<Iterator, void_t< typename Iterator::iterator_concept >>;
        template<typename D, typename IteratorConcept, typename ValueType, 
                 typename Reference, typename Pointer, 
                 typename DifferenceType> 
          void derived_iterator(iterator_interface< D, IteratorConcept, ValueType, Reference, Pointer, DifferenceType > const &);
      }
    }
  }
}
namespace boost {
  namespace stl_interfaces {
    namespace v1 {
      template<typename BidiIter> struct reverse_iterator;
      template<typename BidiIter> 
        constexpr auto 
        operator==(reverse_iterator< BidiIter > lhs, 
                   reverse_iterator< BidiIter > rhs);
      template<typename BidiIter1, typename BidiIter2> 
        constexpr auto 
        operator==(reverse_iterator< BidiIter1 > lhs, 
                   reverse_iterator< BidiIter2 > rhs);
      template<typename BidiIter> auto make_reverse_iterator(BidiIter);
      namespace v1_dtl {
        template<typename Iter> 
          constexpr auto 
          ce_dist(Iter f, Iter l, std::random_access_iterator_tag);
        template<typename Iter, typename Tag> 
          constexpr auto ce_dist(Iter f, Iter l, Tag);
        template<typename Iter> constexpr Iter ce_prev(Iter it);
        template<typename Iter, typename Offset> 
          constexpr void 
          ce_adv(Iter & f, Offset n, std::random_access_iterator_tag);
        template<typename Iter, typename Offset, typename Tag> 
          constexpr void ce_adv(Iter & f, Offset n, Tag);
      }
    }
    namespace v2 {
      typedef std::reverse_iterator< BidiIter > reverse_iterator;
      template<typename BidiIter> auto make_reverse_iterator(BidiIter);
    }
  }
}
namespace boost {
  namespace stl_interfaces {
    namespace v1 {
      template<typename Derived, element_layout Contiguity> 
        struct sequence_container_interface;
      template<typename ContainerInterface> 
        constexpr auto swap(ContainerInterface &, ContainerInterface &);
      template<typename ContainerInterface> 
        constexpr auto 
        operator==(ContainerInterface const &, ContainerInterface const &);
      template<typename ContainerInterface> 
        constexpr auto 
        operator!=(ContainerInterface const &, ContainerInterface const &);
      template<typename ContainerInterface> 
        constexpr auto 
        operator<(ContainerInterface const &, ContainerInterface const &);
      template<typename ContainerInterface> 
        constexpr auto 
        operator<=(ContainerInterface const &, ContainerInterface const &);
      template<typename ContainerInterface> 
        constexpr auto 
        operator>(ContainerInterface const &, ContainerInterface const &);
      template<typename ContainerInterface> 
        constexpr auto 
        operator>=(ContainerInterface const &, ContainerInterface const &);
      namespace v1_dtl {
        template<typename D, typename  = void> struct clear_impl;

        template<typename D> 
          struct clear_impl<D, void_t< decltype(std::declval< D >().clear())>>;

        typedef std::is_convertible< typename std::iterator_traits< Iter >::iterator_category, std::input_iterator_tag > in_iter;
        template<typename D, element_layout Contiguity> 
          void derived_container(sequence_container_interface< D, Contiguity > const &);
      }
    }
  }
}
namespace boost {
  namespace stl_interfaces {
    namespace v1 {
      template<typename Derived, element_layout Contiguity> struct view_interface;
      template<typename ViewInterface> 
        constexpr auto operator!=(ViewInterface, ViewInterface);
      namespace v1_dtl {
        template<typename D, element_layout Contiguity> 
          void derived_view(view_interface< D, Contiguity > const &);
      }
    }
    namespace v2 {
      typedef std::ranges::view_interface< D > view_interface;
    }
  }
}

PrevUpHomeNext