forked from boostorg/iterator
Compare commits
1 Commits
develop
...
svn-branch
Author | SHA1 | Date | |
---|---|---|---|
a9b594c925 |
508
.github/workflows/ci.yml
vendored
508
.github/workflows/ci.yml
vendored
@ -1,508 +0,0 @@
|
|||||||
# Copyright 2021-2022 Andrey Semashev
|
|
||||||
#
|
|
||||||
# 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)
|
|
||||||
|
|
||||||
name: CI
|
|
||||||
|
|
||||||
on:
|
|
||||||
pull_request:
|
|
||||||
push:
|
|
||||||
branches:
|
|
||||||
- master
|
|
||||||
- develop
|
|
||||||
- feature/**
|
|
||||||
|
|
||||||
concurrency:
|
|
||||||
group: ${{format('{0}:{1}', github.repository, github.ref)}}
|
|
||||||
cancel-in-progress: true
|
|
||||||
|
|
||||||
env:
|
|
||||||
GIT_FETCH_JOBS: 8
|
|
||||||
NET_RETRY_COUNT: 5
|
|
||||||
DEFAULT_BUILD_VARIANT: debug,release
|
|
||||||
|
|
||||||
jobs:
|
|
||||||
posix:
|
|
||||||
defaults:
|
|
||||||
run:
|
|
||||||
shell: bash
|
|
||||||
|
|
||||||
strategy:
|
|
||||||
fail-fast: false
|
|
||||||
matrix:
|
|
||||||
include:
|
|
||||||
# Linux, gcc
|
|
||||||
- toolset: gcc-4.6
|
|
||||||
cxxstd: "0x"
|
|
||||||
os: ubuntu-latest
|
|
||||||
container: ubuntu:16.04
|
|
||||||
install:
|
|
||||||
- g++-4.6
|
|
||||||
sources:
|
|
||||||
- "ppa:ubuntu-toolchain-r/test"
|
|
||||||
- toolset: gcc-4.7
|
|
||||||
cxxstd: "11"
|
|
||||||
os: ubuntu-latest
|
|
||||||
container: ubuntu:16.04
|
|
||||||
install:
|
|
||||||
- g++-4.7
|
|
||||||
- toolset: gcc-4.8
|
|
||||||
cxxstd: "11"
|
|
||||||
os: ubuntu-latest
|
|
||||||
container: ubuntu:18.04
|
|
||||||
install:
|
|
||||||
- g++-4.8
|
|
||||||
- toolset: gcc-4.9
|
|
||||||
cxxstd: "11"
|
|
||||||
os: ubuntu-latest
|
|
||||||
container: ubuntu:16.04
|
|
||||||
install:
|
|
||||||
- g++-4.9
|
|
||||||
- toolset: gcc-5
|
|
||||||
cxxstd: "11,14,1z"
|
|
||||||
os: ubuntu-latest
|
|
||||||
container: ubuntu:16.04
|
|
||||||
install:
|
|
||||||
- g++-5
|
|
||||||
- toolset: gcc-6
|
|
||||||
cxxstd: "11,14,1z"
|
|
||||||
os: ubuntu-latest
|
|
||||||
container: ubuntu:18.04
|
|
||||||
install:
|
|
||||||
- g++-6
|
|
||||||
- toolset: gcc-7
|
|
||||||
cxxstd: "11,14,17"
|
|
||||||
os: ubuntu-latest
|
|
||||||
container: ubuntu:18.04
|
|
||||||
install:
|
|
||||||
- g++-7
|
|
||||||
- toolset: gcc-8
|
|
||||||
cxxstd: "11,14,17,2a"
|
|
||||||
os: ubuntu-latest
|
|
||||||
container: ubuntu:18.04
|
|
||||||
install:
|
|
||||||
- g++-8
|
|
||||||
- toolset: gcc-9
|
|
||||||
cxxstd: "11,14,17,2a"
|
|
||||||
os: ubuntu-20.04
|
|
||||||
install:
|
|
||||||
- g++-9
|
|
||||||
- toolset: gcc-10
|
|
||||||
cxxstd: "11,14,17,20"
|
|
||||||
os: ubuntu-20.04
|
|
||||||
install:
|
|
||||||
- g++-10
|
|
||||||
- toolset: gcc-11
|
|
||||||
cxxstd: "11,14,17,20,23"
|
|
||||||
os: ubuntu-22.04
|
|
||||||
install:
|
|
||||||
- g++-11
|
|
||||||
- toolset: gcc-12
|
|
||||||
cxxstd: "11,14,17,20,23"
|
|
||||||
os: ubuntu-22.04
|
|
||||||
install:
|
|
||||||
- g++-12
|
|
||||||
- name: UBSAN
|
|
||||||
toolset: gcc-11
|
|
||||||
cxxstd: "11,14,17,20,23"
|
|
||||||
ubsan: 1
|
|
||||||
build_variant: debug
|
|
||||||
os: ubuntu-22.04
|
|
||||||
install:
|
|
||||||
- g++-11
|
|
||||||
|
|
||||||
# Linux, clang
|
|
||||||
- toolset: clang
|
|
||||||
compiler: clang++-3.5
|
|
||||||
cxxstd: "11"
|
|
||||||
os: ubuntu-latest
|
|
||||||
container: ubuntu:16.04
|
|
||||||
install:
|
|
||||||
- clang-3.5
|
|
||||||
- toolset: clang
|
|
||||||
compiler: clang++-3.6
|
|
||||||
cxxstd: "11,14"
|
|
||||||
os: ubuntu-latest
|
|
||||||
container: ubuntu:16.04
|
|
||||||
install:
|
|
||||||
- clang-3.6
|
|
||||||
- toolset: clang
|
|
||||||
compiler: clang++-3.7
|
|
||||||
cxxstd: "11,14"
|
|
||||||
os: ubuntu-latest
|
|
||||||
container: ubuntu:16.04
|
|
||||||
install:
|
|
||||||
- clang-3.7
|
|
||||||
- toolset: clang
|
|
||||||
compiler: clang++-3.8
|
|
||||||
cxxstd: "11,14"
|
|
||||||
os: ubuntu-latest
|
|
||||||
container: ubuntu:16.04
|
|
||||||
install:
|
|
||||||
- clang-3.8
|
|
||||||
- toolset: clang
|
|
||||||
compiler: clang++-3.9
|
|
||||||
cxxstd: "11,14"
|
|
||||||
os: ubuntu-latest
|
|
||||||
container: ubuntu:18.04
|
|
||||||
install:
|
|
||||||
- clang-3.9
|
|
||||||
- toolset: clang
|
|
||||||
compiler: clang++-4.0
|
|
||||||
cxxstd: "11,14"
|
|
||||||
os: ubuntu-latest
|
|
||||||
container: ubuntu:18.04
|
|
||||||
install:
|
|
||||||
- clang-4.0
|
|
||||||
- toolset: clang
|
|
||||||
compiler: clang++-5.0
|
|
||||||
cxxstd: "11,14,1z"
|
|
||||||
os: ubuntu-latest
|
|
||||||
container: ubuntu:18.04
|
|
||||||
install:
|
|
||||||
- clang-5.0
|
|
||||||
- toolset: clang
|
|
||||||
compiler: clang++-6.0
|
|
||||||
cxxstd: "11,14,17"
|
|
||||||
os: ubuntu-latest
|
|
||||||
container: ubuntu:18.04
|
|
||||||
install:
|
|
||||||
- clang-6.0
|
|
||||||
- toolset: clang
|
|
||||||
compiler: clang++-7
|
|
||||||
cxxstd: "11,14,17"
|
|
||||||
os: ubuntu-latest
|
|
||||||
container: ubuntu:18.04
|
|
||||||
install:
|
|
||||||
- clang-7
|
|
||||||
# Note: clang-8 does not fully support C++20, so it is not compatible with libstdc++-8 in this mode
|
|
||||||
- toolset: clang
|
|
||||||
compiler: clang++-8
|
|
||||||
cxxstd: "11,14,17,2a"
|
|
||||||
os: ubuntu-latest
|
|
||||||
container: ubuntu:18.04
|
|
||||||
install:
|
|
||||||
- clang-8
|
|
||||||
- g++-7
|
|
||||||
gcc_toolchain: 7
|
|
||||||
- toolset: clang
|
|
||||||
compiler: clang++-9
|
|
||||||
cxxstd: "11,14,17,2a"
|
|
||||||
os: ubuntu-20.04
|
|
||||||
install:
|
|
||||||
- clang-9
|
|
||||||
- toolset: clang
|
|
||||||
compiler: clang++-10
|
|
||||||
cxxstd: "11,14,17,20"
|
|
||||||
os: ubuntu-20.04
|
|
||||||
install:
|
|
||||||
- clang-10
|
|
||||||
- toolset: clang
|
|
||||||
compiler: clang++-11
|
|
||||||
cxxstd: "11,14,17,20"
|
|
||||||
os: ubuntu-22.04
|
|
||||||
install:
|
|
||||||
- clang-11
|
|
||||||
- toolset: clang
|
|
||||||
compiler: clang++-12
|
|
||||||
cxxstd: "11,14,17,20,2b"
|
|
||||||
os: ubuntu-22.04
|
|
||||||
install:
|
|
||||||
- clang-12
|
|
||||||
- g++-11
|
|
||||||
gcc_toolchain: 11
|
|
||||||
- toolset: clang
|
|
||||||
compiler: clang++-13
|
|
||||||
cxxstd: "11,14,17,20,2b"
|
|
||||||
os: ubuntu-22.04
|
|
||||||
install:
|
|
||||||
- clang-13
|
|
||||||
- g++-11
|
|
||||||
gcc_toolchain: 11
|
|
||||||
- toolset: clang
|
|
||||||
compiler: clang++-14
|
|
||||||
cxxstd: "11,14,17,20,2b"
|
|
||||||
os: ubuntu-22.04
|
|
||||||
install:
|
|
||||||
- clang-14
|
|
||||||
- g++-11
|
|
||||||
gcc_toolchain: 11
|
|
||||||
- toolset: clang
|
|
||||||
compiler: clang++-15
|
|
||||||
cxxstd: "11,14,17,20,2b"
|
|
||||||
os: ubuntu-22.04
|
|
||||||
install:
|
|
||||||
- clang-15
|
|
||||||
- g++-11
|
|
||||||
gcc_toolchain: 11
|
|
||||||
- toolset: clang
|
|
||||||
compiler: clang++-15
|
|
||||||
cxxstd: "11,14,17,20,2b"
|
|
||||||
os: ubuntu-22.04
|
|
||||||
install:
|
|
||||||
- clang-15
|
|
||||||
- libc++-15-dev
|
|
||||||
- libc++abi-15-dev
|
|
||||||
cxxflags: -stdlib=libc++
|
|
||||||
linkflags: -stdlib=libc++
|
|
||||||
- toolset: clang
|
|
||||||
compiler: clang++-16
|
|
||||||
cxxstd: "11,14,17,20,2b"
|
|
||||||
os: ubuntu-22.04
|
|
||||||
install:
|
|
||||||
- clang-16
|
|
||||||
sources:
|
|
||||||
- "deb http://apt.llvm.org/jammy/ llvm-toolchain-jammy-16 main"
|
|
||||||
source_keys:
|
|
||||||
- "https://apt.llvm.org/llvm-snapshot.gpg.key"
|
|
||||||
- toolset: clang
|
|
||||||
compiler: clang++-16
|
|
||||||
cxxstd: "11,14,17,20,2b"
|
|
||||||
os: ubuntu-22.04
|
|
||||||
install:
|
|
||||||
- clang-16
|
|
||||||
- libc++-16-dev
|
|
||||||
- libc++abi-16-dev
|
|
||||||
sources:
|
|
||||||
- "deb http://apt.llvm.org/jammy/ llvm-toolchain-jammy-16 main"
|
|
||||||
source_keys:
|
|
||||||
- "https://apt.llvm.org/llvm-snapshot.gpg.key"
|
|
||||||
cxxflags: -stdlib=libc++
|
|
||||||
linkflags: -stdlib=libc++
|
|
||||||
- name: UBSAN
|
|
||||||
toolset: clang
|
|
||||||
compiler: clang++-15
|
|
||||||
cxxstd: "11,14,17,20,2b"
|
|
||||||
cxxflags: -stdlib=libc++
|
|
||||||
linkflags: -stdlib=libc++
|
|
||||||
ubsan: 1
|
|
||||||
build_variant: debug
|
|
||||||
os: ubuntu-22.04
|
|
||||||
install:
|
|
||||||
- clang-15
|
|
||||||
- libc++-15-dev
|
|
||||||
- libc++abi-15-dev
|
|
||||||
|
|
||||||
- toolset: clang
|
|
||||||
cxxstd: "11,14,17,2a"
|
|
||||||
os: macos-11
|
|
||||||
|
|
||||||
- name: CMake tests
|
|
||||||
cmake_tests: 1
|
|
||||||
os: ubuntu-20.04
|
|
||||||
|
|
||||||
timeout-minutes: 60
|
|
||||||
runs-on: ${{matrix.os}}
|
|
||||||
container: ${{matrix.container}}
|
|
||||||
|
|
||||||
steps:
|
|
||||||
- name: Setup environment
|
|
||||||
run: |
|
|
||||||
if [ -f "/etc/debian_version" ]
|
|
||||||
then
|
|
||||||
echo "DEBIAN_FRONTEND=noninteractive" >> $GITHUB_ENV
|
|
||||||
export DEBIAN_FRONTEND=noninteractive
|
|
||||||
fi
|
|
||||||
if [ -n "${{matrix.container}}" ]
|
|
||||||
then
|
|
||||||
echo "GHA_CONTAINER=${{matrix.container}}" >> $GITHUB_ENV
|
|
||||||
if [ -f "/etc/debian_version" ]
|
|
||||||
then
|
|
||||||
apt-get -o Acquire::Retries=$NET_RETRY_COUNT update
|
|
||||||
if [ "$(apt-cache search "^python-is-python3$" | wc -l)" -ne 0 ]
|
|
||||||
then
|
|
||||||
PYTHON_PACKAGE="python-is-python3"
|
|
||||||
else
|
|
||||||
PYTHON_PACKAGE="python"
|
|
||||||
fi
|
|
||||||
apt-get -o Acquire::Retries=$NET_RETRY_COUNT install -y sudo software-properties-common tzdata wget curl apt-transport-https ca-certificates make build-essential g++ $PYTHON_PACKAGE python3 perl git cmake
|
|
||||||
fi
|
|
||||||
fi
|
|
||||||
git config --global pack.threads 0
|
|
||||||
|
|
||||||
- uses: actions/checkout@v3
|
|
||||||
|
|
||||||
- name: Install packages
|
|
||||||
if: matrix.install
|
|
||||||
run: |
|
|
||||||
declare -a SOURCE_KEYS SOURCES
|
|
||||||
if [ -n "${{join(matrix.source_keys, ' ')}}" ]
|
|
||||||
then
|
|
||||||
SOURCE_KEYS=("${{join(matrix.source_keys, '" "')}}")
|
|
||||||
fi
|
|
||||||
if [ -n "${{join(matrix.sources, ' ')}}" ]
|
|
||||||
then
|
|
||||||
SOURCES=("${{join(matrix.sources, '" "')}}")
|
|
||||||
fi
|
|
||||||
for key in "${SOURCE_KEYS[@]}"
|
|
||||||
do
|
|
||||||
for i in {1..$NET_RETRY_COUNT}
|
|
||||||
do
|
|
||||||
echo "Adding key: $key"
|
|
||||||
wget -O - "$key" | sudo apt-key add - && break || sleep 2
|
|
||||||
done
|
|
||||||
done
|
|
||||||
if [ ${#SOURCES[@]} -gt 0 ]
|
|
||||||
then
|
|
||||||
APT_ADD_REPO_COMMON_ARGS=("-y")
|
|
||||||
APT_ADD_REPO_SUPPORTED_ARGS="$(apt-add-repository --help | perl -ne 'if (/^\s*-n/) { print "n"; } elsif (/^\s*-P/) { print "P"; } elsif (/^\s*-S/) { print "S"; } elsif (/^\s*-U/) { print "U"; }')"
|
|
||||||
if [ -n "$APT_ADD_REPO_SUPPORTED_ARGS" -a -z "${APT_ADD_REPO_SUPPORTED_ARGS##*n*}" ]
|
|
||||||
then
|
|
||||||
APT_ADD_REPO_COMMON_ARGS+=("-n")
|
|
||||||
fi
|
|
||||||
APT_ADD_REPO_HAS_SOURCE_ARGS="$([ -n "$APT_ADD_REPO_SUPPORTED_ARGS" -a -z "${APT_ADD_REPO_SUPPORTED_ARGS##*P*}" -a -z "${APT_ADD_REPO_SUPPORTED_ARGS##*S*}" -a -z "${APT_ADD_REPO_SUPPORTED_ARGS##*U*}" ] && echo 1 || echo 0)"
|
|
||||||
for source in "${SOURCES[@]}"
|
|
||||||
do
|
|
||||||
for i in {1..$NET_RETRY_COUNT}
|
|
||||||
do
|
|
||||||
APT_ADD_REPO_ARGS=("${APT_ADD_REPO_COMMON_ARGS[@]}")
|
|
||||||
if [ $APT_ADD_REPO_HAS_SOURCE_ARGS -ne 0 ]
|
|
||||||
then
|
|
||||||
case "$source" in
|
|
||||||
"ppa:"*)
|
|
||||||
APT_ADD_REPO_ARGS+=("-P")
|
|
||||||
;;
|
|
||||||
"deb "*)
|
|
||||||
APT_ADD_REPO_ARGS+=("-S")
|
|
||||||
;;
|
|
||||||
*)
|
|
||||||
APT_ADD_REPO_ARGS+=("-U")
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
fi
|
|
||||||
APT_ADD_REPO_ARGS+=("$source")
|
|
||||||
echo "apt-add-repository ${APT_ADD_REPO_ARGS[@]}"
|
|
||||||
sudo -E apt-add-repository "${APT_ADD_REPO_ARGS[@]}" && break || sleep 2
|
|
||||||
done
|
|
||||||
done
|
|
||||||
fi
|
|
||||||
sudo apt-get -o Acquire::Retries=$NET_RETRY_COUNT update
|
|
||||||
sudo apt-get -o Acquire::Retries=$NET_RETRY_COUNT install -y ${{join(matrix.install, ' ')}}
|
|
||||||
|
|
||||||
- name: Setup GCC Toolchain
|
|
||||||
if: matrix.gcc_toolchain
|
|
||||||
run: |
|
|
||||||
GCC_TOOLCHAIN_ROOT="$HOME/gcc-toolchain"
|
|
||||||
echo "GCC_TOOLCHAIN_ROOT=\"$GCC_TOOLCHAIN_ROOT\"" >> $GITHUB_ENV
|
|
||||||
MULTIARCH_TRIPLET="$(dpkg-architecture -qDEB_HOST_MULTIARCH)"
|
|
||||||
mkdir -p "$GCC_TOOLCHAIN_ROOT"
|
|
||||||
ln -s /usr/include "$GCC_TOOLCHAIN_ROOT/include"
|
|
||||||
ln -s /usr/bin "$GCC_TOOLCHAIN_ROOT/bin"
|
|
||||||
mkdir -p "$GCC_TOOLCHAIN_ROOT/lib/gcc/$MULTIARCH_TRIPLET"
|
|
||||||
ln -s "/usr/lib/gcc/$MULTIARCH_TRIPLET/${{matrix.gcc_toolchain}}" "$GCC_TOOLCHAIN_ROOT/lib/gcc/$MULTIARCH_TRIPLET/${{matrix.gcc_toolchain}}"
|
|
||||||
|
|
||||||
- name: Setup Boost
|
|
||||||
run: |
|
|
||||||
echo GITHUB_REPOSITORY: $GITHUB_REPOSITORY
|
|
||||||
LIBRARY=${GITHUB_REPOSITORY#*/}
|
|
||||||
echo LIBRARY: $LIBRARY
|
|
||||||
echo "LIBRARY=$LIBRARY" >> $GITHUB_ENV
|
|
||||||
echo GITHUB_BASE_REF: $GITHUB_BASE_REF
|
|
||||||
echo GITHUB_REF: $GITHUB_REF
|
|
||||||
REF=${GITHUB_BASE_REF:-$GITHUB_REF}
|
|
||||||
REF=${REF#refs/heads/}
|
|
||||||
echo REF: $REF
|
|
||||||
BOOST_BRANCH=develop && [ "$REF" = "master" ] && BOOST_BRANCH=master || true
|
|
||||||
echo BOOST_BRANCH: $BOOST_BRANCH
|
|
||||||
BUILD_JOBS=$((nproc || sysctl -n hw.ncpu) 2> /dev/null)
|
|
||||||
echo "BUILD_JOBS=$BUILD_JOBS" >> $GITHUB_ENV
|
|
||||||
echo "CMAKE_BUILD_PARALLEL_LEVEL=$BUILD_JOBS" >> $GITHUB_ENV
|
|
||||||
DEPINST_ARGS=()
|
|
||||||
GIT_VERSION="$(git --version | sed -e 's/git version //')"
|
|
||||||
GIT_HAS_JOBS=1
|
|
||||||
if [ -f "/etc/debian_version" ]
|
|
||||||
then
|
|
||||||
if $(dpkg --compare-versions "$GIT_VERSION" lt 2.8.0)
|
|
||||||
then
|
|
||||||
GIT_HAS_JOBS=0
|
|
||||||
fi
|
|
||||||
else
|
|
||||||
declare -a GIT_VER=(${GIT_VERSION//./ })
|
|
||||||
declare -a GIT_MIN_VER=(2 8 0)
|
|
||||||
for ((i=0; i<${#GIT_VER[@]}; i++))
|
|
||||||
do
|
|
||||||
if [ -z "${GIT_MIN_VER[i]}" ]
|
|
||||||
then
|
|
||||||
GIT_MIN_VER[i]=0
|
|
||||||
fi
|
|
||||||
if [ "${GIT_VER[i]}" -lt "${GIT_MIN_VER[i]}" ]
|
|
||||||
then
|
|
||||||
GIT_HAS_JOBS=0
|
|
||||||
break
|
|
||||||
fi
|
|
||||||
done
|
|
||||||
fi
|
|
||||||
if [ "$GIT_HAS_JOBS" -ne 0 ]
|
|
||||||
then
|
|
||||||
DEPINST_ARGS+=("--git_args" "--jobs $GIT_FETCH_JOBS")
|
|
||||||
fi
|
|
||||||
cd ..
|
|
||||||
git clone -b "$BOOST_BRANCH" --depth 1 "https://github.com/boostorg/boost.git" "boost-root"
|
|
||||||
cd boost-root
|
|
||||||
mkdir -p libs/$LIBRARY
|
|
||||||
cp -r $GITHUB_WORKSPACE/* libs/$LIBRARY
|
|
||||||
git submodule update --init tools/boostdep
|
|
||||||
DEPINST_ARGS+=("$LIBRARY")
|
|
||||||
python tools/boostdep/depinst/depinst.py "${DEPINST_ARGS[@]}"
|
|
||||||
if [ -z "${{matrix.cmake_tests}}" ]
|
|
||||||
then
|
|
||||||
./bootstrap.sh
|
|
||||||
./b2 headers
|
|
||||||
if [ -n "${{matrix.compiler}}" -o -n "$GCC_TOOLCHAIN_ROOT" ]
|
|
||||||
then
|
|
||||||
echo -n "using ${{matrix.toolset}} : : ${{matrix.compiler}}" > ~/user-config.jam
|
|
||||||
if [ -n "$GCC_TOOLCHAIN_ROOT" ]
|
|
||||||
then
|
|
||||||
echo -n " : <compileflags>\"--gcc-toolchain=$GCC_TOOLCHAIN_ROOT\" <linkflags>\"--gcc-toolchain=$GCC_TOOLCHAIN_ROOT\"" >> ~/user-config.jam
|
|
||||||
fi
|
|
||||||
echo " ;" >> ~/user-config.jam
|
|
||||||
fi
|
|
||||||
fi
|
|
||||||
|
|
||||||
- name: Run tests
|
|
||||||
if: matrix.cmake_tests == ''
|
|
||||||
run: |
|
|
||||||
cd ../boost-root
|
|
||||||
B2_ARGS=("-j" "$BUILD_JOBS" "toolset=${{matrix.toolset}}" "cxxstd=${{matrix.cxxstd}}")
|
|
||||||
if [ -n "${{matrix.build_variant}}" ]
|
|
||||||
then
|
|
||||||
B2_ARGS+=("variant=${{matrix.build_variant}}")
|
|
||||||
else
|
|
||||||
B2_ARGS+=("variant=$DEFAULT_BUILD_VARIANT")
|
|
||||||
fi
|
|
||||||
if [ -n "${{matrix.threading}}" ]
|
|
||||||
then
|
|
||||||
B2_ARGS+=("threading=${{matrix.threading}}")
|
|
||||||
fi
|
|
||||||
if [ -n "${{matrix.ubsan}}" ]
|
|
||||||
then
|
|
||||||
export UBSAN_OPTIONS="print_stacktrace=1"
|
|
||||||
B2_ARGS+=("cxxflags=-fsanitize=undefined -fno-sanitize-recover=undefined" "linkflags=-fsanitize=undefined -fuse-ld=gold" "define=UBSAN=1" "debug-symbols=on" "visibility=global")
|
|
||||||
fi
|
|
||||||
if [ -n "${{matrix.cxxflags}}" ]
|
|
||||||
then
|
|
||||||
B2_ARGS+=("cxxflags=${{matrix.cxxflags}}")
|
|
||||||
fi
|
|
||||||
if [ -n "${{matrix.linkflags}}" ]
|
|
||||||
then
|
|
||||||
B2_ARGS+=("linkflags=${{matrix.linkflags}}")
|
|
||||||
fi
|
|
||||||
B2_ARGS+=("libs/$LIBRARY/test")
|
|
||||||
./b2 "${B2_ARGS[@]}"
|
|
||||||
|
|
||||||
- name: Run CMake tests
|
|
||||||
if: matrix.cmake_tests
|
|
||||||
run: |
|
|
||||||
if [ -n "${{matrix.macosx_version_min}}" ]
|
|
||||||
then
|
|
||||||
export MACOSX_DEPLOYMENT_TARGET="${{matrix.macosx_version_min}}"
|
|
||||||
fi
|
|
||||||
cd ../boost-root
|
|
||||||
mkdir __build_static__ && cd __build_static__
|
|
||||||
cmake ../libs/$LIBRARY/test/test_cmake
|
|
||||||
cmake --build . --target boost_${LIBRARY}_cmake_self_test -j $BUILD_JOBS
|
|
||||||
cd ..
|
|
||||||
mkdir __build_shared__ && cd __build_shared__
|
|
||||||
cmake -DBUILD_SHARED_LIBS=On ../libs/$LIBRARY/test/test_cmake
|
|
||||||
cmake --build . --target boost_${LIBRARY}_cmake_self_test -j $BUILD_JOBS
|
|
@ -1,30 +0,0 @@
|
|||||||
# Copyright 2018 Peter Dimov
|
|
||||||
# Copyright 2018 Andrey Semashev
|
|
||||||
# Distributed under the Boost Software License, Version 1.0.
|
|
||||||
# See accompanying file LICENSE_1_0.txt or copy at https://www.boost.org/LICENSE_1_0.txt
|
|
||||||
|
|
||||||
cmake_minimum_required(VERSION 3.5...3.20)
|
|
||||||
|
|
||||||
project(boost_iterator VERSION "${BOOST_SUPERPROJECT_VERSION}" LANGUAGES CXX)
|
|
||||||
|
|
||||||
add_library(boost_iterator INTERFACE)
|
|
||||||
add_library(Boost::iterator ALIAS boost_iterator)
|
|
||||||
|
|
||||||
target_include_directories(boost_iterator INTERFACE include)
|
|
||||||
|
|
||||||
target_link_libraries(boost_iterator
|
|
||||||
INTERFACE
|
|
||||||
Boost::assert
|
|
||||||
Boost::concept_check
|
|
||||||
Boost::config
|
|
||||||
Boost::core
|
|
||||||
Boost::detail
|
|
||||||
Boost::function_types
|
|
||||||
Boost::fusion
|
|
||||||
Boost::mpl
|
|
||||||
Boost::optional
|
|
||||||
Boost::smart_ptr
|
|
||||||
Boost::static_assert
|
|
||||||
Boost::type_traits
|
|
||||||
Boost::utility
|
|
||||||
)
|
|
27
README.md
27
README.md
@ -1,27 +0,0 @@
|
|||||||
# Boost.Iterator
|
|
||||||
|
|
||||||
Boost.Iterator, part of collection of the [Boost C++ Libraries](https://github.com/boostorg), provides tools for building and working with iterators in C++. The library also provides a number of iterator classes that can be used out of the box.
|
|
||||||
|
|
||||||
### Directories
|
|
||||||
|
|
||||||
* **doc** - Documentation sources
|
|
||||||
* **include** - Interface headers of Boost.Iterator
|
|
||||||
* **test** - Boost.Iterator unit tests
|
|
||||||
* **example** - Boost.Iterator usage examples
|
|
||||||
|
|
||||||
### More information
|
|
||||||
|
|
||||||
* [Documentation](https://boost.org/libs/iterator)
|
|
||||||
* [Report bugs](https://github.com/boostorg/iterator/issues/new). 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](https://github.com/boostorg/iterator/compare) against **develop** branch. Note that by submitting patches you agree to license your modifications under the [Boost Software License, Version 1.0](https://www.boost.org/LICENSE_1_0.txt).
|
|
||||||
|
|
||||||
### Build status
|
|
||||||
|
|
||||||
Branch | GitHub Actions | AppVeyor | Test Matrix | Dependencies |
|
|
||||||
:-------------: | -------------- | -------- | ----------- | ------------ |
|
|
||||||
[`master`](https://github.com/boostorg/iterator/tree/master) | [](https://github.com/boostorg/iterator/actions?query=branch%3Amaster) | [](https://ci.appveyor.com/project/Lastique/iterator/branch/master) | [](http://www.boost.org/development/tests/master/developer/iterator.html) | [](https://pdimov.github.io/boostdep-report/master/iterator.html)
|
|
||||||
[`develop`](https://github.com/boostorg/iterator/tree/develop) | [](https://github.com/boostorg/iterator/actions?query=branch%3Adevelop) | [](https://ci.appveyor.com/project/Lastique/iterator/branch/develop) | [](http://www.boost.org/development/tests/develop/developer/iterator.html) | [](https://pdimov.github.io/boostdep-report/develop/iterator.html)
|
|
||||||
|
|
||||||
### License
|
|
||||||
|
|
||||||
Distributed under the [Boost Software License, Version 1.0](https://www.boost.org/LICENSE_1_0.txt).
|
|
102
appveyor.yml
102
appveyor.yml
@ -1,102 +0,0 @@
|
|||||||
# Copyright 2017 Edward Diener
|
|
||||||
# Copyright 2019 Andrey Semashev
|
|
||||||
# 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)
|
|
||||||
|
|
||||||
version: 1.0.{build}-{branch}
|
|
||||||
|
|
||||||
shallow_clone: true
|
|
||||||
|
|
||||||
branches:
|
|
||||||
only:
|
|
||||||
- master
|
|
||||||
- develop
|
|
||||||
- /feature\/.*/
|
|
||||||
|
|
||||||
environment:
|
|
||||||
matrix:
|
|
||||||
- TOOLSET: msvc-12.0
|
|
||||||
ADDRMD: 32,64
|
|
||||||
APPVEYOR_BUILD_WORKER_IMAGE: Visual Studio 2015
|
|
||||||
- TOOLSET: msvc-14.0
|
|
||||||
CXXSTD: 14,latest
|
|
||||||
ADDRMD: 32,64
|
|
||||||
APPVEYOR_BUILD_WORKER_IMAGE: Visual Studio 2015
|
|
||||||
- TOOLSET: msvc-14.1
|
|
||||||
CXXSTD: 14,17,latest
|
|
||||||
ADDRMD: 32,64
|
|
||||||
APPVEYOR_BUILD_WORKER_IMAGE: Visual Studio 2017
|
|
||||||
- TOOLSET: msvc-14.2
|
|
||||||
ADDRMD: 32,64
|
|
||||||
CXXSTD: 14,17,20,latest
|
|
||||||
APPVEYOR_BUILD_WORKER_IMAGE: Visual Studio 2019
|
|
||||||
- TOOLSET: msvc-14.3
|
|
||||||
ADDRMD: 32,64
|
|
||||||
CXXSTD: 14,17,20,latest
|
|
||||||
APPVEYOR_BUILD_WORKER_IMAGE: Visual Studio 2022
|
|
||||||
- TOOLSET: clang-win
|
|
||||||
ADDRMD: 32,64
|
|
||||||
CXXSTD: 14,17,latest
|
|
||||||
APPVEYOR_BUILD_WORKER_IMAGE: Visual Studio 2017
|
|
||||||
- TOOLSET: gcc
|
|
||||||
CXXSTD: 11,14,1z
|
|
||||||
ADDPATH: C:\cygwin\bin;
|
|
||||||
APPVEYOR_BUILD_WORKER_IMAGE: Visual Studio 2015
|
|
||||||
- TOOLSET: gcc
|
|
||||||
CXXSTD: 11,14,1z
|
|
||||||
ADDPATH: C:\cygwin64\bin;
|
|
||||||
APPVEYOR_BUILD_WORKER_IMAGE: Visual Studio 2015
|
|
||||||
- TOOLSET: gcc
|
|
||||||
CXXSTD: 11,14,1z
|
|
||||||
ADDPATH: C:\mingw\bin;
|
|
||||||
APPVEYOR_BUILD_WORKER_IMAGE: Visual Studio 2015
|
|
||||||
- TOOLSET: gcc
|
|
||||||
CXXSTD: 11,14,1z
|
|
||||||
ADDPATH: C:\mingw-w64\x86_64-6.3.0-posix-seh-rt_v5-rev1\mingw64\bin;
|
|
||||||
APPVEYOR_BUILD_WORKER_IMAGE: Visual Studio 2015
|
|
||||||
- TOOLSET: gcc
|
|
||||||
CXXSTD: 11,14,1z
|
|
||||||
ADDPATH: C:\mingw-w64\x86_64-7.3.0-posix-seh-rt_v5-rev0\mingw64\bin;
|
|
||||||
APPVEYOR_BUILD_WORKER_IMAGE: Visual Studio 2015
|
|
||||||
- TEST_CMAKE: 1
|
|
||||||
APPVEYOR_BUILD_WORKER_IMAGE: Visual Studio 2019
|
|
||||||
|
|
||||||
install:
|
|
||||||
- set GIT_FETCH_JOBS=8
|
|
||||||
- set BOOST_BRANCH=develop
|
|
||||||
- if "%APPVEYOR_REPO_BRANCH%" == "master" set BOOST_BRANCH=master
|
|
||||||
- cd ..
|
|
||||||
- git clone -b %BOOST_BRANCH% --depth 1 https://github.com/boostorg/boost.git boost-root
|
|
||||||
- cd boost-root
|
|
||||||
- git submodule init tools/build
|
|
||||||
- git submodule init tools/boostdep
|
|
||||||
- git submodule init tools/boost_install
|
|
||||||
- git submodule init libs/headers
|
|
||||||
- git submodule init libs/config
|
|
||||||
- git submodule update --jobs %GIT_FETCH_JOBS%
|
|
||||||
- xcopy /s /e /q %APPVEYOR_BUILD_FOLDER% libs\iterator
|
|
||||||
- python tools/boostdep/depinst/depinst.py --git_args "--jobs %GIT_FETCH_JOBS%" iterator
|
|
||||||
- cmd /c bootstrap
|
|
||||||
- b2 -d0 headers
|
|
||||||
|
|
||||||
build: off
|
|
||||||
|
|
||||||
test_script:
|
|
||||||
- PATH=%ADDPATH%%PATH%
|
|
||||||
- if not "%CXXSTD%" == "" set CXXSTD=cxxstd=%CXXSTD%
|
|
||||||
- if not "%ADDRMD%" == "" set ADDRMD=address-model=%ADDRMD%
|
|
||||||
- b2 -j %NUMBER_OF_PROCESSORS% libs/iterator/test toolset=%TOOLSET% %CXXSTD% %ADDRMD%
|
|
||||||
|
|
||||||
for:
|
|
||||||
- matrix:
|
|
||||||
only: [TEST_CMAKE: 1]
|
|
||||||
test_script:
|
|
||||||
- mkdir __build_static__
|
|
||||||
- cd __build_static__
|
|
||||||
- cmake ../libs/iterator/test/test_cmake
|
|
||||||
- cmake --build . --target boost_iterator_cmake_self_test -j %NUMBER_OF_PROCESSORS%
|
|
||||||
- cd ..
|
|
||||||
- mkdir __build_shared__
|
|
||||||
- cd __build_shared__
|
|
||||||
- cmake -DBUILD_SHARED_LIBS=On ../libs/iterator/test/test_cmake
|
|
||||||
- cmake --build . --target boost_iterator_cmake_self_test -j %NUMBER_OF_PROCESSORS%
|
|
@ -13,15 +13,10 @@ boostbook standalone
|
|||||||
:
|
:
|
||||||
iterator
|
iterator
|
||||||
:
|
:
|
||||||
<xsl:param>"boost.root=../../../.."
|
|
||||||
<xsl:param>toc.max.depth=3
|
<xsl:param>toc.max.depth=3
|
||||||
<xsl:param>toc.section.depth=3
|
<xsl:param>toc.section.depth=3
|
||||||
<xsl:param>chunk.section.depth=2
|
<xsl:param>chunk.section.depth=4
|
||||||
<format>pdf:<xsl:param>"boost.url.prefix=http://www.boost.org/doc/libs/release/libs/iterator/doc/html"
|
<format>pdf:<xsl:param>boost.url.prefix=http://www.boost.org/doc/libs/release/libs/iterator/doc
|
||||||
;
|
;
|
||||||
|
|
||||||
###############################################################################
|
|
||||||
alias boostdoc ;
|
|
||||||
explicit boostdoc ;
|
|
||||||
alias boostrelease : standalone ;
|
|
||||||
explicit boostrelease ;
|
|
||||||
|
@ -1,75 +0,0 @@
|
|||||||
.. Copyright (C) 2017 Michel Morin.
|
|
||||||
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)
|
|
||||||
|
|
||||||
=======
|
|
||||||
advance
|
|
||||||
=======
|
|
||||||
|
|
||||||
``boost::iterators::advance`` is an adapted version of ``std::advance`` for
|
|
||||||
the Boost iterator traversal concepts.
|
|
||||||
|
|
||||||
|
|
||||||
Header
|
|
||||||
------
|
|
||||||
|
|
||||||
``<boost/iterator/advance.hpp>``
|
|
||||||
|
|
||||||
|
|
||||||
Synopsis
|
|
||||||
--------
|
|
||||||
|
|
||||||
::
|
|
||||||
|
|
||||||
template <typename Iterator, typename Distance>
|
|
||||||
constexpr void advance(Iterator& it, Distance n);
|
|
||||||
|
|
||||||
|
|
||||||
Description
|
|
||||||
-----------
|
|
||||||
|
|
||||||
Moves ``it`` forward by ``n`` increments
|
|
||||||
(or backward by ``|n|`` decrements if ``n`` is negative).
|
|
||||||
|
|
||||||
|
|
||||||
Requirements
|
|
||||||
------------
|
|
||||||
|
|
||||||
``Iterator`` should model Incrementable Iterator.
|
|
||||||
|
|
||||||
|
|
||||||
Preconditions
|
|
||||||
-------------
|
|
||||||
|
|
||||||
Let ``it``\ :sub:`i` be the iterator obtained by incrementing
|
|
||||||
(or decrementing if ``n`` is negative) ``it`` by *i*. All the iterators
|
|
||||||
``it``\ :sub:`i` for *i* = 0, 1, 2, ..., ``|n|`` should be valid.
|
|
||||||
|
|
||||||
If ``Iterator`` does not model Bidirectional Traversal Iterator,
|
|
||||||
``n`` should be non-negative.
|
|
||||||
|
|
||||||
|
|
||||||
Complexity
|
|
||||||
----------
|
|
||||||
|
|
||||||
If ``Iterator`` models Random Access Traversal Iterator, it takes constant time;
|
|
||||||
otherwise it takes linear time.
|
|
||||||
|
|
||||||
|
|
||||||
Notes
|
|
||||||
-----
|
|
||||||
|
|
||||||
- This function is not a customization point and is protected against
|
|
||||||
being found by argument-dependent lookup (ADL).
|
|
||||||
- This function is ``constexpr`` only in C++14 or later.
|
|
||||||
|
|
||||||
|
|
||||||
--------------------------------------------------------------------------------
|
|
||||||
|
|
||||||
| Author: Michel Morin
|
|
||||||
| Copyright |C| 2017 Michel Morin
|
|
||||||
| Distributed under the `Boost Software License, Version 1.0
|
|
||||||
<http://www.boost.org/LICENSE_1_0.txt>`_.
|
|
||||||
|
|
||||||
.. |C| unicode:: U+00A9 .. COPYRIGHT SIGN
|
|
@ -1,72 +0,0 @@
|
|||||||
.. Copyright (C) 2017 Michel Morin.
|
|
||||||
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)
|
|
||||||
|
|
||||||
========
|
|
||||||
distance
|
|
||||||
========
|
|
||||||
|
|
||||||
``boost::iterators::distance`` is an adapted version of ``std::distance`` for
|
|
||||||
the Boost iterator traversal concepts.
|
|
||||||
|
|
||||||
|
|
||||||
Header
|
|
||||||
------
|
|
||||||
|
|
||||||
``<boost/iterator/distance.hpp>``
|
|
||||||
|
|
||||||
|
|
||||||
Synopsis
|
|
||||||
--------
|
|
||||||
|
|
||||||
::
|
|
||||||
|
|
||||||
template <typename Iterator>
|
|
||||||
constexpr typename iterator_difference<Iterator>::type
|
|
||||||
distance(Iterator first, Iterator last);
|
|
||||||
|
|
||||||
|
|
||||||
Description
|
|
||||||
-----------
|
|
||||||
|
|
||||||
Computes the (signed) distance from ``first`` to ``last``.
|
|
||||||
|
|
||||||
|
|
||||||
Requirements
|
|
||||||
------------
|
|
||||||
|
|
||||||
``Iterator`` should model Single Pass Iterator.
|
|
||||||
|
|
||||||
|
|
||||||
Preconditions
|
|
||||||
-------------
|
|
||||||
|
|
||||||
If ``Iterator`` models Random Access Traversal Iterator,
|
|
||||||
``[first, last)`` or ``[last, first)`` should be valid;
|
|
||||||
otherwise ``[first, last)`` should be valid.
|
|
||||||
|
|
||||||
|
|
||||||
Complexity
|
|
||||||
----------
|
|
||||||
|
|
||||||
If ``Iterator`` models Random Access Traversal Iterator, it takes constant time;
|
|
||||||
otherwise it takes linear time.
|
|
||||||
|
|
||||||
|
|
||||||
Notes
|
|
||||||
-----
|
|
||||||
|
|
||||||
- This function is not a customization point and is protected against
|
|
||||||
being found by argument-dependent lookup (ADL).
|
|
||||||
- This function is ``constexpr`` only in C++14 or later.
|
|
||||||
|
|
||||||
|
|
||||||
--------------------------------------------------------------------------------
|
|
||||||
|
|
||||||
| Author: Michel Morin
|
|
||||||
| Copyright |C| 2017 Michel Morin
|
|
||||||
| Distributed under the `Boost Software License, Version 1.0
|
|
||||||
<http://www.boost.org/LICENSE_1_0.txt>`_.
|
|
||||||
|
|
||||||
.. |C| unicode:: U+00A9 .. COPYRIGHT SIGN
|
|
@ -26,7 +26,7 @@
|
|||||||
Lab</a>, <a class="last reference external" href="http://www.styleadvisor.com">Zephyr Associates, Inc.</a></td></tr>
|
Lab</a>, <a class="last reference external" href="http://www.styleadvisor.com">Zephyr Associates, Inc.</a></td></tr>
|
||||||
<tr><th class="docinfo-name">Date:</th>
|
<tr><th class="docinfo-name">Date:</th>
|
||||||
<td>2006-09-11</td></tr>
|
<td>2006-09-11</td></tr>
|
||||||
<tr class="field"><th class="docinfo-name">Number:</th><td class="field-body">This is a revised version of <a class="reference external" href="http://www.open-std.org/jtc1/sc22/wg21/docs/papers/2003/n1530.html">N1530</a>=03-0113, which was
|
<tr class="field"><th class="docinfo-name">Number:</th><td class="field-body">This is a revised version of <a class="reference external" href="http://anubis.dkuug.dk/jtc1/sc22/wg21/docs/papers/2003/n1530.html">N1530</a>=03-0113, which was
|
||||||
accepted for Technical Report 1 by the C++ standard
|
accepted for Technical Report 1 by the C++ standard
|
||||||
committee's library working group.</td>
|
committee's library working group.</td>
|
||||||
</tr>
|
</tr>
|
||||||
@ -239,29 +239,29 @@ Iterator Concepts.</p>
|
|||||||
<div class="section" id="iterator-concepts">
|
<div class="section" id="iterator-concepts">
|
||||||
<h2><a class="toc-backref" href="#id18">Iterator Concepts</a></h2>
|
<h2><a class="toc-backref" href="#id18">Iterator Concepts</a></h2>
|
||||||
<p>This proposal is formulated in terms of the new <tt class="docutils literal"><span class="pre">iterator</span> <span class="pre">concepts</span></tt>
|
<p>This proposal is formulated in terms of the new <tt class="docutils literal"><span class="pre">iterator</span> <span class="pre">concepts</span></tt>
|
||||||
as proposed in <a class="reference external" href="http://www.open-std.org/JTC1/SC22/WG21/docs/papers/2003/n1550.htm">n1550</a>, since user-defined and especially adapted
|
as proposed in <a class="reference external" href="http://anubis.dkuug.dk/JTC1/SC22/WG21/docs/papers/2003/n1550.html">n1550</a>, since user-defined and especially adapted
|
||||||
iterators suffer from the well known categorization problems that are
|
iterators suffer from the well known categorization problems that are
|
||||||
inherent to the current iterator categories.</p>
|
inherent to the current iterator categories.</p>
|
||||||
<p>This proposal does not strictly depend on proposal <a class="reference external" href="http://www.open-std.org/JTC1/SC22/WG21/docs/papers/2003/n1550.htm">n1550</a>, as there
|
<p>This proposal does not strictly depend on proposal <a class="reference external" href="http://anubis.dkuug.dk/JTC1/SC22/WG21/docs/papers/2003/n1550.html">n1550</a>, as there
|
||||||
is a direct mapping between new and old categories. This proposal
|
is a direct mapping between new and old categories. This proposal
|
||||||
could be reformulated using this mapping if <a class="reference external" href="http://www.open-std.org/JTC1/SC22/WG21/docs/papers/2003/n1550.htm">n1550</a> was not accepted.</p>
|
could be reformulated using this mapping if <a class="reference external" href="http://anubis.dkuug.dk/JTC1/SC22/WG21/docs/papers/2003/n1550.html">n1550</a> was not accepted.</p>
|
||||||
</div>
|
</div>
|
||||||
<div class="section" id="interoperability">
|
<div class="section" id="interoperability">
|
||||||
<h2><a class="toc-backref" href="#id19">Interoperability</a></h2>
|
<h2><a class="toc-backref" href="#id19">Interoperability</a></h2>
|
||||||
<p>The question of iterator interoperability is poorly addressed in the
|
<p>The question of iterator interoperability is poorly addressed in the
|
||||||
current standard. There are currently two defect reports that are
|
current standard. There are currently two defect reports that are
|
||||||
concerned with interoperability issues.</p>
|
concerned with interoperability issues.</p>
|
||||||
<p>Issue <a class="reference external" href="http://www.open-std.org/jtc1/sc22/wg21/docs/lwg-defects.html#179">179</a> concerns the fact that mutable container iterator types
|
<p>Issue <a class="reference external" href="http://anubis.dkuug.dk/jtc1/sc22/wg21/docs/lwg-defects.html#179">179</a> concerns the fact that mutable container iterator types
|
||||||
are only required to be convertible to the corresponding constant
|
are only required to be convertible to the corresponding constant
|
||||||
iterator types, but objects of these types are not required to
|
iterator types, but objects of these types are not required to
|
||||||
interoperate in comparison or subtraction expressions. This situation
|
interoperate in comparison or subtraction expressions. This situation
|
||||||
is tedious in practice and out of line with the way built in types
|
is tedious in practice and out of line with the way built in types
|
||||||
work. This proposal implements the proposed resolution to issue
|
work. This proposal implements the proposed resolution to issue
|
||||||
<a class="reference external" href="http://www.open-std.org/jtc1/sc22/wg21/docs/lwg-defects.html#179">179</a>, as most standard library implementations do nowadays. In other
|
<a class="reference external" href="http://anubis.dkuug.dk/jtc1/sc22/wg21/docs/lwg-defects.html#179">179</a>, as most standard library implementations do nowadays. In other
|
||||||
words, if an iterator type A has an implicit or user defined
|
words, if an iterator type A has an implicit or user defined
|
||||||
conversion to an iterator type B, the iterator types are interoperable
|
conversion to an iterator type B, the iterator types are interoperable
|
||||||
and the usual set of operators are available.</p>
|
and the usual set of operators are available.</p>
|
||||||
<p>Issue <a class="reference external" href="http://www.open-std.org/jtc1/sc22/wg21/docs/lwg-active.html#280">280</a> concerns the current lack of interoperability between
|
<p>Issue <a class="reference external" href="http://anubis.dkuug.dk/jtc1/sc22/wg21/docs/lwg-active.html#280">280</a> concerns the current lack of interoperability between
|
||||||
reverse iterator types. The proposed new reverse_iterator template
|
reverse iterator types. The proposed new reverse_iterator template
|
||||||
fixes the issues raised in 280. It provides the desired
|
fixes the issues raised in 280. It provides the desired
|
||||||
interoperability without introducing unwanted overloads.</p>
|
interoperability without introducing unwanted overloads.</p>
|
||||||
@ -422,8 +422,8 @@ member (e.g. <a class="reference internal" href="#counting"><tt class="docutils
|
|||||||
into the temporary iterator <tt class="docutils literal"><span class="pre">p+n</span></tt>, which is destroyed when
|
into the temporary iterator <tt class="docutils literal"><span class="pre">p+n</span></tt>, which is destroyed when
|
||||||
<tt class="docutils literal"><span class="pre">operator[]</span></tt> returns.</p>
|
<tt class="docutils literal"><span class="pre">operator[]</span></tt> returns.</p>
|
||||||
<p>Writable iterators built with <tt class="docutils literal"><span class="pre">iterator_facade</span></tt> implement the
|
<p>Writable iterators built with <tt class="docutils literal"><span class="pre">iterator_facade</span></tt> implement the
|
||||||
semantics required by the preferred resolution to <a class="reference external" href="http://www.open-std.org/jtc1/sc22/wg21/docs/lwg-active.html#299">issue 299</a> and
|
semantics required by the preferred resolution to <a class="reference external" href="http://anubis.dkuug.dk/jtc1/sc22/wg21/docs/lwg-active.html#299">issue 299</a> and
|
||||||
adopted by proposal <a class="reference external" href="http://www.open-std.org/JTC1/SC22/WG21/docs/papers/2003/n1550.htm">n1550</a>: the result of <tt class="docutils literal"><span class="pre">p[n]</span></tt> is an object
|
adopted by proposal <a class="reference external" href="http://anubis.dkuug.dk/JTC1/SC22/WG21/docs/papers/2003/n1550.html">n1550</a>: the result of <tt class="docutils literal"><span class="pre">p[n]</span></tt> is an object
|
||||||
convertible to the iterator's <tt class="docutils literal"><span class="pre">value_type</span></tt>, and <tt class="docutils literal"><span class="pre">p[n]</span> <span class="pre">=</span> <span class="pre">x</span></tt> is
|
convertible to the iterator's <tt class="docutils literal"><span class="pre">value_type</span></tt>, and <tt class="docutils literal"><span class="pre">p[n]</span> <span class="pre">=</span> <span class="pre">x</span></tt> is
|
||||||
equivalent to <tt class="docutils literal"><span class="pre">*(p</span> <span class="pre">+</span> <span class="pre">n)</span> <span class="pre">=</span> <span class="pre">x</span></tt> (Note: This result object may be
|
equivalent to <tt class="docutils literal"><span class="pre">*(p</span> <span class="pre">+</span> <span class="pre">n)</span> <span class="pre">=</span> <span class="pre">x</span></tt> (Note: This result object may be
|
||||||
implemented as a proxy containing a copy of <tt class="docutils literal"><span class="pre">p+n</span></tt>). This approach
|
implemented as a proxy containing a copy of <tt class="docutils literal"><span class="pre">p+n</span></tt>). This approach
|
||||||
|
@ -19,7 +19,7 @@
|
|||||||
.. Version 1.9 of this ReStructuredText document corresponds to
|
.. Version 1.9 of this ReStructuredText document corresponds to
|
||||||
n1530_, the paper accepted by the LWG.
|
n1530_, the paper accepted by the LWG.
|
||||||
|
|
||||||
.. _n1530: http://www.open-std.org/jtc1/sc22/wg21/docs/papers/2003/n1530.html
|
.. _n1530: http://anubis.dkuug.dk/jtc1/sc22/wg21/docs/papers/2003/n1530.html
|
||||||
|
|
||||||
:copyright: Copyright David Abrahams, Jeremy Siek, and Thomas Witt 2003.
|
:copyright: Copyright David Abrahams, Jeremy Siek, and Thomas Witt 2003.
|
||||||
|
|
||||||
@ -140,7 +140,7 @@ as proposed in n1550_, since user-defined and especially adapted
|
|||||||
iterators suffer from the well known categorization problems that are
|
iterators suffer from the well known categorization problems that are
|
||||||
inherent to the current iterator categories.
|
inherent to the current iterator categories.
|
||||||
|
|
||||||
.. _n1550: http://www.open-std.org/JTC1/SC22/WG21/docs/papers/2003/n1550.htm
|
.. _n1550: http://anubis.dkuug.dk/JTC1/SC22/WG21/docs/papers/2003/n1550.html
|
||||||
|
|
||||||
This proposal does not strictly depend on proposal n1550_, as there
|
This proposal does not strictly depend on proposal n1550_, as there
|
||||||
is a direct mapping between new and old categories. This proposal
|
is a direct mapping between new and old categories. This proposal
|
||||||
@ -169,8 +169,8 @@ reverse iterator types. The proposed new reverse_iterator template
|
|||||||
fixes the issues raised in 280. It provides the desired
|
fixes the issues raised in 280. It provides the desired
|
||||||
interoperability without introducing unwanted overloads.
|
interoperability without introducing unwanted overloads.
|
||||||
|
|
||||||
.. _179: http://www.open-std.org/jtc1/sc22/wg21/docs/lwg-defects.html#179
|
.. _179: http://anubis.dkuug.dk/jtc1/sc22/wg21/docs/lwg-defects.html#179
|
||||||
.. _280: http://www.open-std.org/jtc1/sc22/wg21/docs/lwg-active.html#280
|
.. _280: http://anubis.dkuug.dk/jtc1/sc22/wg21/docs/lwg-active.html#280
|
||||||
|
|
||||||
|
|
||||||
Iterator Facade
|
Iterator Facade
|
||||||
|
@ -1,13 +1,10 @@
|
|||||||
:Author:
|
:Author:
|
||||||
`Dean Michael Berris <mailto:me@deanberris.com>`_
|
`Dean Michael Berris <mailto:mikhailberis@gmail.com>`_
|
||||||
|
|
||||||
:License:
|
:License:
|
||||||
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://www.boost.org/LICENSE_1_0.txt)
|
(See accompanying file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
|
||||||
|
|
||||||
:Copyright:
|
|
||||||
Copyright 2012 Google, Inc.
|
|
||||||
|
|
||||||
Function Input Iterator
|
Function Input Iterator
|
||||||
=======================
|
=======================
|
||||||
|
|
||||||
@ -18,14 +15,11 @@ the iterator has been incremented. A Function Input Iterator models the
|
|||||||
|
|
||||||
.. _InputIterator: http://www.sgi.com/tech/stl/InputIterator.html
|
.. _InputIterator: http://www.sgi.com/tech/stl/InputIterator.html
|
||||||
|
|
||||||
The Function Input Iterator takes a function that models the Generator_ concept
|
Like the Generator Iterator, the Function Input Iterator takes a function
|
||||||
(which is basically a nullary or 0-arity function object). The first dereference
|
that models the Generator_ concept (which is basically a nullary or 0-arity
|
||||||
of the iterator at a given position invokes the generator function and stores
|
function object). Each increment of the function Function Input Iterator
|
||||||
and returns the result; subsequent dereferences at the same position simply
|
invokes the generator function and stores the value in the iterator. When
|
||||||
return the same stored result. Incrementing the iterator places it at a new
|
the iterator is dereferenced the stored value is returned.
|
||||||
position, hence a subsequent dereference will generate a new value via another
|
|
||||||
invokation of the generator function. This ensures the generator function is
|
|
||||||
invoked precisely when the iterator is requested to return a (new) value.
|
|
||||||
|
|
||||||
.. _Generator: http://www.sgi.com/tech/stl/Generator.html
|
.. _Generator: http://www.sgi.com/tech/stl/Generator.html
|
||||||
|
|
||||||
@ -64,7 +58,7 @@ Synopsis
|
|||||||
|
|
||||||
template <class Function, class State>
|
template <class Function, class State>
|
||||||
typename function_input_iterator<Function, State>
|
typename function_input_iterator<Function, State>
|
||||||
make_function_input_iterator(Function & f, State s);
|
make_function_input_iterator(Function & f);
|
||||||
|
|
||||||
struct infinite;
|
struct infinite;
|
||||||
}
|
}
|
||||||
@ -118,7 +112,7 @@ it with the ``boost::infinite`` helper class.
|
|||||||
copy(
|
copy(
|
||||||
make_function_input_iterator(f,infinite()),
|
make_function_input_iterator(f,infinite()),
|
||||||
make_function_input_iterator(f,infinite()),
|
make_function_input_iterator(f,infinite()),
|
||||||
ostream_iterator<int>(cout, " ")
|
ostream_iterator<int>(count, " ")
|
||||||
);
|
);
|
||||||
|
|
||||||
Above, instead of creating a huge vector we rely on the STL copy algorithm
|
Above, instead of creating a huge vector we rely on the STL copy algorithm
|
||||||
|
@ -1,163 +0,0 @@
|
|||||||
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
|
|
||||||
|
|
||||||
<html>
|
|
||||||
<head>
|
|
||||||
<meta http-equiv="Content-Language" content="en-us">
|
|
||||||
<meta http-equiv="Content-Type" content="text/html; charset=us-ascii">
|
|
||||||
|
|
||||||
<title>Generator Iterator Adaptor Documentation</title>
|
|
||||||
</head>
|
|
||||||
|
|
||||||
<body bgcolor="#FFFFFF" text="#000000">
|
|
||||||
<img src="../../boost.png" alt="boost.png (6897 bytes)" align="middle"
|
|
||||||
width="277" height="86">
|
|
||||||
|
|
||||||
<h1>Generator Iterator Adaptor</h1>
|
|
||||||
|
|
||||||
<p>Defined in header <a href=
|
|
||||||
"../../boost/generator_iterator.hpp">boost/generator_iterator.hpp</a></p>
|
|
||||||
|
|
||||||
<p>The generator iterator adaptor makes it easier to create custom input
|
|
||||||
iterators from 0-ary functions and function objects. The adaptor takes a
|
|
||||||
<a href="http://www.sgi.com/tech/stl/Generator.html">Generator</a> and
|
|
||||||
creates a model of <a href=
|
|
||||||
"http://www.sgi.com/tech/stl/InputIterator.html">Input Iterator</a>. Each
|
|
||||||
increment retrieves an item from the generator and makes it available to be
|
|
||||||
retrieved by dereferencing. The motivation for this iterator is that some
|
|
||||||
concepts can be more naturally expressed as a generator, while most STL
|
|
||||||
algorithms expect an iterator. An example is the <a href=
|
|
||||||
"../random/index.html">Random Number</a> library.</p>
|
|
||||||
|
|
||||||
<h2>Synopsis</h2>
|
|
||||||
|
|
||||||
<blockquote>
|
|
||||||
<pre>
|
|
||||||
namespace boost {
|
|
||||||
template <class Generator>
|
|
||||||
class generator_iterator_policies;
|
|
||||||
|
|
||||||
template <class Generator>
|
|
||||||
class generator_iterator_generator;
|
|
||||||
|
|
||||||
template <class Generator>
|
|
||||||
typename generator_iterator_generator<Generator>::type
|
|
||||||
make_generator_iterator(Generator & gen);
|
|
||||||
}
|
|
||||||
</pre>
|
|
||||||
</blockquote>
|
|
||||||
<hr>
|
|
||||||
|
|
||||||
<h2>The Generator Iterator Generator Class</h2>
|
|
||||||
|
|
||||||
<p>The class generator_iterator_generator is a helper class whose purpose
|
|
||||||
is to construct a generator iterator type. The template parameter for this
|
|
||||||
class is the Generator function object type that is being wrapped. The
|
|
||||||
generator iterator adaptor only holds a reference (or pointer) to the
|
|
||||||
function object, therefore the function object must outlive the generator
|
|
||||||
iterator adaptor constructed from it.</p>
|
|
||||||
<pre>
|
|
||||||
template <class Generator>
|
|
||||||
class generator_iterator_generator
|
|
||||||
{
|
|
||||||
public:
|
|
||||||
typedef <i>unspecified</i> type; // the resulting generator iterator type
|
|
||||||
}
|
|
||||||
</pre>
|
|
||||||
|
|
||||||
<h3>Template Parameters</h3>
|
|
||||||
|
|
||||||
<table border summary="">
|
|
||||||
<tr>
|
|
||||||
<th>Parameter</th>
|
|
||||||
|
|
||||||
<th>Description</th>
|
|
||||||
</tr>
|
|
||||||
|
|
||||||
<tr>
|
|
||||||
<td><tt><a href=
|
|
||||||
"http://www.sgi.com/tech/stl/Generator.html">Generator</a></tt></td>
|
|
||||||
|
|
||||||
<td>The generator (0-ary function object) type being wrapped. The
|
|
||||||
return type of the function must be defined as
|
|
||||||
<tt>Generator::result_type</tt>. The function object must be a model of
|
|
||||||
<a href=
|
|
||||||
"http://www.sgi.com/tech/stl/Generator.html">Generator</a>.</td>
|
|
||||||
</tr>
|
|
||||||
</table>
|
|
||||||
|
|
||||||
<h3>Concept Model</h3>
|
|
||||||
|
|
||||||
<p>The generator iterator class is a model of <a href=
|
|
||||||
"http://www.sgi.com/tech/stl/InputIterator.html">Input Iterator</a>.</p>
|
|
||||||
|
|
||||||
<h3>Members</h3>
|
|
||||||
|
|
||||||
<p>The generator iterator implements the member functions and operators
|
|
||||||
required of the <a href=
|
|
||||||
"http://www.sgi.com/tech/stl/InputIterator.html">Input Iterator</a>
|
|
||||||
concept.<br></p>
|
|
||||||
<hr>
|
|
||||||
|
|
||||||
<h2><a name="make_generator_iterator" id="make_generator_iterator">The
|
|
||||||
Generator Iterator Object Generator</a></h2>
|
|
||||||
|
|
||||||
<p>The <tt>make_generator_iterator()</tt> function provides a convenient
|
|
||||||
way to create generator iterator objects. The function saves the user the
|
|
||||||
trouble of explicitly writing out the iterator types.</p>
|
|
||||||
|
|
||||||
<blockquote>
|
|
||||||
<pre>
|
|
||||||
template <class Generator>
|
|
||||||
typename generator_iterator_generator<Generator>::type
|
|
||||||
make_generator_iterator(Generator & gen);
|
|
||||||
</pre>
|
|
||||||
</blockquote>
|
|
||||||
<hr>
|
|
||||||
|
|
||||||
<h3>Example</h3>
|
|
||||||
|
|
||||||
<p>The following program shows how <code>generator_iterator</code>
|
|
||||||
transforms a generator into an input iterator.</p>
|
|
||||||
|
|
||||||
<blockquote>
|
|
||||||
<pre>
|
|
||||||
#include <iostream>
|
|
||||||
#include <boost/generator_iterator.hpp>
|
|
||||||
|
|
||||||
class my_generator
|
|
||||||
{
|
|
||||||
public:
|
|
||||||
typedef int result_type;
|
|
||||||
my_generator() : state(0) { }
|
|
||||||
int operator()() { return ++state; }
|
|
||||||
private:
|
|
||||||
int state;
|
|
||||||
};
|
|
||||||
|
|
||||||
int main()
|
|
||||||
{
|
|
||||||
my_generator gen;
|
|
||||||
boost::generator_iterator_generator<my_generator>::type it = boost::make_generator_iterator(gen);
|
|
||||||
for(int i = 0; i < 10; ++i, ++it)
|
|
||||||
std::cout << *it << std::endl;
|
|
||||||
}
|
|
||||||
</pre>
|
|
||||||
</blockquote>
|
|
||||||
<hr>
|
|
||||||
|
|
||||||
<p><a href="http://validator.w3.org/check?uri=referer"><img border="0" src=
|
|
||||||
"../../doc/images/valid-html401.png" alt="Valid HTML 4.01 Transitional"
|
|
||||||
height="31" width="88"></a></p>
|
|
||||||
|
|
||||||
<p>Revised
|
|
||||||
<!--webbot bot="Timestamp" s-type="EDITED" s-format="%d %B, %Y" startspan -->05 December, 2006<!--webbot bot="Timestamp" endspan i-checksum="38516" --></p>
|
|
||||||
|
|
||||||
<p><i>Copyright © 2001 <a href=
|
|
||||||
"http://www.boost.org/people/jens_maurer.htm">Jens Maurer</a></i></p>
|
|
||||||
|
|
||||||
<p><i>Distributed under the Boost Software License, Version 1.0. (See
|
|
||||||
accompanying file <a href="../../LICENSE_1_0.txt">LICENSE_1_0.txt</a> or
|
|
||||||
copy at <a href=
|
|
||||||
"http://www.boost.org/LICENSE_1_0.txt">http://www.boost.org/LICENSE_1_0.txt</a>)</i></p>
|
|
||||||
</body>
|
|
||||||
</html>
|
|
@ -131,9 +131,6 @@ is called to get the value to return.</li>
|
|||||||
<li><a class="reference external" href="function_output_iterator.html"><tt class="docutils literal"><span class="pre">function_output_iterator</span></tt></a> (<a class="reference external" href="function_output_iterator.pdf">PDF</a>): an output iterator wrapping a unary function
|
<li><a class="reference external" href="function_output_iterator.html"><tt class="docutils literal"><span class="pre">function_output_iterator</span></tt></a> (<a class="reference external" href="function_output_iterator.pdf">PDF</a>): an output iterator wrapping a unary function
|
||||||
object; each time an element is written into the dereferenced
|
object; each time an element is written into the dereferenced
|
||||||
iterator, it is passed as a parameter to the function object.</li>
|
iterator, it is passed as a parameter to the function object.</li>
|
||||||
<li><a class="reference external" href="generator_iterator.htm"><tt class="docutils literal"><span class="pre">generator_iterator</span></tt></a>: an input iterator wrapping a reference to a generator (nullary function object);
|
|
||||||
each time the iterator is dereferenced, the function object
|
|
||||||
is called to get the value to return. This is a more outdated analogue of <tt class="docutils literal"><span class="pre">function_input_iterator</span></tt>.</li>
|
|
||||||
<li><a class="reference external" href="indirect_iterator.html"><tt class="docutils literal"><span class="pre">indirect_iterator</span></tt></a> (<a class="reference external" href="indirect_iterator.pdf">PDF</a>): an iterator over the objects <em>pointed-to</em> by the
|
<li><a class="reference external" href="indirect_iterator.html"><tt class="docutils literal"><span class="pre">indirect_iterator</span></tt></a> (<a class="reference external" href="indirect_iterator.pdf">PDF</a>): an iterator over the objects <em>pointed-to</em> by the
|
||||||
elements of some sequence.</li>
|
elements of some sequence.</li>
|
||||||
<li><a class="reference external" href="permutation_iterator.html"><tt class="docutils literal"><span class="pre">permutation_iterator</span></tt></a> (<a class="reference external" href="permutation_iterator.pdf">PDF</a>): an iterator over the elements of some random-access
|
<li><a class="reference external" href="permutation_iterator.html"><tt class="docutils literal"><span class="pre">permutation_iterator</span></tt></a> (<a class="reference external" href="permutation_iterator.pdf">PDF</a>): an iterator over the elements of some random-access
|
||||||
|
@ -115,8 +115,8 @@ __ iterator_facade.pdf
|
|||||||
__ iterator_adaptor.pdf
|
__ iterator_adaptor.pdf
|
||||||
|
|
||||||
Both |facade| and |adaptor| as well as many of the `specialized
|
Both |facade| and |adaptor| as well as many of the `specialized
|
||||||
adaptors`_ mentioned below have been proposed for standardization;
|
adaptors`_ mentioned below have been proposed for standardization,
|
||||||
see our
|
and accepted into the first C++ technical report; see our
|
||||||
|
|
||||||
`Standard Proposal For Iterator Facade and Adaptor`__ (PDF__)
|
`Standard Proposal For Iterator Facade and Adaptor`__ (PDF__)
|
||||||
|
|
||||||
@ -146,10 +146,6 @@ iterator templates based on the Boost `iterator facade and adaptor`_.
|
|||||||
object; each time an element is written into the dereferenced
|
object; each time an element is written into the dereferenced
|
||||||
iterator, it is passed as a parameter to the function object.
|
iterator, it is passed as a parameter to the function object.
|
||||||
|
|
||||||
* |generator|_: an input iterator wrapping a generator (nullary
|
|
||||||
function object); each time the iterator is dereferenced, the function object
|
|
||||||
is called to get the value to return. This is an outdated analogue of |function_input|_.
|
|
||||||
|
|
||||||
* |indirect|_ (PDF__): an iterator over the objects *pointed-to* by the
|
* |indirect|_ (PDF__): an iterator over the objects *pointed-to* by the
|
||||||
elements of some sequence.
|
elements of some sequence.
|
||||||
|
|
||||||
@ -187,9 +183,6 @@ __ function_input_iterator.pdf
|
|||||||
.. _function_output: function_output_iterator.html
|
.. _function_output: function_output_iterator.html
|
||||||
__ function_output_iterator.pdf
|
__ function_output_iterator.pdf
|
||||||
|
|
||||||
.. |generator| replace:: ``generator_iterator``
|
|
||||||
.. _generator: generator_iterator.htm
|
|
||||||
|
|
||||||
.. |indirect| replace:: ``indirect_iterator``
|
.. |indirect| replace:: ``indirect_iterator``
|
||||||
.. _indirect: indirect_iterator.html
|
.. _indirect: indirect_iterator.html
|
||||||
__ indirect_iterator.pdf
|
__ indirect_iterator.pdf
|
||||||
@ -220,23 +213,6 @@ __ zip_iterator.pdf
|
|||||||
Iterator Utilities
|
Iterator Utilities
|
||||||
====================
|
====================
|
||||||
|
|
||||||
Operations
|
|
||||||
----------
|
|
||||||
|
|
||||||
The standard library does not handle new-style iterators properly,
|
|
||||||
because it knows nothing about the iterator traversal concepts.
|
|
||||||
The Boost.Iterator library provides implementations that fully understand
|
|
||||||
the new concepts for the two basic operations:
|
|
||||||
|
|
||||||
- |advance|_
|
|
||||||
- |distance|_
|
|
||||||
|
|
||||||
.. |advance| replace:: ``advance``
|
|
||||||
.. _advance: advance.html
|
|
||||||
|
|
||||||
.. |distance| replace:: ``distance``
|
|
||||||
.. _distance: distance.html
|
|
||||||
|
|
||||||
Traits
|
Traits
|
||||||
------
|
------
|
||||||
|
|
||||||
|
@ -3,7 +3,7 @@
|
|||||||
++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
|
++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
|
||||||
|
|
||||||
.. _N1550: http://www.boost-consulting.com/writing/n1550.html
|
.. _N1550: http://www.boost-consulting.com/writing/n1550.html
|
||||||
.. _N1530: http://www.open-std.org/jtc1/sc22/wg21/docs/papers/2003/n1530.html
|
.. _N1530: http://anubis.dkuug.dk/jtc1/sc22/wg21/docs/papers/2003/n1530.html
|
||||||
|
|
||||||
:Author: David Abrahams and Jeremy Siek
|
:Author: David Abrahams and Jeremy Siek
|
||||||
:Contact: dave@boost-consulting.com, jsiek@osl.iu.edu
|
:Contact: dave@boost-consulting.com, jsiek@osl.iu.edu
|
||||||
|
@ -242,8 +242,8 @@ member (e.g. <a class="reference external" href="counting_iterator.html"><tt cla
|
|||||||
into the temporary iterator <tt class="docutils literal"><span class="pre">p+n</span></tt>, which is destroyed when
|
into the temporary iterator <tt class="docutils literal"><span class="pre">p+n</span></tt>, which is destroyed when
|
||||||
<tt class="docutils literal"><span class="pre">operator[]</span></tt> returns.</p>
|
<tt class="docutils literal"><span class="pre">operator[]</span></tt> returns.</p>
|
||||||
<p>Writable iterators built with <tt class="docutils literal"><span class="pre">iterator_facade</span></tt> implement the
|
<p>Writable iterators built with <tt class="docutils literal"><span class="pre">iterator_facade</span></tt> implement the
|
||||||
semantics required by the preferred resolution to <a class="reference external" href="http://www.open-std.org/jtc1/sc22/wg21/docs/lwg-active.html#299">issue 299</a> and
|
semantics required by the preferred resolution to <a class="reference external" href="http://anubis.dkuug.dk/jtc1/sc22/wg21/docs/lwg-active.html#299">issue 299</a> and
|
||||||
adopted by proposal <a class="reference external" href="http://www.open-std.org/JTC1/SC22/WG21/docs/papers/2003/n1550.htm">n1550</a>: the result of <tt class="docutils literal"><span class="pre">p[n]</span></tt> is an object
|
adopted by proposal <a class="reference external" href="http://anubis.dkuug.dk/JTC1/SC22/WG21/docs/papers/2003/n1550.html">n1550</a>: the result of <tt class="docutils literal"><span class="pre">p[n]</span></tt> is an object
|
||||||
convertible to the iterator's <tt class="docutils literal"><span class="pre">value_type</span></tt>, and <tt class="docutils literal"><span class="pre">p[n]</span> <span class="pre">=</span> <span class="pre">x</span></tt> is
|
convertible to the iterator's <tt class="docutils literal"><span class="pre">value_type</span></tt>, and <tt class="docutils literal"><span class="pre">p[n]</span> <span class="pre">=</span> <span class="pre">x</span></tt> is
|
||||||
equivalent to <tt class="docutils literal"><span class="pre">*(p</span> <span class="pre">+</span> <span class="pre">n)</span> <span class="pre">=</span> <span class="pre">x</span></tt> (Note: This result object may be
|
equivalent to <tt class="docutils literal"><span class="pre">*(p</span> <span class="pre">+</span> <span class="pre">n)</span> <span class="pre">=</span> <span class="pre">x</span></tt> (Note: This result object may be
|
||||||
implemented as a proxy containing a copy of <tt class="docutils literal"><span class="pre">p+n</span></tt>). This approach
|
implemented as a proxy containing a copy of <tt class="docutils literal"><span class="pre">p+n</span></tt>). This approach
|
||||||
|
@ -167,9 +167,9 @@ the implementation of her iterator is free to implement an
|
|||||||
class; it will hide the one supplied by ``iterator_facade`` from
|
class; it will hide the one supplied by ``iterator_facade`` from
|
||||||
clients of her iterator.
|
clients of her iterator.
|
||||||
|
|
||||||
.. _n1550: http://www.open-std.org/JTC1/SC22/WG21/docs/papers/2003/n1550.htm
|
.. _n1550: http://anubis.dkuug.dk/JTC1/SC22/WG21/docs/papers/2003/n1550.html
|
||||||
|
|
||||||
.. _`issue 299`: http://www.open-std.org/jtc1/sc22/wg21/docs/lwg-active.html#299
|
.. _`issue 299`: http://anubis.dkuug.dk/jtc1/sc22/wg21/docs/lwg-active.html#299
|
||||||
|
|
||||||
.. _`operator arrow`:
|
.. _`operator arrow`:
|
||||||
|
|
||||||
|
@ -106,7 +106,7 @@ The ``iterator_category`` member of ``iterator_facade`` is
|
|||||||
|
|
||||||
.. parsed-literal::
|
.. parsed-literal::
|
||||||
|
|
||||||
*iterator-category*\ (CategoryOrTraversal, reference, value_type)
|
*iterator-category*\ (CategoryOrTraversal, value_type, reference)
|
||||||
|
|
||||||
where *iterator-category* is defined as follows:
|
where *iterator-category* is defined as follows:
|
||||||
|
|
||||||
|
@ -3,11 +3,11 @@
|
|||||||
<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en" lang="en">
|
<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en" lang="en">
|
||||||
<head>
|
<head>
|
||||||
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
|
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
|
||||||
<meta name="generator" content="Docutils 0.11: http://docutils.sourceforge.net/" />
|
<meta name="generator" content="Docutils 0.5: http://docutils.sourceforge.net/" />
|
||||||
<title>Iterator Traits</title>
|
<title>Iterator Traits</title>
|
||||||
<meta name="author" content="David Abrahams" />
|
<meta name="author" content="David Abrahams" />
|
||||||
<meta name="organization" content="Boost Consulting" />
|
<meta name="organization" content="Boost Consulting" />
|
||||||
<meta name="date" content="$Date$" />
|
<meta name="date" content="2006-09-11" />
|
||||||
<meta name="copyright" content="Copyright David Abrahams 2004." />
|
<meta name="copyright" content="Copyright David Abrahams 2004." />
|
||||||
<link rel="stylesheet" href="../../../rst.css" type="text/css" />
|
<link rel="stylesheet" href="../../../rst.css" type="text/css" />
|
||||||
</head>
|
</head>
|
||||||
@ -25,7 +25,7 @@
|
|||||||
<tr><th class="docinfo-name">Organization:</th>
|
<tr><th class="docinfo-name">Organization:</th>
|
||||||
<td><a class="first last reference external" href="http://www.boost-consulting.com">Boost Consulting</a></td></tr>
|
<td><a class="first last reference external" href="http://www.boost-consulting.com">Boost Consulting</a></td></tr>
|
||||||
<tr><th class="docinfo-name">Date:</th>
|
<tr><th class="docinfo-name">Date:</th>
|
||||||
<td>$Date$</td></tr>
|
<td>2006-09-11</td></tr>
|
||||||
<tr><th class="docinfo-name">Copyright:</th>
|
<tr><th class="docinfo-name">Copyright:</th>
|
||||||
<td>Copyright David Abrahams 2004.</td></tr>
|
<td>Copyright David Abrahams 2004.</td></tr>
|
||||||
</tbody>
|
</tbody>
|
||||||
@ -37,7 +37,7 @@
|
|||||||
<col class="field-name" />
|
<col class="field-name" />
|
||||||
<col class="field-body" />
|
<col class="field-body" />
|
||||||
<tbody valign="top">
|
<tbody valign="top">
|
||||||
<tr class="field"><th class="field-name">abstract:</th><td class="field-body">Header <tt class="docutils literal"><boost/iterator/iterator_traits.hpp></tt> provides
|
<tr class="field"><th class="field-name">abstract:</th><td class="field-body">Header <tt class="docutils literal"><span class="pre"><boost/iterator/iterator_traits.hpp></span></tt> provides
|
||||||
the ability to access an iterator's associated types using
|
the ability to access an iterator's associated types using
|
||||||
MPL-compatible <a class="reference external" href="../../mpl/doc/index.html#metafunctions">metafunctions</a>.</td>
|
MPL-compatible <a class="reference external" href="../../mpl/doc/index.html#metafunctions">metafunctions</a>.</td>
|
||||||
</tr>
|
</tr>
|
||||||
@ -46,15 +46,15 @@ MPL-compatible <a class="reference external" href="../../mpl/doc/index.html#meta
|
|||||||
<div class="section" id="overview">
|
<div class="section" id="overview">
|
||||||
<h1>Overview</h1>
|
<h1>Overview</h1>
|
||||||
<p><tt class="docutils literal"><span class="pre">std::iterator_traits</span></tt> provides access to five associated types
|
<p><tt class="docutils literal"><span class="pre">std::iterator_traits</span></tt> provides access to five associated types
|
||||||
of any iterator: its <tt class="docutils literal">value_type</tt>, <tt class="docutils literal">reference</tt>, <tt class="docutils literal">pointer</tt>,
|
of any iterator: its <tt class="docutils literal"><span class="pre">value_type</span></tt>, <tt class="docutils literal"><span class="pre">reference</span></tt>, <tt class="docutils literal"><span class="pre">pointer</span></tt>,
|
||||||
<tt class="docutils literal">iterator_category</tt>, and <tt class="docutils literal">difference_type</tt>. Unfortunately,
|
<tt class="docutils literal"><span class="pre">iterator_category</span></tt>, and <tt class="docutils literal"><span class="pre">difference_type</span></tt>. Unfortunately,
|
||||||
such a "multi-valued" traits template can be difficult to use in a
|
such a "multi-valued" traits template can be difficult to use in a
|
||||||
metaprogramming context. <tt class="docutils literal"><boost/iterator/iterator_traits.hpp></tt>
|
metaprogramming context. <tt class="docutils literal"><span class="pre"><boost/iterator/iterator_traits.hpp></span></tt>
|
||||||
provides access to these types using a standard <a class="reference external" href="../../mpl/doc/index.html#metafunctions">metafunctions</a>.</p>
|
provides access to these types using a standard <a class="reference external" href="../../mpl/doc/index.html#metafunctions">metafunctions</a>.</p>
|
||||||
</div>
|
</div>
|
||||||
<div class="section" id="summary">
|
<div class="section" id="summary">
|
||||||
<h1>Summary</h1>
|
<h1>Summary</h1>
|
||||||
<p>Header <tt class="docutils literal"><boost/iterator/iterator_traits.hpp></tt>:</p>
|
<p>Header <tt class="docutils literal"><span class="pre"><boost/iterator/iterator_traits.hpp></span></tt>:</p>
|
||||||
<pre class="literal-block">
|
<pre class="literal-block">
|
||||||
template <class Iterator>
|
template <class Iterator>
|
||||||
struct iterator_value
|
struct iterator_value
|
||||||
@ -98,6 +98,21 @@ struct iterator_category
|
|||||||
};
|
};
|
||||||
</pre>
|
</pre>
|
||||||
</div>
|
</div>
|
||||||
|
<div class="section" id="broken-compiler-notes">
|
||||||
|
<h1>Broken Compiler Notes</h1>
|
||||||
|
<p>Because of workarounds in Boost, you may find that these
|
||||||
|
<a class="reference external" href="../../mpl/doc/index.html#metafunctions">metafunctions</a> actually work better than the facilities provided by
|
||||||
|
your compiler's standard library.</p>
|
||||||
|
<p>On compilers that don't support partial specialization, such as
|
||||||
|
Microsoft Visual C++ 6.0 or 7.0, you may need to manually invoke
|
||||||
|
<a class="reference external" href="../../type_traits/index.html#transformations">BOOST_BROKEN_COMPILER_TYPE_TRAITS_SPECIALIZATION</a> on the
|
||||||
|
<tt class="docutils literal"><span class="pre">value_type</span></tt> of pointers that are passed to these metafunctions.</p>
|
||||||
|
<p>Because of bugs in the implementation of GCC-2.9x, the name of
|
||||||
|
<tt class="docutils literal"><span class="pre">iterator_category</span></tt> is changed to <tt class="docutils literal"><span class="pre">iterator_category_</span></tt> on that
|
||||||
|
compiler. A macro, <tt class="docutils literal"><span class="pre">BOOST_ITERATOR_CATEGORY</span></tt>, that expands to
|
||||||
|
either <tt class="docutils literal"><span class="pre">iterator_category</span></tt> or <tt class="docutils literal"><span class="pre">iterator_category_</span></tt>, as
|
||||||
|
appropriate to the platform, is provided for portability.</p>
|
||||||
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<div class="footer">
|
<div class="footer">
|
||||||
<hr class="footer" />
|
<hr class="footer" />
|
||||||
|
@ -75,3 +75,24 @@ Header ``<boost/iterator/iterator_traits.hpp>``::
|
|||||||
detail::iterator_traits<Iterator>::iterator_category
|
detail::iterator_traits<Iterator>::iterator_category
|
||||||
type;
|
type;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
Broken Compiler Notes
|
||||||
|
=====================
|
||||||
|
|
||||||
|
Because of workarounds in Boost, you may find that these
|
||||||
|
metafunctions_ actually work better than the facilities provided by
|
||||||
|
your compiler's standard library.
|
||||||
|
|
||||||
|
On compilers that don't support partial specialization, such as
|
||||||
|
Microsoft Visual C++ 6.0 or 7.0, you may need to manually invoke
|
||||||
|
BOOST_BROKEN_COMPILER_TYPE_TRAITS_SPECIALIZATION_ on the
|
||||||
|
``value_type`` of pointers that are passed to these metafunctions.
|
||||||
|
|
||||||
|
Because of bugs in the implementation of GCC-2.9x, the name of
|
||||||
|
``iterator_category`` is changed to ``iterator_category_`` on that
|
||||||
|
compiler. A macro, ``BOOST_ITERATOR_CATEGORY``, that expands to
|
||||||
|
either ``iterator_category`` or ``iterator_category_``, as
|
||||||
|
appropriate to the platform, is provided for portability.
|
||||||
|
|
||||||
|
.. _BOOST_BROKEN_COMPILER_TYPE_TRAITS_SPECIALIZATION: ../../type_traits/index.html#transformations
|
||||||
|
|
||||||
|
@ -27,10 +27,10 @@
|
|||||||
Lab</a>, <a class="last reference external" href="http://www.styleadvisor.com">Zephyr Associates, Inc.</a></td></tr>
|
Lab</a>, <a class="last reference external" href="http://www.styleadvisor.com">Zephyr Associates, Inc.</a></td></tr>
|
||||||
<tr><th class="docinfo-name">Date:</th>
|
<tr><th class="docinfo-name">Date:</th>
|
||||||
<td>2006-09-11</td></tr>
|
<td>2006-09-11</td></tr>
|
||||||
<tr class="field"><th class="docinfo-name">Number:</th><td class="field-body">This is a revised version of <a class="reference external" href="http://www.open-std.org/jtc1/sc22/wg21/docs/papers/2003/n1550.htm">n1550</a>=03-0133, which was
|
<tr class="field"><th class="docinfo-name">Number:</th><td class="field-body">This is a revised version of <a class="reference external" href="http://anubis.dkuug.dk/jtc1/sc22/wg21/docs/papers/2003/n1550.html">n1550</a>=03-0133, which was
|
||||||
accepted for Technical Report 1 by the C++ standard
|
accepted for Technical Report 1 by the C++ standard
|
||||||
committee's library working group. This proposal is a
|
committee's library working group. This proposal is a
|
||||||
revision of paper <a class="reference external" href="http://www.open-std.org/jtc1/sc22/wg21/docs/papers/2001/n1297.html">n1297</a>, <a class="reference external" href="http://www.open-std.org/jtc1/sc22/wg21/docs/papers/2003/n1477.html">n1477</a>, and <a class="reference external" href="http://www.open-std.org/jtc1/sc22/wg21/docs/papers/2003/n1531.html">n1531</a>.</td>
|
revision of paper <a class="reference external" href="http://anubis.dkuug.dk/jtc1/sc22/wg21/docs/papers/2001/n1297.html">n1297</a>, <a class="reference external" href="http://anubis.dkuug.dk/jtc1/sc22/wg21/docs/papers/2003/n1477.html">n1477</a>, and <a class="reference external" href="http://anubis.dkuug.dk/jtc1/sc22/wg21/docs/papers/2003/n1531.html">n1531</a>.</td>
|
||||||
</tr>
|
</tr>
|
||||||
<tr><th class="docinfo-name">Copyright:</th>
|
<tr><th class="docinfo-name">Copyright:</th>
|
||||||
<td>Copyright David Abrahams, Jeremy Siek, and Thomas Witt
|
<td>Copyright David Abrahams, Jeremy Siek, and Thomas Witt
|
||||||
@ -127,12 +127,12 @@ requirements in the iterator categories.</p>
|
|||||||
<td><tt class="docutils literal"><span class="pre">*i</span></tt> is convertible to <tt class="docutils literal"><span class="pre">T</span></tt></td>
|
<td><tt class="docutils literal"><span class="pre">*i</span></tt> is convertible to <tt class="docutils literal"><span class="pre">T</span></tt></td>
|
||||||
</tr>
|
</tr>
|
||||||
<tr><td>Forward Iterator</td>
|
<tr><td>Forward Iterator</td>
|
||||||
<td><tt class="docutils literal"><span class="pre">*i</span></tt> is <tt class="docutils literal"><span class="pre">T&</span></tt> (or <tt class="docutils literal"><span class="pre">const</span> <span class="pre">T&</span></tt> once <a class="reference external" href="http://www.open-std.org/JTC1/SC22/WG21/docs/lwg-active.html#200">issue 200</a>
|
<td><tt class="docutils literal"><span class="pre">*i</span></tt> is <tt class="docutils literal"><span class="pre">T&</span></tt> (or <tt class="docutils literal"><span class="pre">const</span> <span class="pre">T&</span></tt> once <a class="reference external" href="http://anubis.dkuug.dk/JTC1/SC22/WG21/docs/lwg-active.html#200">issue 200</a>
|
||||||
is resolved)</td>
|
is resolved)</td>
|
||||||
</tr>
|
</tr>
|
||||||
<tr><td>Random Access Iterator</td>
|
<tr><td>Random Access Iterator</td>
|
||||||
<td><tt class="docutils literal"><span class="pre">i[n]</span></tt> is convertible to <tt class="docutils literal"><span class="pre">T</span></tt> (also <tt class="docutils literal"><span class="pre">i[n]</span> <span class="pre">=</span> <span class="pre">t</span></tt>
|
<td><tt class="docutils literal"><span class="pre">i[n]</span></tt> is convertible to <tt class="docutils literal"><span class="pre">T</span></tt> (also <tt class="docutils literal"><span class="pre">i[n]</span> <span class="pre">=</span> <span class="pre">t</span></tt>
|
||||||
is required for mutable iterators once <a class="reference external" href="http://www.open-std.org/JTC1/SC22/WG21/docs/lwg-active.html#299">issue 299</a>
|
is required for mutable iterators once <a class="reference external" href="http://anubis.dkuug.dk/JTC1/SC22/WG21/docs/lwg-active.html#299">issue 299</a>
|
||||||
is resolved)</td>
|
is resolved)</td>
|
||||||
</tr>
|
</tr>
|
||||||
</tbody>
|
</tbody>
|
||||||
@ -141,7 +141,7 @@ is resolved)</td>
|
|||||||
single hierarchy, many useful iterators can not be appropriately
|
single hierarchy, many useful iterators can not be appropriately
|
||||||
categorized. For example, <tt class="docutils literal"><span class="pre">vector<bool>::iterator</span></tt> is almost a
|
categorized. For example, <tt class="docutils literal"><span class="pre">vector<bool>::iterator</span></tt> is almost a
|
||||||
random access iterator, but the return type is not <tt class="docutils literal"><span class="pre">bool&</span></tt> (see
|
random access iterator, but the return type is not <tt class="docutils literal"><span class="pre">bool&</span></tt> (see
|
||||||
<a class="reference external" href="http://www.open-std.org/JTC1/SC22/WG21/docs/lwg-active.html#96">issue 96</a> and Herb Sutter's paper J16/99-0008 = WG21
|
<a class="reference external" href="http://anubis.dkuug.dk/JTC1/SC22/WG21/docs/lwg-active.html#96">issue 96</a> and Herb Sutter's paper J16/99-0008 = WG21
|
||||||
N1185). Therefore, the iterators of <tt class="docutils literal"><span class="pre">vector<bool></span></tt> only meet the
|
N1185). Therefore, the iterators of <tt class="docutils literal"><span class="pre">vector<bool></span></tt> only meet the
|
||||||
requirements of input iterator and output iterator. This is so
|
requirements of input iterator and output iterator. This is so
|
||||||
nonintuitive that the C++ standard contradicts itself on this point.
|
nonintuitive that the C++ standard contradicts itself on this point.
|
||||||
@ -344,7 +344,7 @@ approach for specifying <tt class="docutils literal"><span class="pre">operator[
|
|||||||
direction would mean that an iterator satisfying the old Random Access
|
direction would mean that an iterator satisfying the old Random Access
|
||||||
Iterator requirements would not necessarily be a model of Readable or
|
Iterator requirements would not necessarily be a model of Readable or
|
||||||
Writable Lvalue Iterator. Instead we have chosen a design that
|
Writable Lvalue Iterator. Instead we have chosen a design that
|
||||||
matches the preferred resolution of <a class="reference external" href="http://www.open-std.org/JTC1/SC22/WG21/docs/lwg-active.html#299">issue 299</a>: <tt class="docutils literal"><span class="pre">operator[]</span></tt> is
|
matches the preferred resolution of <a class="reference external" href="http://anubis.dkuug.dk/JTC1/SC22/WG21/docs/lwg-active.html#299">issue 299</a>: <tt class="docutils literal"><span class="pre">operator[]</span></tt> is
|
||||||
only required to return something convertible to the <tt class="docutils literal"><span class="pre">value_type</span></tt>
|
only required to return something convertible to the <tt class="docutils literal"><span class="pre">value_type</span></tt>
|
||||||
(for a Readable Iterator), and is required to support assignment
|
(for a Readable Iterator), and is required to support assignment
|
||||||
<tt class="docutils literal"><span class="pre">i[n]</span> <span class="pre">=</span> <span class="pre">t</span></tt> (for a Writable Iterator).</p>
|
<tt class="docutils literal"><span class="pre">i[n]</span> <span class="pre">=</span> <span class="pre">t</span></tt> (for a Writable Iterator).</p>
|
||||||
@ -976,7 +976,7 @@ struct random_access_traversal_tag : bidirectional_traversal_tag { };
|
|||||||
<div class="section" id="addition-to-lib-iterator-traits">
|
<div class="section" id="addition-to-lib-iterator-traits">
|
||||||
<h2><a class="toc-backref" href="#id23">Addition to [lib.iterator.traits]</a></h2>
|
<h2><a class="toc-backref" href="#id23">Addition to [lib.iterator.traits]</a></h2>
|
||||||
<p>The <tt class="docutils literal"><span class="pre">is_readable_iterator</span></tt> class
|
<p>The <tt class="docutils literal"><span class="pre">is_readable_iterator</span></tt> class
|
||||||
template satisfies the <a class="reference external" href="http://www.open-std.org/jtc1/sc22/wg21/docs/papers/2003/n1519.htm">UnaryTypeTrait</a> requirements.</p>
|
template satisfies the <a class="reference external" href="http://anubis.dkuug.dk/jtc1/sc22/wg21/docs/papers/2003/n1519.htm">UnaryTypeTrait</a> requirements.</p>
|
||||||
<p>Given an iterator type <tt class="docutils literal"><span class="pre">X</span></tt>, <tt class="docutils literal"><span class="pre">is_readable_iterator<X>::value</span></tt>
|
<p>Given an iterator type <tt class="docutils literal"><span class="pre">X</span></tt>, <tt class="docutils literal"><span class="pre">is_readable_iterator<X>::value</span></tt>
|
||||||
yields <tt class="docutils literal"><span class="pre">true</span></tt> if, for an object <tt class="docutils literal"><span class="pre">a</span></tt> of type <tt class="docutils literal"><span class="pre">X</span></tt>, <tt class="docutils literal"><span class="pre">*a</span></tt> is
|
yields <tt class="docutils literal"><span class="pre">true</span></tt> if, for an object <tt class="docutils literal"><span class="pre">a</span></tt> of type <tt class="docutils literal"><span class="pre">X</span></tt>, <tt class="docutils literal"><span class="pre">*a</span></tt> is
|
||||||
convertible to <tt class="docutils literal"><span class="pre">iterator_traits<X>::value_type</span></tt>, and <tt class="docutils literal"><span class="pre">false</span></tt>
|
convertible to <tt class="docutils literal"><span class="pre">iterator_traits<X>::value_type</span></tt>, and <tt class="docutils literal"><span class="pre">false</span></tt>
|
||||||
@ -1007,7 +1007,7 @@ otherwise.</p>
|
|||||||
</div>
|
</div>
|
||||||
<div class="section" id="footnotes">
|
<div class="section" id="footnotes">
|
||||||
<h1><a class="toc-backref" href="#id24">Footnotes</a></h1>
|
<h1><a class="toc-backref" href="#id24">Footnotes</a></h1>
|
||||||
<p>The UnaryTypeTrait concept is defined in <a class="reference external" href="http://www.open-std.org/jtc1/sc22/wg21/docs/papers/2003/n1519.htm">n1519</a>; the LWG is
|
<p>The UnaryTypeTrait concept is defined in <a class="reference external" href="http://anubis.dkuug.dk/jtc1/sc22/wg21/docs/papers/2003/n1519.htm">n1519</a>; the LWG is
|
||||||
considering adding the requirement that specializations are derived
|
considering adding the requirement that specializations are derived
|
||||||
from their nested <tt class="docutils literal"><span class="pre">::type</span></tt>.</p>
|
from their nested <tt class="docutils literal"><span class="pre">::type</span></tt>.</p>
|
||||||
<!-- LocalWords: Abrahams Siek Witt const bool Sutter's WG int UL LI href Lvalue
|
<!-- LocalWords: Abrahams Siek Witt const bool Sutter's WG int UL LI href Lvalue
|
||||||
|
@ -38,10 +38,10 @@
|
|||||||
|
|
||||||
.. contents:: Table of Contents
|
.. contents:: Table of Contents
|
||||||
|
|
||||||
.. _n1297: http://www.open-std.org/jtc1/sc22/wg21/docs/papers/2001/n1297.html
|
.. _n1297: http://anubis.dkuug.dk/jtc1/sc22/wg21/docs/papers/2001/n1297.html
|
||||||
.. _n1477: http://www.open-std.org/jtc1/sc22/wg21/docs/papers/2003/n1477.html
|
.. _n1477: http://anubis.dkuug.dk/jtc1/sc22/wg21/docs/papers/2003/n1477.html
|
||||||
.. _n1531: http://www.open-std.org/jtc1/sc22/wg21/docs/papers/2003/n1531.html
|
.. _n1531: http://anubis.dkuug.dk/jtc1/sc22/wg21/docs/papers/2003/n1531.html
|
||||||
.. _n1550: http://www.open-std.org/jtc1/sc22/wg21/docs/papers/2003/n1550.htm
|
.. _n1550: http://anubis.dkuug.dk/jtc1/sc22/wg21/docs/papers/2003/n1550.html
|
||||||
|
|
||||||
============
|
============
|
||||||
Motivation
|
Motivation
|
||||||
@ -76,8 +76,8 @@ requirements in the iterator categories.
|
|||||||
| |is resolved) |
|
| |is resolved) |
|
||||||
+------------------------+-----------------------------------------------------+
|
+------------------------+-----------------------------------------------------+
|
||||||
|
|
||||||
.. _issue 200: http://www.open-std.org/JTC1/SC22/WG21/docs/lwg-active.html#200
|
.. _issue 200: http://anubis.dkuug.dk/JTC1/SC22/WG21/docs/lwg-active.html#200
|
||||||
.. _issue 299: http://www.open-std.org/JTC1/SC22/WG21/docs/lwg-active.html#299
|
.. _issue 299: http://anubis.dkuug.dk/JTC1/SC22/WG21/docs/lwg-active.html#299
|
||||||
|
|
||||||
|
|
||||||
Because iterator traversal and value access are mixed together in a
|
Because iterator traversal and value access are mixed together in a
|
||||||
@ -91,7 +91,7 @@ nonintuitive that the C++ standard contradicts itself on this point.
|
|||||||
In paragraph 23.2.4/1 it says that a ``vector`` is a sequence that
|
In paragraph 23.2.4/1 it says that a ``vector`` is a sequence that
|
||||||
supports random access iterators.
|
supports random access iterators.
|
||||||
|
|
||||||
.. _issue 96: http://www.open-std.org/JTC1/SC22/WG21/docs/lwg-active.html#96
|
.. _issue 96: http://anubis.dkuug.dk/JTC1/SC22/WG21/docs/lwg-active.html#96
|
||||||
|
|
||||||
Another difficult-to-categorize iterator is the transform iterator, an
|
Another difficult-to-categorize iterator is the transform iterator, an
|
||||||
adaptor which applies a unary function object to the dereferenced
|
adaptor which applies a unary function object to the dereferenced
|
||||||
@ -791,7 +791,7 @@ The UnaryTypeTrait concept is defined in n1519_; the LWG is
|
|||||||
considering adding the requirement that specializations are derived
|
considering adding the requirement that specializations are derived
|
||||||
from their nested ``::type``.
|
from their nested ``::type``.
|
||||||
|
|
||||||
.. _n1519: http://www.open-std.org/jtc1/sc22/wg21/docs/papers/2003/n1519.htm
|
.. _n1519: http://anubis.dkuug.dk/jtc1/sc22/wg21/docs/papers/2003/n1519.htm
|
||||||
|
|
||||||
..
|
..
|
||||||
LocalWords: Abrahams Siek Witt const bool Sutter's WG int UL LI href Lvalue
|
LocalWords: Abrahams Siek Witt const bool Sutter's WG int UL LI href Lvalue
|
||||||
|
@ -1,3 +1,4 @@
|
|||||||
|
|
||||||
[section:adaptor Iterator Adaptor]
|
[section:adaptor Iterator Adaptor]
|
||||||
|
|
||||||
The `iterator_adaptor` class template adapts some `Base` [#base]_
|
The `iterator_adaptor` class template adapts some `Base` [#base]_
|
||||||
@ -131,7 +132,7 @@ above are defined as follows:
|
|||||||
|
|
||||||
iterator_adaptor();
|
iterator_adaptor();
|
||||||
|
|
||||||
[*Requires:] The `Base` type must be Default Constructible.[br]
|
[*Requires:] The `Base` type must be Default Constructible.\n
|
||||||
[*Returns:] An instance of `iterator_adaptor` with
|
[*Returns:] An instance of `iterator_adaptor` with
|
||||||
`m_iterator` default constructed.
|
`m_iterator` default constructed.
|
||||||
|
|
||||||
@ -205,7 +206,7 @@ we're going to pick up right where it left off.
|
|||||||
.. |fac_tut| replace:: `iterator_facade` tutorial
|
.. |fac_tut| replace:: `iterator_facade` tutorial
|
||||||
.. _fac_tut: iterator_facade.html#tutorial-example
|
.. _fac_tut: iterator_facade.html#tutorial-example
|
||||||
|
|
||||||
[blurb [*`node_base*` really *is* an iterator][br][br]
|
[blurb [*`node_base*` really *is* an iterator]\n\n
|
||||||
It's not really a very interesting iterator, since `node_base`
|
It's not really a very interesting iterator, since `node_base`
|
||||||
is an abstract class: a pointer to a `node_base` just points
|
is an abstract class: a pointer to a `node_base` just points
|
||||||
at some base subobject of an instance of some other class, and
|
at some base subobject of an instance of some other class, and
|
||||||
@ -287,7 +288,7 @@ Metrowerks CodeWarrior versions prior to 9.0]
|
|||||||
|
|
||||||
You can see an example program that exercises this version of the
|
You can see an example program that exercises this version of the
|
||||||
node iterators
|
node iterators
|
||||||
[example_link node_iterator3.cpp..here].
|
[@../example/node_iterator3.cpp `here`].
|
||||||
|
|
||||||
|
|
||||||
In the case of `node_iter`, it's not very compelling to pass
|
In the case of `node_iter`, it's not very compelling to pass
|
||||||
|
@ -1,149 +0,0 @@
|
|||||||
[section:algorithms Algorithms]
|
|
||||||
|
|
||||||
[section:advance Function template `advance()`]
|
|
||||||
|
|
||||||
The `boost::iterators::advance` function template is an adapted version of `std::advance` for the Boost iterator [link iterator.concepts.traversal traversal concepts].
|
|
||||||
|
|
||||||
[heading Header]
|
|
||||||
|
|
||||||
<boost/iterator/advance.hpp>
|
|
||||||
|
|
||||||
[heading Synopsis]
|
|
||||||
|
|
||||||
template <typename Iterator, typename Distance>
|
|
||||||
constexpr void advance(Iterator& it, Distance n);
|
|
||||||
|
|
||||||
|
|
||||||
[heading Description]
|
|
||||||
|
|
||||||
Moves `it` forward by `n` increments (or backward by `|n|` decrements if `n` is negative).
|
|
||||||
|
|
||||||
[heading Requirements]
|
|
||||||
|
|
||||||
`Iterator` should model Incrementable Iterator.
|
|
||||||
|
|
||||||
[heading Preconditions]
|
|
||||||
|
|
||||||
Let `it`[sub `i`] be the iterator obtained by incrementing (or decrementing if `n` is negative) `it` by `i`. All the iterators `it`[sub `i`] for `i` = 0, 1, 2, ..., `|n|` should be valid.
|
|
||||||
|
|
||||||
If `Iterator` does not model [link iterator.concepts.traversal.bidirectional Bidirectional Traversal Iterator], `n` should be non-negative.
|
|
||||||
|
|
||||||
[heading Complexity]
|
|
||||||
|
|
||||||
If `Iterator` models [link iterator.concepts.traversal.random_access Random Access Traversal Iterator], it takes constant time; otherwise it takes linear time.
|
|
||||||
|
|
||||||
[heading Notes]
|
|
||||||
|
|
||||||
* This function is not a customization point and is protected against being found by argument-dependent lookup (ADL).
|
|
||||||
* This function is `constexpr` only in C++14 or later.
|
|
||||||
|
|
||||||
[heading Acknowledgements]
|
|
||||||
|
|
||||||
Contributed by Michel Morin.
|
|
||||||
|
|
||||||
[endsect]
|
|
||||||
|
|
||||||
[section:distance Function template `distance()`]
|
|
||||||
|
|
||||||
The `boost::iterators::distance` function template is an adapted version of `std::distance` for the Boost iterator [link iterator.concepts.traversal traversal concepts].
|
|
||||||
|
|
||||||
[heading Header]
|
|
||||||
|
|
||||||
<boost/iterator/distance.hpp>
|
|
||||||
|
|
||||||
[heading Synopsis]
|
|
||||||
|
|
||||||
template <typename Iterator>
|
|
||||||
constexpr typename iterator_difference<Iterator>::type
|
|
||||||
distance(Iterator first, Iterator last);
|
|
||||||
|
|
||||||
[heading Description]
|
|
||||||
|
|
||||||
Computes the (signed) distance from `first` to `last`.
|
|
||||||
|
|
||||||
[heading Requirements]
|
|
||||||
|
|
||||||
`Iterator` should model [link iterator.concepts.traversal.single_pass Single Pass Iterator].
|
|
||||||
|
|
||||||
[heading Preconditions]
|
|
||||||
|
|
||||||
If `Iterator` models [link iterator.concepts.traversal.random_access Random Access Traversal Iterator], `[first, last)` or `[last, first)` should be valid; otherwise `[first, last)` should be valid.
|
|
||||||
|
|
||||||
[heading Complexity]
|
|
||||||
|
|
||||||
If `Iterator` models [link iterator.concepts.traversal.random_access Random Access Traversal Iterator], it takes constant time; otherwise it takes linear time.
|
|
||||||
|
|
||||||
[heading Notes]
|
|
||||||
|
|
||||||
* This function is not a customization point and is protected against being found by argument-dependent lookup (ADL).
|
|
||||||
* This function is `constexpr` only in C++14 or later.
|
|
||||||
|
|
||||||
[heading Acknowledgements]
|
|
||||||
|
|
||||||
Contributed by Michel Morin.
|
|
||||||
|
|
||||||
[endsect]
|
|
||||||
|
|
||||||
[section:next_prior Function templates `next()` and `prior()`]
|
|
||||||
|
|
||||||
Certain data types, such as the C++ Standard Library's forward and bidirectional iterators, do not provide addition and subtraction via `operator+()` or `operator-()`. This means that non-modifying computation of the next or prior value requires a temporary, even though `operator++()` or `operator--()` is provided. It also means that writing code like `itr+1` inside a template restricts the iterator category to random access iterators.
|
|
||||||
|
|
||||||
The `next()` and `prior()` functions defined in `boost/next_prior.hpp` provide a simple way around these problems.
|
|
||||||
|
|
||||||
[heading Synopsis]
|
|
||||||
|
|
||||||
template <class T>
|
|
||||||
T next(T x)
|
|
||||||
{
|
|
||||||
return ++x;
|
|
||||||
}
|
|
||||||
|
|
||||||
template <class T, class Distance>
|
|
||||||
T next(T x, Distance n)
|
|
||||||
{
|
|
||||||
std::advance(x, n);
|
|
||||||
return x;
|
|
||||||
}
|
|
||||||
|
|
||||||
template <class T>
|
|
||||||
T prior(T x)
|
|
||||||
{
|
|
||||||
return --x;
|
|
||||||
}
|
|
||||||
|
|
||||||
template <class T, class Distance>
|
|
||||||
T prior(T x, Distance n)
|
|
||||||
{
|
|
||||||
std::advance(x, -n);
|
|
||||||
return x;
|
|
||||||
}
|
|
||||||
|
|
||||||
[note Function implementations above are given for exposition only. The actual implementation has the same effect for iterators, but has different properties, as documented later.]
|
|
||||||
|
|
||||||
[heading Usage]
|
|
||||||
|
|
||||||
Usage is simple:
|
|
||||||
|
|
||||||
const std::list<T>::iterator p = get_some_iterator();
|
|
||||||
const std::list<T>::iterator prev = boost::prior(p);
|
|
||||||
const std::list<T>::iterator next = boost::next(prev, 2);
|
|
||||||
|
|
||||||
The distance from the given iterator should be supplied as an absolute value. For example, the iterator four iterators prior to the given iterator `p` may be obtained by `prior(p, 4)`.
|
|
||||||
|
|
||||||
With C++11, the Standard Library provides `std::next()` and `std::prev()` function templates, which serve the same purpose. However, there are advantages to `boost::next()` and `boost::prior()`.
|
|
||||||
|
|
||||||
First, `boost::next()` and `boost::prior()` are compatible not only with iterators but with any type that provides arithmetic operators `operator++()`, `operator--()`, `operator+()`, `operator-()`, `operator+=()` or `operator-=()`. For example, this is possible:
|
|
||||||
|
|
||||||
int x = 10;
|
|
||||||
int y = boost::next(x, 5);
|
|
||||||
assert(y == 15);
|
|
||||||
|
|
||||||
Second, `boost::next()` and `boost::prior()` use [link iterator.concepts.traversal traversal categories] to select the most efficient implementation. For some kinds of iterators, such as [link iterator.specialized.transform transform iterators], the standard iterator category does not reflect the traversal category correctly and therefore `std::next()` and `std::prev()` will fall back to linear complexity.
|
|
||||||
|
|
||||||
[heading Acknowledgements]
|
|
||||||
|
|
||||||
Contributed by [@http://www.boost.org/people/dave_abrahams.htm Dave Abrahams]. Two-argument versions by Daniel Walker.
|
|
||||||
|
|
||||||
[endsect]
|
|
||||||
|
|
||||||
[endsect]
|
|
@ -1,3 +1,4 @@
|
|||||||
|
|
||||||
[section:archetypes Iterator Archetypes]
|
[section:archetypes Iterator Archetypes]
|
||||||
|
|
||||||
The `iterator_archetype` class constructs a minimal implementation of
|
The `iterator_archetype` class constructs a minimal implementation of
|
||||||
@ -155,4 +156,5 @@ the iterator concept specified by `AccessCategory` and
|
|||||||
arguments. `iterator_archetype` does not model any other access
|
arguments. `iterator_archetype` does not model any other access
|
||||||
concepts or any more derived traversal concepts.
|
concepts or any more derived traversal concepts.
|
||||||
|
|
||||||
|
|
||||||
[endsect]
|
[endsect]
|
@ -4,7 +4,7 @@ The iterator concept checking classes provide a mechanism for a
|
|||||||
template to report better error messages when a user instantiates the
|
template to report better error messages when a user instantiates the
|
||||||
template with a type that does not meet the requirements of the
|
template with a type that does not meet the requirements of the
|
||||||
template. For an introduction to using concept checking classes, see
|
template. For an introduction to using concept checking classes, see
|
||||||
the documentation for the _concept_check_ library.
|
the documentation for the boost::concept_check library.
|
||||||
|
|
||||||
[h2 `iterator_concepts.hpp` Synopsis]
|
[h2 `iterator_concepts.hpp` Synopsis]
|
||||||
|
|
||||||
|
@ -1,8 +1,9 @@
|
|||||||
|
|
||||||
[section:concepts Iterator Concepts]
|
[section:concepts Iterator Concepts]
|
||||||
|
|
||||||
[section:access Access]
|
[section:concepts_access Access]
|
||||||
|
|
||||||
[section:readable Readable Iterator Concept]
|
[h2 Readable Iterator Concept]
|
||||||
|
|
||||||
A class or built-in type `X` models the *Readable Iterator* concept
|
A class or built-in type `X` models the *Readable Iterator* concept
|
||||||
for value type `T` if, in addition to `X` being Assignable and
|
for value type `T` if, in addition to `X` being Assignable and
|
||||||
@ -33,9 +34,8 @@ type `T`.
|
|||||||
]
|
]
|
||||||
]
|
]
|
||||||
|
|
||||||
[endsect]
|
[h2 Writable Iterator Concept ]
|
||||||
|
|
||||||
[section:writable Writable Iterator Concept]
|
|
||||||
|
|
||||||
A class or built-in type `X` models the *Writable Iterator* concept
|
A class or built-in type `X` models the *Writable Iterator* concept
|
||||||
if, in addition to `X` being Copy Constructible, the following
|
if, in addition to `X` being Copy Constructible, the following
|
||||||
@ -55,9 +55,7 @@ Iterators have an associated *set of value types*.
|
|||||||
]
|
]
|
||||||
]
|
]
|
||||||
|
|
||||||
[endsect]
|
[h2 Swappable Iterator Concept]
|
||||||
|
|
||||||
[section:swappable Swappable Iterator Concept]
|
|
||||||
|
|
||||||
A class or built-in type `X` models the *Swappable Iterator* concept
|
A class or built-in type `X` models the *Swappable Iterator* concept
|
||||||
if, in addition to `X` being Copy Constructible, the following
|
if, in addition to `X` being Copy Constructible, the following
|
||||||
@ -79,9 +77,7 @@ expressions are valid and respect the stated semantics.
|
|||||||
[blurb *Note:* An iterator that is a model of the *Readable* and *Writable Iterator* concepts
|
[blurb *Note:* An iterator that is a model of the *Readable* and *Writable Iterator* concepts
|
||||||
is also a model of *Swappable Iterator*. *--end note*]
|
is also a model of *Swappable Iterator*. *--end note*]
|
||||||
|
|
||||||
[endsect]
|
[h2 Lvalue Iterator Concept]
|
||||||
|
|
||||||
[section:lvalue Lvalue Iterator Concept]
|
|
||||||
|
|
||||||
The *Lvalue Iterator* concept adds the requirement that the return
|
The *Lvalue Iterator* concept adds the requirement that the return
|
||||||
type of `operator*` type be a reference to the value type of the
|
type of `operator*` type be a reference to the value type of the
|
||||||
@ -105,17 +101,17 @@ iterator.
|
|||||||
|
|
||||||
[endsect]
|
[endsect]
|
||||||
|
|
||||||
[endsect]
|
[section:concepts_traversal Traversal]
|
||||||
|
|
||||||
[section:traversal Traversal]
|
[h2 Incrementable Iterator Concept]
|
||||||
|
|
||||||
[section:incrementable Incrementable Iterator Concept]
|
|
||||||
|
|
||||||
A class or built-in type `X` models the *Incrementable Iterator*
|
A class or built-in type `X` models the *Incrementable Iterator*
|
||||||
concept if, in addition to `X` being Assignable and Copy
|
concept if, in addition to `X` being Assignable and Copy
|
||||||
Constructible, the following expressions are valid and respect the
|
Constructible, the following expressions are valid and respect the
|
||||||
stated semantics.
|
stated semantics.
|
||||||
|
|
||||||
|
|
||||||
[table Incrementable Iterator Requirements (in addition to Assignable, Copy Constructible)
|
[table Incrementable Iterator Requirements (in addition to Assignable, Copy Constructible)
|
||||||
[
|
[
|
||||||
[Expression ]
|
[Expression ]
|
||||||
@ -145,9 +141,7 @@ stated semantics.
|
|||||||
]
|
]
|
||||||
]
|
]
|
||||||
|
|
||||||
[endsect]
|
[h2 Single Pass Iterator Concept]
|
||||||
|
|
||||||
[section:single_pass Single Pass Iterator Concept]
|
|
||||||
|
|
||||||
A class or built-in type `X` models the *Single Pass Iterator*
|
A class or built-in type `X` models the *Single Pass Iterator*
|
||||||
concept if the following expressions are valid and respect the stated
|
concept if the following expressions are valid and respect the stated
|
||||||
@ -162,7 +156,7 @@ semantics.
|
|||||||
[
|
[
|
||||||
[`++r`]
|
[`++r`]
|
||||||
[`X&`]
|
[`X&`]
|
||||||
[pre:[br]`r` is dereferenceable;[br]post:[br]`r` is dereferenceable or[br]`r` is past-the-end]
|
[pre:\n`r` is dereferenceable;\npost:\n`r` is dereferenceable or\n`r` is past-the-end]
|
||||||
]
|
]
|
||||||
[
|
[
|
||||||
[`a == b`]
|
[`a == b`]
|
||||||
@ -174,11 +168,6 @@ semantics.
|
|||||||
[convertible to `bool`]
|
[convertible to `bool`]
|
||||||
[`!(a == b)`]
|
[`!(a == b)`]
|
||||||
]
|
]
|
||||||
[
|
|
||||||
[`iterator_traits<X>::difference_type`]
|
|
||||||
[A signed integral type representing the distance between iterators]
|
|
||||||
[]
|
|
||||||
]
|
|
||||||
[
|
[
|
||||||
[`iterator_traversal<X>::type`]
|
[`iterator_traversal<X>::type`]
|
||||||
[Convertible to`single_pass_traversal_tag`]
|
[Convertible to`single_pass_traversal_tag`]
|
||||||
@ -186,9 +175,8 @@ semantics.
|
|||||||
]
|
]
|
||||||
]
|
]
|
||||||
|
|
||||||
[endsect]
|
|
||||||
|
|
||||||
[section:forward Forward Traversal Concept]
|
[h2 Forward Traversal Concept]
|
||||||
|
|
||||||
A class or built-in type `X` models the *Forward Traversal*
|
A class or built-in type `X` models the *Forward Traversal*
|
||||||
concept if, in addition to `X` meeting the requirements of Default
|
concept if, in addition to `X` meeting the requirements of Default
|
||||||
@ -211,6 +199,11 @@ valid and respect the stated semantics.
|
|||||||
[`X&`]
|
[`X&`]
|
||||||
[`r == s` and `r` is dereferenceable implies `++r == ++s.`]
|
[`r == s` and `r` is dereferenceable implies `++r == ++s.`]
|
||||||
]
|
]
|
||||||
|
[
|
||||||
|
[`iterator_traits<X>::difference_type`]
|
||||||
|
[A signed integral type representing the distance between iterators]
|
||||||
|
[]
|
||||||
|
]
|
||||||
[
|
[
|
||||||
[`iterator_traversal<X>::type`]
|
[`iterator_traversal<X>::type`]
|
||||||
[Convertible to `forward_traversal_tag`]
|
[Convertible to `forward_traversal_tag`]
|
||||||
@ -218,9 +211,7 @@ valid and respect the stated semantics.
|
|||||||
]
|
]
|
||||||
]
|
]
|
||||||
|
|
||||||
[endsect]
|
[h2 Bidirectional Traversal Concept]
|
||||||
|
|
||||||
[section:bidirectional Bidirectional Traversal Concept]
|
|
||||||
|
|
||||||
A class or built-in type `X` models the *Bidirectional Traversal*
|
A class or built-in type `X` models the *Bidirectional Traversal*
|
||||||
concept if, in addition to `X` meeting the requirements of Forward
|
concept if, in addition to `X` meeting the requirements of Forward
|
||||||
@ -236,7 +227,7 @@ the stated semantics.
|
|||||||
[
|
[
|
||||||
[`--r`]
|
[`--r`]
|
||||||
[`X&`]
|
[`X&`]
|
||||||
[pre: there exists `s` such that `r == ++s`.[br] post: `s` is dereferenceable. `--(++r) == r`. `--r == --s` implies `r == s`. `&r == &--r`.]
|
[pre: there exists `s` such that `r == ++s`.\n post: `s` is dereferenceable. `--(++r) == r`. `--r == --s` implies `r == s`. `&r == &--r`.]
|
||||||
]
|
]
|
||||||
[
|
[
|
||||||
[`r--`]
|
[`r--`]
|
||||||
@ -256,9 +247,7 @@ the stated semantics.
|
|||||||
]
|
]
|
||||||
]
|
]
|
||||||
|
|
||||||
[endsect]
|
[h2 Random Access Traversal Concept]
|
||||||
|
|
||||||
[section:random_access Random Access Traversal Concept]
|
|
||||||
|
|
||||||
A class or built-in type `X` models the *Random Access Traversal*
|
A class or built-in type `X` models the *Random Access Traversal*
|
||||||
concept if the following expressions are valid and respect the stated
|
concept if the following expressions are valid and respect the stated
|
||||||
@ -325,13 +314,13 @@ constant object of type `Distance`.
|
|||||||
[pre: there exists a value `n` of `Distance` such that `a + n == b`. `b == a + (b - a)`.]
|
[pre: there exists a value `n` of `Distance` such that `a + n == b`. `b == a + (b - a)`.]
|
||||||
]
|
]
|
||||||
[
|
[
|
||||||
[`a[n]`]
|
[`a\[n\]`]
|
||||||
[convertible to T]
|
[convertible to T]
|
||||||
[`*(a + n)`]
|
[`*(a + n)`]
|
||||||
[pre: a is a *Readable Iterator*]
|
[pre: a is a *Readable Iterator*]
|
||||||
]
|
]
|
||||||
[
|
[
|
||||||
[`a[n] = v`]
|
[`a\[n\] = v`]
|
||||||
[convertible to T]
|
[convertible to T]
|
||||||
[`*(a + n) = v`]
|
[`*(a + n) = v`]
|
||||||
[pre: a is a *Writable iterator*]
|
[pre: a is a *Writable iterator*]
|
||||||
@ -371,5 +360,3 @@ constant object of type `Distance`.
|
|||||||
[endsect]
|
[endsect]
|
||||||
|
|
||||||
[endsect]
|
[endsect]
|
||||||
|
|
||||||
[endsect]
|
|
||||||
|
@ -1,3 +1,4 @@
|
|||||||
|
|
||||||
[section:counting Counting Iterator]
|
[section:counting Counting Iterator]
|
||||||
|
|
||||||
A `counting_iterator` adapts an object by adding an `operator*` that
|
A `counting_iterator` adapts an object by adding an `operator*` that
|
||||||
@ -35,12 +36,10 @@ into the first array via indirection through the second array.
|
|||||||
|
|
||||||
The output is:
|
The output is:
|
||||||
|
|
||||||
[pre
|
|
||||||
indirectly printing out the numbers from 0 to 7
|
indirectly printing out the numbers from 0 to 7
|
||||||
0 1 2 3 4 5 6
|
0 1 2 3 4 5 6
|
||||||
]
|
|
||||||
|
|
||||||
The source code for this example can be found [example_link counting_iterator_example.cpp..here].
|
The source code for this example can be found [@../example/counting_iterator_example.cpp here].
|
||||||
|
|
||||||
[h2 Reference]
|
[h2 Reference]
|
||||||
|
|
||||||
@ -153,7 +152,7 @@ operations.
|
|||||||
|
|
||||||
counting_iterator();
|
counting_iterator();
|
||||||
|
|
||||||
[*Requires: ] `Incrementable` is Default Constructible.[br]
|
[*Requires: ] `Incrementable` is Default Constructible.\n
|
||||||
[*Effects: ] Default construct the member `m_inc`.
|
[*Effects: ] Default construct the member `m_inc`.
|
||||||
|
|
||||||
|
|
||||||
@ -175,13 +174,13 @@ operations.
|
|||||||
|
|
||||||
counting_iterator& operator++();
|
counting_iterator& operator++();
|
||||||
|
|
||||||
[*Effects: ] `++m_inc`[br]
|
[*Effects: ] `++m_inc`\n
|
||||||
[*Returns: ] `*this`
|
[*Returns: ] `*this`
|
||||||
|
|
||||||
|
|
||||||
counting_iterator& operator--();
|
counting_iterator& operator--();
|
||||||
|
|
||||||
[*Effects: ] `--m_inc`[br]
|
[*Effects: ] `--m_inc`\n
|
||||||
[*Returns: ] `*this`
|
[*Returns: ] `*this`
|
||||||
|
|
||||||
|
|
||||||
|
@ -1,3 +1,4 @@
|
|||||||
|
|
||||||
[section:facade Iterator Facade]
|
[section:facade Iterator Facade]
|
||||||
|
|
||||||
While the iterator interface is rich, there is a core subset of the
|
While the iterator interface is rich, there is a core subset of the
|
||||||
@ -67,7 +68,6 @@ requirements.
|
|||||||
[
|
[
|
||||||
[`i.dereference()`]
|
[`i.dereference()`]
|
||||||
[Access the value referred to]
|
[Access the value referred to]
|
||||||
]
|
|
||||||
[
|
[
|
||||||
[`i.equal(j)`]
|
[`i.equal(j)`]
|
||||||
[Compare for equality with `j`]
|
[Compare for equality with `j`]
|
||||||
@ -83,7 +83,6 @@ requirements.
|
|||||||
[
|
[
|
||||||
[`i.advance(n)`]
|
[`i.advance(n)`]
|
||||||
[Advance by `n` positions]
|
[Advance by `n` positions]
|
||||||
]
|
|
||||||
[
|
[
|
||||||
[`i.distance_to(j)`]
|
[`i.distance_to(j)`]
|
||||||
[Measure the distance to `j`]
|
[Measure the distance to `j`]
|
||||||
@ -140,7 +139,7 @@ standardize the gateway protocol. Note that even if
|
|||||||
open a safety loophole, as every core member function preserves the
|
open a safety loophole, as every core member function preserves the
|
||||||
invariants of the iterator.
|
invariants of the iterator.
|
||||||
|
|
||||||
[h2 `operator[]`]
|
[h2 `operator\[\]`]
|
||||||
|
|
||||||
The indexing operator for a generalized iterator presents special
|
The indexing operator for a generalized iterator presents special
|
||||||
challenges. A random access iterator's `operator[]` is only
|
challenges. A random access iterator's `operator[]` is only
|
||||||
@ -166,9 +165,9 @@ the implementation of her iterator is free to implement an
|
|||||||
class; it will hide the one supplied by `iterator_facade` from
|
class; it will hide the one supplied by `iterator_facade` from
|
||||||
clients of her iterator.
|
clients of her iterator.
|
||||||
|
|
||||||
.. _n1550: http://www.open-std.org/JTC1/SC22/WG21/docs/papers/2003/n1550.htm
|
.. _n1550: http://anubis.dkuug.dk/JTC1/SC22/WG21/docs/papers/2003/n1550.html
|
||||||
|
|
||||||
.. _`issue 299`: http://www.open-std.org/jtc1/sc22/wg21/docs/lwg-active.html#299
|
.. _`issue 299`: http://anubis.dkuug.dk/jtc1/sc22/wg21/docs/lwg-active.html#299
|
||||||
|
|
||||||
.. _`operator arrow`:
|
.. _`operator arrow`:
|
||||||
|
|
||||||
@ -288,7 +287,7 @@ The `iterator_category` member of `iterator_facade` is
|
|||||||
|
|
||||||
.. parsed-literal::
|
.. parsed-literal::
|
||||||
|
|
||||||
*iterator-category*\ (CategoryOrTraversal, reference, value_type)
|
*iterator-category*\ (CategoryOrTraversal, value_type, reference)
|
||||||
|
|
||||||
where *iterator-category* is defined as follows:
|
where *iterator-category* is defined as follows:
|
||||||
|
|
||||||
@ -489,7 +488,6 @@ w.m)` for some temporary object `w` of type `value_type`.
|
|||||||
|
|
||||||
[*Returns:]
|
[*Returns:]
|
||||||
|
|
||||||
[pre
|
|
||||||
if `is_convertible<Dr2,Dr1>::value`
|
if `is_convertible<Dr2,Dr1>::value`
|
||||||
|
|
||||||
then
|
then
|
||||||
@ -497,7 +495,6 @@ w.m)` for some temporary object `w` of type `value_type`.
|
|||||||
|
|
||||||
Otherwise,
|
Otherwise,
|
||||||
`((Dr2 const&)rhs).equal((Dr1 const&)lhs)`.
|
`((Dr2 const&)rhs).equal((Dr1 const&)lhs)`.
|
||||||
]
|
|
||||||
|
|
||||||
|
|
||||||
template <class Dr1, class V1, class TC1, class R1, class D1,
|
template <class Dr1, class V1, class TC1, class R1, class D1,
|
||||||
@ -508,7 +505,6 @@ w.m)` for some temporary object `w` of type `value_type`.
|
|||||||
|
|
||||||
[*Returns:]
|
[*Returns:]
|
||||||
|
|
||||||
[pre
|
|
||||||
if `is_convertible<Dr2,Dr1>::value`
|
if `is_convertible<Dr2,Dr1>::value`
|
||||||
|
|
||||||
then
|
then
|
||||||
@ -516,7 +512,6 @@ w.m)` for some temporary object `w` of type `value_type`.
|
|||||||
|
|
||||||
Otherwise,
|
Otherwise,
|
||||||
`!((Dr2 const&)rhs).equal((Dr1 const&)lhs)`.
|
`!((Dr2 const&)rhs).equal((Dr1 const&)lhs)`.
|
||||||
]
|
|
||||||
|
|
||||||
|
|
||||||
template <class Dr1, class V1, class TC1, class R1, class D1,
|
template <class Dr1, class V1, class TC1, class R1, class D1,
|
||||||
@ -527,7 +522,6 @@ w.m)` for some temporary object `w` of type `value_type`.
|
|||||||
|
|
||||||
[*Returns:]
|
[*Returns:]
|
||||||
|
|
||||||
[pre
|
|
||||||
if `is_convertible<Dr2,Dr1>::value`
|
if `is_convertible<Dr2,Dr1>::value`
|
||||||
|
|
||||||
then
|
then
|
||||||
@ -535,7 +529,6 @@ w.m)` for some temporary object `w` of type `value_type`.
|
|||||||
|
|
||||||
Otherwise,
|
Otherwise,
|
||||||
`((Dr2 const&)rhs).distance_to((Dr1 const&)lhs) > 0`.
|
`((Dr2 const&)rhs).distance_to((Dr1 const&)lhs) > 0`.
|
||||||
]
|
|
||||||
|
|
||||||
|
|
||||||
template <class Dr1, class V1, class TC1, class R1, class D1,
|
template <class Dr1, class V1, class TC1, class R1, class D1,
|
||||||
@ -546,7 +539,6 @@ w.m)` for some temporary object `w` of type `value_type`.
|
|||||||
|
|
||||||
[*Returns:]
|
[*Returns:]
|
||||||
|
|
||||||
[pre
|
|
||||||
if `is_convertible<Dr2,Dr1>::value`
|
if `is_convertible<Dr2,Dr1>::value`
|
||||||
|
|
||||||
then
|
then
|
||||||
@ -554,7 +546,6 @@ w.m)` for some temporary object `w` of type `value_type`.
|
|||||||
|
|
||||||
Otherwise,
|
Otherwise,
|
||||||
`((Dr2 const&)rhs).distance_to((Dr1 const&)lhs) >= 0`.
|
`((Dr2 const&)rhs).distance_to((Dr1 const&)lhs) >= 0`.
|
||||||
]
|
|
||||||
|
|
||||||
|
|
||||||
template <class Dr1, class V1, class TC1, class R1, class D1,
|
template <class Dr1, class V1, class TC1, class R1, class D1,
|
||||||
@ -565,7 +556,6 @@ w.m)` for some temporary object `w` of type `value_type`.
|
|||||||
|
|
||||||
[*Returns:]
|
[*Returns:]
|
||||||
|
|
||||||
[pre
|
|
||||||
if `is_convertible<Dr2,Dr1>::value`
|
if `is_convertible<Dr2,Dr1>::value`
|
||||||
|
|
||||||
then
|
then
|
||||||
@ -573,7 +563,6 @@ w.m)` for some temporary object `w` of type `value_type`.
|
|||||||
|
|
||||||
Otherwise,
|
Otherwise,
|
||||||
`((Dr2 const&)rhs).distance_to((Dr1 const&)lhs) < 0`.
|
`((Dr2 const&)rhs).distance_to((Dr1 const&)lhs) < 0`.
|
||||||
]
|
|
||||||
|
|
||||||
|
|
||||||
template <class Dr1, class V1, class TC1, class R1, class D1,
|
template <class Dr1, class V1, class TC1, class R1, class D1,
|
||||||
@ -584,7 +573,6 @@ w.m)` for some temporary object `w` of type `value_type`.
|
|||||||
|
|
||||||
[*Returns:]
|
[*Returns:]
|
||||||
|
|
||||||
[pre
|
|
||||||
if `is_convertible<Dr2,Dr1>::value`
|
if `is_convertible<Dr2,Dr1>::value`
|
||||||
|
|
||||||
then
|
then
|
||||||
@ -592,7 +580,6 @@ w.m)` for some temporary object `w` of type `value_type`.
|
|||||||
|
|
||||||
Otherwise,
|
Otherwise,
|
||||||
`((Dr2 const&)rhs).distance_to((Dr1 const&)lhs) <= 0`.
|
`((Dr2 const&)rhs).distance_to((Dr1 const&)lhs) <= 0`.
|
||||||
]
|
|
||||||
|
|
||||||
.. _minus:
|
.. _minus:
|
||||||
|
|
||||||
@ -605,7 +592,6 @@ w.m)` for some temporary object `w` of type `value_type`.
|
|||||||
|
|
||||||
[*Return Type:]
|
[*Return Type:]
|
||||||
|
|
||||||
[pre
|
|
||||||
if `is_convertible<Dr2,Dr1>::value`
|
if `is_convertible<Dr2,Dr1>::value`
|
||||||
|
|
||||||
then
|
then
|
||||||
@ -614,11 +600,9 @@ w.m)` for some temporary object `w` of type `value_type`.
|
|||||||
|
|
||||||
Otherwise
|
Otherwise
|
||||||
`difference` shall be `iterator_traits<Dr2>::difference_type`
|
`difference` shall be `iterator_traits<Dr2>::difference_type`
|
||||||
]
|
|
||||||
|
|
||||||
[*Returns:]
|
[*Returns:]
|
||||||
|
|
||||||
[pre
|
|
||||||
if `is_convertible<Dr2,Dr1>::value`
|
if `is_convertible<Dr2,Dr1>::value`
|
||||||
|
|
||||||
then
|
then
|
||||||
@ -626,7 +610,6 @@ w.m)` for some temporary object `w` of type `value_type`.
|
|||||||
|
|
||||||
Otherwise,
|
Otherwise,
|
||||||
`((Dr2 const&)rhs).distance_to((Dr1 const&)lhs)`.
|
`((Dr2 const&)rhs).distance_to((Dr1 const&)lhs)`.
|
||||||
]
|
|
||||||
|
|
||||||
|
|
||||||
[endsect]
|
[endsect]
|
||||||
|
@ -1,3 +1,4 @@
|
|||||||
|
|
||||||
[section:facade_tutorial Tutorial]
|
[section:facade_tutorial Tutorial]
|
||||||
|
|
||||||
In this section we'll walk through the implementation of a few
|
In this section we'll walk through the implementation of a few
|
||||||
@ -254,23 +255,23 @@ make them private and grant friendship to
|
|||||||
|
|
||||||
Voila; a complete and conforming readable, forward-traversal
|
Voila; a complete and conforming readable, forward-traversal
|
||||||
iterator! For a working example of its use, see
|
iterator! For a working example of its use, see
|
||||||
[example_link node_iterator1.cpp..this program].
|
[@../example/node_iterator1.cpp `this program`].
|
||||||
|
|
||||||
__ ../../example/node_iterator1.cpp
|
__ ../example/node_iterator1.cpp
|
||||||
|
|
||||||
[h2 A constant `node_iterator`]
|
[h2 A constant `node_iterator`]
|
||||||
|
|
||||||
[blurb *Constant and Mutable iterators*[br][br]
|
[blurb *Constant and Mutable iterators*\n\n
|
||||||
The term **mutable iterator** means an iterator through which
|
The term **mutable iterator** means an iterator through which
|
||||||
the object it references (its "referent") can be modified. A
|
the object it references (its "referent") can be modified. A
|
||||||
**constant iterator** is one which doesn't allow modification of
|
**constant iterator** is one which doesn't allow modification of
|
||||||
its referent.[br][br]
|
its referent.\n\n
|
||||||
The words *constant* and *mutable* don't refer to the ability to
|
The words *constant* and *mutable* don't refer to the ability to
|
||||||
modify the iterator itself. For example, an `int const*` is a
|
modify the iterator itself. For example, an `int const*` is a
|
||||||
non-\ `const` *constant iterator*, which can be incremented
|
non-\ `const` *constant iterator*, which can be incremented
|
||||||
but doesn't allow modification of its referent, and `int*
|
but doesn't allow modification of its referent, and `int*
|
||||||
const` is a `const` *mutable iterator*, which cannot be
|
const` is a `const` *mutable iterator*, which cannot be
|
||||||
modified but which allows modification of its referent.[br][br]
|
modified but which allows modification of its referent.\n\n
|
||||||
Confusing? We agree, but those are the standard terms. It
|
Confusing? We agree, but those are the standard terms. It
|
||||||
probably doesn't help much that a container's constant iterator
|
probably doesn't help much that a container's constant iterator
|
||||||
is called `const_iterator`.
|
is called `const_iterator`.
|
||||||
@ -284,7 +285,7 @@ changes:
|
|||||||
|
|
||||||
class const_node_iterator
|
class const_node_iterator
|
||||||
: public boost::iterator_facade<
|
: public boost::iterator_facade<
|
||||||
const_node_iterator
|
node_iterator
|
||||||
, node_base **const**
|
, node_base **const**
|
||||||
, boost::forward_traversal_tag
|
, boost::forward_traversal_tag
|
||||||
>
|
>
|
||||||
@ -311,7 +312,7 @@ changes:
|
|||||||
node_base **const**\ * m_node;
|
node_base **const**\ * m_node;
|
||||||
};
|
};
|
||||||
|
|
||||||
[blurb `const` and an iterator's `value_type`[br][br]
|
[blurb `const` and an iterator's `value_type`\n\n
|
||||||
The C++ standard requires an iterator's `value_type` *not* be
|
The C++ standard requires an iterator's `value_type` *not* be
|
||||||
`const`\ -qualified, so `iterator_facade` strips the
|
`const`\ -qualified, so `iterator_facade` strips the
|
||||||
`const` from its `Value` parameter in order to produce the
|
`const` from its `Value` parameter in order to produce the
|
||||||
@ -427,11 +428,11 @@ adding a templatized converting constructor [#broken]_ [#random]_:
|
|||||||
`distance_to` function as well.
|
`distance_to` function as well.
|
||||||
|
|
||||||
|
|
||||||
__ ../../example/node_iterator2.hpp
|
__ ../example/node_iterator2.hpp
|
||||||
|
|
||||||
You can see an example program which exercises our interoperable
|
You can see an example program which exercises our interoperable
|
||||||
iterators
|
iterators
|
||||||
[example_link node_iterator2.cpp..here].
|
[@../example/node_iterator2.cpp `here`].
|
||||||
|
|
||||||
|
|
||||||
[h2 Telling the Truth]
|
[h2 Telling the Truth]
|
||||||
|
@ -1,3 +1,4 @@
|
|||||||
|
|
||||||
[section:filter Filter Iterator]
|
[section:filter Filter Iterator]
|
||||||
|
|
||||||
The filter iterator adaptor creates a view of an iterator range in
|
The filter iterator adaptor creates a view of an iterator range in
|
||||||
@ -18,6 +19,7 @@ This example uses `filter_iterator` and then
|
|||||||
array of integers. Then `make_filter_iterator` is is used to output
|
array of integers. Then `make_filter_iterator` is is used to output
|
||||||
the integers greater than `-2`.
|
the integers greater than `-2`.
|
||||||
|
|
||||||
|
|
||||||
struct is_positive_number {
|
struct is_positive_number {
|
||||||
bool operator()(int x) { return 0 < x; }
|
bool operator()(int x) { return 0 < x; }
|
||||||
};
|
};
|
||||||
@ -50,11 +52,11 @@ the integers greater than `-2`.
|
|||||||
// Another example using make_filter_iterator()
|
// Another example using make_filter_iterator()
|
||||||
std::copy(
|
std::copy(
|
||||||
boost::make_filter_iterator(
|
boost::make_filter_iterator(
|
||||||
std::bind(std::greater<int>(), std::placeholders::_1, -2)
|
std::bind2nd(std::greater<int>(), -2)
|
||||||
, numbers, numbers + N)
|
, numbers, numbers + N)
|
||||||
|
|
||||||
, boost::make_filter_iterator(
|
, boost::make_filter_iterator(
|
||||||
std::bind(std::greater<int>(), std::placeholders::_1, -2)
|
std::bind2nd(std::greater<int>(), -2)
|
||||||
, numbers + N, numbers + N)
|
, numbers + N, numbers + N)
|
||||||
|
|
||||||
, std::ostream_iterator<int>(std::cout, " ")
|
, std::ostream_iterator<int>(std::cout, " ")
|
||||||
@ -68,13 +70,12 @@ the integers greater than `-2`.
|
|||||||
|
|
||||||
The output is:
|
The output is:
|
||||||
|
|
||||||
[pre
|
|
||||||
4 5 8
|
4 5 8
|
||||||
4 5 8
|
4 5 8
|
||||||
0 -1 4 5 8
|
0 -1 4 5 8
|
||||||
]
|
|
||||||
|
|
||||||
The source code for this example can be found [example_link filter_iterator_example.cpp..here].
|
|
||||||
|
The source code for this example can be found [@../example/filter_iterator_example.cpp here].
|
||||||
|
|
||||||
[h2 Reference]
|
[h2 Reference]
|
||||||
|
|
||||||
@ -177,7 +178,7 @@ operations.
|
|||||||
|
|
||||||
filter_iterator();
|
filter_iterator();
|
||||||
|
|
||||||
[*Requires: ]`Predicate` and `Iterator` must be Default Constructible.[br]
|
[*Requires: ]`Predicate` and `Iterator` must be Default Constructible.\n
|
||||||
[*Effects: ] Constructs a `filter_iterator` whose`m_pred`, `m_iter`, and `m_end`
|
[*Effects: ] Constructs a `filter_iterator` whose`m_pred`, `m_iter`, and `m_end`
|
||||||
members are a default constructed.
|
members are a default constructed.
|
||||||
|
|
||||||
@ -194,7 +195,7 @@ operations.
|
|||||||
filter_iterator(Iterator x, Iterator end = Iterator());
|
filter_iterator(Iterator x, Iterator end = Iterator());
|
||||||
|
|
||||||
[*Requires: ] `Predicate` must be Default Constructible and
|
[*Requires: ] `Predicate` must be Default Constructible and
|
||||||
`Predicate` is a class type (not a function pointer).[br]
|
`Predicate` is a class type (not a function pointer).\n
|
||||||
[*Effects: ] Constructs a `filter_iterator` where `m_iter` is either
|
[*Effects: ] Constructs a `filter_iterator` where `m_iter` is either
|
||||||
the first position in the range `[x,end)` such that `m_pred(*m_iter) == true`
|
the first position in the range `[x,end)` such that `m_pred(*m_iter) == true`
|
||||||
or else`m_iter == end`. The member `m_pred` is default constructed.
|
or else`m_iter == end`. The member `m_pred` is default constructed.
|
||||||
@ -204,9 +205,9 @@ operations.
|
|||||||
filter_iterator(
|
filter_iterator(
|
||||||
filter_iterator<Predicate, OtherIterator> const& t
|
filter_iterator<Predicate, OtherIterator> const& t
|
||||||
, typename enable_if_convertible<OtherIterator, Iterator>::type* = 0 // exposition
|
, typename enable_if_convertible<OtherIterator, Iterator>::type* = 0 // exposition
|
||||||
);
|
);`
|
||||||
|
|
||||||
[*Requires: ] `OtherIterator` is implicitly convertible to `Iterator`.[br]
|
[*Requires: ] `OtherIterator` is implicitly convertible to `Iterator`.\n
|
||||||
[*Effects: ] Constructs a filter iterator whose members are copied from `t`.
|
[*Effects: ] Constructs a filter iterator whose members are copied from `t`.
|
||||||
|
|
||||||
|
|
||||||
@ -234,7 +235,8 @@ operations.
|
|||||||
|
|
||||||
[*Effects: ] Increments `m_iter` and then continues to
|
[*Effects: ] Increments `m_iter` and then continues to
|
||||||
increment `m_iter` until either `m_iter == m_end`
|
increment `m_iter` until either `m_iter == m_end`
|
||||||
or `m_pred(*m_iter) == true`.[br]
|
or `m_pred(*m_iter) == true`.\n
|
||||||
[*Returns: ] `*this`
|
[*Returns: ] `*this`
|
||||||
|
|
||||||
|
|
||||||
[endsect]
|
[endsect]
|
@ -1,3 +1,4 @@
|
|||||||
|
|
||||||
[section:function_output Function Output Iterator]
|
[section:function_output Function Output Iterator]
|
||||||
|
|
||||||
The function output iterator adaptor makes it easier to create custom
|
The function output iterator adaptor makes it easier to create custom
|
||||||
|
@ -1,3 +1,4 @@
|
|||||||
|
|
||||||
[section:indirect Indirect Iterator]
|
[section:indirect Indirect Iterator]
|
||||||
|
|
||||||
`indirect_iterator` adapts an iterator by applying an
|
`indirect_iterator` adapts an iterator by applying an
|
||||||
@ -49,7 +50,7 @@ using the `make_indirect_iterator` helper function.
|
|||||||
const_indirect_last(pointers_to_chars + N);
|
const_indirect_last(pointers_to_chars + N);
|
||||||
|
|
||||||
std::transform(const_indirect_first, const_indirect_last,
|
std::transform(const_indirect_first, const_indirect_last,
|
||||||
mutable_indirect_first, std::bind(std::plus<char>(), 1, std::placeholders::_1));
|
mutable_indirect_first, std::bind1st(std::plus<char>(), 1));
|
||||||
|
|
||||||
std::copy(mutable_indirect_first, mutable_indirect_last,
|
std::copy(mutable_indirect_first, mutable_indirect_last,
|
||||||
std::ostream_iterator<char>(std::cout, ","));
|
std::ostream_iterator<char>(std::cout, ","));
|
||||||
@ -66,14 +67,13 @@ using the `make_indirect_iterator` helper function.
|
|||||||
|
|
||||||
The output is:
|
The output is:
|
||||||
|
|
||||||
[pre
|
|
||||||
a,b,c,d,e,f,g,
|
a,b,c,d,e,f,g,
|
||||||
b,c,d,e,f,g,h,
|
b,c,d,e,f,g,h,
|
||||||
a,b,c,d,e,f,g,
|
a,b,c,d,e,f,g,
|
||||||
]
|
|
||||||
|
|
||||||
The source code for this example can be found
|
The source code for this example can be found
|
||||||
[example_link indirect_iterator_example.cpp..here].
|
[@../example/indirect_iterator_example.cpp here].
|
||||||
|
|
||||||
|
|
||||||
[h2 Reference]
|
[h2 Reference]
|
||||||
@ -203,7 +203,7 @@ following operations:
|
|||||||
|
|
||||||
indirect_iterator();
|
indirect_iterator();
|
||||||
|
|
||||||
[*Requires: ] `Iterator` must be Default Constructible.[br]
|
[*Requires: ] `Iterator` must be Default Constructible.\n
|
||||||
[*Effects: ] Constructs an instance of `indirect_iterator` with
|
[*Effects: ] Constructs an instance of `indirect_iterator` with
|
||||||
a default-constructed `m_iterator`.
|
a default-constructed `m_iterator`.
|
||||||
|
|
||||||
@ -225,7 +225,7 @@ following operations:
|
|||||||
, typename enable_if_convertible<Iterator2, Iterator>::type* = 0 // exposition
|
, typename enable_if_convertible<Iterator2, Iterator>::type* = 0 // exposition
|
||||||
);
|
);
|
||||||
|
|
||||||
[*Requires: ] `Iterator2` is implicitly convertible to `Iterator`.[br]
|
[*Requires: ] `Iterator2` is implicitly convertible to `Iterator`.\n
|
||||||
[*Effects: ] Constructs an instance of `indirect_iterator` whose
|
[*Effects: ] Constructs an instance of `indirect_iterator` whose
|
||||||
`m_iterator` subobject is constructed from `y.base()`.
|
`m_iterator` subobject is constructed from `y.base()`.
|
||||||
|
|
||||||
@ -242,13 +242,13 @@ following operations:
|
|||||||
|
|
||||||
indirect_iterator& operator++();
|
indirect_iterator& operator++();
|
||||||
|
|
||||||
[*Effects: ] `++m_iterator`[br]
|
[*Effects: ] `++m_iterator`\n
|
||||||
[*Returns: ] `*this`
|
[*Returns: ] `*this`
|
||||||
|
|
||||||
|
|
||||||
indirect_iterator& operator--();
|
indirect_iterator& operator--();
|
||||||
|
|
||||||
[*Effects: ] `--m_iterator`[br]
|
[*Effects: ] `--m_iterator`\n
|
||||||
[*Returns: ] `*this`
|
[*Returns: ] `*this`
|
||||||
|
|
||||||
[endsect]
|
[endsect]
|
@ -1,6 +1,6 @@
|
|||||||
|
|
||||||
[library Boost.Iterator
|
[library Boost.Iterator
|
||||||
[/ version 1.0.1]
|
[/ version 1.0.1]
|
||||||
[quickbook 1.6]
|
|
||||||
[authors [Abrahams, David], [Siek, Jeremy], [Witt, Thomas]]
|
[authors [Abrahams, David], [Siek, Jeremy], [Witt, Thomas]]
|
||||||
[copyright 2003 2005 David Abrahams Jeremy Siek Thomas Witt]
|
[copyright 2003 2005 David Abrahams Jeremy Siek Thomas Witt]
|
||||||
[category iterator]
|
[category iterator]
|
||||||
@ -28,11 +28,7 @@
|
|||||||
|
|
||||||
[/ Links ]
|
[/ Links ]
|
||||||
|
|
||||||
[def _iterator_ [@../../../iterator/doc/index.html Boost.Iterator]]
|
[def _iterator_ [@../../libs/iterator/doc/index.html Boost.Iterator]]
|
||||||
[def _concept_check_ [@../../../concept_check/index.html Boost.ConceptCheck]]
|
|
||||||
[template example_link[name descr]'''<ulink url="../../example/'''[name]'''">'''[descr]'''</ulink>''']
|
|
||||||
|
|
||||||
[template sub[x]'''<subscript>'''[x]'''</subscript>''']
|
|
||||||
|
|
||||||
[section:intro Introduction]
|
[section:intro Introduction]
|
||||||
|
|
||||||
@ -74,16 +70,12 @@ and a _GOTW_50_. New-style iterators go well beyond
|
|||||||
patching up `vector<bool>`, though: there are lots of other
|
patching up `vector<bool>`, though: there are lots of other
|
||||||
iterators already in use which can't be adequately represented by
|
iterators already in use which can't be adequately represented by
|
||||||
the existing concepts. For details about the new iterator
|
the existing concepts. For details about the new iterator
|
||||||
concepts, see our [@../new-iter-concepts.html Standard Proposal for New-Style Iterators].
|
concepts, see our [@./new-iter-concepts.html Standard Proposal for New-Style Iterators].
|
||||||
|
|
||||||
[h2 Iterator Facade and Adaptor]
|
[h2 Iterator Facade and Adaptor]
|
||||||
|
|
||||||
[/
|
[def _facade_ [@./iterator_facade.html facade]]
|
||||||
[def _facade_ [link iterator.generic.facade facade]]
|
[def _adaptor_ [@./iterator_adaptor.html adaptor]]
|
||||||
[def _adaptor_ [link iterator.generic.adaptor adaptor]]
|
|
||||||
]
|
|
||||||
[def _facade_ [@../iterator_facade.html facade]]
|
|
||||||
[def _adaptor_ [@../iterator_adaptor.html adaptor]]
|
|
||||||
|
|
||||||
Writing standard-conforming iterators is tricky, but the need comes
|
Writing standard-conforming iterators is tricky, but the need comes
|
||||||
up often. In order to ease the implementation of new iterators,
|
up often. In order to ease the implementation of new iterators,
|
||||||
@ -99,28 +91,26 @@ library supplies the _adaptor_ class template, which is specially
|
|||||||
designed to take advantage of as much of the underlying type's
|
designed to take advantage of as much of the underlying type's
|
||||||
behavior as possible.
|
behavior as possible.
|
||||||
|
|
||||||
Both _facade_ and _adaptor_ as well as many of the [link iterator.specialized specialized
|
Both _facade_ and _adaptor_ as well as many of the `specialized
|
||||||
adaptors] mentioned below have been proposed for standardization
|
adaptors`_ mentioned below have been proposed for standardization
|
||||||
([@../facade-and-adaptor.html Standard Proposal For Iterator Facade and Adaptor]).
|
([@./facade-and-adaptor.html Standard Proposal For Iterator Facade and Adaptor]).
|
||||||
|
|
||||||
[h2 Specialized Adaptors]
|
[h2 Specialized Adaptors]
|
||||||
|
|
||||||
The iterator library supplies a useful suite of standard-conforming
|
The iterator library supplies a useful suite of standard-conforming
|
||||||
iterator templates based on the Boost [link
|
iterator templates based on the Boost [link
|
||||||
iterator.intro.iterator_facade_and_adaptor iterator facade and adaptor]
|
intro.iterator_facade_and_adaptor iterator facade and adaptor]
|
||||||
templates.
|
templates.
|
||||||
|
|
||||||
[def _counting_ [link iterator.specialized.counting `counting_iterator`]]
|
[def _counting_ [@./counting_iterator.html `counting_iterator`]]
|
||||||
[def _filter_ [link iterator.specialized.filter `filter_iterator`]]
|
[def _filter_ [@./filter_iterator.html `filter_iterator`]]
|
||||||
[def _function_input_ [@../function_input_iterator.html `function_input_iterator`]]
|
[def _function_ [@./function_output_iterator.html `function_output_iterator`]]
|
||||||
[def _function_output_ [link iterator.specialized.function_output `function_output_iterator`]]
|
[def _indirect_ [@./indirect_iterator.html `indirect_iterator`]]
|
||||||
[def _generator_ [@../generator_iterator.htm `generator_iterator`]]
|
[def _permutation_ [@./permutation_iterator.html `permutation_iterator`]]
|
||||||
[def _indirect_ [link iterator.specialized.indirect `indirect_iterator`]]
|
[def _reverse_ [@./reverse_iterator.html `reverse_iterator`]]
|
||||||
[def _permutation_ [link iterator.specialized.permutation `permutation_iterator`]]
|
[def _shared_ [@./shared_container_iterator.html `shared_container_iterator`]]
|
||||||
[def _reverse_ [link iterator.specialized.reverse `reverse_iterator`]]
|
[def _transform_ [@./transform_iterator.html `transform_iterator`]]
|
||||||
[def _shared_ [link iterator.specialized.shared_container `shared_container_iterator`]]
|
[def _zip_ [@./zip_iterator.html `zip_iterator`]]
|
||||||
[def _transform_ [link iterator.specialized.transform `transform_iterator`]]
|
|
||||||
[def _zip_ [link iterator.specialized.zip `zip_iterator`]]
|
|
||||||
|
|
||||||
[def _shared_ptr_ [@../../smart_ptr/shared_ptr.htm `shared_ptr`]]
|
[def _shared_ptr_ [@../../smart_ptr/shared_ptr.htm `shared_ptr`]]
|
||||||
|
|
||||||
@ -130,18 +120,10 @@ templates.
|
|||||||
* _filter_: an iterator over the subset of elements of some
|
* _filter_: an iterator over the subset of elements of some
|
||||||
sequence which satisfy a given predicate
|
sequence which satisfy a given predicate
|
||||||
|
|
||||||
* _function_input_: an input iterator wrapping a generator (nullary
|
* _function_: an output iterator wrapping a unary function
|
||||||
function object); each time the iterator is dereferenced, the function object
|
|
||||||
is called to get the value to return.
|
|
||||||
|
|
||||||
* _function_output_: an output iterator wrapping a unary function
|
|
||||||
object; each time an element is written into the dereferenced
|
object; each time an element is written into the dereferenced
|
||||||
iterator, it is passed as a parameter to the function object.
|
iterator, it is passed as a parameter to the function object.
|
||||||
|
|
||||||
* _generator_: an input iterator wrapping a generator (nullary
|
|
||||||
function object); each time the iterator is dereferenced, the function object
|
|
||||||
is called to get the value to return. An outdated analogue of _function_input_.
|
|
||||||
|
|
||||||
* _indirect_: an iterator over the objects *pointed-to* by the
|
* _indirect_: an iterator over the objects *pointed-to* by the
|
||||||
elements of some sequence.
|
elements of some sequence.
|
||||||
|
|
||||||
@ -150,7 +132,7 @@ templates.
|
|||||||
|
|
||||||
* _reverse_: an iterator which traverses the elements of some
|
* _reverse_: an iterator which traverses the elements of some
|
||||||
bidirectional sequence in reverse. Corrects many of the
|
bidirectional sequence in reverse. Corrects many of the
|
||||||
shortcomings of C++98's `std::reverse_iterator`.
|
shortcomings of C++98's ``std::reverse_iterator``.
|
||||||
|
|
||||||
* _shared_: an iterator over elements of a container whose
|
* _shared_: an iterator over elements of a container whose
|
||||||
lifetime is maintained by a _shared_ptr_ stored in the iterator.
|
lifetime is maintained by a _shared_ptr_ stored in the iterator.
|
||||||
@ -158,7 +140,7 @@ templates.
|
|||||||
* _transform_: an iterator over elements which are the result of
|
* _transform_: an iterator over elements which are the result of
|
||||||
applying some functional transformation to the elements of an
|
applying some functional transformation to the elements of an
|
||||||
underlying sequence. This component also replaces the old
|
underlying sequence. This component also replaces the old
|
||||||
`projection_iterator_adaptor`.
|
``projection_iterator_adaptor``.
|
||||||
|
|
||||||
* _zip_: an iterator over tuples of the elements at corresponding
|
* _zip_: an iterator over tuples of the elements at corresponding
|
||||||
positions of heterogeneous underlying iterators.
|
positions of heterogeneous underlying iterators.
|
||||||
@ -167,9 +149,9 @@ templates.
|
|||||||
|
|
||||||
[h3 Traits]
|
[h3 Traits]
|
||||||
|
|
||||||
[def _pointee_ [link iterator.utilities.traits `pointee.hpp`]]
|
[def _pointee_ [@./pointee.html `pointee.hpp`]]
|
||||||
[def _iterator_traits_ [link iterator.utilities.iterator_traits `iterator_traits.hpp`]]
|
[def _iterator_traits_ [@./iterator_traits.html `iterator_traits.hpp`]]
|
||||||
[def _interoperable_ [@../interoperable.html `interoperable.hpp`]]
|
[def _interoperable_ [@./interoperable.html `interoperable.hpp`]]
|
||||||
[def _MPL_ [@../../mpl/doc/index.html [*MPL]]]
|
[def _MPL_ [@../../mpl/doc/index.html [*MPL]]]
|
||||||
|
|
||||||
* _pointee_: Provides the capability to deduce the referent types
|
* _pointee_: Provides the capability to deduce the referent types
|
||||||
@ -180,40 +162,19 @@ templates.
|
|||||||
retrieve an iterator's traits. Also corrects for the deficiencies
|
retrieve an iterator's traits. Also corrects for the deficiencies
|
||||||
of broken implementations of `std::iterator_traits`.
|
of broken implementations of `std::iterator_traits`.
|
||||||
|
|
||||||
[/
|
[\ * |interoperable|_ (PDF__): Provides an _MPL_ compatible metafunction for
|
||||||
* _interoperable_: Provides an _MPL_ compatible metafunction for
|
|
||||||
testing iterator interoperability
|
testing iterator interoperability
|
||||||
]
|
]
|
||||||
|
|
||||||
[h3 Testing and Concept Checking]
|
[h3 Testing and Concept Checking]
|
||||||
|
|
||||||
[def _iterator_concepts_ [link iterator.concepts `iterator_concepts.hpp`]]
|
[def _iterator_concepts_ [@./iterator_concepts.html `iterator_concepts.hpp`]]
|
||||||
[def _iterator_archetypes_ [link iterator.utilities.archetypes `iterator_archetypes.hpp`]]
|
[def _iterator_archetypes_ [@./iterator_archetypes.html `iterator_archetypes.hpp`]]
|
||||||
|
|
||||||
* _iterator_concepts_: Concept checking classes for the new iterator concepts.
|
* _iterator_concepts_: Concept checking classes for the new iterator concepts.
|
||||||
|
|
||||||
* _iterator_archetypes_: Concept archetype classes for the new iterators concepts.
|
* _iterator_archetypes_: Concept archetype classes for the new iterators concepts.
|
||||||
|
|
||||||
[h2 Iterator Algorithms]
|
|
||||||
|
|
||||||
The library provides a number of generic algorithms for use with iterators. These
|
|
||||||
algorithms take advantage of the new concepts defined by the library to provide
|
|
||||||
better performance and functionality.
|
|
||||||
|
|
||||||
[def _advance_ [link iterator.algorithms.advance `advance.hpp`]]
|
|
||||||
[def _distance_ [link iterator.algorithms.distance `distance.hpp`]]
|
|
||||||
[def _next_prior_ [link iterator.algorithms.next_prior `next_prior.hpp`]]
|
|
||||||
|
|
||||||
* _advance_: Provides `advance()` function for advancing an iterator a given number
|
|
||||||
of positions forward or backward.
|
|
||||||
|
|
||||||
* _distance_: Provides `distance()` function for computing distance between two
|
|
||||||
iterators.
|
|
||||||
|
|
||||||
* _next_prior_: Provides `next()` and `prior()` functions for obtaining
|
|
||||||
next and prior iterators to a given iterator. The functions are also compatible
|
|
||||||
with non-iterator types.
|
|
||||||
|
|
||||||
[endsect]
|
[endsect]
|
||||||
|
|
||||||
[include concepts.qbk]
|
[include concepts.qbk]
|
||||||
@ -234,14 +195,12 @@ better performance and functionality.
|
|||||||
|
|
||||||
[include concept_checking.qbk]
|
[include concept_checking.qbk]
|
||||||
|
|
||||||
[include iterator_traits.qbk]
|
[include traits.qbk]
|
||||||
|
|
||||||
[include type_traits.qbk]
|
[include utilities.qbk]
|
||||||
|
|
||||||
[endsect]
|
[endsect]
|
||||||
|
|
||||||
[include algorithms.qbk]
|
|
||||||
|
|
||||||
[section:upgrading Upgrading from the old Boost Iterator Adaptor Library]
|
[section:upgrading Upgrading from the old Boost Iterator Adaptor Library]
|
||||||
|
|
||||||
[def _type_generator_ [@http://www.boost.org/more/generic_programming.html#type_generator type generator]]
|
[def _type_generator_ [@http://www.boost.org/more/generic_programming.html#type_generator type generator]]
|
||||||
@ -305,3 +264,5 @@ library you see today.
|
|||||||
Patterns, C++ Report, February 1995, pp. 24-27.]
|
Patterns, C++ Report, February 1995, pp. 24-27.]
|
||||||
|
|
||||||
[endsect]
|
[endsect]
|
||||||
|
|
||||||
|
|
@ -1,54 +0,0 @@
|
|||||||
[section:iterator_traits Iterator Traits]
|
|
||||||
|
|
||||||
`std::iterator_traits` provides access to five associated types
|
|
||||||
of any iterator: its `value_type`, `reference`, `pointer`,
|
|
||||||
`iterator_category`, and `difference_type`. Unfortunately,
|
|
||||||
such a "multi-valued" traits template can be difficult to use in a
|
|
||||||
metaprogramming context. `<boost/iterator/iterator_traits.hpp>`
|
|
||||||
provides access to these types using a standard metafunctions_.
|
|
||||||
|
|
||||||
[h2 Synopsis]
|
|
||||||
|
|
||||||
Header `<boost/iterator/iterator_traits.hpp>`:
|
|
||||||
|
|
||||||
template <class Iterator>
|
|
||||||
struct iterator_value
|
|
||||||
{
|
|
||||||
typedef typename
|
|
||||||
std::iterator_traits<Iterator>::value_type
|
|
||||||
type;
|
|
||||||
};
|
|
||||||
|
|
||||||
template <class Iterator>
|
|
||||||
struct iterator_reference
|
|
||||||
{
|
|
||||||
typedef typename
|
|
||||||
std::iterator_traits<Iterator>::reference
|
|
||||||
type;
|
|
||||||
};
|
|
||||||
|
|
||||||
template <class Iterator>
|
|
||||||
struct iterator_pointer
|
|
||||||
{
|
|
||||||
typedef typename
|
|
||||||
std::iterator_traits<Iterator>::pointer
|
|
||||||
type;
|
|
||||||
};
|
|
||||||
|
|
||||||
template <class Iterator>
|
|
||||||
struct iterator_difference
|
|
||||||
{
|
|
||||||
typedef typename
|
|
||||||
detail::iterator_traits<Iterator>::difference_type
|
|
||||||
type;
|
|
||||||
};
|
|
||||||
|
|
||||||
template <class Iterator>
|
|
||||||
struct iterator_category
|
|
||||||
{
|
|
||||||
typedef typename
|
|
||||||
detail::iterator_traits<Iterator>::iterator_category
|
|
||||||
type;
|
|
||||||
};
|
|
||||||
|
|
||||||
[endsect]
|
|
@ -1,3 +1,4 @@
|
|||||||
|
|
||||||
[section:permutation Permutation Iterator]
|
[section:permutation Permutation Iterator]
|
||||||
|
|
||||||
The permutation iterator adaptor provides a permuted view of a given
|
The permutation iterator adaptor provides a permuted view of a given
|
||||||
@ -74,17 +75,16 @@ past-the-end iterator to the indices.
|
|||||||
|
|
||||||
The output is:
|
The output is:
|
||||||
|
|
||||||
[pre
|
|
||||||
The original range is : 0 1 2 3 4 5 6 7 8 9
|
The original range is : 0 1 2 3 4 5 6 7 8 9
|
||||||
The reindexing scheme is : 9 8 7 6
|
The reindexing scheme is : 9 8 7 6
|
||||||
The permutated range is : 9 8 7 6
|
The permutated range is : 9 8 7 6
|
||||||
Elements at even indices in the permutation : 9 7
|
Elements at even indices in the permutation : 9 7
|
||||||
Permutation backwards : 6 7 8 9
|
Permutation backwards : 6 7 8 9
|
||||||
Iterate backward with stride 2 : 6 8
|
Iterate backward with stride 2 : 6 8
|
||||||
]
|
|
||||||
|
|
||||||
The source code for this example can be found
|
The source code for this example can be found
|
||||||
[example_link permutation_iter_example.cpp..here].
|
[@../example/permutation_iter_example.cpp here].
|
||||||
|
|
||||||
[h2 Reference]
|
[h2 Reference]
|
||||||
|
|
||||||
@ -189,7 +189,7 @@ following operations.
|
|||||||
|
|
||||||
permutation_iterator& operator++();
|
permutation_iterator& operator++();
|
||||||
|
|
||||||
[*Effects: ] `++m_order`[br]
|
[*Effects: ] `++m_order`\n
|
||||||
[*Returns: ] `*this`
|
[*Returns: ] `*this`
|
||||||
|
|
||||||
|
|
||||||
|
@ -1,3 +1,4 @@
|
|||||||
|
|
||||||
[section:reverse Reverse Iterator]
|
[section:reverse Reverse Iterator]
|
||||||
|
|
||||||
The reverse iterator adaptor iterates through the adapted iterator
|
The reverse iterator adaptor iterates through the adapted iterator
|
||||||
@ -8,6 +9,7 @@ range in the opposite direction.
|
|||||||
The following example prints an array of characters in reverse order
|
The following example prints an array of characters in reverse order
|
||||||
using `reverse_iterator`.
|
using `reverse_iterator`.
|
||||||
|
|
||||||
|
|
||||||
char letters_[] = "hello world!";
|
char letters_[] = "hello world!";
|
||||||
const int N = sizeof(letters_)/sizeof(char) - 1;
|
const int N = sizeof(letters_)/sizeof(char) - 1;
|
||||||
typedef char* base_iterator;
|
typedef char* base_iterator;
|
||||||
@ -33,14 +35,13 @@ using `reverse_iterator`.
|
|||||||
|
|
||||||
The output is:
|
The output is:
|
||||||
|
|
||||||
[pre
|
|
||||||
original sequence of letters: hello world!
|
original sequence of letters: hello world!
|
||||||
sequence in reverse order: !dlrow olleh
|
sequence in reverse order: !dlrow olleh
|
||||||
sequence in double-reversed (normal) order: hello world!
|
sequence in double-reversed (normal) order: hello world!
|
||||||
]
|
|
||||||
|
|
||||||
The source code for this example can be found
|
The source code for this example can be found
|
||||||
[example_link reverse_iterator_example.cpp..here].
|
[@../example/reverse_iterator_example.cpp here].
|
||||||
|
|
||||||
[h2 Reference]
|
[h2 Reference]
|
||||||
|
|
||||||
@ -114,7 +115,7 @@ operations.
|
|||||||
|
|
||||||
reverse_iterator();
|
reverse_iterator();
|
||||||
|
|
||||||
[*Requires: ] `Iterator` must be Default Constructible.[br]
|
[*Requires: ] `Iterator` must be Default Constructible.\n
|
||||||
[*Effects: ] Constructs an instance of `reverse_iterator` with `m_iterator`
|
[*Effects: ] Constructs an instance of `reverse_iterator` with `m_iterator`
|
||||||
default constructed.
|
default constructed.
|
||||||
|
|
||||||
@ -130,7 +131,7 @@ operations.
|
|||||||
, typename enable_if_convertible<OtherIterator, Iterator>::type* = 0 // exposition
|
, typename enable_if_convertible<OtherIterator, Iterator>::type* = 0 // exposition
|
||||||
);
|
);
|
||||||
|
|
||||||
[*Requires: ] `OtherIterator` is implicitly convertible to `Iterator`.[br]
|
[*Requires: ] `OtherIterator` is implicitly convertible to `Iterator`.\n
|
||||||
[*Effects: ] Constructs instance of `reverse_iterator` whose
|
[*Effects: ] Constructs instance of `reverse_iterator` whose
|
||||||
`m_iterator` subobject is constructed from `y.base()`.
|
`m_iterator` subobject is constructed from `y.base()`.
|
||||||
|
|
||||||
@ -148,12 +149,12 @@ operations.
|
|||||||
|
|
||||||
reverse_iterator& operator++();
|
reverse_iterator& operator++();
|
||||||
|
|
||||||
[*Effects: ] `--m_iterator`[br]
|
[*Effects: ] `--m_iterator`\n
|
||||||
[*Returns: ] `*this`
|
[*Returns: ] `*this`
|
||||||
|
|
||||||
reverse_iterator& operator--();
|
reverse_iterator& operator--();
|
||||||
|
|
||||||
[*Effects: ] `++m_iterator`[br]
|
[*Effects: ] `++m_iterator`\n
|
||||||
[*Returns: ] `*this`
|
[*Returns: ] `*this`
|
||||||
|
|
||||||
[endsect]
|
[endsect]
|
@ -1,3 +1,4 @@
|
|||||||
|
|
||||||
[section:shared_container Shared Container Iterator]
|
[section:shared_container Shared Container Iterator]
|
||||||
|
|
||||||
Defined in header [@../../../boost/shared_container_iterator.hpp `boost/shared_container_iterator.hpp`].
|
Defined in header [@../../../boost/shared_container_iterator.hpp `boost/shared_container_iterator.hpp`].
|
||||||
@ -55,7 +56,7 @@ original shared pointer `ints` ceases to exist after `set_range()`
|
|||||||
returns, the `shared_counter_iterator` objects maintain references to
|
returns, the `shared_counter_iterator` objects maintain references to
|
||||||
the underlying vector and thereby extend the container's lifetime.
|
the underlying vector and thereby extend the container's lifetime.
|
||||||
|
|
||||||
[example_link shared_iterator_example1.cpp..`shared_iterator_example1.cpp`]:
|
[@../../../libs/utility/shared_iterator_example1.cpp `shared_iterator_example1.cpp`]:
|
||||||
|
|
||||||
#include "shared_container_iterator.hpp"
|
#include "shared_container_iterator.hpp"
|
||||||
#include "boost/shared_ptr.hpp"
|
#include "boost/shared_ptr.hpp"
|
||||||
@ -96,9 +97,7 @@ the underlying vector and thereby extend the container's lifetime.
|
|||||||
|
|
||||||
The output from this part is:
|
The output from this part is:
|
||||||
|
|
||||||
[pre
|
|
||||||
0,1,2,3,4,5,
|
0,1,2,3,4,5,
|
||||||
]
|
|
||||||
|
|
||||||
[table Template Parameters
|
[table Template Parameters
|
||||||
[[Parameter][Description]]
|
[[Parameter][Description]]
|
||||||
@ -140,7 +139,7 @@ explicitly specifying its type.
|
|||||||
This example, similar to the previous,
|
This example, similar to the previous,
|
||||||
uses `make_shared_container_iterator()` to create the iterators.
|
uses `make_shared_container_iterator()` to create the iterators.
|
||||||
|
|
||||||
[example_link shared_iterator_example2.cpp..`shared_iterator_example2.cpp`]:
|
[@../../../libs/utility/shared_iterator_example2.cpp `shared_iterator_example2.cpp`]:
|
||||||
|
|
||||||
#include "shared_container_iterator.hpp"
|
#include "shared_container_iterator.hpp"
|
||||||
#include "boost/shared_ptr.hpp"
|
#include "boost/shared_ptr.hpp"
|
||||||
@ -201,7 +200,7 @@ named. The output from this example is the same as the previous.
|
|||||||
|
|
||||||
In the following example, a range of values is returned as a pair of shared_container_iterator objects.
|
In the following example, a range of values is returned as a pair of shared_container_iterator objects.
|
||||||
|
|
||||||
[example_link shared_iterator_example3.cpp..`shared_iterator_example3.cpp`]:
|
[@../../../libs/utility/shared_iterator_example3.cpp `shared_iterator_example3.cpp`]:
|
||||||
|
|
||||||
#include "shared_container_iterator.hpp"
|
#include "shared_container_iterator.hpp"
|
||||||
#include "boost/shared_ptr.hpp"
|
#include "boost/shared_ptr.hpp"
|
||||||
|
@ -1,3 +1,4 @@
|
|||||||
|
|
||||||
[section:specialized Specialized Adaptors]
|
[section:specialized Specialized Adaptors]
|
||||||
|
|
||||||
[include ./counting_iterator.qbk]
|
[include ./counting_iterator.qbk]
|
||||||
|
72
doc/quickbook/traits.qbk
Normal file
72
doc/quickbook/traits.qbk
Normal file
@ -0,0 +1,72 @@
|
|||||||
|
|
||||||
|
[section:traits Iterator Traits]
|
||||||
|
|
||||||
|
`std::iterator_traits` provides access to five associated types
|
||||||
|
of any iterator: its `value_type`, `reference`, `pointer`,
|
||||||
|
`iterator_category`, and `difference_type`. Unfortunately,
|
||||||
|
such a "multi-valued" traits template can be difficult to use in a
|
||||||
|
metaprogramming context. `<boost/iterator/iterator_traits.hpp>`
|
||||||
|
provides access to these types using a standard metafunctions_.
|
||||||
|
|
||||||
|
[h2 Synopsis]
|
||||||
|
|
||||||
|
Header `<boost/iterator/iterator_traits.hpp>`:
|
||||||
|
|
||||||
|
template <class Iterator>
|
||||||
|
struct iterator_value
|
||||||
|
{
|
||||||
|
typedef typename
|
||||||
|
std::iterator_traits<Iterator>::value_type
|
||||||
|
type;
|
||||||
|
};
|
||||||
|
|
||||||
|
template <class Iterator>
|
||||||
|
struct iterator_reference
|
||||||
|
{
|
||||||
|
typedef typename
|
||||||
|
std::iterator_traits<Iterator>::reference
|
||||||
|
type;
|
||||||
|
};
|
||||||
|
|
||||||
|
template <class Iterator>
|
||||||
|
struct iterator_pointer
|
||||||
|
{
|
||||||
|
typedef typename
|
||||||
|
std::iterator_traits<Iterator>::pointer
|
||||||
|
type;
|
||||||
|
};
|
||||||
|
|
||||||
|
template <class Iterator>
|
||||||
|
struct iterator_difference
|
||||||
|
{
|
||||||
|
typedef typename
|
||||||
|
detail::iterator_traits<Iterator>::difference_type
|
||||||
|
type;
|
||||||
|
};
|
||||||
|
|
||||||
|
template <class Iterator>
|
||||||
|
struct iterator_category
|
||||||
|
{
|
||||||
|
typedef typename
|
||||||
|
detail::iterator_traits<Iterator>::iterator_category
|
||||||
|
type;
|
||||||
|
};
|
||||||
|
|
||||||
|
[h2 Broken Compiler Notes]
|
||||||
|
|
||||||
|
Because of workarounds in Boost, you may find that these
|
||||||
|
[@../../mpl/doc/index.html#metafunctions metafunctions] actually work better than the facilities provided by
|
||||||
|
your compiler's standard library.
|
||||||
|
|
||||||
|
On compilers that don't support partial specialization, such as
|
||||||
|
Microsoft Visual C++ 6.0 or 7.0, you may need to manually invoke
|
||||||
|
[@../../type_traits/index.html#transformations BOOST_BROKEN_COMPILER_TYPE_TRAITS_SPECIALIZATION] on the
|
||||||
|
`value_type` of pointers that are passed to these metafunctions.
|
||||||
|
|
||||||
|
Because of bugs in the implementation of GCC-2.9x, the name of
|
||||||
|
`iterator_category` is changed to `iterator_category_` on that
|
||||||
|
compiler. A macro, `BOOST_ITERATOR_CATEGORY`, that expands to
|
||||||
|
either `iterator_category` or `iterator_category_`, as
|
||||||
|
appropriate to the platform, is provided for portability.
|
||||||
|
|
||||||
|
[endsect]
|
@ -1,3 +1,4 @@
|
|||||||
|
|
||||||
[section:transform Transform Iterator]
|
[section:transform Transform Iterator]
|
||||||
|
|
||||||
The transform iterator adapts an iterator by modifying the
|
The transform iterator adapts an iterator by modifying the
|
||||||
@ -36,15 +37,14 @@ in this example.
|
|||||||
|
|
||||||
The output is:
|
The output is:
|
||||||
|
|
||||||
[pre
|
|
||||||
multiplying the array by 2:
|
multiplying the array by 2:
|
||||||
2 4 6 8 10 12 14 16
|
2 4 6 8 10 12 14 16
|
||||||
adding 4 to each element in the array:
|
adding 4 to each element in the array:
|
||||||
5 6 7 8 9 10 11 12
|
5 6 7 8 9 10 11 12
|
||||||
]
|
|
||||||
|
|
||||||
The source code for this example can be found
|
The source code for this example can be found
|
||||||
[example_link transform_iterator_example.cpp..here].
|
[@../example/transform_iterator_example.cpp here].
|
||||||
|
|
||||||
[h2 Reference]
|
[h2 Reference]
|
||||||
|
|
||||||
@ -85,8 +85,8 @@ The source code for this example can be found
|
|||||||
|
|
||||||
|
|
||||||
If `Reference` is `use_default` then the `reference` member of
|
If `Reference` is `use_default` then the `reference` member of
|
||||||
`transform_iterator` is[br]
|
`transform_iterator` is\n
|
||||||
`result_of<const UnaryFunction(iterator_traits<Iterator>::reference)>::type`.
|
`result_of<UnaryFunction(iterator_traits<Iterator>::reference)>::type`.
|
||||||
Otherwise, `reference` is `Reference`.
|
Otherwise, `reference` is `Reference`.
|
||||||
|
|
||||||
|
|
||||||
@ -110,10 +110,10 @@ convertible to `input_iterator_tag`.
|
|||||||
|
|
||||||
|
|
||||||
The type `UnaryFunction` must be Assignable, Copy Constructible, and
|
The type `UnaryFunction` must be Assignable, Copy Constructible, and
|
||||||
the expression `f(*i)` must be valid where `f` is a const object of
|
the expression `f(*i)` must be valid where `f` is an object of
|
||||||
type `UnaryFunction`, `i` is an object of type `Iterator`, and
|
type `UnaryFunction`, `i` is an object of type `Iterator`, and
|
||||||
where the type of `f(*i)` must be
|
where the type of `f(*i)` must be
|
||||||
`result_of<const UnaryFunction(iterator_traits<Iterator>::reference)>::type`.
|
`result_of<UnaryFunction(iterator_traits<Iterator>::reference)>::type`.
|
||||||
|
|
||||||
|
|
||||||
The argument `Iterator` shall model Readable Iterator.
|
The argument `Iterator` shall model Readable Iterator.
|
||||||
@ -160,7 +160,7 @@ interoperable with `Y`.
|
|||||||
|
|
||||||
[h3 Operations]
|
[h3 Operations]
|
||||||
|
|
||||||
In addition to the operations required by the [link iterator.specialized.transform.concepts concepts] modeled by
|
In addition to the operations required by the [link transform.concepts concepts] modeled by
|
||||||
`transform_iterator`, `transform_iterator` provides the following
|
`transform_iterator`, `transform_iterator` provides the following
|
||||||
operations:
|
operations:
|
||||||
|
|
||||||
@ -183,7 +183,7 @@ operations:
|
|||||||
|
|
||||||
[*Returns: ] An instance of `transform_iterator` with `m_f`
|
[*Returns: ] An instance of `transform_iterator` with `m_f`
|
||||||
initialized to `t.functor()` and `m_iterator` initialized to
|
initialized to `t.functor()` and `m_iterator` initialized to
|
||||||
`t.base()`.[br]
|
`t.base()`.\n
|
||||||
[*Requires: ] `OtherIterator` is implicitly convertible to `Iterator`.
|
[*Requires: ] `OtherIterator` is implicitly convertible to `Iterator`.
|
||||||
|
|
||||||
|
|
||||||
@ -204,13 +204,13 @@ operations:
|
|||||||
|
|
||||||
transform_iterator& operator++();
|
transform_iterator& operator++();
|
||||||
|
|
||||||
[*Effects: ] `++m_iterator`[br]
|
[*Effects: ] `++m_iterator`\n
|
||||||
[*Returns: ] `*this`
|
[*Returns: ] `*this`
|
||||||
|
|
||||||
|
|
||||||
transform_iterator& operator--();
|
transform_iterator& operator--();
|
||||||
|
|
||||||
[*Effects: ] `--m_iterator`[br]
|
[*Effects: ] `--m_iterator`\n
|
||||||
[*Returns: ] `*this`
|
[*Returns: ] `*this`
|
||||||
|
|
||||||
[endsect]
|
[endsect]
|
||||||
|
@ -1,211 +0,0 @@
|
|||||||
[section:traits Type Traits]
|
|
||||||
|
|
||||||
[h2 Overview]
|
|
||||||
|
|
||||||
Have you ever wanted to write a generic function that can operate
|
|
||||||
on any kind of dereferenceable object? If you have, you've
|
|
||||||
probably run into the problem of how to determine the type that the
|
|
||||||
object "points at":
|
|
||||||
|
|
||||||
template <class Dereferenceable>
|
|
||||||
void f(Dereferenceable p)
|
|
||||||
{
|
|
||||||
*what-goes-here?* value = \*p;
|
|
||||||
...
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
[h2 `pointee`]
|
|
||||||
|
|
||||||
It turns out to be impossible to come up with a fully-general
|
|
||||||
algorithm to do determine *what-goes-here* directly, but it is
|
|
||||||
possible to require that `pointee<Dereferenceable>::type` is
|
|
||||||
correct. Naturally, `pointee` has the same difficulty: it can't
|
|
||||||
determine the appropriate `::type` reliably for all
|
|
||||||
`Dereferenceable`\ s, but it makes very good guesses (it works
|
|
||||||
for all pointers, standard and boost smart pointers, and
|
|
||||||
iterators), and when it guesses wrongly, it can be specialized as
|
|
||||||
necessary:
|
|
||||||
|
|
||||||
namespace boost
|
|
||||||
{
|
|
||||||
template <class T>
|
|
||||||
struct pointee<third_party_lib::smart_pointer<T> >
|
|
||||||
{
|
|
||||||
typedef T type;
|
|
||||||
};
|
|
||||||
}
|
|
||||||
|
|
||||||
[h2 `indirect_reference`]
|
|
||||||
|
|
||||||
`indirect_reference<T>::type` is rather more specialized than
|
|
||||||
`pointee`, and is meant to be used to forward the result of
|
|
||||||
dereferencing an object of its argument type. Most dereferenceable
|
|
||||||
types just return a reference to their pointee, but some return
|
|
||||||
proxy references or return the pointee by value. When that
|
|
||||||
information is needed, call on `indirect_reference`.
|
|
||||||
|
|
||||||
Both of these templates are essential to the correct functioning of
|
|
||||||
[link iterator.specialized.indirect `indirect_iterator`].
|
|
||||||
|
|
||||||
[h2 `minimum_category`]
|
|
||||||
|
|
||||||
`minimum_category` takes two iterator categories or two iterator traversal tags
|
|
||||||
and returns the one that is the weakest (i.e. least advanced). For example:
|
|
||||||
|
|
||||||
static_assert(
|
|
||||||
is_same<
|
|
||||||
minimum_category<
|
|
||||||
std::forward_iterator_tag,
|
|
||||||
std::random_access_iterator_tag
|
|
||||||
>::type,
|
|
||||||
std::forward_iterator_tag
|
|
||||||
>::value,
|
|
||||||
"Unexpected minimum_category result"
|
|
||||||
);
|
|
||||||
|
|
||||||
[h2 Iterator category and traversal tags manipulation]
|
|
||||||
|
|
||||||
The library provides several utilities to simplify conversions between iterator categories
|
|
||||||
and traversal tags:
|
|
||||||
|
|
||||||
* `iterator_category_to_traversal<C>::type` - the metafunction takes an iterator category `C` and returns
|
|
||||||
the corresponding traversal tag.
|
|
||||||
* `iterator_traversal<T>::type` - a shorthand for `iterator_category_to_traversal<iterator_category<T>::type>::type`.
|
|
||||||
* `pure_traversal_tag<T>::type` - the metafunction takes a tag `T` which derives from one of the iterator traversal tags
|
|
||||||
and returns that traversal tag. `T` may also derive from other tags describing the iterator (e.g. whether this is a `const`-iterator
|
|
||||||
or not), these additional tags are not considered.
|
|
||||||
* `pure_iterator_traversal<T>::type` - a shorthand for `pure_traversal_tag<iterator_traversal<T>::type>::type`.
|
|
||||||
|
|
||||||
[h2 Reference]
|
|
||||||
|
|
||||||
[h3 `pointee`]
|
|
||||||
|
|
||||||
template <class Dereferenceable>
|
|
||||||
struct pointee
|
|
||||||
{
|
|
||||||
typedef /* see below */ type;
|
|
||||||
};
|
|
||||||
|
|
||||||
[*Requires:] For an object `x` of type `Dereferenceable`, `*x`
|
|
||||||
is well-formed. If `++x` is ill-formed it shall neither be
|
|
||||||
ambiguous nor shall it violate access control, and
|
|
||||||
`Dereferenceable::element_type` shall be an accessible type.
|
|
||||||
Otherwise `iterator_traits<Dereferenceable>::value_type` shall
|
|
||||||
be well formed. \[Note: These requirements need not apply to
|
|
||||||
explicit or partial specializations of `pointee`\]
|
|
||||||
|
|
||||||
`type` is determined according to the following algorithm, where
|
|
||||||
`x` is an object of type `Dereferenceable`:
|
|
||||||
|
|
||||||
if ( ++x is ill-formed )
|
|
||||||
{
|
|
||||||
return Dereferenceable::element_type
|
|
||||||
}
|
|
||||||
else if (*x is a mutable reference to
|
|
||||||
std::iterator_traits<Dereferenceable>::value_type)
|
|
||||||
{
|
|
||||||
return iterator_traits<Dereferenceable>::value_type
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
return iterator_traits<Dereferenceable>::value_type const
|
|
||||||
}
|
|
||||||
|
|
||||||
[h3 `indirect_reference`]
|
|
||||||
|
|
||||||
template <class Dereferenceable>
|
|
||||||
struct indirect_reference
|
|
||||||
{
|
|
||||||
typedef /* see below */ type;
|
|
||||||
};
|
|
||||||
|
|
||||||
[*Requires:] For an object `x` of type `Dereferenceable`, `*x`
|
|
||||||
is well-formed. If `++x` is ill-formed it shall neither be
|
|
||||||
ambiguous nor shall it violate access control, and
|
|
||||||
`pointee<Dereferenceable>::type&` shall be well-formed.
|
|
||||||
Otherwise `iterator_traits<Dereferenceable>::reference` shall
|
|
||||||
be well formed. \[Note: These requirements need not apply to
|
|
||||||
explicit or partial specializations of `indirect_reference`\]
|
|
||||||
|
|
||||||
`type` is determined according to the following algorithm, where
|
|
||||||
`x` is an object of type `Dereferenceable`:
|
|
||||||
|
|
||||||
if ( ++x is ill-formed )
|
|
||||||
return pointee<Dereferenceable>::type&
|
|
||||||
else
|
|
||||||
std::iterator_traits<Dereferenceable>::reference
|
|
||||||
|
|
||||||
[h3 `minimum_category`]
|
|
||||||
|
|
||||||
template <typename C1, typename C2>
|
|
||||||
struct minimum_category
|
|
||||||
{
|
|
||||||
typedef /* see below */ type;
|
|
||||||
};
|
|
||||||
|
|
||||||
[*Requires:] Both `C1` and `C2` shall be standard iterator categories or
|
|
||||||
iterator traversal tags.
|
|
||||||
|
|
||||||
`type` is determined according to the following algorithm, where `c1` is an
|
|
||||||
object of type `C1` and `c2` is an object of type `C2`:
|
|
||||||
|
|
||||||
if (c1 is convertible to c2)
|
|
||||||
return C2;
|
|
||||||
else
|
|
||||||
return C1;
|
|
||||||
|
|
||||||
[note The above definition relies on the fact that the more restricting categories
|
|
||||||
and traversal tags are convertible to the less restricting ones.]
|
|
||||||
|
|
||||||
[h3 `iterator_category_to_traversal`]
|
|
||||||
|
|
||||||
template <typename C>
|
|
||||||
struct iterator_category_to_traversal
|
|
||||||
{
|
|
||||||
typedef /* see below */ type;
|
|
||||||
};
|
|
||||||
|
|
||||||
[*Requires:] `C` shall be a standard iterator category or an
|
|
||||||
iterator traversal tag.
|
|
||||||
|
|
||||||
If `C` is an iterator traversal tag or convertible to one, `type` equivalent to `C`.
|
|
||||||
Otherwise, `type` is defined to the closest iterator traversal tag matching `C`.
|
|
||||||
|
|
||||||
[h3 `iterator_traversal`]
|
|
||||||
|
|
||||||
template <typename Iterator>
|
|
||||||
struct iterator_traversal
|
|
||||||
{
|
|
||||||
typedef typename iterator_category_to_traversal<
|
|
||||||
typename iterator_category<Iterator>::type
|
|
||||||
>::type type;
|
|
||||||
};
|
|
||||||
|
|
||||||
[*Requires:] `Iterator` shall be an iterator.
|
|
||||||
|
|
||||||
[h3 `pure_traversal_tag`]
|
|
||||||
|
|
||||||
template <typename T>
|
|
||||||
struct pure_traversal_tag
|
|
||||||
{
|
|
||||||
typedef /* see below */ type;
|
|
||||||
};
|
|
||||||
|
|
||||||
[*Requires:] `T` shall be convertible to an iterator traversal tag.
|
|
||||||
|
|
||||||
`type` is defined to be the most advanced traversal tag `Tag` so that `T` is convertible to `Tag`.
|
|
||||||
|
|
||||||
[h3 `pure_iterator_traversal`]
|
|
||||||
|
|
||||||
template <typename Iterator>
|
|
||||||
struct pure_iterator_traversal
|
|
||||||
{
|
|
||||||
typedef typename pure_traversal_tag<
|
|
||||||
typename iterator_traversal<Iterator>::type
|
|
||||||
>::type type;
|
|
||||||
};
|
|
||||||
|
|
||||||
[*Requires:] `Iterator` shall be an iterator.
|
|
||||||
|
|
||||||
[endsect]
|
|
224
doc/quickbook/utilities.qbk
Normal file
224
doc/quickbook/utilities.qbk
Normal file
@ -0,0 +1,224 @@
|
|||||||
|
|
||||||
|
[section:utilities Iterator Utilities]
|
||||||
|
|
||||||
|
[section:utilities_traits Traits]
|
||||||
|
|
||||||
|
[h2 Overview]
|
||||||
|
|
||||||
|
Have you ever wanted to write a generic function that can operate
|
||||||
|
on any kind of dereferenceable object? If you have, you've
|
||||||
|
probably run into the problem of how to determine the type that the
|
||||||
|
object "points at":
|
||||||
|
|
||||||
|
template <class Dereferenceable>
|
||||||
|
void f(Dereferenceable p)
|
||||||
|
{
|
||||||
|
*what-goes-here?* value = \*p;
|
||||||
|
...
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
[h2 `pointee`]
|
||||||
|
|
||||||
|
It turns out to be impossible to come up with a fully-general
|
||||||
|
algorithm to do determine *what-goes-here* directly, but it is
|
||||||
|
possible to require that `pointee<Dereferenceable>::type` is
|
||||||
|
correct. Naturally, `pointee` has the same difficulty: it can't
|
||||||
|
determine the appropriate `::type` reliably for all
|
||||||
|
`Dereferenceable`\ s, but it makes very good guesses (it works
|
||||||
|
for all pointers, standard and boost smart pointers, and
|
||||||
|
iterators), and when it guesses wrongly, it can be specialized as
|
||||||
|
necessary:
|
||||||
|
|
||||||
|
namespace boost
|
||||||
|
{
|
||||||
|
template <class T>
|
||||||
|
struct pointee<third_party_lib::smart_pointer<T> >
|
||||||
|
{
|
||||||
|
typedef T type;
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
[h2 `indirect_reference`]
|
||||||
|
|
||||||
|
`indirect_reference<T>::type` is rather more specialized than
|
||||||
|
`pointee`, and is meant to be used to forward the result of
|
||||||
|
dereferencing an object of its argument type. Most dereferenceable
|
||||||
|
types just return a reference to their pointee, but some return
|
||||||
|
proxy references or return the pointee by value. When that
|
||||||
|
information is needed, call on `indirect_reference`.
|
||||||
|
|
||||||
|
Both of these templates are essential to the correct functioning of
|
||||||
|
[link indirecct `indirect_iterator`].
|
||||||
|
|
||||||
|
[h2 Reference]
|
||||||
|
|
||||||
|
[h3 `pointeee`]
|
||||||
|
|
||||||
|
template <class Dereferenceable>
|
||||||
|
struct pointee
|
||||||
|
{
|
||||||
|
typedef /* see below */ type;
|
||||||
|
};
|
||||||
|
|
||||||
|
[*Requires:] For an object `x` of type `Dereferenceable`, `*x`
|
||||||
|
is well-formed. If `++x` is ill-formed it shall neither be
|
||||||
|
ambiguous nor shall it violate access control, and
|
||||||
|
`Dereferenceable::element_type` shall be an accessible type.
|
||||||
|
Otherwise `iterator_traits<Dereferenceable>::value_type` shall
|
||||||
|
be well formed. \[Note: These requirements need not apply to
|
||||||
|
explicit or partial specializations of `pointee`\]
|
||||||
|
|
||||||
|
`type` is determined according to the following algorithm, where
|
||||||
|
`x` is an object of type `Dereferenceable`:
|
||||||
|
|
||||||
|
if ( ++x is ill-formed )
|
||||||
|
{
|
||||||
|
return `Dereferenceable::element_type`
|
||||||
|
}
|
||||||
|
else if (`*x` is a mutable reference to
|
||||||
|
std::iterator_traits<Dereferenceable>::value_type)
|
||||||
|
{
|
||||||
|
return iterator_traits<Dereferenceable>::value_type
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
return iterator_traits<Dereferenceable>::value_type const
|
||||||
|
}
|
||||||
|
|
||||||
|
[h3 `indirect_reference`]
|
||||||
|
|
||||||
|
template <class Dereferenceable>
|
||||||
|
struct indirect_reference
|
||||||
|
{
|
||||||
|
typedef /* see below */ type;
|
||||||
|
};
|
||||||
|
|
||||||
|
[*Requires:] For an object `x` of type `Dereferenceable`, `*x`
|
||||||
|
is well-formed. If `++x` is ill-formed it shall neither be
|
||||||
|
ambiguous nor shall it violate access control, and
|
||||||
|
`pointee<Dereferenceable>::type&` shall be well-formed.
|
||||||
|
Otherwise `iterator_traits<Dereferenceable>::reference` shall
|
||||||
|
be well formed. \[Note: These requirements need not apply to
|
||||||
|
explicit or partial specializations of `indirect_reference`\]
|
||||||
|
|
||||||
|
`type` is determined according to the following algorithm, where
|
||||||
|
`x` is an object of type `Dereferenceable`:
|
||||||
|
|
||||||
|
if ( ++x is ill-formed )
|
||||||
|
return `pointee<Dereferenceable>::type&`
|
||||||
|
else
|
||||||
|
std::iterator_traits<Dereferenceable>::reference
|
||||||
|
|
||||||
|
|
||||||
|
[endsect]
|
||||||
|
|
||||||
|
[section:utilities_testing Testing and Concept Checking]
|
||||||
|
|
||||||
|
The iterator concept checking classes provide a mechanism for a
|
||||||
|
template to report better error messages when a user instantiates
|
||||||
|
the template with a type that does not meet the requirements of the
|
||||||
|
template.
|
||||||
|
|
||||||
|
For an introduction to using concept checking classes, see
|
||||||
|
the documentation for the
|
||||||
|
[@../../concept_check/index.html `boost::concept_check`] library.
|
||||||
|
|
||||||
|
|
||||||
|
[h2 Reference]
|
||||||
|
|
||||||
|
[h3 Iterator Access Concepts]
|
||||||
|
|
||||||
|
* |Readable|_
|
||||||
|
* |Writable|_
|
||||||
|
* |Swappable|_
|
||||||
|
* |Lvalue|_
|
||||||
|
|
||||||
|
[/ .. |Readable| replace:: *Readable Iterator* ]
|
||||||
|
[/ .. _Readable: ReadableIterator.html ]
|
||||||
|
[/ ]
|
||||||
|
[/ .. |Writable| replace:: *Writable Iterator* ]
|
||||||
|
[/ .. _Writable: WritableIterator.html ]
|
||||||
|
[/ ]
|
||||||
|
[/ .. |Swappable| replace:: *Swappable Iterator* ]
|
||||||
|
[/ .. _Swappable: SwappableIterator.html ]
|
||||||
|
[/ ]
|
||||||
|
[/ .. |Lvalue| replace:: *Lvalue Iterator* ]
|
||||||
|
[/ .. _Lvalue: LvalueIterator.html ]
|
||||||
|
|
||||||
|
|
||||||
|
Iterator Traversal Concepts
|
||||||
|
...........................
|
||||||
|
|
||||||
|
* |Incrementable|_
|
||||||
|
* |SinglePass|_
|
||||||
|
* |Forward|_
|
||||||
|
* |Bidir|_
|
||||||
|
* |Random|_
|
||||||
|
|
||||||
|
|
||||||
|
[/ .. |Incrementable| replace:: *Incrementable Iterator* ]
|
||||||
|
[/ .. _Incrementable: IncrementableIterator.html ]
|
||||||
|
[/ ]
|
||||||
|
[/ .. |SinglePass| replace:: *Single Pass Iterator* ]
|
||||||
|
[/ .. _SinglePass: SinglePassIterator.html ]
|
||||||
|
[/ ]
|
||||||
|
[/ .. |Forward| replace:: *Forward Traversal* ]
|
||||||
|
[/ .. _Forward: ForwardTraversal.html ]
|
||||||
|
[/ ]
|
||||||
|
[/ .. |Bidir| replace:: *Bidirectional Traversal* ]
|
||||||
|
[/ .. _Bidir: BidirectionalTraversal.html ]
|
||||||
|
[/ ]
|
||||||
|
[/ .. |Random| replace:: *Random Access Traversal* ]
|
||||||
|
[/ .. _Random: RandomAccessTraversal.html ]
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
[h3 `iterator_concepts.hpp` Synopsis]
|
||||||
|
|
||||||
|
namespace boost_concepts {
|
||||||
|
|
||||||
|
// Iterator Access Concepts
|
||||||
|
|
||||||
|
template <typename Iterator>
|
||||||
|
class ReadableIteratorConcept;
|
||||||
|
|
||||||
|
template <
|
||||||
|
typename Iterator
|
||||||
|
, typename ValueType = std::iterator_traits<Iterator>::value_type
|
||||||
|
>
|
||||||
|
class WritableIteratorConcept;
|
||||||
|
|
||||||
|
template <typename Iterator>
|
||||||
|
class SwappableIteratorConcept;
|
||||||
|
|
||||||
|
template <typename Iterator>
|
||||||
|
class LvalueIteratorConcept;
|
||||||
|
|
||||||
|
// Iterator Traversal Concepts
|
||||||
|
|
||||||
|
template <typename Iterator>
|
||||||
|
class IncrementableIteratorConcept;
|
||||||
|
|
||||||
|
template <typename Iterator>
|
||||||
|
class SinglePassIteratorConcept;
|
||||||
|
|
||||||
|
template <typename Iterator>
|
||||||
|
class ForwardTraversalConcept;
|
||||||
|
|
||||||
|
template <typename Iterator>
|
||||||
|
class BidirectionalTraversalConcept;
|
||||||
|
|
||||||
|
template <typename Iterator>
|
||||||
|
class RandomAccessTraversalConcept;
|
||||||
|
|
||||||
|
// Interoperability
|
||||||
|
|
||||||
|
template <typename Iterator, typename ConstIterator>
|
||||||
|
class InteroperableIteratorConcept;
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
[endsect]
|
||||||
|
|
||||||
|
[endsect]
|
@ -1,3 +1,4 @@
|
|||||||
|
|
||||||
[section:zip Zip Iterator]
|
[section:zip Zip Iterator]
|
||||||
|
|
||||||
The zip iterator provides the ability to parallel-iterate
|
The zip iterator provides the ability to parallel-iterate
|
||||||
@ -7,16 +8,6 @@ the zip iterator moves all the iterators in parallel.
|
|||||||
Dereferencing the zip iterator returns a tuple that contains
|
Dereferencing the zip iterator returns a tuple that contains
|
||||||
the results of dereferencing the individual iterators.
|
the results of dereferencing the individual iterators.
|
||||||
|
|
||||||
The tuple of iterators is now implemented in terms of a Boost fusion sequence.
|
|
||||||
Because of this the 'tuple' may be any Boost fusion sequence and, for backwards
|
|
||||||
compatibility through a Boost fusion sequence adapter, a Boost tuple. Because the
|
|
||||||
'tuple' may be any boost::fusion sequence the 'tuple' may also be any type for which a
|
|
||||||
Boost fusion adapter exists. This includes, among others, a std::tuple and a std::pair.
|
|
||||||
Just remember to include the appropriate Boost fusion adapter header files for these
|
|
||||||
other Boost fusion adapters. The zip_iterator header file already includes the
|
|
||||||
Boost fusion adapter header file for Boost tuple, so you need not include it yourself
|
|
||||||
to use a Boost tuple as your 'tuple'.
|
|
||||||
|
|
||||||
[section:zip_example Example]
|
[section:zip_example Example]
|
||||||
|
|
||||||
There are two main types of applications of the `zip_iterator`. The first
|
There are two main types of applications of the `zip_iterator`. The first
|
||||||
@ -227,7 +218,7 @@ operations.
|
|||||||
, IteratorTuple>::type* = 0 // exposition only
|
, IteratorTuple>::type* = 0 // exposition only
|
||||||
);
|
);
|
||||||
|
|
||||||
[*Returns:] An instance of `zip_iterator` that is a copy of `other`.[br]
|
[*Returns:] An instance of `zip_iterator` that is a copy of `other`.\n
|
||||||
[*Requires:] `OtherIteratorTuple` is implicitly convertible to `IteratorTuple`.
|
[*Requires:] `OtherIteratorTuple` is implicitly convertible to `IteratorTuple`.
|
||||||
|
|
||||||
|
|
||||||
@ -244,13 +235,13 @@ operations.
|
|||||||
|
|
||||||
zip_iterator& operator++();
|
zip_iterator& operator++();
|
||||||
|
|
||||||
[*Effects:] Increments each iterator in `m_iterator_tuple`.[br]
|
[*Effects:] Increments each iterator in `m_iterator_tuple`.\n
|
||||||
[*Returns:] `*this`
|
[*Returns:] `*this`
|
||||||
|
|
||||||
|
|
||||||
zip_iterator& operator--();
|
zip_iterator& operator--();
|
||||||
|
|
||||||
[*Effects:] Decrements each iterator in `m_iterator_tuple`.[br]
|
[*Effects:] Decrements each iterator in `m_iterator_tuple`.\n
|
||||||
[*Returns:] `*this`
|
[*Returns:] `*this`
|
||||||
|
|
||||||
template<typename IteratorTuple>
|
template<typename IteratorTuple>
|
||||||
|
@ -3,7 +3,7 @@
|
|||||||
++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
|
++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
|
||||||
|
|
||||||
.. _N1550: http://www.boost-consulting.com/writing/n1550.html
|
.. _N1550: http://www.boost-consulting.com/writing/n1550.html
|
||||||
.. _N1530: http://www.open-std.org/jtc1/sc22/wg21/docs/papers/2003/n1530.html
|
.. _N1530: http://anubis.dkuug.dk/jtc1/sc22/wg21/docs/papers/2003/n1530.html
|
||||||
|
|
||||||
:Author: David Abrahams and Jeremy Siek
|
:Author: David Abrahams and Jeremy Siek
|
||||||
:Contact: dave@boost-consulting.com, jsiek@osl.iu.edu
|
:Contact: dave@boost-consulting.com, jsiek@osl.iu.edu
|
||||||
|
@ -99,7 +99,7 @@ private:
|
|||||||
</pre>
|
</pre>
|
||||||
<p>If <tt class="docutils literal"><span class="pre">Reference</span></tt> is <tt class="docutils literal"><span class="pre">use_default</span></tt> then the <tt class="docutils literal"><span class="pre">reference</span></tt> member of
|
<p>If <tt class="docutils literal"><span class="pre">Reference</span></tt> is <tt class="docutils literal"><span class="pre">use_default</span></tt> then the <tt class="docutils literal"><span class="pre">reference</span></tt> member of
|
||||||
<tt class="docutils literal"><span class="pre">transform_iterator</span></tt> is
|
<tt class="docutils literal"><span class="pre">transform_iterator</span></tt> is
|
||||||
<tt class="docutils literal"><span class="pre">result_of<const UnaryFunction(iterator_traits<Iterator>::reference)>::type</span></tt>.
|
<tt class="docutils literal"><span class="pre">result_of<UnaryFunction(iterator_traits<Iterator>::reference)>::type</span></tt>.
|
||||||
Otherwise, <tt class="docutils literal"><span class="pre">reference</span></tt> is <tt class="docutils literal"><span class="pre">Reference</span></tt>.</p>
|
Otherwise, <tt class="docutils literal"><span class="pre">reference</span></tt> is <tt class="docutils literal"><span class="pre">Reference</span></tt>.</p>
|
||||||
<p>If <tt class="docutils literal"><span class="pre">Value</span></tt> is <tt class="docutils literal"><span class="pre">use_default</span></tt> then the <tt class="docutils literal"><span class="pre">value_type</span></tt> member is
|
<p>If <tt class="docutils literal"><span class="pre">Value</span></tt> is <tt class="docutils literal"><span class="pre">use_default</span></tt> then the <tt class="docutils literal"><span class="pre">value_type</span></tt> member is
|
||||||
<tt class="docutils literal"><span class="pre">remove_cv<remove_reference<reference></span> <span class="pre">>::type</span></tt>. Otherwise,
|
<tt class="docutils literal"><span class="pre">remove_cv<remove_reference<reference></span> <span class="pre">>::type</span></tt>. Otherwise,
|
||||||
@ -117,10 +117,10 @@ convertible to <tt class="docutils literal"><span class="pre">input_iterator_tag
|
|||||||
<div class="section" id="transform-iterator-requirements">
|
<div class="section" id="transform-iterator-requirements">
|
||||||
<h1><a class="toc-backref" href="#id3"><tt class="docutils literal"><span class="pre">transform_iterator</span></tt> requirements</a></h1>
|
<h1><a class="toc-backref" href="#id3"><tt class="docutils literal"><span class="pre">transform_iterator</span></tt> requirements</a></h1>
|
||||||
<p>The type <tt class="docutils literal"><span class="pre">UnaryFunction</span></tt> must be Assignable, Copy Constructible, and
|
<p>The type <tt class="docutils literal"><span class="pre">UnaryFunction</span></tt> must be Assignable, Copy Constructible, and
|
||||||
the expression <tt class="docutils literal"><span class="pre">f(*i)</span></tt> must be valid where <tt class="docutils literal"><span class="pre">f</span></tt> is a const object of
|
the expression <tt class="docutils literal"><span class="pre">f(*i)</span></tt> must be valid where <tt class="docutils literal"><span class="pre">f</span></tt> is an object of
|
||||||
type <tt class="docutils literal"><span class="pre">UnaryFunction</span></tt>, <tt class="docutils literal"><span class="pre">i</span></tt> is an object of type <tt class="docutils literal"><span class="pre">Iterator</span></tt>, and
|
type <tt class="docutils literal"><span class="pre">UnaryFunction</span></tt>, <tt class="docutils literal"><span class="pre">i</span></tt> is an object of type <tt class="docutils literal"><span class="pre">Iterator</span></tt>, and
|
||||||
where the type of <tt class="docutils literal"><span class="pre">f(*i)</span></tt> must be
|
where the type of <tt class="docutils literal"><span class="pre">f(*i)</span></tt> must be
|
||||||
<tt class="docutils literal"><span class="pre">result_of<const UnaryFunction(iterator_traits<Iterator>::reference)>::type</span></tt>.</p>
|
<tt class="docutils literal"><span class="pre">result_of<UnaryFunction(iterator_traits<Iterator>::reference)>::type</span></tt>.</p>
|
||||||
<p>The argument <tt class="docutils literal"><span class="pre">Iterator</span></tt> shall model Readable Iterator.</p>
|
<p>The argument <tt class="docutils literal"><span class="pre">Iterator</span></tt> shall model Readable Iterator.</p>
|
||||||
</div>
|
</div>
|
||||||
<div class="section" id="transform-iterator-models">
|
<div class="section" id="transform-iterator-models">
|
||||||
|
@ -41,7 +41,7 @@
|
|||||||
|
|
||||||
If ``Reference`` is ``use_default`` then the ``reference`` member of
|
If ``Reference`` is ``use_default`` then the ``reference`` member of
|
||||||
``transform_iterator`` is
|
``transform_iterator`` is
|
||||||
``result_of<const UnaryFunction(iterator_traits<Iterator>::reference)>::type``.
|
``result_of<UnaryFunction(iterator_traits<Iterator>::reference)>::type``.
|
||||||
Otherwise, ``reference`` is ``Reference``.
|
Otherwise, ``reference`` is ``Reference``.
|
||||||
|
|
||||||
If ``Value`` is ``use_default`` then the ``value_type`` member is
|
If ``Value`` is ``use_default`` then the ``value_type`` member is
|
||||||
@ -64,10 +64,10 @@ convertible to ``input_iterator_tag``.
|
|||||||
...................................
|
...................................
|
||||||
|
|
||||||
The type ``UnaryFunction`` must be Assignable, Copy Constructible, and
|
The type ``UnaryFunction`` must be Assignable, Copy Constructible, and
|
||||||
the expression ``f(*i)`` must be valid where ``f`` is a const object of
|
the expression ``f(*i)`` must be valid where ``f`` is an object of
|
||||||
type ``UnaryFunction``, ``i`` is an object of type ``Iterator``, and
|
type ``UnaryFunction``, ``i`` is an object of type ``Iterator``, and
|
||||||
where the type of ``f(*i)`` must be
|
where the type of ``f(*i)`` must be
|
||||||
``result_of<const UnaryFunction(iterator_traits<Iterator>::reference)>::type``.
|
``result_of<UnaryFunction(iterator_traits<Iterator>::reference)>::type``.
|
||||||
|
|
||||||
The argument ``Iterator`` shall model Readable Iterator.
|
The argument ``Iterator`` shall model Readable Iterator.
|
||||||
|
|
||||||
|
@ -8,13 +8,3 @@ iterator is constructed from a tuple of iterators. Moving
|
|||||||
the zip iterator moves all the iterators in parallel.
|
the zip iterator moves all the iterators in parallel.
|
||||||
Dereferencing the zip iterator returns a tuple that contains
|
Dereferencing the zip iterator returns a tuple that contains
|
||||||
the results of dereferencing the individual iterators.
|
the results of dereferencing the individual iterators.
|
||||||
|
|
||||||
The tuple of iterators is now implemented in terms of a Boost fusion sequence.
|
|
||||||
Because of this the 'tuple' may be any Boost fusion sequence and, for backwards
|
|
||||||
compatibility through a Boost fusion sequence adapter, a Boost tuple. Because the
|
|
||||||
'tuple' may be any boost::fusion sequence the 'tuple' may also be any type for which a
|
|
||||||
Boost fusion adapter exists. This includes, among others, a std::tuple and a std::pair.
|
|
||||||
Just remember to include the appropriate Boost fusion adapter header files for these
|
|
||||||
other Boost fusion adapters. The zip_iterator header file already includes the
|
|
||||||
Boost fusion adapter header file for Boost tuple, so you need not include it yourself
|
|
||||||
to use a Boost tuple as your 'tuple'.
|
|
||||||
|
@ -45,7 +45,8 @@ A non-generic implementation of ``zip_func`` could look as follows:
|
|||||||
::
|
::
|
||||||
|
|
||||||
|
|
||||||
struct zip_func
|
struct zip_func :
|
||||||
|
public std::unary_function<const boost::tuple<const double&, const int&>&, void>
|
||||||
{
|
{
|
||||||
void operator()(const boost::tuple<const double&, const int&>& t) const
|
void operator()(const boost::tuple<const double&, const int&>& t) const
|
||||||
{
|
{
|
||||||
|
@ -8,7 +8,6 @@
|
|||||||
#include <functional>
|
#include <functional>
|
||||||
#include <iostream>
|
#include <iostream>
|
||||||
#include <boost/iterator/filter_iterator.hpp>
|
#include <boost/iterator/filter_iterator.hpp>
|
||||||
#include <boost/bind/bind.hpp>
|
|
||||||
#include <boost/cstdlib.hpp> // for exit_success
|
#include <boost/cstdlib.hpp> // for exit_success
|
||||||
|
|
||||||
struct is_positive_number {
|
struct is_positive_number {
|
||||||
@ -43,11 +42,11 @@ int main()
|
|||||||
// Another example using make_filter_iterator()
|
// Another example using make_filter_iterator()
|
||||||
std::copy(
|
std::copy(
|
||||||
boost::make_filter_iterator(
|
boost::make_filter_iterator(
|
||||||
boost::bind(std::greater<int>(), boost::placeholders::_1, -2)
|
std::bind2nd(std::greater<int>(), -2)
|
||||||
, numbers, numbers + N)
|
, numbers, numbers + N)
|
||||||
|
|
||||||
, boost::make_filter_iterator(
|
, boost::make_filter_iterator(
|
||||||
boost::bind(std::greater<int>(), boost::placeholders::_1, -2)
|
std::bind2nd(std::greater<int>(), -2)
|
||||||
, numbers + N, numbers + N)
|
, numbers + N, numbers + N)
|
||||||
|
|
||||||
, std::ostream_iterator<int>(std::cout, " ")
|
, std::ostream_iterator<int>(std::cout, " ")
|
||||||
|
@ -12,7 +12,7 @@
|
|||||||
#include <string>
|
#include <string>
|
||||||
#include <vector>
|
#include <vector>
|
||||||
|
|
||||||
#include <boost/iterator/function_output_iterator.hpp>
|
#include <boost/function_output_iterator.hpp>
|
||||||
|
|
||||||
struct string_appender
|
struct string_appender
|
||||||
{
|
{
|
||||||
|
@ -9,7 +9,6 @@
|
|||||||
#include <iterator>
|
#include <iterator>
|
||||||
#include <functional>
|
#include <functional>
|
||||||
#include <algorithm>
|
#include <algorithm>
|
||||||
#include <boost/bind/bind.hpp>
|
|
||||||
#include <boost/iterator/indirect_iterator.hpp>
|
#include <boost/iterator/indirect_iterator.hpp>
|
||||||
|
|
||||||
int main(int, char*[])
|
int main(int, char*[])
|
||||||
@ -42,7 +41,7 @@ int main(int, char*[])
|
|||||||
const_indirect_last(pointers_to_chars + N);
|
const_indirect_last(pointers_to_chars + N);
|
||||||
|
|
||||||
std::transform(const_indirect_first, const_indirect_last,
|
std::transform(const_indirect_first, const_indirect_last,
|
||||||
mutable_indirect_first, boost::bind(std::plus<char>(), 1, boost::placeholders::_1));
|
mutable_indirect_first, std::bind1st(std::plus<char>(), 1));
|
||||||
|
|
||||||
std::copy(mutable_indirect_first, mutable_indirect_last,
|
std::copy(mutable_indirect_first, mutable_indirect_last,
|
||||||
std::ostream_iterator<char>(std::cout, ","));
|
std::ostream_iterator<char>(std::cout, ","));
|
||||||
|
@ -11,17 +11,7 @@
|
|||||||
|
|
||||||
int main()
|
int main()
|
||||||
{
|
{
|
||||||
|
|
||||||
#if defined(BOOST_NO_CXX11_SMART_PTR)
|
|
||||||
|
|
||||||
std::auto_ptr<node<int> > nodes(new node<int>(42));
|
std::auto_ptr<node<int> > nodes(new node<int>(42));
|
||||||
|
|
||||||
#else
|
|
||||||
|
|
||||||
std::unique_ptr<node<int> > nodes(new node<int>(42));
|
|
||||||
|
|
||||||
#endif
|
|
||||||
|
|
||||||
nodes->append(new node<std::string>(" is greater than "));
|
nodes->append(new node<std::string>(" is greater than "));
|
||||||
nodes->append(new node<int>(13));
|
nodes->append(new node<int>(13));
|
||||||
|
|
||||||
|
@ -12,17 +12,7 @@
|
|||||||
|
|
||||||
int main()
|
int main()
|
||||||
{
|
{
|
||||||
|
|
||||||
#if defined(BOOST_NO_CXX11_SMART_PTR)
|
|
||||||
|
|
||||||
std::auto_ptr<node<int> > nodes(new node<int>(42));
|
std::auto_ptr<node<int> > nodes(new node<int>(42));
|
||||||
|
|
||||||
#else
|
|
||||||
|
|
||||||
std::unique_ptr<node<int> > nodes(new node<int>(42));
|
|
||||||
|
|
||||||
#endif
|
|
||||||
|
|
||||||
nodes->append(new node<std::string>(" is greater than "));
|
nodes->append(new node<std::string>(" is greater than "));
|
||||||
nodes->append(new node<int>(13));
|
nodes->append(new node<int>(13));
|
||||||
|
|
||||||
|
@ -12,17 +12,7 @@
|
|||||||
|
|
||||||
int main()
|
int main()
|
||||||
{
|
{
|
||||||
|
|
||||||
#if defined(BOOST_NO_CXX11_SMART_PTR)
|
|
||||||
|
|
||||||
std::auto_ptr<node<int> > nodes(new node<int>(42));
|
std::auto_ptr<node<int> > nodes(new node<int>(42));
|
||||||
|
|
||||||
#else
|
|
||||||
|
|
||||||
std::unique_ptr<node<int> > nodes(new node<int>(42));
|
|
||||||
|
|
||||||
#endif
|
|
||||||
|
|
||||||
nodes->append(new node<std::string>(" is greater than "));
|
nodes->append(new node<std::string>(" is greater than "));
|
||||||
nodes->append(new node<int>(13));
|
nodes->append(new node<int>(13));
|
||||||
|
|
||||||
|
@ -1,42 +0,0 @@
|
|||||||
// Copyright 2003 The Trustees of Indiana University.
|
|
||||||
|
|
||||||
// Use, modification and distribution is subject to the Boost Software
|
|
||||||
// License, Version 1.0. (See accompanying file LICENSE_1_0.txt or copy at
|
|
||||||
// http://www.boost.org/LICENSE_1_0.txt)
|
|
||||||
|
|
||||||
#include "boost/shared_container_iterator.hpp"
|
|
||||||
#include "boost/shared_ptr.hpp"
|
|
||||||
#include <algorithm>
|
|
||||||
#include <iostream>
|
|
||||||
#include <vector>
|
|
||||||
|
|
||||||
typedef boost::shared_container_iterator< std::vector<int> > iterator;
|
|
||||||
|
|
||||||
|
|
||||||
void set_range(iterator& i, iterator& end) {
|
|
||||||
|
|
||||||
boost::shared_ptr< std::vector<int> > ints(new std::vector<int>());
|
|
||||||
|
|
||||||
ints->push_back(0);
|
|
||||||
ints->push_back(1);
|
|
||||||
ints->push_back(2);
|
|
||||||
ints->push_back(3);
|
|
||||||
ints->push_back(4);
|
|
||||||
ints->push_back(5);
|
|
||||||
|
|
||||||
i = iterator(ints->begin(),ints);
|
|
||||||
end = iterator(ints->end(),ints);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
int main() {
|
|
||||||
|
|
||||||
iterator i,end;
|
|
||||||
|
|
||||||
set_range(i,end);
|
|
||||||
|
|
||||||
std::copy(i,end,std::ostream_iterator<int>(std::cout,","));
|
|
||||||
std::cout.put('\n');
|
|
||||||
|
|
||||||
return 0;
|
|
||||||
}
|
|
@ -1,43 +0,0 @@
|
|||||||
// Copyright 2003 The Trustees of Indiana University.
|
|
||||||
|
|
||||||
// Use, modification and distribution is subject to the Boost Software
|
|
||||||
// License, Version 1.0. (See accompanying file LICENSE_1_0.txt or copy at
|
|
||||||
// http://www.boost.org/LICENSE_1_0.txt)
|
|
||||||
|
|
||||||
#include "boost/shared_container_iterator.hpp"
|
|
||||||
#include "boost/shared_ptr.hpp"
|
|
||||||
#include <algorithm>
|
|
||||||
#include <iterator>
|
|
||||||
#include <iostream>
|
|
||||||
#include <vector>
|
|
||||||
|
|
||||||
|
|
||||||
template <typename Iterator>
|
|
||||||
void print_range_nl (Iterator begin, Iterator end) {
|
|
||||||
typedef typename std::iterator_traits<Iterator>::value_type val;
|
|
||||||
std::copy(begin,end,std::ostream_iterator<val>(std::cout,","));
|
|
||||||
std::cout.put('\n');
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
int main() {
|
|
||||||
|
|
||||||
typedef boost::shared_ptr< std::vector<int> > ints_t;
|
|
||||||
{
|
|
||||||
ints_t ints(new std::vector<int>());
|
|
||||||
|
|
||||||
ints->push_back(0);
|
|
||||||
ints->push_back(1);
|
|
||||||
ints->push_back(2);
|
|
||||||
ints->push_back(3);
|
|
||||||
ints->push_back(4);
|
|
||||||
ints->push_back(5);
|
|
||||||
|
|
||||||
print_range_nl(boost::make_shared_container_iterator(ints->begin(),ints),
|
|
||||||
boost::make_shared_container_iterator(ints->end(),ints));
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
return 0;
|
|
||||||
}
|
|
@ -1,41 +0,0 @@
|
|||||||
// Copyright 2003 The Trustees of Indiana University.
|
|
||||||
|
|
||||||
// Use, modification and distribution is subject to the Boost Software
|
|
||||||
// License, Version 1.0. (See accompanying file LICENSE_1_0.txt or copy at
|
|
||||||
// http://www.boost.org/LICENSE_1_0.txt)
|
|
||||||
|
|
||||||
#include "boost/shared_container_iterator.hpp"
|
|
||||||
#include "boost/shared_ptr.hpp"
|
|
||||||
#include "boost/tuple/tuple.hpp" // for boost::tie
|
|
||||||
#include <algorithm> // for std::copy
|
|
||||||
#include <iostream>
|
|
||||||
#include <vector>
|
|
||||||
|
|
||||||
|
|
||||||
typedef boost::shared_container_iterator< std::vector<int> > iterator;
|
|
||||||
|
|
||||||
std::pair<iterator,iterator>
|
|
||||||
return_range() {
|
|
||||||
boost::shared_ptr< std::vector<int> > range(new std::vector<int>());
|
|
||||||
range->push_back(0);
|
|
||||||
range->push_back(1);
|
|
||||||
range->push_back(2);
|
|
||||||
range->push_back(3);
|
|
||||||
range->push_back(4);
|
|
||||||
range->push_back(5);
|
|
||||||
return boost::make_shared_container_range(range);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
int main() {
|
|
||||||
|
|
||||||
|
|
||||||
iterator i,end;
|
|
||||||
|
|
||||||
boost::tie(i,end) = return_range();
|
|
||||||
|
|
||||||
std::copy(i,end,std::ostream_iterator<int>(std::cout,","));
|
|
||||||
std::cout.put('\n');
|
|
||||||
|
|
||||||
return 0;
|
|
||||||
}
|
|
@ -16,10 +16,9 @@
|
|||||||
namespace boost {
|
namespace boost {
|
||||||
|
|
||||||
template <class Operation>
|
template <class Operation>
|
||||||
class binder1st {
|
class binder1st
|
||||||
public:
|
: public std::unary_function<typename Operation::second_argument_type,
|
||||||
typedef typename Operation::result_type result_type;
|
typename Operation::result_type> {
|
||||||
typedef typename Operation::second_argument_type argument_type;
|
|
||||||
protected:
|
protected:
|
||||||
Operation op;
|
Operation op;
|
||||||
typename Operation::first_argument_type value;
|
typename Operation::first_argument_type value;
|
||||||
@ -73,3 +72,5 @@ main(int, char*[])
|
|||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -1,18 +1,56 @@
|
|||||||
// (C) Copyright Andrey Semashev 2017.
|
// (C) Copyright Jeremy Siek 2001.
|
||||||
// Distributed under the Boost Software License, Version 1.0. (See
|
// Distributed under the Boost Software License, Version 1.0. (See
|
||||||
// accompanying file LICENSE_1_0.txt or copy at
|
// accompanying file LICENSE_1_0.txt or copy at
|
||||||
// http://www.boost.org/LICENSE_1_0.txt)
|
// http://www.boost.org/LICENSE_1_0.txt)
|
||||||
|
|
||||||
|
// Revision History:
|
||||||
|
|
||||||
|
// 27 Feb 2001 Jeremy Siek
|
||||||
|
// Initial checkin.
|
||||||
|
|
||||||
#ifndef BOOST_FUNCTION_OUTPUT_ITERATOR_HPP
|
#ifndef BOOST_FUNCTION_OUTPUT_ITERATOR_HPP
|
||||||
#define BOOST_FUNCTION_OUTPUT_ITERATOR_HPP
|
#define BOOST_FUNCTION_OUTPUT_ITERATOR_HPP
|
||||||
|
|
||||||
// This is a deprecated header left for backward compatibility.
|
#include <iterator>
|
||||||
// Use boost/iterator/function_output_iterator.hpp instead.
|
|
||||||
|
|
||||||
#include <boost/config/header_deprecated.hpp>
|
namespace boost {
|
||||||
|
|
||||||
BOOST_HEADER_DEPRECATED("<boost/iterator/function_output_iterator.hpp>")
|
template <class UnaryFunction>
|
||||||
|
class function_output_iterator {
|
||||||
|
typedef function_output_iterator self;
|
||||||
|
public:
|
||||||
|
typedef std::output_iterator_tag iterator_category;
|
||||||
|
typedef void value_type;
|
||||||
|
typedef void difference_type;
|
||||||
|
typedef void pointer;
|
||||||
|
typedef void reference;
|
||||||
|
|
||||||
#include <boost/iterator/function_output_iterator.hpp>
|
explicit function_output_iterator() {}
|
||||||
|
|
||||||
|
explicit function_output_iterator(const UnaryFunction& f)
|
||||||
|
: m_f(f) {}
|
||||||
|
|
||||||
|
struct output_proxy {
|
||||||
|
output_proxy(UnaryFunction& f) : m_f(f) { }
|
||||||
|
template <class T> output_proxy& operator=(const T& value) {
|
||||||
|
m_f(value);
|
||||||
|
return *this;
|
||||||
|
}
|
||||||
|
UnaryFunction& m_f;
|
||||||
|
};
|
||||||
|
output_proxy operator*() { return output_proxy(m_f); }
|
||||||
|
self& operator++() { return *this; }
|
||||||
|
self& operator++(int) { return *this; }
|
||||||
|
private:
|
||||||
|
UnaryFunction m_f;
|
||||||
|
};
|
||||||
|
|
||||||
|
template <class UnaryFunction>
|
||||||
|
inline function_output_iterator<UnaryFunction>
|
||||||
|
make_function_output_iterator(const UnaryFunction& f = UnaryFunction()) {
|
||||||
|
return function_output_iterator<UnaryFunction>(f);
|
||||||
|
}
|
||||||
|
|
||||||
|
} // namespace boost
|
||||||
|
|
||||||
#endif // BOOST_FUNCTION_OUTPUT_ITERATOR_HPP
|
#endif // BOOST_FUNCTION_OUTPUT_ITERATOR_HPP
|
||||||
|
@ -1,85 +0,0 @@
|
|||||||
// (C) Copyright Jens Maurer 2001.
|
|
||||||
// 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)
|
|
||||||
//
|
|
||||||
// Revision History:
|
|
||||||
|
|
||||||
// 15 Nov 2001 Jens Maurer
|
|
||||||
// created.
|
|
||||||
|
|
||||||
// See http://www.boost.org/libs/utility/iterator_adaptors.htm for documentation.
|
|
||||||
|
|
||||||
#ifndef BOOST_ITERATOR_ADAPTOR_GENERATOR_ITERATOR_HPP
|
|
||||||
#define BOOST_ITERATOR_ADAPTOR_GENERATOR_ITERATOR_HPP
|
|
||||||
|
|
||||||
#include <boost/iterator/iterator_facade.hpp>
|
|
||||||
#include <boost/ref.hpp>
|
|
||||||
|
|
||||||
namespace boost {
|
|
||||||
namespace iterators {
|
|
||||||
|
|
||||||
template<class Generator>
|
|
||||||
class generator_iterator
|
|
||||||
: public iterator_facade<
|
|
||||||
generator_iterator<Generator>
|
|
||||||
, typename Generator::result_type
|
|
||||||
, single_pass_traversal_tag
|
|
||||||
, typename Generator::result_type const&
|
|
||||||
>
|
|
||||||
{
|
|
||||||
typedef iterator_facade<
|
|
||||||
generator_iterator<Generator>
|
|
||||||
, typename Generator::result_type
|
|
||||||
, single_pass_traversal_tag
|
|
||||||
, typename Generator::result_type const&
|
|
||||||
> super_t;
|
|
||||||
|
|
||||||
public:
|
|
||||||
generator_iterator() {}
|
|
||||||
generator_iterator(Generator* g) : m_g(g), m_value((*m_g)()) {}
|
|
||||||
|
|
||||||
void increment()
|
|
||||||
{
|
|
||||||
m_value = (*m_g)();
|
|
||||||
}
|
|
||||||
|
|
||||||
const typename Generator::result_type&
|
|
||||||
dereference() const
|
|
||||||
{
|
|
||||||
return m_value;
|
|
||||||
}
|
|
||||||
|
|
||||||
bool equal(generator_iterator const& y) const
|
|
||||||
{
|
|
||||||
return this->m_g == y.m_g && this->m_value == y.m_value;
|
|
||||||
}
|
|
||||||
|
|
||||||
private:
|
|
||||||
Generator* m_g;
|
|
||||||
typename Generator::result_type m_value;
|
|
||||||
};
|
|
||||||
|
|
||||||
template<class Generator>
|
|
||||||
struct generator_iterator_generator
|
|
||||||
{
|
|
||||||
typedef generator_iterator<Generator> type;
|
|
||||||
};
|
|
||||||
|
|
||||||
template <class Generator>
|
|
||||||
inline generator_iterator<Generator>
|
|
||||||
make_generator_iterator(Generator & gen)
|
|
||||||
{
|
|
||||||
typedef generator_iterator<Generator> result_t;
|
|
||||||
return result_t(&gen);
|
|
||||||
}
|
|
||||||
|
|
||||||
} // namespace iterators
|
|
||||||
|
|
||||||
using iterators::generator_iterator;
|
|
||||||
using iterators::generator_iterator_generator;
|
|
||||||
using iterators::make_generator_iterator;
|
|
||||||
|
|
||||||
} // namespace boost
|
|
||||||
|
|
||||||
#endif // BOOST_ITERATOR_ADAPTOR_GENERATOR_ITERATOR_HPP
|
|
@ -1,43 +0,0 @@
|
|||||||
#ifndef INDIRECT_REFERENCE_DWA200415_HPP
|
|
||||||
# define INDIRECT_REFERENCE_DWA200415_HPP
|
|
||||||
|
|
||||||
//
|
|
||||||
// Copyright David Abrahams 2004. Use, modification and distribution is
|
|
||||||
// subject to the Boost Software License, Version 1.0. (See accompanying
|
|
||||||
// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
|
|
||||||
//
|
|
||||||
// typename indirect_reference<P>::type provides the type of *p.
|
|
||||||
//
|
|
||||||
// http://www.boost.org/libs/iterator/doc/pointee.html
|
|
||||||
//
|
|
||||||
|
|
||||||
# include <boost/detail/is_incrementable.hpp>
|
|
||||||
# include <boost/iterator/iterator_traits.hpp>
|
|
||||||
# include <boost/type_traits/remove_cv.hpp>
|
|
||||||
# include <boost/mpl/eval_if.hpp>
|
|
||||||
# include <boost/pointee.hpp>
|
|
||||||
|
|
||||||
namespace boost {
|
|
||||||
|
|
||||||
namespace detail
|
|
||||||
{
|
|
||||||
template <class P>
|
|
||||||
struct smart_ptr_reference
|
|
||||||
{
|
|
||||||
typedef typename boost::pointee<P>::type& type;
|
|
||||||
};
|
|
||||||
}
|
|
||||||
|
|
||||||
template <class P>
|
|
||||||
struct indirect_reference
|
|
||||||
: mpl::eval_if<
|
|
||||||
detail::is_incrementable<P>
|
|
||||||
, iterator_reference<P>
|
|
||||||
, detail::smart_ptr_reference<P>
|
|
||||||
>
|
|
||||||
{
|
|
||||||
};
|
|
||||||
|
|
||||||
} // namespace boost
|
|
||||||
|
|
||||||
#endif // INDIRECT_REFERENCE_DWA200415_HPP
|
|
59
include/boost/iterator.hpp
Normal file
59
include/boost/iterator.hpp
Normal file
@ -0,0 +1,59 @@
|
|||||||
|
// iterator.hpp workarounds for non-conforming standard libraries ---------//
|
||||||
|
|
||||||
|
// (C) Copyright Beman Dawes 2000. 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)
|
||||||
|
|
||||||
|
// See http://www.boost.org/libs/utility for documentation.
|
||||||
|
|
||||||
|
// Revision History
|
||||||
|
// 12 Jan 01 added <cstddef> for std::ptrdiff_t (Jens Maurer)
|
||||||
|
// 28 Jun 00 Workarounds to deal with known MSVC bugs (David Abrahams)
|
||||||
|
// 26 Jun 00 Initial version (Jeremy Siek)
|
||||||
|
|
||||||
|
#ifndef BOOST_ITERATOR_HPP
|
||||||
|
#define BOOST_ITERATOR_HPP
|
||||||
|
|
||||||
|
#include <iterator>
|
||||||
|
#include <cstddef> // std::ptrdiff_t
|
||||||
|
#include <boost/config.hpp>
|
||||||
|
|
||||||
|
namespace boost
|
||||||
|
{
|
||||||
|
# if defined(BOOST_NO_STD_ITERATOR) && !defined(BOOST_MSVC_STD_ITERATOR)
|
||||||
|
template <class Category, class T,
|
||||||
|
class Distance = std::ptrdiff_t,
|
||||||
|
class Pointer = T*, class Reference = T&>
|
||||||
|
struct iterator
|
||||||
|
{
|
||||||
|
typedef T value_type;
|
||||||
|
typedef Distance difference_type;
|
||||||
|
typedef Pointer pointer;
|
||||||
|
typedef Reference reference;
|
||||||
|
typedef Category iterator_category;
|
||||||
|
};
|
||||||
|
# else
|
||||||
|
|
||||||
|
// declare iterator_base in namespace detail to work around MSVC bugs which
|
||||||
|
// prevent derivation from an identically-named class in a different namespace.
|
||||||
|
namespace detail {
|
||||||
|
template <class Category, class T, class Distance, class Pointer, class Reference>
|
||||||
|
# if !defined(BOOST_MSVC_STD_ITERATOR)
|
||||||
|
struct iterator_base : std::iterator<Category, T, Distance, Pointer, Reference> {};
|
||||||
|
# else
|
||||||
|
struct iterator_base : std::iterator<Category, T, Distance>
|
||||||
|
{
|
||||||
|
typedef Reference reference;
|
||||||
|
typedef Pointer pointer;
|
||||||
|
typedef Distance difference_type;
|
||||||
|
};
|
||||||
|
# endif
|
||||||
|
}
|
||||||
|
|
||||||
|
template <class Category, class T, class Distance = std::ptrdiff_t,
|
||||||
|
class Pointer = T*, class Reference = T&>
|
||||||
|
struct iterator : boost::detail::iterator_base<Category, T, Distance, Pointer, Reference> {};
|
||||||
|
# endif
|
||||||
|
} // namespace boost
|
||||||
|
|
||||||
|
#endif // BOOST_ITERATOR_HPP
|
@ -1,95 +0,0 @@
|
|||||||
// Copyright (C) 2017 Michel Morin.
|
|
||||||
//
|
|
||||||
// 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)
|
|
||||||
|
|
||||||
#ifndef BOOST_ITERATOR_ADVANCE_HPP
|
|
||||||
#define BOOST_ITERATOR_ADVANCE_HPP
|
|
||||||
|
|
||||||
#include <boost/config.hpp>
|
|
||||||
#include <boost/detail/workaround.hpp>
|
|
||||||
#include <boost/iterator/iterator_categories.hpp>
|
|
||||||
|
|
||||||
namespace boost {
|
|
||||||
namespace iterators {
|
|
||||||
|
|
||||||
namespace detail {
|
|
||||||
template <typename InputIterator, typename Distance>
|
|
||||||
inline BOOST_CXX14_CONSTEXPR void
|
|
||||||
advance_impl(
|
|
||||||
InputIterator& it
|
|
||||||
, Distance n
|
|
||||||
, incrementable_traversal_tag
|
|
||||||
)
|
|
||||||
{
|
|
||||||
while (n > 0) {
|
|
||||||
++it;
|
|
||||||
--n;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
#if BOOST_WORKAROUND(BOOST_GCC_VERSION, >= 40600)
|
|
||||||
// type-limits warning issued below when n is an unsigned integral
|
|
||||||
#pragma GCC diagnostic push
|
|
||||||
#pragma GCC diagnostic ignored "-Wtype-limits"
|
|
||||||
#endif
|
|
||||||
|
|
||||||
template <typename BidirectionalIterator, typename Distance>
|
|
||||||
inline BOOST_CXX14_CONSTEXPR void
|
|
||||||
advance_impl(
|
|
||||||
BidirectionalIterator& it
|
|
||||||
, Distance n
|
|
||||||
, bidirectional_traversal_tag
|
|
||||||
)
|
|
||||||
{
|
|
||||||
if (n >= 0) {
|
|
||||||
while (n > 0) {
|
|
||||||
++it;
|
|
||||||
--n;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
while (n < 0) {
|
|
||||||
--it;
|
|
||||||
++n;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
#if BOOST_WORKAROUND(BOOST_GCC_VERSION, >= 40600)
|
|
||||||
#pragma GCC diagnostic pop
|
|
||||||
#endif
|
|
||||||
|
|
||||||
template <typename RandomAccessIterator, typename Distance>
|
|
||||||
inline BOOST_CXX14_CONSTEXPR void
|
|
||||||
advance_impl(
|
|
||||||
RandomAccessIterator& it
|
|
||||||
, Distance n
|
|
||||||
, random_access_traversal_tag
|
|
||||||
)
|
|
||||||
{
|
|
||||||
it += n;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
namespace advance_adl_barrier {
|
|
||||||
template <typename InputIterator, typename Distance>
|
|
||||||
inline BOOST_CXX14_CONSTEXPR void
|
|
||||||
advance(InputIterator& it, Distance n)
|
|
||||||
{
|
|
||||||
detail::advance_impl(
|
|
||||||
it, n, typename iterator_traversal<InputIterator>::type()
|
|
||||||
);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
using namespace advance_adl_barrier;
|
|
||||||
|
|
||||||
} // namespace iterators
|
|
||||||
|
|
||||||
using namespace iterators::advance_adl_barrier;
|
|
||||||
|
|
||||||
} // namespace boost
|
|
||||||
|
|
||||||
#endif
|
|
@ -5,24 +5,14 @@
|
|||||||
#ifndef COUNTING_ITERATOR_DWA200348_HPP
|
#ifndef COUNTING_ITERATOR_DWA200348_HPP
|
||||||
# define COUNTING_ITERATOR_DWA200348_HPP
|
# define COUNTING_ITERATOR_DWA200348_HPP
|
||||||
|
|
||||||
# include <boost/config.hpp>
|
|
||||||
# include <boost/static_assert.hpp>
|
|
||||||
# ifndef BOOST_NO_LIMITS_COMPILE_TIME_CONSTANTS
|
|
||||||
# include <limits>
|
|
||||||
# elif !BOOST_WORKAROUND(BOOST_BORLANDC, BOOST_TESTED_AT(0x551))
|
|
||||||
# include <boost/type_traits/is_convertible.hpp>
|
|
||||||
# else
|
|
||||||
# include <boost/type_traits/is_arithmetic.hpp>
|
|
||||||
# endif
|
|
||||||
# include <boost/type_traits/is_integral.hpp>
|
|
||||||
# include <boost/type_traits/type_identity.hpp>
|
|
||||||
# include <boost/type_traits/conditional.hpp>
|
|
||||||
# include <boost/type_traits/integral_constant.hpp>
|
|
||||||
# include <boost/detail/numeric_traits.hpp>
|
|
||||||
# include <boost/iterator/iterator_adaptor.hpp>
|
# include <boost/iterator/iterator_adaptor.hpp>
|
||||||
|
# include <boost/detail/numeric_traits.hpp>
|
||||||
|
# include <boost/mpl/bool.hpp>
|
||||||
|
# include <boost/mpl/if.hpp>
|
||||||
|
# include <boost/mpl/identity.hpp>
|
||||||
|
# include <boost/mpl/eval_if.hpp>
|
||||||
|
|
||||||
namespace boost {
|
namespace boost {
|
||||||
namespace iterators {
|
|
||||||
|
|
||||||
template <
|
template <
|
||||||
class Incrementable
|
class Incrementable
|
||||||
@ -47,7 +37,7 @@ namespace detail
|
|||||||
|
|
||||||
# else
|
# else
|
||||||
|
|
||||||
# if !BOOST_WORKAROUND(BOOST_BORLANDC, BOOST_TESTED_AT(0x551))
|
# if !BOOST_WORKAROUND(__BORLANDC__, BOOST_TESTED_AT(0x551))
|
||||||
BOOST_STATIC_CONSTANT(
|
BOOST_STATIC_CONSTANT(
|
||||||
bool, value = (
|
bool, value = (
|
||||||
boost::is_convertible<int,T>::value
|
boost::is_convertible<int,T>::value
|
||||||
@ -62,33 +52,23 @@ namespace detail
|
|||||||
|
|
||||||
template <class T>
|
template <class T>
|
||||||
struct is_numeric
|
struct is_numeric
|
||||||
: boost::integral_constant<bool, ::boost::iterators::detail::is_numeric_impl<T>::value>
|
: mpl::bool_<(::boost::detail::is_numeric_impl<T>::value)>
|
||||||
{};
|
{};
|
||||||
|
|
||||||
# if defined(BOOST_HAS_LONG_LONG)
|
# if defined(BOOST_HAS_LONG_LONG)
|
||||||
template <>
|
template <>
|
||||||
struct is_numeric<boost::long_long_type>
|
struct is_numeric< ::boost::long_long_type>
|
||||||
: boost::true_type {};
|
: mpl::true_ {};
|
||||||
|
|
||||||
template <>
|
template <>
|
||||||
struct is_numeric<boost::ulong_long_type>
|
struct is_numeric< ::boost::ulong_long_type>
|
||||||
: boost::true_type {};
|
: mpl::true_ {};
|
||||||
# endif
|
|
||||||
|
|
||||||
# if defined(BOOST_HAS_INT128)
|
|
||||||
template <>
|
|
||||||
struct is_numeric<boost::int128_type>
|
|
||||||
: boost::true_type {};
|
|
||||||
|
|
||||||
template <>
|
|
||||||
struct is_numeric<boost::uint128_type>
|
|
||||||
: boost::true_type {};
|
|
||||||
# endif
|
# endif
|
||||||
|
|
||||||
// Some compilers fail to have a numeric_limits specialization
|
// Some compilers fail to have a numeric_limits specialization
|
||||||
template <>
|
template <>
|
||||||
struct is_numeric<wchar_t>
|
struct is_numeric<wchar_t>
|
||||||
: true_type {};
|
: mpl::true_ {};
|
||||||
|
|
||||||
template <class T>
|
template <class T>
|
||||||
struct numeric_difference
|
struct numeric_difference
|
||||||
@ -96,40 +76,27 @@ namespace detail
|
|||||||
typedef typename boost::detail::numeric_traits<T>::difference_type type;
|
typedef typename boost::detail::numeric_traits<T>::difference_type type;
|
||||||
};
|
};
|
||||||
|
|
||||||
# if defined(BOOST_HAS_INT128)
|
BOOST_STATIC_ASSERT(is_numeric<int>::value);
|
||||||
// std::numeric_limits, which is used by numeric_traits, is not specialized for __int128 in some standard libraries
|
|
||||||
template <>
|
|
||||||
struct numeric_difference<boost::int128_type>
|
|
||||||
{
|
|
||||||
typedef boost::int128_type type;
|
|
||||||
};
|
|
||||||
|
|
||||||
template <>
|
|
||||||
struct numeric_difference<boost::uint128_type>
|
|
||||||
{
|
|
||||||
typedef boost::int128_type type;
|
|
||||||
};
|
|
||||||
# endif
|
|
||||||
|
|
||||||
template <class Incrementable, class CategoryOrTraversal, class Difference>
|
template <class Incrementable, class CategoryOrTraversal, class Difference>
|
||||||
struct counting_iterator_base
|
struct counting_iterator_base
|
||||||
{
|
{
|
||||||
typedef typename detail::ia_dflt_help<
|
typedef typename detail::ia_dflt_help<
|
||||||
CategoryOrTraversal
|
CategoryOrTraversal
|
||||||
, typename boost::conditional<
|
, mpl::eval_if<
|
||||||
is_numeric<Incrementable>::value
|
is_numeric<Incrementable>
|
||||||
, boost::type_identity<random_access_traversal_tag>
|
, mpl::identity<random_access_traversal_tag>
|
||||||
, iterator_traversal<Incrementable>
|
, iterator_traversal<Incrementable>
|
||||||
>::type
|
>
|
||||||
>::type traversal;
|
>::type traversal;
|
||||||
|
|
||||||
typedef typename detail::ia_dflt_help<
|
typedef typename detail::ia_dflt_help<
|
||||||
Difference
|
Difference
|
||||||
, typename boost::conditional<
|
, mpl::eval_if<
|
||||||
is_numeric<Incrementable>::value
|
is_numeric<Incrementable>
|
||||||
, numeric_difference<Incrementable>
|
, numeric_difference<Incrementable>
|
||||||
, iterator_difference<Incrementable>
|
, iterator_difference<Incrementable>
|
||||||
>::type
|
>
|
||||||
>::type difference;
|
>::type difference;
|
||||||
|
|
||||||
typedef iterator_adaptor<
|
typedef iterator_adaptor<
|
||||||
@ -169,7 +136,7 @@ namespace detail
|
|||||||
{
|
{
|
||||||
static Difference distance(Incrementable1 x, Incrementable2 y)
|
static Difference distance(Incrementable1 x, Incrementable2 y)
|
||||||
{
|
{
|
||||||
return boost::detail::numeric_distance(x, y);
|
return numeric_distance(x, y);
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
@ -193,9 +160,9 @@ class counting_iterator
|
|||||||
public:
|
public:
|
||||||
typedef typename super_t::difference_type difference_type;
|
typedef typename super_t::difference_type difference_type;
|
||||||
|
|
||||||
BOOST_DEFAULTED_FUNCTION(counting_iterator(), {})
|
counting_iterator() { }
|
||||||
|
|
||||||
BOOST_DEFAULTED_FUNCTION(counting_iterator(counting_iterator const& rhs), : super_t(rhs.base()) {})
|
counting_iterator(counting_iterator const& rhs) : super_t(rhs.base()) {}
|
||||||
|
|
||||||
counting_iterator(Incrementable x)
|
counting_iterator(Incrementable x)
|
||||||
: super_t(x)
|
: super_t(x)
|
||||||
@ -212,8 +179,6 @@ class counting_iterator
|
|||||||
{}
|
{}
|
||||||
# endif
|
# endif
|
||||||
|
|
||||||
BOOST_DEFAULTED_FUNCTION(counting_iterator& operator=(counting_iterator const& rhs), { *static_cast< super_t* >(this) = static_cast< super_t const& >(rhs); return *this; })
|
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
|
||||||
typename super_t::reference dereference() const
|
typename super_t::reference dereference() const
|
||||||
@ -225,8 +190,8 @@ class counting_iterator
|
|||||||
difference_type
|
difference_type
|
||||||
distance_to(counting_iterator<OtherIncrementable, CategoryOrTraversal, Difference> const& y) const
|
distance_to(counting_iterator<OtherIncrementable, CategoryOrTraversal, Difference> const& y) const
|
||||||
{
|
{
|
||||||
typedef typename boost::conditional<
|
typedef typename mpl::if_<
|
||||||
detail::is_numeric<Incrementable>::value
|
detail::is_numeric<Incrementable>
|
||||||
, detail::number_distance<difference_type, Incrementable, OtherIncrementable>
|
, detail::number_distance<difference_type, Incrementable, OtherIncrementable>
|
||||||
, detail::iterator_distance<difference_type, Incrementable, OtherIncrementable>
|
, detail::iterator_distance<difference_type, Incrementable, OtherIncrementable>
|
||||||
>::type d;
|
>::type d;
|
||||||
@ -244,11 +209,7 @@ make_counting_iterator(Incrementable x)
|
|||||||
return result_t(x);
|
return result_t(x);
|
||||||
}
|
}
|
||||||
|
|
||||||
} // namespace iterators
|
|
||||||
|
|
||||||
using iterators::counting_iterator;
|
} // namespace boost::iterator
|
||||||
using iterators::make_counting_iterator;
|
|
||||||
|
|
||||||
} // namespace boost
|
|
||||||
|
|
||||||
#endif // COUNTING_ITERATOR_DWA200348_HPP
|
#endif // COUNTING_ITERATOR_DWA200348_HPP
|
||||||
|
@ -4,9 +4,7 @@
|
|||||||
#ifndef ANY_CONVERSION_EATER_DWA20031117_HPP
|
#ifndef ANY_CONVERSION_EATER_DWA20031117_HPP
|
||||||
# define ANY_CONVERSION_EATER_DWA20031117_HPP
|
# define ANY_CONVERSION_EATER_DWA20031117_HPP
|
||||||
|
|
||||||
namespace boost {
|
namespace boost { namespace detail {
|
||||||
namespace iterators {
|
|
||||||
namespace detail {
|
|
||||||
|
|
||||||
// This type can be used in traits to "eat" up the one user-defined
|
// This type can be used in traits to "eat" up the one user-defined
|
||||||
// implicit conversion allowed.
|
// implicit conversion allowed.
|
||||||
@ -16,6 +14,6 @@ struct any_conversion_eater
|
|||||||
any_conversion_eater(T const&);
|
any_conversion_eater(T const&);
|
||||||
};
|
};
|
||||||
|
|
||||||
}}} // namespace boost::iterators::detail
|
}} // namespace boost::detail
|
||||||
|
|
||||||
#endif // ANY_CONVERSION_EATER_DWA20031117_HPP
|
#endif // ANY_CONVERSION_EATER_DWA20031117_HPP
|
||||||
|
@ -27,7 +27,7 @@
|
|||||||
// because the operator-> return is improperly deduced as a non-const
|
// because the operator-> return is improperly deduced as a non-const
|
||||||
// pointer.
|
// pointer.
|
||||||
#if 1 || defined(BOOST_NO_TEMPLATE_PARTIAL_SPECIALIZATION) \
|
#if 1 || defined(BOOST_NO_TEMPLATE_PARTIAL_SPECIALIZATION) \
|
||||||
|| BOOST_WORKAROUND(BOOST_BORLANDC, BOOST_TESTED_AT(0x531))
|
|| BOOST_WORKAROUND(__BORLANDC__, BOOST_TESTED_AT(0x531))
|
||||||
|
|
||||||
// Recall that in general, compilers without partial specialization
|
// Recall that in general, compilers without partial specialization
|
||||||
// can't strip constness. Consider counting_iterator, which normally
|
// can't strip constness. Consider counting_iterator, which normally
|
||||||
@ -46,7 +46,8 @@
|
|||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if BOOST_WORKAROUND(BOOST_BORLANDC, BOOST_TESTED_AT(0x5A0)) \
|
#if BOOST_WORKAROUND(BOOST_MSVC, <= 1300) \
|
||||||
|
|| BOOST_WORKAROUND(__BORLANDC__, BOOST_TESTED_AT(0x5A0)) \
|
||||||
|| (BOOST_WORKAROUND(BOOST_INTEL_CXX_VERSION, <= 700) && defined(_MSC_VER)) \
|
|| (BOOST_WORKAROUND(BOOST_INTEL_CXX_VERSION, <= 700) && defined(_MSC_VER)) \
|
||||||
|| BOOST_WORKAROUND(__DECCXX_VER, BOOST_TESTED_AT(60590042)) \
|
|| BOOST_WORKAROUND(__DECCXX_VER, BOOST_TESTED_AT(60590042)) \
|
||||||
|| BOOST_WORKAROUND(__SUNPRO_CC, BOOST_TESTED_AT(0x590))
|
|| BOOST_WORKAROUND(__SUNPRO_CC, BOOST_TESTED_AT(0x590))
|
||||||
@ -87,8 +88,9 @@
|
|||||||
# define BOOST_NO_IS_CONVERTIBLE // "is_convertible doesn't work for simple types"
|
# define BOOST_NO_IS_CONVERTIBLE // "is_convertible doesn't work for simple types"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if BOOST_WORKAROUND(__GNUC__, == 3) && BOOST_WORKAROUND(__GNUC_MINOR__, < 4) && !defined(__EDG_VERSION__) \
|
#if BOOST_WORKAROUND(__GNUC__, == 2) \
|
||||||
|| BOOST_WORKAROUND(BOOST_BORLANDC, BOOST_TESTED_AT(0x551))
|
|| BOOST_WORKAROUND(__GNUC__, == 3) && BOOST_WORKAROUND(__GNUC_MINOR__, < 4) && !defined(__EDG_VERSION__) \
|
||||||
|
|| BOOST_WORKAROUND(__BORLANDC__, BOOST_TESTED_AT(0x551))
|
||||||
# define BOOST_NO_IS_CONVERTIBLE_TEMPLATE // The following program fails to compile:
|
# define BOOST_NO_IS_CONVERTIBLE_TEMPLATE // The following program fails to compile:
|
||||||
|
|
||||||
# if 0 // test code
|
# if 0 // test code
|
||||||
@ -114,9 +116,16 @@
|
|||||||
# define BOOST_NO_STRICT_ITERATOR_INTEROPERABILITY
|
# define BOOST_NO_STRICT_ITERATOR_INTEROPERABILITY
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
# if BOOST_WORKAROUND(BOOST_BORLANDC, BOOST_TESTED_AT(0x564))
|
# if !BOOST_WORKAROUND(BOOST_MSVC, <= 1300)
|
||||||
|
# define BOOST_ARG_DEPENDENT_TYPENAME typename
|
||||||
|
# else
|
||||||
|
# define BOOST_ARG_DEPENDENT_TYPENAME
|
||||||
|
# endif
|
||||||
|
|
||||||
// GCC-2.95 (obsolete) eagerly instantiates templated constructors and conversion
|
# if BOOST_WORKAROUND(__GNUC__, == 2) && BOOST_WORKAROUND(__GNUC_MINOR__, BOOST_TESTED_AT(95)) \
|
||||||
|
|| BOOST_WORKAROUND(__BORLANDC__, BOOST_TESTED_AT(0x564))
|
||||||
|
|
||||||
|
// GCC-2.95 eagerly instantiates templated constructors and conversion
|
||||||
// operators in convertibility checks, causing premature errors.
|
// operators in convertibility checks, causing premature errors.
|
||||||
//
|
//
|
||||||
// Borland's problems are harder to diagnose due to lack of an
|
// Borland's problems are harder to diagnose due to lack of an
|
||||||
|
@ -14,6 +14,7 @@
|
|||||||
#undef BOOST_NO_IS_CONVERTIBLE
|
#undef BOOST_NO_IS_CONVERTIBLE
|
||||||
#undef BOOST_NO_IS_CONVERTIBLE_TEMPLATE
|
#undef BOOST_NO_IS_CONVERTIBLE_TEMPLATE
|
||||||
#undef BOOST_NO_STRICT_ITERATOR_INTEROPERABILITY
|
#undef BOOST_NO_STRICT_ITERATOR_INTEROPERABILITY
|
||||||
|
#undef BOOST_ARG_DEPENDENT_TYPENAME
|
||||||
#undef BOOST_NO_LVALUE_RETURN_DETECTION
|
#undef BOOST_NO_LVALUE_RETURN_DETECTION
|
||||||
#undef BOOST_NO_ONE_WAY_ITERATOR_INTEROP
|
#undef BOOST_NO_ONE_WAY_ITERATOR_INTEROP
|
||||||
|
|
||||||
|
@ -7,11 +7,10 @@
|
|||||||
#ifndef BOOST_ENABLE_IF_23022003THW_HPP
|
#ifndef BOOST_ENABLE_IF_23022003THW_HPP
|
||||||
#define BOOST_ENABLE_IF_23022003THW_HPP
|
#define BOOST_ENABLE_IF_23022003THW_HPP
|
||||||
|
|
||||||
#include <boost/config.hpp>
|
#include <boost/detail/workaround.hpp>
|
||||||
|
#include <boost/mpl/identity.hpp>
|
||||||
|
|
||||||
#include <boost/iterator/detail/config_def.hpp>
|
#include <boost/iterator/detail/config_def.hpp>
|
||||||
#if defined(BOOST_NO_SFINAE) || defined(BOOST_NO_IS_CONVERTIBLE)
|
|
||||||
#include <boost/type_traits/type_identity.hpp>
|
|
||||||
#endif
|
|
||||||
|
|
||||||
//
|
//
|
||||||
// Boost iterators uses its own enable_if cause we need
|
// Boost iterators uses its own enable_if cause we need
|
||||||
@ -49,6 +48,7 @@ namespace boost
|
|||||||
struct base
|
struct base
|
||||||
{
|
{
|
||||||
#ifdef BOOST_NO_SFINAE
|
#ifdef BOOST_NO_SFINAE
|
||||||
|
|
||||||
typedef T type;
|
typedef T type;
|
||||||
|
|
||||||
// This way to do it would give a nice error message containing
|
// This way to do it would give a nice error message containing
|
||||||
@ -69,9 +69,12 @@ namespace boost
|
|||||||
# if !defined(BOOST_NO_SFINAE) && !defined(BOOST_NO_IS_CONVERTIBLE)
|
# if !defined(BOOST_NO_SFINAE) && !defined(BOOST_NO_IS_CONVERTIBLE)
|
||||||
: enabled<(Cond::value)>::template base<Return>
|
: enabled<(Cond::value)>::template base<Return>
|
||||||
# else
|
# else
|
||||||
: boost::type_identity<Return>
|
: mpl::identity<Return>
|
||||||
# endif
|
# endif
|
||||||
{
|
{
|
||||||
|
# if BOOST_WORKAROUND(BOOST_MSVC, < 1300)
|
||||||
|
typedef Return type;
|
||||||
|
# endif
|
||||||
};
|
};
|
||||||
|
|
||||||
} // namespace iterators
|
} // namespace iterators
|
||||||
|
@ -4,8 +4,6 @@
|
|||||||
#ifndef FACADE_ITERATOR_CATEGORY_DWA20031118_HPP
|
#ifndef FACADE_ITERATOR_CATEGORY_DWA20031118_HPP
|
||||||
# define FACADE_ITERATOR_CATEGORY_DWA20031118_HPP
|
# define FACADE_ITERATOR_CATEGORY_DWA20031118_HPP
|
||||||
|
|
||||||
# include <boost/core/use_default.hpp>
|
|
||||||
|
|
||||||
# include <boost/iterator/iterator_categories.hpp>
|
# include <boost/iterator/iterator_categories.hpp>
|
||||||
|
|
||||||
# include <boost/mpl/or.hpp> // used in iterator_tag inheritance logic
|
# include <boost/mpl/or.hpp> // used in iterator_tag inheritance logic
|
||||||
@ -13,14 +11,15 @@
|
|||||||
# include <boost/mpl/if.hpp>
|
# include <boost/mpl/if.hpp>
|
||||||
# include <boost/mpl/eval_if.hpp>
|
# include <boost/mpl/eval_if.hpp>
|
||||||
# include <boost/mpl/identity.hpp>
|
# include <boost/mpl/identity.hpp>
|
||||||
|
# include <boost/mpl/assert.hpp>
|
||||||
# include <boost/static_assert.hpp>
|
|
||||||
|
|
||||||
# include <boost/type_traits/is_same.hpp>
|
# include <boost/type_traits/is_same.hpp>
|
||||||
# include <boost/type_traits/is_const.hpp>
|
# include <boost/type_traits/is_const.hpp>
|
||||||
# include <boost/type_traits/is_reference.hpp>
|
# include <boost/type_traits/is_reference.hpp>
|
||||||
# include <boost/type_traits/is_convertible.hpp>
|
# include <boost/type_traits/is_convertible.hpp>
|
||||||
|
|
||||||
|
# include <boost/type_traits/is_same.hpp>
|
||||||
|
|
||||||
# include <boost/iterator/detail/config_def.hpp> // try to keep this last
|
# include <boost/iterator/detail/config_def.hpp> // try to keep this last
|
||||||
|
|
||||||
# ifdef BOOST_ITERATOR_REF_CONSTNESS_KILLS_WRITABILITY
|
# ifdef BOOST_ITERATOR_REF_CONSTNESS_KILLS_WRITABILITY
|
||||||
@ -31,12 +30,10 @@
|
|||||||
// iterator_category deduction for iterator_facade
|
// iterator_category deduction for iterator_facade
|
||||||
//
|
//
|
||||||
|
|
||||||
namespace boost {
|
// forward declaration
|
||||||
namespace iterators {
|
namespace boost { struct use_default; }
|
||||||
|
|
||||||
using boost::use_default;
|
namespace boost { namespace detail {
|
||||||
|
|
||||||
namespace detail {
|
|
||||||
|
|
||||||
struct input_output_iterator_tag
|
struct input_output_iterator_tag
|
||||||
: std::input_iterator_tag
|
: std::input_iterator_tag
|
||||||
@ -76,10 +73,16 @@ struct iterator_writability_disabled
|
|||||||
// Convert an iterator_facade's traversal category, Value parameter,
|
// Convert an iterator_facade's traversal category, Value parameter,
|
||||||
// and ::reference type to an appropriate old-style category.
|
// and ::reference type to an appropriate old-style category.
|
||||||
//
|
//
|
||||||
// Due to changeset 21683, this now never results in a category convertible
|
// If writability has been disabled per the above metafunction, the
|
||||||
// to output_iterator_tag.
|
// result will not be convertible to output_iterator_tag.
|
||||||
|
//
|
||||||
|
// Otherwise, if Traversal == single_pass_traversal_tag, the following
|
||||||
|
// conditions will result in a tag that is convertible both to
|
||||||
|
// input_iterator_tag and output_iterator_tag:
|
||||||
|
//
|
||||||
|
// 1. Reference is a reference to non-const
|
||||||
|
// 2. Reference is not a reference and is convertible to Value
|
||||||
//
|
//
|
||||||
// Change at: https://svn.boost.org/trac/boost/changeset/21683
|
|
||||||
template <class Traversal, class ValueParam, class Reference>
|
template <class Traversal, class ValueParam, class Reference>
|
||||||
struct iterator_facade_default_category
|
struct iterator_facade_default_category
|
||||||
: mpl::eval_if<
|
: mpl::eval_if<
|
||||||
@ -135,20 +138,22 @@ template <class Category, class Traversal>
|
|||||||
struct iterator_category_with_traversal
|
struct iterator_category_with_traversal
|
||||||
: Category, Traversal
|
: Category, Traversal
|
||||||
{
|
{
|
||||||
|
# if !BOOST_WORKAROUND(BOOST_MSVC, <= 1300)
|
||||||
// Make sure this isn't used to build any categories where
|
// Make sure this isn't used to build any categories where
|
||||||
// convertibility to Traversal is redundant. Should just use the
|
// convertibility to Traversal is redundant. Should just use the
|
||||||
// Category element in that case.
|
// Category element in that case.
|
||||||
BOOST_STATIC_ASSERT((
|
BOOST_MPL_ASSERT_NOT((
|
||||||
!is_convertible<
|
is_convertible<
|
||||||
typename iterator_category_to_traversal<Category>::type
|
typename iterator_category_to_traversal<Category>::type
|
||||||
, Traversal
|
, Traversal
|
||||||
>::value));
|
>));
|
||||||
|
|
||||||
BOOST_STATIC_ASSERT(is_iterator_category<Category>::value);
|
BOOST_MPL_ASSERT((is_iterator_category<Category>));
|
||||||
BOOST_STATIC_ASSERT(!is_iterator_category<Traversal>::value);
|
BOOST_MPL_ASSERT_NOT((is_iterator_category<Traversal>));
|
||||||
BOOST_STATIC_ASSERT(!is_iterator_traversal<Category>::value);
|
BOOST_MPL_ASSERT_NOT((is_iterator_traversal<Category>));
|
||||||
# if !BOOST_WORKAROUND(BOOST_MSVC, BOOST_TESTED_AT(1310))
|
# if !BOOST_WORKAROUND(BOOST_MSVC, BOOST_TESTED_AT(1310))
|
||||||
BOOST_STATIC_ASSERT(is_iterator_traversal<Traversal>::value);
|
BOOST_MPL_ASSERT((is_iterator_traversal<Traversal>));
|
||||||
|
# endif
|
||||||
# endif
|
# endif
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -157,7 +162,9 @@ struct iterator_category_with_traversal
|
|||||||
template <class Traversal, class ValueParam, class Reference>
|
template <class Traversal, class ValueParam, class Reference>
|
||||||
struct facade_iterator_category_impl
|
struct facade_iterator_category_impl
|
||||||
{
|
{
|
||||||
BOOST_STATIC_ASSERT(!is_iterator_category<Traversal>::value);
|
# if !BOOST_WORKAROUND(BOOST_MSVC, <= 1300)
|
||||||
|
BOOST_MPL_ASSERT_NOT((is_iterator_category<Traversal>));
|
||||||
|
# endif
|
||||||
|
|
||||||
typedef typename iterator_facade_default_category<
|
typedef typename iterator_facade_default_category<
|
||||||
Traversal,ValueParam,Reference
|
Traversal,ValueParam,Reference
|
||||||
@ -186,7 +193,7 @@ struct facade_iterator_category
|
|||||||
{
|
{
|
||||||
};
|
};
|
||||||
|
|
||||||
}}} // namespace boost::iterators::detail
|
}} // namespace boost::detail
|
||||||
|
|
||||||
# include <boost/iterator/detail/config_undef.hpp>
|
# include <boost/iterator/detail/config_undef.hpp>
|
||||||
|
|
||||||
|
@ -4,16 +4,113 @@
|
|||||||
#ifndef MINIMUM_CATEGORY_DWA20031119_HPP
|
#ifndef MINIMUM_CATEGORY_DWA20031119_HPP
|
||||||
# define MINIMUM_CATEGORY_DWA20031119_HPP
|
# define MINIMUM_CATEGORY_DWA20031119_HPP
|
||||||
|
|
||||||
# include <boost/iterator/minimum_category.hpp>
|
# include <boost/type_traits/is_convertible.hpp>
|
||||||
|
# include <boost/type_traits/is_same.hpp>
|
||||||
|
|
||||||
namespace boost {
|
# include <boost/mpl/aux_/lambda_support.hpp>
|
||||||
|
|
||||||
// This import below (as well as the whole header) is for backward compatibility
|
namespace boost { namespace detail {
|
||||||
// with boost/token_iterator.hpp. It should be removed as soon as that header is fixed.
|
//
|
||||||
namespace detail {
|
// Returns the minimum category type or error_type
|
||||||
using iterators::minimum_category;
|
// if T1 and T2 are unrelated.
|
||||||
} // namespace detail
|
//
|
||||||
|
// For compilers not supporting is_convertible this only
|
||||||
|
// works with the new boost return and traversal category
|
||||||
|
// types. The exact boost _types_ are required. No derived types
|
||||||
|
// will work.
|
||||||
|
//
|
||||||
|
//
|
||||||
|
template <bool GreaterEqual, bool LessEqual>
|
||||||
|
struct minimum_category_impl
|
||||||
|
# if BOOST_WORKAROUND(BOOST_MSVC, < 1300)
|
||||||
|
{
|
||||||
|
template <class T1, class T2> struct apply
|
||||||
|
{
|
||||||
|
typedef T2 type;
|
||||||
|
};
|
||||||
|
typedef void type;
|
||||||
|
}
|
||||||
|
# endif
|
||||||
|
;
|
||||||
|
|
||||||
} // namespace boost
|
template <class T1, class T2>
|
||||||
|
struct error_not_related_by_convertibility;
|
||||||
|
|
||||||
|
template <>
|
||||||
|
struct minimum_category_impl<true,false>
|
||||||
|
{
|
||||||
|
template <class T1, class T2> struct apply
|
||||||
|
{
|
||||||
|
typedef T2 type;
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
template <>
|
||||||
|
struct minimum_category_impl<false,true>
|
||||||
|
{
|
||||||
|
template <class T1, class T2> struct apply
|
||||||
|
{
|
||||||
|
typedef T1 type;
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
template <>
|
||||||
|
struct minimum_category_impl<true,true>
|
||||||
|
{
|
||||||
|
template <class T1, class T2> struct apply
|
||||||
|
{
|
||||||
|
BOOST_STATIC_ASSERT((is_same<T1,T2>::value));
|
||||||
|
typedef T1 type;
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
template <>
|
||||||
|
struct minimum_category_impl<false,false>
|
||||||
|
{
|
||||||
|
template <class T1, class T2> struct apply
|
||||||
|
: error_not_related_by_convertibility<T1,T2>
|
||||||
|
{
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
template <class T1 = mpl::_1, class T2 = mpl::_2>
|
||||||
|
struct minimum_category
|
||||||
|
{
|
||||||
|
typedef minimum_category_impl<
|
||||||
|
# if BOOST_WORKAROUND(BOOST_MSVC, < 1300) // ETI workaround
|
||||||
|
is_same<T2,int>::value ||
|
||||||
|
# endif
|
||||||
|
::boost::is_convertible<T1,T2>::value
|
||||||
|
, ::boost::is_convertible<T2,T1>::value
|
||||||
|
# if BOOST_WORKAROUND(BOOST_MSVC, < 1300) // ETI workaround
|
||||||
|
|| is_same<T1,int>::value
|
||||||
|
# endif
|
||||||
|
> outer;
|
||||||
|
|
||||||
|
typedef typename outer::template apply<T1,T2> inner;
|
||||||
|
typedef typename inner::type type;
|
||||||
|
|
||||||
|
BOOST_MPL_AUX_LAMBDA_SUPPORT(2,minimum_category,(T1,T2))
|
||||||
|
};
|
||||||
|
|
||||||
|
template <>
|
||||||
|
struct minimum_category<mpl::_1,mpl::_2>
|
||||||
|
{
|
||||||
|
template <class T1, class T2>
|
||||||
|
struct apply : minimum_category<T1,T2>
|
||||||
|
{};
|
||||||
|
|
||||||
|
BOOST_MPL_AUX_LAMBDA_SUPPORT_SPEC(2,minimum_category,(mpl::_1,mpl::_2))
|
||||||
|
};
|
||||||
|
|
||||||
|
# if BOOST_WORKAROUND(BOOST_MSVC, < 1300) // ETI workaround
|
||||||
|
template <>
|
||||||
|
struct minimum_category<int,int>
|
||||||
|
{
|
||||||
|
typedef int type;
|
||||||
|
};
|
||||||
|
# endif
|
||||||
|
|
||||||
|
}} // namespace boost::detail
|
||||||
|
|
||||||
#endif // MINIMUM_CATEGORY_DWA20031119_HPP
|
#endif // MINIMUM_CATEGORY_DWA20031119_HPP
|
||||||
|
@ -1,65 +0,0 @@
|
|||||||
// Copyright (C) 2017 Michel Morin.
|
|
||||||
//
|
|
||||||
// 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)
|
|
||||||
|
|
||||||
#ifndef BOOST_ITERATOR_DISTANCE_HPP
|
|
||||||
#define BOOST_ITERATOR_DISTANCE_HPP
|
|
||||||
|
|
||||||
#include <boost/config.hpp>
|
|
||||||
#include <boost/iterator/iterator_categories.hpp>
|
|
||||||
#include <boost/iterator/iterator_traits.hpp>
|
|
||||||
|
|
||||||
namespace boost {
|
|
||||||
namespace iterators {
|
|
||||||
|
|
||||||
namespace detail {
|
|
||||||
template <typename SinglePassIterator>
|
|
||||||
inline BOOST_CXX14_CONSTEXPR typename iterator_difference<SinglePassIterator>::type
|
|
||||||
distance_impl(
|
|
||||||
SinglePassIterator first
|
|
||||||
, SinglePassIterator last
|
|
||||||
, single_pass_traversal_tag
|
|
||||||
)
|
|
||||||
{
|
|
||||||
typename iterator_difference<SinglePassIterator>::type n = 0;
|
|
||||||
while (first != last) {
|
|
||||||
++first;
|
|
||||||
++n;
|
|
||||||
}
|
|
||||||
return n;
|
|
||||||
}
|
|
||||||
|
|
||||||
template <typename RandomAccessIterator>
|
|
||||||
inline BOOST_CXX14_CONSTEXPR typename iterator_difference<RandomAccessIterator>::type
|
|
||||||
distance_impl(
|
|
||||||
RandomAccessIterator first
|
|
||||||
, RandomAccessIterator last
|
|
||||||
, random_access_traversal_tag
|
|
||||||
)
|
|
||||||
{
|
|
||||||
return last - first;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
namespace distance_adl_barrier {
|
|
||||||
template <typename SinglePassIterator>
|
|
||||||
inline BOOST_CXX14_CONSTEXPR typename iterator_difference<SinglePassIterator>::type
|
|
||||||
distance(SinglePassIterator first, SinglePassIterator last)
|
|
||||||
{
|
|
||||||
return detail::distance_impl(
|
|
||||||
first, last, typename iterator_traversal<SinglePassIterator>::type()
|
|
||||||
);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
using namespace distance_adl_barrier;
|
|
||||||
|
|
||||||
} // namespace iterators
|
|
||||||
|
|
||||||
using namespace iterators::distance_adl_barrier;
|
|
||||||
|
|
||||||
} // namespace boost
|
|
||||||
|
|
||||||
#endif
|
|
@ -7,23 +7,15 @@
|
|||||||
#ifndef BOOST_FILTER_ITERATOR_23022003THW_HPP
|
#ifndef BOOST_FILTER_ITERATOR_23022003THW_HPP
|
||||||
#define BOOST_FILTER_ITERATOR_23022003THW_HPP
|
#define BOOST_FILTER_ITERATOR_23022003THW_HPP
|
||||||
|
|
||||||
|
#include <boost/iterator.hpp>
|
||||||
#include <boost/iterator/iterator_adaptor.hpp>
|
#include <boost/iterator/iterator_adaptor.hpp>
|
||||||
#include <boost/iterator/iterator_categories.hpp>
|
#include <boost/iterator/iterator_categories.hpp>
|
||||||
|
|
||||||
#include <boost/type_traits/is_class.hpp>
|
#include <boost/type_traits/is_class.hpp>
|
||||||
#include <boost/static_assert.hpp>
|
#include <boost/static_assert.hpp>
|
||||||
#include <boost/config.hpp>
|
|
||||||
#include <boost/config/workaround.hpp>
|
|
||||||
|
|
||||||
#ifndef BOOST_NO_CXX11_RVALUE_REFERENCES
|
|
||||||
#define BOOST_ITERATOR_DETAIL_MOVE(_type, _value) static_cast< _type&& >(_value)
|
|
||||||
#else
|
|
||||||
#define BOOST_ITERATOR_DETAIL_MOVE(_type, _value) _value
|
|
||||||
#endif
|
|
||||||
|
|
||||||
namespace boost {
|
|
||||||
namespace iterators {
|
|
||||||
|
|
||||||
|
namespace boost
|
||||||
|
{
|
||||||
template <class Predicate, class Iterator>
|
template <class Predicate, class Iterator>
|
||||||
class filter_iterator;
|
class filter_iterator;
|
||||||
|
|
||||||
@ -62,13 +54,13 @@ namespace iterators {
|
|||||||
filter_iterator() { }
|
filter_iterator() { }
|
||||||
|
|
||||||
filter_iterator(Predicate f, Iterator x, Iterator end_ = Iterator())
|
filter_iterator(Predicate f, Iterator x, Iterator end_ = Iterator())
|
||||||
: super_t(BOOST_ITERATOR_DETAIL_MOVE(Iterator, x)), m_predicate(BOOST_ITERATOR_DETAIL_MOVE(Predicate, f)), m_end(BOOST_ITERATOR_DETAIL_MOVE(Iterator, end_))
|
: super_t(x), m_predicate(f), m_end(end_)
|
||||||
{
|
{
|
||||||
satisfy_predicate();
|
satisfy_predicate();
|
||||||
}
|
}
|
||||||
|
|
||||||
filter_iterator(Iterator x, Iterator end_ = Iterator())
|
filter_iterator(Iterator x, Iterator end_ = Iterator())
|
||||||
: super_t(BOOST_ITERATOR_DETAIL_MOVE(Iterator, x)), m_predicate(), m_end(BOOST_ITERATOR_DETAIL_MOVE(Iterator, end_))
|
: super_t(x), m_predicate(), m_end(end_)
|
||||||
{
|
{
|
||||||
// Pro8 is a little too aggressive about instantiating the
|
// Pro8 is a little too aggressive about instantiating the
|
||||||
// body of this function.
|
// body of this function.
|
||||||
@ -116,31 +108,28 @@ namespace iterators {
|
|||||||
};
|
};
|
||||||
|
|
||||||
template <class Predicate, class Iterator>
|
template <class Predicate, class Iterator>
|
||||||
inline filter_iterator<Predicate,Iterator>
|
filter_iterator<Predicate,Iterator>
|
||||||
make_filter_iterator(Predicate f, Iterator x, Iterator end = Iterator())
|
make_filter_iterator(Predicate f, Iterator x, Iterator end = Iterator())
|
||||||
{
|
{
|
||||||
return filter_iterator<Predicate,Iterator>(BOOST_ITERATOR_DETAIL_MOVE(Predicate, f), BOOST_ITERATOR_DETAIL_MOVE(Iterator, x), BOOST_ITERATOR_DETAIL_MOVE(Iterator, end));
|
return filter_iterator<Predicate,Iterator>(f,x,end);
|
||||||
}
|
}
|
||||||
|
|
||||||
template <class Predicate, class Iterator>
|
template <class Predicate, class Iterator>
|
||||||
inline filter_iterator<Predicate,Iterator>
|
filter_iterator<Predicate,Iterator>
|
||||||
make_filter_iterator(
|
make_filter_iterator(
|
||||||
typename iterators::enable_if<
|
typename iterators::enable_if<
|
||||||
is_class<Predicate>
|
is_class<Predicate>
|
||||||
, Iterator
|
, Iterator
|
||||||
>::type x
|
>::type x
|
||||||
, Iterator end = Iterator())
|
, Iterator end = Iterator()
|
||||||
|
#if BOOST_WORKAROUND(BOOST_MSVC, < 1300)
|
||||||
|
, Predicate* = 0
|
||||||
|
#endif
|
||||||
|
)
|
||||||
{
|
{
|
||||||
return filter_iterator<Predicate,Iterator>(BOOST_ITERATOR_DETAIL_MOVE(Iterator, x), BOOST_ITERATOR_DETAIL_MOVE(Iterator, end));
|
return filter_iterator<Predicate,Iterator>(x,end);
|
||||||
}
|
}
|
||||||
|
|
||||||
} // namespace iterators
|
|
||||||
|
|
||||||
using iterators::filter_iterator;
|
|
||||||
using iterators::make_filter_iterator;
|
|
||||||
|
|
||||||
} // namespace boost
|
} // namespace boost
|
||||||
|
|
||||||
#undef BOOST_ITERATOR_DETAIL_MOVE
|
|
||||||
|
|
||||||
#endif // BOOST_FILTER_ITERATOR_23022003THW_HPP
|
#endif // BOOST_FILTER_ITERATOR_23022003THW_HPP
|
||||||
|
@ -1,6 +1,4 @@
|
|||||||
// Copyright 2009 (C) Dean Michael Berris <me@deanberris.com>
|
// Copyright 2009 (C) Dean Michael Berris <me@deanberris.com>
|
||||||
// Copyright 2012 (C) Google, Inc.
|
|
||||||
// Copyright 2012 (C) Jeffrey Lee Hellrung, Jr.
|
|
||||||
// Distributed under the Boost Software License, Version 1.0. (See
|
// Distributed under the Boost Software License, Version 1.0. (See
|
||||||
// accompanying file LICENSE_1_0.txt or copy at
|
// accompanying file LICENSE_1_0.txt or copy at
|
||||||
// http://www.boost.org/LICENSE_1_0.txt)
|
// http://www.boost.org/LICENSE_1_0.txt)
|
||||||
@ -9,172 +7,58 @@
|
|||||||
#ifndef BOOST_FUNCTION_INPUT_ITERATOR
|
#ifndef BOOST_FUNCTION_INPUT_ITERATOR
|
||||||
#define BOOST_FUNCTION_INPUT_ITERATOR
|
#define BOOST_FUNCTION_INPUT_ITERATOR
|
||||||
|
|
||||||
#include <boost/config.hpp>
|
|
||||||
#include <boost/assert.hpp>
|
|
||||||
#include <boost/core/addressof.hpp>
|
|
||||||
#include <boost/type_traits/conditional.hpp>
|
|
||||||
#include <boost/function_types/is_function_pointer.hpp>
|
|
||||||
#include <boost/function_types/result_type.hpp>
|
|
||||||
#include <boost/iterator/iterator_facade.hpp>
|
#include <boost/iterator/iterator_facade.hpp>
|
||||||
#include <boost/none.hpp>
|
|
||||||
#include <boost/optional/optional.hpp>
|
|
||||||
#include <boost/utility/result_of.hpp>
|
|
||||||
|
|
||||||
#ifdef BOOST_RESULT_OF_USE_TR1
|
|
||||||
#include <boost/type_traits/is_function.hpp>
|
|
||||||
#endif
|
|
||||||
|
|
||||||
namespace boost {
|
namespace boost {
|
||||||
|
|
||||||
namespace iterators {
|
|
||||||
|
|
||||||
template <class Function, class Input>
|
template <class Function, class Input>
|
||||||
class function_input_iterator;
|
class function_input_iterator
|
||||||
|
: public iterator_facade<
|
||||||
namespace impl {
|
function_input_iterator<Function, Input>,
|
||||||
|
typename Function::result_type,
|
||||||
// Computes the return type of an lvalue-call with an empty argument,
|
|
||||||
// i.e. decltype(declval<F&>()()). F should be a nullary lvalue-callable
|
|
||||||
// or function.
|
|
||||||
template <class F>
|
|
||||||
struct result_of_nullary_lvalue_call
|
|
||||||
{
|
|
||||||
typedef typename result_of<
|
|
||||||
#ifdef BOOST_RESULT_OF_USE_TR1
|
|
||||||
typename boost::conditional<is_function<F>::value, F&, F>::type()
|
|
||||||
#else
|
|
||||||
F&()
|
|
||||||
#endif
|
|
||||||
>::type type;
|
|
||||||
};
|
|
||||||
|
|
||||||
template <class Function, class Input>
|
|
||||||
class function_object_input_iterator :
|
|
||||||
public iterator_facade<
|
|
||||||
iterators::function_input_iterator<Function, Input>,
|
|
||||||
typename result_of_nullary_lvalue_call<Function>::type,
|
|
||||||
single_pass_traversal_tag,
|
single_pass_traversal_tag,
|
||||||
typename result_of_nullary_lvalue_call<Function>::type const &
|
typename Function::result_type const &
|
||||||
>
|
>
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
function_object_input_iterator() {}
|
function_input_iterator() {}
|
||||||
function_object_input_iterator(Function & f_, Input state_ = Input())
|
function_input_iterator(Function * f_, Input state_ = Input())
|
||||||
: f(boost::addressof(f_)), state(state_) {}
|
: f(f_), state(state_), value((*f)()) {}
|
||||||
|
|
||||||
void increment() {
|
void increment() {
|
||||||
if (value)
|
value = (*f)();
|
||||||
value = none;
|
|
||||||
else
|
|
||||||
(*f)();
|
|
||||||
++state;
|
++state;
|
||||||
}
|
}
|
||||||
|
|
||||||
typename result_of_nullary_lvalue_call<Function>::type const &
|
typename Function::result_type const &
|
||||||
dereference() const {
|
dereference() const {
|
||||||
if (!value)
|
return value;
|
||||||
value = (*f)();
|
|
||||||
return value.get();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
bool equal(function_object_input_iterator const & other) const {
|
bool equal(function_input_iterator const & other) const {
|
||||||
return f == other.f && state == other.state;
|
return f == other.f && state == other.state;
|
||||||
}
|
}
|
||||||
|
|
||||||
private:
|
private:
|
||||||
Function * f;
|
Function * f;
|
||||||
Input state;
|
Input state;
|
||||||
mutable optional<typename result_of_nullary_lvalue_call<Function>::type> value;
|
typename Function::result_type value;
|
||||||
};
|
|
||||||
|
|
||||||
template <class Function, class Input>
|
|
||||||
class function_pointer_input_iterator :
|
|
||||||
public iterator_facade<
|
|
||||||
iterators::function_input_iterator<Function, Input>,
|
|
||||||
typename function_types::result_type<Function>::type,
|
|
||||||
single_pass_traversal_tag,
|
|
||||||
typename function_types::result_type<Function>::type const &
|
|
||||||
>
|
|
||||||
{
|
|
||||||
public:
|
|
||||||
function_pointer_input_iterator() {}
|
|
||||||
function_pointer_input_iterator(Function &f_, Input state_ = Input())
|
|
||||||
: f(f_), state(state_) {}
|
|
||||||
|
|
||||||
void increment() {
|
|
||||||
if (value)
|
|
||||||
value = none;
|
|
||||||
else
|
|
||||||
(*f)();
|
|
||||||
++state;
|
|
||||||
}
|
|
||||||
|
|
||||||
typename function_types::result_type<Function>::type const &
|
|
||||||
dereference() const {
|
|
||||||
if (!value)
|
|
||||||
value = (*f)();
|
|
||||||
return value.get();
|
|
||||||
}
|
|
||||||
|
|
||||||
bool equal(function_pointer_input_iterator const & other) const {
|
|
||||||
return f == other.f && state == other.state;
|
|
||||||
}
|
|
||||||
|
|
||||||
private:
|
|
||||||
Function f;
|
|
||||||
Input state;
|
|
||||||
mutable optional<typename function_types::result_type<Function>::type> value;
|
|
||||||
};
|
|
||||||
|
|
||||||
} // namespace impl
|
|
||||||
|
|
||||||
template <class Function, class Input>
|
|
||||||
class function_input_iterator :
|
|
||||||
public boost::conditional<
|
|
||||||
function_types::is_function_pointer<Function>::value,
|
|
||||||
impl::function_pointer_input_iterator<Function,Input>,
|
|
||||||
impl::function_object_input_iterator<Function,Input>
|
|
||||||
>::type
|
|
||||||
{
|
|
||||||
typedef typename boost::conditional<
|
|
||||||
function_types::is_function_pointer<Function>::value,
|
|
||||||
impl::function_pointer_input_iterator<Function,Input>,
|
|
||||||
impl::function_object_input_iterator<Function,Input>
|
|
||||||
>::type base_type;
|
|
||||||
public:
|
|
||||||
function_input_iterator(Function & f, Input i)
|
|
||||||
: base_type(f, i) {}
|
|
||||||
};
|
};
|
||||||
|
|
||||||
template <class Function, class Input>
|
template <class Function, class Input>
|
||||||
inline function_input_iterator<Function, Input>
|
inline function_input_iterator<Function, Input>
|
||||||
make_function_input_iterator(Function & f, Input state) {
|
make_function_input_iterator(Function & f, Input state) {
|
||||||
typedef function_input_iterator<Function, Input> result_t;
|
typedef function_input_iterator<Function, Input> result_t;
|
||||||
return result_t(f, state);
|
return result_t(&f, state);
|
||||||
}
|
}
|
||||||
|
|
||||||
template <class Function, class Input>
|
struct infinite {
|
||||||
inline function_input_iterator<Function*, Input>
|
|
||||||
make_function_input_iterator(Function * f, Input state) {
|
|
||||||
typedef function_input_iterator<Function*, Input> result_t;
|
|
||||||
return result_t(f, state);
|
|
||||||
}
|
|
||||||
|
|
||||||
struct infinite
|
|
||||||
{
|
|
||||||
infinite & operator++() { return *this; }
|
infinite & operator++() { return *this; }
|
||||||
infinite & operator++(int) { return *this; }
|
infinite & operator++(int) { return *this; }
|
||||||
bool operator==(infinite &) const { return false; };
|
bool operator==(infinite &) const { return false; };
|
||||||
bool operator==(infinite const &) const { return false; };
|
bool operator==(infinite const &) const { return false; };
|
||||||
};
|
};
|
||||||
|
}
|
||||||
} // namespace iterators
|
|
||||||
|
|
||||||
using iterators::function_input_iterator;
|
|
||||||
using iterators::make_function_input_iterator;
|
|
||||||
using iterators::infinite;
|
|
||||||
|
|
||||||
} // namespace boost
|
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
@ -1,95 +0,0 @@
|
|||||||
// (C) Copyright Jeremy Siek 2001.
|
|
||||||
// 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)
|
|
||||||
|
|
||||||
// Revision History:
|
|
||||||
|
|
||||||
// 27 Feb 2001 Jeremy Siek
|
|
||||||
// Initial checkin.
|
|
||||||
|
|
||||||
#ifndef BOOST_ITERATOR_FUNCTION_OUTPUT_ITERATOR_HPP
|
|
||||||
#define BOOST_ITERATOR_FUNCTION_OUTPUT_ITERATOR_HPP
|
|
||||||
|
|
||||||
#include <iterator>
|
|
||||||
#include <boost/config.hpp>
|
|
||||||
#include <boost/core/enable_if.hpp>
|
|
||||||
#include <boost/type_traits/is_same.hpp>
|
|
||||||
#include <boost/type_traits/remove_cv.hpp>
|
|
||||||
#ifndef BOOST_NO_CXX11_RVALUE_REFERENCES
|
|
||||||
#include <boost/type_traits/remove_reference.hpp>
|
|
||||||
#endif
|
|
||||||
|
|
||||||
namespace boost {
|
|
||||||
namespace iterators {
|
|
||||||
|
|
||||||
template <class UnaryFunction>
|
|
||||||
class function_output_iterator {
|
|
||||||
private:
|
|
||||||
typedef function_output_iterator self;
|
|
||||||
|
|
||||||
class output_proxy {
|
|
||||||
public:
|
|
||||||
explicit output_proxy(UnaryFunction& f) BOOST_NOEXCEPT : m_f(f) { }
|
|
||||||
|
|
||||||
#ifdef BOOST_NO_CXX11_RVALUE_REFERENCES
|
|
||||||
template <class T>
|
|
||||||
typename boost::disable_if_c<
|
|
||||||
boost::is_same< typename boost::remove_cv< T >::type, output_proxy >::value,
|
|
||||||
output_proxy&
|
|
||||||
>::type operator=(const T& value) {
|
|
||||||
m_f(value);
|
|
||||||
return *this;
|
|
||||||
}
|
|
||||||
#else
|
|
||||||
template <class T>
|
|
||||||
typename boost::disable_if_c<
|
|
||||||
boost::is_same< typename boost::remove_cv< typename boost::remove_reference< T >::type >::type, output_proxy >::value,
|
|
||||||
output_proxy&
|
|
||||||
>::type operator=(T&& value) {
|
|
||||||
m_f(static_cast< T&& >(value));
|
|
||||||
return *this;
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
BOOST_DEFAULTED_FUNCTION(output_proxy(output_proxy const& that), BOOST_NOEXCEPT : m_f(that.m_f) {})
|
|
||||||
BOOST_DELETED_FUNCTION(output_proxy& operator=(output_proxy const&))
|
|
||||||
|
|
||||||
private:
|
|
||||||
UnaryFunction& m_f;
|
|
||||||
};
|
|
||||||
|
|
||||||
public:
|
|
||||||
typedef std::output_iterator_tag iterator_category;
|
|
||||||
typedef void value_type;
|
|
||||||
typedef void difference_type;
|
|
||||||
typedef void pointer;
|
|
||||||
typedef void reference;
|
|
||||||
|
|
||||||
explicit function_output_iterator() {}
|
|
||||||
|
|
||||||
explicit function_output_iterator(const UnaryFunction& f)
|
|
||||||
: m_f(f) {}
|
|
||||||
|
|
||||||
output_proxy operator*() { return output_proxy(m_f); }
|
|
||||||
self& operator++() { return *this; }
|
|
||||||
self& operator++(int) { return *this; }
|
|
||||||
|
|
||||||
private:
|
|
||||||
UnaryFunction m_f;
|
|
||||||
};
|
|
||||||
|
|
||||||
template <class UnaryFunction>
|
|
||||||
inline function_output_iterator<UnaryFunction>
|
|
||||||
make_function_output_iterator(const UnaryFunction& f = UnaryFunction()) {
|
|
||||||
return function_output_iterator<UnaryFunction>(f);
|
|
||||||
}
|
|
||||||
|
|
||||||
} // namespace iterators
|
|
||||||
|
|
||||||
using iterators::function_output_iterator;
|
|
||||||
using iterators::make_function_output_iterator;
|
|
||||||
|
|
||||||
} // namespace boost
|
|
||||||
|
|
||||||
#endif // BOOST_ITERATOR_FUNCTION_OUTPUT_ITERATOR_HPP
|
|
@ -7,10 +7,12 @@
|
|||||||
#ifndef BOOST_INDIRECT_ITERATOR_23022003THW_HPP
|
#ifndef BOOST_INDIRECT_ITERATOR_23022003THW_HPP
|
||||||
#define BOOST_INDIRECT_ITERATOR_23022003THW_HPP
|
#define BOOST_INDIRECT_ITERATOR_23022003THW_HPP
|
||||||
|
|
||||||
|
#include <boost/iterator.hpp>
|
||||||
#include <boost/iterator/iterator_adaptor.hpp>
|
#include <boost/iterator/iterator_adaptor.hpp>
|
||||||
|
|
||||||
#include <boost/pointee.hpp>
|
#include <boost/pointee.hpp>
|
||||||
#include <boost/indirect_reference.hpp>
|
#include <boost/indirect_reference.hpp>
|
||||||
|
#include <boost/detail/iterator.hpp>
|
||||||
|
|
||||||
#include <boost/detail/indirect_traits.hpp>
|
#include <boost/detail/indirect_traits.hpp>
|
||||||
|
|
||||||
@ -23,8 +25,6 @@
|
|||||||
#include <boost/mpl/not.hpp>
|
#include <boost/mpl/not.hpp>
|
||||||
#include <boost/mpl/has_xxx.hpp>
|
#include <boost/mpl/has_xxx.hpp>
|
||||||
|
|
||||||
#include <iterator>
|
|
||||||
|
|
||||||
#ifdef BOOST_MPL_CFG_NO_HAS_XXX
|
#ifdef BOOST_MPL_CFG_NO_HAS_XXX
|
||||||
# include <boost/shared_ptr.hpp>
|
# include <boost/shared_ptr.hpp>
|
||||||
# include <boost/scoped_ptr.hpp>
|
# include <boost/scoped_ptr.hpp>
|
||||||
@ -34,9 +34,8 @@
|
|||||||
|
|
||||||
#include <boost/iterator/detail/config_def.hpp> // must be last #include
|
#include <boost/iterator/detail/config_def.hpp> // must be last #include
|
||||||
|
|
||||||
namespace boost {
|
namespace boost
|
||||||
namespace iterators {
|
{
|
||||||
|
|
||||||
template <class Iter, class Value, class Category, class Reference, class Difference>
|
template <class Iter, class Value, class Category, class Reference, class Difference>
|
||||||
class indirect_iterator;
|
class indirect_iterator;
|
||||||
|
|
||||||
@ -45,7 +44,7 @@ namespace iterators {
|
|||||||
template <class Iter, class Value, class Category, class Reference, class Difference>
|
template <class Iter, class Value, class Category, class Reference, class Difference>
|
||||||
struct indirect_base
|
struct indirect_base
|
||||||
{
|
{
|
||||||
typedef typename std::iterator_traits<Iter>::value_type dereferenceable;
|
typedef typename iterator_traits<Iter>::value_type dereferenceable;
|
||||||
|
|
||||||
typedef iterator_adaptor<
|
typedef iterator_adaptor<
|
||||||
indirect_iterator<Iter, Value, Category, Reference, Difference>
|
indirect_iterator<Iter, Value, Category, Reference, Difference>
|
||||||
@ -111,7 +110,7 @@ namespace iterators {
|
|||||||
private:
|
private:
|
||||||
typename super_t::reference dereference() const
|
typename super_t::reference dereference() const
|
||||||
{
|
{
|
||||||
# if BOOST_WORKAROUND(BOOST_BORLANDC, < 0x5A0 )
|
# if BOOST_WORKAROUND(__BORLANDC__, < 0x5A0 )
|
||||||
return const_cast<super_t::reference>(**this->base());
|
return const_cast<super_t::reference>(**this->base());
|
||||||
# else
|
# else
|
||||||
return **this->base();
|
return **this->base();
|
||||||
@ -133,11 +132,6 @@ namespace iterators {
|
|||||||
return indirect_iterator<Iter, Traits>(x);
|
return indirect_iterator<Iter, Traits>(x);
|
||||||
}
|
}
|
||||||
|
|
||||||
} // namespace iterators
|
|
||||||
|
|
||||||
using iterators::indirect_iterator;
|
|
||||||
using iterators::make_indirect_iterator;
|
|
||||||
|
|
||||||
} // namespace boost
|
} // namespace boost
|
||||||
|
|
||||||
#include <boost/iterator/detail/config_undef.hpp>
|
#include <boost/iterator/detail/config_undef.hpp>
|
||||||
|
@ -14,8 +14,8 @@
|
|||||||
|
|
||||||
# include <boost/iterator/detail/config_def.hpp> // must appear last
|
# include <boost/iterator/detail/config_def.hpp> // must appear last
|
||||||
|
|
||||||
namespace boost {
|
namespace boost
|
||||||
namespace iterators {
|
{
|
||||||
|
|
||||||
//
|
//
|
||||||
// Meta function that determines whether two
|
// Meta function that determines whether two
|
||||||
@ -43,10 +43,6 @@ namespace iterators {
|
|||||||
{
|
{
|
||||||
};
|
};
|
||||||
|
|
||||||
} // namespace iterators
|
|
||||||
|
|
||||||
using iterators::is_interoperable;
|
|
||||||
|
|
||||||
} // namespace boost
|
} // namespace boost
|
||||||
|
|
||||||
# include <boost/iterator/detail/config_undef.hpp>
|
# include <boost/iterator/detail/config_undef.hpp>
|
||||||
|
@ -1,148 +0,0 @@
|
|||||||
/*
|
|
||||||
* Distributed under the Boost Software License, Version 1.0.
|
|
||||||
* (See accompanying file LICENSE_1_0.txt or copy at
|
|
||||||
* https://www.boost.org/LICENSE_1_0.txt)
|
|
||||||
*
|
|
||||||
* Copyright (c) 2023 Andrey Semashev
|
|
||||||
*/
|
|
||||||
/*!
|
|
||||||
* \file iterator/is_iterator.hpp
|
|
||||||
*
|
|
||||||
* This header contains definition of the \c is_iterator type trait.
|
|
||||||
*/
|
|
||||||
|
|
||||||
#ifndef BOOST_ITERATOR_IS_ITERATOR_HPP_INCLUDED_
|
|
||||||
#define BOOST_ITERATOR_IS_ITERATOR_HPP_INCLUDED_
|
|
||||||
|
|
||||||
#include <cstddef>
|
|
||||||
#include <boost/config.hpp>
|
|
||||||
#include <boost/type_traits/integral_constant.hpp>
|
|
||||||
#include <boost/type_traits/negation.hpp>
|
|
||||||
#include <boost/type_traits/conjunction.hpp>
|
|
||||||
#include <boost/type_traits/is_complete.hpp>
|
|
||||||
#include <boost/type_traits/is_function.hpp>
|
|
||||||
#if !defined(BOOST_NO_CXX17_ITERATOR_TRAITS)
|
|
||||||
#include <iterator>
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#ifdef BOOST_HAS_PRAGMA_ONCE
|
|
||||||
#pragma once
|
|
||||||
#endif
|
|
||||||
|
|
||||||
namespace boost {
|
|
||||||
namespace iterators {
|
|
||||||
namespace detail {
|
|
||||||
|
|
||||||
// The trait attempts to detect if the T type is an iterator class. Class-type iterators are assumed
|
|
||||||
// to have the nested type iterator_category. Strictly speaking, this is not required to be the
|
|
||||||
// case (e.g. a user can specialize iterator_traits for T without defining T::iterator_category).
|
|
||||||
// Still, this is a good heuristic in practice, and we can't do anything better anyway.
|
|
||||||
// Since C++17 we can test for iterator_traits<T>::iterator_category presence instead as it is
|
|
||||||
// required to be only present for iterators.
|
|
||||||
namespace has_iterator_category_detail {
|
|
||||||
|
|
||||||
typedef char yes_type;
|
|
||||||
struct no_type { char padding[2]; };
|
|
||||||
|
|
||||||
template< typename T >
|
|
||||||
yes_type check(
|
|
||||||
#if !defined(BOOST_NO_CXX17_ITERATOR_TRAITS)
|
|
||||||
typename std::iterator_traits< T >::iterator_category*
|
|
||||||
#else
|
|
||||||
typename T::iterator_category*
|
|
||||||
#endif
|
|
||||||
);
|
|
||||||
template< typename >
|
|
||||||
no_type check(...);
|
|
||||||
|
|
||||||
} // namespace has_iterator_category_detail
|
|
||||||
|
|
||||||
template< typename T >
|
|
||||||
struct is_iterator_impl :
|
|
||||||
public boost::integral_constant<
|
|
||||||
bool,
|
|
||||||
sizeof(has_iterator_category_detail::check< T >(0)) == sizeof(has_iterator_category_detail::yes_type)
|
|
||||||
>
|
|
||||||
{
|
|
||||||
};
|
|
||||||
|
|
||||||
template< typename T >
|
|
||||||
struct is_iterator_impl< T* > :
|
|
||||||
public boost::conjunction<
|
|
||||||
boost::is_complete< T >,
|
|
||||||
boost::negation< boost::is_function< T > >
|
|
||||||
>::type
|
|
||||||
{
|
|
||||||
};
|
|
||||||
|
|
||||||
template< typename T, typename U >
|
|
||||||
struct is_iterator_impl< T U::* > :
|
|
||||||
public boost::false_type
|
|
||||||
{
|
|
||||||
};
|
|
||||||
|
|
||||||
template< typename T >
|
|
||||||
struct is_iterator_impl< T& > :
|
|
||||||
public boost::false_type
|
|
||||||
{
|
|
||||||
};
|
|
||||||
|
|
||||||
template< typename T, std::size_t N >
|
|
||||||
struct is_iterator_impl< T[N] > :
|
|
||||||
public boost::false_type
|
|
||||||
{
|
|
||||||
};
|
|
||||||
|
|
||||||
#if !defined(BOOST_TT_HAS_WORKING_IS_COMPLETE)
|
|
||||||
template< typename T >
|
|
||||||
struct is_iterator_impl< T[] > :
|
|
||||||
public boost::false_type
|
|
||||||
{
|
|
||||||
};
|
|
||||||
|
|
||||||
template< >
|
|
||||||
struct is_iterator_impl< void > :
|
|
||||||
public boost::false_type
|
|
||||||
{
|
|
||||||
};
|
|
||||||
|
|
||||||
template< >
|
|
||||||
struct is_iterator_impl< void* > :
|
|
||||||
public boost::false_type
|
|
||||||
{
|
|
||||||
};
|
|
||||||
#endif // !defined(BOOST_TT_HAS_WORKING_IS_COMPLETE)
|
|
||||||
|
|
||||||
} // namespace detail
|
|
||||||
|
|
||||||
/*!
|
|
||||||
* \brief The type trait detects whether the type \c T is an iterator type.
|
|
||||||
*
|
|
||||||
* The type trait yields \c true if its argument type \c T, after stripping top level
|
|
||||||
* cv qualifiers, is one of the following:
|
|
||||||
*
|
|
||||||
* - A pointer type, other than a pointer to function, a pointer to a class member,
|
|
||||||
* or a pointer to an incomplete type, including `void`.
|
|
||||||
* - A class type for which an iterator category is obtainable. Prior to C++17,
|
|
||||||
* the iterator category must be defined as a public `T::iterator_category` type.
|
|
||||||
* Since C++17, the expression `std::iterator_traits< T >::iterator_category` must
|
|
||||||
* be valid and produce the iterator category type.
|
|
||||||
*
|
|
||||||
* Otherwise, the type trait yields \c false.
|
|
||||||
*/
|
|
||||||
template< typename T >
|
|
||||||
struct is_iterator : public detail::is_iterator_impl< T >::type {};
|
|
||||||
template< typename T >
|
|
||||||
struct is_iterator< const T > : public detail::is_iterator_impl< T >::type {};
|
|
||||||
template< typename T >
|
|
||||||
struct is_iterator< volatile T > : public detail::is_iterator_impl< T >::type {};
|
|
||||||
template< typename T >
|
|
||||||
struct is_iterator< const volatile T > : public detail::is_iterator_impl< T >::type {};
|
|
||||||
|
|
||||||
} // namespace iterators
|
|
||||||
|
|
||||||
using iterators::is_iterator;
|
|
||||||
|
|
||||||
} // namespace boost
|
|
||||||
|
|
||||||
#endif // BOOST_ITERATOR_IS_ITERATOR_HPP_INCLUDED_
|
|
@ -4,25 +4,21 @@
|
|||||||
#ifndef IS_LVALUE_ITERATOR_DWA2003112_HPP
|
#ifndef IS_LVALUE_ITERATOR_DWA2003112_HPP
|
||||||
# define IS_LVALUE_ITERATOR_DWA2003112_HPP
|
# define IS_LVALUE_ITERATOR_DWA2003112_HPP
|
||||||
|
|
||||||
|
#include <boost/iterator.hpp>
|
||||||
|
|
||||||
#include <boost/detail/workaround.hpp>
|
#include <boost/detail/workaround.hpp>
|
||||||
|
#include <boost/detail/iterator.hpp>
|
||||||
|
|
||||||
#include <boost/type_traits/add_lvalue_reference.hpp>
|
|
||||||
#include <boost/iterator/detail/any_conversion_eater.hpp>
|
#include <boost/iterator/detail/any_conversion_eater.hpp>
|
||||||
#include <boost/mpl/bool.hpp>
|
|
||||||
#include <boost/mpl/aux_/lambda_support.hpp>
|
|
||||||
|
|
||||||
#include <iterator>
|
|
||||||
|
|
||||||
// should be the last #includes
|
// should be the last #includes
|
||||||
#include <boost/type_traits/integral_constant.hpp>
|
#include <boost/type_traits/detail/bool_trait_def.hpp>
|
||||||
#include <boost/iterator/detail/config_def.hpp>
|
#include <boost/iterator/detail/config_def.hpp>
|
||||||
|
|
||||||
#ifndef BOOST_NO_IS_CONVERTIBLE
|
#ifndef BOOST_NO_IS_CONVERTIBLE
|
||||||
|
|
||||||
namespace boost {
|
namespace boost {
|
||||||
|
|
||||||
namespace iterators {
|
|
||||||
|
|
||||||
namespace detail
|
namespace detail
|
||||||
{
|
{
|
||||||
#ifndef BOOST_NO_LVALUE_RETURN_DETECTION
|
#ifndef BOOST_NO_LVALUE_RETURN_DETECTION
|
||||||
@ -54,7 +50,7 @@ namespace detail
|
|||||||
// convertible to Value const&
|
// convertible to Value const&
|
||||||
struct conversion_eater
|
struct conversion_eater
|
||||||
{
|
{
|
||||||
conversion_eater(typename add_lvalue_reference<Value>::type);
|
conversion_eater(Value&);
|
||||||
};
|
};
|
||||||
|
|
||||||
static char tester(conversion_eater, int);
|
static char tester(conversion_eater, int);
|
||||||
@ -124,41 +120,31 @@ namespace detail
|
|||||||
template <class It>
|
template <class It>
|
||||||
struct is_readable_lvalue_iterator_impl
|
struct is_readable_lvalue_iterator_impl
|
||||||
: is_lvalue_iterator_impl<
|
: is_lvalue_iterator_impl<
|
||||||
BOOST_DEDUCED_TYPENAME std::iterator_traits<It>::value_type const
|
BOOST_DEDUCED_TYPENAME boost::detail::iterator_traits<It>::value_type const
|
||||||
>::template rebind<It>
|
>::template rebind<It>
|
||||||
{};
|
{};
|
||||||
|
|
||||||
template <class It>
|
template <class It>
|
||||||
struct is_non_const_lvalue_iterator_impl
|
struct is_non_const_lvalue_iterator_impl
|
||||||
: is_lvalue_iterator_impl<
|
: is_lvalue_iterator_impl<
|
||||||
BOOST_DEDUCED_TYPENAME std::iterator_traits<It>::value_type
|
BOOST_DEDUCED_TYPENAME boost::detail::iterator_traits<It>::value_type
|
||||||
>::template rebind<It>
|
>::template rebind<It>
|
||||||
{};
|
{};
|
||||||
} // namespace detail
|
} // namespace detail
|
||||||
|
|
||||||
template< typename T > struct is_lvalue_iterator
|
// Define the trait with full mpl lambda capability and various broken
|
||||||
: public ::boost::integral_constant<bool,::boost::iterators::detail::is_readable_lvalue_iterator_impl<T>::value>
|
// compiler workarounds
|
||||||
{
|
BOOST_TT_AUX_BOOL_TRAIT_DEF1(
|
||||||
public:
|
is_lvalue_iterator,T,::boost::detail::is_readable_lvalue_iterator_impl<T>::value)
|
||||||
BOOST_MPL_AUX_LAMBDA_SUPPORT(1,is_lvalue_iterator,(T))
|
|
||||||
};
|
|
||||||
|
|
||||||
template< typename T > struct is_non_const_lvalue_iterator
|
BOOST_TT_AUX_BOOL_TRAIT_DEF1(
|
||||||
: public ::boost::integral_constant<bool,::boost::iterators::detail::is_non_const_lvalue_iterator_impl<T>::value>
|
is_non_const_lvalue_iterator,T,::boost::detail::is_non_const_lvalue_iterator_impl<T>::value)
|
||||||
{
|
|
||||||
public:
|
|
||||||
BOOST_MPL_AUX_LAMBDA_SUPPORT(1,is_non_const_lvalue_iterator,(T))
|
|
||||||
};
|
|
||||||
|
|
||||||
} // namespace iterators
|
|
||||||
|
|
||||||
using iterators::is_lvalue_iterator;
|
|
||||||
using iterators::is_non_const_lvalue_iterator;
|
|
||||||
|
|
||||||
} // namespace boost
|
} // namespace boost
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#include <boost/iterator/detail/config_undef.hpp>
|
#include <boost/iterator/detail/config_undef.hpp>
|
||||||
|
#include <boost/type_traits/detail/bool_trait_undef.hpp>
|
||||||
|
|
||||||
#endif // IS_LVALUE_ITERATOR_DWA2003112_HPP
|
#endif // IS_LVALUE_ITERATOR_DWA2003112_HPP
|
||||||
|
@ -5,23 +5,18 @@
|
|||||||
# define IS_READABLE_ITERATOR_DWA2003112_HPP
|
# define IS_READABLE_ITERATOR_DWA2003112_HPP
|
||||||
|
|
||||||
#include <boost/mpl/bool.hpp>
|
#include <boost/mpl/bool.hpp>
|
||||||
#include <boost/mpl/aux_/lambda_support.hpp>
|
#include <boost/detail/iterator.hpp>
|
||||||
#include <boost/type_traits/add_lvalue_reference.hpp>
|
|
||||||
|
|
||||||
|
#include <boost/type_traits/detail/bool_trait_def.hpp>
|
||||||
#include <boost/iterator/detail/any_conversion_eater.hpp>
|
#include <boost/iterator/detail/any_conversion_eater.hpp>
|
||||||
|
|
||||||
#include <iterator>
|
|
||||||
|
|
||||||
// should be the last #include
|
// should be the last #include
|
||||||
#include <boost/type_traits/integral_constant.hpp>
|
|
||||||
#include <boost/iterator/detail/config_def.hpp>
|
#include <boost/iterator/detail/config_def.hpp>
|
||||||
|
|
||||||
#ifndef BOOST_NO_IS_CONVERTIBLE
|
#ifndef BOOST_NO_IS_CONVERTIBLE
|
||||||
|
|
||||||
namespace boost {
|
namespace boost {
|
||||||
|
|
||||||
namespace iterators {
|
|
||||||
|
|
||||||
namespace detail
|
namespace detail
|
||||||
{
|
{
|
||||||
// Guts of is_readable_iterator. Value is the iterator's value_type
|
// Guts of is_readable_iterator. Value is the iterator's value_type
|
||||||
@ -29,7 +24,7 @@ namespace detail
|
|||||||
template <class Value>
|
template <class Value>
|
||||||
struct is_readable_iterator_impl
|
struct is_readable_iterator_impl
|
||||||
{
|
{
|
||||||
static char tester(typename add_lvalue_reference<Value>::type, int);
|
static char tester(Value&, int);
|
||||||
static char (& tester(any_conversion_eater, ...) )[2];
|
static char (& tester(any_conversion_eater, ...) )[2];
|
||||||
|
|
||||||
template <class It>
|
template <class It>
|
||||||
@ -94,21 +89,15 @@ namespace detail
|
|||||||
template <class It>
|
template <class It>
|
||||||
struct is_readable_iterator_impl2
|
struct is_readable_iterator_impl2
|
||||||
: is_readable_iterator_impl<
|
: is_readable_iterator_impl<
|
||||||
BOOST_DEDUCED_TYPENAME std::iterator_traits<It>::value_type const
|
BOOST_DEDUCED_TYPENAME boost::detail::iterator_traits<It>::value_type const
|
||||||
>::template rebind<It>
|
>::template rebind<It>
|
||||||
{};
|
{};
|
||||||
} // namespace detail
|
} // namespace detail
|
||||||
|
|
||||||
template< typename T > struct is_readable_iterator
|
// Define the trait with full mpl lambda capability and various broken
|
||||||
: public ::boost::integral_constant<bool,::boost::iterators::detail::is_readable_iterator_impl2<T>::value>
|
// compiler workarounds
|
||||||
{
|
BOOST_TT_AUX_BOOL_TRAIT_DEF1(
|
||||||
public:
|
is_readable_iterator,T,::boost::detail::is_readable_iterator_impl2<T>::value)
|
||||||
BOOST_MPL_AUX_LAMBDA_SUPPORT(1,is_readable_iterator,(T))
|
|
||||||
};
|
|
||||||
|
|
||||||
} // namespace iterators
|
|
||||||
|
|
||||||
using iterators::is_readable_iterator;
|
|
||||||
|
|
||||||
} // namespace boost
|
} // namespace boost
|
||||||
|
|
||||||
|
@ -8,8 +8,8 @@
|
|||||||
#define BOOST_ITERATOR_ADAPTOR_23022003THW_HPP
|
#define BOOST_ITERATOR_ADAPTOR_23022003THW_HPP
|
||||||
|
|
||||||
#include <boost/static_assert.hpp>
|
#include <boost/static_assert.hpp>
|
||||||
|
#include <boost/iterator.hpp>
|
||||||
#include <boost/core/use_default.hpp>
|
#include <boost/detail/iterator.hpp>
|
||||||
|
|
||||||
#include <boost/iterator/iterator_categories.hpp>
|
#include <boost/iterator/iterator_categories.hpp>
|
||||||
#include <boost/iterator/iterator_facade.hpp>
|
#include <boost/iterator/iterator_facade.hpp>
|
||||||
@ -24,31 +24,34 @@
|
|||||||
|
|
||||||
#ifdef BOOST_ITERATOR_REF_CONSTNESS_KILLS_WRITABILITY
|
#ifdef BOOST_ITERATOR_REF_CONSTNESS_KILLS_WRITABILITY
|
||||||
# include <boost/type_traits/remove_reference.hpp>
|
# include <boost/type_traits/remove_reference.hpp>
|
||||||
|
|
||||||
|
# if BOOST_WORKAROUND(__CODEGEARC__, BOOST_TESTED_AT(0x610))
|
||||||
|
# include <boost/type_traits/add_reference.hpp>
|
||||||
# endif
|
# endif
|
||||||
|
|
||||||
|
#else
|
||||||
# include <boost/type_traits/add_reference.hpp>
|
# include <boost/type_traits/add_reference.hpp>
|
||||||
|
#endif
|
||||||
|
|
||||||
#include <boost/iterator/detail/config_def.hpp>
|
#include <boost/iterator/detail/config_def.hpp>
|
||||||
|
|
||||||
#include <boost/iterator/iterator_traits.hpp>
|
#include <boost/iterator/iterator_traits.hpp>
|
||||||
|
|
||||||
namespace boost {
|
namespace boost
|
||||||
namespace iterators {
|
{
|
||||||
|
|
||||||
// Used as a default template argument internally, merely to
|
// Used as a default template argument internally, merely to
|
||||||
// indicate "use the default", this can also be passed by users
|
// indicate "use the default", this can also be passed by users
|
||||||
// explicitly in order to specify that the default should be used.
|
// explicitly in order to specify that the default should be used.
|
||||||
using boost::use_default;
|
struct use_default;
|
||||||
|
|
||||||
} // namespace iterators
|
|
||||||
|
|
||||||
|
# ifndef BOOST_NO_TEMPLATE_PARTIAL_SPECIALIZATION
|
||||||
// the incompleteness of use_default causes massive problems for
|
// the incompleteness of use_default causes massive problems for
|
||||||
// is_convertible (naturally). This workaround is fortunately not
|
// is_convertible (naturally). This workaround is fortunately not
|
||||||
// needed for vc6/vc7.
|
// needed for vc6/vc7.
|
||||||
template<class To>
|
template<class To>
|
||||||
struct is_convertible<use_default,To>
|
struct is_convertible<use_default,To>
|
||||||
: mpl::false_ {};
|
: mpl::false_ {};
|
||||||
|
# endif
|
||||||
namespace iterators {
|
|
||||||
|
|
||||||
namespace detail
|
namespace detail
|
||||||
{
|
{
|
||||||
@ -102,15 +105,30 @@ namespace iterators {
|
|||||||
// false positives for user/library defined iterator types. See comments
|
// false positives for user/library defined iterator types. See comments
|
||||||
// on operator implementation for consequences.
|
// on operator implementation for consequences.
|
||||||
//
|
//
|
||||||
# if defined(BOOST_NO_IS_CONVERTIBLE) || defined(BOOST_NO_SFINAE)
|
# if BOOST_WORKAROUND(BOOST_MSVC, <= 1300)
|
||||||
|
|
||||||
|
template<typename From, typename To>
|
||||||
|
struct enable_if_convertible
|
||||||
|
{
|
||||||
|
typedef typename mpl::if_<
|
||||||
|
mpl::or_<
|
||||||
|
is_same<From,To>
|
||||||
|
, is_convertible<From, To>
|
||||||
|
>
|
||||||
|
, boost::detail::enable_type
|
||||||
|
, int&
|
||||||
|
>::type type;
|
||||||
|
};
|
||||||
|
|
||||||
|
# elif defined(BOOST_NO_IS_CONVERTIBLE) || defined(BOOST_NO_SFINAE)
|
||||||
|
|
||||||
template <class From, class To>
|
template <class From, class To>
|
||||||
struct enable_if_convertible
|
struct enable_if_convertible
|
||||||
{
|
{
|
||||||
typedef boost::iterators::detail::enable_type type;
|
typedef boost::detail::enable_type type;
|
||||||
};
|
};
|
||||||
|
|
||||||
# elif BOOST_WORKAROUND(_MSC_FULL_VER, BOOST_TESTED_AT(13102292))
|
# elif BOOST_WORKAROUND(_MSC_FULL_VER, BOOST_TESTED_AT(13102292)) && BOOST_MSVC > 1300
|
||||||
|
|
||||||
// For some reason vc7.1 needs us to "cut off" instantiation
|
// For some reason vc7.1 needs us to "cut off" instantiation
|
||||||
// of is_convertible in a few cases.
|
// of is_convertible in a few cases.
|
||||||
@ -121,7 +139,7 @@ namespace iterators {
|
|||||||
is_same<From,To>
|
is_same<From,To>
|
||||||
, is_convertible<From, To>
|
, is_convertible<From, To>
|
||||||
>
|
>
|
||||||
, boost::iterators::detail::enable_type
|
, boost::detail::enable_type
|
||||||
>
|
>
|
||||||
{};
|
{};
|
||||||
|
|
||||||
@ -131,7 +149,7 @@ namespace iterators {
|
|||||||
struct enable_if_convertible
|
struct enable_if_convertible
|
||||||
: iterators::enable_if<
|
: iterators::enable_if<
|
||||||
is_convertible<From, To>
|
is_convertible<From, To>
|
||||||
, boost::iterators::detail::enable_type
|
, boost::detail::enable_type
|
||||||
>
|
>
|
||||||
{};
|
{};
|
||||||
|
|
||||||
@ -170,7 +188,7 @@ namespace iterators {
|
|||||||
Derived
|
Derived
|
||||||
|
|
||||||
# ifdef BOOST_ITERATOR_REF_CONSTNESS_KILLS_WRITABILITY
|
# ifdef BOOST_ITERATOR_REF_CONSTNESS_KILLS_WRITABILITY
|
||||||
, typename boost::iterators::detail::ia_dflt_help<
|
, typename boost::detail::ia_dflt_help<
|
||||||
Value
|
Value
|
||||||
, mpl::eval_if<
|
, mpl::eval_if<
|
||||||
is_same<Reference,use_default>
|
is_same<Reference,use_default>
|
||||||
@ -179,17 +197,17 @@ namespace iterators {
|
|||||||
>
|
>
|
||||||
>::type
|
>::type
|
||||||
# else
|
# else
|
||||||
, typename boost::iterators::detail::ia_dflt_help<
|
, typename boost::detail::ia_dflt_help<
|
||||||
Value, iterator_value<Base>
|
Value, iterator_value<Base>
|
||||||
>::type
|
>::type
|
||||||
# endif
|
# endif
|
||||||
|
|
||||||
, typename boost::iterators::detail::ia_dflt_help<
|
, typename boost::detail::ia_dflt_help<
|
||||||
Traversal
|
Traversal
|
||||||
, iterator_traversal<Base>
|
, iterator_traversal<Base>
|
||||||
>::type
|
>::type
|
||||||
|
|
||||||
, typename boost::iterators::detail::ia_dflt_help<
|
, typename boost::detail::ia_dflt_help<
|
||||||
Reference
|
Reference
|
||||||
, mpl::eval_if<
|
, mpl::eval_if<
|
||||||
is_same<Value,use_default>
|
is_same<Value,use_default>
|
||||||
@ -198,7 +216,7 @@ namespace iterators {
|
|||||||
>
|
>
|
||||||
>::type
|
>::type
|
||||||
|
|
||||||
, typename boost::iterators::detail::ia_dflt_help<
|
, typename boost::detail::ia_dflt_help<
|
||||||
Difference, iterator_difference<Base>
|
Difference, iterator_difference<Base>
|
||||||
>::type
|
>::type
|
||||||
>
|
>
|
||||||
@ -247,14 +265,14 @@ namespace iterators {
|
|||||||
, class Difference = use_default
|
, class Difference = use_default
|
||||||
>
|
>
|
||||||
class iterator_adaptor
|
class iterator_adaptor
|
||||||
: public boost::iterators::detail::iterator_adaptor_base<
|
: public boost::detail::iterator_adaptor_base<
|
||||||
Derived, Base, Value, Traversal, Reference, Difference
|
Derived, Base, Value, Traversal, Reference, Difference
|
||||||
>::type
|
>::type
|
||||||
{
|
{
|
||||||
friend class iterator_core_access;
|
friend class iterator_core_access;
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
typedef typename boost::iterators::detail::iterator_adaptor_base<
|
typedef typename boost::detail::iterator_adaptor_base<
|
||||||
Derived, Base, Value, Traversal, Reference, Difference
|
Derived, Base, Value, Traversal, Reference, Difference
|
||||||
>::type super_t;
|
>::type super_t;
|
||||||
public:
|
public:
|
||||||
@ -310,7 +328,7 @@ namespace iterators {
|
|||||||
>::type my_traversal;
|
>::type my_traversal;
|
||||||
|
|
||||||
# define BOOST_ITERATOR_ADAPTOR_ASSERT_TRAVERSAL(cat) \
|
# define BOOST_ITERATOR_ADAPTOR_ASSERT_TRAVERSAL(cat) \
|
||||||
boost::iterators::detail::iterator_adaptor_assert_traversal<my_traversal, cat>();
|
boost::detail::iterator_adaptor_assert_traversal<my_traversal, cat>();
|
||||||
|
|
||||||
void advance(typename super_t::difference_type n)
|
void advance(typename super_t::difference_type n)
|
||||||
{
|
{
|
||||||
@ -346,11 +364,6 @@ namespace iterators {
|
|||||||
Base m_iterator;
|
Base m_iterator;
|
||||||
};
|
};
|
||||||
|
|
||||||
} // namespace iterators
|
|
||||||
|
|
||||||
using iterators::iterator_adaptor;
|
|
||||||
using iterators::enable_if_convertible;
|
|
||||||
|
|
||||||
} // namespace boost
|
} // namespace boost
|
||||||
|
|
||||||
#include <boost/iterator/detail/config_undef.hpp>
|
#include <boost/iterator/detail/config_undef.hpp>
|
||||||
|
@ -9,6 +9,7 @@
|
|||||||
#include <boost/iterator/iterator_categories.hpp>
|
#include <boost/iterator/iterator_categories.hpp>
|
||||||
#include <boost/operators.hpp>
|
#include <boost/operators.hpp>
|
||||||
#include <boost/static_assert.hpp>
|
#include <boost/static_assert.hpp>
|
||||||
|
#include <boost/iterator.hpp>
|
||||||
|
|
||||||
#include <boost/iterator/detail/facade_iterator_category.hpp>
|
#include <boost/iterator/detail/facade_iterator_category.hpp>
|
||||||
|
|
||||||
@ -19,6 +20,7 @@
|
|||||||
|
|
||||||
#include <boost/concept_archetype.hpp>
|
#include <boost/concept_archetype.hpp>
|
||||||
|
|
||||||
|
#include <boost/mpl/aux_/msvc_eti_base.hpp>
|
||||||
#include <boost/mpl/bitand.hpp>
|
#include <boost/mpl/bitand.hpp>
|
||||||
#include <boost/mpl/int.hpp>
|
#include <boost/mpl/int.hpp>
|
||||||
#include <boost/mpl/equal_to.hpp>
|
#include <boost/mpl/equal_to.hpp>
|
||||||
@ -30,7 +32,6 @@
|
|||||||
#include <cstddef>
|
#include <cstddef>
|
||||||
|
|
||||||
namespace boost {
|
namespace boost {
|
||||||
namespace iterators {
|
|
||||||
|
|
||||||
template <class Value, class AccessCategory>
|
template <class Value, class AccessCategory>
|
||||||
struct access_archetype;
|
struct access_archetype;
|
||||||
@ -38,7 +39,7 @@ struct access_archetype;
|
|||||||
template <class Derived, class Value, class AccessCategory, class TraversalCategory>
|
template <class Derived, class Value, class AccessCategory, class TraversalCategory>
|
||||||
struct traversal_archetype;
|
struct traversal_archetype;
|
||||||
|
|
||||||
namespace archetypes
|
namespace iterator_archetypes
|
||||||
{
|
{
|
||||||
enum {
|
enum {
|
||||||
readable_iterator_bit = 1
|
readable_iterator_bit = 1
|
||||||
@ -118,18 +119,19 @@ namespace detail
|
|||||||
|
|
||||||
template <class Value, class AccessCategory, class TraversalCategory>
|
template <class Value, class AccessCategory, class TraversalCategory>
|
||||||
struct operator_brackets
|
struct operator_brackets
|
||||||
: mpl::eval_if<
|
: mpl::aux::msvc_eti_base<
|
||||||
|
typename mpl::eval_if<
|
||||||
is_convertible<TraversalCategory, random_access_traversal_tag>
|
is_convertible<TraversalCategory, random_access_traversal_tag>
|
||||||
, mpl::eval_if<
|
, mpl::eval_if<
|
||||||
archetypes::has_access<
|
iterator_archetypes::has_access<
|
||||||
AccessCategory
|
AccessCategory
|
||||||
, archetypes::writable_iterator_t
|
, iterator_archetypes::writable_iterator_t
|
||||||
>
|
>
|
||||||
, mpl::identity<writable_operator_brackets<Value> >
|
, mpl::identity<writable_operator_brackets<Value> >
|
||||||
, mpl::if_<
|
, mpl::if_<
|
||||||
archetypes::has_access<
|
iterator_archetypes::has_access<
|
||||||
AccessCategory
|
AccessCategory
|
||||||
, archetypes::readable_iterator_t
|
, iterator_archetypes::readable_iterator_t
|
||||||
>
|
>
|
||||||
, readable_operator_brackets<Value>
|
, readable_operator_brackets<Value>
|
||||||
, no_operator_brackets
|
, no_operator_brackets
|
||||||
@ -137,6 +139,7 @@ namespace detail
|
|||||||
>
|
>
|
||||||
, mpl::identity<no_operator_brackets>
|
, mpl::identity<no_operator_brackets>
|
||||||
>::type
|
>::type
|
||||||
|
>::type
|
||||||
{};
|
{};
|
||||||
|
|
||||||
template <class TraversalCategory>
|
template <class TraversalCategory>
|
||||||
@ -151,7 +154,9 @@ namespace detail
|
|||||||
|
|
||||||
template <class Derived, class Value, class TraversalCategory>
|
template <class Derived, class Value, class TraversalCategory>
|
||||||
struct traversal_archetype_
|
struct traversal_archetype_
|
||||||
: traversal_archetype_impl<TraversalCategory>::template archetype<Derived,Value>
|
: mpl::aux::msvc_eti_base<
|
||||||
|
typename traversal_archetype_impl<TraversalCategory>::template archetype<Derived,Value>
|
||||||
|
>::type
|
||||||
{
|
{
|
||||||
typedef typename
|
typedef typename
|
||||||
traversal_archetype_impl<TraversalCategory>::template archetype<Derived,Value>
|
traversal_archetype_impl<TraversalCategory>::template archetype<Derived,Value>
|
||||||
@ -200,6 +205,12 @@ namespace detail
|
|||||||
bool operator==(traversal_archetype_<Derived, Value, single_pass_traversal_tag> const&,
|
bool operator==(traversal_archetype_<Derived, Value, single_pass_traversal_tag> const&,
|
||||||
traversal_archetype_<Derived, Value, single_pass_traversal_tag> const&) { return true; }
|
traversal_archetype_<Derived, Value, single_pass_traversal_tag> const&) { return true; }
|
||||||
|
|
||||||
|
#if BOOST_WORKAROUND(BOOST_MSVC, <= 1300)
|
||||||
|
// doesn't seem to pick up != from equality_comparable
|
||||||
|
template <class Derived, class Value>
|
||||||
|
bool operator!=(traversal_archetype_<Derived, Value, single_pass_traversal_tag> const&,
|
||||||
|
traversal_archetype_<Derived, Value, single_pass_traversal_tag> const&) { return true; }
|
||||||
|
#endif
|
||||||
template <>
|
template <>
|
||||||
struct traversal_archetype_impl<forward_traversal_tag>
|
struct traversal_archetype_impl<forward_traversal_tag>
|
||||||
{
|
{
|
||||||
@ -298,15 +309,17 @@ struct iterator_access_archetype_impl
|
|||||||
|
|
||||||
template <class Value, class AccessCategory>
|
template <class Value, class AccessCategory>
|
||||||
struct iterator_access_archetype
|
struct iterator_access_archetype
|
||||||
: iterator_access_archetype_impl<
|
: mpl::aux::msvc_eti_base<
|
||||||
|
typename iterator_access_archetype_impl<
|
||||||
AccessCategory
|
AccessCategory
|
||||||
>::template archetype<Value>
|
>::template archetype<Value>
|
||||||
|
>::type
|
||||||
{
|
{
|
||||||
};
|
};
|
||||||
|
|
||||||
template <>
|
template <>
|
||||||
struct iterator_access_archetype_impl<
|
struct iterator_access_archetype_impl<
|
||||||
archetypes::readable_iterator_t
|
iterator_archetypes::readable_iterator_t
|
||||||
>
|
>
|
||||||
{
|
{
|
||||||
template <class Value>
|
template <class Value>
|
||||||
@ -324,13 +337,15 @@ struct iterator_access_archetype_impl<
|
|||||||
|
|
||||||
template <>
|
template <>
|
||||||
struct iterator_access_archetype_impl<
|
struct iterator_access_archetype_impl<
|
||||||
archetypes::writable_iterator_t
|
iterator_archetypes::writable_iterator_t
|
||||||
>
|
>
|
||||||
{
|
{
|
||||||
template <class Value>
|
template <class Value>
|
||||||
struct archetype
|
struct archetype
|
||||||
{
|
{
|
||||||
|
# if !BOOST_WORKAROUND(BOOST_MSVC, <= 1300)
|
||||||
BOOST_STATIC_ASSERT(!is_const<Value>::value);
|
BOOST_STATIC_ASSERT(!is_const<Value>::value);
|
||||||
|
# endif
|
||||||
typedef void value_type;
|
typedef void value_type;
|
||||||
typedef void reference;
|
typedef void reference;
|
||||||
typedef void pointer;
|
typedef void pointer;
|
||||||
@ -341,13 +356,13 @@ struct iterator_access_archetype_impl<
|
|||||||
|
|
||||||
template <>
|
template <>
|
||||||
struct iterator_access_archetype_impl<
|
struct iterator_access_archetype_impl<
|
||||||
archetypes::readable_writable_iterator_t
|
iterator_archetypes::readable_writable_iterator_t
|
||||||
>
|
>
|
||||||
{
|
{
|
||||||
template <class Value>
|
template <class Value>
|
||||||
struct archetype
|
struct archetype
|
||||||
: public virtual iterator_access_archetype<
|
: public virtual iterator_access_archetype<
|
||||||
Value, archetypes::readable_iterator_t
|
Value, iterator_archetypes::readable_iterator_t
|
||||||
>
|
>
|
||||||
{
|
{
|
||||||
typedef detail::read_write_proxy<Value> reference;
|
typedef detail::read_write_proxy<Value> reference;
|
||||||
@ -357,12 +372,12 @@ struct iterator_access_archetype_impl<
|
|||||||
};
|
};
|
||||||
|
|
||||||
template <>
|
template <>
|
||||||
struct iterator_access_archetype_impl<archetypes::readable_lvalue_iterator_t>
|
struct iterator_access_archetype_impl<iterator_archetypes::readable_lvalue_iterator_t>
|
||||||
{
|
{
|
||||||
template <class Value>
|
template <class Value>
|
||||||
struct archetype
|
struct archetype
|
||||||
: public virtual iterator_access_archetype<
|
: public virtual iterator_access_archetype<
|
||||||
Value, archetypes::readable_iterator_t
|
Value, iterator_archetypes::readable_iterator_t
|
||||||
>
|
>
|
||||||
{
|
{
|
||||||
typedef Value& reference;
|
typedef Value& reference;
|
||||||
@ -373,15 +388,17 @@ struct iterator_access_archetype_impl<archetypes::readable_lvalue_iterator_t>
|
|||||||
};
|
};
|
||||||
|
|
||||||
template <>
|
template <>
|
||||||
struct iterator_access_archetype_impl<archetypes::writable_lvalue_iterator_t>
|
struct iterator_access_archetype_impl<iterator_archetypes::writable_lvalue_iterator_t>
|
||||||
{
|
{
|
||||||
template <class Value>
|
template <class Value>
|
||||||
struct archetype
|
struct archetype
|
||||||
: public virtual iterator_access_archetype<
|
: public virtual iterator_access_archetype<
|
||||||
Value, archetypes::readable_lvalue_iterator_t
|
Value, iterator_archetypes::readable_lvalue_iterator_t
|
||||||
>
|
>
|
||||||
{
|
{
|
||||||
|
# if !BOOST_WORKAROUND(BOOST_MSVC, <= 1300)
|
||||||
BOOST_STATIC_ASSERT((!is_const<Value>::value));
|
BOOST_STATIC_ASSERT((!is_const<Value>::value));
|
||||||
|
# endif
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -416,8 +433,8 @@ namespace detail
|
|||||||
typedef typename detail::facade_iterator_category<
|
typedef typename detail::facade_iterator_category<
|
||||||
TraversalCategory
|
TraversalCategory
|
||||||
, typename mpl::eval_if<
|
, typename mpl::eval_if<
|
||||||
archetypes::has_access<
|
iterator_archetypes::has_access<
|
||||||
AccessCategory, archetypes::writable_iterator_t
|
AccessCategory, iterator_archetypes::writable_iterator_t
|
||||||
>
|
>
|
||||||
, remove_const<Value>
|
, remove_const<Value>
|
||||||
, add_const<Value>
|
, add_const<Value>
|
||||||
@ -426,16 +443,15 @@ namespace detail
|
|||||||
>::type iterator_category;
|
>::type iterator_category;
|
||||||
|
|
||||||
// Needed for some broken libraries (see below)
|
// Needed for some broken libraries (see below)
|
||||||
struct workaround_iterator_base
|
typedef boost::iterator<
|
||||||
{
|
iterator_category
|
||||||
typedef typename iterator_archetype_base::iterator_category iterator_category;
|
, Value
|
||||||
typedef Value value_type;
|
, typename traversal_archetype_base<
|
||||||
typedef typename traversal_archetype_base<
|
|
||||||
Value, AccessCategory, TraversalCategory
|
Value, AccessCategory, TraversalCategory
|
||||||
>::difference_type difference_type;
|
>::difference_type
|
||||||
typedef typename access::pointer pointer;
|
, typename access::pointer
|
||||||
typedef typename access::reference reference;
|
, typename access::reference
|
||||||
};
|
> workaround_iterator_base;
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -493,17 +509,7 @@ struct iterator_archetype
|
|||||||
# endif
|
# endif
|
||||||
};
|
};
|
||||||
|
|
||||||
} // namespace iterators
|
|
||||||
|
|
||||||
// Backward compatibility names
|
|
||||||
namespace iterator_archetypes = iterators::archetypes;
|
|
||||||
using iterators::access_archetype;
|
|
||||||
using iterators::traversal_archetype;
|
|
||||||
using iterators::iterator_archetype;
|
|
||||||
using iterators::undefined;
|
|
||||||
using iterators::iterator_access_archetype_impl;
|
|
||||||
using iterators::traversal_archetype_base;
|
|
||||||
|
|
||||||
} // namespace boost
|
} // namespace boost
|
||||||
|
|
||||||
|
|
||||||
#endif // BOOST_ITERATOR_ARCHETYPES_HPP
|
#endif // BOOST_ITERATOR_ARCHETYPES_HPP
|
||||||
|
@ -7,6 +7,7 @@
|
|||||||
# define BOOST_ITERATOR_CATEGORIES_HPP
|
# define BOOST_ITERATOR_CATEGORIES_HPP
|
||||||
|
|
||||||
# include <boost/config.hpp>
|
# include <boost/config.hpp>
|
||||||
|
# include <boost/detail/iterator.hpp>
|
||||||
# include <boost/iterator/detail/config_def.hpp>
|
# include <boost/iterator/detail/config_def.hpp>
|
||||||
|
|
||||||
# include <boost/detail/workaround.hpp>
|
# include <boost/detail/workaround.hpp>
|
||||||
@ -20,10 +21,7 @@
|
|||||||
|
|
||||||
# include <boost/static_assert.hpp>
|
# include <boost/static_assert.hpp>
|
||||||
|
|
||||||
#include <iterator>
|
|
||||||
|
|
||||||
namespace boost {
|
namespace boost {
|
||||||
namespace iterators {
|
|
||||||
|
|
||||||
//
|
//
|
||||||
// Traversal Categories
|
// Traversal Categories
|
||||||
@ -99,50 +97,14 @@ namespace detail
|
|||||||
>
|
>
|
||||||
{};
|
{};
|
||||||
|
|
||||||
} // namespace detail
|
# if BOOST_WORKAROUND(BOOST_MSVC, < 1300)
|
||||||
|
|
||||||
//
|
|
||||||
// Convert an iterator category into a traversal tag
|
|
||||||
//
|
|
||||||
template <class Cat>
|
|
||||||
struct iterator_category_to_traversal
|
|
||||||
: mpl::eval_if< // if already convertible to a traversal tag, we're done.
|
|
||||||
is_convertible<Cat,incrementable_traversal_tag>
|
|
||||||
, mpl::identity<Cat>
|
|
||||||
, boost::iterators::detail::old_category_to_traversal<Cat>
|
|
||||||
>
|
|
||||||
{};
|
|
||||||
|
|
||||||
// Trait to get an iterator's traversal category
|
|
||||||
template <class Iterator = mpl::_1>
|
|
||||||
struct iterator_traversal
|
|
||||||
: iterator_category_to_traversal<
|
|
||||||
typename std::iterator_traits<Iterator>::iterator_category
|
|
||||||
>
|
|
||||||
{};
|
|
||||||
|
|
||||||
# ifdef BOOST_MPL_CFG_NO_FULL_LAMBDA_SUPPORT
|
|
||||||
// Hack because BOOST_MPL_AUX_LAMBDA_SUPPORT doesn't seem to work
|
|
||||||
// out well. Instantiating the nested apply template also
|
|
||||||
// requires instantiating iterator_traits on the
|
|
||||||
// placeholder. Instead we just specialize it as a metafunction
|
|
||||||
// class.
|
|
||||||
template <>
|
template <>
|
||||||
struct iterator_traversal<mpl::_1>
|
struct old_category_to_traversal<int>
|
||||||
{
|
{
|
||||||
template <class T>
|
typedef int type;
|
||||||
struct apply : iterator_traversal<T>
|
|
||||||
{};
|
|
||||||
};
|
};
|
||||||
template <>
|
|
||||||
struct iterator_traversal<mpl::_>
|
|
||||||
: iterator_traversal<mpl::_1>
|
|
||||||
{};
|
|
||||||
# endif
|
# endif
|
||||||
|
|
||||||
//
|
|
||||||
// Convert an iterator traversal to one of the traversal tags.
|
|
||||||
//
|
|
||||||
template <class Traversal>
|
template <class Traversal>
|
||||||
struct pure_traversal_tag
|
struct pure_traversal_tag
|
||||||
: mpl::eval_if<
|
: mpl::eval_if<
|
||||||
@ -169,46 +131,56 @@ struct pure_traversal_tag
|
|||||||
{
|
{
|
||||||
};
|
};
|
||||||
|
|
||||||
|
# if BOOST_WORKAROUND(BOOST_MSVC, < 1300)
|
||||||
|
template <>
|
||||||
|
struct pure_traversal_tag<int>
|
||||||
|
{
|
||||||
|
typedef int type;
|
||||||
|
};
|
||||||
|
# endif
|
||||||
|
|
||||||
|
} // namespace detail
|
||||||
|
|
||||||
|
|
||||||
//
|
//
|
||||||
// Trait to retrieve one of the iterator traversal tags from the iterator category or traversal.
|
// Convert an iterator category into a traversal tag
|
||||||
//
|
//
|
||||||
|
template <class Cat>
|
||||||
|
struct iterator_category_to_traversal
|
||||||
|
: mpl::eval_if< // if already convertible to a traversal tag, we're done.
|
||||||
|
is_convertible<Cat,incrementable_traversal_tag>
|
||||||
|
, mpl::identity<Cat>
|
||||||
|
, boost::detail::old_category_to_traversal<Cat>
|
||||||
|
>
|
||||||
|
{};
|
||||||
|
|
||||||
|
// Trait to get an iterator's traversal category
|
||||||
template <class Iterator = mpl::_1>
|
template <class Iterator = mpl::_1>
|
||||||
struct pure_iterator_traversal
|
struct iterator_traversal
|
||||||
: pure_traversal_tag<typename iterator_traversal<Iterator>::type>
|
: iterator_category_to_traversal<
|
||||||
|
typename boost::detail::iterator_traits<Iterator>::iterator_category
|
||||||
|
>
|
||||||
{};
|
{};
|
||||||
|
|
||||||
# ifdef BOOST_MPL_CFG_NO_FULL_LAMBDA_SUPPORT
|
# ifdef BOOST_MPL_CFG_NO_FULL_LAMBDA_SUPPORT
|
||||||
|
// Hack because BOOST_MPL_AUX_LAMBDA_SUPPORT doesn't seem to work
|
||||||
|
// out well. Instantiating the nested apply template also
|
||||||
|
// requires instantiating iterator_traits on the
|
||||||
|
// placeholder. Instead we just specialize it as a metafunction
|
||||||
|
// class.
|
||||||
template <>
|
template <>
|
||||||
struct pure_iterator_traversal<mpl::_1>
|
struct iterator_traversal<mpl::_1>
|
||||||
{
|
{
|
||||||
template <class T>
|
template <class T>
|
||||||
struct apply : pure_iterator_traversal<T>
|
struct apply : iterator_traversal<T>
|
||||||
{};
|
{};
|
||||||
};
|
};
|
||||||
template <>
|
template <>
|
||||||
struct pure_iterator_traversal<mpl::_>
|
struct iterator_traversal<mpl::_>
|
||||||
: pure_iterator_traversal<mpl::_1>
|
: iterator_traversal<mpl::_1>
|
||||||
{};
|
{};
|
||||||
# endif
|
# endif
|
||||||
|
|
||||||
} // namespace iterators
|
|
||||||
|
|
||||||
using iterators::no_traversal_tag;
|
|
||||||
using iterators::incrementable_traversal_tag;
|
|
||||||
using iterators::single_pass_traversal_tag;
|
|
||||||
using iterators::forward_traversal_tag;
|
|
||||||
using iterators::bidirectional_traversal_tag;
|
|
||||||
using iterators::random_access_traversal_tag;
|
|
||||||
using iterators::iterator_category_to_traversal;
|
|
||||||
using iterators::iterator_traversal;
|
|
||||||
|
|
||||||
// This import is needed for backward compatibility with Boost.Range:
|
|
||||||
// boost/range/detail/demote_iterator_traversal_tag.hpp
|
|
||||||
// It should be removed when that header is fixed.
|
|
||||||
namespace detail {
|
|
||||||
using iterators::pure_traversal_tag;
|
|
||||||
} // namespace detail
|
|
||||||
|
|
||||||
} // namespace boost
|
} // namespace boost
|
||||||
|
|
||||||
#include <boost/iterator/detail/config_undef.hpp>
|
#include <boost/iterator/detail/config_undef.hpp>
|
||||||
|
@ -9,6 +9,9 @@
|
|||||||
#include <boost/concept_check.hpp>
|
#include <boost/concept_check.hpp>
|
||||||
#include <boost/iterator/iterator_categories.hpp>
|
#include <boost/iterator/iterator_categories.hpp>
|
||||||
|
|
||||||
|
// Use boost::detail::iterator_traits to work around some MSVC/Dinkumware problems.
|
||||||
|
#include <boost/detail/iterator.hpp>
|
||||||
|
|
||||||
#include <boost/type_traits/is_same.hpp>
|
#include <boost/type_traits/is_same.hpp>
|
||||||
#include <boost/type_traits/is_integral.hpp>
|
#include <boost/type_traits/is_integral.hpp>
|
||||||
|
|
||||||
@ -24,7 +27,6 @@
|
|||||||
#include <boost/config.hpp>
|
#include <boost/config.hpp>
|
||||||
|
|
||||||
#include <algorithm>
|
#include <algorithm>
|
||||||
#include <iterator>
|
|
||||||
|
|
||||||
#include <boost/concept/detail/concept_def.hpp>
|
#include <boost/concept/detail/concept_def.hpp>
|
||||||
|
|
||||||
@ -42,8 +44,8 @@ namespace boost_concepts
|
|||||||
, boost::CopyConstructible<Iterator>
|
, boost::CopyConstructible<Iterator>
|
||||||
|
|
||||||
{
|
{
|
||||||
typedef BOOST_DEDUCED_TYPENAME std::iterator_traits<Iterator>::value_type value_type;
|
typedef BOOST_DEDUCED_TYPENAME boost::detail::iterator_traits<Iterator>::value_type value_type;
|
||||||
typedef BOOST_DEDUCED_TYPENAME std::iterator_traits<Iterator>::reference reference;
|
typedef BOOST_DEDUCED_TYPENAME boost::detail::iterator_traits<Iterator>::reference reference;
|
||||||
|
|
||||||
BOOST_CONCEPT_USAGE(ReadableIterator)
|
BOOST_CONCEPT_USAGE(ReadableIterator)
|
||||||
{
|
{
|
||||||
@ -57,7 +59,7 @@ namespace boost_concepts
|
|||||||
|
|
||||||
template <
|
template <
|
||||||
typename Iterator
|
typename Iterator
|
||||||
, typename ValueType = BOOST_DEDUCED_TYPENAME std::iterator_traits<Iterator>::value_type
|
, typename ValueType = BOOST_DEDUCED_TYPENAME boost::detail::iterator_traits<Iterator>::value_type
|
||||||
>
|
>
|
||||||
struct WritableIterator
|
struct WritableIterator
|
||||||
: boost::CopyConstructible<Iterator>
|
: boost::CopyConstructible<Iterator>
|
||||||
@ -73,7 +75,7 @@ namespace boost_concepts
|
|||||||
|
|
||||||
template <
|
template <
|
||||||
typename Iterator
|
typename Iterator
|
||||||
, typename ValueType = BOOST_DEDUCED_TYPENAME std::iterator_traits<Iterator>::value_type
|
, typename ValueType = BOOST_DEDUCED_TYPENAME boost::detail::iterator_traits<Iterator>::value_type
|
||||||
>
|
>
|
||||||
struct WritableIteratorConcept : WritableIterator<Iterator,ValueType> {};
|
struct WritableIteratorConcept : WritableIterator<Iterator,ValueType> {};
|
||||||
|
|
||||||
@ -90,7 +92,7 @@ namespace boost_concepts
|
|||||||
|
|
||||||
BOOST_concept(LvalueIterator,(Iterator))
|
BOOST_concept(LvalueIterator,(Iterator))
|
||||||
{
|
{
|
||||||
typedef typename std::iterator_traits<Iterator>::value_type value_type;
|
typedef typename boost::detail::iterator_traits<Iterator>::value_type value_type;
|
||||||
|
|
||||||
BOOST_CONCEPT_USAGE(LvalueIterator)
|
BOOST_CONCEPT_USAGE(LvalueIterator)
|
||||||
{
|
{
|
||||||
@ -142,10 +144,10 @@ namespace boost_concepts
|
|||||||
: SinglePassIterator<Iterator>
|
: SinglePassIterator<Iterator>
|
||||||
, boost::DefaultConstructible<Iterator>
|
, boost::DefaultConstructible<Iterator>
|
||||||
{
|
{
|
||||||
typedef typename std::iterator_traits<Iterator>::difference_type difference_type;
|
typedef typename boost::detail::iterator_traits<Iterator>::difference_type difference_type;
|
||||||
|
|
||||||
BOOST_STATIC_ASSERT(boost::is_integral<difference_type>::value);
|
BOOST_MPL_ASSERT((boost::is_integral<difference_type>));
|
||||||
BOOST_STATIC_ASSERT(std::numeric_limits<difference_type>::is_signed);
|
BOOST_MPL_ASSERT_RELATION(std::numeric_limits<difference_type>::is_signed, ==, true);
|
||||||
|
|
||||||
BOOST_CONCEPT_ASSERT((
|
BOOST_CONCEPT_ASSERT((
|
||||||
boost::Convertible<
|
boost::Convertible<
|
||||||
@ -219,7 +221,7 @@ namespace boost_concepts
|
|||||||
boost::random_access_traversal_tag, boost::random_access_traversal_tag)
|
boost::random_access_traversal_tag, boost::random_access_traversal_tag)
|
||||||
{
|
{
|
||||||
bool b;
|
bool b;
|
||||||
typename std::iterator_traits<Iterator2>::difference_type n;
|
typename boost::detail::iterator_traits<Iterator2>::difference_type n;
|
||||||
b = i1 < i2;
|
b = i1 < i2;
|
||||||
b = i1 <= i2;
|
b = i1 <= i2;
|
||||||
b = i1 > i2;
|
b = i1 > i2;
|
||||||
@ -246,8 +248,17 @@ namespace boost_concepts
|
|||||||
BOOST_concept(InteroperableIterator,(Iterator)(ConstIterator))
|
BOOST_concept(InteroperableIterator,(Iterator)(ConstIterator))
|
||||||
{
|
{
|
||||||
private:
|
private:
|
||||||
typedef typename boost::iterators::pure_iterator_traversal<Iterator>::type traversal_category;
|
typedef typename boost::detail::pure_traversal_tag<
|
||||||
typedef typename boost::iterators::pure_iterator_traversal<ConstIterator>::type const_traversal_category;
|
typename boost::iterator_traversal<
|
||||||
|
Iterator
|
||||||
|
>::type
|
||||||
|
>::type traversal_category;
|
||||||
|
|
||||||
|
typedef typename boost::detail::pure_traversal_tag<
|
||||||
|
typename boost::iterator_traversal<
|
||||||
|
ConstIterator
|
||||||
|
>::type
|
||||||
|
>::type const_traversal_category;
|
||||||
|
|
||||||
public:
|
public:
|
||||||
BOOST_CONCEPT_ASSERT((SinglePassIterator<Iterator>));
|
BOOST_CONCEPT_ASSERT((SinglePassIterator<Iterator>));
|
||||||
|
@ -7,21 +7,19 @@
|
|||||||
#ifndef BOOST_ITERATOR_FACADE_23022003THW_HPP
|
#ifndef BOOST_ITERATOR_FACADE_23022003THW_HPP
|
||||||
#define BOOST_ITERATOR_FACADE_23022003THW_HPP
|
#define BOOST_ITERATOR_FACADE_23022003THW_HPP
|
||||||
|
|
||||||
#include <boost/config.hpp>
|
#include <boost/iterator.hpp>
|
||||||
#include <boost/iterator/interoperable.hpp>
|
#include <boost/iterator/interoperable.hpp>
|
||||||
#include <boost/iterator/iterator_traits.hpp>
|
#include <boost/iterator/iterator_traits.hpp>
|
||||||
#include <boost/iterator/iterator_categories.hpp>
|
|
||||||
|
|
||||||
#include <boost/iterator/detail/facade_iterator_category.hpp>
|
#include <boost/iterator/detail/facade_iterator_category.hpp>
|
||||||
#include <boost/iterator/detail/enable_if.hpp>
|
#include <boost/iterator/detail/enable_if.hpp>
|
||||||
|
|
||||||
|
#include <boost/implicit_cast.hpp>
|
||||||
#include <boost/static_assert.hpp>
|
#include <boost/static_assert.hpp>
|
||||||
#include <boost/core/addressof.hpp>
|
|
||||||
|
|
||||||
#include <boost/type_traits/is_same.hpp>
|
#include <boost/type_traits/is_same.hpp>
|
||||||
#include <boost/type_traits/add_const.hpp>
|
#include <boost/type_traits/add_const.hpp>
|
||||||
#include <boost/type_traits/add_pointer.hpp>
|
#include <boost/type_traits/add_pointer.hpp>
|
||||||
#include <boost/type_traits/add_lvalue_reference.hpp>
|
|
||||||
#include <boost/type_traits/remove_const.hpp>
|
#include <boost/type_traits/remove_const.hpp>
|
||||||
#include <boost/type_traits/remove_reference.hpp>
|
#include <boost/type_traits/remove_reference.hpp>
|
||||||
#include <boost/type_traits/is_convertible.hpp>
|
#include <boost/type_traits/is_convertible.hpp>
|
||||||
@ -36,13 +34,10 @@
|
|||||||
#include <boost/mpl/apply.hpp>
|
#include <boost/mpl/apply.hpp>
|
||||||
#include <boost/mpl/identity.hpp>
|
#include <boost/mpl/identity.hpp>
|
||||||
|
|
||||||
#include <cstddef>
|
|
||||||
|
|
||||||
#include <boost/iterator/detail/config_def.hpp> // this goes last
|
#include <boost/iterator/detail/config_def.hpp> // this goes last
|
||||||
|
|
||||||
namespace boost {
|
namespace boost
|
||||||
namespace iterators {
|
{
|
||||||
|
|
||||||
// This forward declaration is required for the friend declaration
|
// This forward declaration is required for the friend declaration
|
||||||
// in iterator_core_access
|
// in iterator_core_access
|
||||||
template <class I, class V, class TC, class R, class D> class iterator_facade;
|
template <class I, class V, class TC, class R, class D> class iterator_facade;
|
||||||
@ -61,12 +56,6 @@ namespace iterators {
|
|||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
|
||||||
// The type trait checks if the category or traversal is at least as advanced as the specified required traversal
|
|
||||||
template< typename CategoryOrTraversal, typename Required >
|
|
||||||
struct is_traversal_at_least :
|
|
||||||
public boost::is_convertible< typename iterator_category_to_traversal< CategoryOrTraversal >::type, Required >
|
|
||||||
{};
|
|
||||||
|
|
||||||
//
|
//
|
||||||
// enable if for use in operator implementation.
|
// enable if for use in operator implementation.
|
||||||
//
|
//
|
||||||
@ -75,31 +64,28 @@ namespace iterators {
|
|||||||
, class Facade2
|
, class Facade2
|
||||||
, class Return
|
, class Return
|
||||||
>
|
>
|
||||||
struct enable_if_interoperable :
|
struct enable_if_interoperable
|
||||||
public boost::iterators::enable_if<
|
#if BOOST_WORKAROUND(BOOST_MSVC, <= 1300)
|
||||||
is_interoperable< Facade1, Facade2 >
|
{
|
||||||
|
typedef typename mpl::if_<
|
||||||
|
mpl::or_<
|
||||||
|
is_convertible<Facade1, Facade2>
|
||||||
|
, is_convertible<Facade2, Facade1>
|
||||||
|
>
|
||||||
, Return
|
, Return
|
||||||
>
|
, int[3]
|
||||||
{};
|
>::type type;
|
||||||
|
};
|
||||||
//
|
#else
|
||||||
// enable if for use in implementation of operators specific for random access traversal.
|
: ::boost::iterators::enable_if<
|
||||||
//
|
mpl::or_<
|
||||||
template <
|
is_convertible<Facade1, Facade2>
|
||||||
class Facade1
|
, is_convertible<Facade2, Facade1>
|
||||||
, class Facade2
|
|
||||||
, class Return
|
|
||||||
>
|
|
||||||
struct enable_if_interoperable_and_random_access_traversal :
|
|
||||||
public boost::iterators::enable_if<
|
|
||||||
mpl::and_<
|
|
||||||
is_interoperable< Facade1, Facade2 >
|
|
||||||
, is_traversal_at_least< typename iterator_category< Facade1 >::type, random_access_traversal_tag >
|
|
||||||
, is_traversal_at_least< typename iterator_category< Facade2 >::type, random_access_traversal_tag >
|
|
||||||
>
|
>
|
||||||
, Return
|
, Return
|
||||||
>
|
>
|
||||||
{};
|
{};
|
||||||
|
#endif
|
||||||
|
|
||||||
//
|
//
|
||||||
// Generates associated types for an iterator_facade with the
|
// Generates associated types for an iterator_facade with the
|
||||||
@ -121,7 +107,7 @@ namespace iterators {
|
|||||||
|
|
||||||
// Not the real associated pointer type
|
// Not the real associated pointer type
|
||||||
typedef typename mpl::eval_if<
|
typedef typename mpl::eval_if<
|
||||||
boost::iterators::detail::iterator_writability_disabled<ValueParam,Reference>
|
boost::detail::iterator_writability_disabled<ValueParam,Reference>
|
||||||
, add_pointer<const value_type>
|
, add_pointer<const value_type>
|
||||||
, add_pointer<value_type>
|
, add_pointer<value_type>
|
||||||
>::type pointer;
|
>::type pointer;
|
||||||
@ -154,160 +140,79 @@ namespace iterators {
|
|||||||
class postfix_increment_proxy
|
class postfix_increment_proxy
|
||||||
{
|
{
|
||||||
typedef typename iterator_value<Iterator>::type value_type;
|
typedef typename iterator_value<Iterator>::type value_type;
|
||||||
|
|
||||||
public:
|
public:
|
||||||
explicit postfix_increment_proxy(Iterator const& x)
|
explicit postfix_increment_proxy(Iterator const& x)
|
||||||
: stored_iterator(x)
|
: stored_value(*x)
|
||||||
, stored_value(*x)
|
|
||||||
{}
|
{}
|
||||||
|
|
||||||
// Returning a mutable reference allows nonsense like
|
// Returning a mutable reference allows nonsense like
|
||||||
// (*r++).mutate(), but it imposes fewer assumptions about the
|
// (*r++).mutate(), but it imposes fewer assumptions about the
|
||||||
// behavior of the value_type. In particular, recall that
|
// behavior of the value_type. In particular, recall taht
|
||||||
// (*r).mutate() is legal if operator* returns by value.
|
// (*r).mutate() is legal if operator* returns by value.
|
||||||
|
value_type&
|
||||||
|
operator*() const
|
||||||
|
{
|
||||||
|
return this->stored_value;
|
||||||
|
}
|
||||||
|
private:
|
||||||
|
mutable value_type stored_value;
|
||||||
|
};
|
||||||
|
|
||||||
|
//
|
||||||
|
// In general, we can't determine that such an iterator isn't
|
||||||
|
// writable -- we also need to store a copy of the old iterator so
|
||||||
|
// that it can be written into.
|
||||||
|
template <class Iterator>
|
||||||
|
class writable_postfix_increment_proxy
|
||||||
|
{
|
||||||
|
typedef typename iterator_value<Iterator>::type value_type;
|
||||||
|
public:
|
||||||
|
explicit writable_postfix_increment_proxy(Iterator const& x)
|
||||||
|
: stored_value(*x)
|
||||||
|
, stored_iterator(x)
|
||||||
|
{}
|
||||||
|
|
||||||
|
// Dereferencing must return a proxy so that both *r++ = o and
|
||||||
|
// value_type(*r++) can work. In this case, *r is the same as
|
||||||
|
// *r++, and the conversion operator below is used to ensure
|
||||||
|
// readability.
|
||||||
|
writable_postfix_increment_proxy const&
|
||||||
|
operator*() const
|
||||||
|
{
|
||||||
|
return *this;
|
||||||
|
}
|
||||||
|
|
||||||
// Provides readability of *r++
|
// Provides readability of *r++
|
||||||
value_type& operator*() const
|
operator value_type&() const
|
||||||
{
|
{
|
||||||
return stored_value;
|
return stored_value;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Provides writability of *r++
|
||||||
|
template <class T>
|
||||||
|
T const& operator=(T const& x) const
|
||||||
|
{
|
||||||
|
*this->stored_iterator = x;
|
||||||
|
return x;
|
||||||
|
}
|
||||||
|
|
||||||
|
// This overload just in case only non-const objects are writable
|
||||||
|
template <class T>
|
||||||
|
T& operator=(T& x) const
|
||||||
|
{
|
||||||
|
*this->stored_iterator = x;
|
||||||
|
return x;
|
||||||
|
}
|
||||||
|
|
||||||
// Provides X(r++)
|
// Provides X(r++)
|
||||||
operator Iterator const&() const
|
operator Iterator const&() const
|
||||||
{
|
{
|
||||||
return stored_iterator;
|
return stored_iterator;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Provides (r++)->foo()
|
|
||||||
value_type* operator->() const
|
|
||||||
{
|
|
||||||
return boost::addressof(stored_value);
|
|
||||||
}
|
|
||||||
|
|
||||||
private:
|
private:
|
||||||
Iterator stored_iterator;
|
|
||||||
mutable value_type stored_value;
|
mutable value_type stored_value;
|
||||||
};
|
|
||||||
|
|
||||||
|
|
||||||
template <class Iterator>
|
|
||||||
class writable_postfix_increment_dereference_proxy;
|
|
||||||
|
|
||||||
template <class T>
|
|
||||||
struct is_not_writable_postfix_increment_dereference_proxy :
|
|
||||||
public boost::true_type
|
|
||||||
{};
|
|
||||||
|
|
||||||
template <class Iterator>
|
|
||||||
struct is_not_writable_postfix_increment_dereference_proxy<
|
|
||||||
writable_postfix_increment_dereference_proxy<Iterator>
|
|
||||||
> :
|
|
||||||
public boost::false_type
|
|
||||||
{};
|
|
||||||
|
|
||||||
template <class Iterator>
|
|
||||||
class writable_postfix_increment_proxy;
|
|
||||||
|
|
||||||
//
|
|
||||||
// In general, we can't determine that such an iterator isn't
|
|
||||||
// writable -- we also need to store a copy of the old iterator so
|
|
||||||
// that it can be written into.
|
|
||||||
template <class Iterator>
|
|
||||||
class writable_postfix_increment_dereference_proxy
|
|
||||||
{
|
|
||||||
friend class writable_postfix_increment_proxy<Iterator>;
|
|
||||||
|
|
||||||
typedef typename iterator_value<Iterator>::type value_type;
|
|
||||||
|
|
||||||
public:
|
|
||||||
explicit writable_postfix_increment_dereference_proxy(Iterator const& x)
|
|
||||||
: stored_iterator(x)
|
|
||||||
, stored_value(*x)
|
|
||||||
{}
|
|
||||||
|
|
||||||
// Provides readability of *r++
|
|
||||||
operator value_type&() const
|
|
||||||
{
|
|
||||||
return this->stored_value;
|
|
||||||
}
|
|
||||||
|
|
||||||
template <class OtherIterator>
|
|
||||||
writable_postfix_increment_dereference_proxy const&
|
|
||||||
operator=(writable_postfix_increment_dereference_proxy<OtherIterator> const& x) const
|
|
||||||
{
|
|
||||||
typedef typename iterator_value<OtherIterator>::type other_value_type;
|
|
||||||
*this->stored_iterator = static_cast<other_value_type&>(x);
|
|
||||||
return *this;
|
|
||||||
}
|
|
||||||
|
|
||||||
// Provides writability of *r++
|
|
||||||
#if !defined(BOOST_NO_CXX11_RVALUE_REFERENCES)
|
|
||||||
template <class T>
|
|
||||||
typename iterators::enable_if<
|
|
||||||
is_not_writable_postfix_increment_dereference_proxy< T >,
|
|
||||||
writable_postfix_increment_dereference_proxy const&
|
|
||||||
>::type operator=(T&& x) const
|
|
||||||
{
|
|
||||||
*this->stored_iterator = static_cast< T&& >(x);
|
|
||||||
return *this;
|
|
||||||
}
|
|
||||||
#else
|
|
||||||
template <class T>
|
|
||||||
typename iterators::enable_if<
|
|
||||||
is_not_writable_postfix_increment_dereference_proxy< T >,
|
|
||||||
writable_postfix_increment_dereference_proxy const&
|
|
||||||
>::type operator=(T const& x) const
|
|
||||||
{
|
|
||||||
*this->stored_iterator = x;
|
|
||||||
return *this;
|
|
||||||
}
|
|
||||||
|
|
||||||
// This overload just in case only non-const objects are writable
|
|
||||||
template <class T>
|
|
||||||
typename iterators::enable_if<
|
|
||||||
is_not_writable_postfix_increment_dereference_proxy< T >,
|
|
||||||
writable_postfix_increment_dereference_proxy const&
|
|
||||||
>::type operator=(T& x) const
|
|
||||||
{
|
|
||||||
*this->stored_iterator = x;
|
|
||||||
return *this;
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
private:
|
|
||||||
Iterator stored_iterator;
|
Iterator stored_iterator;
|
||||||
mutable value_type stored_value;
|
|
||||||
};
|
|
||||||
|
|
||||||
template <class Iterator>
|
|
||||||
class writable_postfix_increment_proxy
|
|
||||||
{
|
|
||||||
typedef typename iterator_value<Iterator>::type value_type;
|
|
||||||
|
|
||||||
public:
|
|
||||||
explicit writable_postfix_increment_proxy(Iterator const& x)
|
|
||||||
: dereference_proxy(x)
|
|
||||||
{}
|
|
||||||
|
|
||||||
writable_postfix_increment_dereference_proxy<Iterator> const&
|
|
||||||
operator*() const
|
|
||||||
{
|
|
||||||
return dereference_proxy;
|
|
||||||
}
|
|
||||||
|
|
||||||
// Provides X(r++)
|
|
||||||
operator Iterator const&() const
|
|
||||||
{
|
|
||||||
return dereference_proxy.stored_iterator;
|
|
||||||
}
|
|
||||||
|
|
||||||
// Provides (r++)->foo()
|
|
||||||
value_type* operator->() const
|
|
||||||
{
|
|
||||||
return boost::addressof(dereference_proxy.stored_value);
|
|
||||||
}
|
|
||||||
|
|
||||||
private:
|
|
||||||
writable_postfix_increment_dereference_proxy<Iterator> dereference_proxy;
|
|
||||||
};
|
};
|
||||||
|
|
||||||
# ifdef BOOST_NO_TEMPLATE_PARTIAL_SPECIALIZATION
|
# ifdef BOOST_NO_TEMPLATE_PARTIAL_SPECIALIZATION
|
||||||
@ -367,15 +272,7 @@ namespace iterators {
|
|||||||
: mpl::eval_if<
|
: mpl::eval_if<
|
||||||
mpl::and_<
|
mpl::and_<
|
||||||
// A proxy is only needed for readable iterators
|
// A proxy is only needed for readable iterators
|
||||||
is_convertible<
|
is_convertible<Reference,Value const&>
|
||||||
Reference
|
|
||||||
// Use add_lvalue_reference to form `reference to Value` due to
|
|
||||||
// some (strict) C++03 compilers (e.g. `gcc -std=c++03`) reject
|
|
||||||
// 'reference-to-reference' in the template which described in CWG
|
|
||||||
// DR106.
|
|
||||||
// http://www.open-std.org/Jtc1/sc22/wg21/docs/cwg_defects.html#106
|
|
||||||
, typename add_lvalue_reference<Value const>::type
|
|
||||||
>
|
|
||||||
|
|
||||||
// No multipass iterator can have values that disappear
|
// No multipass iterator can have values that disappear
|
||||||
// before positions can be re-visited
|
// before positions can be re-visited
|
||||||
@ -397,36 +294,48 @@ namespace iterators {
|
|||||||
|
|
||||||
// operator->() needs special support for input iterators to strictly meet the
|
// operator->() needs special support for input iterators to strictly meet the
|
||||||
// standard's requirements. If *i is not a reference type, we must still
|
// standard's requirements. If *i is not a reference type, we must still
|
||||||
// produce an lvalue to which a pointer can be formed. We do that by
|
// produce a lvalue to which a pointer can be formed. We do that by
|
||||||
// returning a proxy object containing an instance of the reference object.
|
// returning an instantiation of this special proxy class template.
|
||||||
template <class Reference, class Pointer>
|
template <class T>
|
||||||
struct operator_arrow_dispatch // proxy references
|
struct operator_arrow_proxy
|
||||||
{
|
{
|
||||||
struct proxy
|
operator_arrow_proxy(T const* px) : m_value(*px) {}
|
||||||
{
|
T* operator->() const { return &m_value; }
|
||||||
explicit proxy(Reference const & x) : m_ref(x) {}
|
// This function is needed for MWCW and BCC, which won't call operator->
|
||||||
Reference* operator->() { return boost::addressof(m_ref); }
|
// again automatically per 13.3.1.2 para 8
|
||||||
// This function is needed for MWCW and BCC, which won't call
|
operator T*() const { return &m_value; }
|
||||||
// operator-> again automatically per 13.3.1.2 para 8
|
mutable T m_value;
|
||||||
operator Reference*() { return boost::addressof(m_ref); }
|
|
||||||
Reference m_ref;
|
|
||||||
};
|
};
|
||||||
typedef proxy result_type;
|
|
||||||
static result_type apply(Reference const & x)
|
// A metafunction that gets the result type for operator->. Also
|
||||||
|
// has a static function make() which builds the result from a
|
||||||
|
// Reference
|
||||||
|
template <class ValueType, class Reference, class Pointer>
|
||||||
|
struct operator_arrow_result
|
||||||
{
|
{
|
||||||
return result_type(x);
|
// CWPro8.3 won't accept "operator_arrow_result::type", and we
|
||||||
|
// need that type below, so metafunction forwarding would be a
|
||||||
|
// losing proposition here.
|
||||||
|
typedef typename mpl::if_<
|
||||||
|
is_reference<Reference>
|
||||||
|
, Pointer
|
||||||
|
, operator_arrow_proxy<ValueType>
|
||||||
|
>::type type;
|
||||||
|
|
||||||
|
static type make(Reference x)
|
||||||
|
{
|
||||||
|
return implicit_cast<type>(&x);
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
template <class T, class Pointer>
|
# if BOOST_WORKAROUND(BOOST_MSVC, < 1300)
|
||||||
struct operator_arrow_dispatch<T&, Pointer> // "real" references
|
// Deal with ETI
|
||||||
|
template<>
|
||||||
|
struct operator_arrow_result<int, int, int>
|
||||||
{
|
{
|
||||||
typedef Pointer result_type;
|
typedef int type;
|
||||||
static result_type apply(T& x)
|
|
||||||
{
|
|
||||||
return boost::addressof(x);
|
|
||||||
}
|
|
||||||
};
|
};
|
||||||
|
# endif
|
||||||
|
|
||||||
// A proxy return type for operator[], needed to deal with
|
// A proxy return type for operator[], needed to deal with
|
||||||
// iterators that may invalidate referents upon destruction.
|
// iterators that may invalidate referents upon destruction.
|
||||||
@ -502,6 +411,12 @@ namespace iterators {
|
|||||||
:
|
:
|
||||||
# ifdef BOOST_NO_ONE_WAY_ITERATOR_INTEROP
|
# ifdef BOOST_NO_ONE_WAY_ITERATOR_INTEROP
|
||||||
iterator_difference<I1>
|
iterator_difference<I1>
|
||||||
|
# elif BOOST_WORKAROUND(BOOST_MSVC, < 1300)
|
||||||
|
mpl::if_<
|
||||||
|
is_convertible<I2,I1>
|
||||||
|
, typename I1::difference_type
|
||||||
|
, typename I2::difference_type
|
||||||
|
>
|
||||||
# else
|
# else
|
||||||
mpl::eval_if<
|
mpl::eval_if<
|
||||||
is_convertible<I2,I1>
|
is_convertible<I2,I1>
|
||||||
@ -512,24 +427,12 @@ namespace iterators {
|
|||||||
{};
|
{};
|
||||||
|
|
||||||
};
|
};
|
||||||
|
|
||||||
template <
|
|
||||||
class Derived
|
|
||||||
, class Value
|
|
||||||
, class CategoryOrTraversal
|
|
||||||
, class Reference
|
|
||||||
, class Difference
|
|
||||||
, bool IsBidirectionalTraversal
|
|
||||||
, bool IsRandomAccessTraversal
|
|
||||||
>
|
|
||||||
class iterator_facade_base;
|
|
||||||
|
|
||||||
} // namespace detail
|
} // namespace detail
|
||||||
|
|
||||||
|
|
||||||
// Macros which describe the declarations of binary operators
|
// Macros which describe the declarations of binary operators
|
||||||
# ifdef BOOST_NO_STRICT_ITERATOR_INTEROPERABILITY
|
# ifdef BOOST_NO_STRICT_ITERATOR_INTEROPERABILITY
|
||||||
# define BOOST_ITERATOR_FACADE_INTEROP_HEAD_IMPL(prefix, op, result_type, enabler) \
|
# define BOOST_ITERATOR_FACADE_INTEROP_HEAD(prefix, op, result_type) \
|
||||||
template < \
|
template < \
|
||||||
class Derived1, class V1, class TC1, class Reference1, class Difference1 \
|
class Derived1, class V1, class TC1, class Reference1, class Difference1 \
|
||||||
, class Derived2, class V2, class TC2, class Reference2, class Difference2 \
|
, class Derived2, class V2, class TC2, class Reference2, class Difference2 \
|
||||||
@ -539,12 +442,12 @@ namespace iterators {
|
|||||||
iterator_facade<Derived1, V1, TC1, Reference1, Difference1> const& lhs \
|
iterator_facade<Derived1, V1, TC1, Reference1, Difference1> const& lhs \
|
||||||
, iterator_facade<Derived2, V2, TC2, Reference2, Difference2> const& rhs)
|
, iterator_facade<Derived2, V2, TC2, Reference2, Difference2> const& rhs)
|
||||||
# else
|
# else
|
||||||
# define BOOST_ITERATOR_FACADE_INTEROP_HEAD_IMPL(prefix, op, result_type, enabler) \
|
# define BOOST_ITERATOR_FACADE_INTEROP_HEAD(prefix, op, result_type) \
|
||||||
template < \
|
template < \
|
||||||
class Derived1, class V1, class TC1, class Reference1, class Difference1 \
|
class Derived1, class V1, class TC1, class Reference1, class Difference1 \
|
||||||
, class Derived2, class V2, class TC2, class Reference2, class Difference2 \
|
, class Derived2, class V2, class TC2, class Reference2, class Difference2 \
|
||||||
> \
|
> \
|
||||||
prefix typename enabler< \
|
prefix typename boost::detail::enable_if_interoperable< \
|
||||||
Derived1, Derived2 \
|
Derived1, Derived2 \
|
||||||
, typename mpl::apply2<result_type,Derived1,Derived2>::type \
|
, typename mpl::apply2<result_type,Derived1,Derived2>::type \
|
||||||
>::type \
|
>::type \
|
||||||
@ -553,18 +456,9 @@ namespace iterators {
|
|||||||
, iterator_facade<Derived2, V2, TC2, Reference2, Difference2> const& rhs)
|
, iterator_facade<Derived2, V2, TC2, Reference2, Difference2> const& rhs)
|
||||||
# endif
|
# endif
|
||||||
|
|
||||||
# define BOOST_ITERATOR_FACADE_INTEROP_HEAD(prefix, op, result_type) \
|
|
||||||
BOOST_ITERATOR_FACADE_INTEROP_HEAD_IMPL(prefix, op, result_type, boost::iterators::detail::enable_if_interoperable)
|
|
||||||
|
|
||||||
# define BOOST_ITERATOR_FACADE_INTEROP_RANDOM_ACCESS_HEAD(prefix, op, result_type) \
|
|
||||||
BOOST_ITERATOR_FACADE_INTEROP_HEAD_IMPL(prefix, op, result_type, boost::iterators::detail::enable_if_interoperable_and_random_access_traversal)
|
|
||||||
|
|
||||||
# define BOOST_ITERATOR_FACADE_PLUS_HEAD(prefix,args) \
|
# define BOOST_ITERATOR_FACADE_PLUS_HEAD(prefix,args) \
|
||||||
template <class Derived, class V, class TC, class R, class D> \
|
template <class Derived, class V, class TC, class R, class D> \
|
||||||
prefix typename boost::iterators::enable_if< \
|
prefix Derived operator+ args
|
||||||
boost::iterators::detail::is_traversal_at_least< TC, boost::iterators::random_access_traversal_tag >, \
|
|
||||||
Derived \
|
|
||||||
>::type operator+ args
|
|
||||||
|
|
||||||
//
|
//
|
||||||
// Helper class for granting access to the iterator core interface.
|
// Helper class for granting access to the iterator core interface.
|
||||||
@ -584,29 +478,21 @@ namespace iterators {
|
|||||||
# else
|
# else
|
||||||
|
|
||||||
template <class I, class V, class TC, class R, class D> friend class iterator_facade;
|
template <class I, class V, class TC, class R, class D> friend class iterator_facade;
|
||||||
template <class I, class V, class TC, class R, class D, bool IsBidirectionalTraversal, bool IsRandomAccessTraversal>
|
|
||||||
friend class detail::iterator_facade_base;
|
|
||||||
|
|
||||||
# define BOOST_ITERATOR_FACADE_RELATION(op) \
|
# define BOOST_ITERATOR_FACADE_RELATION(op) \
|
||||||
BOOST_ITERATOR_FACADE_INTEROP_HEAD(friend,op, boost::iterators::detail::always_bool2);
|
BOOST_ITERATOR_FACADE_INTEROP_HEAD(friend,op, boost::detail::always_bool2);
|
||||||
|
|
||||||
BOOST_ITERATOR_FACADE_RELATION(==)
|
BOOST_ITERATOR_FACADE_RELATION(==)
|
||||||
BOOST_ITERATOR_FACADE_RELATION(!=)
|
BOOST_ITERATOR_FACADE_RELATION(!=)
|
||||||
|
|
||||||
|
BOOST_ITERATOR_FACADE_RELATION(<)
|
||||||
|
BOOST_ITERATOR_FACADE_RELATION(>)
|
||||||
|
BOOST_ITERATOR_FACADE_RELATION(<=)
|
||||||
|
BOOST_ITERATOR_FACADE_RELATION(>=)
|
||||||
# undef BOOST_ITERATOR_FACADE_RELATION
|
# undef BOOST_ITERATOR_FACADE_RELATION
|
||||||
|
|
||||||
# define BOOST_ITERATOR_FACADE_RANDOM_ACCESS_RELATION(op) \
|
BOOST_ITERATOR_FACADE_INTEROP_HEAD(
|
||||||
BOOST_ITERATOR_FACADE_INTEROP_RANDOM_ACCESS_HEAD(friend,op, boost::iterators::detail::always_bool2);
|
friend, -, boost::detail::choose_difference_type)
|
||||||
|
|
||||||
BOOST_ITERATOR_FACADE_RANDOM_ACCESS_RELATION(<)
|
|
||||||
BOOST_ITERATOR_FACADE_RANDOM_ACCESS_RELATION(>)
|
|
||||||
BOOST_ITERATOR_FACADE_RANDOM_ACCESS_RELATION(<=)
|
|
||||||
BOOST_ITERATOR_FACADE_RANDOM_ACCESS_RELATION(>=)
|
|
||||||
|
|
||||||
# undef BOOST_ITERATOR_FACADE_RANDOM_ACCESS_RELATION
|
|
||||||
|
|
||||||
BOOST_ITERATOR_FACADE_INTEROP_RANDOM_ACCESS_HEAD(
|
|
||||||
friend, -, boost::iterators::detail::choose_difference_type)
|
|
||||||
;
|
;
|
||||||
|
|
||||||
BOOST_ITERATOR_FACADE_PLUS_HEAD(
|
BOOST_ITERATOR_FACADE_PLUS_HEAD(
|
||||||
@ -690,65 +576,31 @@ namespace iterators {
|
|||||||
return *static_cast<I const*>(&facade);
|
return *static_cast<I const*>(&facade);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private:
|
||||||
// objects of this class are useless
|
// objects of this class are useless
|
||||||
BOOST_DELETED_FUNCTION(iterator_core_access())
|
iterator_core_access(); //undefined
|
||||||
};
|
};
|
||||||
|
|
||||||
namespace detail {
|
//
|
||||||
|
// iterator_facade - use as a public base class for defining new
|
||||||
// Implementation for forward traversal iterators
|
// standard-conforming iterators.
|
||||||
|
//
|
||||||
template <
|
template <
|
||||||
class Derived
|
class Derived // The derived iterator type being constructed
|
||||||
, class Value
|
, class Value
|
||||||
, class CategoryOrTraversal
|
, class CategoryOrTraversal
|
||||||
, class Reference
|
, class Reference = Value&
|
||||||
, class Difference
|
, class Difference = std::ptrdiff_t
|
||||||
>
|
>
|
||||||
class iterator_facade_base< Derived, Value, CategoryOrTraversal, Reference, Difference, false, false >
|
class iterator_facade
|
||||||
# ifdef BOOST_ITERATOR_FACADE_NEEDS_ITERATOR_BASE
|
# ifdef BOOST_ITERATOR_FACADE_NEEDS_ITERATOR_BASE
|
||||||
: public boost::iterators::detail::iterator_facade_types<
|
: public boost::detail::iterator_facade_types<
|
||||||
Value, CategoryOrTraversal, Reference, Difference
|
Value, CategoryOrTraversal, Reference, Difference
|
||||||
>::base
|
>::base
|
||||||
# undef BOOST_ITERATOR_FACADE_NEEDS_ITERATOR_BASE
|
# undef BOOST_ITERATOR_FACADE_NEEDS_ITERATOR_BASE
|
||||||
# endif
|
# endif
|
||||||
{
|
{
|
||||||
private:
|
private:
|
||||||
typedef boost::iterators::detail::iterator_facade_types<
|
|
||||||
Value, CategoryOrTraversal, Reference, Difference
|
|
||||||
> associated_types;
|
|
||||||
|
|
||||||
typedef boost::iterators::detail::operator_arrow_dispatch<
|
|
||||||
Reference
|
|
||||||
, typename associated_types::pointer
|
|
||||||
> operator_arrow_dispatch_;
|
|
||||||
|
|
||||||
public:
|
|
||||||
typedef typename associated_types::value_type value_type;
|
|
||||||
typedef Reference reference;
|
|
||||||
typedef Difference difference_type;
|
|
||||||
|
|
||||||
typedef typename operator_arrow_dispatch_::result_type pointer;
|
|
||||||
|
|
||||||
typedef typename associated_types::iterator_category iterator_category;
|
|
||||||
|
|
||||||
public:
|
|
||||||
reference operator*() const
|
|
||||||
{
|
|
||||||
return iterator_core_access::dereference(this->derived());
|
|
||||||
}
|
|
||||||
|
|
||||||
pointer operator->() const
|
|
||||||
{
|
|
||||||
return operator_arrow_dispatch_::apply(*this->derived());
|
|
||||||
}
|
|
||||||
|
|
||||||
Derived& operator++()
|
|
||||||
{
|
|
||||||
iterator_core_access::increment(this->derived());
|
|
||||||
return this->derived();
|
|
||||||
}
|
|
||||||
|
|
||||||
protected:
|
|
||||||
//
|
//
|
||||||
// Curiously Recurring Template interface.
|
// Curiously Recurring Template interface.
|
||||||
//
|
//
|
||||||
@ -761,20 +613,69 @@ namespace iterators {
|
|||||||
{
|
{
|
||||||
return *static_cast<Derived const*>(this);
|
return *static_cast<Derived const*>(this);
|
||||||
}
|
}
|
||||||
};
|
|
||||||
|
|
||||||
// Implementation for bidirectional traversal iterators
|
typedef boost::detail::iterator_facade_types<
|
||||||
template <
|
Value, CategoryOrTraversal, Reference, Difference
|
||||||
class Derived
|
> associated_types;
|
||||||
, class Value
|
|
||||||
, class CategoryOrTraversal
|
typedef boost::detail::operator_arrow_result<
|
||||||
, class Reference
|
typename associated_types::value_type
|
||||||
, class Difference
|
, Reference
|
||||||
>
|
, typename associated_types::pointer
|
||||||
class iterator_facade_base< Derived, Value, CategoryOrTraversal, Reference, Difference, true, false > :
|
> pointer_;
|
||||||
public iterator_facade_base< Derived, Value, CategoryOrTraversal, Reference, Difference, false, false >
|
|
||||||
{
|
protected:
|
||||||
|
// For use by derived classes
|
||||||
|
typedef iterator_facade<Derived,Value,CategoryOrTraversal,Reference,Difference> iterator_facade_;
|
||||||
|
|
||||||
public:
|
public:
|
||||||
|
|
||||||
|
typedef typename associated_types::value_type value_type;
|
||||||
|
typedef Reference reference;
|
||||||
|
typedef Difference difference_type;
|
||||||
|
|
||||||
|
typedef typename pointer_::type pointer;
|
||||||
|
|
||||||
|
typedef typename associated_types::iterator_category iterator_category;
|
||||||
|
|
||||||
|
reference operator*() const
|
||||||
|
{
|
||||||
|
return iterator_core_access::dereference(this->derived());
|
||||||
|
}
|
||||||
|
|
||||||
|
pointer operator->() const
|
||||||
|
{
|
||||||
|
return pointer_::make(*this->derived());
|
||||||
|
}
|
||||||
|
|
||||||
|
typename boost::detail::operator_brackets_result<Derived,Value,reference>::type
|
||||||
|
operator[](difference_type n) const
|
||||||
|
{
|
||||||
|
typedef boost::detail::use_operator_brackets_proxy<Value,Reference> use_proxy;
|
||||||
|
|
||||||
|
return boost::detail::make_operator_brackets_result<Derived>(
|
||||||
|
this->derived() + n
|
||||||
|
, use_proxy()
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
Derived& operator++()
|
||||||
|
{
|
||||||
|
iterator_core_access::increment(this->derived());
|
||||||
|
return this->derived();
|
||||||
|
}
|
||||||
|
|
||||||
|
# if BOOST_WORKAROUND(BOOST_MSVC, < 1300)
|
||||||
|
typename boost::detail::postfix_increment_result<Derived,Value,Reference,CategoryOrTraversal>::type
|
||||||
|
operator++(int)
|
||||||
|
{
|
||||||
|
typename boost::detail::postfix_increment_result<Derived,Value,Reference,CategoryOrTraversal>::type
|
||||||
|
tmp(this->derived());
|
||||||
|
++*this;
|
||||||
|
return tmp;
|
||||||
|
}
|
||||||
|
# endif
|
||||||
|
|
||||||
Derived& operator--()
|
Derived& operator--()
|
||||||
{
|
{
|
||||||
iterator_core_access::decrement(this->derived());
|
iterator_core_access::decrement(this->derived());
|
||||||
@ -787,37 +688,6 @@ namespace iterators {
|
|||||||
--*this;
|
--*this;
|
||||||
return tmp;
|
return tmp;
|
||||||
}
|
}
|
||||||
};
|
|
||||||
|
|
||||||
// Implementation for random access traversal iterators
|
|
||||||
template <
|
|
||||||
class Derived
|
|
||||||
, class Value
|
|
||||||
, class CategoryOrTraversal
|
|
||||||
, class Reference
|
|
||||||
, class Difference
|
|
||||||
>
|
|
||||||
class iterator_facade_base< Derived, Value, CategoryOrTraversal, Reference, Difference, true, true > :
|
|
||||||
public iterator_facade_base< Derived, Value, CategoryOrTraversal, Reference, Difference, true, false >
|
|
||||||
{
|
|
||||||
private:
|
|
||||||
typedef iterator_facade_base< Derived, Value, CategoryOrTraversal, Reference, Difference, true, false > base_type;
|
|
||||||
|
|
||||||
public:
|
|
||||||
typedef typename base_type::reference reference;
|
|
||||||
typedef typename base_type::difference_type difference_type;
|
|
||||||
|
|
||||||
public:
|
|
||||||
typename boost::iterators::detail::operator_brackets_result<Derived, Value, reference>::type
|
|
||||||
operator[](difference_type n) const
|
|
||||||
{
|
|
||||||
typedef boost::iterators::detail::use_operator_brackets_proxy<Value, Reference> use_proxy;
|
|
||||||
|
|
||||||
return boost::iterators::detail::make_operator_brackets_result<Derived>(
|
|
||||||
this->derived() + n
|
|
||||||
, use_proxy()
|
|
||||||
);
|
|
||||||
}
|
|
||||||
|
|
||||||
Derived& operator+=(difference_type n)
|
Derived& operator+=(difference_type n)
|
||||||
{
|
{
|
||||||
@ -836,51 +706,36 @@ namespace iterators {
|
|||||||
Derived result(this->derived());
|
Derived result(this->derived());
|
||||||
return result -= x;
|
return result -= x;
|
||||||
}
|
}
|
||||||
};
|
|
||||||
|
|
||||||
} // namespace detail
|
# if BOOST_WORKAROUND(BOOST_MSVC, < 1300)
|
||||||
|
// There appears to be a bug which trashes the data of classes
|
||||||
//
|
// derived from iterator_facade when they are assigned unless we
|
||||||
// iterator_facade - use as a public base class for defining new
|
// define this assignment operator. This bug is only revealed
|
||||||
// standard-conforming iterators.
|
// (so far) in STLPort debug mode, but it's clearly a codegen
|
||||||
//
|
// problem so we apply the workaround for all MSVC6.
|
||||||
template <
|
iterator_facade& operator=(iterator_facade const&)
|
||||||
class Derived // The derived iterator type being constructed
|
|
||||||
, class Value
|
|
||||||
, class CategoryOrTraversal
|
|
||||||
, class Reference = Value&
|
|
||||||
, class Difference = std::ptrdiff_t
|
|
||||||
>
|
|
||||||
class iterator_facade :
|
|
||||||
public detail::iterator_facade_base<
|
|
||||||
Derived,
|
|
||||||
Value,
|
|
||||||
CategoryOrTraversal,
|
|
||||||
Reference,
|
|
||||||
Difference,
|
|
||||||
detail::is_traversal_at_least< CategoryOrTraversal, bidirectional_traversal_tag >::value,
|
|
||||||
detail::is_traversal_at_least< CategoryOrTraversal, random_access_traversal_tag >::value
|
|
||||||
>
|
|
||||||
{
|
{
|
||||||
protected:
|
return *this;
|
||||||
// For use by derived classes
|
}
|
||||||
typedef iterator_facade<Derived,Value,CategoryOrTraversal,Reference,Difference> iterator_facade_;
|
# endif
|
||||||
};
|
};
|
||||||
|
|
||||||
|
# if !BOOST_WORKAROUND(BOOST_MSVC, < 1300)
|
||||||
template <class I, class V, class TC, class R, class D>
|
template <class I, class V, class TC, class R, class D>
|
||||||
inline typename boost::iterators::detail::postfix_increment_result<I,V,R,TC>::type
|
inline typename boost::detail::postfix_increment_result<I,V,R,TC>::type
|
||||||
operator++(
|
operator++(
|
||||||
iterator_facade<I,V,TC,R,D>& i
|
iterator_facade<I,V,TC,R,D>& i
|
||||||
, int
|
, int
|
||||||
)
|
)
|
||||||
{
|
{
|
||||||
typename boost::iterators::detail::postfix_increment_result<I,V,R,TC>::type
|
typename boost::detail::postfix_increment_result<I,V,R,TC>::type
|
||||||
tmp(*static_cast<I*>(&i));
|
tmp(*static_cast<I*>(&i));
|
||||||
|
|
||||||
++i;
|
++i;
|
||||||
|
|
||||||
return tmp;
|
return tmp;
|
||||||
}
|
}
|
||||||
|
# endif
|
||||||
|
|
||||||
|
|
||||||
//
|
//
|
||||||
@ -973,7 +828,7 @@ namespace iterators {
|
|||||||
# define BOOST_ITERATOR_FACADE_RELATION(op, return_prefix, base_op) \
|
# define BOOST_ITERATOR_FACADE_RELATION(op, return_prefix, base_op) \
|
||||||
BOOST_ITERATOR_FACADE_INTEROP( \
|
BOOST_ITERATOR_FACADE_INTEROP( \
|
||||||
op \
|
op \
|
||||||
, boost::iterators::detail::always_bool2 \
|
, boost::detail::always_bool2 \
|
||||||
, return_prefix \
|
, return_prefix \
|
||||||
, base_op \
|
, base_op \
|
||||||
)
|
)
|
||||||
@ -981,50 +836,21 @@ namespace iterators {
|
|||||||
BOOST_ITERATOR_FACADE_RELATION(==, return, equal)
|
BOOST_ITERATOR_FACADE_RELATION(==, return, equal)
|
||||||
BOOST_ITERATOR_FACADE_RELATION(!=, return !, equal)
|
BOOST_ITERATOR_FACADE_RELATION(!=, return !, equal)
|
||||||
|
|
||||||
|
BOOST_ITERATOR_FACADE_RELATION(<, return 0 >, distance_from)
|
||||||
|
BOOST_ITERATOR_FACADE_RELATION(>, return 0 <, distance_from)
|
||||||
|
BOOST_ITERATOR_FACADE_RELATION(<=, return 0 >=, distance_from)
|
||||||
|
BOOST_ITERATOR_FACADE_RELATION(>=, return 0 <=, distance_from)
|
||||||
# undef BOOST_ITERATOR_FACADE_RELATION
|
# undef BOOST_ITERATOR_FACADE_RELATION
|
||||||
|
|
||||||
|
|
||||||
# define BOOST_ITERATOR_FACADE_INTEROP_RANDOM_ACCESS(op, result_type, return_prefix, base_op) \
|
|
||||||
BOOST_ITERATOR_FACADE_INTEROP_RANDOM_ACCESS_HEAD(inline, op, result_type) \
|
|
||||||
{ \
|
|
||||||
/* For those compilers that do not support enable_if */ \
|
|
||||||
BOOST_STATIC_ASSERT(( \
|
|
||||||
is_interoperable< Derived1, Derived2 >::value && \
|
|
||||||
boost::iterators::detail::is_traversal_at_least< typename iterator_category< Derived1 >::type, random_access_traversal_tag >::value && \
|
|
||||||
boost::iterators::detail::is_traversal_at_least< typename iterator_category< Derived2 >::type, random_access_traversal_tag >::value \
|
|
||||||
)); \
|
|
||||||
return_prefix iterator_core_access::base_op( \
|
|
||||||
*static_cast<Derived1 const*>(&lhs) \
|
|
||||||
, *static_cast<Derived2 const*>(&rhs) \
|
|
||||||
, BOOST_ITERATOR_CONVERTIBLE(Derived2,Derived1) \
|
|
||||||
); \
|
|
||||||
}
|
|
||||||
|
|
||||||
# define BOOST_ITERATOR_FACADE_RANDOM_ACCESS_RELATION(op, return_prefix, base_op) \
|
|
||||||
BOOST_ITERATOR_FACADE_INTEROP_RANDOM_ACCESS( \
|
|
||||||
op \
|
|
||||||
, boost::iterators::detail::always_bool2 \
|
|
||||||
, return_prefix \
|
|
||||||
, base_op \
|
|
||||||
)
|
|
||||||
|
|
||||||
BOOST_ITERATOR_FACADE_RANDOM_ACCESS_RELATION(<, return 0 >, distance_from)
|
|
||||||
BOOST_ITERATOR_FACADE_RANDOM_ACCESS_RELATION(>, return 0 <, distance_from)
|
|
||||||
BOOST_ITERATOR_FACADE_RANDOM_ACCESS_RELATION(<=, return 0 >=, distance_from)
|
|
||||||
BOOST_ITERATOR_FACADE_RANDOM_ACCESS_RELATION(>=, return 0 <=, distance_from)
|
|
||||||
|
|
||||||
# undef BOOST_ITERATOR_FACADE_RANDOM_ACCESS_RELATION
|
|
||||||
|
|
||||||
// operator- requires an additional part in the static assertion
|
// operator- requires an additional part in the static assertion
|
||||||
BOOST_ITERATOR_FACADE_INTEROP_RANDOM_ACCESS(
|
BOOST_ITERATOR_FACADE_INTEROP(
|
||||||
-
|
-
|
||||||
, boost::iterators::detail::choose_difference_type
|
, boost::detail::choose_difference_type
|
||||||
, return
|
, return
|
||||||
, distance_from
|
, distance_from
|
||||||
)
|
)
|
||||||
|
|
||||||
# undef BOOST_ITERATOR_FACADE_INTEROP
|
# undef BOOST_ITERATOR_FACADE_INTEROP
|
||||||
# undef BOOST_ITERATOR_FACADE_INTEROP_RANDOM_ACCESS
|
# undef BOOST_ITERATOR_FACADE_INTEROP_HEAD
|
||||||
|
|
||||||
# define BOOST_ITERATOR_FACADE_PLUS(args) \
|
# define BOOST_ITERATOR_FACADE_PLUS(args) \
|
||||||
BOOST_ITERATOR_FACADE_PLUS_HEAD(inline, args) \
|
BOOST_ITERATOR_FACADE_PLUS_HEAD(inline, args) \
|
||||||
@ -1042,19 +868,9 @@ namespace iterators {
|
|||||||
typename Derived::difference_type n
|
typename Derived::difference_type n
|
||||||
, iterator_facade<Derived, V, TC, R, D> const& i
|
, iterator_facade<Derived, V, TC, R, D> const& i
|
||||||
))
|
))
|
||||||
|
|
||||||
# undef BOOST_ITERATOR_FACADE_PLUS
|
# undef BOOST_ITERATOR_FACADE_PLUS
|
||||||
# undef BOOST_ITERATOR_FACADE_PLUS_HEAD
|
# undef BOOST_ITERATOR_FACADE_PLUS_HEAD
|
||||||
|
|
||||||
# undef BOOST_ITERATOR_FACADE_INTEROP_HEAD
|
|
||||||
# undef BOOST_ITERATOR_FACADE_INTEROP_RANDOM_ACCESS_HEAD
|
|
||||||
# undef BOOST_ITERATOR_FACADE_INTEROP_HEAD_IMPL
|
|
||||||
|
|
||||||
} // namespace iterators
|
|
||||||
|
|
||||||
using iterators::iterator_core_access;
|
|
||||||
using iterators::iterator_facade;
|
|
||||||
|
|
||||||
} // namespace boost
|
} // namespace boost
|
||||||
|
|
||||||
#include <boost/iterator/detail/config_undef.hpp>
|
#include <boost/iterator/detail/config_undef.hpp>
|
||||||
|
@ -5,57 +5,88 @@
|
|||||||
#ifndef ITERATOR_TRAITS_DWA200347_HPP
|
#ifndef ITERATOR_TRAITS_DWA200347_HPP
|
||||||
# define ITERATOR_TRAITS_DWA200347_HPP
|
# define ITERATOR_TRAITS_DWA200347_HPP
|
||||||
|
|
||||||
|
# include <boost/detail/iterator.hpp>
|
||||||
# include <boost/detail/workaround.hpp>
|
# include <boost/detail/workaround.hpp>
|
||||||
|
|
||||||
#include <iterator>
|
|
||||||
|
|
||||||
namespace boost {
|
namespace boost {
|
||||||
namespace iterators {
|
|
||||||
|
|
||||||
// Macro for supporting old compilers, no longer needed but kept
|
// Unfortunately, g++ 2.95.x chokes when we define a class template
|
||||||
// for backwards compatibility (it was documented).
|
// iterator_category which has the same name as its
|
||||||
|
// std::iterator_category() function, probably due in part to the
|
||||||
|
// "std:: is visible globally" hack it uses. Use
|
||||||
|
// BOOST_ITERATOR_CATEGORY to write code that's portable to older
|
||||||
|
// GCCs.
|
||||||
|
|
||||||
|
# if BOOST_WORKAROUND(__GNUC__, <= 2)
|
||||||
|
# define BOOST_ITERATOR_CATEGORY iterator_category_
|
||||||
|
# else
|
||||||
# define BOOST_ITERATOR_CATEGORY iterator_category
|
# define BOOST_ITERATOR_CATEGORY iterator_category
|
||||||
|
# endif
|
||||||
|
|
||||||
|
|
||||||
template <class Iterator>
|
template <class Iterator>
|
||||||
struct iterator_value
|
struct iterator_value
|
||||||
{
|
{
|
||||||
typedef typename std::iterator_traits<Iterator>::value_type type;
|
typedef typename boost::detail::iterator_traits<Iterator>::value_type type;
|
||||||
};
|
};
|
||||||
|
|
||||||
template <class Iterator>
|
template <class Iterator>
|
||||||
struct iterator_reference
|
struct iterator_reference
|
||||||
{
|
{
|
||||||
typedef typename std::iterator_traits<Iterator>::reference type;
|
typedef typename boost::detail::iterator_traits<Iterator>::reference type;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
template <class Iterator>
|
template <class Iterator>
|
||||||
struct iterator_pointer
|
struct iterator_pointer
|
||||||
{
|
{
|
||||||
typedef typename std::iterator_traits<Iterator>::pointer type;
|
typedef typename boost::detail::iterator_traits<Iterator>::pointer type;
|
||||||
};
|
};
|
||||||
|
|
||||||
template <class Iterator>
|
template <class Iterator>
|
||||||
struct iterator_difference
|
struct iterator_difference
|
||||||
{
|
{
|
||||||
typedef typename std::iterator_traits<Iterator>::difference_type type;
|
typedef typename boost::detail::iterator_traits<Iterator>::difference_type type;
|
||||||
};
|
};
|
||||||
|
|
||||||
template <class Iterator>
|
template <class Iterator>
|
||||||
struct iterator_category
|
struct BOOST_ITERATOR_CATEGORY
|
||||||
{
|
{
|
||||||
typedef typename std::iterator_traits<Iterator>::iterator_category type;
|
typedef typename boost::detail::iterator_traits<Iterator>::iterator_category type;
|
||||||
};
|
};
|
||||||
|
|
||||||
} // namespace iterators
|
# if BOOST_WORKAROUND(BOOST_MSVC, < 1300)
|
||||||
|
template <>
|
||||||
|
struct iterator_value<int>
|
||||||
|
{
|
||||||
|
typedef void type;
|
||||||
|
};
|
||||||
|
|
||||||
using iterators::iterator_value;
|
template <>
|
||||||
using iterators::iterator_reference;
|
struct iterator_reference<int>
|
||||||
using iterators::iterator_pointer;
|
{
|
||||||
using iterators::iterator_difference;
|
typedef void type;
|
||||||
using iterators::iterator_category;
|
};
|
||||||
|
|
||||||
} // namespace boost
|
template <>
|
||||||
|
struct iterator_pointer<int>
|
||||||
|
{
|
||||||
|
typedef void type;
|
||||||
|
};
|
||||||
|
|
||||||
|
template <>
|
||||||
|
struct iterator_difference<int>
|
||||||
|
{
|
||||||
|
typedef void type;
|
||||||
|
};
|
||||||
|
|
||||||
|
template <>
|
||||||
|
struct BOOST_ITERATOR_CATEGORY<int>
|
||||||
|
{
|
||||||
|
typedef void type;
|
||||||
|
};
|
||||||
|
# endif
|
||||||
|
|
||||||
|
} // namespace boost::iterator
|
||||||
|
|
||||||
#endif // ITERATOR_TRAITS_DWA200347_HPP
|
#endif // ITERATOR_TRAITS_DWA200347_HPP
|
||||||
|
@ -1,95 +0,0 @@
|
|||||||
// Copyright David Abrahams 2003. Use, modification and distribution is
|
|
||||||
// subject to the Boost Software License, Version 1.0. (See accompanying
|
|
||||||
// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
|
|
||||||
#ifndef BOOST_ITERATOR_MINIMUM_CATEGORY_HPP_INCLUDED_
|
|
||||||
# define BOOST_ITERATOR_MINIMUM_CATEGORY_HPP_INCLUDED_
|
|
||||||
|
|
||||||
# include <boost/static_assert.hpp>
|
|
||||||
# include <boost/type_traits/is_convertible.hpp>
|
|
||||||
# include <boost/type_traits/is_same.hpp>
|
|
||||||
|
|
||||||
# include <boost/mpl/placeholders.hpp>
|
|
||||||
# include <boost/mpl/aux_/lambda_support.hpp>
|
|
||||||
|
|
||||||
namespace boost {
|
|
||||||
namespace iterators {
|
|
||||||
namespace detail {
|
|
||||||
|
|
||||||
template <bool GreaterEqual, bool LessEqual>
|
|
||||||
struct minimum_category_impl;
|
|
||||||
|
|
||||||
template <class T1, class T2>
|
|
||||||
struct error_not_related_by_convertibility;
|
|
||||||
|
|
||||||
template <>
|
|
||||||
struct minimum_category_impl<true,false>
|
|
||||||
{
|
|
||||||
template <class T1, class T2> struct apply
|
|
||||||
{
|
|
||||||
typedef T2 type;
|
|
||||||
};
|
|
||||||
};
|
|
||||||
|
|
||||||
template <>
|
|
||||||
struct minimum_category_impl<false,true>
|
|
||||||
{
|
|
||||||
template <class T1, class T2> struct apply
|
|
||||||
{
|
|
||||||
typedef T1 type;
|
|
||||||
};
|
|
||||||
};
|
|
||||||
|
|
||||||
template <>
|
|
||||||
struct minimum_category_impl<true,true>
|
|
||||||
{
|
|
||||||
template <class T1, class T2> struct apply
|
|
||||||
{
|
|
||||||
BOOST_STATIC_ASSERT((is_same<T1,T2>::value));
|
|
||||||
typedef T1 type;
|
|
||||||
};
|
|
||||||
};
|
|
||||||
|
|
||||||
template <>
|
|
||||||
struct minimum_category_impl<false,false>
|
|
||||||
{
|
|
||||||
template <class T1, class T2> struct apply
|
|
||||||
: error_not_related_by_convertibility<T1,T2>
|
|
||||||
{
|
|
||||||
};
|
|
||||||
};
|
|
||||||
|
|
||||||
} // namespace detail
|
|
||||||
|
|
||||||
//
|
|
||||||
// Returns the minimum category type or fails to compile
|
|
||||||
// if T1 and T2 are unrelated.
|
|
||||||
//
|
|
||||||
template <class T1 = mpl::_1, class T2 = mpl::_2>
|
|
||||||
struct minimum_category
|
|
||||||
{
|
|
||||||
typedef boost::iterators::detail::minimum_category_impl<
|
|
||||||
::boost::is_convertible<T1,T2>::value
|
|
||||||
, ::boost::is_convertible<T2,T1>::value
|
|
||||||
> outer;
|
|
||||||
|
|
||||||
typedef typename outer::template apply<T1,T2> inner;
|
|
||||||
typedef typename inner::type type;
|
|
||||||
|
|
||||||
BOOST_MPL_AUX_LAMBDA_SUPPORT(2,minimum_category,(T1,T2))
|
|
||||||
};
|
|
||||||
|
|
||||||
template <>
|
|
||||||
struct minimum_category<mpl::_1,mpl::_2>
|
|
||||||
{
|
|
||||||
template <class T1, class T2>
|
|
||||||
struct apply : minimum_category<T1,T2>
|
|
||||||
{};
|
|
||||||
|
|
||||||
BOOST_MPL_AUX_LAMBDA_SUPPORT_SPEC(2,minimum_category,(mpl::_1,mpl::_2))
|
|
||||||
};
|
|
||||||
|
|
||||||
} // namespace iterators
|
|
||||||
|
|
||||||
} // namespace boost
|
|
||||||
|
|
||||||
#endif // BOOST_ITERATOR_MINIMUM_CATEGORY_HPP_INCLUDED_
|
|
@ -29,18 +29,17 @@
|
|||||||
// (David Abrahams)
|
// (David Abrahams)
|
||||||
|
|
||||||
# include <iterator>
|
# include <iterator>
|
||||||
|
# include <boost/type_traits.hpp>
|
||||||
# include <boost/static_assert.hpp>
|
# include <boost/static_assert.hpp>
|
||||||
# include <boost/concept_archetype.hpp> // for detail::dummy_constructor
|
# include <boost/concept_archetype.hpp> // for detail::dummy_constructor
|
||||||
|
# include <boost/detail/iterator.hpp>
|
||||||
# include <boost/pending/iterator_tests.hpp>
|
# include <boost/pending/iterator_tests.hpp>
|
||||||
# include <boost/iterator/is_readable_iterator.hpp>
|
# include <boost/iterator/is_readable_iterator.hpp>
|
||||||
# include <boost/iterator/is_lvalue_iterator.hpp>
|
# include <boost/iterator/is_lvalue_iterator.hpp>
|
||||||
# include <boost/type_traits/is_same.hpp>
|
|
||||||
# include <boost/mpl/bool.hpp>
|
|
||||||
# include <boost/mpl/and.hpp>
|
|
||||||
|
|
||||||
# include <boost/iterator/detail/config_def.hpp>
|
# include <boost/iterator/detail/config_def.hpp>
|
||||||
# include <boost/detail/is_incrementable.hpp>
|
# include <boost/detail/is_incrementable.hpp>
|
||||||
# include <boost/core/lightweight_test.hpp>
|
# include <boost/detail/lightweight_test.hpp>
|
||||||
|
|
||||||
namespace boost {
|
namespace boost {
|
||||||
|
|
||||||
@ -77,7 +76,7 @@ template <class Iterator, class T>
|
|||||||
void readable_iterator_test(const Iterator i1, T v)
|
void readable_iterator_test(const Iterator i1, T v)
|
||||||
{
|
{
|
||||||
Iterator i2(i1); // Copy Constructible
|
Iterator i2(i1); // Copy Constructible
|
||||||
typedef typename std::iterator_traits<Iterator>::reference ref_t;
|
typedef typename detail::iterator_traits<Iterator>::reference ref_t;
|
||||||
ref_t r1 = *i1;
|
ref_t r1 = *i1;
|
||||||
ref_t r2 = *i2;
|
ref_t r2 = *i2;
|
||||||
T v1 = r1;
|
T v1 = r1;
|
||||||
@ -113,9 +112,9 @@ template <class Iterator>
|
|||||||
void swappable_iterator_test(Iterator i, Iterator j)
|
void swappable_iterator_test(Iterator i, Iterator j)
|
||||||
{
|
{
|
||||||
Iterator i2(i), j2(j);
|
Iterator i2(i), j2(j);
|
||||||
typename std::iterator_traits<Iterator>::value_type bi = *i, bj = *j;
|
typename detail::iterator_traits<Iterator>::value_type bi = *i, bj = *j;
|
||||||
iter_swap(i2, j2);
|
iter_swap(i2, j2);
|
||||||
typename std::iterator_traits<Iterator>::value_type ai = *i, aj = *j;
|
typename detail::iterator_traits<Iterator>::value_type ai = *i, aj = *j;
|
||||||
BOOST_TEST(bi == aj && bj == ai);
|
BOOST_TEST(bi == aj && bj == ai);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -123,8 +122,8 @@ template <class Iterator, class T>
|
|||||||
void constant_lvalue_iterator_test(Iterator i, T v1)
|
void constant_lvalue_iterator_test(Iterator i, T v1)
|
||||||
{
|
{
|
||||||
Iterator i2(i);
|
Iterator i2(i);
|
||||||
typedef typename std::iterator_traits<Iterator>::value_type value_type;
|
typedef typename detail::iterator_traits<Iterator>::value_type value_type;
|
||||||
typedef typename std::iterator_traits<Iterator>::reference reference;
|
typedef typename detail::iterator_traits<Iterator>::reference reference;
|
||||||
BOOST_STATIC_ASSERT((is_same<const value_type&, reference>::value));
|
BOOST_STATIC_ASSERT((is_same<const value_type&, reference>::value));
|
||||||
const T& v2 = *i2;
|
const T& v2 = *i2;
|
||||||
BOOST_TEST(v1 == v2);
|
BOOST_TEST(v1 == v2);
|
||||||
@ -138,8 +137,8 @@ template <class Iterator, class T>
|
|||||||
void non_const_lvalue_iterator_test(Iterator i, T v1, T v2)
|
void non_const_lvalue_iterator_test(Iterator i, T v1, T v2)
|
||||||
{
|
{
|
||||||
Iterator i2(i);
|
Iterator i2(i);
|
||||||
typedef typename std::iterator_traits<Iterator>::value_type value_type;
|
typedef typename detail::iterator_traits<Iterator>::value_type value_type;
|
||||||
typedef typename std::iterator_traits<Iterator>::reference reference;
|
typedef typename detail::iterator_traits<Iterator>::reference reference;
|
||||||
BOOST_STATIC_ASSERT((is_same<value_type&, reference>::value));
|
BOOST_STATIC_ASSERT((is_same<value_type&, reference>::value));
|
||||||
T& v3 = *i2;
|
T& v3 = *i2;
|
||||||
BOOST_TEST(v1 == v3);
|
BOOST_TEST(v1 == v3);
|
||||||
@ -230,7 +229,7 @@ void random_access_readable_iterator_test(Iterator i, int N, TrueVals vals)
|
|||||||
{
|
{
|
||||||
BOOST_TEST(i == j + c);
|
BOOST_TEST(i == j + c);
|
||||||
BOOST_TEST(*i == vals[c]);
|
BOOST_TEST(*i == vals[c]);
|
||||||
typename std::iterator_traits<Iterator>::value_type x = j[c];
|
typename detail::iterator_traits<Iterator>::value_type x = j[c];
|
||||||
BOOST_TEST(*i == x);
|
BOOST_TEST(*i == x);
|
||||||
BOOST_TEST(*i == *(j + c));
|
BOOST_TEST(*i == *(j + c));
|
||||||
BOOST_TEST(*i == *(c + j));
|
BOOST_TEST(*i == *(c + j));
|
||||||
@ -246,7 +245,7 @@ void random_access_readable_iterator_test(Iterator i, int N, TrueVals vals)
|
|||||||
{
|
{
|
||||||
BOOST_TEST(i == k - c);
|
BOOST_TEST(i == k - c);
|
||||||
BOOST_TEST(*i == vals[N - 1 - c]);
|
BOOST_TEST(*i == vals[N - 1 - c]);
|
||||||
typename std::iterator_traits<Iterator>::value_type x = j[N - 1 - c];
|
typename detail::iterator_traits<Iterator>::value_type x = j[N - 1 - c];
|
||||||
BOOST_TEST(*i == x);
|
BOOST_TEST(*i == x);
|
||||||
Iterator q = k - c;
|
Iterator q = k - c;
|
||||||
BOOST_TEST(*i == *q);
|
BOOST_TEST(*i == *q);
|
||||||
|
@ -13,21 +13,21 @@
|
|||||||
#include <boost/iterator/iterator_adaptor.hpp>
|
#include <boost/iterator/iterator_adaptor.hpp>
|
||||||
|
|
||||||
|
|
||||||
namespace boost {
|
namespace boost
|
||||||
namespace iterators {
|
{
|
||||||
|
|
||||||
template< class ElementIterator
|
template< class ElementIterator
|
||||||
, class IndexIterator>
|
, class IndexIterator>
|
||||||
class permutation_iterator
|
class permutation_iterator
|
||||||
: public iterator_adaptor<
|
: public iterator_adaptor<
|
||||||
permutation_iterator<ElementIterator, IndexIterator>
|
permutation_iterator<ElementIterator, IndexIterator>
|
||||||
, IndexIterator, typename std::iterator_traits<ElementIterator>::value_type
|
, IndexIterator, typename detail::iterator_traits<ElementIterator>::value_type
|
||||||
, use_default, typename std::iterator_traits<ElementIterator>::reference>
|
, use_default, typename detail::iterator_traits<ElementIterator>::reference>
|
||||||
{
|
{
|
||||||
typedef iterator_adaptor<
|
typedef iterator_adaptor<
|
||||||
permutation_iterator<ElementIterator, IndexIterator>
|
permutation_iterator<ElementIterator, IndexIterator>
|
||||||
, IndexIterator, typename std::iterator_traits<ElementIterator>::value_type
|
, IndexIterator, typename detail::iterator_traits<ElementIterator>::value_type
|
||||||
, use_default, typename std::iterator_traits<ElementIterator>::reference> super_t;
|
, use_default, typename detail::iterator_traits<ElementIterator>::reference> super_t;
|
||||||
|
|
||||||
friend class iterator_core_access;
|
friend class iterator_core_access;
|
||||||
|
|
||||||
@ -60,16 +60,12 @@ private:
|
|||||||
|
|
||||||
|
|
||||||
template <class ElementIterator, class IndexIterator>
|
template <class ElementIterator, class IndexIterator>
|
||||||
inline permutation_iterator<ElementIterator, IndexIterator>
|
permutation_iterator<ElementIterator, IndexIterator>
|
||||||
make_permutation_iterator( ElementIterator e, IndexIterator i )
|
make_permutation_iterator( ElementIterator e, IndexIterator i )
|
||||||
{
|
{
|
||||||
return permutation_iterator<ElementIterator, IndexIterator>( e, i );
|
return permutation_iterator<ElementIterator, IndexIterator>( e, i );
|
||||||
}
|
}
|
||||||
|
|
||||||
} // namespace iterators
|
|
||||||
|
|
||||||
using iterators::permutation_iterator;
|
|
||||||
using iterators::make_permutation_iterator;
|
|
||||||
|
|
||||||
} // namespace boost
|
} // namespace boost
|
||||||
|
|
||||||
|
@ -7,10 +7,12 @@
|
|||||||
#ifndef BOOST_REVERSE_ITERATOR_23022003THW_HPP
|
#ifndef BOOST_REVERSE_ITERATOR_23022003THW_HPP
|
||||||
#define BOOST_REVERSE_ITERATOR_23022003THW_HPP
|
#define BOOST_REVERSE_ITERATOR_23022003THW_HPP
|
||||||
|
|
||||||
|
#include <boost/iterator.hpp>
|
||||||
|
#include <boost/utility.hpp>
|
||||||
#include <boost/iterator/iterator_adaptor.hpp>
|
#include <boost/iterator/iterator_adaptor.hpp>
|
||||||
|
|
||||||
namespace boost {
|
namespace boost
|
||||||
namespace iterators {
|
{
|
||||||
|
|
||||||
//
|
//
|
||||||
//
|
//
|
||||||
@ -38,19 +40,14 @@ namespace iterators {
|
|||||||
{}
|
{}
|
||||||
|
|
||||||
private:
|
private:
|
||||||
typename super_t::reference dereference() const
|
typename super_t::reference dereference() const { return *boost::prior(this->base()); }
|
||||||
{
|
|
||||||
Iterator it = this->base_reference();
|
|
||||||
--it;
|
|
||||||
return *it;
|
|
||||||
}
|
|
||||||
|
|
||||||
void increment() { --this->base_reference(); }
|
void increment() { --this->base_reference(); }
|
||||||
void decrement() { ++this->base_reference(); }
|
void decrement() { ++this->base_reference(); }
|
||||||
|
|
||||||
void advance(typename super_t::difference_type n)
|
void advance(typename super_t::difference_type n)
|
||||||
{
|
{
|
||||||
this->base_reference() -= n;
|
this->base_reference() += -n;
|
||||||
}
|
}
|
||||||
|
|
||||||
template <class OtherIterator>
|
template <class OtherIterator>
|
||||||
@ -62,16 +59,11 @@ namespace iterators {
|
|||||||
};
|
};
|
||||||
|
|
||||||
template <class BidirectionalIterator>
|
template <class BidirectionalIterator>
|
||||||
inline reverse_iterator<BidirectionalIterator> make_reverse_iterator(BidirectionalIterator x)
|
reverse_iterator<BidirectionalIterator> make_reverse_iterator(BidirectionalIterator x)
|
||||||
{
|
{
|
||||||
return reverse_iterator<BidirectionalIterator>(x);
|
return reverse_iterator<BidirectionalIterator>(x);
|
||||||
}
|
}
|
||||||
|
|
||||||
} // namespace iterators
|
|
||||||
|
|
||||||
using iterators::reverse_iterator;
|
|
||||||
using iterators::make_reverse_iterator;
|
|
||||||
|
|
||||||
} // namespace boost
|
} // namespace boost
|
||||||
|
|
||||||
#endif // BOOST_REVERSE_ITERATOR_23022003THW_HPP
|
#endif // BOOST_REVERSE_ITERATOR_23022003THW_HPP
|
||||||
|
@ -7,11 +7,12 @@
|
|||||||
#ifndef BOOST_TRANSFORM_ITERATOR_23022003THW_HPP
|
#ifndef BOOST_TRANSFORM_ITERATOR_23022003THW_HPP
|
||||||
#define BOOST_TRANSFORM_ITERATOR_23022003THW_HPP
|
#define BOOST_TRANSFORM_ITERATOR_23022003THW_HPP
|
||||||
|
|
||||||
#include <boost/config.hpp>
|
#include <boost/iterator.hpp>
|
||||||
#include <boost/config/workaround.hpp>
|
|
||||||
#include <boost/iterator/detail/enable_if.hpp>
|
#include <boost/iterator/detail/enable_if.hpp>
|
||||||
#include <boost/iterator/iterator_adaptor.hpp>
|
#include <boost/iterator/iterator_adaptor.hpp>
|
||||||
#include <boost/iterator/iterator_categories.hpp>
|
#include <boost/iterator/iterator_categories.hpp>
|
||||||
|
#include <boost/mpl/not.hpp>
|
||||||
|
#include <boost/mpl/bool.hpp>
|
||||||
#include <boost/type_traits/function_traits.hpp>
|
#include <boost/type_traits/function_traits.hpp>
|
||||||
#include <boost/type_traits/is_const.hpp>
|
#include <boost/type_traits/is_const.hpp>
|
||||||
#include <boost/type_traits/is_class.hpp>
|
#include <boost/type_traits/is_class.hpp>
|
||||||
@ -21,22 +22,16 @@
|
|||||||
#include <boost/type_traits/remove_reference.hpp>
|
#include <boost/type_traits/remove_reference.hpp>
|
||||||
#include <boost/utility/result_of.hpp>
|
#include <boost/utility/result_of.hpp>
|
||||||
|
|
||||||
#include <iterator>
|
|
||||||
|
|
||||||
#if BOOST_WORKAROUND(BOOST_MSVC, BOOST_TESTED_AT(1310))
|
#if BOOST_WORKAROUND(BOOST_MSVC, BOOST_TESTED_AT(1310))
|
||||||
# include <boost/type_traits/is_base_and_derived.hpp>
|
# include <boost/type_traits/is_base_and_derived.hpp>
|
||||||
#endif
|
|
||||||
|
|
||||||
#if !BOOST_WORKAROUND(__MWERKS__, BOOST_TESTED_AT(0x3003))
|
|
||||||
#include <boost/static_assert.hpp>
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#include <boost/iterator/detail/config_def.hpp>
|
#include <boost/iterator/detail/config_def.hpp>
|
||||||
|
|
||||||
|
|
||||||
namespace boost {
|
namespace boost
|
||||||
namespace iterators {
|
{
|
||||||
|
|
||||||
template <class UnaryFunction, class Iterator, class Reference = use_default, class Value = use_default>
|
template <class UnaryFunction, class Iterator, class Reference = use_default, class Value = use_default>
|
||||||
class transform_iterator;
|
class transform_iterator;
|
||||||
|
|
||||||
@ -47,15 +42,13 @@ namespace iterators {
|
|||||||
struct transform_iterator_base
|
struct transform_iterator_base
|
||||||
{
|
{
|
||||||
private:
|
private:
|
||||||
|
typedef typename std::iterator_traits<Iterator>::reference Arg1;
|
||||||
|
|
||||||
// By default, dereferencing the iterator yields the same as
|
// By default, dereferencing the iterator yields the same as
|
||||||
// the function.
|
// the function.
|
||||||
typedef typename ia_dflt_help<
|
typedef typename ia_dflt_help<
|
||||||
Reference
|
Reference
|
||||||
#ifdef BOOST_RESULT_OF_USE_TR1
|
, result_of<UnaryFunc(typename std::iterator_traits<Iterator>::value_type)>
|
||||||
, result_of<const UnaryFunc(typename std::iterator_traits<Iterator>::reference)>
|
|
||||||
#else
|
|
||||||
, result_of<const UnaryFunc&(typename std::iterator_traits<Iterator>::reference)>
|
|
||||||
#endif
|
|
||||||
>::type reference;
|
>::type reference;
|
||||||
|
|
||||||
// To get the default for Value: remove any reference on the
|
// To get the default for Value: remove any reference on the
|
||||||
@ -81,10 +74,10 @@ namespace iterators {
|
|||||||
|
|
||||||
template <class UnaryFunc, class Iterator, class Reference, class Value>
|
template <class UnaryFunc, class Iterator, class Reference, class Value>
|
||||||
class transform_iterator
|
class transform_iterator
|
||||||
: public boost::iterators::detail::transform_iterator_base<UnaryFunc, Iterator, Reference, Value>::type
|
: public boost::detail::transform_iterator_base<UnaryFunc, Iterator, Reference, Value>::type
|
||||||
{
|
{
|
||||||
typedef typename
|
typedef typename
|
||||||
boost::iterators::detail::transform_iterator_base<UnaryFunc, Iterator, Reference, Value>::type
|
boost::detail::transform_iterator_base<UnaryFunc, Iterator, Reference, Value>::type
|
||||||
super_t;
|
super_t;
|
||||||
|
|
||||||
friend class iterator_core_access;
|
friend class iterator_core_access;
|
||||||
@ -135,7 +128,7 @@ namespace iterators {
|
|||||||
};
|
};
|
||||||
|
|
||||||
template <class UnaryFunc, class Iterator>
|
template <class UnaryFunc, class Iterator>
|
||||||
inline transform_iterator<UnaryFunc, Iterator>
|
transform_iterator<UnaryFunc, Iterator>
|
||||||
make_transform_iterator(Iterator it, UnaryFunc fun)
|
make_transform_iterator(Iterator it, UnaryFunc fun)
|
||||||
{
|
{
|
||||||
return transform_iterator<UnaryFunc, Iterator>(it, fun);
|
return transform_iterator<UnaryFunc, Iterator>(it, fun);
|
||||||
@ -149,9 +142,16 @@ namespace iterators {
|
|||||||
// function pointer in the iterator be 0, leading to a runtime
|
// function pointer in the iterator be 0, leading to a runtime
|
||||||
// crash.
|
// crash.
|
||||||
template <class UnaryFunc, class Iterator>
|
template <class UnaryFunc, class Iterator>
|
||||||
inline typename iterators::enable_if<
|
#if BOOST_WORKAROUND(BOOST_MSVC, <= 1300)
|
||||||
|
typename mpl::if_<
|
||||||
|
#else
|
||||||
|
typename iterators::enable_if<
|
||||||
|
#endif
|
||||||
is_class<UnaryFunc> // We should probably find a cheaper test than is_class<>
|
is_class<UnaryFunc> // We should probably find a cheaper test than is_class<>
|
||||||
, transform_iterator<UnaryFunc, Iterator>
|
, transform_iterator<UnaryFunc, Iterator>
|
||||||
|
#if BOOST_WORKAROUND(BOOST_MSVC, <= 1300)
|
||||||
|
, int[3]
|
||||||
|
#endif
|
||||||
>::type
|
>::type
|
||||||
make_transform_iterator(Iterator it)
|
make_transform_iterator(Iterator it)
|
||||||
{
|
{
|
||||||
@ -160,18 +160,13 @@ namespace iterators {
|
|||||||
|
|
||||||
#if defined(BOOST_NO_TEMPLATE_PARTIAL_SPECIALIZATION ) && !defined(BOOST_NO_FUNCTION_TEMPLATE_ORDERING)
|
#if defined(BOOST_NO_TEMPLATE_PARTIAL_SPECIALIZATION ) && !defined(BOOST_NO_FUNCTION_TEMPLATE_ORDERING)
|
||||||
template <class Return, class Argument, class Iterator>
|
template <class Return, class Argument, class Iterator>
|
||||||
inline transform_iterator< Return (*)(Argument), Iterator, Return>
|
transform_iterator< Return (*)(Argument), Iterator, Return>
|
||||||
make_transform_iterator(Iterator it, Return (*fun)(Argument))
|
make_transform_iterator(Iterator it, Return (*fun)(Argument))
|
||||||
{
|
{
|
||||||
return transform_iterator<Return (*)(Argument), Iterator, Return>(it, fun);
|
return transform_iterator<Return (*)(Argument), Iterator, Return>(it, fun);
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
} // namespace iterators
|
|
||||||
|
|
||||||
using iterators::transform_iterator;
|
|
||||||
using iterators::make_transform_iterator;
|
|
||||||
|
|
||||||
} // namespace boost
|
} // namespace boost
|
||||||
|
|
||||||
#include <boost/iterator/detail/config_undef.hpp>
|
#include <boost/iterator/detail/config_undef.hpp>
|
||||||
|
@ -1,46 +1,55 @@
|
|||||||
// Copyright David Abrahams and Thomas Becker 2000-2006.
|
// Copyright David Abrahams and Thomas Becker 2000-2006. Distributed
|
||||||
// Copyright Kohei Takahashi 2012-2014.
|
// under the Boost Software License, Version 1.0. (See accompanying
|
||||||
//
|
// file LICENSE_1_0.txt or copy at
|
||||||
// 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)
|
// http://www.boost.org/LICENSE_1_0.txt)
|
||||||
|
|
||||||
#ifndef BOOST_ZIP_ITERATOR_TMB_07_13_2003_HPP_
|
#ifndef BOOST_ZIP_ITERATOR_TMB_07_13_2003_HPP_
|
||||||
# define BOOST_ZIP_ITERATOR_TMB_07_13_2003_HPP_
|
# define BOOST_ZIP_ITERATOR_TMB_07_13_2003_HPP_
|
||||||
|
|
||||||
#include <stddef.h>
|
#include <stddef.h>
|
||||||
|
#include <boost/iterator.hpp>
|
||||||
#include <boost/iterator/iterator_traits.hpp>
|
#include <boost/iterator/iterator_traits.hpp>
|
||||||
#include <boost/iterator/iterator_facade.hpp>
|
#include <boost/iterator/iterator_facade.hpp>
|
||||||
#include <boost/iterator/iterator_adaptor.hpp> // for enable_if_convertible
|
#include <boost/iterator/iterator_adaptor.hpp> // for enable_if_convertible
|
||||||
#include <boost/iterator/iterator_categories.hpp>
|
#include <boost/iterator/iterator_categories.hpp>
|
||||||
|
#include <boost/detail/iterator.hpp>
|
||||||
|
|
||||||
#include <boost/iterator/minimum_category.hpp>
|
#include <boost/iterator/detail/minimum_category.hpp>
|
||||||
|
|
||||||
#include <utility> // for std::pair
|
#include <boost/tuple/tuple.hpp>
|
||||||
#include <boost/fusion/adapted/boost_tuple.hpp> // for backward compatibility
|
|
||||||
|
|
||||||
#include <boost/type_traits/remove_reference.hpp>
|
#include <boost/type_traits/is_same.hpp>
|
||||||
#include <boost/type_traits/remove_cv.hpp>
|
#include <boost/mpl/and.hpp>
|
||||||
|
#include <boost/mpl/apply.hpp>
|
||||||
#include <boost/mpl/at.hpp>
|
#include <boost/mpl/eval_if.hpp>
|
||||||
#include <boost/mpl/fold.hpp>
|
#include <boost/mpl/lambda.hpp>
|
||||||
#include <boost/mpl/transform.hpp>
|
|
||||||
#include <boost/mpl/placeholders.hpp>
|
#include <boost/mpl/placeholders.hpp>
|
||||||
|
#include <boost/mpl/aux_/lambda_support.hpp>
|
||||||
#include <boost/fusion/algorithm/iteration/for_each.hpp>
|
|
||||||
#include <boost/fusion/algorithm/transformation/transform.hpp>
|
|
||||||
#include <boost/fusion/sequence/convert.hpp>
|
|
||||||
#include <boost/fusion/sequence/intrinsic/at_c.hpp>
|
|
||||||
#include <boost/fusion/sequence/comparison/equal_to.hpp>
|
|
||||||
#include <boost/fusion/support/tag_of_fwd.hpp>
|
|
||||||
|
|
||||||
namespace boost {
|
namespace boost {
|
||||||
namespace iterators {
|
|
||||||
|
|
||||||
// Zip iterator forward declaration for zip_iterator_base
|
// Zip iterator forward declaration for zip_iterator_base
|
||||||
template<typename IteratorTuple>
|
template<typename IteratorTuple>
|
||||||
class zip_iterator;
|
class zip_iterator;
|
||||||
|
|
||||||
|
// One important design goal of the zip_iterator is to isolate all
|
||||||
|
// functionality whose implementation relies on the current tuple
|
||||||
|
// implementation. This goal has been achieved as follows: Inside
|
||||||
|
// the namespace detail there is a namespace tuple_impl_specific.
|
||||||
|
// This namespace encapsulates all functionality that is specific
|
||||||
|
// to the current Boost tuple implementation. More precisely, the
|
||||||
|
// namespace tuple_impl_specific provides the following tuple
|
||||||
|
// algorithms and meta-algorithms for the current Boost tuple
|
||||||
|
// implementation:
|
||||||
|
//
|
||||||
|
// tuple_meta_transform
|
||||||
|
// tuple_meta_accumulate
|
||||||
|
// tuple_transform
|
||||||
|
// tuple_for_each
|
||||||
|
//
|
||||||
|
// If the tuple implementation changes, all that needs to be
|
||||||
|
// replaced is the implementation of these four (meta-)algorithms.
|
||||||
|
|
||||||
namespace detail
|
namespace detail
|
||||||
{
|
{
|
||||||
|
|
||||||
@ -63,97 +72,332 @@ namespace iterators {
|
|||||||
struct increment_iterator
|
struct increment_iterator
|
||||||
{
|
{
|
||||||
template<typename Iterator>
|
template<typename Iterator>
|
||||||
void operator()(Iterator& it) const
|
void operator()(Iterator& it)
|
||||||
{ ++it; }
|
{ ++it; }
|
||||||
};
|
};
|
||||||
//
|
//
|
||||||
struct decrement_iterator
|
struct decrement_iterator
|
||||||
{
|
{
|
||||||
template<typename Iterator>
|
template<typename Iterator>
|
||||||
void operator()(Iterator& it) const
|
void operator()(Iterator& it)
|
||||||
{ --it; }
|
{ --it; }
|
||||||
};
|
};
|
||||||
//
|
//
|
||||||
struct dereference_iterator
|
struct dereference_iterator
|
||||||
{
|
{
|
||||||
template<typename>
|
template<typename Iterator>
|
||||||
struct result;
|
struct apply
|
||||||
|
|
||||||
template<typename This, typename Iterator>
|
|
||||||
struct result<This(Iterator)>
|
|
||||||
{
|
{
|
||||||
typedef typename
|
typedef typename
|
||||||
remove_cv<typename remove_reference<Iterator>::type>::type
|
iterator_traits<Iterator>::reference
|
||||||
iterator;
|
type;
|
||||||
|
|
||||||
typedef typename iterator_reference<iterator>::type type;
|
|
||||||
};
|
};
|
||||||
|
|
||||||
template<typename Iterator>
|
template<typename Iterator>
|
||||||
typename result<dereference_iterator(Iterator)>::type
|
typename apply<Iterator>::type operator()(Iterator const& it)
|
||||||
operator()(Iterator const& it) const
|
|
||||||
{ return *it; }
|
{ return *it; }
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
|
// The namespace tuple_impl_specific provides two meta-
|
||||||
|
// algorithms and two algorithms for tuples.
|
||||||
|
//
|
||||||
|
namespace tuple_impl_specific
|
||||||
|
{
|
||||||
|
// Meta-transform algorithm for tuples
|
||||||
|
//
|
||||||
|
template<typename Tuple, class UnaryMetaFun>
|
||||||
|
struct tuple_meta_transform;
|
||||||
|
|
||||||
|
template<typename Tuple, class UnaryMetaFun>
|
||||||
|
struct tuple_meta_transform_impl
|
||||||
|
{
|
||||||
|
typedef tuples::cons<
|
||||||
|
typename mpl::apply1<
|
||||||
|
typename mpl::lambda<UnaryMetaFun>::type
|
||||||
|
, typename Tuple::head_type
|
||||||
|
>::type
|
||||||
|
, typename tuple_meta_transform<
|
||||||
|
typename Tuple::tail_type
|
||||||
|
, UnaryMetaFun
|
||||||
|
>::type
|
||||||
|
> type;
|
||||||
|
};
|
||||||
|
|
||||||
|
template<typename Tuple, class UnaryMetaFun>
|
||||||
|
struct tuple_meta_transform
|
||||||
|
: mpl::eval_if<
|
||||||
|
boost::is_same<Tuple, tuples::null_type>
|
||||||
|
, mpl::identity<tuples::null_type>
|
||||||
|
, tuple_meta_transform_impl<Tuple, UnaryMetaFun>
|
||||||
|
>
|
||||||
|
{
|
||||||
|
};
|
||||||
|
|
||||||
|
// Meta-accumulate algorithm for tuples. Note: The template
|
||||||
|
// parameter StartType corresponds to the initial value in
|
||||||
|
// ordinary accumulation.
|
||||||
|
//
|
||||||
|
template<class Tuple, class BinaryMetaFun, class StartType>
|
||||||
|
struct tuple_meta_accumulate;
|
||||||
|
|
||||||
|
template<
|
||||||
|
typename Tuple
|
||||||
|
, class BinaryMetaFun
|
||||||
|
, typename StartType
|
||||||
|
>
|
||||||
|
struct tuple_meta_accumulate_impl
|
||||||
|
{
|
||||||
|
typedef typename mpl::apply2<
|
||||||
|
typename mpl::lambda<BinaryMetaFun>::type
|
||||||
|
, typename Tuple::head_type
|
||||||
|
, typename tuple_meta_accumulate<
|
||||||
|
typename Tuple::tail_type
|
||||||
|
, BinaryMetaFun
|
||||||
|
, StartType
|
||||||
|
>::type
|
||||||
|
>::type type;
|
||||||
|
};
|
||||||
|
|
||||||
|
template<
|
||||||
|
typename Tuple
|
||||||
|
, class BinaryMetaFun
|
||||||
|
, typename StartType
|
||||||
|
>
|
||||||
|
struct tuple_meta_accumulate
|
||||||
|
: mpl::eval_if<
|
||||||
|
#if BOOST_WORKAROUND(BOOST_MSVC, < 1300)
|
||||||
|
mpl::or_<
|
||||||
|
#endif
|
||||||
|
boost::is_same<Tuple, tuples::null_type>
|
||||||
|
#if BOOST_WORKAROUND(BOOST_MSVC, < 1300)
|
||||||
|
, boost::is_same<Tuple,int>
|
||||||
|
>
|
||||||
|
#endif
|
||||||
|
, mpl::identity<StartType>
|
||||||
|
, tuple_meta_accumulate_impl<
|
||||||
|
Tuple
|
||||||
|
, BinaryMetaFun
|
||||||
|
, StartType
|
||||||
|
>
|
||||||
|
>
|
||||||
|
{
|
||||||
|
};
|
||||||
|
|
||||||
|
#if defined(BOOST_NO_FUNCTION_TEMPLATE_ORDERING) \
|
||||||
|
|| ( \
|
||||||
|
BOOST_WORKAROUND(BOOST_INTEL_CXX_VERSION, != 0) && defined(_MSC_VER) \
|
||||||
|
)
|
||||||
|
// Not sure why intel's partial ordering fails in this case, but I'm
|
||||||
|
// assuming int's an MSVC bug-compatibility feature.
|
||||||
|
|
||||||
|
# define BOOST_TUPLE_ALGO_DISPATCH
|
||||||
|
# define BOOST_TUPLE_ALGO(algo) algo##_impl
|
||||||
|
# define BOOST_TUPLE_ALGO_TERMINATOR , int
|
||||||
|
# define BOOST_TUPLE_ALGO_RECURSE , ...
|
||||||
|
#else
|
||||||
|
# define BOOST_TUPLE_ALGO(algo) algo
|
||||||
|
# define BOOST_TUPLE_ALGO_TERMINATOR
|
||||||
|
# define BOOST_TUPLE_ALGO_RECURSE
|
||||||
|
#endif
|
||||||
|
|
||||||
|
// transform algorithm for tuples. The template parameter Fun
|
||||||
|
// must be a unary functor which is also a unary metafunction
|
||||||
|
// class that computes its return type based on its argument
|
||||||
|
// type. For example:
|
||||||
|
//
|
||||||
|
// struct to_ptr
|
||||||
|
// {
|
||||||
|
// template <class Arg>
|
||||||
|
// struct apply
|
||||||
|
// {
|
||||||
|
// typedef Arg* type;
|
||||||
|
// }
|
||||||
|
//
|
||||||
|
// template <class Arg>
|
||||||
|
// Arg* operator()(Arg x);
|
||||||
|
// };
|
||||||
|
template<typename Fun>
|
||||||
|
tuples::null_type BOOST_TUPLE_ALGO(tuple_transform)
|
||||||
|
(tuples::null_type const&, Fun BOOST_TUPLE_ALGO_TERMINATOR)
|
||||||
|
{ return tuples::null_type(); }
|
||||||
|
|
||||||
|
template<typename Tuple, typename Fun>
|
||||||
|
typename tuple_meta_transform<
|
||||||
|
Tuple
|
||||||
|
, Fun
|
||||||
|
>::type
|
||||||
|
|
||||||
|
BOOST_TUPLE_ALGO(tuple_transform)(
|
||||||
|
const Tuple& t,
|
||||||
|
Fun f
|
||||||
|
BOOST_TUPLE_ALGO_RECURSE
|
||||||
|
)
|
||||||
|
{
|
||||||
|
typedef typename tuple_meta_transform<
|
||||||
|
BOOST_DEDUCED_TYPENAME Tuple::tail_type
|
||||||
|
, Fun
|
||||||
|
>::type transformed_tail_type;
|
||||||
|
|
||||||
|
return tuples::cons<
|
||||||
|
BOOST_DEDUCED_TYPENAME mpl::apply1<
|
||||||
|
Fun, BOOST_DEDUCED_TYPENAME Tuple::head_type
|
||||||
|
>::type
|
||||||
|
, transformed_tail_type
|
||||||
|
>(
|
||||||
|
f(boost::tuples::get<0>(t)), tuple_transform(t.get_tail(), f)
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
#ifdef BOOST_TUPLE_ALGO_DISPATCH
|
||||||
|
template<typename Tuple, typename Fun>
|
||||||
|
typename tuple_meta_transform<
|
||||||
|
Tuple
|
||||||
|
, Fun
|
||||||
|
>::type
|
||||||
|
|
||||||
|
tuple_transform(
|
||||||
|
const Tuple& t,
|
||||||
|
Fun f
|
||||||
|
)
|
||||||
|
{
|
||||||
|
return tuple_transform_impl(t, f, 1);
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
// for_each algorithm for tuples.
|
||||||
|
//
|
||||||
|
template<typename Fun>
|
||||||
|
Fun BOOST_TUPLE_ALGO(tuple_for_each)(
|
||||||
|
tuples::null_type
|
||||||
|
, Fun f BOOST_TUPLE_ALGO_TERMINATOR
|
||||||
|
)
|
||||||
|
{ return f; }
|
||||||
|
|
||||||
|
|
||||||
|
template<typename Tuple, typename Fun>
|
||||||
|
Fun BOOST_TUPLE_ALGO(tuple_for_each)(
|
||||||
|
Tuple& t
|
||||||
|
, Fun f BOOST_TUPLE_ALGO_RECURSE)
|
||||||
|
{
|
||||||
|
f( t.get_head() );
|
||||||
|
return tuple_for_each(t.get_tail(), f);
|
||||||
|
}
|
||||||
|
|
||||||
|
#ifdef BOOST_TUPLE_ALGO_DISPATCH
|
||||||
|
template<typename Tuple, typename Fun>
|
||||||
|
Fun
|
||||||
|
tuple_for_each(
|
||||||
|
Tuple& t,
|
||||||
|
Fun f
|
||||||
|
)
|
||||||
|
{
|
||||||
|
return tuple_for_each_impl(t, f, 1);
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
// Equality of tuples. NOTE: "==" for tuples currently (7/2003)
|
||||||
|
// has problems under some compilers, so I just do my own.
|
||||||
|
// No point in bringing in a bunch of #ifdefs here. This is
|
||||||
|
// going to go away with the next tuple implementation anyway.
|
||||||
|
//
|
||||||
|
inline bool tuple_equal(tuples::null_type, tuples::null_type)
|
||||||
|
{ return true; }
|
||||||
|
|
||||||
|
template<typename Tuple1, typename Tuple2>
|
||||||
|
bool tuple_equal(
|
||||||
|
Tuple1 const& t1,
|
||||||
|
Tuple2 const& t2
|
||||||
|
)
|
||||||
|
{
|
||||||
|
return t1.get_head() == t2.get_head() &&
|
||||||
|
tuple_equal(t1.get_tail(), t2.get_tail());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
//
|
||||||
|
// end namespace tuple_impl_specific
|
||||||
|
|
||||||
|
template<typename Iterator>
|
||||||
|
struct iterator_reference
|
||||||
|
{
|
||||||
|
typedef typename iterator_traits<Iterator>::reference type;
|
||||||
|
};
|
||||||
|
|
||||||
|
#ifdef BOOST_MPL_CFG_NO_FULL_LAMBDA_SUPPORT
|
||||||
|
// Hack because BOOST_MPL_AUX_LAMBDA_SUPPORT doesn't seem to work
|
||||||
|
// out well. Instantiating the nested apply template also
|
||||||
|
// requires instantiating iterator_traits on the
|
||||||
|
// placeholder. Instead we just specialize it as a metafunction
|
||||||
|
// class.
|
||||||
|
template<>
|
||||||
|
struct iterator_reference<mpl::_1>
|
||||||
|
{
|
||||||
|
template <class T>
|
||||||
|
struct apply : iterator_reference<T> {};
|
||||||
|
};
|
||||||
|
#endif
|
||||||
|
|
||||||
// Metafunction to obtain the type of the tuple whose element types
|
// Metafunction to obtain the type of the tuple whose element types
|
||||||
// are the reference types of an iterator tuple.
|
// are the reference types of an iterator tuple.
|
||||||
//
|
//
|
||||||
template<typename IteratorTuple>
|
template<typename IteratorTuple>
|
||||||
struct tuple_of_references
|
struct tuple_of_references
|
||||||
: mpl::transform<
|
: tuple_impl_specific::tuple_meta_transform<
|
||||||
IteratorTuple,
|
IteratorTuple,
|
||||||
iterator_reference<mpl::_1>
|
iterator_reference<mpl::_1>
|
||||||
>
|
>
|
||||||
{
|
{
|
||||||
};
|
};
|
||||||
|
|
||||||
// Specialization for std::pair
|
|
||||||
template<typename Iterator1, typename Iterator2>
|
|
||||||
struct tuple_of_references<std::pair<Iterator1, Iterator2> >
|
|
||||||
{
|
|
||||||
typedef std::pair<
|
|
||||||
typename iterator_reference<Iterator1>::type
|
|
||||||
, typename iterator_reference<Iterator2>::type
|
|
||||||
> type;
|
|
||||||
};
|
|
||||||
|
|
||||||
// Metafunction to obtain the minimal traversal tag in a tuple
|
// Metafunction to obtain the minimal traversal tag in a tuple
|
||||||
// of iterators.
|
// of iterators.
|
||||||
//
|
//
|
||||||
template<typename IteratorTuple>
|
template<typename IteratorTuple>
|
||||||
struct minimum_traversal_category_in_iterator_tuple
|
struct minimum_traversal_category_in_iterator_tuple
|
||||||
{
|
{
|
||||||
typedef typename mpl::transform<
|
typedef typename tuple_impl_specific::tuple_meta_transform<
|
||||||
IteratorTuple
|
IteratorTuple
|
||||||
, pure_traversal_tag<iterator_traversal<> >
|
, pure_traversal_tag<iterator_traversal<> >
|
||||||
>::type tuple_of_traversal_tags;
|
>::type tuple_of_traversal_tags;
|
||||||
|
|
||||||
typedef typename mpl::fold<
|
typedef typename tuple_impl_specific::tuple_meta_accumulate<
|
||||||
tuple_of_traversal_tags
|
tuple_of_traversal_tags
|
||||||
, random_access_traversal_tag
|
|
||||||
, minimum_category<>
|
, minimum_category<>
|
||||||
>::type type;
|
|
||||||
};
|
|
||||||
|
|
||||||
template<typename Iterator1, typename Iterator2>
|
|
||||||
struct minimum_traversal_category_in_iterator_tuple<std::pair<Iterator1, Iterator2> >
|
|
||||||
{
|
|
||||||
typedef typename pure_traversal_tag<
|
|
||||||
typename iterator_traversal<Iterator1>::type
|
|
||||||
>::type iterator1_traversal;
|
|
||||||
typedef typename pure_traversal_tag<
|
|
||||||
typename iterator_traversal<Iterator2>::type
|
|
||||||
>::type iterator2_traversal;
|
|
||||||
|
|
||||||
typedef typename minimum_category<
|
|
||||||
iterator1_traversal
|
|
||||||
, typename minimum_category<
|
|
||||||
iterator2_traversal
|
|
||||||
, random_access_traversal_tag
|
, random_access_traversal_tag
|
||||||
>::type
|
|
||||||
>::type type;
|
>::type type;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
#if BOOST_WORKAROUND(BOOST_MSVC, < 1300) // ETI workaround
|
||||||
|
template <>
|
||||||
|
struct minimum_traversal_category_in_iterator_tuple<int>
|
||||||
|
{
|
||||||
|
typedef int type;
|
||||||
|
};
|
||||||
|
#endif
|
||||||
|
|
||||||
|
// We need to call tuple_meta_accumulate with mpl::and_ as the
|
||||||
|
// accumulating functor. To this end, we need to wrap it into
|
||||||
|
// a struct that has exactly two arguments (that is, template
|
||||||
|
// parameters) and not five, like mpl::and_ does.
|
||||||
|
//
|
||||||
|
template<typename Arg1, typename Arg2>
|
||||||
|
struct and_with_two_args
|
||||||
|
: mpl::and_<Arg1, Arg2>
|
||||||
|
{
|
||||||
|
};
|
||||||
|
|
||||||
|
# ifdef BOOST_MPL_CFG_NO_FULL_LAMBDA_SUPPORT
|
||||||
|
// Hack because BOOST_MPL_AUX_LAMBDA_SUPPORT doesn't seem to work
|
||||||
|
// out well. In this case I think it's an MPL bug
|
||||||
|
template<>
|
||||||
|
struct and_with_two_args<mpl::_1,mpl::_2>
|
||||||
|
{
|
||||||
|
template <class A1, class A2>
|
||||||
|
struct apply : mpl::and_<A1,A2>
|
||||||
|
{};
|
||||||
|
};
|
||||||
|
# endif
|
||||||
|
|
||||||
///////////////////////////////////////////////////////////////////
|
///////////////////////////////////////////////////////////////////
|
||||||
//
|
//
|
||||||
// Class zip_iterator_base
|
// Class zip_iterator_base
|
||||||
@ -174,9 +418,9 @@ namespace iterators {
|
|||||||
typedef reference value_type;
|
typedef reference value_type;
|
||||||
|
|
||||||
// Difference type is the first iterator's difference type
|
// Difference type is the first iterator's difference type
|
||||||
typedef typename iterator_difference<
|
typedef typename iterator_traits<
|
||||||
typename mpl::at_c<IteratorTuple, 0>::type
|
typename tuples::element<0, IteratorTuple>::type
|
||||||
>::type difference_type;
|
>::difference_type difference_type;
|
||||||
|
|
||||||
// Traversal catetgory is the minimum traversal category in the
|
// Traversal catetgory is the minimum traversal category in the
|
||||||
// iterator tuple.
|
// iterator tuple.
|
||||||
@ -202,30 +446,6 @@ namespace iterators {
|
|||||||
{
|
{
|
||||||
typedef int type;
|
typedef int type;
|
||||||
};
|
};
|
||||||
|
|
||||||
template <typename reference>
|
|
||||||
struct converter
|
|
||||||
{
|
|
||||||
template <typename Seq>
|
|
||||||
static reference call(Seq seq)
|
|
||||||
{
|
|
||||||
typedef typename fusion::traits::tag_of<reference>::type tag;
|
|
||||||
return fusion::convert<tag>(seq);
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
template <typename Reference1, typename Reference2>
|
|
||||||
struct converter<std::pair<Reference1, Reference2> >
|
|
||||||
{
|
|
||||||
typedef std::pair<Reference1, Reference2> reference;
|
|
||||||
template <typename Seq>
|
|
||||||
static reference call(Seq seq)
|
|
||||||
{
|
|
||||||
return reference(
|
|
||||||
fusion::at_c<0>(seq)
|
|
||||||
, fusion::at_c<1>(seq));
|
|
||||||
}
|
|
||||||
};
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/////////////////////////////////////////////////////////////////////
|
/////////////////////////////////////////////////////////////////////
|
||||||
@ -281,11 +501,10 @@ namespace iterators {
|
|||||||
// iterators in the iterator tuple.
|
// iterators in the iterator tuple.
|
||||||
typename super_t::reference dereference() const
|
typename super_t::reference dereference() const
|
||||||
{
|
{
|
||||||
typedef typename super_t::reference reference;
|
return detail::tuple_impl_specific::tuple_transform(
|
||||||
typedef detail::converter<reference> gen;
|
|
||||||
return gen::call(fusion::transform(
|
|
||||||
get_iterator_tuple(),
|
get_iterator_tuple(),
|
||||||
detail::dereference_iterator()));
|
detail::dereference_iterator()
|
||||||
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
// Two zip iterators are equal if all iterators in the iterator
|
// Two zip iterators are equal if all iterators in the iterator
|
||||||
@ -301,35 +520,39 @@ namespace iterators {
|
|||||||
template<typename OtherIteratorTuple>
|
template<typename OtherIteratorTuple>
|
||||||
bool equal(const zip_iterator<OtherIteratorTuple>& other) const
|
bool equal(const zip_iterator<OtherIteratorTuple>& other) const
|
||||||
{
|
{
|
||||||
return fusion::equal_to(
|
return detail::tuple_impl_specific::tuple_equal(
|
||||||
get_iterator_tuple(),
|
get_iterator_tuple(),
|
||||||
other.get_iterator_tuple());
|
other.get_iterator_tuple()
|
||||||
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
// Advancing a zip iterator means to advance all iterators in the
|
// Advancing a zip iterator means to advance all iterators in the
|
||||||
// iterator tuple.
|
// iterator tuple.
|
||||||
void advance(typename super_t::difference_type n)
|
void advance(typename super_t::difference_type n)
|
||||||
{
|
{
|
||||||
fusion::for_each(
|
detail::tuple_impl_specific::tuple_for_each(
|
||||||
m_iterator_tuple,
|
m_iterator_tuple,
|
||||||
detail::advance_iterator<BOOST_DEDUCED_TYPENAME super_t::difference_type>(n));
|
detail::advance_iterator<BOOST_DEDUCED_TYPENAME super_t::difference_type>(n)
|
||||||
|
);
|
||||||
}
|
}
|
||||||
// Incrementing a zip iterator means to increment all iterators in
|
// Incrementing a zip iterator means to increment all iterators in
|
||||||
// the iterator tuple.
|
// the iterator tuple.
|
||||||
void increment()
|
void increment()
|
||||||
{
|
{
|
||||||
fusion::for_each(
|
detail::tuple_impl_specific::tuple_for_each(
|
||||||
m_iterator_tuple,
|
m_iterator_tuple,
|
||||||
detail::increment_iterator());
|
detail::increment_iterator()
|
||||||
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
// Decrementing a zip iterator means to decrement all iterators in
|
// Decrementing a zip iterator means to decrement all iterators in
|
||||||
// the iterator tuple.
|
// the iterator tuple.
|
||||||
void decrement()
|
void decrement()
|
||||||
{
|
{
|
||||||
fusion::for_each(
|
detail::tuple_impl_specific::tuple_for_each(
|
||||||
m_iterator_tuple,
|
m_iterator_tuple,
|
||||||
detail::decrement_iterator());
|
detail::decrement_iterator()
|
||||||
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
// Distance is calculated using the first iterator in the tuple.
|
// Distance is calculated using the first iterator in the tuple.
|
||||||
@ -338,8 +561,8 @@ namespace iterators {
|
|||||||
const zip_iterator<OtherIteratorTuple>& other
|
const zip_iterator<OtherIteratorTuple>& other
|
||||||
) const
|
) const
|
||||||
{
|
{
|
||||||
return fusion::at_c<0>(other.get_iterator_tuple()) -
|
return boost::tuples::get<0>(other.get_iterator_tuple()) -
|
||||||
fusion::at_c<0>(this->get_iterator_tuple());
|
boost::tuples::get<0>(this->get_iterator_tuple());
|
||||||
}
|
}
|
||||||
|
|
||||||
// Data Members
|
// Data Members
|
||||||
@ -353,15 +576,10 @@ namespace iterators {
|
|||||||
// Make function for zip iterator
|
// Make function for zip iterator
|
||||||
//
|
//
|
||||||
template<typename IteratorTuple>
|
template<typename IteratorTuple>
|
||||||
inline zip_iterator<IteratorTuple>
|
zip_iterator<IteratorTuple>
|
||||||
make_zip_iterator(IteratorTuple t)
|
make_zip_iterator(IteratorTuple t)
|
||||||
{ return zip_iterator<IteratorTuple>(t); }
|
{ return zip_iterator<IteratorTuple>(t); }
|
||||||
|
|
||||||
} // namespace iterators
|
}
|
||||||
|
|
||||||
using iterators::zip_iterator;
|
|
||||||
using iterators::make_zip_iterator;
|
|
||||||
|
|
||||||
} // namespace boost
|
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
@ -1,154 +0,0 @@
|
|||||||
// Boost next_prior.hpp header file ---------------------------------------//
|
|
||||||
|
|
||||||
// (C) Copyright Dave Abrahams and Daniel Walker 1999-2003.
|
|
||||||
// Copyright (c) Andrey Semashev 2017
|
|
||||||
//
|
|
||||||
// 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)
|
|
||||||
|
|
||||||
// See http://www.boost.org/libs/utility for documentation.
|
|
||||||
|
|
||||||
// Revision History
|
|
||||||
// 13 Dec 2003 Added next(x, n) and prior(x, n) (Daniel Walker)
|
|
||||||
|
|
||||||
#ifndef BOOST_NEXT_PRIOR_HPP_INCLUDED
|
|
||||||
#define BOOST_NEXT_PRIOR_HPP_INCLUDED
|
|
||||||
|
|
||||||
#include <boost/config.hpp>
|
|
||||||
#include <boost/type_traits/has_plus.hpp>
|
|
||||||
#include <boost/type_traits/has_plus_assign.hpp>
|
|
||||||
#include <boost/type_traits/has_minus.hpp>
|
|
||||||
#include <boost/type_traits/has_minus_assign.hpp>
|
|
||||||
#include <boost/iterator/is_iterator.hpp>
|
|
||||||
#include <boost/iterator/advance.hpp>
|
|
||||||
#include <boost/iterator/reverse_iterator.hpp>
|
|
||||||
|
|
||||||
namespace boost {
|
|
||||||
|
|
||||||
// Helper functions for classes like bidirectional iterators not supporting
|
|
||||||
// operator+ and operator-
|
|
||||||
//
|
|
||||||
// Usage:
|
|
||||||
// const std::list<T>::iterator p = get_some_iterator();
|
|
||||||
// const std::list<T>::iterator prev = boost::prior(p);
|
|
||||||
// const std::list<T>::iterator next = boost::next(prev, 2);
|
|
||||||
|
|
||||||
// Contributed by Dave Abrahams
|
|
||||||
|
|
||||||
namespace next_prior_detail {
|
|
||||||
|
|
||||||
template< typename T, typename Distance, bool HasPlus = has_plus< T, Distance >::value >
|
|
||||||
struct next_plus_impl;
|
|
||||||
|
|
||||||
template< typename T, typename Distance >
|
|
||||||
struct next_plus_impl< T, Distance, true >
|
|
||||||
{
|
|
||||||
static T call(T x, Distance n)
|
|
||||||
{
|
|
||||||
return x + n;
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
template< typename T, typename Distance, bool HasPlusAssign = has_plus_assign< T, Distance >::value >
|
|
||||||
struct next_plus_assign_impl :
|
|
||||||
public next_plus_impl< T, Distance >
|
|
||||||
{
|
|
||||||
};
|
|
||||||
|
|
||||||
template< typename T, typename Distance >
|
|
||||||
struct next_plus_assign_impl< T, Distance, true >
|
|
||||||
{
|
|
||||||
static T call(T x, Distance n)
|
|
||||||
{
|
|
||||||
x += n;
|
|
||||||
return x;
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
template< typename T, typename Distance, bool IsIterator = boost::iterators::is_iterator< T >::value >
|
|
||||||
struct next_advance_impl :
|
|
||||||
public next_plus_assign_impl< T, Distance >
|
|
||||||
{
|
|
||||||
};
|
|
||||||
|
|
||||||
template< typename T, typename Distance >
|
|
||||||
struct next_advance_impl< T, Distance, true >
|
|
||||||
{
|
|
||||||
static T call(T x, Distance n)
|
|
||||||
{
|
|
||||||
boost::iterators::advance(x, n);
|
|
||||||
return x;
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
|
|
||||||
template< typename T, typename Distance, bool HasMinus = has_minus< T, Distance >::value >
|
|
||||||
struct prior_minus_impl;
|
|
||||||
|
|
||||||
template< typename T, typename Distance >
|
|
||||||
struct prior_minus_impl< T, Distance, true >
|
|
||||||
{
|
|
||||||
static T call(T x, Distance n)
|
|
||||||
{
|
|
||||||
return x - n;
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
template< typename T, typename Distance, bool HasMinusAssign = has_minus_assign< T, Distance >::value >
|
|
||||||
struct prior_minus_assign_impl :
|
|
||||||
public prior_minus_impl< T, Distance >
|
|
||||||
{
|
|
||||||
};
|
|
||||||
|
|
||||||
template< typename T, typename Distance >
|
|
||||||
struct prior_minus_assign_impl< T, Distance, true >
|
|
||||||
{
|
|
||||||
static T call(T x, Distance n)
|
|
||||||
{
|
|
||||||
x -= n;
|
|
||||||
return x;
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
template< typename T, typename Distance, bool IsIterator = boost::iterators::is_iterator< T >::value >
|
|
||||||
struct prior_advance_impl :
|
|
||||||
public prior_minus_assign_impl< T, Distance >
|
|
||||||
{
|
|
||||||
};
|
|
||||||
|
|
||||||
template< typename T, typename Distance >
|
|
||||||
struct prior_advance_impl< T, Distance, true >
|
|
||||||
{
|
|
||||||
static T call(T x, Distance n)
|
|
||||||
{
|
|
||||||
// Avoid negating n to sidestep possible integer overflow
|
|
||||||
boost::iterators::reverse_iterator< T > rx(x);
|
|
||||||
boost::iterators::advance(rx, n);
|
|
||||||
return rx.base();
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
} // namespace next_prior_detail
|
|
||||||
|
|
||||||
template <class T>
|
|
||||||
inline T next(T x) { return ++x; }
|
|
||||||
|
|
||||||
template <class T, class Distance>
|
|
||||||
inline T next(T x, Distance n)
|
|
||||||
{
|
|
||||||
return next_prior_detail::next_advance_impl< T, Distance >::call(x, n);
|
|
||||||
}
|
|
||||||
|
|
||||||
template <class T>
|
|
||||||
inline T prior(T x) { return --x; }
|
|
||||||
|
|
||||||
template <class T, class Distance>
|
|
||||||
inline T prior(T x, Distance n)
|
|
||||||
{
|
|
||||||
return next_prior_detail::prior_advance_impl< T, Distance >::call(x, n);
|
|
||||||
}
|
|
||||||
|
|
||||||
} // namespace boost
|
|
||||||
|
|
||||||
#endif // BOOST_NEXT_PRIOR_HPP_INCLUDED
|
|
@ -6,17 +6,15 @@
|
|||||||
#ifndef BOOST_INT_ITERATOR_H
|
#ifndef BOOST_INT_ITERATOR_H
|
||||||
#define BOOST_INT_ITERATOR_H
|
#define BOOST_INT_ITERATOR_H
|
||||||
|
|
||||||
|
#include <boost/iterator.hpp>
|
||||||
#if !defined BOOST_MSVC
|
#if !defined BOOST_MSVC
|
||||||
#include <boost/operators.hpp>
|
#include <boost/operators.hpp>
|
||||||
#endif
|
#endif
|
||||||
#include <iostream>
|
#include <iostream>
|
||||||
#include <iterator>
|
|
||||||
#include <cstddef>
|
|
||||||
//using namespace std;
|
//using namespace std;
|
||||||
|
|
||||||
#ifndef BOOST_NO_OPERATORS_IN_NAMESPACE
|
#ifndef BOOST_NO_OPERATORS_IN_NAMESPACE
|
||||||
namespace boost {
|
namespace boost {
|
||||||
namespace iterators {
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
// this should use random_access_iterator_helper but I've had
|
// this should use random_access_iterator_helper but I've had
|
||||||
@ -63,19 +61,13 @@ inline int_iterator<IntT>
|
|||||||
operator+(IntT n, int_iterator<IntT> t) { t += n; return t; }
|
operator+(IntT n, int_iterator<IntT> t) { t += n; return t; }
|
||||||
|
|
||||||
#ifndef BOOST_NO_OPERATORS_IN_NAMESPACE
|
#ifndef BOOST_NO_OPERATORS_IN_NAMESPACE
|
||||||
} /* namespace iterators */
|
|
||||||
|
|
||||||
using iterators::int_iterator;
|
|
||||||
|
|
||||||
} /* namespace boost */
|
} /* namespace boost */
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifdef BOOST_NO_OPERATORS_IN_NAMESPACE
|
#ifdef BOOST_NO_OPERATORS_IN_NAMESPACE
|
||||||
namespace boost {
|
namespace boost {
|
||||||
using ::int_iterator;
|
using ::int_iterator;
|
||||||
namespace iterators {
|
}
|
||||||
using ::int_iterator;
|
|
||||||
}}
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
59
include/boost/pending/integer_range.hpp
Normal file
59
include/boost/pending/integer_range.hpp
Normal file
@ -0,0 +1,59 @@
|
|||||||
|
// (C) Copyright David Abrahams and Jeremy Siek 2000-2001.
|
||||||
|
// 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)
|
||||||
|
//
|
||||||
|
// Revision History:
|
||||||
|
// 04 Jan 2001 Factored counting_iterator stuff into
|
||||||
|
// boost/counting_iterator.hpp (David Abrahams)
|
||||||
|
|
||||||
|
#ifndef BOOST_INTEGER_RANGE_HPP_
|
||||||
|
#define BOOST_INTEGER_RANGE_HPP_
|
||||||
|
|
||||||
|
#include <boost/config.hpp>
|
||||||
|
#include <boost/iterator/counting_iterator.hpp>
|
||||||
|
#include <algorithm>
|
||||||
|
|
||||||
|
namespace boost {
|
||||||
|
|
||||||
|
//=============================================================================
|
||||||
|
// Counting Iterator and Integer Range Class
|
||||||
|
|
||||||
|
template <class IntegerType>
|
||||||
|
struct integer_range {
|
||||||
|
typedef counting_iterator<IntegerType> iterator;
|
||||||
|
|
||||||
|
typedef iterator const_iterator;
|
||||||
|
typedef IntegerType value_type;
|
||||||
|
typedef std::ptrdiff_t difference_type;
|
||||||
|
typedef IntegerType reference;
|
||||||
|
typedef IntegerType const_reference;
|
||||||
|
typedef const IntegerType* pointer;
|
||||||
|
typedef const IntegerType* const_pointer;
|
||||||
|
typedef IntegerType size_type;
|
||||||
|
|
||||||
|
integer_range(IntegerType start, IntegerType finish)
|
||||||
|
: m_start(start), m_finish(finish) { }
|
||||||
|
|
||||||
|
iterator begin() const { return iterator(m_start); }
|
||||||
|
iterator end() const { return iterator(m_finish); }
|
||||||
|
size_type size() const { return m_finish - m_start; }
|
||||||
|
bool empty() const { return m_finish == m_start; }
|
||||||
|
void swap(integer_range& x) {
|
||||||
|
std::swap(m_start, x.m_start);
|
||||||
|
std::swap(m_finish, x.m_finish);
|
||||||
|
}
|
||||||
|
protected:
|
||||||
|
IntegerType m_start, m_finish;
|
||||||
|
};
|
||||||
|
|
||||||
|
template <class IntegerType>
|
||||||
|
inline integer_range<IntegerType>
|
||||||
|
make_integer_range(IntegerType first, IntegerType last)
|
||||||
|
{
|
||||||
|
return integer_range<IntegerType>(first, last);
|
||||||
|
}
|
||||||
|
|
||||||
|
} // namespace boost
|
||||||
|
|
||||||
|
#endif // BOOST_INTEGER_RANGE_HPP_
|
@ -20,13 +20,12 @@
|
|||||||
// (David Abrahams)
|
// (David Abrahams)
|
||||||
|
|
||||||
# include <iterator>
|
# include <iterator>
|
||||||
|
# include <assert.h>
|
||||||
|
# include <boost/type_traits.hpp>
|
||||||
# include <boost/static_assert.hpp>
|
# include <boost/static_assert.hpp>
|
||||||
# include <boost/concept_archetype.hpp> // for detail::dummy_constructor
|
# include <boost/concept_archetype.hpp> // for detail::dummy_constructor
|
||||||
# include <boost/core/ignore_unused.hpp>
|
# include <boost/implicit_cast.hpp>
|
||||||
# include <boost/core/lightweight_test.hpp>
|
# include <boost/type_traits/broken_compiler_spec.hpp>
|
||||||
# include <boost/type_traits/is_same.hpp>
|
|
||||||
# include <boost/type_traits/is_pointer.hpp>
|
|
||||||
# include <boost/type_traits/is_reference.hpp>
|
|
||||||
|
|
||||||
namespace boost {
|
namespace boost {
|
||||||
|
|
||||||
@ -42,8 +41,9 @@ struct dummyT {
|
|||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
BOOST_TT_BROKEN_COMPILER_SPEC(boost::dummyT)
|
||||||
|
|
||||||
namespace boost {
|
namespace boost {
|
||||||
namespace iterators {
|
|
||||||
|
|
||||||
// Tests whether type Iterator satisfies the requirements for a
|
// Tests whether type Iterator satisfies the requirements for a
|
||||||
// TrivialIterator.
|
// TrivialIterator.
|
||||||
@ -52,29 +52,27 @@ template <class Iterator, class T>
|
|||||||
void trivial_iterator_test(const Iterator i, const Iterator j, T val)
|
void trivial_iterator_test(const Iterator i, const Iterator j, T val)
|
||||||
{
|
{
|
||||||
Iterator k;
|
Iterator k;
|
||||||
BOOST_TEST(i == i);
|
assert(i == i);
|
||||||
BOOST_TEST(j == j);
|
assert(j == j);
|
||||||
BOOST_TEST(i != j);
|
assert(i != j);
|
||||||
#ifdef BOOST_NO_STD_ITERATOR_TRAITS
|
#ifdef BOOST_NO_STD_ITERATOR_TRAITS
|
||||||
T v = *i;
|
T v = *i;
|
||||||
#else
|
#else
|
||||||
typename std::iterator_traits<Iterator>::value_type v = *i;
|
typename std::iterator_traits<Iterator>::value_type v = *i;
|
||||||
#endif
|
#endif
|
||||||
BOOST_TEST(v == val);
|
assert(v == val);
|
||||||
boost::ignore_unused(v);
|
|
||||||
#if 0
|
#if 0
|
||||||
// hmm, this will give a warning for transform_iterator... perhaps
|
// hmm, this will give a warning for transform_iterator... perhaps
|
||||||
// this should be separated out into a stand-alone test since there
|
// this should be separated out into a stand-alone test since there
|
||||||
// are several situations where it can't be used, like for
|
// are several situations where it can't be used, like for
|
||||||
// integer_range::iterator.
|
// integer_range::iterator.
|
||||||
BOOST_TEST(v == i->foo());
|
assert(v == i->foo());
|
||||||
#endif
|
#endif
|
||||||
k = i;
|
k = i;
|
||||||
BOOST_TEST(k == k);
|
assert(k == k);
|
||||||
BOOST_TEST(k == i);
|
assert(k == i);
|
||||||
BOOST_TEST(k != j);
|
assert(k != j);
|
||||||
BOOST_TEST(*k == val);
|
assert(*k == val);
|
||||||
boost::ignore_unused(k);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -93,8 +91,8 @@ void input_iterator_test(Iterator i, T v1, T v2)
|
|||||||
{
|
{
|
||||||
Iterator i1(i);
|
Iterator i1(i);
|
||||||
|
|
||||||
BOOST_TEST(i == i1);
|
assert(i == i1);
|
||||||
BOOST_TEST(!(i != i1));
|
assert(!(i != i1));
|
||||||
|
|
||||||
// I can see no generic way to create an input iterator
|
// I can see no generic way to create an input iterator
|
||||||
// that is in the domain of== of i and != i.
|
// that is in the domain of== of i and != i.
|
||||||
@ -103,25 +101,23 @@ void input_iterator_test(Iterator i, T v1, T v2)
|
|||||||
//
|
//
|
||||||
// Iterator i2;
|
// Iterator i2;
|
||||||
//
|
//
|
||||||
// BOOST_TEST(i != i2);
|
// assert(i != i2);
|
||||||
// BOOST_TEST(!(i == i2));
|
// assert(!(i == i2));
|
||||||
|
|
||||||
BOOST_TEST(*i1 == v1);
|
assert(*i1 == v1);
|
||||||
BOOST_TEST(*i == v1);
|
assert(*i == v1);
|
||||||
|
|
||||||
// we cannot test for equivalence of (void)++i & (void)i++
|
// we cannot test for equivalence of (void)++i & (void)i++
|
||||||
// as i is only guaranteed to be single pass.
|
// as i is only guaranteed to be single pass.
|
||||||
BOOST_TEST(*i++ == v1);
|
assert(*i++ == v1);
|
||||||
boost::ignore_unused(i1);
|
|
||||||
|
|
||||||
i1 = i;
|
i1 = i;
|
||||||
|
|
||||||
BOOST_TEST(i == i1);
|
assert(i == i1);
|
||||||
BOOST_TEST(!(i != i1));
|
assert(!(i != i1));
|
||||||
|
|
||||||
BOOST_TEST(*i1 == v2);
|
assert(*i1 == v2);
|
||||||
BOOST_TEST(*i == v2);
|
assert(*i == v2);
|
||||||
boost::ignore_unused(i1);
|
|
||||||
|
|
||||||
// i is dereferencable, so it must be incrementable.
|
// i is dereferencable, so it must be incrementable.
|
||||||
++i;
|
++i;
|
||||||
@ -163,15 +159,15 @@ void forward_iterator_test(Iterator i, T v1, T v2)
|
|||||||
|
|
||||||
Iterator i1 = i, i2 = i;
|
Iterator i1 = i, i2 = i;
|
||||||
|
|
||||||
BOOST_TEST(i == i1++);
|
assert(i == i1++);
|
||||||
BOOST_TEST(i != ++i2);
|
assert(i != ++i2);
|
||||||
|
|
||||||
trivial_iterator_test(i, i1, v1);
|
trivial_iterator_test(i, i1, v1);
|
||||||
trivial_iterator_test(i, i2, v1);
|
trivial_iterator_test(i, i2, v1);
|
||||||
|
|
||||||
++i;
|
++i;
|
||||||
BOOST_TEST(i == i1);
|
assert(i == i1);
|
||||||
BOOST_TEST(i == i2);
|
assert(i == i2);
|
||||||
++i1;
|
++i1;
|
||||||
++i2;
|
++i2;
|
||||||
|
|
||||||
@ -179,7 +175,7 @@ void forward_iterator_test(Iterator i, T v1, T v2)
|
|||||||
trivial_iterator_test(i, i2, v2);
|
trivial_iterator_test(i, i2, v2);
|
||||||
|
|
||||||
// borland doesn't allow non-type template parameters
|
// borland doesn't allow non-type template parameters
|
||||||
# if !defined(BOOST_BORLANDC) || (BOOST_BORLANDC > 0x551)
|
# if !defined(__BORLANDC__) || (__BORLANDC__ > 0x551)
|
||||||
lvalue_test<(boost::is_pointer<Iterator>::value)>::check(i);
|
lvalue_test<(boost::is_pointer<Iterator>::value)>::check(i);
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
@ -193,15 +189,15 @@ void bidirectional_iterator_test(Iterator i, T v1, T v2)
|
|||||||
|
|
||||||
Iterator i1 = i, i2 = i;
|
Iterator i1 = i, i2 = i;
|
||||||
|
|
||||||
BOOST_TEST(i == i1--);
|
assert(i == i1--);
|
||||||
BOOST_TEST(i != --i2);
|
assert(i != --i2);
|
||||||
|
|
||||||
trivial_iterator_test(i, i1, v2);
|
trivial_iterator_test(i, i1, v2);
|
||||||
trivial_iterator_test(i, i2, v2);
|
trivial_iterator_test(i, i2, v2);
|
||||||
|
|
||||||
--i;
|
--i;
|
||||||
BOOST_TEST(i == i1);
|
assert(i == i1);
|
||||||
BOOST_TEST(i == i2);
|
assert(i == i2);
|
||||||
++i1;
|
++i1;
|
||||||
++i2;
|
++i2;
|
||||||
|
|
||||||
@ -221,37 +217,32 @@ void random_access_iterator_test(Iterator i, int N, TrueVals vals)
|
|||||||
const Iterator j = i;
|
const Iterator j = i;
|
||||||
int c;
|
int c;
|
||||||
|
|
||||||
typedef typename std::iterator_traits<Iterator>::value_type value_type;
|
typedef typename boost::detail::iterator_traits<Iterator>::value_type value_type;
|
||||||
struct local
|
|
||||||
{
|
|
||||||
static value_type to_value_type(value_type v) { return v; }
|
|
||||||
};
|
|
||||||
|
|
||||||
for (c = 0; c < N-1; ++c) {
|
for (c = 0; c < N-1; ++c) {
|
||||||
BOOST_TEST(i == j + c);
|
assert(i == j + c);
|
||||||
BOOST_TEST(*i == vals[c]);
|
assert(*i == vals[c]);
|
||||||
BOOST_TEST(*i == local::to_value_type(j[c]));
|
assert(*i == boost::implicit_cast<value_type>(j[c]));
|
||||||
BOOST_TEST(*i == *(j + c));
|
assert(*i == *(j + c));
|
||||||
BOOST_TEST(*i == *(c + j));
|
assert(*i == *(c + j));
|
||||||
++i;
|
++i;
|
||||||
BOOST_TEST(i > j);
|
assert(i > j);
|
||||||
BOOST_TEST(i >= j);
|
assert(i >= j);
|
||||||
BOOST_TEST(j <= i);
|
assert(j <= i);
|
||||||
BOOST_TEST(j < i);
|
assert(j < i);
|
||||||
}
|
}
|
||||||
|
|
||||||
Iterator k = j + N - 1;
|
Iterator k = j + N - 1;
|
||||||
for (c = 0; c < N-1; ++c) {
|
for (c = 0; c < N-1; ++c) {
|
||||||
BOOST_TEST(i == k - c);
|
assert(i == k - c);
|
||||||
BOOST_TEST(*i == vals[N - 1 - c]);
|
assert(*i == vals[N - 1 - c]);
|
||||||
BOOST_TEST(*i == local::to_value_type(j[N - 1 - c]));
|
assert(*i == boost::implicit_cast<value_type>(j[N - 1 - c]));
|
||||||
Iterator q = k - c;
|
Iterator q = k - c;
|
||||||
boost::ignore_unused(q);
|
assert(*i == *q);
|
||||||
BOOST_TEST(*i == *q);
|
assert(i > j);
|
||||||
BOOST_TEST(i > j);
|
assert(i >= j);
|
||||||
BOOST_TEST(i >= j);
|
assert(j <= i);
|
||||||
BOOST_TEST(j <= i);
|
assert(j < i);
|
||||||
BOOST_TEST(j < i);
|
|
||||||
--i;
|
--i;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -260,31 +251,18 @@ void random_access_iterator_test(Iterator i, int N, TrueVals vals)
|
|||||||
template <class Iterator, class ConstIterator>
|
template <class Iterator, class ConstIterator>
|
||||||
void const_nonconst_iterator_test(Iterator i, ConstIterator j)
|
void const_nonconst_iterator_test(Iterator i, ConstIterator j)
|
||||||
{
|
{
|
||||||
BOOST_TEST(i != j);
|
assert(i != j);
|
||||||
BOOST_TEST(j != i);
|
assert(j != i);
|
||||||
|
|
||||||
ConstIterator k(i);
|
ConstIterator k(i);
|
||||||
BOOST_TEST(k == i);
|
assert(k == i);
|
||||||
BOOST_TEST(i == k);
|
assert(i == k);
|
||||||
|
|
||||||
k = i;
|
k = i;
|
||||||
BOOST_TEST(k == i);
|
assert(k == i);
|
||||||
BOOST_TEST(i == k);
|
assert(i == k);
|
||||||
boost::ignore_unused(k);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
} // namespace iterators
|
|
||||||
|
|
||||||
using iterators::undefined;
|
|
||||||
using iterators::trivial_iterator_test;
|
|
||||||
using iterators::mutable_trivial_iterator_test;
|
|
||||||
using iterators::input_iterator_test;
|
|
||||||
using iterators::lvalue_test;
|
|
||||||
using iterators::forward_iterator_test;
|
|
||||||
using iterators::bidirectional_iterator_test;
|
|
||||||
using iterators::random_access_iterator_test;
|
|
||||||
using iterators::const_nonconst_iterator_test;
|
|
||||||
|
|
||||||
} // namespace boost
|
} // namespace boost
|
||||||
|
|
||||||
#endif // BOOST_ITERATOR_TESTS_HPP
|
#endif // BOOST_ITERATOR_TESTS_HPP
|
||||||
|
@ -20,8 +20,6 @@
|
|||||||
# include <boost/mpl/if.hpp>
|
# include <boost/mpl/if.hpp>
|
||||||
# include <boost/mpl/eval_if.hpp>
|
# include <boost/mpl/eval_if.hpp>
|
||||||
|
|
||||||
#include <iterator>
|
|
||||||
|
|
||||||
namespace boost {
|
namespace boost {
|
||||||
|
|
||||||
namespace detail
|
namespace detail
|
||||||
@ -35,7 +33,7 @@ namespace detail
|
|||||||
template <class Iterator>
|
template <class Iterator>
|
||||||
struct iterator_pointee
|
struct iterator_pointee
|
||||||
{
|
{
|
||||||
typedef typename std::iterator_traits<Iterator>::value_type value_type;
|
typedef typename iterator_traits<Iterator>::value_type value_type;
|
||||||
|
|
||||||
struct impl
|
struct impl
|
||||||
{
|
{
|
||||||
@ -50,7 +48,7 @@ namespace detail
|
|||||||
BOOST_STATIC_CONSTANT(bool, is_constant = sizeof(impl::test(*impl::x)) == 1);
|
BOOST_STATIC_CONSTANT(bool, is_constant = sizeof(impl::test(*impl::x)) == 1);
|
||||||
|
|
||||||
typedef typename mpl::if_c<
|
typedef typename mpl::if_c<
|
||||||
# if BOOST_WORKAROUND(BOOST_BORLANDC, BOOST_TESTED_AT(0x551))
|
# if BOOST_WORKAROUND(__BORLANDC__, BOOST_TESTED_AT(0x551))
|
||||||
::boost::detail::iterator_pointee<Iterator>::is_constant
|
::boost::detail::iterator_pointee<Iterator>::is_constant
|
||||||
# else
|
# else
|
||||||
is_constant
|
is_constant
|
||||||
|
@ -5,15 +5,14 @@
|
|||||||
|
|
||||||
// See http://www.boost.org/libs/utility/shared_container_iterator.html for documentation.
|
// See http://www.boost.org/libs/utility/shared_container_iterator.html for documentation.
|
||||||
|
|
||||||
#ifndef BOOST_SHARED_CONTAINER_ITERATOR_HPP
|
#ifndef SHARED_CONTAINER_ITERATOR_RG08102002_HPP
|
||||||
#define BOOST_SHARED_CONTAINER_ITERATOR_HPP
|
#define SHARED_CONTAINER_ITERATOR_RG08102002_HPP
|
||||||
|
|
||||||
#include "boost/iterator_adaptors.hpp"
|
#include "boost/iterator_adaptors.hpp"
|
||||||
#include "boost/shared_ptr.hpp"
|
#include "boost/shared_ptr.hpp"
|
||||||
#include <utility>
|
#include <utility>
|
||||||
|
|
||||||
namespace boost {
|
namespace boost {
|
||||||
namespace iterators {
|
|
||||||
|
|
||||||
template <typename Container>
|
template <typename Container>
|
||||||
class shared_container_iterator : public iterator_adaptor<
|
class shared_container_iterator : public iterator_adaptor<
|
||||||
@ -38,7 +37,7 @@ public:
|
|||||||
};
|
};
|
||||||
|
|
||||||
template <typename Container>
|
template <typename Container>
|
||||||
inline shared_container_iterator<Container>
|
shared_container_iterator<Container>
|
||||||
make_shared_container_iterator(typename Container::iterator iter,
|
make_shared_container_iterator(typename Container::iterator iter,
|
||||||
boost::shared_ptr<Container> const& container) {
|
boost::shared_ptr<Container> const& container) {
|
||||||
typedef shared_container_iterator<Container> iterator;
|
typedef shared_container_iterator<Container> iterator;
|
||||||
@ -48,7 +47,7 @@ make_shared_container_iterator(typename Container::iterator iter,
|
|||||||
|
|
||||||
|
|
||||||
template <typename Container>
|
template <typename Container>
|
||||||
inline std::pair<
|
std::pair<
|
||||||
shared_container_iterator<Container>,
|
shared_container_iterator<Container>,
|
||||||
shared_container_iterator<Container> >
|
shared_container_iterator<Container> >
|
||||||
make_shared_container_range(boost::shared_ptr<Container> const& container) {
|
make_shared_container_range(boost::shared_ptr<Container> const& container) {
|
||||||
@ -58,12 +57,6 @@ make_shared_container_range(boost::shared_ptr<Container> const& container) {
|
|||||||
make_shared_container_iterator(container->end(),container));
|
make_shared_container_iterator(container->end(),container));
|
||||||
}
|
}
|
||||||
|
|
||||||
} // namespace iterators
|
|
||||||
|
|
||||||
using iterators::shared_container_iterator;
|
|
||||||
using iterators::make_shared_container_iterator;
|
|
||||||
using iterators::make_shared_container_range;
|
|
||||||
|
|
||||||
} // namespace boost
|
} // namespace boost
|
||||||
|
#endif // SHARED_CONTAINER_ITERATOR_RG08102002_HPP
|
||||||
#endif
|
|
||||||
|
@ -1,19 +0,0 @@
|
|||||||
{
|
|
||||||
"key": "iterator",
|
|
||||||
"name": "Iterator",
|
|
||||||
"authors": [
|
|
||||||
"Dave Abrahams",
|
|
||||||
"Jeremy Siek",
|
|
||||||
"Thomas Witt"
|
|
||||||
],
|
|
||||||
"description": "The Boost Iterator Library contains two parts. The first is a system of concepts which extend the C++ standard iterator requirements. The second is a framework of components for building iterators based on these extended concepts and includes several useful iterator adaptors.",
|
|
||||||
"category": [
|
|
||||||
"Iterators"
|
|
||||||
],
|
|
||||||
"maintainers": [
|
|
||||||
"David Abrahams <dave -at- boost-consulting.com>",
|
|
||||||
"Thomas Witt <witt - at - acm.org>",
|
|
||||||
"Jeffrey Lee Hellrung Jr. <jeffrey.hellrung -at- gmail.com>"
|
|
||||||
],
|
|
||||||
"cxxstd": "03"
|
|
||||||
}
|
|
Some files were not shown because too many files have changed in this diff Show More
Reference in New Issue
Block a user