mirror of
https://github.com/boostorg/algorithm.git
synced 2025-06-25 20:11:50 +02:00
Compare commits
41 Commits
boost-1.74
...
boost-1.80
Author | SHA1 | Date | |
---|---|---|---|
1c5f74ae25 | |||
6931736390 | |||
1cfd9592f7 | |||
12ade334e0 | |||
eec00d8421 | |||
055ebaa4cd | |||
559835eaa5 | |||
00c6f1d6c1 | |||
6b7a38f639 | |||
02f436c25d | |||
da8ea581eb | |||
a9cd6c353f | |||
2a05506d52 | |||
9d5ddb6a7a | |||
9031f17bb8 | |||
0c2e904c0d | |||
d717d999be | |||
2409048368 | |||
fe66d6211d | |||
c5f6f52560 | |||
ba3f706b1d | |||
aab7e1c121 | |||
02b05e5e24 | |||
4ad181f464 | |||
3b3bd8d3db | |||
c9077bd495 | |||
bcd55d9992 | |||
b139b72230 | |||
137c92dac0 | |||
bd81ca42a2 | |||
fc86cd34f7 | |||
ca77e55428 | |||
8c26a50a12 | |||
c16b8ffadd | |||
1e098f39d4 | |||
e4c3628f4d | |||
49d284392c | |||
68100d9198 | |||
1634b819b3 | |||
4547b1a5fe | |||
ac1713e130 |
310
.travis.yml
310
.travis.yml
@ -1,171 +1,193 @@
|
|||||||
# Copyright 2016, 2017, 2018 Peter Dimov
|
# Copyright 2016 - 2018 Peter Dimov
|
||||||
# Copyright 2018 T. Zachary Laine
|
# Copyright 2018 T. Zachary Laine
|
||||||
|
# Copyright 2017 - 2019 James E. King III
|
||||||
# Distributed under the Boost Software License, Version 1.0.
|
# Distributed under the Boost Software License, Version 1.0.
|
||||||
# (See accompanying file LICENSE_1_0.txt or copy at http://boost.org/LICENSE_1_0.txt)
|
# (See accompanying file LICENSE_1_0.txt or copy at http://boost.org/LICENSE_1_0.txt)
|
||||||
|
|
||||||
|
#
|
||||||
|
# Generic Travis CI build script for boostorg repositories
|
||||||
|
# See: https://github.com/boostorg/boost-ci
|
||||||
|
#
|
||||||
|
# Instructions for customizing this script for your library:
|
||||||
|
#
|
||||||
|
# 1. Customize the compilers and language levels you want in the 'jobs'.
|
||||||
|
# 2. If you have more than include/, src/, test/, example/, examples/, or
|
||||||
|
# tools/ directories, modify your Travis CI project and add the environment
|
||||||
|
# variable DEPINST. For example if your build uses code in "bench/" and
|
||||||
|
# "fog/" directories, then set DEPINST to the following:
|
||||||
|
# --include bench --include fog
|
||||||
|
# 3. If you want to enable Coverity Scan, you need to provide the environment
|
||||||
|
# variables COVERITY_SCAN_TOKEN and COVERITY_SCAN_NOTIFICATION_EMAIL in
|
||||||
|
# your github settings.
|
||||||
|
# 4. Enable pull request builds in your boostorg/<library> account.
|
||||||
|
#
|
||||||
|
# That's it - the scripts will do everything else for you.
|
||||||
|
|
||||||
|
dist: xenial
|
||||||
language: cpp
|
language: cpp
|
||||||
|
|
||||||
sudo: false
|
env:
|
||||||
|
global:
|
||||||
|
# see: http://www.boost.org/build/doc/html/bbv2/overview/invocation.html#bbv2.overview.invocation.properties
|
||||||
|
# to use the default for a given environment, comment it out; recommend you build debug and release however..
|
||||||
|
# - B2_ADDRESS_MODEL=address-model=64,32
|
||||||
|
# - B2_LINK=link=shared,static
|
||||||
|
# - B2_THREADING=threading=multi,single
|
||||||
|
- B2_VARIANT=variant=release,debug
|
||||||
|
|
||||||
|
install:
|
||||||
|
- git clone https://github.com/boostorg/boost-ci.git boost-ci
|
||||||
|
- cp -pr boost-ci/ci boost-ci/.codecov.yml .
|
||||||
|
- source ci/travis/install.sh
|
||||||
|
|
||||||
|
addons:
|
||||||
|
apt:
|
||||||
|
packages:
|
||||||
|
- binutils-gold
|
||||||
|
- gdb
|
||||||
|
- libc6-dbg
|
||||||
|
|
||||||
branches:
|
branches:
|
||||||
only:
|
only:
|
||||||
- master
|
- master
|
||||||
- develop
|
- develop
|
||||||
- /feature\/.*/
|
- bugfix/*
|
||||||
|
- feature/*
|
||||||
|
- fix/*
|
||||||
|
- pr/*
|
||||||
|
|
||||||
env:
|
script:
|
||||||
matrix:
|
- cd $BOOST_ROOT/libs/$SELF
|
||||||
- BOGUS_JOB=true
|
- ci/travis/build.sh
|
||||||
|
|
||||||
matrix:
|
#
|
||||||
|
# Default toolsets in Ubuntu
|
||||||
|
#
|
||||||
|
# trusty xenial bionic
|
||||||
|
# 14.04 16.04 18.04
|
||||||
|
# ------ ------ ------
|
||||||
|
# clang 3.4 3.8 6.0
|
||||||
|
# gcc 4.8.2 5.3.1 7.3.0
|
||||||
|
#
|
||||||
|
|
||||||
exclude:
|
anchors:
|
||||||
- env: BOGUS_JOB=true
|
clang-38: &clang-38 { apt: { packages: [ "clang-3.8",
|
||||||
|
"libstdc++-6-dev" ], sources: [ "llvm-toolchain-xenial-3.8",
|
||||||
|
"ubuntu-toolchain-r-test" ] } }
|
||||||
|
clang-4: &clang-4 { apt: { packages: [ "clang-4.0",
|
||||||
|
"libstdc++-6-dev" ], sources: [ "llvm-toolchain-xenial-4.0",
|
||||||
|
"ubuntu-toolchain-r-test" ] } }
|
||||||
|
clang-5: &clang-5 { apt: { packages: [ "clang-5.0",
|
||||||
|
"libstdc++-7-dev" ], sources: [ "llvm-toolchain-xenial-5.0",
|
||||||
|
"ubuntu-toolchain-r-test" ] } }
|
||||||
|
clang-6: &clang-6 { apt: { packages: [ "clang-6.0",
|
||||||
|
"libc6-dbg",
|
||||||
|
"libc++-dev",
|
||||||
|
"libstdc++-8-dev" ], sources: [ "llvm-toolchain-xenial-6.0",
|
||||||
|
"ubuntu-toolchain-r-test" ] } }
|
||||||
|
clang-7: &clang-7 { apt: { packages: [ "clang-7",
|
||||||
|
"libc6-dbg",
|
||||||
|
"libc++-dev",
|
||||||
|
"libstdc++-8-dev" ], sources: [ "llvm-toolchain-xenial-7",
|
||||||
|
"ubuntu-toolchain-r-test" ] } }
|
||||||
|
clang-8: &clang-8 { apt: { packages: [ "clang-8",
|
||||||
|
"libc6-dbg",
|
||||||
|
"libc++-dev",
|
||||||
|
"libstdc++-8-dev" ], sources: [ "llvm-toolchain-xenial-8",
|
||||||
|
"ubuntu-toolchain-r-test" ] } }
|
||||||
|
gcc-48: &gcc-48 { apt: { packages: [ "g++-4.8" ] } }
|
||||||
|
gcc-49: &gcc-49 { apt: { packages: [ "g++-4.9" ] } }
|
||||||
|
gcc-5: &gcc-5 { apt: { packages: [ "g++-5" ] } }
|
||||||
|
gcc-6: &gcc-6 { apt: { packages: [ "g++-6" ], sources: [ "ubuntu-toolchain-r-test" ] } }
|
||||||
|
gcc-7: &gcc-7 { apt: { packages: [ "g++-7" ], sources: [ "ubuntu-toolchain-r-test" ] } }
|
||||||
|
gcc-8: &gcc-8 { apt: { packages: [ "g++-8" ], sources: [ "ubuntu-toolchain-r-test" ] } }
|
||||||
|
|
||||||
|
jobs:
|
||||||
|
allow_failures:
|
||||||
|
- env:
|
||||||
|
- COPY="all the environment settings from your job"
|
||||||
|
|
||||||
include:
|
include:
|
||||||
- os: linux
|
# libstdc++
|
||||||
env: TOOLSET=gcc COMPILER=g++ CXXSTD=11
|
- { os: "linux", env: [ "B2_TOOLSET=gcc-4.8", "B2_CXXSTD=03,11" ], addons: *gcc-48 }
|
||||||
|
- { os: "linux", env: [ "B2_TOOLSET=gcc-4.9", "B2_CXXSTD=03,11" ], addons: *gcc-49 }
|
||||||
|
- { os: "linux", env: [ "B2_TOOLSET=gcc-5", "B2_CXXSTD=11" ], addons: *gcc-5 }
|
||||||
|
- { os: "linux", env: [ "B2_TOOLSET=gcc-6", "B2_CXXSTD=11,14" ], addons: *gcc-6 }
|
||||||
|
- { os: "linux", env: [ "B2_TOOLSET=gcc-7", "B2_CXXSTD=11,14,17" ], addons: *gcc-7 }
|
||||||
|
- { os: "linux", env: [ "B2_TOOLSET=gcc-8", "B2_CXXSTD=14,17,2a" ], addons: *gcc-8 }
|
||||||
|
- { os: "linux", env: [ "B2_TOOLSET=clang-3.8", "B2_CXXSTD=03,11,14" ], addons: *clang-38 }
|
||||||
|
- { os: "linux", env: [ "B2_TOOLSET=clang-4.0", "B2_CXXSTD=11,14" ], addons: *clang-4 }
|
||||||
|
- { os: "linux", env: [ "B2_TOOLSET=clang-5.0", "B2_CXXSTD=11,14,17" ], addons: *clang-5 }
|
||||||
|
- { os: "linux", env: [ "B2_TOOLSET=clang-6.0", "B2_CXXSTD=14,17,2a" ], addons: *clang-6 }
|
||||||
|
- { os: "linux", env: [ "B2_TOOLSET=clang-7", "B2_CXXSTD=14,17,2a" ], addons: *clang-7 }
|
||||||
|
- { os: "linux", env: [ "B2_TOOLSET=clang-8", "B2_CXXSTD=14,17,2a" ], addons: *clang-8 }
|
||||||
|
|
||||||
|
# libc++
|
||||||
|
- { os: "linux", env: [ "B2_TOOLSET=clang-6.0", "B2_CXXSTD=03,11,14,17,2a",
|
||||||
|
"B2_CXXFLAGS=-stdlib=libc++" ], addons: *clang-6 }
|
||||||
|
- { os: "osx" , env: [ "B2_TOOLSET=clang", "B2_CXXSTD=03,11,17" ] }
|
||||||
|
|
||||||
|
# to enable Intel ICC define INTEL_ICC_SERIAL_NUMBER and the following:
|
||||||
|
# - { os: "linux", env: [ "B2_TOOLSET=intel-linux", "B2_CXXSTD=11,14,17" ], addons: *gcc-7,
|
||||||
|
# script: cd $BOOST_ROOT/libs/$SELF && ci/travis/intelicc.sh }
|
||||||
|
|
||||||
- os: linux
|
- os: linux
|
||||||
env: TOOLSET=gcc COMPILER=g++-4.7 CXXSTD=11
|
env:
|
||||||
addons:
|
- COMMENT=codecov.io
|
||||||
apt:
|
- B2_TOOLSET=03,11,14
|
||||||
packages:
|
- B2_TOOLSET=gcc-8
|
||||||
- g++-4.7
|
- B2_DEFINES="define=BOOST_NO_STRESS_TEST=1"
|
||||||
sources:
|
addons: *gcc-8
|
||||||
- ubuntu-toolchain-r-test
|
script:
|
||||||
|
- pushd /tmp && git clone https://github.com/linux-test-project/lcov.git && export PATH=/tmp/lcov/bin:$PATH && which lcov && lcov --version && popd
|
||||||
|
- cd $BOOST_ROOT/libs/$SELF
|
||||||
|
- ci/travis/codecov.sh
|
||||||
|
|
||||||
- os: linux
|
- os: linux
|
||||||
env: TOOLSET=gcc COMPILER=g++-4.8 CXXSTD=11
|
env:
|
||||||
addons:
|
- COMMENT=cppcheck
|
||||||
apt:
|
script:
|
||||||
packages:
|
- cd $BOOST_ROOT/libs/$SELF
|
||||||
- g++-4.8
|
- ci/travis/cppcheck.sh
|
||||||
sources:
|
|
||||||
- ubuntu-toolchain-r-test
|
|
||||||
|
|
||||||
- os: linux
|
- os: linux
|
||||||
env: TOOLSET=gcc COMPILER=g++-4.9 CXXSTD=11
|
env:
|
||||||
addons:
|
- COMMENT=ubsan
|
||||||
apt:
|
- B2_VARIANT=variant=debug
|
||||||
packages:
|
- B2_TOOLSET=gcc-8
|
||||||
- g++-4.9
|
- B2_CXXSTD=03,11,14,17,2a
|
||||||
sources:
|
- B2_DEFINES="define=BOOST_NO_STRESS_TEST=1"
|
||||||
- ubuntu-toolchain-r-test
|
- B2_CXXFLAGS="cxxflags=-fno-omit-frame-pointer cxxflags=-fsanitize=undefined cxxflags=-fno-sanitize-recover=all"
|
||||||
|
- B2_LINKFLAGS="linkflags=-fsanitize=undefined linkflags=-fno-sanitize-recover=all linkflags=-fuse-ld=gold"
|
||||||
|
- UBSAN_OPTIONS=print_stacktrace=1
|
||||||
|
addons: *gcc-8
|
||||||
|
|
||||||
- os: linux
|
- os: linux
|
||||||
env: TOOLSET=gcc COMPILER=g++-5 CXXSTD=11,14,1z
|
env:
|
||||||
addons:
|
- COMMENT=valgrind
|
||||||
apt:
|
- B2_TOOLSET=clang-6.0
|
||||||
packages:
|
- B2_CXXSTD=03,11,14,17,2a
|
||||||
- g++-5
|
- B2_DEFINES="define=BOOST_NO_STRESS_TEST=1"
|
||||||
sources:
|
- B2_VARIANT=variant=debug
|
||||||
- ubuntu-toolchain-r-test
|
- B2_TESTFLAGS=testing.launcher=valgrind
|
||||||
|
- VALGRIND_OPTS=--error-exitcode=1
|
||||||
|
addons: *clang-6
|
||||||
|
script:
|
||||||
|
- cd $BOOST_ROOT/libs/$SELF
|
||||||
|
- ci/travis/valgrind.sh
|
||||||
|
|
||||||
|
#################### Jobs to run on pushes to master, develop ###################
|
||||||
|
|
||||||
|
# Coverity Scan
|
||||||
- os: linux
|
- os: linux
|
||||||
env: TOOLSET=gcc COMPILER=g++-6 CXXSTD=11,14,1z
|
if: (env(COVERITY_SCAN_NOTIFICATION_EMAIL) IS present) AND (branch IN (develop, master)) AND (type IN (cron, push))
|
||||||
addons:
|
env:
|
||||||
apt:
|
- COMMENT="Coverity Scan"
|
||||||
packages:
|
- B2_TOOLSET=clang
|
||||||
- g++-6
|
script:
|
||||||
sources:
|
- cd $BOOST_ROOT/libs/$SELF
|
||||||
- ubuntu-toolchain-r-test
|
- ci/travis/coverity.sh
|
||||||
|
|
||||||
- os: linux
|
notifications:
|
||||||
env: TOOLSET=gcc COMPILER=g++-6 CXXSTD=11,14,1z CXXSTD_DIALECT=cxxstd-dialect=gnu
|
email:
|
||||||
addons:
|
false
|
||||||
apt:
|
|
||||||
packages:
|
|
||||||
- g++-6
|
|
||||||
sources:
|
|
||||||
- ubuntu-toolchain-r-test
|
|
||||||
|
|
||||||
- os: linux
|
|
||||||
env: TOOLSET=gcc COMPILER=g++-7 CXXSTD=11,14,17
|
|
||||||
addons:
|
|
||||||
apt:
|
|
||||||
packages:
|
|
||||||
- g++-7
|
|
||||||
sources:
|
|
||||||
- ubuntu-toolchain-r-test
|
|
||||||
|
|
||||||
- os: linux
|
|
||||||
env: TOOLSET=clang COMPILER=clang++ CXXSTD=11
|
|
||||||
|
|
||||||
- os: linux
|
|
||||||
compiler: clang++-libc++
|
|
||||||
env: TOOLSET=clang COMPILER=clang++-libc++ CXXSTD=11,14,1z
|
|
||||||
addons:
|
|
||||||
apt:
|
|
||||||
packages:
|
|
||||||
- libc++-dev
|
|
||||||
|
|
||||||
- os: osx
|
|
||||||
env: TOOLSET=clang COMPILER=clang++ CXXSTD=11,14,1z
|
|
||||||
osx_image: xcode9.1
|
|
||||||
|
|
||||||
- os: osx
|
|
||||||
env: TOOLSET=clang COMPILER=clang++ CXXSTD=11,14,1z
|
|
||||||
osx_image: xcode9
|
|
||||||
|
|
||||||
- os: osx
|
|
||||||
env: TOOLSET=clang COMPILER=clang++ CXXSTD=11,14,1z
|
|
||||||
osx_image: xcode8.3
|
|
||||||
|
|
||||||
- os: osx
|
|
||||||
env: TOOLSET=clang COMPILER=clang++ CXXSTD=11,14,1z
|
|
||||||
osx_image: xcode8
|
|
||||||
|
|
||||||
- os: osx
|
|
||||||
env: TOOLSET=clang COMPILER=clang++ CXXSTD=11,14,1z
|
|
||||||
osx_image: xcode7.3
|
|
||||||
|
|
||||||
- os: osx
|
|
||||||
env: TOOLSET=clang COMPILER=clang++ CXXSTD=11,14,1z
|
|
||||||
osx_image: xcode6.4
|
|
||||||
|
|
||||||
install:
|
|
||||||
- BOOST_BRANCH=develop && [ "$TRAVIS_BRANCH" == "master" ] && BOOST_BRANCH=master || true
|
|
||||||
- cd ..
|
|
||||||
- git clone -b $BOOST_BRANCH --depth 1 https://github.com/boostorg/boost.git boost-root
|
|
||||||
- cd boost-root
|
|
||||||
- git submodule update --init tools/build
|
|
||||||
- git submodule update --init libs/config
|
|
||||||
- git submodule update --init libs/predef
|
|
||||||
- git submodule update --init libs/core
|
|
||||||
- git submodule update --init libs/detail
|
|
||||||
- git submodule update --init libs/range
|
|
||||||
- git submodule update --init libs/assert
|
|
||||||
- git submodule update --init libs/array
|
|
||||||
- git submodule update --init libs/type_traits
|
|
||||||
- git submodule update --init libs/static_assert
|
|
||||||
- git submodule update --init libs/iterator
|
|
||||||
- git submodule update --init libs/preprocessor
|
|
||||||
- git submodule update --init libs/mpl
|
|
||||||
- git submodule update --init libs/smart_ptr
|
|
||||||
- git submodule update --init libs/callable_traits
|
|
||||||
- git submodule update --init libs/type_index
|
|
||||||
- git submodule update --init libs/exception
|
|
||||||
- git submodule update --init libs/throw_exception
|
|
||||||
- git submodule update --init libs/utility
|
|
||||||
- git submodule update --init libs/bind
|
|
||||||
- git submodule update --init libs/ratio
|
|
||||||
- git submodule update --init libs/function
|
|
||||||
- git submodule update --init libs/integer
|
|
||||||
- git submodule update --init libs/numeric
|
|
||||||
- git submodule update --init libs/move
|
|
||||||
- git submodule update --init libs/container_hash
|
|
||||||
- git submodule update --init libs/io
|
|
||||||
- git submodule update --init libs/concept_check
|
|
||||||
- git submodule update --init libs/test
|
|
||||||
- git submodule update --init libs/timer
|
|
||||||
- git submodule update --init libs/chrono
|
|
||||||
- git submodule update --init libs/system
|
|
||||||
- cp -r $TRAVIS_BUILD_DIR/* libs/algorithm
|
|
||||||
- ./bootstrap.sh
|
|
||||||
- ./b2 headers
|
|
||||||
|
|
||||||
script:
|
|
||||||
- |-
|
|
||||||
echo "using $TOOLSET : : $COMPILER ;" > ~/user-config.jam
|
|
||||||
- ./b2 -j3 libs/algorithm/test toolset=$TOOLSET cxxstd=$CXXSTD $CXXSTD_DIALECT
|
|
||||||
|
41
CMakeLists.txt
Normal file
41
CMakeLists.txt
Normal file
@ -0,0 +1,41 @@
|
|||||||
|
# Generated by `boostdep --cmake algorithm`
|
||||||
|
# Copyright 2020 Peter Dimov
|
||||||
|
# Distributed under the Boost Software License, Version 1.0.
|
||||||
|
# https://www.boost.org/LICENSE_1_0.txt
|
||||||
|
|
||||||
|
cmake_minimum_required(VERSION 3.5...3.16)
|
||||||
|
|
||||||
|
project(boost_algorithm VERSION "${BOOST_SUPERPROJECT_VERSION}" LANGUAGES CXX)
|
||||||
|
|
||||||
|
add_library(boost_algorithm INTERFACE)
|
||||||
|
add_library(Boost::algorithm ALIAS boost_algorithm)
|
||||||
|
|
||||||
|
target_include_directories(boost_algorithm INTERFACE include)
|
||||||
|
|
||||||
|
target_link_libraries(boost_algorithm
|
||||||
|
INTERFACE
|
||||||
|
Boost::array
|
||||||
|
Boost::assert
|
||||||
|
Boost::bind
|
||||||
|
Boost::concept_check
|
||||||
|
Boost::config
|
||||||
|
Boost::core
|
||||||
|
Boost::exception
|
||||||
|
Boost::function
|
||||||
|
Boost::iterator
|
||||||
|
Boost::mpl
|
||||||
|
Boost::range
|
||||||
|
Boost::regex
|
||||||
|
Boost::static_assert
|
||||||
|
Boost::throw_exception
|
||||||
|
Boost::tuple
|
||||||
|
Boost::type_traits
|
||||||
|
Boost::unordered
|
||||||
|
)
|
||||||
|
|
||||||
|
if(BUILD_TESTING AND EXISTS "${CMAKE_CURRENT_SOURCE_DIR}/test/CMakeLists.txt")
|
||||||
|
|
||||||
|
add_subdirectory(test)
|
||||||
|
|
||||||
|
endif()
|
||||||
|
|
11
Jamfile
Normal file
11
Jamfile
Normal file
@ -0,0 +1,11 @@
|
|||||||
|
# Boost.Algorithm Library Jamfile
|
||||||
|
#
|
||||||
|
# Copyright (c) 2018 James E. King III
|
||||||
|
#
|
||||||
|
# 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)
|
||||||
|
|
||||||
|
# please order by name to ease maintenance
|
||||||
|
build-project example ;
|
||||||
|
build-project test ;
|
23
LICENSE
Normal file
23
LICENSE
Normal file
@ -0,0 +1,23 @@
|
|||||||
|
Boost Software License - Version 1.0 - August 17th, 2003
|
||||||
|
|
||||||
|
Permission is hereby granted, free of charge, to any person or organization
|
||||||
|
obtaining a copy of the software and accompanying documentation covered by
|
||||||
|
this license (the "Software") to use, reproduce, display, distribute,
|
||||||
|
execute, and transmit the Software, and to prepare derivative works of the
|
||||||
|
Software, and to permit third-parties to whom the Software is furnished to
|
||||||
|
do so, all subject to the following:
|
||||||
|
|
||||||
|
The copyright notices in the Software and this entire statement, including
|
||||||
|
the above license grant, this restriction and the following disclaimer,
|
||||||
|
must be included in all copies of the Software, in whole or in part, and
|
||||||
|
all derivative works of the Software, unless such copies or derivative
|
||||||
|
works are solely in the form of machine-executable object code generated by
|
||||||
|
a source language processor.
|
||||||
|
|
||||||
|
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||||||
|
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
||||||
|
FITNESS FOR A PARTICULAR PURPOSE, TITLE AND NON-INFRINGEMENT. IN NO EVENT
|
||||||
|
SHALL THE COPYRIGHT HOLDERS OR ANYONE DISTRIBUTING THE SOFTWARE BE LIABLE
|
||||||
|
FOR ANY DAMAGES OR OTHER LIABILITY, WHETHER IN CONTRACT, TORT OR OTHERWISE,
|
||||||
|
ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
|
||||||
|
DEALINGS IN THE SOFTWARE.
|
35
README.md
Normal file
35
README.md
Normal file
@ -0,0 +1,35 @@
|
|||||||
|
Algorithm, part of collection of the [Boost C++ Libraries](http://github.com/boostorg), is a collection of general purpose algorithms.
|
||||||
|
|
||||||
|
### License
|
||||||
|
|
||||||
|
Distributed under the [Boost Software License, Version 1.0](http://www.boost.org/LICENSE_1_0.txt).
|
||||||
|
|
||||||
|
### Properties
|
||||||
|
|
||||||
|
* C++03
|
||||||
|
* Header-only
|
||||||
|
|
||||||
|
### Build Status
|
||||||
|
|
||||||
|
Branch | Travis | Appveyor | Coverity Scan | codecov.io | Deps | Docs | Tests |
|
||||||
|
:-------------: | ------ | -------- | ------------- | ---------- | ---- | ---- | ----- |
|
||||||
|
[`master`](https://github.com/boostorg/algorithm/tree/master) | [](https://travis-ci.org/boostorg/algorithm) | [](https://ci.appveyor.com/project/USER/PROJECT/branch/master) | [](https://scan.coverity.com/projects/boostorg-algorithm) | [](https://codecov.io/gh/boostorg/algorithm/branch/master)| [](https://pdimov.github.io/boostdep-report/master/algorithm.html) | [](http://www.boost.org/doc/libs/master/doc/html/algorithm.html) | [](http://www.boost.org/development/tests/master/developer/algorithm.html)
|
||||||
|
[`develop`](https://github.com/boostorg/algorithm/tree/develop) | [](https://travis-ci.org/boostorg/algorithm) | [](https://ci.appveyor.com/project/USER/PROJECT/branch/develop) | [](https://scan.coverity.com/projects/boostorg-algorithm) | [](https://codecov.io/gh/boostorg/algorithm/branch/develop) | [](https://pdimov.github.io/boostdep-report/develop/algorithm.html) | [](http://www.boost.org/doc/libs/develop/doc/html/algorithm.html) | [](http://www.boost.org/development/tests/develop/developer/algorithm.html)
|
||||||
|
|
||||||
|
### Directories
|
||||||
|
|
||||||
|
| Name | Purpose |
|
||||||
|
| ----------- | ------------------------------ |
|
||||||
|
| `doc` | documentation |
|
||||||
|
| `example` | examples |
|
||||||
|
| `include` | headers |
|
||||||
|
| `test` | unit tests |
|
||||||
|
|
||||||
|
### More information
|
||||||
|
|
||||||
|
* [Ask questions](http://stackoverflow.com/questions/ask?tags=c%2B%2B,boost,boost-algorithm)
|
||||||
|
* [Report bugs](https://github.com/boostorg/algorithm/issues): Be sure to mention Boost version, platform and compiler you're using. A small compilable code sample to reproduce the problem is always good as well.
|
||||||
|
* Submit your patches as pull requests against **develop** branch. Note that by submitting patches you agree to license your modifications under the [Boost Software License, Version 1.0](http://www.boost.org/LICENSE_1_0.txt).
|
||||||
|
* Discussions about the library are held on the [Boost developers mailing list](http://www.boost.org/community/groups.html#main). Be sure to read the [discussion policy](http://www.boost.org/community/policy.html) before posting and add the `[algorithm]` tag at the beginning of the subject line.
|
||||||
|
|
||||||
|
|
183
appveyor.yml
183
appveyor.yml
@ -1,7 +1,24 @@
|
|||||||
# Copyright 2016 Peter Dimov
|
# Copyright 2016, 2017 Peter Dimov
|
||||||
|
# Copyright (C) 2017 - 2019 James E. King III
|
||||||
# Distributed under the Boost Software License, Version 1.0.
|
# Distributed under the Boost Software License, Version 1.0.
|
||||||
# (See accompanying file LICENSE_1_0.txt or copy at http://boost.org/LICENSE_1_0.txt)
|
# (See accompanying file LICENSE_1_0.txt or copy at http://boost.org/LICENSE_1_0.txt)
|
||||||
|
|
||||||
|
#
|
||||||
|
# Generic Appveyor build script for boostorg repositories
|
||||||
|
# See: https://github.com/boostorg/boost-ci/
|
||||||
|
#
|
||||||
|
# Instructions for customizing this script for your library:
|
||||||
|
#
|
||||||
|
# 1. Customize the compilers and language levels you want.
|
||||||
|
# 2. If you have more than include/, src/, test/, example/, examples/,
|
||||||
|
# benchmark/ or tools/ directories, set the environment variable DEPINST.
|
||||||
|
# For example if your build uses code in "bench/" and "fog/" directories:
|
||||||
|
# - DEPINST: --include bench --include fog
|
||||||
|
# 3. Enable pull request builds in your boostorg/<library> account.
|
||||||
|
#
|
||||||
|
# That's it - the script will do everything else for you.
|
||||||
|
#
|
||||||
|
|
||||||
version: 1.0.{build}-{branch}
|
version: 1.0.{build}-{branch}
|
||||||
|
|
||||||
shallow_clone: true
|
shallow_clone: true
|
||||||
@ -10,84 +27,104 @@ branches:
|
|||||||
only:
|
only:
|
||||||
- master
|
- master
|
||||||
- develop
|
- develop
|
||||||
|
- bugfix/*
|
||||||
|
- feature/*
|
||||||
|
- fix/*
|
||||||
|
- pr/*
|
||||||
|
|
||||||
platform:
|
matrix:
|
||||||
- x64
|
# Adding MAYFAIL to any matrix job allows it to fail but the build stays green:
|
||||||
|
allow_failures:
|
||||||
|
- MAYFAIL: true
|
||||||
|
|
||||||
environment:
|
environment:
|
||||||
|
global:
|
||||||
|
# see: http://www.boost.org/build/doc/html/bbv2/overview/invocation.html#bbv2.overview.invocation.properties
|
||||||
|
# to use the default for a given environment, comment it out; recommend you build debug and release however:
|
||||||
|
# on Windows it is important to exercise all the possibilities, especially shared vs static, however most
|
||||||
|
# libraries that care about this exercise it in their Jamfiles...
|
||||||
|
# B2_ADDRESS_MODEL: address-model=64,32
|
||||||
|
# B2_LINK: link=shared,static
|
||||||
|
# B2_THREADING: threading=multi,single
|
||||||
|
B2_VARIANT: variant=release,debug
|
||||||
|
|
||||||
matrix:
|
matrix:
|
||||||
- APPVEYOR_BUILD_WORKER_IMAGE: Visual Studio 2017
|
- FLAVOR: Visual Studio 2017 C++2a Strict
|
||||||
ARGS: --toolset=msvc-14.1 address-model=64
|
APPVEYOR_BUILD_WORKER_IMAGE: Visual Studio 2017
|
||||||
- APPVEYOR_BUILD_WORKER_IMAGE: Visual Studio 2017
|
B2_ADDRESS_MODEL: address-model=64
|
||||||
ARGS: --toolset=msvc-14.1 address-model=32
|
B2_CXXFLAGS: cxxflags=-permissive-
|
||||||
- APPVEYOR_BUILD_WORKER_IMAGE: Visual Studio 2017
|
B2_CXXSTD: latest # 2a
|
||||||
ARGS: --toolset=msvc-14.1 address-model=64 cxxflags=-std:c++latest cxxflags=-permissive-
|
B2_TOOLSET: msvc-14.1
|
||||||
- ARGS: --toolset=msvc-9.0 address-model=32
|
|
||||||
- ARGS: --toolset=msvc-10.0 address-model=32
|
- FLAVOR: Visual Studio 2017 C++17
|
||||||
- ARGS: --toolset=msvc-11.0 address-model=32
|
APPVEYOR_BUILD_WORKER_IMAGE: Visual Studio 2017
|
||||||
- ARGS: --toolset=msvc-12.0 address-model=32
|
B2_ADDRESS_MODEL: address-model=64
|
||||||
- ARGS: --toolset=msvc-14.0 address-model=32
|
B2_CXXSTD: 17
|
||||||
- ARGS: --toolset=msvc-12.0 address-model=64
|
B2_TOOLSET: msvc-14.1
|
||||||
- ARGS: --toolset=msvc-14.0 address-model=64
|
|
||||||
- ARGS: --toolset=msvc-14.0 address-model=64 cxxflags=-std:c++latest
|
- FLAVOR: Visual Studio 2017 C++14 (Default)
|
||||||
- ARGS: --toolset=gcc address-model=64
|
APPVEYOR_BUILD_WORKER_IMAGE: Visual Studio 2017
|
||||||
CXXSTD: 03,11,14,1z
|
B2_ADDRESS_MODEL: address-model=64,32
|
||||||
PATH: C:\mingw-w64\x86_64-6.3.0-posix-seh-rt_v5-rev1\mingw64\bin;%PATH%
|
B2_TOOLSET: msvc-14.1
|
||||||
- ARGS: --toolset=gcc address-model=64
|
|
||||||
CXXSTD: 03,11,14,1z
|
- FLAVOR: Visual Studio 2015 C++14 (Default)
|
||||||
PATH: C:\mingw-w64\x86_64-7.2.0-posix-seh-rt_v5-rev1\mingw64\bin;%PATH%
|
APPVEYOR_BUILD_WORKER_IMAGE: Visual Studio 2015
|
||||||
- ARGS: --toolset=gcc address-model=32 linkflags=-Wl,-allow-multiple-definition
|
B2_ADDRESS_MODEL: address-model=64,32
|
||||||
CXXSTD: 03,11,14,1z
|
B2_TOOLSET: msvc-14.0
|
||||||
PATH: C:\MinGW\bin;%PATH%
|
|
||||||
- ARGS: --toolset=gcc address-model=64
|
- FLAVOR: Visual Studio 2010, 2012, 2013
|
||||||
CXXSTD: 03,11,14,1z
|
APPVEYOR_BUILD_WORKER_IMAGE: Visual Studio 2015
|
||||||
PATH: C:\cygwin64\bin;%PATH%
|
B2_TOOLSET: msvc-10.0,msvc-11.0,msvc-12.0
|
||||||
- ARGS: --toolset=gcc address-model=32
|
|
||||||
CXXSTD: 03,11,14,1z
|
- FLAVOR: cygwin (32-bit)
|
||||||
PATH: C:\cygwin\bin;%PATH%
|
APPVEYOR_BUILD_WORKER_IMAGE: Visual Studio 2017
|
||||||
|
ADDPATH: C:\cygwin\bin;
|
||||||
|
B2_ADDRESS_MODEL: address-model=32
|
||||||
|
B2_CXXSTD: 03,11
|
||||||
|
# https://github.com/boostorg/test/issues/144
|
||||||
|
B2_DEFINES: define=_POSIX_C_SOURCE=200112L
|
||||||
|
B2_THREADING: threadapi=pthread
|
||||||
|
B2_TOOLSET: gcc
|
||||||
|
|
||||||
|
- FLAVOR: cygwin (64-bit)
|
||||||
|
APPVEYOR_BUILD_WORKER_IMAGE: Visual Studio 2017
|
||||||
|
ADDPATH: C:\cygwin64\bin;
|
||||||
|
B2_ADDRESS_MODEL: address-model=64
|
||||||
|
B2_CXXSTD: 11,17
|
||||||
|
# https://github.com/boostorg/test/issues/144
|
||||||
|
B2_DEFINES: define=_POSIX_C_SOURCE=200112L define=__USE_ISOC99
|
||||||
|
B2_THREADING: threadapi=pthread
|
||||||
|
B2_TOOLSET: gcc
|
||||||
|
|
||||||
|
- FLAVOR: mingw32
|
||||||
|
APPVEYOR_BUILD_WORKER_IMAGE: Visual Studio 2017
|
||||||
|
ARCH: i686
|
||||||
|
B2_ADDRESS_MODEL: address-model=32
|
||||||
|
B2_CXXSTD: 03,11
|
||||||
|
SCRIPT: ci\appveyor\mingw.bat
|
||||||
|
|
||||||
|
- FLAVOR: mingw64
|
||||||
|
APPVEYOR_BUILD_WORKER_IMAGE: Visual Studio 2017
|
||||||
|
ARCH: x86_64
|
||||||
|
B2_ADDRESS_MODEL: address-model=64
|
||||||
|
B2_CXXSTD: 11,17
|
||||||
|
B2_DEFINES: define=__USE_ISOC99
|
||||||
|
SCRIPT: ci\appveyor\mingw.bat
|
||||||
|
|
||||||
install:
|
install:
|
||||||
- cd ..
|
- set SELF=%APPVEYOR_PROJECT_NAME:-=_%
|
||||||
- git clone -b %APPVEYOR_REPO_BRANCH% --depth 1 https://github.com/boostorg/boost.git boost-root
|
- git clone https://github.com/boostorg/boost-ci.git C:\boost-ci
|
||||||
- cd boost-root
|
- xcopy /s /e /q /i C:\boost-ci\ci .\ci
|
||||||
- xcopy /s /e /q %APPVEYOR_BUILD_FOLDER% libs\algorithm
|
- ci\appveyor\install.bat
|
||||||
- git submodule update --init tools/build
|
|
||||||
- git submodule update --init libs/config
|
|
||||||
- git submodule update --init libs/predef
|
|
||||||
- git submodule update --init libs/core
|
|
||||||
- git submodule update --init libs/detail
|
|
||||||
- git submodule update --init libs/range
|
|
||||||
- git submodule update --init libs/assert
|
|
||||||
- git submodule update --init libs/array
|
|
||||||
- git submodule update --init libs/type_traits
|
|
||||||
- git submodule update --init libs/static_assert
|
|
||||||
- git submodule update --init libs/iterator
|
|
||||||
- git submodule update --init libs/preprocessor
|
|
||||||
- git submodule update --init libs/mpl
|
|
||||||
- git submodule update --init libs/smart_ptr
|
|
||||||
- git submodule update --init libs/callable_traits
|
|
||||||
- git submodule update --init libs/type_index
|
|
||||||
- git submodule update --init libs/exception
|
|
||||||
- git submodule update --init libs/throw_exception
|
|
||||||
- git submodule update --init libs/utility
|
|
||||||
- git submodule update --init libs/bind
|
|
||||||
- git submodule update --init libs/ratio
|
|
||||||
- git submodule update --init libs/function
|
|
||||||
- git submodule update --init libs/integer
|
|
||||||
- git submodule update --init libs/numeric
|
|
||||||
- git submodule update --init libs/move
|
|
||||||
- git submodule update --init libs/container_hash
|
|
||||||
- git submodule update --init libs/io
|
|
||||||
- git submodule update --init libs/concept_check
|
|
||||||
- git submodule update --init libs/test
|
|
||||||
- git submodule update --init libs/timer
|
|
||||||
- git submodule update --init libs/chrono
|
|
||||||
- git submodule update --init libs/system
|
|
||||||
- bootstrap
|
|
||||||
- b2 headers
|
|
||||||
|
|
||||||
build: off
|
build: off
|
||||||
|
|
||||||
test_script:
|
test_script:
|
||||||
- cd libs\config\test
|
- set SELF=%APPVEYOR_PROJECT_NAME:-=_%
|
||||||
- ..\..\..\b2 -j3 %ARGS% cxxstd=%CXXSTD%
|
- PATH=%ADDPATH%%PATH%
|
||||||
|
# The definition of B2_TOOLCXX omits B2_CXXSTD= if it was not defined above
|
||||||
|
- IF NOT DEFINED B2_CXXSTD (SET B2_TOOLCXX=toolset=%B2_TOOLSET%) ELSE (SET B2_TOOLCXX=toolset=%B2_TOOLSET% cxxstd=%B2_CXXSTD%)
|
||||||
|
# Echo the complete build command to the build log
|
||||||
|
- IF NOT DEFINED SCRIPT (ECHO b2 libs/%SELF:\=/% %B2_TOOLCXX% %B2_CXXFLAGS% %B2_DEFINES% %B2_THREADING% %B2_ADDRESS_MODEL% %B2_LINK% %B2_THREADING% %B2_VARIANT% -j3)
|
||||||
|
# Now go build...
|
||||||
|
- IF DEFINED SCRIPT (call libs\%SELF%\%SCRIPT%) ELSE (b2 libs/%SELF:\=/% %B2_TOOLCXX% %B2_CXXFLAGS% %B2_DEFINES% %B2_THREADING% %B2_ADDRESS_MODEL% %B2_LINK% %B2_THREADING% %B2_VARIANT% -j3)
|
||||||
|
@ -106,11 +106,50 @@ Generate an increasing series
|
|||||||
Apply a functor to the elements of a sequence
|
Apply a functor to the elements of a sequence
|
||||||
[endsect:for_each_n]
|
[endsect:for_each_n]
|
||||||
|
|
||||||
|
[section:transform_inclusive_scan transform_inclusive_scan]
|
||||||
|
[*[^[link boost.algorithm.transform_inclusive_scan transform_inclusive_scan] ] ]
|
||||||
|
Transform each element in a range then combine adjacent elements to create an output range. Inclusive scaning means that the nth input is present in the nth output.
|
||||||
|
[endsect:transform_inclusive_scan]
|
||||||
|
|
||||||
|
[section:transform_exclusive_scan transform_exclusive_scan]
|
||||||
|
[*[^[link boost.algorithm.transform_exclusive_scan transform_exclusive_scan] ] ]
|
||||||
|
Transform each element in a range then combine adjacent elements to create an output range. Exclusive scanning means that the nth input is not present in the nth output.
|
||||||
|
[endsect:transform_exclusive_scan]
|
||||||
|
|
||||||
[endsect:CXX17_inner_algorithms]
|
[endsect:CXX17_inner_algorithms]
|
||||||
|
|
||||||
[endsect:CXX17]
|
[endsect:CXX17]
|
||||||
|
|
||||||
|
|
||||||
|
[section:Copy Variations on Copy]
|
||||||
|
[section:variations_on_copy]
|
||||||
|
|
||||||
|
[section:copy_until copy_until ]
|
||||||
|
[*[^[link header.boost.algorithm.cxx11.copy_if_hpp copy_until] ] ]
|
||||||
|
Copy all the elements from the start of the input range to the output range until the predicate is satisfied
|
||||||
|
[endsect:copy_until]
|
||||||
|
|
||||||
|
[section:copy_while copy_while ]
|
||||||
|
[*[^[link header.boost.algorithm.cxx11.copy_if_hpp copy_while] ] ]
|
||||||
|
Copy all the elements from the start of the input range to the output range while the predicate is satisfied
|
||||||
|
[endsect:copy_while]
|
||||||
|
|
||||||
|
[section:copy_if_until copy_if_until ]
|
||||||
|
[*[^[link header.boost.algorithm.cxx11.copy_if_hpp copy_if_until ] ]
|
||||||
|
Copy all elements that satisfy the element predicate from the start of the input range to the output range until the termination predicate is satisfied
|
||||||
|
|
||||||
|
[endsect:copy_if_until]
|
||||||
|
|
||||||
|
[section:copy_if_while copy_if_while ]
|
||||||
|
[*[^[link header.boost.algorithm.cxx11.copy_if_hpp copy_if_while ] ]
|
||||||
|
Copy all elements that satisfy the element predicate from the start of the input range to the output range while the termination predicate is satisfied
|
||||||
|
|
||||||
|
[endsect:copy_if_while]
|
||||||
|
|
||||||
|
[endsect:variations_on_copy]
|
||||||
|
[endsect:Copy]
|
||||||
|
|
||||||
|
|
||||||
[section:Misc Other Algorithms]
|
[section:Misc Other Algorithms]
|
||||||
|
|
||||||
[section:misc_inner_algorithms]
|
[section:misc_inner_algorithms]
|
||||||
@ -204,16 +243,6 @@ See below
|
|||||||
|
|
||||||
[include apply_permutation.qbk]
|
[include apply_permutation.qbk]
|
||||||
|
|
||||||
[section:copy_until copy_until ]
|
|
||||||
[*[^[link header.boost.algorithm.cxx11.copy_if_hpp copy_until] ] ]
|
|
||||||
Copy all the elements at the start of the input range that do not satisfy the predicate to the output range
|
|
||||||
[endsect:copy_until]
|
|
||||||
|
|
||||||
[section:copy_while copy_while ]
|
|
||||||
[*[^[link header.boost.algorithm.cxx11.copy_if_hpp copy_while] ] ]
|
|
||||||
Copy all the elements at the start of the input range that satisfy the predicate to the output range
|
|
||||||
[endsect:copy_while]
|
|
||||||
|
|
||||||
[section:iota_n iota_n ]
|
[section:iota_n iota_n ]
|
||||||
[*[^[link boost.algorithm.iota_n iota_n] ] ]
|
[*[^[link boost.algorithm.iota_n iota_n] ] ]
|
||||||
Write a sequence of n increasing values to an output iterator
|
Write a sequence of n increasing values to an output iterator
|
||||||
@ -234,8 +263,6 @@ Raise a value to an integral power ([^constexpr] since C++14)
|
|||||||
* [*[^[link header.boost.algorithm.cxx17.exclusive_scan_hpp exclusive_scan] ] ]
|
* [*[^[link header.boost.algorithm.cxx17.exclusive_scan_hpp exclusive_scan] ] ]
|
||||||
* [*[^[link header.boost.algorithm.cxx17.inclusive_scan_hpp inclusive_scan] ] ]
|
* [*[^[link header.boost.algorithm.cxx17.inclusive_scan_hpp inclusive_scan] ] ]
|
||||||
* [*[^[link header.boost.algorithm.cxx17.reduce_hpp reduce] ] ]
|
* [*[^[link header.boost.algorithm.cxx17.reduce_hpp reduce] ] ]
|
||||||
* [*[^[link header.boost.algorithm.cxx17.transform_exclusive_scan_hpp transform_exclusive_scan] ] ]
|
|
||||||
* [*[^[link header.boost.algorithm.cxx17.transform_inclusive_scan_hpp transform_inclusive_scan] ] ]
|
|
||||||
* [*[^[link header.boost.algorithm.cxx17.transform_reduce_hpp transform_reduce] ] ]
|
* [*[^[link header.boost.algorithm.cxx17.transform_reduce_hpp transform_reduce] ] ]
|
||||||
|
|
||||||
[endsect:not_yet_documented_cxx17_algos]
|
[endsect:not_yet_documented_cxx17_algos]
|
||||||
|
@ -19,7 +19,6 @@
|
|||||||
#define BOOST_ALGORITHM_APPLY_PERMUTATION_HPP
|
#define BOOST_ALGORITHM_APPLY_PERMUTATION_HPP
|
||||||
|
|
||||||
#include <algorithm>
|
#include <algorithm>
|
||||||
#include <type_traits>
|
|
||||||
|
|
||||||
#include <boost/config.hpp>
|
#include <boost/config.hpp>
|
||||||
#include <boost/range/begin.hpp>
|
#include <boost/range/begin.hpp>
|
||||||
|
@ -26,14 +26,14 @@
|
|||||||
#include <boost/config.hpp>
|
#include <boost/config.hpp>
|
||||||
#include <boost/range/begin.hpp>
|
#include <boost/range/begin.hpp>
|
||||||
#include <boost/range/end.hpp>
|
#include <boost/range/end.hpp>
|
||||||
#include <boost/mpl/identity.hpp> // for identity
|
#include <boost/type_traits/type_identity.hpp> // for boost::type_identity
|
||||||
#include <boost/utility/enable_if.hpp> // for boost::disable_if
|
#include <boost/utility/enable_if.hpp> // for boost::disable_if
|
||||||
|
|
||||||
namespace boost { namespace algorithm {
|
namespace boost { namespace algorithm {
|
||||||
|
|
||||||
/// \fn clamp ( T const& val,
|
/// \fn clamp ( T const& val,
|
||||||
/// typename boost::mpl::identity<T>::type const & lo,
|
/// typename boost::type_identity<T>::type const & lo,
|
||||||
/// typename boost::mpl::identity<T>::type const & hi, Pred p )
|
/// typename boost::type_identity<T>::type const & hi, Pred p )
|
||||||
/// \return the value "val" brought into the range [ lo, hi ]
|
/// \return the value "val" brought into the range [ lo, hi ]
|
||||||
/// using the comparison predicate p.
|
/// using the comparison predicate p.
|
||||||
/// If p ( val, lo ) return lo.
|
/// If p ( val, lo ) return lo.
|
||||||
@ -48,8 +48,8 @@ namespace boost { namespace algorithm {
|
|||||||
///
|
///
|
||||||
template<typename T, typename Pred>
|
template<typename T, typename Pred>
|
||||||
BOOST_CXX14_CONSTEXPR T const & clamp ( T const& val,
|
BOOST_CXX14_CONSTEXPR T const & clamp ( T const& val,
|
||||||
typename boost::mpl::identity<T>::type const & lo,
|
typename boost::type_identity<T>::type const & lo,
|
||||||
typename boost::mpl::identity<T>::type const & hi, Pred p )
|
typename boost::type_identity<T>::type const & hi, Pred p )
|
||||||
{
|
{
|
||||||
// assert ( !p ( hi, lo )); // Can't assert p ( lo, hi ) b/c they might be equal
|
// assert ( !p ( hi, lo )); // Can't assert p ( lo, hi ) b/c they might be equal
|
||||||
return p ( val, lo ) ? lo : p ( hi, val ) ? hi : val;
|
return p ( val, lo ) ? lo : p ( hi, val ) ? hi : val;
|
||||||
@ -57,8 +57,8 @@ namespace boost { namespace algorithm {
|
|||||||
|
|
||||||
|
|
||||||
/// \fn clamp ( T const& val,
|
/// \fn clamp ( T const& val,
|
||||||
/// typename boost::mpl::identity<T>::type const & lo,
|
/// typename boost::identity<T>::type const & lo,
|
||||||
/// typename boost::mpl::identity<T>::type const & hi )
|
/// typename boost::identity<T>::type const & hi )
|
||||||
/// \return the value "val" brought into the range [ lo, hi ].
|
/// \return the value "val" brought into the range [ lo, hi ].
|
||||||
/// If the value is less than lo, return lo.
|
/// If the value is less than lo, return lo.
|
||||||
/// If the value is greater than "hi", return hi.
|
/// If the value is greater than "hi", return hi.
|
||||||
@ -70,8 +70,8 @@ namespace boost { namespace algorithm {
|
|||||||
///
|
///
|
||||||
template<typename T>
|
template<typename T>
|
||||||
BOOST_CXX14_CONSTEXPR T const& clamp ( const T& val,
|
BOOST_CXX14_CONSTEXPR T const& clamp ( const T& val,
|
||||||
typename boost::mpl::identity<T>::type const & lo,
|
typename boost::type_identity<T>::type const & lo,
|
||||||
typename boost::mpl::identity<T>::type const & hi )
|
typename boost::type_identity<T>::type const & hi )
|
||||||
{
|
{
|
||||||
return boost::algorithm::clamp ( val, lo, hi, std::less<T>());
|
return boost::algorithm::clamp ( val, lo, hi, std::less<T>());
|
||||||
}
|
}
|
||||||
|
@ -126,6 +126,86 @@ copy_until ( const Range &r, OutputIterator result, Predicate p )
|
|||||||
return boost::algorithm::copy_until (boost::begin (r), boost::end(r), result, p);
|
return boost::algorithm::copy_until (boost::begin (r), boost::end(r), result, p);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// \fn copy_if_while ( InputIterator first, InputIterator last, OutputIterator result, CopyPredicate copy_pred, TerminatePred term_pred )
|
||||||
|
/// \brief Copies all the elements from the input range that satisfy the
|
||||||
|
/// copy predicate to the output range while the termination predicate is
|
||||||
|
/// satisfied.
|
||||||
|
/// \return The updated output iterator
|
||||||
|
///
|
||||||
|
/// \param first The start of the input sequence
|
||||||
|
/// \param last One past the end of the input sequence
|
||||||
|
/// \param result An output iterator to write the results into
|
||||||
|
/// \param copy_pred A predicate for testing whether to the current element
|
||||||
|
/// \param term_pred A predicate for testing whether to end the copy operation
|
||||||
|
template<typename InputIterator, typename OutputIterator, typename CopyPredicate, typename TerminatePred>
|
||||||
|
BOOST_CXX14_CONSTEXPR std::pair<InputIterator, OutputIterator>
|
||||||
|
copy_if_while ( InputIterator first, InputIterator last, OutputIterator result, CopyPredicate copy_pred, TerminatePred term_pred)
|
||||||
|
{
|
||||||
|
for ( ; first != last && term_pred(*first); ++first ) {
|
||||||
|
if (copy_pred(*first)) {
|
||||||
|
*result++ = *first;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return std::make_pair(first, result);
|
||||||
|
}
|
||||||
|
|
||||||
|
/// \fn copy_if_while ( const Range& r, OutputIterator result, CopyPredicate copy_pred, TerminatePred term_pred )
|
||||||
|
/// \brief Copies all the elements from the input range that satisfy the
|
||||||
|
/// copy predicate to the output range while the termination predicate is
|
||||||
|
/// satisfied.
|
||||||
|
/// \return The updated output iterator
|
||||||
|
///
|
||||||
|
/// \param r The input range
|
||||||
|
/// \param result An output iterator to write the results into
|
||||||
|
/// \param copy_pred A predicate for testing whether to the current element
|
||||||
|
/// \param term_pred A predicate for testing whether to end the copy operation
|
||||||
|
template<typename Range, typename OutputIterator, typename CopyPredicate, typename TerminatePred>
|
||||||
|
BOOST_CXX14_CONSTEXPR std::pair<typename boost::range_iterator<const Range>::type, OutputIterator>
|
||||||
|
copy_if_while ( const Range& r, OutputIterator result, CopyPredicate copy_pred, TerminatePred term_pred)
|
||||||
|
{
|
||||||
|
return boost::algorithm::copy_if_while(boost::begin(r), boost::end(r), result, copy_pred, term_pred);
|
||||||
|
}
|
||||||
|
|
||||||
|
/// \fn copy_if_until ( InputIterator first, InputIterator last, OutputIterator result, CopyPredicate copy_pred, TerminatePred term_pred )
|
||||||
|
/// \brief Copies all the elements from the input range that satisfy the
|
||||||
|
/// copy predicate to the output range until the termination predicate is
|
||||||
|
/// satisfied.
|
||||||
|
/// \return The updated output iterator
|
||||||
|
///
|
||||||
|
/// \param first The start of the input sequence
|
||||||
|
/// \param last One past the end of the input sequence
|
||||||
|
/// \param result An output iterator to write the results into
|
||||||
|
/// \param copy_pred A predicate for testing whether to the current element
|
||||||
|
/// \param term_pred A predicate for testing whether to end the copy operation
|
||||||
|
template<typename InputIterator, typename OutputIterator, typename CopyPredicate, typename TerminatePred>
|
||||||
|
BOOST_CXX14_CONSTEXPR std::pair<InputIterator, OutputIterator>
|
||||||
|
copy_if_until ( InputIterator first, InputIterator last, OutputIterator result, CopyPredicate copy_pred, TerminatePred term_pred)
|
||||||
|
{
|
||||||
|
for ( ; first != last && !term_pred(*first); ++first ) {
|
||||||
|
if (copy_pred(*first)) {
|
||||||
|
*result++ = *first;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return std::make_pair(first, result);
|
||||||
|
}
|
||||||
|
|
||||||
|
/// \fn copy_if_until ( const Range& r, OutputIterator result, CopyPredicate copy_pred, TerminatePred term_pred )
|
||||||
|
/// \brief Copies all the elements from the input range that satisfy the
|
||||||
|
/// copy predicate to the output range until the termination predicate is
|
||||||
|
/// satisfied.
|
||||||
|
/// \return The updated output iterator
|
||||||
|
///
|
||||||
|
/// \param r The input range
|
||||||
|
/// \param result An output iterator to write the results into
|
||||||
|
/// \param copy_pred A predicate for testing whether to the current element
|
||||||
|
/// \param term_pred A predicate for testing whether to end the copy operation
|
||||||
|
template<typename Range, typename OutputIterator, typename CopyPredicate, typename TerminatePred>
|
||||||
|
BOOST_CXX14_CONSTEXPR std::pair<typename boost::range_iterator<const Range>::type, OutputIterator>
|
||||||
|
copy_if_until ( const Range& r, OutputIterator result, CopyPredicate copy_pred, TerminatePred term_pred)
|
||||||
|
{
|
||||||
|
return boost::algorithm::copy_if_until(boost::begin(r), boost::end(r), result, copy_pred, term_pred);
|
||||||
|
}
|
||||||
|
|
||||||
}} // namespace boost and algorithm
|
}} // namespace boost and algorithm
|
||||||
|
|
||||||
#endif // BOOST_ALGORITHM_COPY_IF_HPP
|
#endif // BOOST_ALGORITHM_COPY_IF_HPP
|
||||||
|
@ -22,7 +22,7 @@
|
|||||||
|
|
||||||
#include <boost/utility/enable_if.hpp>
|
#include <boost/utility/enable_if.hpp>
|
||||||
#include <boost/type_traits/is_same.hpp>
|
#include <boost/type_traits/is_same.hpp>
|
||||||
#include <boost/mpl/identity.hpp>
|
#include <boost/type_traits/type_identity.hpp> // for boost::type_identity
|
||||||
|
|
||||||
namespace boost { namespace algorithm {
|
namespace boost { namespace algorithm {
|
||||||
|
|
||||||
@ -127,7 +127,7 @@ namespace boost { namespace algorithm {
|
|||||||
/// \param p A binary predicate that returns true if two elements are ordered.
|
/// \param p A binary predicate that returns true if two elements are ordered.
|
||||||
///
|
///
|
||||||
template <typename R, typename Pred>
|
template <typename R, typename Pred>
|
||||||
BOOST_CXX14_CONSTEXPR typename boost::lazy_disable_if_c< boost::is_same<R, Pred>::value, boost::mpl::identity<bool> >::type
|
BOOST_CXX14_CONSTEXPR typename boost::lazy_disable_if_c< boost::is_same<R, Pred>::value, boost::type_identity<bool> >::type
|
||||||
is_sorted ( const R &range, Pred p )
|
is_sorted ( const R &range, Pred p )
|
||||||
{
|
{
|
||||||
return boost::algorithm::is_sorted ( boost::begin ( range ), boost::end ( range ), p );
|
return boost::algorithm::is_sorted ( boost::begin ( range ), boost::end ( range ), p );
|
||||||
|
@ -9,8 +9,8 @@
|
|||||||
/// \brief Combine the (transformed) elements of a sequence (or two) into a single value.
|
/// \brief Combine the (transformed) elements of a sequence (or two) into a single value.
|
||||||
/// \author Marshall Clow
|
/// \author Marshall Clow
|
||||||
|
|
||||||
#ifndef BOOST_ALGORITHM_TRANSFORM_REDUCE_HPP
|
#ifndef BOOST_ALGORITHM_INCLUSIVE_SCAN_HPP
|
||||||
#define BOOST_ALGORITHM_TRANSFORM_REDUCE_HPP
|
#define BOOST_ALGORITHM_INCLUSIVE_SCAN_HPP
|
||||||
|
|
||||||
#include <functional> // for std::plus
|
#include <functional> // for std::plus
|
||||||
#include <iterator> // for std::iterator_traits
|
#include <iterator> // for std::iterator_traits
|
||||||
@ -58,4 +58,4 @@ OutputIterator inclusive_scan(InputIterator first, InputIterator last,
|
|||||||
|
|
||||||
}} // namespace boost and algorithm
|
}} // namespace boost and algorithm
|
||||||
|
|
||||||
#endif // BOOST_ALGORITHM_TRANSFORM_REDUCE_HPP
|
#endif // BOOST_ALGORITHM_INCLUSIVE_SCAN_HPP
|
||||||
|
@ -22,6 +22,21 @@
|
|||||||
|
|
||||||
namespace boost { namespace algorithm {
|
namespace boost { namespace algorithm {
|
||||||
|
|
||||||
|
/// \fn transform_exclusive_scan ( InputIterator first, InputIterator last, OutputIterator result, BinaryOperation bOp, UnaryOperation uOp, T init )
|
||||||
|
/// \brief Transforms elements from the input range with uOp and then combines
|
||||||
|
/// those transformed elements with bOp such that the n-1th element and the nth
|
||||||
|
/// element are combined. Exclusivity means that the nth element is not
|
||||||
|
/// included in the nth combination.
|
||||||
|
/// \return The updated output iterator
|
||||||
|
///
|
||||||
|
/// \param first The start of the input sequence
|
||||||
|
/// \param last The end of the input sequence
|
||||||
|
/// \param result The output iterator to write the results into
|
||||||
|
/// \param bOp The operation for combining transformed input elements
|
||||||
|
/// \param uOp The operation for transforming input elements
|
||||||
|
/// \param init The initial value
|
||||||
|
///
|
||||||
|
/// \note This function is part of the C++17 standard library
|
||||||
template<class InputIterator, class OutputIterator, class T,
|
template<class InputIterator, class OutputIterator, class T,
|
||||||
class BinaryOperation, class UnaryOperation>
|
class BinaryOperation, class UnaryOperation>
|
||||||
OutputIterator transform_exclusive_scan(InputIterator first, InputIterator last,
|
OutputIterator transform_exclusive_scan(InputIterator first, InputIterator last,
|
||||||
|
@ -22,6 +22,21 @@
|
|||||||
|
|
||||||
namespace boost { namespace algorithm {
|
namespace boost { namespace algorithm {
|
||||||
|
|
||||||
|
/// \fn transform_inclusive_scan ( InputIterator first, InputIterator last, OutputIterator result, BinaryOperation bOp, UnaryOperation uOp, T init )
|
||||||
|
/// \brief Transforms elements from the input range with uOp and then combines
|
||||||
|
/// those transformed elements with bOp such that the n-1th element and the nth
|
||||||
|
/// element are combined. Inclusivity means that the nth element is included in
|
||||||
|
/// the nth combination.
|
||||||
|
/// \return The updated output iterator
|
||||||
|
///
|
||||||
|
/// \param first The start of the input sequence
|
||||||
|
/// \param last The end of the input sequence
|
||||||
|
/// \param result The output iterator to write the results into
|
||||||
|
/// \param bOp The operation for combining transformed input elements
|
||||||
|
/// \param uOp The operation for transforming input elements
|
||||||
|
/// \param init The initial value
|
||||||
|
///
|
||||||
|
/// \note This function is part of the C++17 standard library
|
||||||
template<class InputIterator, class OutputIterator,
|
template<class InputIterator, class OutputIterator,
|
||||||
class BinaryOperation, class UnaryOperation, class T>
|
class BinaryOperation, class UnaryOperation, class T>
|
||||||
OutputIterator transform_inclusive_scan(InputIterator first, InputIterator last,
|
OutputIterator transform_inclusive_scan(InputIterator first, InputIterator last,
|
||||||
@ -37,6 +52,20 @@ OutputIterator transform_inclusive_scan(InputIterator first, InputIterator last,
|
|||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// \fn transform_inclusive_scan ( InputIterator first, InputIterator last, OutputIterator result, BinaryOperation bOp, UnaryOperation uOp, T init )
|
||||||
|
/// \brief Transforms elements from the input range with uOp and then combines
|
||||||
|
/// those transformed elements with bOp such that the n-1th element and the nth
|
||||||
|
/// element are combined. Inclusivity means that the nth element is included in
|
||||||
|
/// the nth combination. The first value will be used as the init.
|
||||||
|
/// \return The updated output iterator
|
||||||
|
///
|
||||||
|
/// \param first The start of the input sequence
|
||||||
|
/// \param last The end of the input sequence
|
||||||
|
/// \param result The output iterator to write the results into
|
||||||
|
/// \param bOp The operation for combining transformed input elements
|
||||||
|
/// \param uOp The operation for transforming input elements
|
||||||
|
///
|
||||||
|
/// \note This function is part of the C++17 standard library
|
||||||
template<class InputIterator, class OutputIterator,
|
template<class InputIterator, class OutputIterator,
|
||||||
class BinaryOperation, class UnaryOperation>
|
class BinaryOperation, class UnaryOperation>
|
||||||
OutputIterator transform_inclusive_scan(InputIterator first, InputIterator last,
|
OutputIterator transform_inclusive_scan(InputIterator first, InputIterator last,
|
||||||
|
@ -48,9 +48,9 @@ namespace boost { namespace algorithm {
|
|||||||
\brief Thrown when the input sequence unexpectedly ends
|
\brief Thrown when the input sequence unexpectedly ends
|
||||||
|
|
||||||
*/
|
*/
|
||||||
struct hex_decode_error : virtual boost::exception, virtual std::exception {};
|
struct BOOST_SYMBOL_VISIBLE hex_decode_error : virtual boost::exception, virtual std::exception {};
|
||||||
struct not_enough_input : virtual hex_decode_error {};
|
struct BOOST_SYMBOL_VISIBLE not_enough_input : virtual hex_decode_error {};
|
||||||
struct non_hex_input : virtual hex_decode_error {};
|
struct BOOST_SYMBOL_VISIBLE non_hex_input : virtual hex_decode_error {};
|
||||||
typedef boost::error_info<struct bad_char_,char> bad_char;
|
typedef boost::error_info<struct bad_char_,char> bad_char;
|
||||||
|
|
||||||
namespace detail {
|
namespace detail {
|
||||||
|
72
include/boost/algorithm/is_clamped.hpp
Normal file
72
include/boost/algorithm/is_clamped.hpp
Normal file
@ -0,0 +1,72 @@
|
|||||||
|
/*
|
||||||
|
Copyright (c) Ivan Matek, Marshall Clow 2021.
|
||||||
|
|
||||||
|
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)
|
||||||
|
|
||||||
|
*/
|
||||||
|
|
||||||
|
/// \file is_clamped.hpp
|
||||||
|
/// \brief IsClamped algorithm
|
||||||
|
/// \authors Ivan Matek, Marshall Clow
|
||||||
|
///
|
||||||
|
|
||||||
|
#ifndef BOOST_ALGORITHM_IS_CLAMPED_HPP
|
||||||
|
#define BOOST_ALGORITHM_IS_CLAMPED_HPP
|
||||||
|
|
||||||
|
#include <functional> // for std::less
|
||||||
|
#include <cassert>
|
||||||
|
|
||||||
|
#include <boost/type_traits/type_identity.hpp> // for boost::type_identity
|
||||||
|
|
||||||
|
namespace boost { namespace algorithm {
|
||||||
|
|
||||||
|
/// \fn is_clamped ( T const& val,
|
||||||
|
/// typename boost::type_identity<T>::type const & lo,
|
||||||
|
/// typename boost::type_identity<T>::type const & hi, Pred p )
|
||||||
|
/// \returns true if value "val" is in the range [ lo, hi ]
|
||||||
|
/// using the comparison predicate p.
|
||||||
|
/// If p ( val, lo ) return false.
|
||||||
|
/// If p ( hi, val ) return false.
|
||||||
|
/// Otherwise, returns true.
|
||||||
|
///
|
||||||
|
/// \param val The value to be checked
|
||||||
|
/// \param lo The lower bound of the range
|
||||||
|
/// \param hi The upper bound of the range
|
||||||
|
/// \param p A predicate to use to compare the values.
|
||||||
|
/// p ( a, b ) returns a boolean.
|
||||||
|
///
|
||||||
|
template <typename T, typename Pred>
|
||||||
|
BOOST_CXX14_CONSTEXPR bool is_clamped(
|
||||||
|
T const& val, typename boost::type_identity<T>::type const& lo,
|
||||||
|
typename boost::type_identity<T>::type const& hi, Pred p) {
|
||||||
|
// assert ( !p ( hi, lo )); // Can't assert p ( lo, hi ) b/c they
|
||||||
|
// might be equal
|
||||||
|
return p(val, lo) ? false : p(hi, val) ? false : true;
|
||||||
|
}
|
||||||
|
|
||||||
|
/// \fn is_clamped ( T const& val,
|
||||||
|
/// typename boost::type_identity<T>::type const & lo,
|
||||||
|
/// typename boost::type_identity<T>::type const & hi)
|
||||||
|
/// \returns true if value "val" is in the range [ lo, hi ]
|
||||||
|
/// using operator < for comparison.
|
||||||
|
/// If the value is less than lo, return false.
|
||||||
|
/// If the value is greater than hi, return false.
|
||||||
|
/// Otherwise, returns true.
|
||||||
|
///
|
||||||
|
/// \param val The value to be checked
|
||||||
|
/// \param lo The lower bound of the range
|
||||||
|
/// \param hi The upper bound of the range
|
||||||
|
///
|
||||||
|
|
||||||
|
template<typename T>
|
||||||
|
BOOST_CXX14_CONSTEXPR bool is_clamped ( const T& val,
|
||||||
|
typename boost::type_identity<T>::type const & lo,
|
||||||
|
typename boost::type_identity<T>::type const & hi )
|
||||||
|
{
|
||||||
|
return boost::algorithm::is_clamped ( val, lo, hi, std::less<T>());
|
||||||
|
}
|
||||||
|
|
||||||
|
}}
|
||||||
|
|
||||||
|
#endif // BOOST_ALGORITHM_CLAMP_HPP
|
@ -15,6 +15,9 @@
|
|||||||
#include <locale>
|
#include <locale>
|
||||||
#include <functional>
|
#include <functional>
|
||||||
|
|
||||||
|
#include <boost/iterator/transform_iterator.hpp>
|
||||||
|
#include <boost/range/begin.hpp>
|
||||||
|
#include <boost/range/end.hpp>
|
||||||
#include <boost/type_traits/make_unsigned.hpp>
|
#include <boost/type_traits/make_unsigned.hpp>
|
||||||
|
|
||||||
namespace boost {
|
namespace boost {
|
||||||
|
@ -13,10 +13,12 @@
|
|||||||
|
|
||||||
#include <boost/algorithm/string/config.hpp>
|
#include <boost/algorithm/string/config.hpp>
|
||||||
#include <algorithm>
|
#include <algorithm>
|
||||||
|
#include <cstring>
|
||||||
#include <functional>
|
#include <functional>
|
||||||
#include <locale>
|
#include <locale>
|
||||||
|
|
||||||
#include <boost/range/begin.hpp>
|
#include <boost/range/begin.hpp>
|
||||||
|
#include <boost/range/distance.hpp>
|
||||||
#include <boost/range/end.hpp>
|
#include <boost/range/end.hpp>
|
||||||
|
|
||||||
#include <boost/algorithm/string/predicate_facade.hpp>
|
#include <boost/algorithm/string/predicate_facade.hpp>
|
||||||
|
@ -18,6 +18,8 @@
|
|||||||
#include <boost/algorithm/string/detail/find_format_store.hpp>
|
#include <boost/algorithm/string/detail/find_format_store.hpp>
|
||||||
#include <boost/algorithm/string/detail/replace_storage.hpp>
|
#include <boost/algorithm/string/detail/replace_storage.hpp>
|
||||||
|
|
||||||
|
#include <deque>
|
||||||
|
|
||||||
namespace boost {
|
namespace boost {
|
||||||
namespace algorithm {
|
namespace algorithm {
|
||||||
namespace detail {
|
namespace detail {
|
||||||
|
@ -40,10 +40,18 @@ namespace boost {
|
|||||||
// Protected construction/destruction
|
// Protected construction/destruction
|
||||||
|
|
||||||
// Default constructor
|
// Default constructor
|
||||||
find_iterator_base() {}
|
BOOST_DEFAULTED_FUNCTION(find_iterator_base(), {})
|
||||||
|
|
||||||
// Copy construction
|
// Copy construction
|
||||||
find_iterator_base( const find_iterator_base& Other ) :
|
BOOST_DEFAULTED_FUNCTION(find_iterator_base( const find_iterator_base& Other ), :
|
||||||
m_Finder(Other.m_Finder) {}
|
m_Finder(Other.m_Finder) {}
|
||||||
|
)
|
||||||
|
|
||||||
|
// Assignment
|
||||||
|
BOOST_DEFAULTED_FUNCTION(find_iterator_base& operator=( const find_iterator_base& Other ), {
|
||||||
|
m_Finder = Other.m_Finder;
|
||||||
|
return *this;
|
||||||
|
})
|
||||||
|
|
||||||
// Constructor
|
// Constructor
|
||||||
template<typename FinderT>
|
template<typename FinderT>
|
||||||
@ -51,7 +59,7 @@ namespace boost {
|
|||||||
m_Finder(Finder) {}
|
m_Finder(Finder) {}
|
||||||
|
|
||||||
// Destructor
|
// Destructor
|
||||||
~find_iterator_base() {}
|
BOOST_DEFAULTED_FUNCTION(~find_iterator_base(), {})
|
||||||
|
|
||||||
// Find operation
|
// Find operation
|
||||||
match_type do_find(
|
match_type do_find(
|
||||||
|
@ -74,7 +74,7 @@ namespace boost {
|
|||||||
|
|
||||||
\post eof()==true
|
\post eof()==true
|
||||||
*/
|
*/
|
||||||
find_iterator() {}
|
BOOST_DEFAULTED_FUNCTION(find_iterator(), {})
|
||||||
|
|
||||||
//! Copy constructor
|
//! Copy constructor
|
||||||
/*!
|
/*!
|
||||||
@ -85,6 +85,18 @@ namespace boost {
|
|||||||
m_Match(Other.m_Match),
|
m_Match(Other.m_Match),
|
||||||
m_End(Other.m_End) {}
|
m_End(Other.m_End) {}
|
||||||
|
|
||||||
|
//! Copy assignment
|
||||||
|
/*!
|
||||||
|
Assigns a copy of the find_iterator
|
||||||
|
*/
|
||||||
|
BOOST_DEFAULTED_FUNCTION(find_iterator& operator=( const find_iterator& Other ), {
|
||||||
|
if (this == &Other) return *this;
|
||||||
|
this->base_type::operator=(Other);
|
||||||
|
m_Match = Other.m_Match;
|
||||||
|
m_End = Other.m_End;
|
||||||
|
return *this;
|
||||||
|
})
|
||||||
|
|
||||||
//! Constructor
|
//! Constructor
|
||||||
/*!
|
/*!
|
||||||
Construct new find_iterator for a given finder
|
Construct new find_iterator for a given finder
|
||||||
@ -248,6 +260,20 @@ namespace boost {
|
|||||||
m_bEof(Other.m_bEof)
|
m_bEof(Other.m_bEof)
|
||||||
{}
|
{}
|
||||||
|
|
||||||
|
//! Assignment operator
|
||||||
|
/*!
|
||||||
|
Assigns a copy of the split_iterator
|
||||||
|
*/
|
||||||
|
BOOST_DEFAULTED_FUNCTION(split_iterator& operator=( const split_iterator& Other ), {
|
||||||
|
if (this == &Other) return *this;
|
||||||
|
this->base_type::operator=(Other);
|
||||||
|
m_Match = Other.m_Match;
|
||||||
|
m_Next = Other.m_Next;
|
||||||
|
m_End = Other.m_End;
|
||||||
|
m_bEof = Other.m_bEof;
|
||||||
|
return *this;
|
||||||
|
})
|
||||||
|
|
||||||
//! Constructor
|
//! Constructor
|
||||||
/*!
|
/*!
|
||||||
Construct new split_iterator for a given finder
|
Construct new split_iterator for a given finder
|
||||||
|
@ -11,7 +11,8 @@
|
|||||||
],
|
],
|
||||||
"maintainers": [
|
"maintainers": [
|
||||||
"Marshall Clow <marshall -at- idio.com>"
|
"Marshall Clow <marshall -at- idio.com>"
|
||||||
]
|
],
|
||||||
|
"cxxstd": "03"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"key": "algorithm/minmax",
|
"key": "algorithm/minmax",
|
||||||
@ -26,7 +27,8 @@
|
|||||||
],
|
],
|
||||||
"maintainers": [
|
"maintainers": [
|
||||||
"Marshall Clow <marshall -at- idio.com>"
|
"Marshall Clow <marshall -at- idio.com>"
|
||||||
]
|
],
|
||||||
|
"cxxstd": "03"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"key": "algorithm/string",
|
"key": "algorithm/string",
|
||||||
@ -42,6 +44,7 @@
|
|||||||
],
|
],
|
||||||
"maintainers": [
|
"maintainers": [
|
||||||
"Marshall Clow <marshall -at- idio.com>"
|
"Marshall Clow <marshall -at- idio.com>"
|
||||||
]
|
],
|
||||||
|
"cxxstd": "03"
|
||||||
}
|
}
|
||||||
]
|
]
|
@ -265,7 +265,7 @@
|
|||||||
<title>Find Iterator</title>
|
<title>Find Iterator</title>
|
||||||
|
|
||||||
<para>
|
<para>
|
||||||
An extension to find algorithms it the Find Iterator. Instead of searching for just a one part of a string,
|
An extension to find algorithms is the Find Iterator. Instead of searching for just a one part of a string,
|
||||||
the find iterator allows us to iterate over the substrings matching the specified criteria.
|
the find iterator allows us to iterate over the substrings matching the specified criteria.
|
||||||
This facility is using the <link linkend="string_algo.finder_concept">Finder</link> to incrementally
|
This facility is using the <link linkend="string_algo.finder_concept">Finder</link> to incrementally
|
||||||
search the string.
|
search the string.
|
||||||
|
@ -29,6 +29,7 @@ alias unit_test_framework
|
|||||||
|
|
||||||
# Misc tests
|
# Misc tests
|
||||||
[ run clamp_test.cpp unit_test_framework : : : : clamp_test ]
|
[ run clamp_test.cpp unit_test_framework : : : : clamp_test ]
|
||||||
|
[ run is_clamped_test.cpp unit_test_framework : : : : is_clamped_test ]
|
||||||
[ run power_test.cpp unit_test_framework : : : : power_test ]
|
[ run power_test.cpp unit_test_framework : : : : power_test ]
|
||||||
[ compile-fail power_fail1.cpp : : : : ]
|
[ compile-fail power_fail1.cpp : : : : ]
|
||||||
|
|
||||||
@ -68,6 +69,7 @@ alias unit_test_framework
|
|||||||
[ run hex_test2.cpp unit_test_framework : : : : hex_test2 ]
|
[ run hex_test2.cpp unit_test_framework : : : : hex_test2 ]
|
||||||
[ run hex_test3.cpp unit_test_framework : : : : hex_test3 ]
|
[ run hex_test3.cpp unit_test_framework : : : : hex_test3 ]
|
||||||
[ run hex_test4.cpp unit_test_framework : : : : hex_test4 ]
|
[ run hex_test4.cpp unit_test_framework : : : : hex_test4 ]
|
||||||
|
[ run mclow.cpp unit_test_framework : : : : mclow ]
|
||||||
[ compile-fail hex_fail1.cpp ]
|
[ compile-fail hex_fail1.cpp ]
|
||||||
|
|
||||||
# Gather tests
|
# Gather tests
|
||||||
|
@ -34,13 +34,15 @@ BOOST_CXX14_CONSTEXPR bool is_even ( int v ) { return v % 2 == 0; }
|
|||||||
BOOST_CXX14_CONSTEXPR bool is_odd ( int v ) { return v % 2 == 1; }
|
BOOST_CXX14_CONSTEXPR bool is_odd ( int v ) { return v % 2 == 1; }
|
||||||
BOOST_CXX14_CONSTEXPR bool is_zero ( int v ) { return v == 0; }
|
BOOST_CXX14_CONSTEXPR bool is_zero ( int v ) { return v == 0; }
|
||||||
|
|
||||||
|
BOOST_CXX14_CONSTEXPR bool less_than_ten ( int v ) { return v < 10; }
|
||||||
|
BOOST_CXX14_CONSTEXPR bool greater_than_ten ( int v ) { return v > 10; }
|
||||||
|
|
||||||
template <typename Container>
|
template <typename Container>
|
||||||
void test_copy_if ( Container const &c ) {
|
void test_copy_if ( Container const &c ) {
|
||||||
|
|
||||||
typedef typename Container::value_type value_type;
|
typedef typename Container::value_type value_type;
|
||||||
std::vector<value_type> v;
|
std::vector<value_type> v;
|
||||||
|
|
||||||
// None of the elements
|
// None of the elements
|
||||||
v.clear ();
|
v.clear ();
|
||||||
ba::copy_if ( c.begin (), c.end (), back_inserter ( v ), is_false);
|
ba::copy_if ( c.begin (), c.end (), back_inserter ( v ), is_false);
|
||||||
@ -118,6 +120,160 @@ void test_copy_while ( Container const &c ) {
|
|||||||
BOOST_CHECK ( std::equal ( v.begin (), v.end (), c.begin ()));
|
BOOST_CHECK ( std::equal ( v.begin (), v.end (), c.begin ()));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
template <typename Container>
|
||||||
|
void test_copy_if_while ( Container const &c ) {
|
||||||
|
|
||||||
|
typedef typename Container::value_type value_type;
|
||||||
|
typename Container::const_iterator it;
|
||||||
|
|
||||||
|
// Terminate immediately
|
||||||
|
{
|
||||||
|
std::vector<value_type> v;
|
||||||
|
ba::copy_if_while ( c.begin (), c.end (), back_inserter ( v ), is_true, is_false);
|
||||||
|
BOOST_CHECK ( v.size () == 0 );
|
||||||
|
}
|
||||||
|
{
|
||||||
|
std::vector<value_type> v;
|
||||||
|
ba::copy_if_while ( c, back_inserter ( v ), is_true, is_false);
|
||||||
|
BOOST_CHECK ( v.size () == 0 );
|
||||||
|
}
|
||||||
|
|
||||||
|
// Copy nothing - never terminate
|
||||||
|
{
|
||||||
|
std::vector<value_type> v;
|
||||||
|
ba::copy_if_while ( c.begin (), c.end (), back_inserter ( v ), is_false, is_true);
|
||||||
|
BOOST_CHECK ( v.size () == 0 );
|
||||||
|
}
|
||||||
|
{
|
||||||
|
std::vector<value_type> v;
|
||||||
|
ba::copy_if_while ( c, back_inserter ( v ), is_false, is_true);
|
||||||
|
BOOST_CHECK ( v.size () == 0 );
|
||||||
|
}
|
||||||
|
|
||||||
|
// Copy everything
|
||||||
|
{
|
||||||
|
std::vector<value_type> v;
|
||||||
|
ba::copy_if_while ( c.begin (), c.end (), back_inserter ( v ), is_true, is_true);
|
||||||
|
BOOST_CHECK ( v.size () == c.size() );
|
||||||
|
BOOST_CHECK ( std::equal ( v.begin (), v.end (), c.begin ()));
|
||||||
|
}
|
||||||
|
{
|
||||||
|
std::vector<value_type> v;
|
||||||
|
ba::copy_if_while ( c, back_inserter ( v ), is_true, is_true);
|
||||||
|
BOOST_CHECK ( v.size () == c.size() );
|
||||||
|
BOOST_CHECK ( std::equal ( v.begin (), v.end (), c.begin ()));
|
||||||
|
}
|
||||||
|
|
||||||
|
// Copy all evens
|
||||||
|
{
|
||||||
|
std::vector<value_type> v;
|
||||||
|
ba::copy_if_while ( c.begin (), c.end (), back_inserter ( v ), is_even, is_true);
|
||||||
|
BOOST_CHECK ( v.size () == (size_t) std::count_if ( c.begin (), c.end (), is_even ));
|
||||||
|
BOOST_CHECK ( ba::all_of ( v.begin (), v.end (), is_even ));
|
||||||
|
}
|
||||||
|
{
|
||||||
|
std::vector<value_type> v;
|
||||||
|
ba::copy_if_while ( c, back_inserter ( v ), is_even, is_true);
|
||||||
|
BOOST_CHECK ( v.size () == (size_t) std::count_if ( c.begin (), c.end (), is_even ));
|
||||||
|
BOOST_CHECK ( ba::all_of ( v.begin (), v.end (), is_even ));
|
||||||
|
}
|
||||||
|
|
||||||
|
// Copy some until termination
|
||||||
|
{
|
||||||
|
std::vector<value_type> v;
|
||||||
|
typename Container::const_iterator it = ba::copy_if_while (
|
||||||
|
c.begin (), c.end (), back_inserter ( v ), is_even, less_than_ten).first;
|
||||||
|
BOOST_CHECK ( it == std::find_if ( c.begin(), c.end(), greater_than_ten ));
|
||||||
|
BOOST_CHECK ( v.size () == std::count_if ( c.begin(), it, is_even ));
|
||||||
|
BOOST_CHECK ( ba::all_of ( v.begin (), v.end (), is_even ));
|
||||||
|
}
|
||||||
|
{
|
||||||
|
std::vector<value_type> v;
|
||||||
|
typename Container::const_iterator it = ba::copy_if_while (
|
||||||
|
c, back_inserter ( v ), is_even, less_than_ten).first;
|
||||||
|
BOOST_CHECK ( it == std::find_if ( c.begin(), c.end(), greater_than_ten ));
|
||||||
|
BOOST_CHECK ( v.size () == std::count_if ( c.begin(), it, is_even ));
|
||||||
|
BOOST_CHECK ( ba::all_of ( v.begin (), v.end (), is_even ));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
template <typename Container>
|
||||||
|
void test_copy_if_until ( Container const &c ) {
|
||||||
|
|
||||||
|
typedef typename Container::value_type value_type;
|
||||||
|
typename Container::const_iterator it;
|
||||||
|
|
||||||
|
// Terminate immediately
|
||||||
|
{
|
||||||
|
std::vector<value_type> v;
|
||||||
|
ba::copy_if_until ( c.begin (), c.end (), back_inserter ( v ), is_true, is_true);
|
||||||
|
BOOST_CHECK ( v.size () == 0 );
|
||||||
|
}
|
||||||
|
{
|
||||||
|
std::vector<value_type> v;
|
||||||
|
ba::copy_if_until ( c, back_inserter ( v ), is_true, is_true);
|
||||||
|
BOOST_CHECK ( v.size () == 0 );
|
||||||
|
}
|
||||||
|
|
||||||
|
// Copy nothing - never terminate
|
||||||
|
{
|
||||||
|
std::vector<value_type> v;
|
||||||
|
ba::copy_if_until ( c.begin (), c.end (), back_inserter ( v ), is_false, is_false);
|
||||||
|
BOOST_CHECK ( v.size () == 0 );
|
||||||
|
}
|
||||||
|
{
|
||||||
|
std::vector<value_type> v;
|
||||||
|
ba::copy_if_until ( c, back_inserter ( v ), is_false, is_false);
|
||||||
|
BOOST_CHECK ( v.size () == 0 );
|
||||||
|
}
|
||||||
|
|
||||||
|
// Copy everything
|
||||||
|
{
|
||||||
|
std::vector<value_type> v;
|
||||||
|
ba::copy_if_until ( c.begin (), c.end (), back_inserter ( v ), is_true, is_false);
|
||||||
|
BOOST_CHECK ( v.size () == c.size() );
|
||||||
|
BOOST_CHECK ( std::equal ( v.begin (), v.end (), c.begin ()));
|
||||||
|
}
|
||||||
|
{
|
||||||
|
std::vector<value_type> v;
|
||||||
|
ba::copy_if_until ( c, back_inserter ( v ), is_true, is_false);
|
||||||
|
BOOST_CHECK ( v.size () == c.size() );
|
||||||
|
BOOST_CHECK ( std::equal ( v.begin (), v.end (), c.begin ()));
|
||||||
|
}
|
||||||
|
|
||||||
|
// Copy all evens
|
||||||
|
{
|
||||||
|
std::vector<value_type> v;
|
||||||
|
ba::copy_if_until ( c.begin (), c.end (), back_inserter ( v ), is_even, is_false);
|
||||||
|
BOOST_CHECK ( v.size () == (size_t) std::count_if ( c.begin (), c.end (), is_even ));
|
||||||
|
BOOST_CHECK ( ba::all_of ( v.begin (), v.end (), is_even ));
|
||||||
|
}
|
||||||
|
{
|
||||||
|
std::vector<value_type> v;
|
||||||
|
ba::copy_if_until ( c, back_inserter ( v ), is_even, is_false);
|
||||||
|
BOOST_CHECK ( v.size () == (size_t) std::count_if ( c.begin (), c.end (), is_even ));
|
||||||
|
BOOST_CHECK ( ba::all_of ( v.begin (), v.end (), is_even ));
|
||||||
|
}
|
||||||
|
|
||||||
|
// Copy some until termination
|
||||||
|
{
|
||||||
|
std::vector<value_type> v;
|
||||||
|
typename Container::const_iterator it = ba::copy_if_until (
|
||||||
|
c.begin (), c.end (), back_inserter ( v ), is_even, greater_than_ten).first;
|
||||||
|
BOOST_CHECK ( it == std::find_if ( c.begin(), c.end(), greater_than_ten ));
|
||||||
|
BOOST_CHECK ( v.size () == std::count_if ( c.begin(), it, is_even ));
|
||||||
|
BOOST_CHECK ( ba::all_of ( v.begin (), v.end (), is_even ));
|
||||||
|
}
|
||||||
|
{
|
||||||
|
std::vector<value_type> v;
|
||||||
|
typename Container::const_iterator it = ba::copy_if_until (
|
||||||
|
c, back_inserter ( v ), is_even, greater_than_ten).first;
|
||||||
|
BOOST_CHECK ( it == std::find_if ( c.begin(), c.end(), greater_than_ten ));
|
||||||
|
BOOST_CHECK ( v.size () == std::count_if ( c.begin(), it, is_even ));
|
||||||
|
BOOST_CHECK ( ba::all_of ( v.begin (), v.end (), is_even ));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
template <typename Container>
|
template <typename Container>
|
||||||
void test_copy_until ( Container const &c ) {
|
void test_copy_until ( Container const &c ) {
|
||||||
|
|
||||||
@ -224,8 +380,77 @@ BOOST_CXX14_CONSTEXPR inline bool constexpr_test_copy_until() {
|
|||||||
|
|
||||||
return res;
|
return res;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
BOOST_CXX14_CONSTEXPR inline bool constexpr_test_copy_if_while() {
|
||||||
|
const int sz = 64;
|
||||||
|
int in_data[sz] = {0};
|
||||||
|
bool res = true;
|
||||||
|
|
||||||
|
const int* from = in_data;
|
||||||
|
const int* to = in_data + sz;
|
||||||
|
|
||||||
|
// Terminate immediately
|
||||||
|
{
|
||||||
|
int out_data[sz] = {0};
|
||||||
|
int* out = out_data;
|
||||||
|
out = ba::copy_if_while ( from, to, out, is_true, is_false ).second;
|
||||||
|
res = (res && out == out_data && ba::all_of(out, out + sz, is_zero));
|
||||||
|
}
|
||||||
|
// Copy nothing
|
||||||
|
{
|
||||||
|
int out_data[sz] = {0};
|
||||||
|
int* out = out_data;
|
||||||
|
out = ba::copy_if_while ( from, to, out, is_false, is_true ).second;
|
||||||
|
res = (res && out == out_data && ba::all_of(out, out + sz, is_zero));
|
||||||
|
}
|
||||||
|
// Copy everything
|
||||||
|
{
|
||||||
|
int out_data[sz] = {0};
|
||||||
|
int* out = out_data;
|
||||||
|
out = ba::copy_if_while ( from, to, out, is_true, is_true ).second;
|
||||||
|
res = (res && out == out_data + sz
|
||||||
|
&& ba::equal( input_iterator<const int *>(out_data), input_iterator<const int *>(out_data + sz),
|
||||||
|
input_iterator<const int *>(from), input_iterator<const int *>(to)));
|
||||||
|
}
|
||||||
|
|
||||||
|
return res;
|
||||||
|
}
|
||||||
|
|
||||||
|
BOOST_CXX14_CONSTEXPR inline bool constexpr_test_copy_if_until() {
|
||||||
|
const int sz = 64;
|
||||||
|
int in_data[sz] = {0};
|
||||||
|
bool res = true;
|
||||||
|
|
||||||
|
const int* from = in_data;
|
||||||
|
const int* to = in_data + sz;
|
||||||
|
|
||||||
|
// Terminate immediately
|
||||||
|
{
|
||||||
|
int out_data[sz] = {0};
|
||||||
|
int* out = out_data;
|
||||||
|
out = ba::copy_if_until ( from, to, out, is_true, is_true ).second;
|
||||||
|
res = (res && out == out_data && ba::all_of(out, out + sz, is_zero));
|
||||||
|
}
|
||||||
|
// Copy nothing
|
||||||
|
{
|
||||||
|
int out_data[sz] = {0};
|
||||||
|
int* out = out_data;
|
||||||
|
out = ba::copy_if_until ( from, to, out, is_false, is_false ).second;
|
||||||
|
res = (res && out == out_data && ba::all_of(out, out + sz, is_zero));
|
||||||
|
}
|
||||||
|
// Copy everything
|
||||||
|
{
|
||||||
|
int out_data[sz] = {0};
|
||||||
|
int* out = out_data;
|
||||||
|
out = ba::copy_if_until ( from, to, out, is_true, is_false ).second;
|
||||||
|
res = (res && out == out_data + sz
|
||||||
|
&& ba::equal( input_iterator<const int *>(out_data), input_iterator<const int *>(out_data + sz),
|
||||||
|
input_iterator<const int *>(from), input_iterator<const int *>(to)));
|
||||||
|
}
|
||||||
|
|
||||||
|
return res;
|
||||||
|
}
|
||||||
|
|
||||||
void test_sequence1 () {
|
void test_sequence1 () {
|
||||||
std::vector<int> v;
|
std::vector<int> v;
|
||||||
for ( int i = 5; i < 15; ++i )
|
for ( int i = 5; i < 15; ++i )
|
||||||
@ -233,20 +458,26 @@ void test_sequence1 () {
|
|||||||
test_copy_if ( v );
|
test_copy_if ( v );
|
||||||
test_copy_while ( v );
|
test_copy_while ( v );
|
||||||
test_copy_until ( v );
|
test_copy_until ( v );
|
||||||
|
|
||||||
BOOST_CXX14_CONSTEXPR bool constexpr_res_if = constexpr_test_copy_if();
|
BOOST_CXX14_CONSTEXPR bool constexpr_res_if = constexpr_test_copy_if();
|
||||||
BOOST_CHECK ( constexpr_res_if );
|
BOOST_CHECK ( constexpr_res_if );
|
||||||
BOOST_CXX14_CONSTEXPR bool constexpr_res_while = constexpr_test_copy_while();
|
BOOST_CXX14_CONSTEXPR bool constexpr_res_while = constexpr_test_copy_while();
|
||||||
BOOST_CHECK ( constexpr_res_while );
|
BOOST_CHECK ( constexpr_res_while );
|
||||||
BOOST_CXX14_CONSTEXPR bool constexpr_res_until = constexpr_test_copy_until();
|
BOOST_CXX14_CONSTEXPR bool constexpr_res_until = constexpr_test_copy_until();
|
||||||
BOOST_CHECK ( constexpr_res_until );
|
BOOST_CHECK ( constexpr_res_until );
|
||||||
|
BOOST_CXX14_CONSTEXPR bool constexpr_res_if_while = constexpr_test_copy_if_while();
|
||||||
|
BOOST_CHECK ( constexpr_res_if_while );
|
||||||
|
BOOST_CXX14_CONSTEXPR bool constexpr_res_if_until = constexpr_test_copy_if_until();
|
||||||
|
BOOST_CHECK ( constexpr_res_if_until );
|
||||||
|
|
||||||
std::list<int> l;
|
std::list<int> l;
|
||||||
for ( int i = 25; i > 15; --i )
|
for ( int i = 25; i > 15; --i )
|
||||||
l.push_back ( i );
|
l.push_back ( i );
|
||||||
test_copy_if ( l );
|
test_copy_if ( l );
|
||||||
test_copy_while ( l );
|
test_copy_while ( l );
|
||||||
test_copy_until ( l );
|
test_copy_until ( l );
|
||||||
|
test_copy_if_while ( l );
|
||||||
|
test_copy_if_until ( l );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
246
test/is_clamped_test.cpp
Normal file
246
test/is_clamped_test.cpp
Normal file
@ -0,0 +1,246 @@
|
|||||||
|
// (C) Copyright Ivan Matek, Marshall Clow 2021.
|
||||||
|
// 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)
|
||||||
|
|
||||||
|
#include <boost/algorithm/is_clamped.hpp>
|
||||||
|
#include <boost/algorithm/clamp.hpp>
|
||||||
|
#include <cmath>
|
||||||
|
#include <cstdint>
|
||||||
|
#ifdef __cpp_impl_three_way_comparison
|
||||||
|
#if __has_include(<compare>)
|
||||||
|
#define BOOST_IS_CLAMPED_TEST_SPACESHIP
|
||||||
|
#endif
|
||||||
|
#ifdef BOOST_IS_CLAMPED_TEST_SPACESHIP
|
||||||
|
#include <compare>
|
||||||
|
#endif
|
||||||
|
#endif
|
||||||
|
#include <limits>
|
||||||
|
#include <string>
|
||||||
|
#include <tuple>
|
||||||
|
|
||||||
|
#define BOOST_TEST_MAIN
|
||||||
|
#include <boost/test/unit_test.hpp>
|
||||||
|
|
||||||
|
namespace ba = boost::algorithm;
|
||||||
|
|
||||||
|
BOOST_CONSTEXPR bool intGreater(int lhs, int rhs) { return lhs > rhs; }
|
||||||
|
|
||||||
|
class custom {
|
||||||
|
public:
|
||||||
|
custom(int x) : v(x) {}
|
||||||
|
custom(const custom &rhs) : v(rhs.v) {}
|
||||||
|
|
||||||
|
bool operator<(const custom &rhs) const { return v < rhs.v; }
|
||||||
|
bool operator==(const custom &rhs) const {
|
||||||
|
return v == rhs.v;
|
||||||
|
} // need this for the test
|
||||||
|
int v;
|
||||||
|
};
|
||||||
|
|
||||||
|
static bool customLess(const custom &lhs, const custom &rhs) { return lhs.v < rhs.v; }
|
||||||
|
|
||||||
|
void test_ints() {
|
||||||
|
// Inside the range, equal to the endpoints, and outside the endpoints.
|
||||||
|
BOOST_CHECK_EQUAL ( true, ba::is_clamped ( 3, 1, 6 ));
|
||||||
|
BOOST_CHECK_EQUAL ( true, ba::is_clamped ( 1, 1, 6 ));
|
||||||
|
BOOST_CHECK_EQUAL ( true, ba::is_clamped ( 6, 1, 6 ));
|
||||||
|
BOOST_CHECK_EQUAL ( false, ba::is_clamped ( 0, 1, 6 ));
|
||||||
|
BOOST_CHECK_EQUAL ( false, ba::is_clamped ( 7, 1, 6 ));
|
||||||
|
|
||||||
|
BOOST_CHECK_EQUAL ( true, ba::is_clamped ( 3, 6, 1, intGreater ));
|
||||||
|
BOOST_CHECK_EQUAL ( true, ba::is_clamped ( 1, 6, 1, intGreater ));
|
||||||
|
BOOST_CHECK_EQUAL ( true, ba::is_clamped ( 6, 6, 1, intGreater ));
|
||||||
|
BOOST_CHECK_EQUAL ( false, ba::is_clamped ( 0, 6, 1, intGreater ));
|
||||||
|
BOOST_CHECK_EQUAL ( false, ba::is_clamped ( 7, 6, 1, intGreater ));
|
||||||
|
|
||||||
|
// Negative numbers
|
||||||
|
BOOST_CHECK_EQUAL ( true, ba::is_clamped ( -3, -6, -1 ));
|
||||||
|
BOOST_CHECK_EQUAL ( true, ba::is_clamped ( -1, -6, -1 ));
|
||||||
|
BOOST_CHECK_EQUAL ( true, ba::is_clamped ( -6, -6, -1 ));
|
||||||
|
BOOST_CHECK_EQUAL ( false, ba::is_clamped ( 0, -6, -1 ));
|
||||||
|
BOOST_CHECK_EQUAL ( false, ba::is_clamped ( -7, -6, -1 ));
|
||||||
|
|
||||||
|
// Mixed positive and negative numbers
|
||||||
|
BOOST_CHECK_EQUAL ( true, ba::is_clamped ( 1, -5, 5 ));
|
||||||
|
BOOST_CHECK_EQUAL ( true, ba::is_clamped ( -5, -5, 5 ));
|
||||||
|
BOOST_CHECK_EQUAL ( true, ba::is_clamped ( 5, -5, 5 ));
|
||||||
|
BOOST_CHECK_EQUAL ( false, ba::is_clamped ( -6, -5, 5 ));
|
||||||
|
BOOST_CHECK_EQUAL ( false, ba::is_clamped ( 6, -5, 5 ));
|
||||||
|
|
||||||
|
// Unsigned
|
||||||
|
BOOST_CHECK_EQUAL ( true, ba::is_clamped ( 5U, 1U, 6U ));
|
||||||
|
BOOST_CHECK_EQUAL ( true, ba::is_clamped ( 1U, 1U, 6U ));
|
||||||
|
BOOST_CHECK_EQUAL ( true, ba::is_clamped ( 6U, 1U, 6U ));
|
||||||
|
BOOST_CHECK_EQUAL ( false, ba::is_clamped ( 0U, 1U, 6U ));
|
||||||
|
BOOST_CHECK_EQUAL ( false, ba::is_clamped ( 8U, 1U, 6U ));
|
||||||
|
|
||||||
|
// Mixed (1)
|
||||||
|
BOOST_CHECK_EQUAL ( true, ba::is_clamped ( 5U, 1, 6 ));
|
||||||
|
BOOST_CHECK_EQUAL ( true, ba::is_clamped ( 1U, 1, 6 ));
|
||||||
|
BOOST_CHECK_EQUAL ( true, ba::is_clamped ( 6U, 1, 6 ));
|
||||||
|
BOOST_CHECK_EQUAL ( false, ba::is_clamped ( 0U, 1, 6 ));
|
||||||
|
BOOST_CHECK_EQUAL ( false, ba::is_clamped ( 8U, 1, 6 ));
|
||||||
|
|
||||||
|
// Mixed (2)
|
||||||
|
BOOST_CHECK_EQUAL ( true, ba::is_clamped ( 5U, 1, 6. ));
|
||||||
|
BOOST_CHECK_EQUAL ( true, ba::is_clamped ( 1U, 1, 6. ));
|
||||||
|
BOOST_CHECK_EQUAL ( true, ba::is_clamped ( 6U, 1, 6. ));
|
||||||
|
BOOST_CHECK_EQUAL ( false, ba::is_clamped ( 0U, 1, 6. ));
|
||||||
|
BOOST_CHECK_EQUAL ( false, ba::is_clamped ( 8U, 1, 6. ));
|
||||||
|
|
||||||
|
// float->short conversion does not round
|
||||||
|
BOOST_CHECK_EQUAL ( true, ba::is_clamped ( 50, 50.999, 100 ));
|
||||||
|
BOOST_CHECK_EQUAL ( false, ba::is_clamped ( 50, 51.001, 100 ));
|
||||||
|
}
|
||||||
|
|
||||||
|
void test_floats() {
|
||||||
|
// If floats are IEEE754 certain floats have exact representations.
|
||||||
|
if (std::numeric_limits<float>::is_iec559) {
|
||||||
|
const float lo = 0.125;
|
||||||
|
const float hi = 0.625;
|
||||||
|
BOOST_CHECK_EQUAL ( true, ba::is_clamped ( lo, lo, hi ));
|
||||||
|
BOOST_CHECK_EQUAL ( true, ba::is_clamped ( hi, lo, hi ));
|
||||||
|
BOOST_CHECK_EQUAL ( true, ba::is_clamped ( lo + 0.01, lo, hi ));
|
||||||
|
BOOST_CHECK_EQUAL ( false, ba::is_clamped ( lo - 0.01, lo, hi ));
|
||||||
|
BOOST_CHECK_EQUAL ( false, ba::is_clamped ( hi + 0.01, lo, hi ));
|
||||||
|
// If we have nextafterf we can be more precise.
|
||||||
|
#if __cplusplus >= 201103L
|
||||||
|
assert(lo < hi);
|
||||||
|
BOOST_CHECK_EQUAL ( true, ba::is_clamped ( hi, lo, hi ));
|
||||||
|
BOOST_CHECK_EQUAL ( true, ba::is_clamped ( std::nextafterf( lo, hi ), lo, hi ));
|
||||||
|
BOOST_CHECK_EQUAL ( true, ba::is_clamped ( std::nextafterf( hi, lo ), lo, hi ));
|
||||||
|
BOOST_CHECK_EQUAL ( true, ba::is_clamped ( (lo + hi) / 2, lo, hi ));
|
||||||
|
// 1.0 is just for direction of nextafterf, value of 1.0 is not significant.
|
||||||
|
BOOST_CHECK_EQUAL ( false, ba::is_clamped ( std::nextafterf( lo, lo - 1.0f ), lo, hi ));
|
||||||
|
BOOST_CHECK_EQUAL ( false, ba::is_clamped ( std::nextafterf( hi, hi + 1.0f ), lo, hi ));
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void test_std_string() {
|
||||||
|
BOOST_CHECK_EQUAL ( true, ba::is_clamped ( std::string("a3"), std::string("a1"), std::string("a6") ));
|
||||||
|
BOOST_CHECK_EQUAL ( true, ba::is_clamped ( std::string("a1"), std::string("a1"), std::string("a6") ));
|
||||||
|
BOOST_CHECK_EQUAL ( true, ba::is_clamped ( std::string("a6"), std::string("a1"), std::string("a6") ));
|
||||||
|
BOOST_CHECK_EQUAL ( false, ba::is_clamped ( std::string("a7"), std::string("a1"), std::string("a6") ));
|
||||||
|
BOOST_CHECK_EQUAL ( false, ba::is_clamped ( std::string("a0"), std::string("a1"), std::string("a6") ));
|
||||||
|
}
|
||||||
|
|
||||||
|
void test_custom() {
|
||||||
|
// Inside the range, equal to the endpoints, and outside the endpoints.
|
||||||
|
const custom c0(0);
|
||||||
|
const custom c1(1);
|
||||||
|
const custom c3(3);
|
||||||
|
const custom c6(6);
|
||||||
|
const custom c7(7);
|
||||||
|
BOOST_CHECK_EQUAL ( true, ba::is_clamped ( c3, c1, c6 ));
|
||||||
|
BOOST_CHECK_EQUAL ( true, ba::is_clamped ( c1, c1, c6 ));
|
||||||
|
BOOST_CHECK_EQUAL ( true, ba::is_clamped ( c6, c1, c6 ));
|
||||||
|
BOOST_CHECK_EQUAL ( false, ba::is_clamped ( c0, c1, c6 ));
|
||||||
|
BOOST_CHECK_EQUAL ( false, ba::is_clamped ( c7, c1, c6 ));
|
||||||
|
|
||||||
|
BOOST_CHECK_EQUAL ( true, ba::is_clamped ( c3, c1, c6, customLess ));
|
||||||
|
BOOST_CHECK_EQUAL ( true, ba::is_clamped ( c1, c1, c6, customLess ));
|
||||||
|
BOOST_CHECK_EQUAL ( true, ba::is_clamped ( c6, c1, c6, customLess ));
|
||||||
|
BOOST_CHECK_EQUAL ( false, ba::is_clamped ( c0, c1, c6, customLess ));
|
||||||
|
BOOST_CHECK_EQUAL ( false, ba::is_clamped ( c7, c1, c6, customLess ));
|
||||||
|
}
|
||||||
|
|
||||||
|
void test_point_interval() {
|
||||||
|
BOOST_CHECK_EQUAL(true, ba::is_clamped(1, 1, 1));
|
||||||
|
BOOST_CHECK_EQUAL(false, ba::is_clamped(0, 1, 1));
|
||||||
|
BOOST_CHECK_EQUAL(false, ba::is_clamped(2, 1, 1));
|
||||||
|
}
|
||||||
|
|
||||||
|
void test_first_argument_determines_types() {
|
||||||
|
// all arguments are int
|
||||||
|
BOOST_CHECK_EQUAL(true, ba::is_clamped(5, 5.9, 6.1));
|
||||||
|
BOOST_CHECK_EQUAL(true, ba::is_clamped(6, 5.9, 6.1));
|
||||||
|
// all arguments are double
|
||||||
|
BOOST_CHECK_EQUAL(false, ba::is_clamped(5.0, 5.9, 6.1));
|
||||||
|
BOOST_CHECK_EQUAL(false, ba::is_clamped(6.2, 5.9, 6.1));
|
||||||
|
}
|
||||||
|
|
||||||
|
void test_constexpr() {
|
||||||
|
#if __cplusplus >= 201402L
|
||||||
|
{
|
||||||
|
constexpr bool is_clamped = (ba::is_clamped ( 3, 1, 6 ));
|
||||||
|
BOOST_CHECK_EQUAL (true, is_clamped );
|
||||||
|
}
|
||||||
|
{
|
||||||
|
constexpr bool is_clamped = (ba::is_clamped ( 1, 1, 6 ));
|
||||||
|
BOOST_CHECK_EQUAL (true, is_clamped );
|
||||||
|
}
|
||||||
|
{
|
||||||
|
constexpr bool is_clamped = (ba::is_clamped ( 6, 1, 6 ));
|
||||||
|
BOOST_CHECK_EQUAL (true, is_clamped );
|
||||||
|
}
|
||||||
|
{
|
||||||
|
constexpr bool is_clamped = (ba::is_clamped ( 0, 1, 6 ));
|
||||||
|
BOOST_CHECK_EQUAL(false, is_clamped );
|
||||||
|
}
|
||||||
|
{
|
||||||
|
constexpr bool is_clamped = (ba::is_clamped ( 7, 1, 6 ));
|
||||||
|
BOOST_CHECK_EQUAL(false, is_clamped );
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
#ifdef BOOST_IS_CLAMPED_TEST_SPACESHIP
|
||||||
|
struct custom_with_spaceship {
|
||||||
|
int v;
|
||||||
|
auto operator<=>(const custom_with_spaceship&) const = default;
|
||||||
|
};
|
||||||
|
#endif
|
||||||
|
|
||||||
|
void test_spaceship() {
|
||||||
|
#ifdef BOOST_IS_CLAMPED_TEST_SPACESHIP
|
||||||
|
// Inside the range, equal to the endpoints, and outside the endpoints.
|
||||||
|
const custom_with_spaceship c0(0);
|
||||||
|
const custom_with_spaceship c1(1);
|
||||||
|
const custom_with_spaceship c3(3);
|
||||||
|
const custom_with_spaceship c6(6);
|
||||||
|
const custom_with_spaceship c7(7);
|
||||||
|
BOOST_CHECK_EQUAL ( true, ba::is_clamped (c3, c1, c6 ));
|
||||||
|
BOOST_CHECK_EQUAL ( true, ba::is_clamped (c1, c1, c6 ));
|
||||||
|
BOOST_CHECK_EQUAL ( true, ba::is_clamped (c6, c1, c6 ));
|
||||||
|
BOOST_CHECK_EQUAL ( false, ba::is_clamped (c0, c1, c6 ));
|
||||||
|
BOOST_CHECK_EQUAL ( false, ba::is_clamped (c7, c1, c6 ));
|
||||||
|
{
|
||||||
|
constexpr custom_with_spaceship c1(1);
|
||||||
|
constexpr custom_with_spaceship c3(3);
|
||||||
|
constexpr custom_with_spaceship c6(6);
|
||||||
|
constexpr bool clamped = ba::is_clamped (c3, c1, c6 );
|
||||||
|
BOOST_CHECK_EQUAL ( true, clamped );
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
|
||||||
|
BOOST_AUTO_TEST_CASE(test_main) {
|
||||||
|
test_ints();
|
||||||
|
test_floats();
|
||||||
|
test_std_string();
|
||||||
|
test_custom();
|
||||||
|
test_point_interval();
|
||||||
|
test_first_argument_determines_types();
|
||||||
|
test_constexpr();
|
||||||
|
test_spaceship();
|
||||||
|
}
|
||||||
|
|
||||||
|
#if __cplusplus >= 201103L
|
||||||
|
typedef std::tuple<std::uint8_t, std::int8_t, std::uint16_t, std::int16_t,
|
||||||
|
std::int32_t, std::uint32_t, std::int64_t, std::uint64_t> test_types_tuple;
|
||||||
|
|
||||||
|
BOOST_AUTO_TEST_CASE_TEMPLATE(test_extremes, T, test_types_tuple) {
|
||||||
|
const T max = std::numeric_limits<T>::max();
|
||||||
|
BOOST_CHECK_EQUAL(true, ba::is_clamped( max, max, max ));
|
||||||
|
BOOST_CHECK_EQUAL(true, ba::is_clamped( max, max - 1, max ));
|
||||||
|
BOOST_CHECK_EQUAL(false, ba::is_clamped( max - 1, max, max ));
|
||||||
|
|
||||||
|
const T min = std::numeric_limits<T>::min();
|
||||||
|
BOOST_CHECK_EQUAL(true, ba::is_clamped( min, min, min ));
|
||||||
|
BOOST_CHECK_EQUAL(true, ba::is_clamped( min, min, min + 1 ));
|
||||||
|
BOOST_CHECK_EQUAL(false, ba::is_clamped( min, min + 1, min + 1 ));
|
||||||
|
}
|
||||||
|
#endif
|
15
test/mclow.cpp
Normal file
15
test/mclow.cpp
Normal file
@ -0,0 +1,15 @@
|
|||||||
|
#include <stdexcept>
|
||||||
|
|
||||||
|
#include <boost/exception/exception.hpp>
|
||||||
|
#include <boost/throw_exception.hpp>
|
||||||
|
|
||||||
|
struct hex_decode_error : virtual boost::exception, virtual std::exception {};
|
||||||
|
struct not_enough_input : virtual hex_decode_error {};
|
||||||
|
struct non_hex_input : virtual hex_decode_error {};
|
||||||
|
|
||||||
|
void toss() { BOOST_THROW_EXCEPTION(not_enough_input()); }
|
||||||
|
|
||||||
|
int main () {
|
||||||
|
try { toss(); }
|
||||||
|
catch ( const hex_decode_error & /*ex*/ ) {}
|
||||||
|
}
|
Reference in New Issue
Block a user