forked from boostorg/utility
		
	Compare commits
	
		
			121 Commits
		
	
	
		
			string_vie
			...
			ostream_wr
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|  | dabf53a703 | ||
|  | ff56b3649e | ||
|  | 31e0ae4c37 | ||
|  | 5fe9df91c0 | ||
|  | f03b681d01 | ||
|  | e120a83d1e | ||
|  | 424fea5881 | ||
|  | 53d9aa9d2f | ||
|  | ce64b13846 | ||
|  | 32c50e0814 | ||
|  | 05dda09fd3 | ||
|  | a4cafcc75d | ||
|  | 796fb965be | ||
|  | 08da98a551 | ||
|  | 57b027f1cd | ||
|  | db05c11f50 | ||
|  | 3d2a7f0c17 | ||
|  | 8858bad352 | ||
|  | fc135e0d72 | ||
|  | ebe44296ca | ||
|  | bdf55e0b6f | ||
|  | d4170ccdb5 | ||
|  | e2d115db97 | ||
|  | 15cfa44937 | ||
|  | 473be2e4c1 | ||
|  | 6ad6bc005c | ||
|  | 7709f0e430 | ||
|  | eacea4664d | ||
|  | 1fe5af5264 | ||
|  | d2fb06e6a0 | ||
|  | 73baeb7a63 | ||
|  | 56f13625b1 | ||
|  | ac4e8da91d | ||
|  | 426836d860 | ||
|  | 82df2b82fc | ||
|  | f8a243bcff | ||
|  | 51f7f7f53e | ||
|  | 5f535a151c | ||
|  | c88936800d | ||
|  | 96fbce5759 | ||
|  | 9d46de1578 | ||
|  | 976a4d2fc1 | ||
|  | ea81279b35 | ||
|  | 7d101d420c | ||
|  | d8acfef27b | ||
|  | d7ae336915 | ||
|  | b74f49f1e5 | ||
|  | 5977f11be8 | ||
|  | ad0fc7c9d3 | ||
|  | a6c175e2c3 | ||
|  | 874ca2307b | ||
|  | 5220260145 | ||
|  | 2f5a6fbcf1 | ||
|  | 51ba9f1b45 | ||
|  | 5cef1403b0 | ||
|  | 81ce4693f6 | ||
|  | fb2f110eb4 | ||
|  | 2ed5ee9588 | ||
|  | 88c36c1941 | ||
|  | 0b2409a942 | ||
|  | 62b39548be | ||
|  | 2722fdcda3 | ||
|  | 792d0538d2 | ||
|  | 06ae661775 | ||
|  | d9d076874e | ||
|  | e25d85446e | ||
|  | 5bc9e47688 | ||
|  | ec50f22b8b | ||
|  | 592382dc61 | ||
|  | 6cf9c22cf1 | ||
|  | 33475f87e4 | ||
|  | 21261a8630 | ||
|  | 7d60e8e378 | ||
|  | 10ff4d4fcd | ||
|  | 89bf74beee | ||
|  | bfdcce0f97 | ||
|  | 330b49d602 | ||
|  | 68b26cddbe | ||
|  | 6c4ab93573 | ||
|  | 0876da45db | ||
|  | 00f02167e3 | ||
|  | 9960d9f395 | ||
|  | ccfd741c0a | ||
|  | c5c479d49c | ||
|  | 3e8f73c6ac | ||
|  | 38121f2af3 | ||
|  | 38b536ff05 | ||
|  | 9ae6492af9 | ||
|  | 816607e212 | ||
|  | a3ab942bc2 | ||
|  | 0f1f793caf | ||
|  | ff445c0ece | ||
|  | 9fae8be166 | ||
|  | b90a28f0e1 | ||
|  | febca584d9 | ||
|  | 21dc552cf9 | ||
|  | fda210f597 | ||
|  | 3d853b0e83 | ||
|  | 4814d1ebfe | ||
|  | e5932ebb08 | ||
|  | 93a2e25092 | ||
|  | 39577f86d1 | ||
|  | 8392991c46 | ||
|  | c5b1256650 | ||
|  | c56dd13592 | ||
|  | 181f302ee4 | ||
|  | 287844fe76 | ||
|  | 3982b6d633 | ||
|  | 0b492bee9c | ||
|  | a9236d00a9 | ||
|  | 4313bfc323 | ||
|  | f61c94e812 | ||
|  | 1dfacff7ec | ||
|  | a25ac4550b | ||
|  | d767054a79 | ||
|  | 08a1b7da61 | ||
|  | 8ab8e36dcf | ||
|  | 1caa745dd7 | ||
|  | cf5ad341ed | ||
|  | 1f6de83fe2 | ||
|  | cb6500161b | 
							
								
								
									
										250
									
								
								.travis.yml
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										250
									
								
								.travis.yml
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,250 @@ | ||||
| # Copyright 2016, 2017 Peter Dimov | ||||
| # 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) | ||||
|  | ||||
| language: cpp | ||||
|  | ||||
| sudo: false | ||||
|  | ||||
| python: "2.7" | ||||
|  | ||||
| branches: | ||||
|   only: | ||||
|     - master | ||||
|     - develop | ||||
|     - /feature\/.*/ | ||||
|  | ||||
| env: | ||||
|   matrix: | ||||
|     - BOGUS_JOB=true | ||||
|  | ||||
| matrix: | ||||
|  | ||||
|   exclude: | ||||
|     - env: BOGUS_JOB=true | ||||
|  | ||||
|   include: | ||||
|     - os: linux | ||||
|       compiler: g++ | ||||
|       env: TOOLSET=gcc COMPILER=g++ CXXSTD=03,11 | ||||
|  | ||||
|     - os: linux | ||||
|       compiler: g++-4.7 | ||||
|       env: TOOLSET=gcc COMPILER=g++-4.7 CXXSTD=03,11 | ||||
|       addons: | ||||
|         apt: | ||||
|           packages: | ||||
|             - g++-4.7 | ||||
|           sources: | ||||
|             - ubuntu-toolchain-r-test | ||||
|  | ||||
|     - os: linux | ||||
|       compiler: g++-4.8 | ||||
|       env: TOOLSET=gcc COMPILER=g++-4.8 CXXSTD=03,11 | ||||
|       addons: | ||||
|         apt: | ||||
|           packages: | ||||
|             - g++-4.8 | ||||
|           sources: | ||||
|             - ubuntu-toolchain-r-test | ||||
|     - os: linux | ||||
|       compiler: g++-4.9 | ||||
|       env: TOOLSET=gcc COMPILER=g++-4.9 CXXSTD=03,11 | ||||
|       addons: | ||||
|         apt: | ||||
|           packages: | ||||
|             - g++-4.9 | ||||
|           sources: | ||||
|             - ubuntu-toolchain-r-test | ||||
|  | ||||
|     - os: linux | ||||
|       compiler: g++-5 | ||||
|       env: TOOLSET=gcc COMPILER=g++-5 CXXSTD=03,11,14,1z | ||||
|       addons: | ||||
|         apt: | ||||
|           packages: | ||||
|             - g++-5 | ||||
|           sources: | ||||
|             - ubuntu-toolchain-r-test | ||||
|  | ||||
|     - os: linux | ||||
|       compiler: g++-6 | ||||
|       env: TOOLSET=gcc COMPILER=g++-6 CXXSTD=03,11,14,1z | ||||
|       addons: | ||||
|         apt: | ||||
|           packages: | ||||
|             - g++-6 | ||||
|           sources: | ||||
|             - ubuntu-toolchain-r-test | ||||
|  | ||||
|     - os: linux | ||||
|       dist: trusty | ||||
|       compiler: g++-7 | ||||
|       env: TOOLSET=gcc COMPILER=g++-7 CXXSTD=03,11,14,17 | ||||
|       addons: | ||||
|         apt: | ||||
|           packages: | ||||
|             - g++-7 | ||||
|           sources: | ||||
|             - ubuntu-toolchain-r-test | ||||
|  | ||||
|     - os: linux | ||||
|       dist: trusty | ||||
|       compiler: g++-8 | ||||
|       env: TOOLSET=gcc COMPILER=g++-8 CXXSTD=03,11,14,17 | ||||
|       addons: | ||||
|         apt: | ||||
|           packages: | ||||
|             - g++-8 | ||||
|           sources: | ||||
|             - ubuntu-toolchain-r-test | ||||
|  | ||||
|     - os: linux | ||||
|       compiler: clang++ | ||||
|       env: TOOLSET=clang COMPILER=clang++ CXXSTD=03,11 | ||||
|  | ||||
|     - os: linux | ||||
|       compiler: clang++-3.5 | ||||
|       env: TOOLSET=clang COMPILER=clang++-3.5 CXXSTD=03,11 | ||||
|       addons: | ||||
|         apt: | ||||
|           packages: | ||||
|             - clang-3.5 | ||||
|           sources: | ||||
|             - ubuntu-toolchain-r-test | ||||
|             - llvm-toolchain-precise-3.5 | ||||
|  | ||||
|     - os: linux | ||||
|       compiler: clang++-3.6 | ||||
|       env: TOOLSET=clang COMPILER=clang++-3.6 CXXSTD=03,11,14,1z | ||||
|       addons: | ||||
|         apt: | ||||
|           packages: | ||||
|             - clang-3.6 | ||||
|             - libstdc++-5-dev | ||||
|           sources: | ||||
|             - ubuntu-toolchain-r-test | ||||
|             - llvm-toolchain-precise-3.6 | ||||
|  | ||||
|     - os: linux | ||||
|       compiler: clang++-3.7 | ||||
|       env: TOOLSET=clang COMPILER=clang++-3.7 CXXSTD=03,11,14,1z | ||||
|       addons: | ||||
|         apt: | ||||
|           packages: | ||||
|             - clang-3.7 | ||||
|             - libstdc++-5-dev | ||||
|           sources: | ||||
|             - ubuntu-toolchain-r-test | ||||
|             - llvm-toolchain-precise-3.7 | ||||
|  | ||||
|     - os: linux | ||||
|       compiler: clang++-3.8 | ||||
|       env: TOOLSET=clang COMPILER=clang++-3.8 CXXSTD=03,11,14,1z | ||||
|       addons: | ||||
|         apt: | ||||
|           packages: | ||||
|             - clang-3.8 | ||||
|             - libstdc++-5-dev | ||||
|           sources: | ||||
|             - ubuntu-toolchain-r-test | ||||
|             - llvm-toolchain-precise-3.8 | ||||
|  | ||||
|     - os: linux | ||||
|       compiler: clang++-3.9 | ||||
|       env: TOOLSET=clang COMPILER=clang++-3.9 CXXSTD=03,11,14,1z | ||||
|       addons: | ||||
|         apt: | ||||
|           packages: | ||||
|             - clang-3.9 | ||||
|             - libstdc++-5-dev | ||||
|           sources: | ||||
|             - ubuntu-toolchain-r-test | ||||
|             - llvm-toolchain-precise-3.9 | ||||
|  | ||||
|     - os: linux | ||||
|       compiler: clang++-4.0 | ||||
|       env: TOOLSET=clang COMPILER=clang++-4.0 CXXSTD=03,11,14,1z | ||||
|       addons: | ||||
|         apt: | ||||
|           packages: | ||||
|             - clang-4.0 | ||||
|             - libstdc++-5-dev | ||||
|           sources: | ||||
|             - ubuntu-toolchain-r-test | ||||
|             - llvm-toolchain-trusty-4.0 | ||||
|  | ||||
|     - os: linux | ||||
|       compiler: clang++-5.0 | ||||
|       env: TOOLSET=clang COMPILER=clang++-5.0 CXXSTD=03,11,14,1z | ||||
|       addons: | ||||
|         apt: | ||||
|           packages: | ||||
|             - clang-5.0 | ||||
|             - libstdc++-5-dev | ||||
|           sources: | ||||
|             - ubuntu-toolchain-r-test | ||||
|             - llvm-toolchain-trusty-5.0 | ||||
|  | ||||
|     - os: linux | ||||
|       compiler: clang++-6.0 | ||||
|       env: TOOLSET=clang COMPILER=clang++-6.0 CXXSTD=03,11,14,17 | ||||
|       addons: | ||||
|         apt: | ||||
|           packages: | ||||
|             - clang-6.0 | ||||
|             - libstdc++-5-dev | ||||
|           sources: | ||||
|             - ubuntu-toolchain-r-test | ||||
|             - llvm-toolchain-trusty-6.0 | ||||
|  | ||||
|     - os: linux | ||||
|       compiler: clang++-7 | ||||
|       env: TOOLSET=clang COMPILER=clang++-7 CXXSTD=03,11,14,17 | ||||
|       addons: | ||||
|         apt: | ||||
|           packages: | ||||
|             - clang-7 | ||||
|             - libstdc++-5-dev | ||||
|           sources: | ||||
|             - ubuntu-toolchain-r-test | ||||
|             - llvm-toolchain-trusty-7 | ||||
|  | ||||
|     - os: osx | ||||
|       compiler: clang++ | ||||
|       env: TOOLSET=clang COMPILER=clang++ CXXSTD=03,11,14,1z | ||||
|  | ||||
| install: | ||||
|   - GIT_FETCH_JOBS=8 | ||||
|   - BOOST_BRANCH=develop | ||||
|   - if [ "$TRAVIS_BRANCH" = "master" ]; then BOOST_BRANCH=master; fi | ||||
|   - 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/boost_install | ||||
|   - git submodule init libs/headers | ||||
|   - git submodule init libs/assert | ||||
|   - git submodule init libs/config | ||||
|   - git submodule init libs/core | ||||
|   - git submodule init libs/preprocessor | ||||
|   - git submodule init libs/static_assert | ||||
|   - git submodule init libs/throw_exception | ||||
|   - git submodule init libs/type_traits | ||||
|   - git submodule init libs/container_hash | ||||
|   - git submodule init libs/integer | ||||
|   - git submodule init libs/detail | ||||
|   - git submodule update --jobs $GIT_FETCH_JOBS | ||||
|   - cp -r $TRAVIS_BUILD_DIR/* libs/utility | ||||
|   - ./bootstrap.sh | ||||
|   - ./b2 headers | ||||
|  | ||||
| script: | ||||
|   - |- | ||||
|     echo "using $TOOLSET : : $COMPILER ;" > ~/user-config.jam | ||||
|   - BUILD_JOBS=`(nproc || sysctl -n hw.ncpu) 2> /dev/null` | ||||
|   - ./b2 -j $BUILD_JOBS libs/utility/test toolset=$TOOLSET cxxstd=$CXXSTD | ||||
|  | ||||
| notifications: | ||||
|   email: | ||||
|     on_success: always | ||||
							
								
								
									
										27
									
								
								CMakeLists.txt
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										27
									
								
								CMakeLists.txt
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,27 @@ | ||||
| # 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 | ||||
|  | ||||
| # Partial (add_subdirectory only) and experimental CMake support | ||||
| # Subject to change; please do not rely on the contents of this file yet. | ||||
|  | ||||
| cmake_minimum_required(VERSION 3.5) | ||||
|  | ||||
| project(BoostUtility LANGUAGES CXX) | ||||
|  | ||||
| add_library(boost_utility INTERFACE) | ||||
| add_library(Boost::utility ALIAS boost_utility) | ||||
|  | ||||
| target_include_directories(boost_utility INTERFACE include) | ||||
|  | ||||
| target_link_libraries(boost_utility | ||||
|     INTERFACE | ||||
|         Boost::config | ||||
|         Boost::container_hash | ||||
|         Boost::core | ||||
|         Boost::preprocessor | ||||
|         Boost::static_assert | ||||
|         Boost::throw_exception | ||||
|         Boost::type_traits | ||||
| ) | ||||
							
								
								
									
										24
									
								
								README.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										24
									
								
								README.md
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,24 @@ | ||||
| #  | ||||
|  | ||||
| Boost.Utility, part of collection of the [Boost C++ Libraries](https://github.com/boostorg), provides a number of smaller components, too small to be called libraries in their own right. See the documentation for the list of components. | ||||
|  | ||||
| ### Directories | ||||
|  | ||||
| * **doc** - Documentation sources | ||||
| * **include** - Interface headers of Boost.Utility | ||||
| * **test** - Boost.Utility unit tests | ||||
|  | ||||
| ### More information | ||||
|  | ||||
| * [Documentation](https://boost.org/libs/utility) | ||||
| * [Report bugs](https://github.com/boostorg/utility/issues/new). Be sure to mention Boost version, Boost.Utility component, platform and compiler you're using. A small compilable code sample to reproduce the problem is always good as well. | ||||
| * Submit your patches as pull requests against **develop** branch. Note that by submitting patches you agree to license your modifications under the [Boost Software License, Version 1.0](https://www.boost.org/LICENSE_1_0.txt). | ||||
|  | ||||
| ### Build status | ||||
|  | ||||
| Master: [](https://travis-ci.org/boostorg/utility) | ||||
| Develop: [](https://travis-ci.org/boostorg/utility) | ||||
|  | ||||
| ### License | ||||
|  | ||||
| Distributed under the [Boost Software License, Version 1.0](https://www.boost.org/LICENSE_1_0.txt). | ||||
							
								
								
									
										58
									
								
								appveyor.yml
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										58
									
								
								appveyor.yml
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,58 @@ | ||||
| # Copyright 2016-2019 Peter Dimov | ||||
| # 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: | ||||
|     - APPVEYOR_BUILD_WORKER_IMAGE: Visual Studio 2015 | ||||
|       TOOLSET: msvc-9.0,msvc-10.0,msvc-11.0 | ||||
|     - APPVEYOR_BUILD_WORKER_IMAGE: Visual Studio 2015 | ||||
|       TOOLSET: msvc-12.0,msvc-14.0 | ||||
|       ADDRMD: 32,64 | ||||
|     - APPVEYOR_BUILD_WORKER_IMAGE: Visual Studio 2017 | ||||
|       TOOLSET: msvc-14.1 | ||||
|       ADDRMD: 32,64 | ||||
|       CXXSTD: 14,17 | ||||
|  | ||||
| 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/boost_install | ||||
|   - git submodule init libs/headers | ||||
|   - git submodule init libs/assert | ||||
|   - git submodule init libs/config | ||||
|   - git submodule init libs/core | ||||
|   - git submodule init libs/preprocessor | ||||
|   - git submodule init libs/static_assert | ||||
|   - git submodule init libs/throw_exception | ||||
|   - git submodule init libs/type_traits | ||||
|   - git submodule init libs/container_hash | ||||
|   - git submodule init libs/integer | ||||
|   - git submodule init libs/detail | ||||
|   - git submodule update --jobs %GIT_FETCH_JOBS% | ||||
|   - xcopy /s /e /q %APPVEYOR_BUILD_FOLDER% libs\utility\ | ||||
|   - 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/utility/test toolset=%TOOLSET% %CXXSTD% %ADDRMD% variant=debug,release | ||||
| @@ -493,7 +493,7 @@ call_traits can not be used with reference or array types.</p> | ||||
| <h4>Example 1:</h4> | ||||
|  | ||||
| <p>The following class is a trivial class that stores some type T | ||||
| by value (see the <a href="call_traits_test.cpp">call_traits_test.cpp</a> | ||||
| by value (see the <a href="test/call_traits_test.cpp">call_traits_test.cpp</a> | ||||
| file), the aim is to illustrate how each of the available | ||||
| call_traits typedefs may be used:</p> | ||||
|  | ||||
|   | ||||
| @@ -99,6 +99,19 @@ boostbook standalone_declval | ||||
|         <xsl:param>generate.section.toc.level=1 | ||||
|      ; | ||||
|  | ||||
| xml ostream_string : ostream_string.qbk ; | ||||
| boostbook standalone_ostream_string | ||||
|     : | ||||
|         ostream_string | ||||
|     : | ||||
|         <xsl:param>root.filename=ostream_string | ||||
|         <xsl:param>chunk.section.depth=0 | ||||
|         <xsl:param>chunk.first.sections=0 | ||||
|         <xsl:param>toc.section.depth=1 | ||||
|         <xsl:param>toc.max.depth=1 | ||||
|         <xsl:param>generate.section.toc.level=1 | ||||
|      ; | ||||
|  | ||||
| xml string_ref : string_ref.qbk ; | ||||
| boostbook standalone_string_ref | ||||
|     : | ||||
| @@ -118,21 +131,10 @@ boostbook standalone_string_ref | ||||
|         <xsl:param>generate.section.toc.level=1 | ||||
|      ; | ||||
|  | ||||
| xml string_view : string_view.qbk ; | ||||
| boostbook standalone_string_view | ||||
|     : | ||||
|         string_view | ||||
|     : | ||||
|         # File name of HTML output: | ||||
|         <xsl:param>root.filename=string_view | ||||
|         # How far down we chunk nested sections, basically all of them: | ||||
|         <xsl:param>chunk.section.depth=0 | ||||
|         # Don't put the first section on the same page as the TOC: | ||||
|         <xsl:param>chunk.first.sections=0 | ||||
|         # How far down sections get TOC's | ||||
|         <xsl:param>toc.section.depth=1 | ||||
|         # Max depth in each TOC: | ||||
|         <xsl:param>toc.max.depth=1 | ||||
|         # How far down we go with TOC's | ||||
|         <xsl:param>generate.section.toc.level=1 | ||||
|      ; | ||||
| ############################################################################### | ||||
| alias boostdoc ; | ||||
| explicit boostdoc ; | ||||
| alias boostrelease : | ||||
|     standalone_base_from_member standalone_compressed_pair | ||||
|     standalone_declval standalone_ostream_string standalone_string_ref ; | ||||
| explicit boostrelease ; | ||||
|   | ||||
| @@ -356,7 +356,7 @@ templates that can be controlled and automated with macros. The | ||||
| implementation uses the [@../../../preprocessor/index.html Preprocessor library]. | ||||
|  | ||||
| * [@http://www.boost.org/people/daryle_walker.html">Daryle Walker] started the | ||||
| library. Contributed the test file [@../../base_from_member_test.cpp | ||||
| library. Contributed the test file [@../../test/base_from_member_test.cpp | ||||
| base_from_member_test.cpp]. | ||||
|  | ||||
| [endsect] | ||||
|   | ||||
| @@ -1,381 +0,0 @@ | ||||
| <html> | ||||
| <head> | ||||
| <meta http-equiv="Content-Type" content="text/html; charset=US-ASCII"> | ||||
| <title>String_View</title> | ||||
| <link rel="stylesheet" href="../../../../doc/src/boostbook.css" type="text/css"> | ||||
| <meta name="generator" content="DocBook XSL Stylesheets V1.77.1"> | ||||
| <link rel="home" href="string_view.html" title="String_View"> | ||||
| </head> | ||||
| <body bgcolor="white" text="black" link="#0000FF" vlink="#840084" alink="#0000FF"> | ||||
| <table cellpadding="2" width="100%"><tr> | ||||
| <td valign="top"><img alt="Boost C++ Libraries" width="277" height="86" src="../../../../boost.png"></td> | ||||
| <td align="center"><a href="../../../../index.html">Home</a></td> | ||||
| <td align="center"><a href="../../../../libs/libraries.htm">Libraries</a></td> | ||||
| <td align="center"><a href="http://www.boost.org/users/people.html">People</a></td> | ||||
| <td align="center"><a href="http://www.boost.org/users/faq.html">FAQ</a></td> | ||||
| <td align="center"><a href="../../../../more/index.htm">More</a></td> | ||||
| </tr></table> | ||||
| <hr> | ||||
| <div class="spirit-nav"></div> | ||||
| <div class="article"> | ||||
| <div class="titlepage"> | ||||
| <div> | ||||
| <div><h2 class="title"> | ||||
| <a name="string_view"></a>String_View</h2></div> | ||||
| <div><div class="authorgroup"> | ||||
| <div class="author"><h3 class="author"> | ||||
| <span class="firstname">Marshall</span> <span class="surname">Clow</span> | ||||
| </h3></div> | ||||
| <div class="author"><h3 class="author"> | ||||
| <span class="firstname">Beman</span> <span class="surname">Dawes</span> | ||||
| </h3></div> | ||||
| </div></div> | ||||
| <div><p class="copyright">Copyright © 2012 Marshall Clow</p></div> | ||||
| <div><p class="copyright">Copyright © 2015 Beman Dawes</p></div> | ||||
| <div><div class="legalnotice"> | ||||
| <a name="string_view.legal"></a><p> | ||||
|         Distributed under the Boost Software License, Version 1.0. <a href="http://www.boost.org/LICENSE_1_0.txt" target="_top">http://www.boost.org/LICENSE_1_0.txt</a> | ||||
|       </p> | ||||
| </div></div> | ||||
| </div> | ||||
| <hr> | ||||
| </div> | ||||
| <div class="toc"> | ||||
| <p><b>Table of Contents</b></p> | ||||
| <dl> | ||||
| <dt><span class="section"><a href="string_view.html#string_view.overview">Overview</a></span></dt> | ||||
| <dt><span class="section"><a href="string_view.html#string_view.examples">Examples</a></span></dt> | ||||
| <dt><span class="section"><a href="string_view.html#string_view.reference">Reference </a></span></dt> | ||||
| <dt><span class="section"><a href="string_view.html#string_view.compiler_support">Compiler Support</a></span></dt> | ||||
| <dt><span class="section"><a href="string_view.html#string_view.history">History</a></span></dt> | ||||
| </dl> | ||||
| </div> | ||||
| <div class="section"> | ||||
| <div class="titlepage"><div><div><h2 class="title" style="clear: both"> | ||||
| <a name="string_view.overview"></a><a class="link" href="string_view.html#string_view.overview" title="Overview">Overview</a> | ||||
| </h2></div></div></div> | ||||
| <p> | ||||
|       Boost.StringView is an implementation of <code class="computeroutput"><span class="identifier">string_view</span></code> | ||||
|       as specified in <a href="http://www.open-std.org/jtc1/sc22/wg21/docs/papers/2015/n4480.html#string.view" target="_top">N4480: | ||||
|       ISO/IEC DTS 19568, Technical Specification - C++ Extensions for Library Fundamentals</a>. | ||||
|     </p> | ||||
| <p> | ||||
|       When you are parsing/processing strings from some external source, frequently | ||||
|       you want to pass a piece of text to a procedure for specialized processing. | ||||
|       The canonical way to do this is as a <code class="computeroutput"><span class="identifier">std</span><span class="special">::</span><span class="identifier">string</span></code>, | ||||
|       but that has certain drawbacks: | ||||
|     </p> | ||||
| <p> | ||||
|       1) If you are processing a buffer of text (say a HTTP response or the contents | ||||
|       of a file), then you have to create the string from the text you want to pass, | ||||
|       which involves memory allocation and copying of data. | ||||
|     </p> | ||||
| <p> | ||||
|       2) if a routine receives a constant <code class="computeroutput"><span class="identifier">std</span><span class="special">::</span><span class="identifier">string</span></code> | ||||
|       and wants to pass a portion of that string to another routine, then it must | ||||
|       create a new string of that substring. | ||||
|     </p> | ||||
| <p> | ||||
|       3) A routine receives a constant <code class="computeroutput"><span class="identifier">std</span><span class="special">::</span><span class="identifier">string</span></code> | ||||
|       and wants to return a portion of the string, then it must create a new string | ||||
|       to return. | ||||
|     </p> | ||||
| <p> | ||||
|       <code class="computeroutput"><span class="identifier">string_view</span></code> is designed to | ||||
|       solve these efficiency problems. A <code class="computeroutput"><span class="identifier">string_view</span></code> | ||||
|       is a read-only reference to a contiguous sequence of characters, and provides | ||||
|       much of the functionality of <code class="computeroutput"><span class="identifier">std</span><span class="special">::</span><span class="identifier">string</span></code>. | ||||
|       A <code class="computeroutput"><span class="identifier">string_view</span></code> is cheap to create, | ||||
|       copy and pass by value, because it does not actually own the storage that it | ||||
|       points to. | ||||
|     </p> | ||||
| <p> | ||||
|       A <code class="computeroutput"><span class="identifier">string_view</span></code> is implemented | ||||
|       as a small struct that contains a pointer to the start of the character data | ||||
|       and a count. A <code class="computeroutput"><span class="identifier">string_view</span></code> | ||||
|       is cheap to create and cheap to copy. | ||||
|     </p> | ||||
| <p> | ||||
|       <code class="computeroutput"><span class="identifier">string_view</span></code> acts as a container; | ||||
|       it includes all the methods that you would expect in a container, including | ||||
|       iteration support, <code class="computeroutput"><span class="keyword">operator</span> <span class="special">[]</span></code>, | ||||
|       <code class="computeroutput"><span class="identifier">at</span></code> and <code class="computeroutput"><span class="identifier">size</span></code>. | ||||
|       It can be used with any of the iterator-based algorithms in the STL - as long | ||||
|       as you don't need to change the underlying data (<code class="computeroutput"><span class="identifier">sort</span></code> | ||||
|       and <code class="computeroutput"><span class="identifier">remove</span></code>, for example, will | ||||
|       not work) | ||||
|     </p> | ||||
| <p> | ||||
|       Besides generic container functionality, <code class="computeroutput"><span class="identifier">string_view</span></code> | ||||
|       provides a subset of the interface of <code class="computeroutput"><span class="identifier">std</span><span class="special">::</span><span class="identifier">string</span></code>. | ||||
|       This makes it easy to replace parameters of type <code class="computeroutput"><span class="keyword">const</span> | ||||
|       <span class="identifier">std</span><span class="special">::</span><span class="identifier">string</span> <span class="special">&</span></code> | ||||
|       with <code class="computeroutput"><span class="identifier">boost</span><span class="special">::</span><span class="identifier">string_view</span></code>. Like <code class="computeroutput"><span class="identifier">std</span><span class="special">::</span><span class="identifier">string</span></code>, | ||||
|       <code class="computeroutput"><span class="identifier">string_view</span></code> has a static member | ||||
|       variable named <code class="computeroutput"><span class="identifier">npos</span></code> to denote | ||||
|       the result of failed searches, and to mean "the end". | ||||
|     </p> | ||||
| <p> | ||||
|       Because a <code class="computeroutput"><span class="identifier">string_view</span></code> does | ||||
|       not own the data that it "points to", it introduces lifetime issues | ||||
|       into code that uses it. The programmer must ensure that the data that a <code class="computeroutput"><span class="identifier">string_view</span></code> refers to exists as long as the | ||||
|       <code class="computeroutput"><span class="identifier">string_view</span></code> does. | ||||
|     </p> | ||||
| <p> | ||||
|       Note: The header actually contains a class template, <code class="computeroutput"><span class="identifier">basic_string_view</span></code> | ||||
|       and four typedefs: | ||||
|     </p> | ||||
| <pre class="programlisting"><span class="keyword">template</span><span class="special"><</span><span class="keyword">class</span> <span class="identifier">charT</span><span class="special">,</span> <span class="keyword">class</span> <span class="identifier">traits</span> <span class="special">=</span> <span class="identifier">char_traits</span><span class="special"><</span><span class="identifier">charT</span><span class="special">>></span> | ||||
|     <span class="keyword">class</span> <span class="identifier">basic_string_view</span><span class="special">;</span> | ||||
|  | ||||
| <span class="keyword">typedef</span> <span class="identifier">basic_string_view</span><span class="special"><</span><span class="keyword">char</span><span class="special">></span>     <span class="identifier">string_view</span><span class="special">;</span> | ||||
| <span class="keyword">typedef</span> <span class="identifier">basic_string_view</span><span class="special"><</span><span class="keyword">char16_t</span><span class="special">></span> <span class="identifier">u16string_view</span><span class="special">;</span> | ||||
| <span class="keyword">typedef</span> <span class="identifier">basic_string_view</span><span class="special"><</span><span class="keyword">char32_t</span><span class="special">></span> <span class="identifier">u32string_view</span><span class="special">;</span> | ||||
| <span class="keyword">typedef</span> <span class="identifier">basic_string_view</span><span class="special"><</span><span class="keyword">wchar_t</span><span class="special">></span>  <span class="identifier">wstring_view</span><span class="special">;</span> | ||||
| </pre> | ||||
| <p> | ||||
|       So you can have views of strings of any of the four built-in character types | ||||
|       as well as strings of user-defined character-like type strings. For the sake | ||||
|       of simple exposition, we concentrate on <code class="computeroutput"><span class="identifier">string_view</span></code> | ||||
|       (i.e. <code class="computeroutput"><span class="keyword">char</span></code> strings) in this documentation. | ||||
|     </p> | ||||
| </div> | ||||
| <div class="section"> | ||||
| <div class="titlepage"><div><div><h2 class="title" style="clear: both"> | ||||
| <a name="string_view.examples"></a><a class="link" href="string_view.html#string_view.examples" title="Examples">Examples</a> | ||||
| </h2></div></div></div> | ||||
| <p> | ||||
|       Integrating <code class="computeroutput"><span class="identifier">string_view</span></code> into | ||||
|       your code is fairly simple. Wherever you pass a <code class="computeroutput"><span class="keyword">const</span> | ||||
|       <span class="identifier">std</span><span class="special">::</span><span class="identifier">string</span> <span class="special">&</span></code> | ||||
|       or <code class="computeroutput"><span class="identifier">std</span><span class="special">::</span><span class="identifier">string</span></code> as a parameter, that's a candidate | ||||
|       for passing a <code class="computeroutput"><span class="identifier">boost</span><span class="special">::</span><span class="identifier">string_view</span></code>. | ||||
|     </p> | ||||
| <pre class="programlisting"><span class="identifier">std</span><span class="special">::</span><span class="identifier">string</span> <span class="identifier">extract_part</span> <span class="special">(</span> <span class="keyword">const</span> <span class="identifier">std</span><span class="special">::</span><span class="identifier">string</span> <span class="special">&</span><span class="identifier">bar</span> <span class="special">)</span> <span class="special">{</span> | ||||
|     <span class="keyword">return</span> <span class="identifier">bar</span><span class="special">.</span><span class="identifier">substr</span> <span class="special">(</span> <span class="number">2</span><span class="special">,</span> <span class="number">3</span> <span class="special">);</span> | ||||
|     <span class="special">}</span> | ||||
|  | ||||
| <span class="keyword">if</span> <span class="special">(</span> <span class="identifier">extract_part</span> <span class="special">(</span> <span class="string">"ABCDEFG"</span> <span class="special">).</span><span class="identifier">front</span><span class="special">()</span> <span class="special">==</span> <span class="char">'C'</span> <span class="special">)</span> <span class="special">{</span> <span class="comment">/* do something */</span> <span class="special">}</span> | ||||
| </pre> | ||||
| <p> | ||||
|       Let's figure out what happens in this (contrived) example. | ||||
|     </p> | ||||
| <p> | ||||
|       First, a temporary string is created from the string literal <code class="computeroutput"><span class="string">"ABCDEFG"</span></code>, and it is passed (by reference) | ||||
|       to the routine <code class="computeroutput"><span class="identifier">extract_part</span></code>. | ||||
|       Then a second string is created in the call <code class="computeroutput"><span class="identifier">std</span><span class="special">::</span><span class="identifier">string</span><span class="special">::</span><span class="identifier">substr</span></code> | ||||
|       and returned to <code class="computeroutput"><span class="identifier">extract_part</span></code> | ||||
|       (this copy may be elided by RVO). Then <code class="computeroutput"><span class="identifier">extract_part</span></code> | ||||
|       returns that string back to the caller (again this copy may be elided). The | ||||
|       first temporary string is deallocated, and <code class="computeroutput"><span class="identifier">front</span></code> | ||||
|       is called on the second string, and then it is deallocated as well. | ||||
|     </p> | ||||
| <p> | ||||
|       Two <code class="computeroutput"><span class="identifier">std</span><span class="special">::</span><span class="identifier">string</span></code>s are created, and two copy operations. | ||||
|       That's (potentially) four memory allocations and deallocations, and the associated | ||||
|       copying of data. | ||||
|     </p> | ||||
| <p> | ||||
|       Now let's look at the same code with <code class="computeroutput"><span class="identifier">string_view</span></code>: | ||||
|     </p> | ||||
| <pre class="programlisting"><span class="identifier">boost</span><span class="special">::</span><span class="identifier">string_view</span> <span class="identifier">extract_part</span> <span class="special">(</span> <span class="identifier">boost</span><span class="special">::</span><span class="identifier">string_view</span> <span class="identifier">bar</span> <span class="special">)</span> <span class="special">{</span> | ||||
|     <span class="keyword">return</span> <span class="identifier">bar</span><span class="special">.</span><span class="identifier">substr</span> <span class="special">(</span> <span class="number">2</span><span class="special">,</span> <span class="number">3</span> <span class="special">);</span> | ||||
|     <span class="special">}</span> | ||||
|  | ||||
| <span class="keyword">if</span> <span class="special">(</span> <span class="identifier">extract_part</span> <span class="special">(</span> <span class="string">"ABCDEFG"</span> <span class="special">).</span><span class="identifier">front</span><span class="special">()</span> <span class="special">==</span> <span class="string">"C"</span> <span class="special">)</span> <span class="special">{</span> <span class="comment">/* do something */</span> <span class="special">}</span> | ||||
| </pre> | ||||
| <p> | ||||
|       No memory allocations. No copying of character data. No changes to the code | ||||
|       other than the types. There are two <code class="computeroutput"><span class="identifier">string_view</span></code>s | ||||
|       created, and two <code class="computeroutput"><span class="identifier">string_view</span></code>s | ||||
|       copied, but those are cheap operations. | ||||
|     </p> | ||||
| </div> | ||||
| <div class="section"> | ||||
| <div class="titlepage"><div><div><h2 class="title" style="clear: both"> | ||||
| <a name="string_view.reference"></a><a class="link" href="string_view.html#string_view.reference" title="Reference">Reference </a> | ||||
| </h2></div></div></div> | ||||
| <p> | ||||
|       The header file "string_view.hpp" defines a class template <code class="computeroutput"><span class="identifier">boost</span><span class="special">::</span><span class="identifier">basic_string_view</span></code>, | ||||
|       and four specializations - for <code class="computeroutput"><span class="keyword">char</span></code> | ||||
|       / <code class="computeroutput"><span class="keyword">wchar_t</span></code> / <code class="computeroutput"><span class="keyword">char16_t</span></code> | ||||
|       / <code class="computeroutput"><span class="keyword">char32_t</span></code> . | ||||
|     </p> | ||||
| <p> | ||||
|       <code class="computeroutput"><span class="preprocessor">#include</span> <span class="special"><</span><span class="identifier">boost</span><span class="special">/</span><span class="identifier">utility</span><span class="special">/</span><span class="identifier">string_view</span><span class="special">.</span><span class="identifier">hpp</span><span class="special">></span></code> | ||||
|     </p> | ||||
| <p> | ||||
|       Types: | ||||
|     </p> | ||||
| <pre class="programlisting"><span class="keyword">typedef</span> <span class="identifier">traits</span> <span class="identifier">traits_type</span><span class="special">;</span> | ||||
| <span class="keyword">typedef</span> <span class="identifier">charT</span> <span class="identifier">value_type</span><span class="special">;</span> | ||||
| <span class="keyword">typedef</span> <span class="identifier">charT</span><span class="special">*</span> <span class="identifier">pointer</span><span class="special">;</span> | ||||
| <span class="keyword">typedef</span> <span class="keyword">const</span> <span class="identifier">charT</span><span class="special">*</span> <span class="identifier">const_pointer</span><span class="special">;</span> | ||||
| <span class="keyword">typedef</span> <span class="identifier">charT</span><span class="special">&</span> <span class="identifier">reference</span><span class="special">;</span> | ||||
| <span class="keyword">typedef</span> <span class="keyword">const</span> <span class="identifier">charT</span><span class="special">&</span> <span class="identifier">const_reference</span><span class="special">;</span> | ||||
| <span class="keyword">typedef</span> <span class="identifier">const_pointer</span> <span class="identifier">const_iterator</span><span class="special">;</span>  <span class="comment">// implementation defined</span> | ||||
| <span class="keyword">typedef</span> <span class="identifier">const_iterator</span> <span class="identifier">iterator</span><span class="special">;</span> | ||||
| <span class="keyword">typedef</span> <span class="identifier">std</span><span class="special">::</span><span class="identifier">reverse_iterator</span><span class="special"><</span><span class="identifier">const_iterator</span><span class="special">></span> <span class="identifier">const_reverse_iterator</span><span class="special">;</span> | ||||
| <span class="keyword">typedef</span> <span class="identifier">const_reverse_iterator</span> <span class="identifier">reverse_iterator</span><span class="special">;</span> | ||||
| <span class="keyword">typedef</span> <span class="identifier">std</span><span class="special">::</span><span class="identifier">size_t</span> <span class="identifier">size_type</span><span class="special">;</span> | ||||
| <span class="keyword">typedef</span> <span class="identifier">std</span><span class="special">::</span><span class="identifier">ptrdiff_t</span> <span class="identifier">difference_type</span><span class="special">;</span> | ||||
| <span class="keyword">static</span> <span class="identifier">BOOST_CONSTEXPR_OR_CONST</span> <span class="identifier">size_type</span> <span class="identifier">npos</span> <span class="special">=</span> <span class="identifier">size_type</span><span class="special">(-</span><span class="number">1</span><span class="special">);</span> | ||||
| </pre> | ||||
| <p> | ||||
|       Construction and copying: | ||||
|     </p> | ||||
| <pre class="programlisting"><span class="identifier">BOOST_CONSTEXPR</span> <span class="identifier">basic_string_view</span> <span class="special">()</span> <span class="identifier">BOOST_NOEXCEPT</span><span class="special">;</span>    <span class="comment">// Constructs empty string_view</span> | ||||
| <span class="identifier">BOOST_CONSTEXPR</span> <span class="identifier">basic_string_view</span> <span class="special">(</span><span class="keyword">const</span> <span class="identifier">basic_string_view</span> <span class="special">&</span><span class="identifier">rhs</span><span class="special">)</span> <span class="identifier">BOOST_NOEXCEPT</span><span class="special">;</span> | ||||
| <span class="identifier">basic_string_view</span><span class="special">&</span> <span class="keyword">operator</span><span class="special">=(</span><span class="keyword">const</span> <span class="identifier">basic_string_view</span> <span class="special">&</span><span class="identifier">rhs</span><span class="special">)</span> <span class="identifier">BOOST_NOEXCEPT</span><span class="special">;</span> | ||||
| <span class="keyword">template</span><span class="special"><</span><span class="keyword">typename</span> <span class="identifier">Allocator</span><span class="special">></span> | ||||
|   <span class="identifier">basic_string_view</span><span class="special">(</span><span class="keyword">const</span> <span class="identifier">std</span><span class="special">::</span><span class="identifier">basic_string</span><span class="special"><</span><span class="identifier">charT</span><span class="special">,</span> <span class="identifier">traits</span><span class="special">,</span> <span class="identifier">Allocator</span><span class="special">>&</span> <span class="identifier">str</span><span class="special">)</span> <span class="identifier">BOOST_NOEXCEPT</span><span class="special">;</span> <span class="comment">// Ctor from std::string</span> | ||||
| <span class="identifier">BOOST_CONSTEXPR</span> <span class="identifier">basic_string_view</span><span class="special">(</span><span class="keyword">const</span> <span class="identifier">charT</span><span class="special">*</span> <span class="identifier">str</span><span class="special">);</span> <span class="comment">// Ctor from NULL-terminated string</span> | ||||
| <span class="identifier">BOOST_CONSTEXPR</span> <span class="identifier">basic_string_view</span><span class="special">(</span><span class="keyword">const</span> <span class="identifier">charT</span><span class="special">*</span> <span class="identifier">str</span><span class="special">,</span> <span class="identifier">size_type</span> <span class="identifier">len</span><span class="special">);</span> <span class="comment">// Ctor from pointer, length pair</span> | ||||
| </pre> | ||||
| <p> | ||||
|       <code class="computeroutput"><span class="identifier">string_view</span></code> does not define | ||||
|       a move constructor or a move-assignment operator because copying a <code class="computeroutput"><span class="identifier">string_view</span></code> is just as cheap as moving one | ||||
|       would be. | ||||
|     </p> | ||||
| <p> | ||||
|       Basic container-like functions: | ||||
|     </p> | ||||
| <pre class="programlisting"><span class="identifier">BOOST_CONSTEXPR</span> <span class="identifier">size_type</span> <span class="identifier">size</span><span class="special">()</span>     <span class="keyword">const</span> <span class="identifier">BOOST_NOEXCEPT</span> <span class="special">;</span> | ||||
| <span class="identifier">BOOST_CONSTEXPR</span> <span class="identifier">size_type</span> <span class="identifier">length</span><span class="special">()</span>   <span class="keyword">const</span> <span class="identifier">BOOST_NOEXCEPT</span> <span class="special">;</span> | ||||
| <span class="identifier">BOOST_CONSTEXPR</span> <span class="identifier">size_type</span> <span class="identifier">max_size</span><span class="special">()</span> <span class="keyword">const</span> <span class="identifier">BOOST_NOEXCEPT</span> <span class="special">;</span> | ||||
| <span class="identifier">BOOST_CONSTEXPR</span> <span class="keyword">bool</span> <span class="identifier">empty</span><span class="special">()</span>         <span class="keyword">const</span> <span class="identifier">BOOST_NOEXCEPT</span> <span class="special">;</span> | ||||
|  | ||||
| <span class="comment">// All iterators are const_iterators</span> | ||||
| <span class="identifier">BOOST_CONSTEXPR</span> <span class="identifier">const_iterator</span>  <span class="identifier">begin</span><span class="special">()</span> <span class="keyword">const</span> <span class="identifier">BOOST_NOEXCEPT</span> <span class="special">;</span> | ||||
| <span class="identifier">BOOST_CONSTEXPR</span> <span class="identifier">const_iterator</span> <span class="identifier">cbegin</span><span class="special">()</span> <span class="keyword">const</span> <span class="identifier">BOOST_NOEXCEPT</span> <span class="special">;</span> | ||||
| <span class="identifier">BOOST_CONSTEXPR</span> <span class="identifier">const_iterator</span>    <span class="identifier">end</span><span class="special">()</span> <span class="keyword">const</span> <span class="identifier">BOOST_NOEXCEPT</span> <span class="special">;</span> | ||||
| <span class="identifier">BOOST_CONSTEXPR</span> <span class="identifier">const_iterator</span>   <span class="identifier">cend</span><span class="special">()</span> <span class="keyword">const</span> <span class="identifier">BOOST_NOEXCEPT</span> <span class="special">;</span> | ||||
| <span class="identifier">const_reverse_iterator</span>         <span class="identifier">rbegin</span><span class="special">()</span> <span class="keyword">const</span> <span class="identifier">BOOST_NOEXCEPT</span> <span class="special">;</span> | ||||
| <span class="identifier">const_reverse_iterator</span>        <span class="identifier">crbegin</span><span class="special">()</span> <span class="keyword">const</span> <span class="identifier">BOOST_NOEXCEPT</span> <span class="special">;</span> | ||||
| <span class="identifier">const_reverse_iterator</span>           <span class="identifier">rend</span><span class="special">()</span> <span class="keyword">const</span> <span class="identifier">BOOST_NOEXCEPT</span> <span class="special">;</span> | ||||
| <span class="identifier">const_reverse_iterator</span>          <span class="identifier">crend</span><span class="special">()</span> <span class="keyword">const</span> <span class="identifier">BOOST_NOEXCEPT</span> <span class="special">;</span> | ||||
| </pre> | ||||
| <p> | ||||
|       Access to the individual elements (all of which are const): | ||||
|     </p> | ||||
| <pre class="programlisting"><span class="identifier">BOOST_CONSTEXPR</span> <span class="keyword">const</span> <span class="identifier">charT</span><span class="special">&</span> <span class="keyword">operator</span><span class="special">[](</span><span class="identifier">size_type</span> <span class="identifier">pos</span><span class="special">)</span> <span class="keyword">const</span> <span class="special">;</span> | ||||
| <span class="identifier">BOOST_CONSTEXPR</span> <span class="keyword">const</span> <span class="identifier">charT</span><span class="special">&</span> <span class="identifier">at</span><span class="special">(</span><span class="identifier">size_t</span> <span class="identifier">pos</span><span class="special">)</span> <span class="keyword">const</span> <span class="special">;</span> | ||||
| <span class="identifier">BOOST_CONSTEXPR</span> <span class="keyword">const</span> <span class="identifier">charT</span><span class="special">&</span> <span class="identifier">front</span><span class="special">()</span> <span class="keyword">const</span> <span class="special">;</span> | ||||
| <span class="identifier">BOOST_CONSTEXPR</span> <span class="keyword">const</span> <span class="identifier">charT</span><span class="special">&</span> <span class="identifier">back</span><span class="special">()</span>  <span class="keyword">const</span> <span class="special">;</span> | ||||
| <span class="identifier">BOOST_CONSTEXPR</span> <span class="keyword">const</span> <span class="identifier">charT</span><span class="special">*</span> <span class="identifier">data</span><span class="special">()</span>  <span class="keyword">const</span> <span class="identifier">BOOST_NOEXCEPT</span> <span class="special">;</span> | ||||
| </pre> | ||||
| <p> | ||||
|       Modifying the <code class="computeroutput"><span class="identifier">string_view</span></code> (but | ||||
|       not the underlying data): | ||||
|     </p> | ||||
| <pre class="programlisting"><span class="keyword">void</span> <span class="identifier">clear</span><span class="special">();</span>  <span class="comment">// boost extension</span> | ||||
| <span class="identifier">BOOST_CXX14_CONSTEXPR</span> <span class="keyword">void</span> <span class="identifier">remove_prefix</span><span class="special">(</span><span class="identifier">size_type</span> <span class="identifier">n</span><span class="special">);</span> | ||||
| <span class="identifier">BOOST_CXX14_CONSTEXPR</span> <span class="keyword">void</span> <span class="identifier">remove_suffix</span><span class="special">(</span><span class="identifier">size_type</span> <span class="identifier">n</span><span class="special">);</span> | ||||
| <span class="identifier">BOOST_CXX14_CONSTEXPR</span> <span class="keyword">void</span> <span class="identifier">swap</span><span class="special">(</span><span class="identifier">basic_string_view</span><span class="special">&</span> <span class="identifier">s</span><span class="special">)</span> <span class="identifier">BOOST_NOEXCEPT</span><span class="special">;</span> | ||||
| </pre> | ||||
| <p> | ||||
|       Searching: | ||||
|     </p> | ||||
| <pre class="programlisting"><span class="identifier">BOOST_CXX14_CONSTEXPR</span> <span class="identifier">size_type</span> <span class="identifier">find</span><span class="special">(</span><span class="identifier">basic_string_view</span> <span class="identifier">s</span><span class="special">,</span> <span class="identifier">size_type</span> <span class="identifier">pos</span> <span class="special">=</span> <span class="number">0</span><span class="special">)</span> <span class="keyword">const</span> <span class="identifier">BOOST_NOEXCEPT</span><span class="special">;</span> | ||||
| <span class="identifier">BOOST_CXX14_CONSTEXPR</span> <span class="identifier">size_type</span> <span class="identifier">find</span><span class="special">(</span><span class="identifier">charT</span> <span class="identifier">c</span><span class="special">,</span> <span class="identifier">size_type</span> <span class="identifier">pos</span> <span class="special">=</span> <span class="number">0</span><span class="special">)</span> <span class="keyword">const</span> <span class="identifier">BOOST_NOEXCEPT</span><span class="special">;</span> | ||||
| <span class="identifier">BOOST_CXX14_CONSTEXPR</span> <span class="identifier">size_type</span> <span class="identifier">find</span><span class="special">(</span><span class="keyword">const</span> <span class="identifier">charT</span><span class="special">*</span> <span class="identifier">s</span><span class="special">,</span> <span class="identifier">size_type</span> <span class="identifier">pos</span><span class="special">,</span> <span class="identifier">size_type</span> <span class="identifier">n</span><span class="special">)</span> <span class="keyword">const</span><span class="special">;</span> | ||||
| <span class="identifier">BOOST_CXX14_CONSTEXPR</span> <span class="identifier">size_type</span> <span class="identifier">find</span><span class="special">(</span><span class="keyword">const</span> <span class="identifier">charT</span><span class="special">*</span> <span class="identifier">s</span><span class="special">,</span> <span class="identifier">size_type</span> <span class="identifier">pos</span> <span class="special">=</span> <span class="number">0</span><span class="special">)</span> <span class="keyword">const</span><span class="special">;</span> | ||||
|  | ||||
| <span class="identifier">BOOST_CXX14_CONSTEXPR</span> <span class="identifier">size_type</span> <span class="identifier">rfind</span><span class="special">(</span><span class="identifier">basic_string_view</span> <span class="identifier">s</span><span class="special">,</span> <span class="identifier">size_type</span> <span class="identifier">pos</span> <span class="special">=</span> <span class="identifier">npos</span><span class="special">)</span> <span class="keyword">const</span> <span class="identifier">BOOST_NOEXCEPT</span><span class="special">;</span> | ||||
| <span class="identifier">BOOST_CXX14_CONSTEXPR</span> <span class="identifier">size_type</span> <span class="identifier">rfind</span><span class="special">(</span><span class="identifier">charT</span> <span class="identifier">c</span><span class="special">,</span> <span class="identifier">size_type</span> <span class="identifier">pos</span> <span class="special">=</span> <span class="identifier">npos</span><span class="special">)</span> <span class="keyword">const</span> <span class="identifier">BOOST_NOEXCEPT</span><span class="special">;</span> | ||||
| <span class="identifier">BOOST_CXX14_CONSTEXPR</span> <span class="identifier">size_type</span> <span class="identifier">rfind</span><span class="special">(</span><span class="keyword">const</span> <span class="identifier">charT</span><span class="special">*</span> <span class="identifier">s</span><span class="special">,</span> <span class="identifier">size_type</span> <span class="identifier">pos</span><span class="special">,</span> <span class="identifier">size_type</span> <span class="identifier">n</span><span class="special">)</span> <span class="keyword">const</span><span class="special">;</span> | ||||
| <span class="identifier">BOOST_CXX14_CONSTEXPR</span> <span class="identifier">size_type</span> <span class="identifier">rfind</span><span class="special">(</span><span class="keyword">const</span> <span class="identifier">charT</span><span class="special">*</span> <span class="identifier">s</span><span class="special">,</span> <span class="identifier">size_type</span> <span class="identifier">pos</span> <span class="special">=</span> <span class="identifier">npos</span><span class="special">)</span> <span class="keyword">const</span><span class="special">;</span> | ||||
|  | ||||
| <span class="identifier">BOOST_CXX14_CONSTEXPR</span> <span class="identifier">size_type</span> <span class="identifier">find_first_of</span><span class="special">(</span><span class="identifier">basic_string_view</span> <span class="identifier">s</span><span class="special">,</span> <span class="identifier">size_type</span> <span class="identifier">pos</span> <span class="special">=</span> <span class="number">0</span><span class="special">)</span> <span class="keyword">const</span> <span class="identifier">BOOST_NOEXCEPT</span><span class="special">;</span> | ||||
| <span class="identifier">BOOST_CXX14_CONSTEXPR</span> <span class="identifier">size_type</span> <span class="identifier">find_first_of</span><span class="special">(</span><span class="identifier">charT</span> <span class="identifier">c</span><span class="special">,</span> <span class="identifier">size_type</span> <span class="identifier">pos</span> <span class="special">=</span> <span class="number">0</span><span class="special">)</span> <span class="keyword">const</span> <span class="identifier">BOOST_NOEXCEPT</span><span class="special">;</span> | ||||
| <span class="identifier">BOOST_CXX14_CONSTEXPR</span> <span class="identifier">size_type</span> <span class="identifier">find_first_of</span><span class="special">(</span><span class="keyword">const</span> <span class="identifier">charT</span><span class="special">*</span> <span class="identifier">s</span><span class="special">,</span> <span class="identifier">size_type</span> <span class="identifier">pos</span><span class="special">,</span> <span class="identifier">size_type</span> <span class="identifier">n</span><span class="special">)</span> <span class="keyword">const</span><span class="special">;</span> | ||||
| <span class="identifier">BOOST_CXX14_CONSTEXPR</span> <span class="identifier">size_type</span> <span class="identifier">find_first_of</span><span class="special">(</span><span class="keyword">const</span> <span class="identifier">charT</span><span class="special">*</span> <span class="identifier">s</span><span class="special">,</span> <span class="identifier">size_type</span> <span class="identifier">pos</span> <span class="special">=</span> <span class="number">0</span><span class="special">)</span> <span class="keyword">const</span><span class="special">;</span> | ||||
|  | ||||
| <span class="identifier">BOOST_CXX14_CONSTEXPR</span> <span class="identifier">size_type</span> <span class="identifier">find_last_of</span><span class="special">(</span><span class="identifier">basic_string_view</span> <span class="identifier">s</span><span class="special">,</span> <span class="identifier">size_type</span> <span class="identifier">pos</span> <span class="special">=</span> <span class="identifier">npos</span><span class="special">)</span> <span class="keyword">const</span> <span class="identifier">BOOST_NOEXCEPT</span><span class="special">;</span> | ||||
| <span class="identifier">BOOST_CXX14_CONSTEXPR</span> <span class="identifier">size_type</span> <span class="identifier">find_last_of</span><span class="special">(</span><span class="identifier">charT</span> <span class="identifier">c</span><span class="special">,</span> <span class="identifier">size_type</span> <span class="identifier">pos</span> <span class="special">=</span> <span class="identifier">npos</span><span class="special">)</span> <span class="keyword">const</span> <span class="identifier">BOOST_NOEXCEPT</span><span class="special">;</span> | ||||
| <span class="identifier">BOOST_CXX14_CONSTEXPR</span> <span class="identifier">size_type</span> <span class="identifier">find_last_of</span><span class="special">(</span><span class="keyword">const</span> <span class="identifier">charT</span><span class="special">*</span> <span class="identifier">s</span><span class="special">,</span> <span class="identifier">size_type</span> <span class="identifier">pos</span><span class="special">,</span> <span class="identifier">size_type</span> <span class="identifier">n</span><span class="special">)</span> <span class="keyword">const</span><span class="special">;</span> | ||||
| <span class="identifier">BOOST_CXX14_CONSTEXPR</span> <span class="identifier">size_type</span> <span class="identifier">find_last_of</span><span class="special">(</span><span class="keyword">const</span> <span class="identifier">charT</span><span class="special">*</span> <span class="identifier">s</span><span class="special">,</span> <span class="identifier">size_type</span> <span class="identifier">pos</span> <span class="special">=</span> <span class="identifier">npos</span><span class="special">)</span> <span class="keyword">const</span><span class="special">;</span> | ||||
|  | ||||
| <span class="identifier">BOOST_CXX14_CONSTEXPR</span> <span class="identifier">size_type</span> <span class="identifier">find_first_not_of</span><span class="special">(</span><span class="identifier">basic_string_view</span> <span class="identifier">s</span><span class="special">,</span> <span class="identifier">size_type</span> <span class="identifier">pos</span> <span class="special">=</span> <span class="number">0</span><span class="special">)</span> <span class="keyword">const</span> <span class="identifier">BOOST_NOEXCEPT</span><span class="special">;</span> | ||||
| <span class="identifier">BOOST_CXX14_CONSTEXPR</span> <span class="identifier">size_type</span> <span class="identifier">find_first_not_of</span><span class="special">(</span><span class="identifier">charT</span> <span class="identifier">c</span><span class="special">,</span> <span class="identifier">size_type</span> <span class="identifier">pos</span> <span class="special">=</span> <span class="number">0</span><span class="special">)</span> <span class="keyword">const</span> <span class="identifier">BOOST_NOEXCEPT</span><span class="special">;</span> | ||||
| <span class="identifier">BOOST_CXX14_CONSTEXPR</span> <span class="identifier">size_type</span> <span class="identifier">find_first_not_of</span><span class="special">(</span><span class="keyword">const</span> <span class="identifier">charT</span><span class="special">*</span> <span class="identifier">s</span><span class="special">,</span> <span class="identifier">size_type</span> <span class="identifier">pos</span><span class="special">,</span> <span class="identifier">size_type</span> <span class="identifier">n</span><span class="special">)</span> <span class="keyword">const</span><span class="special">;</span> | ||||
| <span class="identifier">BOOST_CXX14_CONSTEXPR</span> <span class="identifier">size_type</span> <span class="identifier">find_first_not_of</span><span class="special">(</span><span class="keyword">const</span> <span class="identifier">charT</span><span class="special">*</span> <span class="identifier">s</span><span class="special">,</span> <span class="identifier">size_type</span> <span class="identifier">pos</span> <span class="special">=</span> <span class="number">0</span><span class="special">)</span> <span class="keyword">const</span><span class="special">;</span> | ||||
|  | ||||
| <span class="identifier">BOOST_CXX14_CONSTEXPR</span> <span class="identifier">size_type</span> <span class="identifier">find_last_not_of</span><span class="special">(</span><span class="identifier">basic_string_view</span> <span class="identifier">s</span><span class="special">,</span> <span class="identifier">size_type</span> <span class="identifier">pos</span> <span class="special">=</span> <span class="identifier">npos</span><span class="special">)</span> <span class="keyword">const</span> <span class="identifier">BOOST_NOEXCEPT</span><span class="special">;</span> | ||||
| <span class="identifier">BOOST_CXX14_CONSTEXPR</span> <span class="identifier">size_type</span> <span class="identifier">find_last_not_of</span><span class="special">(</span><span class="identifier">charT</span> <span class="identifier">c</span><span class="special">,</span> <span class="identifier">size_type</span> <span class="identifier">pos</span> <span class="special">=</span> <span class="identifier">npos</span><span class="special">)</span> <span class="keyword">const</span> <span class="identifier">BOOST_NOEXCEPT</span><span class="special">;</span> | ||||
| <span class="identifier">BOOST_CXX14_CONSTEXPR</span> <span class="identifier">size_type</span> <span class="identifier">find_last_not_of</span><span class="special">(</span><span class="keyword">const</span> <span class="identifier">charT</span><span class="special">*</span> <span class="identifier">s</span><span class="special">,</span> <span class="identifier">size_type</span> <span class="identifier">pos</span><span class="special">,</span> <span class="identifier">size_type</span> <span class="identifier">n</span><span class="special">)</span> <span class="keyword">const</span><span class="special">;</span> | ||||
| <span class="identifier">BOOST_CXX14_CONSTEXPR</span> <span class="identifier">size_type</span> <span class="identifier">find_last_not_of</span><span class="special">(</span><span class="keyword">const</span> <span class="identifier">charT</span><span class="special">*</span> <span class="identifier">s</span><span class="special">,</span> <span class="identifier">size_type</span> <span class="identifier">pos</span> <span class="special">=</span> <span class="identifier">npos</span><span class="special">)</span> <span class="keyword">const</span><span class="special">;</span> | ||||
|  | ||||
| <span class="identifier">BOOST_CONSTEXPR</span> <span class="keyword">bool</span> <span class="identifier">starts_with</span><span class="special">(</span><span class="identifier">charT</span> <span class="identifier">c</span><span class="special">)</span> <span class="keyword">const</span> <span class="special">;</span>                 <span class="comment">// boost extension</span> | ||||
| <span class="identifier">BOOST_CONSTEXPR</span> <span class="keyword">bool</span> <span class="identifier">starts_with</span><span class="special">(</span><span class="identifier">basic_string_view</span> <span class="identifier">x</span><span class="special">)</span> <span class="keyword">const</span> <span class="special">;</span>     <span class="comment">// boost extension</span> | ||||
| <span class="identifier">BOOST_CONSTEXPR</span> <span class="keyword">bool</span> <span class="identifier">ends_with</span><span class="special">(</span><span class="identifier">charT</span> <span class="identifier">c</span><span class="special">)</span> <span class="keyword">const</span> <span class="special">;</span>                   <span class="comment">// boost extension</span> | ||||
| <span class="identifier">BOOST_CONSTEXPR</span> <span class="keyword">bool</span> <span class="identifier">ends_with</span><span class="special">(</span><span class="identifier">basic_string_view</span> <span class="identifier">x</span><span class="special">)</span> <span class="keyword">const</span> <span class="special">;</span>       <span class="comment">// boost extension</span> | ||||
| </pre> | ||||
| <p> | ||||
|       String-like operations: | ||||
|     </p> | ||||
| <pre class="programlisting"><span class="keyword">template</span><span class="special"><</span><span class="keyword">class</span> <span class="identifier">Allocator</span><span class="special">></span>  <span class="comment">// Only present if compiler supports C++11 explicit conversion</span> | ||||
|   <span class="keyword">explicit</span> <span class="keyword">operator</span> <span class="identifier">basic_string</span><span class="special"><</span><span class="identifier">charT</span><span class="special">,</span> <span class="identifier">traits</span><span class="special">,</span> <span class="identifier">Allocator</span><span class="special">>()</span> <span class="keyword">const</span><span class="special">;</span> | ||||
|  | ||||
| <span class="keyword">template</span><span class="special"><</span><span class="keyword">class</span> <span class="identifier">Allocator</span> <span class="special">=</span> <span class="identifier">allocator</span><span class="special"><</span><span class="identifier">charT</span><span class="special">></span> <span class="special">></span>  <span class="comment">// Default only present if compiler supports</span> | ||||
|   <span class="identifier">basic_string</span><span class="special"><</span><span class="identifier">charT</span><span class="special">,</span> <span class="identifier">traits</span><span class="special">,</span> <span class="identifier">Allocator</span><span class="special">></span>       <span class="comment">//   C++11 default template parameters</span> | ||||
|     <span class="identifier">to_string</span><span class="special">(</span><span class="keyword">const</span> <span class="identifier">Allocator</span><span class="special">&</span> <span class="identifier">a</span> <span class="special">=</span> <span class="identifier">Allocator</span><span class="special">())</span> <span class="keyword">const</span><span class="special">;</span> | ||||
|  | ||||
| <span class="identifier">size_type</span> <span class="identifier">copy</span><span class="special">(</span><span class="identifier">charT</span><span class="special">*</span> <span class="identifier">s</span><span class="special">,</span> <span class="identifier">size_type</span> <span class="identifier">n</span><span class="special">,</span> <span class="identifier">size_type</span> <span class="identifier">pos</span> <span class="special">=</span> <span class="number">0</span><span class="special">)</span> <span class="keyword">const</span><span class="special">;</span> | ||||
|  | ||||
| <span class="identifier">BOOST_CXX14_CONSTEXPR</span> <span class="identifier">basic_string_view</span> <span class="identifier">substr</span><span class="special">(</span><span class="identifier">size_type</span> <span class="identifier">pos</span><span class="special">,</span> | ||||
|   <span class="identifier">size_type</span> <span class="identifier">n</span><span class="special">=</span><span class="identifier">npos</span><span class="special">)</span> <span class="keyword">const</span> <span class="special">;</span> <span class="comment">// Create new string_view</span> | ||||
| </pre> | ||||
| <p> | ||||
|       Comparison: | ||||
|     </p> | ||||
| <pre class="programlisting"><span class="identifier">To</span> <span class="identifier">be</span> <span class="identifier">supplied</span> | ||||
| </pre> | ||||
| </div> | ||||
| <div class="section"> | ||||
| <div class="titlepage"><div><div><h2 class="title" style="clear: both"> | ||||
| <a name="string_view.compiler_support"></a><a class="link" href="string_view.html#string_view.compiler_support" title="Compiler Support">Compiler Support</a> | ||||
| </h2></div></div></div> | ||||
| <p> | ||||
|       This Boost implementation only requires a C++03 compliant compiler. | ||||
|     </p> | ||||
| <p> | ||||
|       The actual Library Fundamentals specification assumes a C++14 compliant compiler, | ||||
|       so a few features are only present if actually supported by the compiler. Boost | ||||
|       macros such as BOOST_CONSTEXPR, BOOST_CXX14_CONSTEXPR, and BOOST_NOEXCEPT supply | ||||
|       certain features if supported by the compiler. | ||||
|     </p> | ||||
| </div> | ||||
| <div class="section"> | ||||
| <div class="titlepage"><div><div><h2 class="title" style="clear: both"> | ||||
| <a name="string_view.history"></a><a class="link" href="string_view.html#string_view.history" title="History">History</a> | ||||
| </h2></div></div></div> | ||||
| <h4> | ||||
| <a name="string_view.history.h0"></a> | ||||
|       <span class="phrase"><a name="string_view.history.boost_1_53"></a></span><a class="link" href="string_view.html#string_view.history.boost_1_53">boost | ||||
|       1.53</a> | ||||
|     </h4> | ||||
| <div class="itemizedlist"><ul class="itemizedlist" style="list-style-type: disc; "><li class="listitem"> | ||||
|           Introduced, based on Jeffrey Yaskin's <a href="http://www.open-std.org/jtc1/sc22/wg21/docs/papers/2012/n3442.html" target="_top">N3442: | ||||
|           string_ref: a non-owning reference to a string</a> | ||||
|         </li></ul></div> | ||||
| <h4> | ||||
| <a name="string_view.history.h1"></a> | ||||
|       <span class="phrase"><a name="string_view.history.boost_1_60"></a></span><a class="link" href="string_view.html#string_view.history.boost_1_60">boost | ||||
|       1.60</a> | ||||
|     </h4> | ||||
| <div class="itemizedlist"><ul class="itemizedlist" style="list-style-type: disc; "><li class="listitem"> | ||||
|           Updated to reflect <a href="http://www.open-std.org/jtc1/sc22/wg21/docs/papers/2015/n4480.html#string.view" target="_top">N4480: | ||||
|           ISO/IEC DTS 19568, Technical Specification - C++ Extensions for Library | ||||
|           Fundamentals</a> | ||||
|         </li></ul></div> | ||||
| </div> | ||||
| </div> | ||||
| <table xmlns:rev="http://www.cs.rpi.edu/~gregod/boost/tools/doc/revision" width="100%"><tr> | ||||
| <td align="left"><p><small>Last revised: July 17, 2015 at 19:19:23 GMT</small></p></td> | ||||
| <td align="right"><div class="copyright-footer"></div></td> | ||||
| </tr></table> | ||||
| <hr> | ||||
| <div class="spirit-nav"></div> | ||||
| </body> | ||||
| </html> | ||||
							
								
								
									
										
											BIN
										
									
								
								doc/logo.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								doc/logo.png
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							| After Width: | Height: | Size: 10 KiB | 
							
								
								
									
										539
									
								
								doc/logo.svg
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										539
									
								
								doc/logo.svg
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,539 @@ | ||||
| <?xml version="1.0" encoding="UTF-8" standalone="no"?> | ||||
| <!-- Created with Inkscape (http://www.inkscape.org/) --> | ||||
|  | ||||
| <svg | ||||
|    xmlns:dc="http://purl.org/dc/elements/1.1/" | ||||
|    xmlns:cc="http://creativecommons.org/ns#" | ||||
|    xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#" | ||||
|    xmlns:svg="http://www.w3.org/2000/svg" | ||||
|    xmlns="http://www.w3.org/2000/svg" | ||||
|    xmlns:xlink="http://www.w3.org/1999/xlink" | ||||
|    xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd" | ||||
|    xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape" | ||||
|    width="744.09448819" | ||||
|    height="1052.3622047" | ||||
|    id="svg6858" | ||||
|    version="1.1" | ||||
|    inkscape:version="0.48.4 r9939" | ||||
|    sodipodi:docname="utility.svg"> | ||||
|   <defs | ||||
|      id="defs6860"> | ||||
|     <linearGradient | ||||
|        inkscape:collect="always" | ||||
|        xlink:href="#linearGradient4453-7-8-6-7-3-5" | ||||
|        id="linearGradient10687-2-5" | ||||
|        gradientUnits="userSpaceOnUse" | ||||
|        x1="753.02301" | ||||
|        y1="3132.0801" | ||||
|        x2="1146.25" | ||||
|        y2="3132.0801" /> | ||||
|     <linearGradient | ||||
|        id="linearGradient4453-7-8-6-7-3-5"> | ||||
|       <stop | ||||
|          style="stop-color:#aac4dd;stop-opacity:1;" | ||||
|          offset="0" | ||||
|          id="stop4455-61-8-7-1-2-8" /> | ||||
|       <stop | ||||
|          style="stop-color:#c2dbe9;stop-opacity:1;" | ||||
|          offset="1" | ||||
|          id="stop4457-4-1-9-1-12-1" /> | ||||
|     </linearGradient> | ||||
|     <linearGradient | ||||
|        inkscape:collect="always" | ||||
|        xlink:href="#linearGradient4453-7-8-6-7-3-5" | ||||
|        id="linearGradient10685-2-2" | ||||
|        gradientUnits="userSpaceOnUse" | ||||
|        x1="753.02301" | ||||
|        y1="3132.0801" | ||||
|        x2="1146.25" | ||||
|        y2="3132.0801" /> | ||||
|     <linearGradient | ||||
|        id="linearGradient6749"> | ||||
|       <stop | ||||
|          style="stop-color:#aac4dd;stop-opacity:1;" | ||||
|          offset="0" | ||||
|          id="stop6751" /> | ||||
|       <stop | ||||
|          style="stop-color:#c2dbe9;stop-opacity:1;" | ||||
|          offset="1" | ||||
|          id="stop6753" /> | ||||
|     </linearGradient> | ||||
|     <clipPath | ||||
|        clipPathUnits="userSpaceOnUse" | ||||
|        id="clipPath3387-3-6-4-2-8-4"> | ||||
|       <path | ||||
|          inkscape:connector-curvature="0" | ||||
|          d="m 862.109,3289.75 -109.086,-190.45 69.122,-124.42 164.511,-0.47 c 0,0 111.044,188.28 116.564,197.63 7.66,0 43.03,0 43.03,0 l -67.03,117.71 -217.111,0 z" | ||||
|          id="path3389-2-0-7-7-8-9" /> | ||||
|     </clipPath> | ||||
|     <linearGradient | ||||
|        y2="3132.0801" | ||||
|        x2="1146.25" | ||||
|        y1="3132.0801" | ||||
|        x1="753.02301" | ||||
|        gradientUnits="userSpaceOnUse" | ||||
|        id="linearGradient4492-8-8" | ||||
|        xlink:href="#linearGradient4453-7-8-6-7-3-5" | ||||
|        inkscape:collect="always" /> | ||||
|     <linearGradient | ||||
|        id="linearGradient6758"> | ||||
|       <stop | ||||
|          style="stop-color:#aac4dd;stop-opacity:1;" | ||||
|          offset="0" | ||||
|          id="stop6760" /> | ||||
|       <stop | ||||
|          style="stop-color:#c2dbe9;stop-opacity:1;" | ||||
|          offset="1" | ||||
|          id="stop6762" /> | ||||
|     </linearGradient> | ||||
|     <linearGradient | ||||
|        inkscape:collect="always" | ||||
|        xlink:href="#linearGradient4453-7-8-6-7-3-5" | ||||
|        id="linearGradient10691-7-8" | ||||
|        gradientUnits="userSpaceOnUse" | ||||
|        x1="1026.6899" | ||||
|        y1="2937.73" | ||||
|        x2="1463.14" | ||||
|        y2="2937.73" /> | ||||
|     <linearGradient | ||||
|        id="linearGradient6765"> | ||||
|       <stop | ||||
|          style="stop-color:#aac4dd;stop-opacity:1;" | ||||
|          offset="0" | ||||
|          id="stop6767" /> | ||||
|       <stop | ||||
|          style="stop-color:#c2dbe9;stop-opacity:1;" | ||||
|          offset="1" | ||||
|          id="stop6769" /> | ||||
|     </linearGradient> | ||||
|     <linearGradient | ||||
|        inkscape:collect="always" | ||||
|        xlink:href="#linearGradient4453-7-8-6-7-3-5" | ||||
|        id="linearGradient10689-4-2" | ||||
|        gradientUnits="userSpaceOnUse" | ||||
|        x1="1026.6899" | ||||
|        y1="2937.73" | ||||
|        x2="1463.14" | ||||
|        y2="2937.73" /> | ||||
|     <linearGradient | ||||
|        id="linearGradient6772"> | ||||
|       <stop | ||||
|          style="stop-color:#aac4dd;stop-opacity:1;" | ||||
|          offset="0" | ||||
|          id="stop6774" /> | ||||
|       <stop | ||||
|          style="stop-color:#c2dbe9;stop-opacity:1;" | ||||
|          offset="1" | ||||
|          id="stop6776" /> | ||||
|     </linearGradient> | ||||
|     <clipPath | ||||
|        clipPathUnits="userSpaceOnUse" | ||||
|        id="clipPath3369-1-5-6-1-0-7"> | ||||
|       <path | ||||
|          inkscape:connector-curvature="0" | ||||
|          d="m 1131.64,3128.5 -104.95,-181.12 116.38,-200.42 208.05,0.94 112.02,191.63 -112.08,188.97 -219.42,0 z" | ||||
|          id="path3371-89-4-1-6-0-1" /> | ||||
|     </clipPath> | ||||
|     <linearGradient | ||||
|        y2="2937.73" | ||||
|        x2="1463.14" | ||||
|        y1="2937.73" | ||||
|        x1="1026.6899" | ||||
|        gradientUnits="userSpaceOnUse" | ||||
|        id="linearGradient4498-5-7" | ||||
|        xlink:href="#linearGradient4453-7-8-6-7-3-5" | ||||
|        inkscape:collect="always" /> | ||||
|     <linearGradient | ||||
|        id="linearGradient6781"> | ||||
|       <stop | ||||
|          style="stop-color:#aac4dd;stop-opacity:1;" | ||||
|          offset="0" | ||||
|          id="stop6783" /> | ||||
|       <stop | ||||
|          style="stop-color:#c2dbe9;stop-opacity:1;" | ||||
|          offset="1" | ||||
|          id="stop6785" /> | ||||
|     </linearGradient> | ||||
|     <linearGradient | ||||
|        inkscape:collect="always" | ||||
|        xlink:href="#linearGradient4459-1-2-8-9-9-5" | ||||
|        id="linearGradient10695-9-9" | ||||
|        gradientUnits="userSpaceOnUse" | ||||
|        x1="646.55499" | ||||
|        y1="2736.25" | ||||
|        x2="1088.27" | ||||
|        y2="2736.25" /> | ||||
|     <linearGradient | ||||
|        id="linearGradient4459-1-2-8-9-9-5"> | ||||
|       <stop | ||||
|          id="stop4461-2-1-5-2-5-0" | ||||
|          offset="0" | ||||
|          style="stop-color:#839bc2;stop-opacity:1;" /> | ||||
|       <stop | ||||
|          id="stop4463-3-2-8-7-30-3" | ||||
|          offset="1" | ||||
|          style="stop-color:#9fb6d4;stop-opacity:1;" /> | ||||
|     </linearGradient> | ||||
|     <linearGradient | ||||
|        inkscape:collect="always" | ||||
|        xlink:href="#linearGradient4459-1-2-8-9-9-5" | ||||
|        id="linearGradient10693-9-4" | ||||
|        gradientUnits="userSpaceOnUse" | ||||
|        x1="646.55499" | ||||
|        y1="2736.25" | ||||
|        x2="1088.27" | ||||
|        y2="2736.25" /> | ||||
|     <linearGradient | ||||
|        id="linearGradient6792"> | ||||
|       <stop | ||||
|          id="stop6794" | ||||
|          offset="0" | ||||
|          style="stop-color:#839bc2;stop-opacity:1;" /> | ||||
|       <stop | ||||
|          id="stop6796" | ||||
|          offset="1" | ||||
|          style="stop-color:#9fb6d4;stop-opacity:1;" /> | ||||
|     </linearGradient> | ||||
|     <clipPath | ||||
|        clipPathUnits="userSpaceOnUse" | ||||
|        id="clipPath3351-4-7-3-5-95-0"> | ||||
|       <path | ||||
|          inkscape:connector-curvature="0" | ||||
|          d="m 757.242,2926.25 -110.687,-189.11 110.656,-190.89 219.437,0 111.622,189.1 -111.59,190.9 -219.438,0 z" | ||||
|          id="path3353-1-9-3-4-1-1" /> | ||||
|     </clipPath> | ||||
|     <linearGradient | ||||
|        y2="2736.25" | ||||
|        x2="1088.27" | ||||
|        y1="2736.25" | ||||
|        x1="646.55499" | ||||
|        gradientUnits="userSpaceOnUse" | ||||
|        id="linearGradient4510-1-5" | ||||
|        xlink:href="#linearGradient4459-1-2-8-9-9-5" | ||||
|        inkscape:collect="always" /> | ||||
|     <linearGradient | ||||
|        id="linearGradient6801"> | ||||
|       <stop | ||||
|          id="stop6803" | ||||
|          offset="0" | ||||
|          style="stop-color:#839bc2;stop-opacity:1;" /> | ||||
|       <stop | ||||
|          id="stop6805" | ||||
|          offset="1" | ||||
|          style="stop-color:#9fb6d4;stop-opacity:1;" /> | ||||
|     </linearGradient> | ||||
|     <radialGradient | ||||
|        inkscape:collect="always" | ||||
|        xlink:href="#radialGradient3327-8-4-8-0-2-4" | ||||
|        id="radialGradient10699-1-3" | ||||
|        gradientUnits="userSpaceOnUse" | ||||
|        cx="997.46997" | ||||
|        cy="2896.25" | ||||
|        fx="997.46997" | ||||
|        fy="2896.25" | ||||
|        r="583.73999" /> | ||||
|     <radialGradient | ||||
|        fx="0" | ||||
|        fy="0" | ||||
|        cx="0" | ||||
|        cy="0" | ||||
|        r="1" | ||||
|        gradientUnits="userSpaceOnUse" | ||||
|        gradientTransform="matrix(58.375,0,0,-58.375,99.75,289.625)" | ||||
|        spreadMethod="pad" | ||||
|        id="radialGradient3327-8-4-8-0-2-4"> | ||||
|       <stop | ||||
|          style="stop-opacity:1;stop-color:#aeaeb3" | ||||
|          offset="0" | ||||
|          id="stop3329-7-0-1-0-33-2" /> | ||||
|       <stop | ||||
|          style="stop-opacity:1;stop-color:#ffffff" | ||||
|          offset="0.949438" | ||||
|          id="stop3331-4-3-0-0-97-3" /> | ||||
|       <stop | ||||
|          style="stop-opacity:1;stop-color:#ffffff" | ||||
|          offset="1" | ||||
|          id="stop3333-2-4-9-7-2-2" /> | ||||
|     </radialGradient> | ||||
|     <radialGradient | ||||
|        r="583.73999" | ||||
|        fy="2896.25" | ||||
|        fx="997.46997" | ||||
|        cy="2896.25" | ||||
|        cx="997.46997" | ||||
|        gradientUnits="userSpaceOnUse" | ||||
|        id="radialGradient13050" | ||||
|        xlink:href="#radialGradient3327-8-4-8-0-2-4" | ||||
|        inkscape:collect="always" /> | ||||
|     <radialGradient | ||||
|        fx="0" | ||||
|        fy="0" | ||||
|        cx="0" | ||||
|        cy="0" | ||||
|        r="1" | ||||
|        gradientUnits="userSpaceOnUse" | ||||
|        gradientTransform="matrix(58.375,0,0,-58.375,99.75,289.625)" | ||||
|        spreadMethod="pad" | ||||
|        id="radialGradient6813"> | ||||
|       <stop | ||||
|          style="stop-opacity:1;stop-color:#aeaeb3" | ||||
|          offset="0" | ||||
|          id="stop6815" /> | ||||
|       <stop | ||||
|          style="stop-opacity:1;stop-color:#ffffff" | ||||
|          offset="0.949438" | ||||
|          id="stop6817" /> | ||||
|       <stop | ||||
|          style="stop-opacity:1;stop-color:#ffffff" | ||||
|          offset="1" | ||||
|          id="stop6819" /> | ||||
|     </radialGradient> | ||||
|     <clipPath | ||||
|        clipPathUnits="userSpaceOnUse" | ||||
|        id="clipPath3323-7-2-4-5-3-4"> | ||||
|       <path | ||||
|          inkscape:connector-curvature="0" | ||||
|          d="m 997.469,2312.51 c -322.379,0 -583.739,261.36 -583.739,583.74 0,322.38 261.36,583.74 583.739,583.74 322.381,0 583.741,-261.36 583.741,-583.74 0,-322.38 -261.36,-583.74 -583.741,-583.74" | ||||
|          id="path3325-9-2-9-5-04-9" /> | ||||
|     </clipPath> | ||||
|     <radialGradient | ||||
|        r="583.73999" | ||||
|        fy="2896.25" | ||||
|        fx="997.46997" | ||||
|        cy="2896.25" | ||||
|        cx="997.46997" | ||||
|        gradientUnits="userSpaceOnUse" | ||||
|        id="radialGradient4516-8-2" | ||||
|        xlink:href="#radialGradient3327-8-4-8-0-2-4" | ||||
|        inkscape:collect="always" /> | ||||
|     <radialGradient | ||||
|        fx="0" | ||||
|        fy="0" | ||||
|        cx="0" | ||||
|        cy="0" | ||||
|        r="1" | ||||
|        gradientUnits="userSpaceOnUse" | ||||
|        gradientTransform="matrix(58.375,0,0,-58.375,99.75,289.625)" | ||||
|        spreadMethod="pad" | ||||
|        id="radialGradient6824"> | ||||
|       <stop | ||||
|          style="stop-opacity:1;stop-color:#aeaeb3" | ||||
|          offset="0" | ||||
|          id="stop6826" /> | ||||
|       <stop | ||||
|          style="stop-opacity:1;stop-color:#ffffff" | ||||
|          offset="0.949438" | ||||
|          id="stop6828" /> | ||||
|       <stop | ||||
|          style="stop-opacity:1;stop-color:#ffffff" | ||||
|          offset="1" | ||||
|          id="stop6830" /> | ||||
|     </radialGradient> | ||||
|     <radialGradient | ||||
|        r="583.73999" | ||||
|        fy="2896.25" | ||||
|        fx="997.46997" | ||||
|        cy="2896.25" | ||||
|        cx="997.46997" | ||||
|        gradientUnits="userSpaceOnUse" | ||||
|        id="radialGradient6856" | ||||
|        xlink:href="#radialGradient3327-8-4-8-0-2-4" | ||||
|        inkscape:collect="always" /> | ||||
|   </defs> | ||||
|   <sodipodi:namedview | ||||
|      id="base" | ||||
|      pagecolor="#ffffff" | ||||
|      bordercolor="#666666" | ||||
|      borderopacity="1.0" | ||||
|      inkscape:pageopacity="0.0" | ||||
|      inkscape:pageshadow="2" | ||||
|      inkscape:zoom="1.4" | ||||
|      inkscape:cx="234.05635" | ||||
|      inkscape:cy="581.46313" | ||||
|      inkscape:document-units="px" | ||||
|      inkscape:current-layer="layer1" | ||||
|      showgrid="false" | ||||
|      inkscape:window-width="1680" | ||||
|      inkscape:window-height="982" | ||||
|      inkscape:window-x="-8" | ||||
|      inkscape:window-y="-8" | ||||
|      inkscape:window-maximized="1"> | ||||
|     <inkscape:grid | ||||
|        type="xygrid" | ||||
|        id="grid3066" /> | ||||
|   </sodipodi:namedview> | ||||
|   <metadata | ||||
|      id="metadata6863"> | ||||
|     <rdf:RDF> | ||||
|       <cc:Work | ||||
|          rdf:about=""> | ||||
|         <dc:format>image/svg+xml</dc:format> | ||||
|         <dc:type | ||||
|            rdf:resource="http://purl.org/dc/dcmitype/StillImage" /> | ||||
|         <dc:title /> | ||||
|       </cc:Work> | ||||
|     </rdf:RDF> | ||||
|   </metadata> | ||||
|   <g | ||||
|      inkscape:label="Layer 1" | ||||
|      inkscape:groupmode="layer" | ||||
|      id="layer1"> | ||||
|     <g | ||||
|        id="g3319-1-2-5-1-4-4" | ||||
|        transform="matrix(0.10419818,0,0,-0.10419818,137.10955,897.00327)" | ||||
|        style="fill:url(#radialGradient10699-1-3);fill-opacity:1" | ||||
|        inkscape:export-filename="C:\Users\Adam\Desktop\bg_logo1.png" | ||||
|        inkscape:export-xdpi="63.625523" | ||||
|        inkscape:export-ydpi="63.625523"> | ||||
|       <g | ||||
|          clip-path="url(#clipPath3323-7-2-4-5-3-4)" | ||||
|          id="g3321-9-2-7-4-3-9" | ||||
|          style="fill:url(#radialGradient6856);fill-opacity:1"> | ||||
|         <path | ||||
|            id="path3335-8-7-3-8-92-0" | ||||
|            style="fill:url(#radialGradient4516-8-2);fill-opacity:1;fill-rule:nonzero;stroke:none" | ||||
|            d="m 997.469,2312.51 c -322.379,0 -583.739,261.36 -583.739,583.74 0,322.38 261.36,583.74 583.739,583.74 322.381,0 583.741,-261.36 583.741,-583.74 0,-322.38 -261.36,-583.74 -583.741,-583.74" | ||||
|            inkscape:connector-curvature="0" /> | ||||
|       </g> | ||||
|     </g> | ||||
|     <g | ||||
|        id="g3347-6-8-3-7-4-4" | ||||
|        transform="matrix(0.125,0,0,-0.125,112.08304,959.82207)" | ||||
|        style="fill:url(#linearGradient10695-9-9);fill-opacity:1" | ||||
|        inkscape:export-filename="C:\Users\Adam\Desktop\bg_logo1.png" | ||||
|        inkscape:export-xdpi="63.625523" | ||||
|        inkscape:export-ydpi="63.625523"> | ||||
|       <g | ||||
|          clip-path="url(#clipPath3351-4-7-3-5-95-0)" | ||||
|          id="g3349-5-5-4-7-9-4" | ||||
|          style="fill:url(#linearGradient10693-9-4);fill-opacity:1"> | ||||
|         <path | ||||
|            id="path3361-0-8-2-9-0-9" | ||||
|            style="fill:url(#linearGradient4510-1-5);fill-opacity:1;fill-rule:nonzero;stroke:none" | ||||
|            d="m 757.242,2926.25 -110.687,-189.11 110.656,-190.89 219.437,0 111.622,189.1 -111.59,190.9 -219.438,0" | ||||
|            inkscape:connector-curvature="0" /> | ||||
|       </g> | ||||
|     </g> | ||||
|     <path | ||||
|        id="path3363-6-9-0-1-5-8" | ||||
|        style="fill:#ffffff;fill-opacity:1;fill-rule:nonzero;stroke:none" | ||||
|        d="m 194.34816,617.68335 13.106,-22.3925 25.99649,0 13.21487,22.60874 -13.21487,22.39125 -25.99649,0 -13.106,-22.60749 z m 40.53761,-24.8925 -28.86524,0 -0.72412,1.23749 -13.106,22.39251 -0.73575,1.25625 0.73087,1.26 13.106,22.60744 0.72263,1.24634 28.86374,0 0.72512,-1.22884 13.215,-22.39119 0.74625,-1.265 -0.74,-1.26751 -13.21537,-22.60875 -0.72313,-1.23874" | ||||
|        inkscape:connector-curvature="0" | ||||
|        inkscape:export-filename="C:\Users\Adam\Desktop\bg_logo1.png" | ||||
|        inkscape:export-xdpi="63.625523" | ||||
|        inkscape:export-ydpi="63.625523" /> | ||||
|     <g | ||||
|        id="g3365-0-4-1-9-7-5" | ||||
|        transform="matrix(0.125,0,0,-0.125,112.08304,959.82207)" | ||||
|        style="fill:url(#linearGradient10691-7-8);fill-opacity:1" | ||||
|        inkscape:export-filename="C:\Users\Adam\Desktop\bg_logo1.png" | ||||
|        inkscape:export-xdpi="63.625523" | ||||
|        inkscape:export-ydpi="63.625523"> | ||||
|       <g | ||||
|          clip-path="url(#clipPath3369-1-5-6-1-0-7)" | ||||
|          id="g3367-2-4-2-8-4-3" | ||||
|          style="fill:url(#linearGradient10689-4-2);fill-opacity:1"> | ||||
|         <path | ||||
|            id="path3379-4-6-7-6-7-2" | ||||
|            style="fill:url(#linearGradient4498-5-7);fill-opacity:1;fill-rule:nonzero;stroke:none" | ||||
|            d="m 1131.64,3128.5 -104.95,-181.12 116.38,-200.42 208.05,0.94 112.02,191.63 -112.08,188.97 -219.42,0" | ||||
|            inkscape:connector-curvature="0" /> | ||||
|       </g> | ||||
|     </g> | ||||
|     <path | ||||
|        id="path3381-6-8-0-0-66-3" | ||||
|        style="fill:#ffffff;fill-opacity:1;fill-rule:nonzero;stroke:none" | ||||
|        d="m 241.86427,591.39959 12.3925,-21.38999 25.99625,0 13.27125,22.37625 -13.27125,22.7025 -24.56875,0.11 -13.82,-23.79876 z m 39.8125,-23.88999 -28.86125,0 -0.7225,1.24625 -12.3925,21.39 -0.72625,1.255 0.7275,1.25374 13.82,23.79876 0.7275,1.25125 1.44625,-0.006 24.56875,-0.11 1.4275,-0.006 0.72,-1.2325 13.27125,-22.7025 0.7425,-1.27 -0.75125,-1.26625 -13.27125,-22.37625 -0.72625,-1.225" | ||||
|        inkscape:connector-curvature="0" | ||||
|        inkscape:export-filename="C:\Users\Adam\Desktop\bg_logo1.png" | ||||
|        inkscape:export-xdpi="63.625523" | ||||
|        inkscape:export-ydpi="63.625523" /> | ||||
|     <g | ||||
|        id="g3383-5-5-2-2-3-0" | ||||
|        transform="matrix(0.125,0,0,-0.125,112.08304,959.82207)" | ||||
|        style="fill:url(#linearGradient10687-2-5);fill-opacity:1" | ||||
|        inkscape:export-filename="C:\Users\Adam\Desktop\bg_logo1.png" | ||||
|        inkscape:export-xdpi="63.625523" | ||||
|        inkscape:export-ydpi="63.625523"> | ||||
|       <g | ||||
|          clip-path="url(#clipPath3387-3-6-4-2-8-4)" | ||||
|          id="g3385-0-6-4-8-0-1" | ||||
|          style="fill:url(#linearGradient10685-2-2);fill-opacity:1"> | ||||
|         <path | ||||
|            id="path3397-9-6-1-6-9-7" | ||||
|            style="fill:url(#linearGradient4492-8-8);fill-opacity:1;fill-rule:nonzero;stroke:none" | ||||
|            d="m 862.109,3289.75 -109.086,-190.45 69.122,-124.42 164.511,-0.47 c 0,0 111.044,188.28 116.564,197.63 7.66,0 43.03,0 43.03,0 l -67.03,117.71 -217.111,0" | ||||
|            inkscape:connector-curvature="0" /> | ||||
|       </g> | ||||
|     </g> | ||||
|     <path | ||||
|        id="path3399-6-7-3-2-0-1" | ||||
|        style="fill:#ffffff;fill-opacity:1;fill-rule:nonzero;stroke:none" | ||||
|        d="m 207.64603,572.41959 12.92424,-22.56624 25.68775,0 6.95625,12.21375 -3.94375,0 -14.56837,24.7025 -19.11525,-0.055 -7.94087,-14.295 z m 40.06574,-25.06624 -28.59012,0 -0.71975,1.2575 -12.92537,22.56625 -0.70112,1.22375 0.68512,1.23249 7.94137,14.295 0.71087,1.2825 1.46638,0.004 19.11525,0.055 1.43212,0.004 0.729,-1.23375 13.84375,-23.47249 6.81625,0 -2.12875,-3.7375 -6.95625,-12.21375 -0.71875,-1.2625" | ||||
|        inkscape:connector-curvature="0" | ||||
|        inkscape:export-filename="C:\Users\Adam\Desktop\bg_logo1.png" | ||||
|        inkscape:export-xdpi="63.625523" | ||||
|        inkscape:export-ydpi="63.625523" /> | ||||
|     <g | ||||
|        transform="matrix(1.25,0,0,-1.25,105.02062,972.84257)" | ||||
|        id="g3465-0-8-9" | ||||
|        inkscape:export-filename="C:\Users\Adam\Desktop\bg_logo1.png" | ||||
|        inkscape:export-xdpi="63.625523" | ||||
|        inkscape:export-ydpi="63.625523"> | ||||
|       <text | ||||
|          id="text3467-9-0-8" | ||||
|          transform="matrix(1,0,-0.17627963,-1,0,0)" | ||||
|          x="116.98372" | ||||
|          y="-267.77499" | ||||
|          style="font-size:11.81779194px"> | ||||
|         <tspan | ||||
|            sodipodi:role="line" | ||||
|            style="font-size:46.39999771px;font-variant:normal;font-weight:normal;writing-mode:lr-tb;fill:#49608a;fill-opacity:1;fill-rule:nonzero;stroke:none;font-family:Denmark;-inkscape-font-specification:Denmark" | ||||
|            x="116.98372" | ||||
|            y="-267.77499" | ||||
|            id="tspan13239">UTILITY</tspan> | ||||
|         <tspan | ||||
|            sodipodi:role="line" | ||||
|            style="font-size:46.39999771px;font-variant:normal;font-weight:normal;writing-mode:lr-tb;fill:#49608a;fill-opacity:1;fill-rule:nonzero;stroke:none;font-family:Denmark;-inkscape-font-specification:Denmark" | ||||
|            x="116.98372" | ||||
|            y="-209.77499" | ||||
|            id="tspan11278-3" /> | ||||
|       </text> | ||||
|       <text | ||||
|          id="text3471-0-51-2" | ||||
|          transform="matrix(0.99235617,0,-0.17763746,-1.0077027,0,0)" | ||||
|          style="font-size:38.40000153px" | ||||
|          x="112.74373" | ||||
|          y="-306.75479"> | ||||
|         <tspan | ||||
|            id="tspan3473-6-0-9" | ||||
|            sodipodi:role="line" | ||||
|            style="font-size:38.40000153px;font-variant:normal;font-weight:normal;writing-mode:lr-tb;fill:#49608a;fill-opacity:1;fill-rule:nonzero;stroke:none;font-family:Denmark;-inkscape-font-specification:Denmark" | ||||
|            x="112.74373" | ||||
|            y="-306.75479">boost</tspan> | ||||
|       </text> | ||||
|     </g> | ||||
|     <path | ||||
|        style="fill:#ffffff;fill-opacity:1;stroke:none" | ||||
|        d="m 201.43967,613.81579 4.64114,4.2175 3.3738,-3.71306 -0.92817,-0.84354 1.68708,-1.85636 20.53445,20.81026 4.2175,-4.64111 -22.22144,-18.95384 c 0,0 1.69594,-1.83698 2.53062,-2.78454 2.53905,-2.76559 5.98925,-4.72587 5.98925,-4.72587 0,0 -6.03647,0.58224 -8.76507,2.21476 -0.84428,0.92751 -6.75676,7.40649 -6.75676,7.40649 l -0.92819,-0.84355 -3.37382,3.71308" | ||||
|        id="path13283" | ||||
|        inkscape:connector-curvature="0" | ||||
|        sodipodi:nodetypes="cccccccccccccc" /> | ||||
|     <g | ||||
|        id="g3086" | ||||
|        transform="matrix(0.99872217,-0.05053738,0.05053738,0.99872217,-31.539183,11.181538)"> | ||||
|       <path | ||||
|          sodipodi:nodetypes="ccccccccc" | ||||
|          inkscape:connector-curvature="0" | ||||
|          id="path13243" | ||||
|          d="m 227.74101,611.16418 -15.09943,12.783 2.55659,3.01989 15.09944,-12.78302 c 3.56324,2.16769 7.58975,-1.2411 7.0464,-5.96538 l -4.02652,3.40879 -2.55659,-3.01989 4.02652,-3.40879 c -3.56324,-2.16769 -8.59639,2.0933 -7.04641,5.9654 z" | ||||
|          style="fill:#ffffff;fill-opacity:1;stroke:none" /> | ||||
|       <path | ||||
|          sodipodi:nodetypes="ccccccccc" | ||||
|          inkscape:connector-curvature="0" | ||||
|          id="path13243-1" | ||||
|          d="m 215.25729,626.9851 15.08951,-12.7947 -2.55893,-3.01791 -15.08952,12.79471 c -3.56492,-2.16491 -7.58878,1.24699 -7.04177,5.97085 l 4.02388,-3.41192 2.55892,3.01791 -4.02387,3.41192 c 3.56491,2.16492 8.59476,-2.09997 7.04178,-5.97086 z" | ||||
|          style="fill:#ffffff;fill-opacity:1;stroke:none" /> | ||||
|     </g> | ||||
|   </g> | ||||
| </svg> | ||||
| After Width: | Height: | Size: 20 KiB | 
							
								
								
									
										62
									
								
								doc/ostream_string.qbk
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										62
									
								
								doc/ostream_string.qbk
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,62 @@ | ||||
| [/ | ||||
| Copyright 2019 Glen Joseph Fernandes | ||||
| (glenjofe@gmail.com) | ||||
|  | ||||
| Distributed under the Boost Software License, Version 1.0. | ||||
| (http://www.boost.org/LICENSE_1_0.txt) | ||||
| ] | ||||
|  | ||||
| [article ostream_string | ||||
| [quickbook 1.5] | ||||
| [authors [Fernandes, Glen]] | ||||
| [copyright 2019 Glen Joseph Fernandes] | ||||
| [license Distributed under the Boost Software License, Version 1.0.]] | ||||
|  | ||||
| [section Overview] | ||||
|  | ||||
| The header <boost/utility/ostream_string.hpp> provides the function template | ||||
| boost::ostream_string for formatted output that satisfies the requirements of | ||||
| \[ostream.formatted.reqmts\]. | ||||
|  | ||||
| [endsect] | ||||
|  | ||||
| [section Examples] | ||||
|  | ||||
| The inserter for class template `basic_string_view` could be implemented as | ||||
| follows: | ||||
|  | ||||
| ``` | ||||
| template<class charT, class traits> | ||||
| std::basic_ostream<charT, traits>& | ||||
| operator<<(std::basic_ostream<charT, traits>& os, | ||||
|     const basic_string_view<charT, traits>& str) | ||||
| { | ||||
|     return boost::ostream_string(os, str.data(), str.size()); | ||||
| } | ||||
| ``` | ||||
|  | ||||
| [endsect] | ||||
|  | ||||
| [section Reference] | ||||
|  | ||||
| ``` | ||||
| namespace boost { | ||||
|  | ||||
| template<class charT, class traits> | ||||
| std::basic_ostream<charT, traits>& | ||||
| ostream_string(std::basic_ostream<charT, traits>& os, | ||||
|     const charT* data, std::size_t size); | ||||
|  | ||||
| } /* boost */ | ||||
| ``` | ||||
|  | ||||
| [variablelist | ||||
| [[Effects] | ||||
| [Behaves like a formatted inserter (as described in | ||||
| \[ostream.formatted.reqmts\]) of `os`. Creates a character sequence `seq` of | ||||
| `size` characters starting at `data`, each widened using `os.widen()` | ||||
| (\[basic.ios.members\]). Determines padding for `seq` as described in | ||||
| \[ostream.formatted.reqmts\]. Inserts `seq` into `os`. Calls `width(0)`.]] | ||||
| [[Returns] [`os`.]]] | ||||
|  | ||||
| [endsect] | ||||
| @@ -1,243 +0,0 @@ | ||||
| [/ | ||||
|  / Copyright (c) 2012 Marshall Clow | ||||
|  / Copyright (c) 2015 Beman Dawes | ||||
|  / | ||||
|  / 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) | ||||
|  /] | ||||
|  | ||||
| [article String_View | ||||
|     [quickbook 1.5] | ||||
|     [authors [Clow, Marshall] [Dawes, Beman]] | ||||
|     [copyright 2012 Marshall Clow, 2015 Beman Dawes] | ||||
|     [license | ||||
|         Distributed under the Boost Software License, Version 1.0. | ||||
|         [@http://www.boost.org/LICENSE_1_0.txt]  | ||||
|     ] | ||||
| ] | ||||
|  | ||||
| [/===============] | ||||
| [section Overview] | ||||
| [/===============] | ||||
|  | ||||
| Boost.StringView is an implementation of `string_view` as specified in [@ | ||||
| http://www.open-std.org/jtc1/sc22/wg21/docs/papers/2015/n4480.html#string.view N4480: | ||||
| ISO/IEC DTS 19568, Technical Specification - C++ Extensions for Library Fundamentals]. | ||||
|      | ||||
| When you are parsing/processing strings from some external source, frequently you want to pass a piece of text to a procedure for specialized processing. The canonical way to do this is as a `std::string`, but that has certain drawbacks: | ||||
|  | ||||
| 1) If you are processing a buffer of text (say a HTTP response or the contents of a file), then you have to create the string from the text you want to pass, which involves memory allocation and copying of data. | ||||
|  | ||||
| 2) if a routine receives a constant `std::string` and wants to pass a portion of that string to another routine, then it must create a new string of that substring. | ||||
|  | ||||
| 3) A routine receives a constant `std::string` and wants to return a portion of the string, then it must create a new string to return. | ||||
|  | ||||
| `string_view` is designed to solve these efficiency problems. A `string_view` is a read-only reference to a contiguous sequence of characters, and provides much of the functionality of `std::string`. A `string_view` is cheap to create, copy and pass by value, because it does not actually own the storage that it points to.  | ||||
|  | ||||
| A `string_view` is implemented as a small struct that contains a pointer to the start of the character data and a count. A `string_view` is cheap to create and cheap to copy. | ||||
|  | ||||
| `string_view` acts as a container; it includes all the methods that you would expect in a container, including iteration support, `operator []`, `at` and `size`. It can be used with any of the iterator-based algorithms in the STL - as long as you don't need to change the underlying data (`sort` and `remove`, for example, will not work) | ||||
|  | ||||
| Besides generic container functionality, `string_view` provides a subset of the interface of `std::string`. This makes it easy to replace parameters of type `const std::string &` with `boost::string_view`. Like `std::string`, `string_view` has a static member variable named `npos` to denote the result of failed searches, and to mean "the end". | ||||
|  | ||||
| Because a `string_view` does not own the data that it "points to", it introduces lifetime issues into code that uses it. The programmer must ensure that the data that a `string_view` refers to exists as long as the `string_view` does. | ||||
|  | ||||
| Note: The header actually contains a class template, `basic_string_view` and four typedefs: | ||||
|  | ||||
|     template<class charT, class traits = char_traits<charT>> | ||||
|         class basic_string_view; | ||||
|     | ||||
|     typedef basic_string_view<char>     string_view; | ||||
|     typedef basic_string_view<char16_t> u16string_view; | ||||
|     typedef basic_string_view<char32_t> u32string_view; | ||||
|     typedef basic_string_view<wchar_t>  wstring_view; | ||||
|  | ||||
| So you can have views of strings of any of the four built-in character types as well as strings of user-defined character-like type strings. For the sake of simple exposition, we concentrate on `string_view` (i.e. `char` strings) in this documentation. | ||||
|  | ||||
| [endsect] | ||||
|  | ||||
|  | ||||
| [/===============] | ||||
| [section Examples] | ||||
| [/===============] | ||||
|  | ||||
| Integrating `string_view` into your code is fairly simple. Wherever you pass a `const std::string &` or `std::string` as a parameter, that's a candidate for passing a `boost::string_view`. | ||||
|  | ||||
|     std::string extract_part ( const std::string &bar ) { | ||||
|         return bar.substr ( 2, 3 ); | ||||
|         } | ||||
|          | ||||
|     if ( extract_part ( "ABCDEFG" ).front() == 'C' ) { /* do something */ } | ||||
|      | ||||
| Let's figure out what happens in this (contrived) example. | ||||
|  | ||||
| First, a temporary string is created from the string literal `"ABCDEFG"`, and it is passed (by reference) to the routine `extract_part`. Then a second string is created in the call `std::string::substr` and returned to `extract_part` (this copy may be elided by RVO). Then `extract_part` returns that string back to the caller (again this copy may be elided). The first temporary string is deallocated, and `front` is called on the second string, and then it is deallocated as well. | ||||
|  | ||||
| Two `std::string`s are created, and two copy operations. That's (potentially) four memory allocations and deallocations, and the associated copying of data. | ||||
|  | ||||
| Now let's look at the same code with `string_view`: | ||||
|  | ||||
|     boost::string_view extract_part ( boost::string_view bar ) { | ||||
|         return bar.substr ( 2, 3 ); | ||||
|         } | ||||
|          | ||||
|     if ( extract_part ( "ABCDEFG" ).front() == "C" ) { /* do something */ } | ||||
|  | ||||
| No memory allocations. No copying of character data. No changes to the code other than the types. There are two `string_view`s created, and two `string_view`s copied, but those are cheap operations. | ||||
|  | ||||
| [endsect] | ||||
|  | ||||
|  | ||||
| [/=================] | ||||
| [section:reference Reference ] | ||||
| [/=================] | ||||
|  | ||||
| The header file "string_view.hpp" defines a class template `boost::basic_string_view`, and four specializations - for `char` / `wchar_t` / `char16_t` / `char32_t` . | ||||
|  | ||||
| `#include <boost/utility/string_view.hpp>` | ||||
|  | ||||
| Types: | ||||
|  | ||||
|     typedef traits traits_type; | ||||
|     typedef charT value_type; | ||||
|     typedef charT* pointer; | ||||
|     typedef const charT* const_pointer; | ||||
|     typedef charT& reference; | ||||
|     typedef const charT& const_reference; | ||||
|     typedef const_pointer const_iterator;  // implementation defined | ||||
|     typedef const_iterator iterator; | ||||
|     typedef std::reverse_iterator<const_iterator> const_reverse_iterator; | ||||
|     typedef const_reverse_iterator reverse_iterator; | ||||
|     typedef std::size_t size_type; | ||||
|     typedef std::ptrdiff_t difference_type; | ||||
|     static BOOST_CONSTEXPR_OR_CONST size_type npos = size_type(-1); | ||||
|  | ||||
| Construction and copying: | ||||
|  | ||||
|     BOOST_CONSTEXPR basic_string_view () BOOST_NOEXCEPT;    // Constructs empty string_view | ||||
|     BOOST_CONSTEXPR basic_string_view (const basic_string_view &rhs) BOOST_NOEXCEPT; | ||||
|     basic_string_view& operator=(const basic_string_view &rhs) BOOST_NOEXCEPT; | ||||
|     template<typename Allocator> | ||||
|       basic_string_view(const std::basic_string<charT, traits, Allocator>& str) BOOST_NOEXCEPT; // Ctor from std::string | ||||
|     BOOST_CONSTEXPR basic_string_view(const charT* str); // Ctor from NULL-terminated string | ||||
|     BOOST_CONSTEXPR basic_string_view(const charT* str, size_type len); // Ctor from pointer, length pair | ||||
|  | ||||
| `string_view` does not define a move constructor or a move-assignment operator because copying a `string_view` is just as cheap as moving one would be. | ||||
|  | ||||
| Basic container-like functions: | ||||
|  | ||||
|     BOOST_CONSTEXPR size_type size()     const BOOST_NOEXCEPT ; | ||||
|     BOOST_CONSTEXPR size_type length()   const BOOST_NOEXCEPT ; | ||||
|     BOOST_CONSTEXPR size_type max_size() const BOOST_NOEXCEPT ; | ||||
|     BOOST_CONSTEXPR bool empty()         const BOOST_NOEXCEPT ; | ||||
|      | ||||
|     // All iterators are const_iterators | ||||
|     BOOST_CONSTEXPR const_iterator  begin() const BOOST_NOEXCEPT ; | ||||
|     BOOST_CONSTEXPR const_iterator cbegin() const BOOST_NOEXCEPT ; | ||||
|     BOOST_CONSTEXPR const_iterator    end() const BOOST_NOEXCEPT ; | ||||
|     BOOST_CONSTEXPR const_iterator   cend() const BOOST_NOEXCEPT ; | ||||
|     const_reverse_iterator         rbegin() const BOOST_NOEXCEPT ; | ||||
|     const_reverse_iterator        crbegin() const BOOST_NOEXCEPT ; | ||||
|     const_reverse_iterator           rend() const BOOST_NOEXCEPT ; | ||||
|     const_reverse_iterator          crend() const BOOST_NOEXCEPT ; | ||||
|  | ||||
| Access to the individual elements (all of which are const): | ||||
|  | ||||
|     BOOST_CONSTEXPR const charT& operator[](size_type pos) const ; | ||||
|     BOOST_CONSTEXPR const charT& at(size_t pos) const ; | ||||
|     BOOST_CONSTEXPR const charT& front() const ; | ||||
|     BOOST_CONSTEXPR const charT& back()  const ; | ||||
|     BOOST_CONSTEXPR const charT* data()  const BOOST_NOEXCEPT ; | ||||
|  | ||||
| Modifying the `string_view` (but not the underlying data): | ||||
|  | ||||
|     void clear();  // boost extension | ||||
|     BOOST_CXX14_CONSTEXPR void remove_prefix(size_type n); | ||||
|     BOOST_CXX14_CONSTEXPR void remove_suffix(size_type n); | ||||
|     BOOST_CXX14_CONSTEXPR void swap(basic_string_view& s) BOOST_NOEXCEPT; | ||||
|      | ||||
| Searching: | ||||
|  | ||||
|     BOOST_CXX14_CONSTEXPR size_type find(basic_string_view s, size_type pos = 0) const BOOST_NOEXCEPT; | ||||
|     BOOST_CXX14_CONSTEXPR size_type find(charT c, size_type pos = 0) const BOOST_NOEXCEPT; | ||||
|     BOOST_CXX14_CONSTEXPR size_type find(const charT* s, size_type pos, size_type n) const; | ||||
|     BOOST_CXX14_CONSTEXPR size_type find(const charT* s, size_type pos = 0) const; | ||||
|      | ||||
|     BOOST_CXX14_CONSTEXPR size_type rfind(basic_string_view s, size_type pos = npos) const BOOST_NOEXCEPT; | ||||
|     BOOST_CXX14_CONSTEXPR size_type rfind(charT c, size_type pos = npos) const BOOST_NOEXCEPT; | ||||
|     BOOST_CXX14_CONSTEXPR size_type rfind(const charT* s, size_type pos, size_type n) const; | ||||
|     BOOST_CXX14_CONSTEXPR size_type rfind(const charT* s, size_type pos = npos) const; | ||||
|      | ||||
|     BOOST_CXX14_CONSTEXPR size_type find_first_of(basic_string_view s, size_type pos = 0) const BOOST_NOEXCEPT; | ||||
|     BOOST_CXX14_CONSTEXPR size_type find_first_of(charT c, size_type pos = 0) const BOOST_NOEXCEPT; | ||||
|     BOOST_CXX14_CONSTEXPR size_type find_first_of(const charT* s, size_type pos, size_type n) const; | ||||
|     BOOST_CXX14_CONSTEXPR size_type find_first_of(const charT* s, size_type pos = 0) const; | ||||
|      | ||||
|     BOOST_CXX14_CONSTEXPR size_type find_last_of(basic_string_view s, size_type pos = npos) const BOOST_NOEXCEPT; | ||||
|     BOOST_CXX14_CONSTEXPR size_type find_last_of(charT c, size_type pos = npos) const BOOST_NOEXCEPT; | ||||
|     BOOST_CXX14_CONSTEXPR size_type find_last_of(const charT* s, size_type pos, size_type n) const; | ||||
|     BOOST_CXX14_CONSTEXPR size_type find_last_of(const charT* s, size_type pos = npos) const; | ||||
|      | ||||
|     BOOST_CXX14_CONSTEXPR size_type find_first_not_of(basic_string_view s, size_type pos = 0) const BOOST_NOEXCEPT; | ||||
|     BOOST_CXX14_CONSTEXPR size_type find_first_not_of(charT c, size_type pos = 0) const BOOST_NOEXCEPT; | ||||
|     BOOST_CXX14_CONSTEXPR size_type find_first_not_of(const charT* s, size_type pos, size_type n) const; | ||||
|     BOOST_CXX14_CONSTEXPR size_type find_first_not_of(const charT* s, size_type pos = 0) const; | ||||
|      | ||||
|     BOOST_CXX14_CONSTEXPR size_type find_last_not_of(basic_string_view s, size_type pos = npos) const BOOST_NOEXCEPT; | ||||
|     BOOST_CXX14_CONSTEXPR size_type find_last_not_of(charT c, size_type pos = npos) const BOOST_NOEXCEPT; | ||||
|     BOOST_CXX14_CONSTEXPR size_type find_last_not_of(const charT* s, size_type pos, size_type n) const; | ||||
|     BOOST_CXX14_CONSTEXPR size_type find_last_not_of(const charT* s, size_type pos = npos) const; | ||||
|    | ||||
|     BOOST_CONSTEXPR bool starts_with(charT c) const ;                 // boost extension | ||||
|     BOOST_CONSTEXPR bool starts_with(basic_string_view x) const ;     // boost extension | ||||
|     BOOST_CONSTEXPR bool ends_with(charT c) const ;                   // boost extension | ||||
|     BOOST_CONSTEXPR bool ends_with(basic_string_view x) const ;       // boost extension | ||||
|  | ||||
| String-like operations: | ||||
|  | ||||
|     template<class Allocator>  // Only present if compiler supports C++11 explicit conversion | ||||
|       explicit operator basic_string<charT, traits, Allocator>() const; | ||||
|      | ||||
|     template<class Allocator = allocator<charT> >  // Default only present if compiler supports | ||||
|       basic_string<charT, traits, Allocator>       //   C++11 default template parameters | ||||
|         to_string(const Allocator& a = Allocator()) const; | ||||
|  | ||||
|     size_type copy(charT* s, size_type n, size_type pos = 0) const; | ||||
|    | ||||
|     BOOST_CXX14_CONSTEXPR basic_string_view substr(size_type pos, | ||||
|       size_type n=npos) const ; // Create new string_view | ||||
|      | ||||
| Comparison: | ||||
|  | ||||
|     To be supplied | ||||
|  | ||||
| [endsect] | ||||
|  | ||||
| [/===============] | ||||
| [section Compiler Support] | ||||
| [/===============] | ||||
|  | ||||
| This Boost implementation only requires a C++03 compliant compiler. | ||||
|  | ||||
| The actual Library Fundamentals specification assumes a C++14 compliant compiler, so a few features are only present if actually supported by the compiler. Boost macros such as BOOST_CONSTEXPR, BOOST_CXX14_CONSTEXPR, and BOOST_NOEXCEPT supply certain features if supported by the compiler.  | ||||
|  | ||||
| [endsect] | ||||
|  | ||||
| [/===============] | ||||
| [section History] | ||||
| [/===============] | ||||
|  | ||||
| [heading boost 1.53] | ||||
| * Introduced, based on Jeffrey Yaskin's [@http://www.open-std.org/jtc1/sc22/wg21/docs/papers/2012/n3442.html N3442: | ||||
| string_ref: a non-owning reference to a string] | ||||
|  | ||||
| [heading boost 1.60] | ||||
| *  Updated to reflect [@ | ||||
| http://www.open-std.org/jtc1/sc22/wg21/docs/papers/2015/n4480.html#string.view N4480: | ||||
| ISO/IEC DTS 19568, Technical Specification - C++ Extensions for Library Fundamentals]    | ||||
|  | ||||
| [endsect] | ||||
|  | ||||
|  | ||||
|  | ||||
|  | ||||
| @@ -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> | ||||
| @@ -1,63 +0,0 @@ | ||||
| // | ||||
| // Copyright 2014 Peter Dimov | ||||
| // | ||||
| // 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 | ||||
| // | ||||
|  | ||||
| #include <boost/generator_iterator.hpp> | ||||
| #include <boost/detail/lightweight_test.hpp> | ||||
| #include <algorithm> | ||||
|  | ||||
| class X | ||||
| { | ||||
| private: | ||||
|  | ||||
|     int v; | ||||
|  | ||||
| public: | ||||
|  | ||||
|     typedef int result_type; | ||||
|  | ||||
|     X(): v( 0 ) | ||||
|     { | ||||
|     } | ||||
|  | ||||
|     int operator()() | ||||
|     { | ||||
|         return ++v; | ||||
|     } | ||||
| }; | ||||
|  | ||||
| template<class InputIterator, class Size, class OutputIterator> OutputIterator copy_n( InputIterator first, Size n, OutputIterator result ) | ||||
| { | ||||
|     while( n-- > 0 ) | ||||
|     { | ||||
|         *result++ = *first++; | ||||
|     } | ||||
|  | ||||
|     return result; | ||||
| } | ||||
|  | ||||
| void copy_test() | ||||
| { | ||||
|     X x; | ||||
|     boost::generator_iterator<X> in( &x ); | ||||
|  | ||||
|     int const N = 4; | ||||
|     int v[ N ] = { 0 }; | ||||
|  | ||||
|     ::copy_n( in, 4, v ); | ||||
|  | ||||
|     BOOST_TEST_EQ( v[0], 1 ); | ||||
|     BOOST_TEST_EQ( v[1], 2 ); | ||||
|     BOOST_TEST_EQ( v[2], 3 ); | ||||
|     BOOST_TEST_EQ( v[3], 4 ); | ||||
| } | ||||
|  | ||||
| int main() | ||||
| { | ||||
|     copy_test(); | ||||
|     return boost::report_errors(); | ||||
| } | ||||
| @@ -24,6 +24,7 @@ | ||||
|  | ||||
| #include <boost/type_traits/remove_cv.hpp> | ||||
| #include <boost/type_traits/is_empty.hpp> | ||||
| #include <boost/type_traits/is_final.hpp> | ||||
| #include <boost/type_traits/is_same.hpp> | ||||
| #include <boost/call_traits.hpp> | ||||
|  | ||||
| @@ -42,6 +43,14 @@ class compressed_pair; | ||||
|  | ||||
| namespace details | ||||
| { | ||||
|    template<class T, bool E = boost::is_final<T>::value> | ||||
|    struct compressed_pair_empty | ||||
|       : ::boost::false_type { }; | ||||
|  | ||||
|    template<class T> | ||||
|    struct compressed_pair_empty<T, false> | ||||
|       : ::boost::is_empty<T> { }; | ||||
|  | ||||
|    // JM altered 26 Jan 2000: | ||||
|    template <class T1, class T2, bool IsSame, bool FirstEmpty, bool SecondEmpty> | ||||
|    struct compressed_pair_switch; | ||||
| @@ -343,8 +352,8 @@ class compressed_pair | ||||
|                     T1, | ||||
|                     T2, | ||||
|                     ::boost::is_same<typename remove_cv<T1>::type, typename remove_cv<T2>::type>::value, | ||||
|                     ::boost::is_empty<T1>::value, | ||||
|                     ::boost::is_empty<T2>::value>::value> | ||||
|                     ::boost::details::compressed_pair_empty<T1>::value, | ||||
|                     ::boost::details::compressed_pair_empty<T2>::value>::value> | ||||
| { | ||||
| private: | ||||
|    typedef details::compressed_pair_imp<T1, T2, | ||||
| @@ -352,8 +361,8 @@ private: | ||||
|                     T1, | ||||
|                     T2, | ||||
|                     ::boost::is_same<typename remove_cv<T1>::type, typename remove_cv<T2>::type>::value, | ||||
|                     ::boost::is_empty<T1>::value, | ||||
|                     ::boost::is_empty<T2>::value>::value> base; | ||||
|                     ::boost::details::compressed_pair_empty<T1>::value, | ||||
|                     ::boost::details::compressed_pair_empty<T2>::value>::value> base; | ||||
| public: | ||||
|    typedef T1                                                 first_type; | ||||
|    typedef T2                                                 second_type; | ||||
| @@ -388,8 +397,8 @@ class compressed_pair<T, T> | ||||
|                     T, | ||||
|                     T, | ||||
|                     ::boost::is_same<typename remove_cv<T>::type, typename remove_cv<T>::type>::value, | ||||
|                     ::boost::is_empty<T>::value, | ||||
|                     ::boost::is_empty<T>::value>::value> | ||||
|                     ::boost::details::compressed_pair_empty<T>::value, | ||||
|                     ::boost::details::compressed_pair_empty<T>::value>::value> | ||||
| { | ||||
| private: | ||||
|    typedef details::compressed_pair_imp<T, T, | ||||
| @@ -397,8 +406,8 @@ private: | ||||
|                     T, | ||||
|                     T, | ||||
|                     ::boost::is_same<typename remove_cv<T>::type, typename remove_cv<T>::type>::value, | ||||
|                     ::boost::is_empty<T>::value, | ||||
|                     ::boost::is_empty<T>::value>::value> base; | ||||
|                     ::boost::details::compressed_pair_empty<T>::value, | ||||
|                     ::boost::details::compressed_pair_empty<T>::value>::value> base; | ||||
| public: | ||||
|    typedef T                                                  first_type; | ||||
|    typedef T                                                  second_type; | ||||
|   | ||||
| @@ -1,165 +0,0 @@ | ||||
| //  Boost next_prior.hpp header file  ---------------------------------------// | ||||
|  | ||||
| //  (C) Copyright Dave Abrahams and Daniel Walker 1999-2003. 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 <iterator> | ||||
| #if defined(_MSC_VER) && _MSC_VER <= 1310 | ||||
| #include <boost/mpl/and.hpp> | ||||
| #include <boost/type_traits/is_integral.hpp> | ||||
| #endif | ||||
| #include <boost/type_traits/is_unsigned.hpp> | ||||
| #include <boost/type_traits/integral_promotion.hpp> | ||||
| #include <boost/type_traits/make_signed.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> | ||||
|  | ||||
| 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_impl2 | ||||
| { | ||||
|     static T call(T x, Distance n) | ||||
|     { | ||||
|         std::advance(x, n); | ||||
|         return x; | ||||
|     } | ||||
| }; | ||||
|  | ||||
| template< typename T, typename Distance > | ||||
| struct next_impl2< 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_impl1 : | ||||
|     public next_impl2< T, Distance > | ||||
| { | ||||
| }; | ||||
|  | ||||
| template< typename T, typename Distance > | ||||
| struct next_impl1< T, Distance, true > | ||||
| { | ||||
|     static T call(T x, Distance n) | ||||
|     { | ||||
|         x += n; | ||||
|         return x; | ||||
|     } | ||||
| }; | ||||
|  | ||||
|  | ||||
| template< | ||||
|     typename T, | ||||
|     typename Distance, | ||||
|     typename PromotedDistance = typename integral_promotion< Distance >::type, | ||||
| #if !defined(_MSC_VER) || _MSC_VER > 1310 | ||||
|     bool IsUInt = is_unsigned< PromotedDistance >::value | ||||
| #else | ||||
|     // MSVC 7.1 has problems with applying is_unsigned to non-integral types | ||||
|     bool IsUInt = mpl::and_< is_integral< PromotedDistance >, is_unsigned< PromotedDistance > >::value | ||||
| #endif | ||||
| > | ||||
| struct prior_impl3 | ||||
| { | ||||
|     static T call(T x, Distance n) | ||||
|     { | ||||
|         std::advance(x, -n); | ||||
|         return x; | ||||
|     } | ||||
| }; | ||||
|  | ||||
| template< typename T, typename Distance, typename PromotedDistance > | ||||
| struct prior_impl3< T, Distance, PromotedDistance, true > | ||||
| { | ||||
|     static T call(T x, Distance n) | ||||
|     { | ||||
|         typedef typename make_signed< PromotedDistance >::type signed_distance; | ||||
|         std::advance(x, -static_cast< signed_distance >(static_cast< PromotedDistance >(n))); | ||||
|         return x; | ||||
|     } | ||||
| }; | ||||
|  | ||||
|  | ||||
| template< typename T, typename Distance, bool HasMinus = has_minus< T, Distance >::value > | ||||
| struct prior_impl2 : | ||||
|     public prior_impl3< T, Distance > | ||||
| { | ||||
| }; | ||||
|  | ||||
| template< typename T, typename Distance > | ||||
| struct prior_impl2< 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_impl1 : | ||||
|     public prior_impl2< T, Distance > | ||||
| { | ||||
| }; | ||||
|  | ||||
| template< typename T, typename Distance > | ||||
| struct prior_impl1< T, Distance, true > | ||||
| { | ||||
|     static T call(T x, Distance n) | ||||
|     { | ||||
|         x -= n; | ||||
|         return x; | ||||
|     } | ||||
| }; | ||||
|  | ||||
| } // 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_impl1< 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_impl1< T, Distance >::call(x, n); | ||||
| } | ||||
|  | ||||
| } // namespace boost | ||||
|  | ||||
| #endif  // BOOST_NEXT_PRIOR_HPP_INCLUDED | ||||
| @@ -1,6 +1,7 @@ | ||||
| //  Boost operators.hpp header file  ----------------------------------------// | ||||
|  | ||||
| //  (C) Copyright David Abrahams, Jeremy Siek, Daryle Walker 1999-2001. | ||||
| //  (C) Copyright Daniel Frey 2002-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) | ||||
| @@ -8,6 +9,11 @@ | ||||
| //  See http://www.boost.org/libs/utility/operators.htm for documentation. | ||||
|  | ||||
| //  Revision History | ||||
| //  23 Nov 17 Protect dereferenceable<> from overloaded operator&. | ||||
| //  15 Oct 17 Adapted to C++17, replace std::iterator<> with manual | ||||
| //            implementation. | ||||
| //  22 Feb 16 Added ADL protection, preserve old work-arounds in | ||||
| //            operators_v1.hpp and clean up this file. (Daniel Frey) | ||||
| //  16 Dec 10 Limit warning suppression for 4284 to older versions of VC++ | ||||
| //            (Matthew Bradbury, fixes #4432) | ||||
| //  07 Aug 08 Added "euclidean" spelling. (Daniel Frey) | ||||
| @@ -24,8 +30,8 @@ | ||||
| //            additional classes for groups of related operators added; | ||||
| //            workaround for empty base class optimization | ||||
| //            bug of GCC 3.0 (Helmut Zeisel) | ||||
| //  25 Jun 01 output_iterator_helper changes: removed default template  | ||||
| //            parameters, added support for self-proxying, additional  | ||||
| //  25 Jun 01 output_iterator_helper changes: removed default template | ||||
| //            parameters, added support for self-proxying, additional | ||||
| //            documentation and tests (Aleksey Gurtovoy) | ||||
| //  29 May 01 Added operator classes for << and >>.  Added input and output | ||||
| //            iterator helper classes.  Added classes to connect equality and | ||||
| @@ -38,18 +44,18 @@ | ||||
| //  04 Jul 00 Fixed NO_OPERATORS_IN_NAMESPACE bugs, major cleanup and | ||||
| //            refactoring of compiler workarounds, additional documentation | ||||
| //            (Alexy Gurtovoy and Mark Rodgers with some help and prompting from | ||||
| //            Dave Abrahams)  | ||||
| //            Dave Abrahams) | ||||
| //  28 Jun 00 General cleanup and integration of bugfixes from Mark Rodgers and | ||||
| //            Jeremy Siek (Dave Abrahams) | ||||
| //  20 Jun 00 Changes to accommodate Borland C++Builder 4 and Borland C++ 5.5 | ||||
| //            (Mark Rodgers) | ||||
| //  20 Jun 00 Minor fixes to the prior revision (Aleksey Gurtovoy) | ||||
| //  10 Jun 00 Support for the base class chaining technique was added | ||||
| //            (Aleksey Gurtovoy). See documentation and the comments below  | ||||
| //            for the details.  | ||||
| //            (Aleksey Gurtovoy). See documentation and the comments below | ||||
| //            for the details. | ||||
| //  12 Dec 99 Initial version with iterator operators (Jeremy Siek) | ||||
| //  18 Nov 99 Change name "divideable" to "dividable", remove unnecessary | ||||
| //            specializations of dividable, subtractable, modable (Ed Brey)  | ||||
| //            specializations of dividable, subtractable, modable (Ed Brey) | ||||
| //  17 Nov 99 Add comments (Beman Dawes) | ||||
| //            Remove unnecessary specialization of operators<> (Ed Brey) | ||||
| //  15 Nov 99 Fix less_than_comparable<T,U> second operand type for first two | ||||
| @@ -60,8 +66,8 @@ | ||||
| //  10 Nov 99 Initial version | ||||
|  | ||||
| // 10 Jun 00: | ||||
| // An additional optional template parameter was added to most of  | ||||
| // operator templates to support the base class chaining technique (see  | ||||
| // An additional optional template parameter was added to most of | ||||
| // operator templates to support the base class chaining technique (see | ||||
| // documentation for the details). Unfortunately, a straightforward | ||||
| // implementation of this change would have broken compatibility with the | ||||
| // previous version of the library by making it impossible to use the same | ||||
| @@ -70,56 +76,60 @@ | ||||
| // issue at the cost of some simplicity. | ||||
| // | ||||
| // One of the complications is an existence of special auxiliary class template | ||||
| // 'is_chained_base<>' (see 'detail' namespace below), which is used | ||||
| // 'is_chained_base<>' (see 'operators_detail' namespace below), which is used | ||||
| // to determine whether its template parameter is a library's operator template | ||||
| // or not. You have to specialize 'is_chained_base<>' for each new  | ||||
| // or not. You have to specialize 'is_chained_base<>' for each new | ||||
| // operator template you add to the library. | ||||
| // | ||||
| // However, most of the non-trivial implementation details are hidden behind  | ||||
| // However, most of the non-trivial implementation details are hidden behind | ||||
| // several local macros defined below, and as soon as you understand them, | ||||
| // you understand the whole library implementation.  | ||||
| // you understand the whole library implementation. | ||||
|  | ||||
| #ifndef BOOST_OPERATORS_HPP | ||||
| #define BOOST_OPERATORS_HPP | ||||
|  | ||||
| // If old work-arounds are needed, refer to the preserved version without | ||||
| // ADL protection. | ||||
| #if defined(BOOST_NO_OPERATORS_IN_NAMESPACE) || defined(BOOST_USE_OPERATORS_V1) | ||||
| #include "operators_v1.hpp" | ||||
| #else | ||||
|  | ||||
| #include <cstddef> | ||||
| #include <iterator> | ||||
|  | ||||
| #include <boost/config.hpp> | ||||
| #include <boost/iterator.hpp> | ||||
| #include <boost/detail/workaround.hpp> | ||||
| #include <boost/core/addressof.hpp> | ||||
|  | ||||
| #if defined(__sgi) && !defined(__GNUC__) | ||||
| #   pragma set woff 1234 | ||||
| #endif | ||||
|  | ||||
| #if BOOST_WORKAROUND(BOOST_MSVC, < 1600) | ||||
| #   pragma warning( disable : 4284 ) // complaint about return type of  | ||||
| #   pragma warning( disable : 4284 ) // complaint about return type of | ||||
| #endif                               // operator-> not begin a UDT | ||||
|  | ||||
| namespace boost { | ||||
| namespace detail { | ||||
|  | ||||
| template <typename T> class empty_base {}; | ||||
|  | ||||
| } // namespace detail | ||||
| } // namespace boost | ||||
|  | ||||
| // In this section we supply the xxxx1 and xxxx2 forms of the operator | ||||
| // templates, which are explicitly targeted at the 1-type-argument and | ||||
| // 2-type-argument operator forms, respectively. Some compilers get confused | ||||
| // when inline friend functions are overloaded in namespaces other than the | ||||
| // global namespace. When BOOST_NO_OPERATORS_IN_NAMESPACE is defined, all of | ||||
| // these templates must go in the global namespace. | ||||
| // 2-type-argument operator forms, respectively. | ||||
|  | ||||
| #ifndef BOOST_NO_OPERATORS_IN_NAMESPACE | ||||
| namespace boost | ||||
| { | ||||
| #endif | ||||
| namespace operators_impl | ||||
| { | ||||
| namespace operators_detail | ||||
| { | ||||
|  | ||||
| template <typename T> class empty_base {}; | ||||
|  | ||||
| } // namespace operators_detail | ||||
|  | ||||
| //  Basic operator classes (contributed by Dave Abrahams) ------------------// | ||||
|  | ||||
| //  Note that friend functions defined in a class are implicitly inline. | ||||
| //  See the C++ std, 11.4 [class.friend] paragraph 5 | ||||
|  | ||||
| template <class T, class U, class B = ::boost::detail::empty_base<T> > | ||||
| template <class T, class U, class B = operators_detail::empty_base<T> > | ||||
| struct less_than_comparable2 : B | ||||
| { | ||||
|      friend bool operator<=(const T& x, const U& y) { return !static_cast<bool>(x > y); } | ||||
| @@ -130,7 +140,7 @@ struct less_than_comparable2 : B | ||||
|      friend bool operator>=(const U& x, const T& y) { return !static_cast<bool>(y > x); } | ||||
| }; | ||||
|  | ||||
| template <class T, class B = ::boost::detail::empty_base<T> > | ||||
| template <class T, class B = operators_detail::empty_base<T> > | ||||
| struct less_than_comparable1 : B | ||||
| { | ||||
|      friend bool operator>(const T& x, const T& y)  { return y < x; } | ||||
| @@ -138,7 +148,7 @@ struct less_than_comparable1 : B | ||||
|      friend bool operator>=(const T& x, const T& y) { return !static_cast<bool>(x < y); } | ||||
| }; | ||||
|  | ||||
| template <class T, class U, class B = ::boost::detail::empty_base<T> > | ||||
| template <class T, class U, class B = operators_detail::empty_base<T> > | ||||
| struct equality_comparable2 : B | ||||
| { | ||||
|      friend bool operator==(const U& y, const T& x) { return x == y; } | ||||
| @@ -146,7 +156,7 @@ struct equality_comparable2 : B | ||||
|      friend bool operator!=(const T& y, const U& x) { return !static_cast<bool>(y == x); } | ||||
| }; | ||||
|  | ||||
| template <class T, class B = ::boost::detail::empty_base<T> > | ||||
| template <class T, class B = operators_detail::empty_base<T> > | ||||
| struct equality_comparable1 : B | ||||
| { | ||||
|      friend bool operator!=(const T& x, const T& y) { return !static_cast<bool>(x == y); } | ||||
| @@ -164,39 +174,39 @@ struct equality_comparable1 : B | ||||
| // If the compiler has no NRVO, this is the best symmetric | ||||
| // implementation available. | ||||
|  | ||||
| #define BOOST_BINARY_OPERATOR_COMMUTATIVE( NAME, OP )                         \ | ||||
| template <class T, class U, class B = ::boost::detail::empty_base<T> >        \ | ||||
| struct NAME##2 : B                                                            \ | ||||
| {                                                                             \ | ||||
|   friend T operator OP( const T& lhs, const U& rhs )                          \ | ||||
|     { T nrv( lhs ); nrv OP##= rhs; return nrv; }                              \ | ||||
|   friend T operator OP( const U& lhs, const T& rhs )                          \ | ||||
|     { T nrv( rhs ); nrv OP##= lhs; return nrv; }                              \ | ||||
| };                                                                            \ | ||||
|                                                                               \ | ||||
| template <class T, class B = ::boost::detail::empty_base<T> >                 \ | ||||
| struct NAME##1 : B                                                            \ | ||||
| {                                                                             \ | ||||
|   friend T operator OP( const T& lhs, const T& rhs )                          \ | ||||
|     { T nrv( lhs ); nrv OP##= rhs; return nrv; }                              \ | ||||
| #define BOOST_BINARY_OPERATOR_COMMUTATIVE( NAME, OP )                   \ | ||||
| template <class T, class U, class B = operators_detail::empty_base<T> > \ | ||||
| struct NAME##2 : B                                                      \ | ||||
| {                                                                       \ | ||||
|   friend T operator OP( const T& lhs, const U& rhs )                    \ | ||||
|     { T nrv( lhs ); nrv OP##= rhs; return nrv; }                        \ | ||||
|   friend T operator OP( const U& lhs, const T& rhs )                    \ | ||||
|     { T nrv( rhs ); nrv OP##= lhs; return nrv; }                        \ | ||||
| };                                                                      \ | ||||
|                                                                         \ | ||||
| template <class T, class B = operators_detail::empty_base<T> >          \ | ||||
| struct NAME##1 : B                                                      \ | ||||
| {                                                                       \ | ||||
|   friend T operator OP( const T& lhs, const T& rhs )                    \ | ||||
|     { T nrv( lhs ); nrv OP##= rhs; return nrv; }                        \ | ||||
| }; | ||||
|  | ||||
| #define BOOST_BINARY_OPERATOR_NON_COMMUTATIVE( NAME, OP )               \ | ||||
| template <class T, class U, class B = ::boost::detail::empty_base<T> >  \ | ||||
| template <class T, class U, class B = operators_detail::empty_base<T> > \ | ||||
| struct NAME##2 : B                                                      \ | ||||
| {                                                                       \ | ||||
|   friend T operator OP( const T& lhs, const U& rhs )                    \ | ||||
|     { T nrv( lhs ); nrv OP##= rhs; return nrv; }                        \ | ||||
| };                                                                      \ | ||||
|                                                                         \ | ||||
| template <class T, class U, class B = ::boost::detail::empty_base<T> >  \ | ||||
| template <class T, class U, class B = operators_detail::empty_base<T> > \ | ||||
| struct BOOST_OPERATOR2_LEFT(NAME) : B                                   \ | ||||
| {                                                                       \ | ||||
|   friend T operator OP( const U& lhs, const T& rhs )                    \ | ||||
|     { T nrv( lhs ); nrv OP##= rhs; return nrv; }                        \ | ||||
| };                                                                      \ | ||||
|                                                                         \ | ||||
| template <class T, class B = ::boost::detail::empty_base<T> >           \ | ||||
| template <class T, class B = operators_detail::empty_base<T> >          \ | ||||
| struct NAME##1 : B                                                      \ | ||||
| {                                                                       \ | ||||
|   friend T operator OP( const T& lhs, const T& rhs )                    \ | ||||
| @@ -211,34 +221,34 @@ struct NAME##1 : B                                                      \ | ||||
| // optimization opportunities to the compiler :) | ||||
|  | ||||
| #define BOOST_BINARY_OPERATOR_COMMUTATIVE( NAME, OP )                   \ | ||||
| template <class T, class U, class B = ::boost::detail::empty_base<T> >  \ | ||||
| template <class T, class U, class B = operators_detail::empty_base<T> > \ | ||||
| struct NAME##2 : B                                                      \ | ||||
| {                                                                       \ | ||||
|   friend T operator OP( T lhs, const U& rhs ) { return lhs OP##= rhs; } \ | ||||
|   friend T operator OP( const U& lhs, T rhs ) { return rhs OP##= lhs; } \ | ||||
| };                                                                      \ | ||||
|                                                                         \ | ||||
| template <class T, class B = ::boost::detail::empty_base<T> >           \ | ||||
| template <class T, class B = operators_detail::empty_base<T> >          \ | ||||
| struct NAME##1 : B                                                      \ | ||||
| {                                                                       \ | ||||
|   friend T operator OP( T lhs, const T& rhs ) { return lhs OP##= rhs; } \ | ||||
| }; | ||||
|  | ||||
| #define BOOST_BINARY_OPERATOR_NON_COMMUTATIVE( NAME, OP )               \ | ||||
| template <class T, class U, class B = ::boost::detail::empty_base<T> >  \ | ||||
| template <class T, class U, class B = operators_detail::empty_base<T> > \ | ||||
| struct NAME##2 : B                                                      \ | ||||
| {                                                                       \ | ||||
|   friend T operator OP( T lhs, const U& rhs ) { return lhs OP##= rhs; } \ | ||||
| };                                                                      \ | ||||
|                                                                         \ | ||||
| template <class T, class U, class B = ::boost::detail::empty_base<T> >  \ | ||||
| template <class T, class U, class B = operators_detail::empty_base<T> > \ | ||||
| struct BOOST_OPERATOR2_LEFT(NAME) : B                                   \ | ||||
| {                                                                       \ | ||||
|   friend T operator OP( const U& lhs, const T& rhs )                    \ | ||||
|     { return T( lhs ) OP##= rhs; }                                      \ | ||||
| };                                                                      \ | ||||
|                                                                         \ | ||||
| template <class T, class B = ::boost::detail::empty_base<T> >           \ | ||||
| template <class T, class B = operators_detail::empty_base<T> >          \ | ||||
| struct NAME##1 : B                                                      \ | ||||
| {                                                                       \ | ||||
|   friend T operator OP( T lhs, const T& rhs ) { return lhs OP##= rhs; } \ | ||||
| @@ -261,7 +271,7 @@ BOOST_BINARY_OPERATOR_COMMUTATIVE( orable, | ) | ||||
|  | ||||
| //  incrementable and decrementable contributed by Jeremy Siek | ||||
|  | ||||
| template <class T, class B = ::boost::detail::empty_base<T> > | ||||
| template <class T, class B = operators_detail::empty_base<T> > | ||||
| struct incrementable : B | ||||
| { | ||||
|   friend T operator++(T& x, int) | ||||
| @@ -274,7 +284,7 @@ private: // The use of this typedef works around a Borland bug | ||||
|   typedef T incrementable_type; | ||||
| }; | ||||
|  | ||||
| template <class T, class B = ::boost::detail::empty_base<T> > | ||||
| template <class T, class B = operators_detail::empty_base<T> > | ||||
| struct decrementable : B | ||||
| { | ||||
|   friend T operator--(T& x, int) | ||||
| @@ -289,16 +299,16 @@ private: // The use of this typedef works around a Borland bug | ||||
|  | ||||
| //  Iterator operator classes (contributed by Jeremy Siek) ------------------// | ||||
|  | ||||
| template <class T, class P, class B = ::boost::detail::empty_base<T> > | ||||
| template <class T, class P, class B = operators_detail::empty_base<T> > | ||||
| struct dereferenceable : B | ||||
| { | ||||
|   P operator->() const | ||||
|   {  | ||||
|     return &*static_cast<const T&>(*this);  | ||||
|   { | ||||
|     return ::boost::addressof(*static_cast<const T&>(*this)); | ||||
|   } | ||||
| }; | ||||
|  | ||||
| template <class T, class I, class R, class B = ::boost::detail::empty_base<T> > | ||||
| template <class T, class I, class R, class B = operators_detail::empty_base<T> > | ||||
| struct indexable : B | ||||
| { | ||||
|   R operator[](I n) const | ||||
| @@ -312,34 +322,34 @@ struct indexable : B | ||||
|  | ||||
| #if defined(BOOST_HAS_NRVO) || defined(BOOST_FORCE_SYMMETRIC_OPERATORS) | ||||
|  | ||||
| #define BOOST_BINARY_OPERATOR( NAME, OP )                                     \ | ||||
| template <class T, class U, class B = ::boost::detail::empty_base<T> >        \ | ||||
| struct NAME##2 : B                                                            \ | ||||
| {                                                                             \ | ||||
|   friend T operator OP( const T& lhs, const U& rhs )                          \ | ||||
|     { T nrv( lhs ); nrv OP##= rhs; return nrv; }                              \ | ||||
| };                                                                            \ | ||||
|                                                                               \ | ||||
| template <class T, class B = ::boost::detail::empty_base<T> >                 \ | ||||
| struct NAME##1 : B                                                            \ | ||||
| {                                                                             \ | ||||
|   friend T operator OP( const T& lhs, const T& rhs )                          \ | ||||
|     { T nrv( lhs ); nrv OP##= rhs; return nrv; }                              \ | ||||
| #define BOOST_BINARY_OPERATOR( NAME, OP )                               \ | ||||
| template <class T, class U, class B = operators_detail::empty_base<T> > \ | ||||
| struct NAME##2 : B                                                      \ | ||||
| {                                                                       \ | ||||
|   friend T operator OP( const T& lhs, const U& rhs )                    \ | ||||
|     { T nrv( lhs ); nrv OP##= rhs; return nrv; }                        \ | ||||
| };                                                                      \ | ||||
|                                                                         \ | ||||
| template <class T, class B = operators_detail::empty_base<T> >          \ | ||||
| struct NAME##1 : B                                                      \ | ||||
| {                                                                       \ | ||||
|   friend T operator OP( const T& lhs, const T& rhs )                    \ | ||||
|     { T nrv( lhs ); nrv OP##= rhs; return nrv; }                        \ | ||||
| }; | ||||
|  | ||||
| #else // defined(BOOST_HAS_NRVO) || defined(BOOST_FORCE_SYMMETRIC_OPERATORS) | ||||
|  | ||||
| #define BOOST_BINARY_OPERATOR( NAME, OP )                                     \ | ||||
| template <class T, class U, class B = ::boost::detail::empty_base<T> >        \ | ||||
| struct NAME##2 : B                                                            \ | ||||
| {                                                                             \ | ||||
|   friend T operator OP( T lhs, const U& rhs ) { return lhs OP##= rhs; }       \ | ||||
| };                                                                            \ | ||||
|                                                                               \ | ||||
| template <class T, class B = ::boost::detail::empty_base<T> >                 \ | ||||
| struct NAME##1 : B                                                            \ | ||||
| {                                                                             \ | ||||
|   friend T operator OP( T lhs, const T& rhs ) { return lhs OP##= rhs; }       \ | ||||
| #define BOOST_BINARY_OPERATOR( NAME, OP )                               \ | ||||
| template <class T, class U, class B = operators_detail::empty_base<T> > \ | ||||
| struct NAME##2 : B                                                      \ | ||||
| {                                                                       \ | ||||
|   friend T operator OP( T lhs, const U& rhs ) { return lhs OP##= rhs; } \ | ||||
| };                                                                      \ | ||||
|                                                                         \ | ||||
| template <class T, class B = operators_detail::empty_base<T> >          \ | ||||
| struct NAME##1 : B                                                      \ | ||||
| {                                                                       \ | ||||
|   friend T operator OP( T lhs, const T& rhs ) { return lhs OP##= rhs; } \ | ||||
| }; | ||||
|  | ||||
| #endif // defined(BOOST_HAS_NRVO) || defined(BOOST_FORCE_SYMMETRIC_OPERATORS) | ||||
| @@ -349,7 +359,7 @@ BOOST_BINARY_OPERATOR( right_shiftable, >> ) | ||||
|  | ||||
| #undef BOOST_BINARY_OPERATOR | ||||
|  | ||||
| template <class T, class U, class B = ::boost::detail::empty_base<T> > | ||||
| template <class T, class U, class B = operators_detail::empty_base<T> > | ||||
| struct equivalent2 : B | ||||
| { | ||||
|   friend bool operator==(const T& x, const U& y) | ||||
| @@ -358,7 +368,7 @@ struct equivalent2 : B | ||||
|   } | ||||
| }; | ||||
|  | ||||
| template <class T, class B = ::boost::detail::empty_base<T> > | ||||
| template <class T, class B = operators_detail::empty_base<T> > | ||||
| struct equivalent1 : B | ||||
| { | ||||
|   friend bool operator==(const T&x, const T&y) | ||||
| @@ -367,7 +377,7 @@ struct equivalent1 : B | ||||
|   } | ||||
| }; | ||||
|  | ||||
| template <class T, class U, class B = ::boost::detail::empty_base<T> > | ||||
| template <class T, class U, class B = operators_detail::empty_base<T> > | ||||
| struct partially_ordered2 : B | ||||
| { | ||||
|   friend bool operator<=(const T& x, const U& y) | ||||
| @@ -384,7 +394,7 @@ struct partially_ordered2 : B | ||||
|     { return static_cast<bool>(y < x) || static_cast<bool>(y == x); } | ||||
| }; | ||||
|  | ||||
| template <class T, class B = ::boost::detail::empty_base<T> > | ||||
| template <class T, class B = operators_detail::empty_base<T> > | ||||
| struct partially_ordered1 : B | ||||
| { | ||||
|   friend bool operator>(const T& x, const T& y) | ||||
| @@ -397,161 +407,161 @@ struct partially_ordered1 : B | ||||
|  | ||||
| //  Combined operator classes (contributed by Daryle Walker) ----------------// | ||||
|  | ||||
| template <class T, class U, class B = ::boost::detail::empty_base<T> > | ||||
| template <class T, class U, class B = operators_detail::empty_base<T> > | ||||
| struct totally_ordered2 | ||||
|     : less_than_comparable2<T, U | ||||
|     , equality_comparable2<T, U, B | ||||
|       > > {}; | ||||
|  | ||||
| template <class T, class B = ::boost::detail::empty_base<T> > | ||||
| template <class T, class B = operators_detail::empty_base<T> > | ||||
| struct totally_ordered1 | ||||
|     : less_than_comparable1<T | ||||
|     , equality_comparable1<T, B | ||||
|       > > {}; | ||||
|  | ||||
| template <class T, class U, class B = ::boost::detail::empty_base<T> > | ||||
| template <class T, class U, class B = operators_detail::empty_base<T> > | ||||
| struct additive2 | ||||
|     : addable2<T, U | ||||
|     , subtractable2<T, U, B | ||||
|       > > {}; | ||||
|  | ||||
| template <class T, class B = ::boost::detail::empty_base<T> > | ||||
| template <class T, class B = operators_detail::empty_base<T> > | ||||
| struct additive1 | ||||
|     : addable1<T | ||||
|     , subtractable1<T, B | ||||
|       > > {}; | ||||
|  | ||||
| template <class T, class U, class B = ::boost::detail::empty_base<T> > | ||||
| template <class T, class U, class B = operators_detail::empty_base<T> > | ||||
| struct multiplicative2 | ||||
|     : multipliable2<T, U | ||||
|     , dividable2<T, U, B | ||||
|       > > {}; | ||||
|  | ||||
| template <class T, class B = ::boost::detail::empty_base<T> > | ||||
| template <class T, class B = operators_detail::empty_base<T> > | ||||
| struct multiplicative1 | ||||
|     : multipliable1<T | ||||
|     , dividable1<T, B | ||||
|       > > {}; | ||||
|  | ||||
| template <class T, class U, class B = ::boost::detail::empty_base<T> > | ||||
| template <class T, class U, class B = operators_detail::empty_base<T> > | ||||
| struct integer_multiplicative2 | ||||
|     : multiplicative2<T, U | ||||
|     , modable2<T, U, B | ||||
|       > > {}; | ||||
|  | ||||
| template <class T, class B = ::boost::detail::empty_base<T> > | ||||
| template <class T, class B = operators_detail::empty_base<T> > | ||||
| struct integer_multiplicative1 | ||||
|     : multiplicative1<T | ||||
|     , modable1<T, B | ||||
|       > > {}; | ||||
|  | ||||
| template <class T, class U, class B = ::boost::detail::empty_base<T> > | ||||
| template <class T, class U, class B = operators_detail::empty_base<T> > | ||||
| struct arithmetic2 | ||||
|     : additive2<T, U | ||||
|     , multiplicative2<T, U, B | ||||
|       > > {}; | ||||
|  | ||||
| template <class T, class B = ::boost::detail::empty_base<T> > | ||||
| template <class T, class B = operators_detail::empty_base<T> > | ||||
| struct arithmetic1 | ||||
|     : additive1<T | ||||
|     , multiplicative1<T, B | ||||
|       > > {}; | ||||
|  | ||||
| template <class T, class U, class B = ::boost::detail::empty_base<T> > | ||||
| template <class T, class U, class B = operators_detail::empty_base<T> > | ||||
| struct integer_arithmetic2 | ||||
|     : additive2<T, U | ||||
|     , integer_multiplicative2<T, U, B | ||||
|       > > {}; | ||||
|  | ||||
| template <class T, class B = ::boost::detail::empty_base<T> > | ||||
| template <class T, class B = operators_detail::empty_base<T> > | ||||
| struct integer_arithmetic1 | ||||
|     : additive1<T | ||||
|     , integer_multiplicative1<T, B | ||||
|       > > {}; | ||||
|  | ||||
| template <class T, class U, class B = ::boost::detail::empty_base<T> > | ||||
| template <class T, class U, class B = operators_detail::empty_base<T> > | ||||
| struct bitwise2 | ||||
|     : xorable2<T, U | ||||
|     , andable2<T, U | ||||
|     , orable2<T, U, B | ||||
|       > > > {}; | ||||
|  | ||||
| template <class T, class B = ::boost::detail::empty_base<T> > | ||||
| template <class T, class B = operators_detail::empty_base<T> > | ||||
| struct bitwise1 | ||||
|     : xorable1<T | ||||
|     , andable1<T | ||||
|     , orable1<T, B | ||||
|       > > > {}; | ||||
|  | ||||
| template <class T, class B = ::boost::detail::empty_base<T> > | ||||
| template <class T, class B = operators_detail::empty_base<T> > | ||||
| struct unit_steppable | ||||
|     : incrementable<T | ||||
|     , decrementable<T, B | ||||
|       > > {}; | ||||
|  | ||||
| template <class T, class U, class B = ::boost::detail::empty_base<T> > | ||||
| template <class T, class U, class B = operators_detail::empty_base<T> > | ||||
| struct shiftable2 | ||||
|     : left_shiftable2<T, U | ||||
|     , right_shiftable2<T, U, B | ||||
|       > > {}; | ||||
|  | ||||
| template <class T, class B = ::boost::detail::empty_base<T> > | ||||
| template <class T, class B = operators_detail::empty_base<T> > | ||||
| struct shiftable1 | ||||
|     : left_shiftable1<T | ||||
|     , right_shiftable1<T, B | ||||
|       > > {}; | ||||
|  | ||||
| template <class T, class U, class B = ::boost::detail::empty_base<T> > | ||||
| template <class T, class U, class B = operators_detail::empty_base<T> > | ||||
| struct ring_operators2 | ||||
|     : additive2<T, U | ||||
|     , subtractable2_left<T, U | ||||
|     , multipliable2<T, U, B | ||||
|       > > > {}; | ||||
|  | ||||
| template <class T, class B = ::boost::detail::empty_base<T> > | ||||
| template <class T, class B = operators_detail::empty_base<T> > | ||||
| struct ring_operators1 | ||||
|     : additive1<T | ||||
|     , multipliable1<T, B | ||||
|       > > {}; | ||||
|  | ||||
| template <class T, class U, class B = ::boost::detail::empty_base<T> > | ||||
| template <class T, class U, class B = operators_detail::empty_base<T> > | ||||
| struct ordered_ring_operators2 | ||||
|     : ring_operators2<T, U | ||||
|     , totally_ordered2<T, U, B | ||||
|       > > {}; | ||||
|  | ||||
| template <class T, class B = ::boost::detail::empty_base<T> > | ||||
| template <class T, class B = operators_detail::empty_base<T> > | ||||
| struct ordered_ring_operators1 | ||||
|     : ring_operators1<T | ||||
|     , totally_ordered1<T, B | ||||
|       > > {}; | ||||
|  | ||||
| template <class T, class U, class B = ::boost::detail::empty_base<T> > | ||||
| template <class T, class U, class B = operators_detail::empty_base<T> > | ||||
| struct field_operators2 | ||||
|     : ring_operators2<T, U | ||||
|     , dividable2<T, U | ||||
|     , dividable2_left<T, U, B | ||||
|       > > > {}; | ||||
|  | ||||
| template <class T, class B = ::boost::detail::empty_base<T> > | ||||
| template <class T, class B = operators_detail::empty_base<T> > | ||||
| struct field_operators1 | ||||
|     : ring_operators1<T | ||||
|     , dividable1<T, B | ||||
|       > > {}; | ||||
|  | ||||
| template <class T, class U, class B = ::boost::detail::empty_base<T> > | ||||
| template <class T, class U, class B = operators_detail::empty_base<T> > | ||||
| struct ordered_field_operators2 | ||||
|     : field_operators2<T, U | ||||
|     , totally_ordered2<T, U, B | ||||
|       > > {}; | ||||
|  | ||||
| template <class T, class B = ::boost::detail::empty_base<T> > | ||||
| template <class T, class B = operators_detail::empty_base<T> > | ||||
| struct ordered_field_operators1 | ||||
|     : field_operators1<T | ||||
|     , totally_ordered1<T, B | ||||
|       > > {}; | ||||
|  | ||||
| template <class T, class U, class B = ::boost::detail::empty_base<T> > | ||||
| template <class T, class U, class B = operators_detail::empty_base<T> > | ||||
| struct euclidian_ring_operators2 | ||||
|     : ring_operators2<T, U | ||||
|     , dividable2<T, U | ||||
| @@ -560,26 +570,26 @@ struct euclidian_ring_operators2 | ||||
|     , modable2_left<T, U, B | ||||
|       > > > > > {}; | ||||
|  | ||||
| template <class T, class B = ::boost::detail::empty_base<T> > | ||||
| template <class T, class B = operators_detail::empty_base<T> > | ||||
| struct euclidian_ring_operators1 | ||||
|     : ring_operators1<T | ||||
|     , dividable1<T | ||||
|     , modable1<T, B | ||||
|       > > > {}; | ||||
|  | ||||
| template <class T, class U, class B = ::boost::detail::empty_base<T> > | ||||
| template <class T, class U, class B = operators_detail::empty_base<T> > | ||||
| struct ordered_euclidian_ring_operators2 | ||||
|     : totally_ordered2<T, U | ||||
|     , euclidian_ring_operators2<T, U, B | ||||
|       > > {}; | ||||
|  | ||||
| template <class T, class B = ::boost::detail::empty_base<T> > | ||||
| template <class T, class B = operators_detail::empty_base<T> > | ||||
| struct ordered_euclidian_ring_operators1 | ||||
|     : totally_ordered1<T | ||||
|     , euclidian_ring_operators1<T, B | ||||
|       > > {}; | ||||
|  | ||||
| template <class T, class U, class B = ::boost::detail::empty_base<T> > | ||||
| template <class T, class U, class B = operators_detail::empty_base<T> > | ||||
| struct euclidean_ring_operators2 | ||||
|     : ring_operators2<T, U | ||||
|     , dividable2<T, U | ||||
| @@ -588,43 +598,43 @@ struct euclidean_ring_operators2 | ||||
|     , modable2_left<T, U, B | ||||
|       > > > > > {}; | ||||
|  | ||||
| template <class T, class B = ::boost::detail::empty_base<T> > | ||||
| template <class T, class B = operators_detail::empty_base<T> > | ||||
| struct euclidean_ring_operators1 | ||||
|     : ring_operators1<T | ||||
|     , dividable1<T | ||||
|     , modable1<T, B | ||||
|       > > > {}; | ||||
|  | ||||
| template <class T, class U, class B = ::boost::detail::empty_base<T> > | ||||
| template <class T, class U, class B = operators_detail::empty_base<T> > | ||||
| struct ordered_euclidean_ring_operators2 | ||||
|     : totally_ordered2<T, U | ||||
|     , euclidean_ring_operators2<T, U, B | ||||
|       > > {}; | ||||
|  | ||||
| template <class T, class B = ::boost::detail::empty_base<T> > | ||||
| template <class T, class B = operators_detail::empty_base<T> > | ||||
| struct ordered_euclidean_ring_operators1 | ||||
|     : totally_ordered1<T | ||||
|     , euclidean_ring_operators1<T, B | ||||
|       > > {}; | ||||
|  | ||||
| template <class T, class P, class B = ::boost::detail::empty_base<T> > | ||||
| template <class T, class P, class B = operators_detail::empty_base<T> > | ||||
| struct input_iteratable | ||||
|     : equality_comparable1<T | ||||
|     , incrementable<T | ||||
|     , dereferenceable<T, P, B | ||||
|       > > > {}; | ||||
|  | ||||
| template <class T, class B = ::boost::detail::empty_base<T> > | ||||
| template <class T, class B = operators_detail::empty_base<T> > | ||||
| struct output_iteratable | ||||
|     : incrementable<T, B | ||||
|       > {}; | ||||
|  | ||||
| template <class T, class P, class B = ::boost::detail::empty_base<T> > | ||||
| template <class T, class P, class B = operators_detail::empty_base<T> > | ||||
| struct forward_iteratable | ||||
|     : input_iteratable<T, P, B | ||||
|       > {}; | ||||
|  | ||||
| template <class T, class P, class B = ::boost::detail::empty_base<T> > | ||||
| template <class T, class P, class B = operators_detail::empty_base<T> > | ||||
| struct bidirectional_iteratable | ||||
|     : forward_iteratable<T, P | ||||
|     , decrementable<T, B | ||||
| @@ -634,7 +644,7 @@ struct bidirectional_iteratable | ||||
| //  which is an indirect base class of bidirectional_iterable, | ||||
| //  random_access_iteratable must not be derived from totally_ordered1 | ||||
| //  but from less_than_comparable1 only. (Helmut Zeisel, 02-Dec-2001) | ||||
| template <class T, class P, class D, class R, class B = ::boost::detail::empty_base<T> > | ||||
| template <class T, class P, class D, class R, class B = operators_detail::empty_base<T> > | ||||
| struct random_access_iteratable | ||||
|     : bidirectional_iteratable<T, P | ||||
|     , less_than_comparable1<T | ||||
| @@ -642,124 +652,64 @@ struct random_access_iteratable | ||||
|     , indexable<T, D, R, B | ||||
|       > > > > {}; | ||||
|  | ||||
| #ifndef BOOST_NO_OPERATORS_IN_NAMESPACE | ||||
| } // namespace boost | ||||
| #endif // BOOST_NO_OPERATORS_IN_NAMESPACE | ||||
|  | ||||
|  | ||||
| // BOOST_IMPORT_TEMPLATE1 .. BOOST_IMPORT_TEMPLATE4 - | ||||
| // | ||||
| // When BOOST_NO_OPERATORS_IN_NAMESPACE is defined we need a way to import an | ||||
| // operator template into the boost namespace. BOOST_IMPORT_TEMPLATE1 is used | ||||
| // for one-argument forms of operator templates; BOOST_IMPORT_TEMPLATE2 for | ||||
| // two-argument forms. Note that these macros expect to be invoked from within | ||||
| // boost. | ||||
|  | ||||
| #ifndef BOOST_NO_OPERATORS_IN_NAMESPACE | ||||
|  | ||||
|   // The template is already in boost so we have nothing to do. | ||||
| # define BOOST_IMPORT_TEMPLATE4(template_name) | ||||
| # define BOOST_IMPORT_TEMPLATE3(template_name) | ||||
| # define BOOST_IMPORT_TEMPLATE2(template_name) | ||||
| # define BOOST_IMPORT_TEMPLATE1(template_name) | ||||
|  | ||||
| #else // BOOST_NO_OPERATORS_IN_NAMESPACE | ||||
|  | ||||
| #  ifndef BOOST_NO_USING_TEMPLATE | ||||
|  | ||||
|      // Bring the names in with a using-declaration | ||||
|      // to avoid stressing the compiler. | ||||
| #    define BOOST_IMPORT_TEMPLATE4(template_name) using ::template_name; | ||||
| #    define BOOST_IMPORT_TEMPLATE3(template_name) using ::template_name; | ||||
| #    define BOOST_IMPORT_TEMPLATE2(template_name) using ::template_name; | ||||
| #    define BOOST_IMPORT_TEMPLATE1(template_name) using ::template_name; | ||||
|  | ||||
| #  else | ||||
|  | ||||
|      // Otherwise, because a Borland C++ 5.5 bug prevents a using declaration | ||||
|      // from working, we are forced to use inheritance for that compiler. | ||||
| #    define BOOST_IMPORT_TEMPLATE4(template_name)                                             \ | ||||
|      template <class T, class U, class V, class W, class B = ::boost::detail::empty_base<T> > \ | ||||
|      struct template_name : ::template_name<T, U, V, W, B> {}; | ||||
|  | ||||
| #    define BOOST_IMPORT_TEMPLATE3(template_name)                                    \ | ||||
|      template <class T, class U, class V, class B = ::boost::detail::empty_base<T> > \ | ||||
|      struct template_name : ::template_name<T, U, V, B> {}; | ||||
|  | ||||
| #    define BOOST_IMPORT_TEMPLATE2(template_name)                           \ | ||||
|      template <class T, class U, class B = ::boost::detail::empty_base<T> > \ | ||||
|      struct template_name : ::template_name<T, U, B> {}; | ||||
|  | ||||
| #    define BOOST_IMPORT_TEMPLATE1(template_name)                  \ | ||||
|      template <class T, class B = ::boost::detail::empty_base<T> > \ | ||||
|      struct template_name : ::template_name<T, B> {}; | ||||
|  | ||||
| #  endif // BOOST_NO_USING_TEMPLATE | ||||
|  | ||||
| #endif // BOOST_NO_OPERATORS_IN_NAMESPACE | ||||
|  | ||||
| // | ||||
| // Here's where we put it all together, defining the xxxx forms of the templates | ||||
| // in namespace boost. We also define specializations of is_chained_base<> for | ||||
| // the xxxx, xxxx1, and xxxx2 templates, importing them into boost:: as | ||||
| // necessary. | ||||
| // Here's where we put it all together, defining the xxxx forms of the templates. | ||||
| // We also define specializations of is_chained_base<> for | ||||
| // the xxxx, xxxx1, and xxxx2 templates. | ||||
| // | ||||
|  | ||||
| namespace operators_detail | ||||
| { | ||||
|  | ||||
| // A type parameter is used instead of a plain bool because Borland's compiler | ||||
| // didn't cope well with the more obvious non-type template parameter. | ||||
| struct true_t {}; | ||||
| struct false_t {}; | ||||
|  | ||||
| } // namespace operators_detail | ||||
|  | ||||
| // is_chained_base<> - a traits class used to distinguish whether an operator | ||||
| // template argument is being used for base class chaining, or is specifying a | ||||
| // 2nd argument type. | ||||
|  | ||||
| namespace boost { | ||||
| // A type parameter is used instead of a plain bool because Borland's compiler | ||||
| // didn't cope well with the more obvious non-type template parameter. | ||||
| namespace detail { | ||||
|   struct true_t {}; | ||||
|   struct false_t {}; | ||||
| } // namespace detail | ||||
|  | ||||
| // Unspecialized version assumes that most types are not being used for base | ||||
| // class chaining. We specialize for the operator templates defined in this | ||||
| // library. | ||||
| template<class T> struct is_chained_base { | ||||
|   typedef ::boost::detail::false_t value; | ||||
|   typedef operators_detail::false_t value; | ||||
| }; | ||||
|  | ||||
| } // namespace boost | ||||
|  | ||||
| // Import a 4-type-argument operator template into boost (if necessary) and | ||||
| // provide a specialization of 'is_chained_base<>' for it. | ||||
| # define BOOST_OPERATOR_TEMPLATE4(template_name4)                     \ | ||||
|   BOOST_IMPORT_TEMPLATE4(template_name4)                              \ | ||||
|   template<class T, class U, class V, class W, class B>               \ | ||||
|   struct is_chained_base< ::boost::template_name4<T, U, V, W, B> > {  \ | ||||
|     typedef ::boost::detail::true_t value;                            \ | ||||
| // Provide a specialization of 'is_chained_base<>' | ||||
| // for a 4-type-argument operator template. | ||||
| # define BOOST_OPERATOR_TEMPLATE4(template_name4)           \ | ||||
|   template<class T, class U, class V, class W, class B>     \ | ||||
|   struct is_chained_base< template_name4<T, U, V, W, B> > { \ | ||||
|     typedef operators_detail::true_t value;                 \ | ||||
|   }; | ||||
|  | ||||
| // Import a 3-type-argument operator template into boost (if necessary) and | ||||
| // provide a specialization of 'is_chained_base<>' for it. | ||||
| # define BOOST_OPERATOR_TEMPLATE3(template_name3)                     \ | ||||
|   BOOST_IMPORT_TEMPLATE3(template_name3)                              \ | ||||
|   template<class T, class U, class V, class B>                        \ | ||||
|   struct is_chained_base< ::boost::template_name3<T, U, V, B> > {     \ | ||||
|     typedef ::boost::detail::true_t value;                            \ | ||||
| // Provide a specialization of 'is_chained_base<>' | ||||
| // for a 3-type-argument operator template. | ||||
| # define BOOST_OPERATOR_TEMPLATE3(template_name3)        \ | ||||
|   template<class T, class U, class V, class B>           \ | ||||
|   struct is_chained_base< template_name3<T, U, V, B> > { \ | ||||
|     typedef operators_detail::true_t value;              \ | ||||
|   }; | ||||
|  | ||||
| // Import a 2-type-argument operator template into boost (if necessary) and | ||||
| // provide a specialization of 'is_chained_base<>' for it. | ||||
| # define BOOST_OPERATOR_TEMPLATE2(template_name2)                  \ | ||||
|   BOOST_IMPORT_TEMPLATE2(template_name2)                           \ | ||||
|   template<class T, class U, class B>                              \ | ||||
|   struct is_chained_base< ::boost::template_name2<T, U, B> > {     \ | ||||
|     typedef ::boost::detail::true_t value;                         \ | ||||
| // Provide a specialization of 'is_chained_base<>' | ||||
| // for a 2-type-argument operator template. | ||||
| # define BOOST_OPERATOR_TEMPLATE2(template_name2)     \ | ||||
|   template<class T, class U, class B>                 \ | ||||
|   struct is_chained_base< template_name2<T, U, B> > { \ | ||||
|     typedef operators_detail::true_t value;           \ | ||||
|   }; | ||||
|  | ||||
| // Import a 1-type-argument operator template into boost (if necessary) and | ||||
| // provide a specialization of 'is_chained_base<>' for it. | ||||
| # define BOOST_OPERATOR_TEMPLATE1(template_name1)                  \ | ||||
|   BOOST_IMPORT_TEMPLATE1(template_name1)                           \ | ||||
|   template<class T, class B>                                       \ | ||||
|   struct is_chained_base< ::boost::template_name1<T, B> > {        \ | ||||
|     typedef ::boost::detail::true_t value;                         \ | ||||
| // Provide a specialization of 'is_chained_base<>' | ||||
| // for a 1-type-argument operator template. | ||||
| # define BOOST_OPERATOR_TEMPLATE1(template_name1)  \ | ||||
|   template<class T, class B>                       \ | ||||
|   struct is_chained_base< template_name1<T, B> > { \ | ||||
|     typedef operators_detail::true_t value;        \ | ||||
|   }; | ||||
|  | ||||
| // BOOST_OPERATOR_TEMPLATE(template_name) defines template_name<> such that it | ||||
| @@ -776,34 +726,34 @@ template<class T> struct is_chained_base { | ||||
| // implementation in terms of either '<template_name>1' or '<template_name>2'. | ||||
| // | ||||
|  | ||||
| # define BOOST_OPERATOR_TEMPLATE(template_name)                    \ | ||||
| template <class T                                                  \ | ||||
|          ,class U = T                                              \ | ||||
|          ,class B = ::boost::detail::empty_base<T>                 \ | ||||
|          ,class O = typename is_chained_base<U>::value             \ | ||||
|          >                                                         \ | ||||
| struct template_name : template_name##2<T, U, B> {};               \ | ||||
|                                                                    \ | ||||
| template<class T, class U, class B>                                \ | ||||
| struct template_name<T, U, B, ::boost::detail::true_t>             \ | ||||
|   : template_name##1<T, U> {};                                     \ | ||||
|                                                                    \ | ||||
| template <class T, class B>                                        \ | ||||
| struct template_name<T, T, B, ::boost::detail::false_t>            \ | ||||
|   : template_name##1<T, B> {};                                     \ | ||||
|                                                                    \ | ||||
| template<class T, class U, class B, class O>                       \ | ||||
| struct is_chained_base< ::boost::template_name<T, U, B, O> > {     \ | ||||
|   typedef ::boost::detail::true_t value;                           \ | ||||
| };                                                                 \ | ||||
|                                                                    \ | ||||
| BOOST_OPERATOR_TEMPLATE2(template_name##2)                         \ | ||||
| # define BOOST_OPERATOR_TEMPLATE(template_name)                                       \ | ||||
| template <class T                                                                     \ | ||||
|          ,class U = T                                                                 \ | ||||
|          ,class B = operators_detail::empty_base<T>                                   \ | ||||
|          ,class O = typename is_chained_base<U>::value                                \ | ||||
|          >                                                                            \ | ||||
| struct template_name;                                                                 \ | ||||
|                                                                                       \ | ||||
| template<class T, class U, class B>                                                   \ | ||||
| struct template_name<T, U, B, operators_detail::false_t>                              \ | ||||
|   : template_name##2<T, U, B> {};                                                     \ | ||||
|                                                                                       \ | ||||
| template<class T, class U>                                                            \ | ||||
| struct template_name<T, U, operators_detail::empty_base<T>, operators_detail::true_t> \ | ||||
|   : template_name##1<T, U> {};                                                        \ | ||||
|                                                                                       \ | ||||
| template <class T, class B>                                                           \ | ||||
| struct template_name<T, T, B, operators_detail::false_t>                              \ | ||||
|   : template_name##1<T, B> {};                                                        \ | ||||
|                                                                                       \ | ||||
| template<class T, class U, class B, class O>                                          \ | ||||
| struct is_chained_base< template_name<T, U, B, O> > {                                 \ | ||||
|   typedef operators_detail::true_t value;                                             \ | ||||
| };                                                                                    \ | ||||
|                                                                                       \ | ||||
| BOOST_OPERATOR_TEMPLATE2(template_name##2)                                            \ | ||||
| BOOST_OPERATOR_TEMPLATE1(template_name##1) | ||||
|  | ||||
|  | ||||
|  | ||||
| namespace boost { | ||||
|      | ||||
| BOOST_OPERATOR_TEMPLATE(less_than_comparable) | ||||
| BOOST_OPERATOR_TEMPLATE(equality_comparable) | ||||
| BOOST_OPERATOR_TEMPLATE(multipliable) | ||||
| @@ -857,13 +807,7 @@ BOOST_OPERATOR_TEMPLATE4(random_access_iteratable) | ||||
| #undef BOOST_OPERATOR_TEMPLATE3 | ||||
| #undef BOOST_OPERATOR_TEMPLATE2 | ||||
| #undef BOOST_OPERATOR_TEMPLATE1 | ||||
| #undef BOOST_IMPORT_TEMPLATE1 | ||||
| #undef BOOST_IMPORT_TEMPLATE2 | ||||
| #undef BOOST_IMPORT_TEMPLATE3 | ||||
| #undef BOOST_IMPORT_TEMPLATE4 | ||||
|  | ||||
| // The following 'operators' classes can only be used portably if the derived class | ||||
| // declares ALL of the required member operators. | ||||
| template <class T, class U> | ||||
| struct operators2 | ||||
|     : totally_ordered2<T,U | ||||
| @@ -884,6 +828,21 @@ template <class T> struct operators<T, T> | ||||
| //  Iterator helper classes (contributed by Jeremy Siek) -------------------// | ||||
| //  (Input and output iterator helpers contributed by Daryle Walker) -------// | ||||
| //  (Changed to use combined operator classes by Daryle Walker) ------------// | ||||
| //  (Adapted to C++17 by Daniel Frey) --------------------------------------// | ||||
| template <class Category, | ||||
|           class T, | ||||
|           class Distance = std::ptrdiff_t, | ||||
|           class Pointer = T*, | ||||
|           class Reference = T&> | ||||
| struct iterator_helper | ||||
| { | ||||
|   typedef Category iterator_category; | ||||
|   typedef T value_type; | ||||
|   typedef Distance difference_type; | ||||
|   typedef Pointer pointer; | ||||
|   typedef Reference reference; | ||||
| }; | ||||
|  | ||||
| template <class T, | ||||
|           class V, | ||||
|           class D = std::ptrdiff_t, | ||||
| @@ -891,13 +850,13 @@ template <class T, | ||||
|           class R = V const &> | ||||
| struct input_iterator_helper | ||||
|   : input_iteratable<T, P | ||||
|   , boost::iterator<std::input_iterator_tag, V, D, P, R | ||||
|   , iterator_helper<std::input_iterator_tag, V, D, P, R | ||||
|     > > {}; | ||||
|  | ||||
| template<class T> | ||||
| struct output_iterator_helper | ||||
|   : output_iteratable<T | ||||
|   , boost::iterator<std::output_iterator_tag, void, void, void, void | ||||
|   , iterator_helper<std::output_iterator_tag, void, void, void, void | ||||
|   > > | ||||
| { | ||||
|   T& operator*()  { return static_cast<T&>(*this); } | ||||
| @@ -911,7 +870,7 @@ template <class T, | ||||
|           class R = V&> | ||||
| struct forward_iterator_helper | ||||
|   : forward_iteratable<T, P | ||||
|   , boost::iterator<std::forward_iterator_tag, V, D, P, R | ||||
|   , iterator_helper<std::forward_iterator_tag, V, D, P, R | ||||
|     > > {}; | ||||
|  | ||||
| template <class T, | ||||
| @@ -921,17 +880,17 @@ template <class T, | ||||
|           class R = V&> | ||||
| struct bidirectional_iterator_helper | ||||
|   : bidirectional_iteratable<T, P | ||||
|   , boost::iterator<std::bidirectional_iterator_tag, V, D, P, R | ||||
|   , iterator_helper<std::bidirectional_iterator_tag, V, D, P, R | ||||
|     > > {}; | ||||
|  | ||||
| template <class T, | ||||
|           class V,  | ||||
|           class V, | ||||
|           class D = std::ptrdiff_t, | ||||
|           class P = V*, | ||||
|           class R = V&> | ||||
| struct random_access_iterator_helper | ||||
|   : random_access_iteratable<T, P, D, R | ||||
|   , boost::iterator<std::random_access_iterator_tag, V, D, P, R | ||||
|   , iterator_helper<std::random_access_iterator_tag, V, D, P, R | ||||
|     > > | ||||
| { | ||||
|   friend D requires_difference_operator(const T& x, const T& y) { | ||||
| @@ -939,10 +898,14 @@ struct random_access_iterator_helper | ||||
|   } | ||||
| }; // random_access_iterator_helper | ||||
|  | ||||
| } // namespace operators_impl | ||||
| using namespace operators_impl; | ||||
|  | ||||
| } // namespace boost | ||||
|  | ||||
| #if defined(__sgi) && !defined(__GNUC__) | ||||
| #pragma reset woff 1234 | ||||
| #endif | ||||
|  | ||||
| #endif // BOOST_NO_OPERATORS_IN_NAMESPACE | ||||
| #endif // BOOST_OPERATORS_HPP | ||||
|   | ||||
							
								
								
									
										951
									
								
								include/boost/operators_v1.hpp
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										951
									
								
								include/boost/operators_v1.hpp
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,951 @@ | ||||
| //  Boost operators.hpp header file  ----------------------------------------// | ||||
|  | ||||
| //  (C) Copyright David Abrahams, Jeremy Siek, Daryle Walker 1999-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) | ||||
|  | ||||
| //  See http://www.boost.org/libs/utility/operators.htm for documentation. | ||||
|  | ||||
| //  Revision History | ||||
| //  22 Feb 16 Preserve old work-arounds. (Daniel Frey) | ||||
| //  16 Dec 10 Limit warning suppression for 4284 to older versions of VC++ | ||||
| //            (Matthew Bradbury, fixes #4432) | ||||
| //  07 Aug 08 Added "euclidean" spelling. (Daniel Frey) | ||||
| //  03 Apr 08 Make sure "convertible to bool" is sufficient | ||||
| //            for T::operator<, etc. (Daniel Frey) | ||||
| //  24 May 07 Changed empty_base to depend on T, see | ||||
| //            http://svn.boost.org/trac/boost/ticket/979 | ||||
| //  21 Oct 02 Modified implementation of operators to allow compilers with a | ||||
| //            correct named return value optimization (NRVO) to produce optimal | ||||
| //            code.  (Daniel Frey) | ||||
| //  02 Dec 01 Bug fixed in random_access_iteratable.  (Helmut Zeisel) | ||||
| //  28 Sep 01 Factored out iterator operator groups.  (Daryle Walker) | ||||
| //  27 Aug 01 'left' form for non commutative operators added; | ||||
| //            additional classes for groups of related operators added; | ||||
| //            workaround for empty base class optimization | ||||
| //            bug of GCC 3.0 (Helmut Zeisel) | ||||
| //  25 Jun 01 output_iterator_helper changes: removed default template  | ||||
| //            parameters, added support for self-proxying, additional  | ||||
| //            documentation and tests (Aleksey Gurtovoy) | ||||
| //  29 May 01 Added operator classes for << and >>.  Added input and output | ||||
| //            iterator helper classes.  Added classes to connect equality and | ||||
| //            relational operators.  Added classes for groups of related | ||||
| //            operators.  Reimplemented example operator and iterator helper | ||||
| //            classes in terms of the new groups.  (Daryle Walker, with help | ||||
| //            from Alexy Gurtovoy) | ||||
| //  11 Feb 01 Fixed bugs in the iterator helpers which prevented explicitly | ||||
| //            supplied arguments from actually being used (Dave Abrahams) | ||||
| //  04 Jul 00 Fixed NO_OPERATORS_IN_NAMESPACE bugs, major cleanup and | ||||
| //            refactoring of compiler workarounds, additional documentation | ||||
| //            (Alexy Gurtovoy and Mark Rodgers with some help and prompting from | ||||
| //            Dave Abrahams)  | ||||
| //  28 Jun 00 General cleanup and integration of bugfixes from Mark Rodgers and | ||||
| //            Jeremy Siek (Dave Abrahams) | ||||
| //  20 Jun 00 Changes to accommodate Borland C++Builder 4 and Borland C++ 5.5 | ||||
| //            (Mark Rodgers) | ||||
| //  20 Jun 00 Minor fixes to the prior revision (Aleksey Gurtovoy) | ||||
| //  10 Jun 00 Support for the base class chaining technique was added | ||||
| //            (Aleksey Gurtovoy). See documentation and the comments below  | ||||
| //            for the details.  | ||||
| //  12 Dec 99 Initial version with iterator operators (Jeremy Siek) | ||||
| //  18 Nov 99 Change name "divideable" to "dividable", remove unnecessary | ||||
| //            specializations of dividable, subtractable, modable (Ed Brey)  | ||||
| //  17 Nov 99 Add comments (Beman Dawes) | ||||
| //            Remove unnecessary specialization of operators<> (Ed Brey) | ||||
| //  15 Nov 99 Fix less_than_comparable<T,U> second operand type for first two | ||||
| //            operators.(Beman Dawes) | ||||
| //  12 Nov 99 Add operators templates (Ed Brey) | ||||
| //  11 Nov 99 Add single template parameter version for compilers without | ||||
| //            partial specialization (Beman Dawes) | ||||
| //  10 Nov 99 Initial version | ||||
|  | ||||
| // 10 Jun 00: | ||||
| // An additional optional template parameter was added to most of  | ||||
| // operator templates to support the base class chaining technique (see  | ||||
| // documentation for the details). Unfortunately, a straightforward | ||||
| // implementation of this change would have broken compatibility with the | ||||
| // previous version of the library by making it impossible to use the same | ||||
| // template name (e.g. 'addable') for both the 1- and 2-argument versions of | ||||
| // an operator template. This implementation solves the backward-compatibility | ||||
| // issue at the cost of some simplicity. | ||||
| // | ||||
| // One of the complications is an existence of special auxiliary class template | ||||
| // 'is_chained_base<>' (see 'detail' namespace below), which is used | ||||
| // to determine whether its template parameter is a library's operator template | ||||
| // or not. You have to specialize 'is_chained_base<>' for each new  | ||||
| // operator template you add to the library. | ||||
| // | ||||
| // However, most of the non-trivial implementation details are hidden behind  | ||||
| // several local macros defined below, and as soon as you understand them, | ||||
| // you understand the whole library implementation.  | ||||
|  | ||||
| #ifndef BOOST_OPERATORS_V1_HPP | ||||
| #define BOOST_OPERATORS_V1_HPP | ||||
|  | ||||
| #include <cstddef> | ||||
| #include <iterator> | ||||
|  | ||||
| #include <boost/config.hpp> | ||||
| #include <boost/detail/workaround.hpp> | ||||
|  | ||||
| #if defined(__sgi) && !defined(__GNUC__) | ||||
| #   pragma set woff 1234 | ||||
| #endif | ||||
|  | ||||
| #if BOOST_WORKAROUND(BOOST_MSVC, < 1600) | ||||
| #   pragma warning( disable : 4284 ) // complaint about return type of  | ||||
| #endif                               // operator-> not begin a UDT | ||||
|  | ||||
| namespace boost { | ||||
| namespace detail { | ||||
|  | ||||
| template <typename T> class empty_base {}; | ||||
|  | ||||
| } // namespace detail | ||||
| } // namespace boost | ||||
|  | ||||
| // In this section we supply the xxxx1 and xxxx2 forms of the operator | ||||
| // templates, which are explicitly targeted at the 1-type-argument and | ||||
| // 2-type-argument operator forms, respectively. Some compilers get confused | ||||
| // when inline friend functions are overloaded in namespaces other than the | ||||
| // global namespace. When BOOST_NO_OPERATORS_IN_NAMESPACE is defined, all of | ||||
| // these templates must go in the global namespace. | ||||
|  | ||||
| #ifndef BOOST_NO_OPERATORS_IN_NAMESPACE | ||||
| namespace boost | ||||
| { | ||||
| #endif | ||||
|  | ||||
| //  Basic operator classes (contributed by Dave Abrahams) ------------------// | ||||
|  | ||||
| //  Note that friend functions defined in a class are implicitly inline. | ||||
| //  See the C++ std, 11.4 [class.friend] paragraph 5 | ||||
|  | ||||
| template <class T, class U, class B = ::boost::detail::empty_base<T> > | ||||
| struct less_than_comparable2 : B | ||||
| { | ||||
|      friend bool operator<=(const T& x, const U& y) { return !static_cast<bool>(x > y); } | ||||
|      friend bool operator>=(const T& x, const U& y) { return !static_cast<bool>(x < y); } | ||||
|      friend bool operator>(const U& x, const T& y)  { return y < x; } | ||||
|      friend bool operator<(const U& x, const T& y)  { return y > x; } | ||||
|      friend bool operator<=(const U& x, const T& y) { return !static_cast<bool>(y < x); } | ||||
|      friend bool operator>=(const U& x, const T& y) { return !static_cast<bool>(y > x); } | ||||
| }; | ||||
|  | ||||
| template <class T, class B = ::boost::detail::empty_base<T> > | ||||
| struct less_than_comparable1 : B | ||||
| { | ||||
|      friend bool operator>(const T& x, const T& y)  { return y < x; } | ||||
|      friend bool operator<=(const T& x, const T& y) { return !static_cast<bool>(y < x); } | ||||
|      friend bool operator>=(const T& x, const T& y) { return !static_cast<bool>(x < y); } | ||||
| }; | ||||
|  | ||||
| template <class T, class U, class B = ::boost::detail::empty_base<T> > | ||||
| struct equality_comparable2 : B | ||||
| { | ||||
|      friend bool operator==(const U& y, const T& x) { return x == y; } | ||||
|      friend bool operator!=(const U& y, const T& x) { return !static_cast<bool>(x == y); } | ||||
|      friend bool operator!=(const T& y, const U& x) { return !static_cast<bool>(y == x); } | ||||
| }; | ||||
|  | ||||
| template <class T, class B = ::boost::detail::empty_base<T> > | ||||
| struct equality_comparable1 : B | ||||
| { | ||||
|      friend bool operator!=(const T& x, const T& y) { return !static_cast<bool>(x == y); } | ||||
| }; | ||||
|  | ||||
| // A macro which produces "name_2left" from "name". | ||||
| #define BOOST_OPERATOR2_LEFT(name) name##2##_##left | ||||
|  | ||||
| //  NRVO-friendly implementation (contributed by Daniel Frey) ---------------// | ||||
|  | ||||
| #if defined(BOOST_HAS_NRVO) || defined(BOOST_FORCE_SYMMETRIC_OPERATORS) | ||||
|  | ||||
| // This is the optimal implementation for ISO/ANSI C++, | ||||
| // but it requires the compiler to implement the NRVO. | ||||
| // If the compiler has no NRVO, this is the best symmetric | ||||
| // implementation available. | ||||
|  | ||||
| #define BOOST_BINARY_OPERATOR_COMMUTATIVE( NAME, OP )                         \ | ||||
| template <class T, class U, class B = ::boost::detail::empty_base<T> >        \ | ||||
| struct NAME##2 : B                                                            \ | ||||
| {                                                                             \ | ||||
|   friend T operator OP( const T& lhs, const U& rhs )                          \ | ||||
|     { T nrv( lhs ); nrv OP##= rhs; return nrv; }                              \ | ||||
|   friend T operator OP( const U& lhs, const T& rhs )                          \ | ||||
|     { T nrv( rhs ); nrv OP##= lhs; return nrv; }                              \ | ||||
| };                                                                            \ | ||||
|                                                                               \ | ||||
| template <class T, class B = ::boost::detail::empty_base<T> >                 \ | ||||
| struct NAME##1 : B                                                            \ | ||||
| {                                                                             \ | ||||
|   friend T operator OP( const T& lhs, const T& rhs )                          \ | ||||
|     { T nrv( lhs ); nrv OP##= rhs; return nrv; }                              \ | ||||
| }; | ||||
|  | ||||
| #define BOOST_BINARY_OPERATOR_NON_COMMUTATIVE( NAME, OP )               \ | ||||
| template <class T, class U, class B = ::boost::detail::empty_base<T> >  \ | ||||
| struct NAME##2 : B                                                      \ | ||||
| {                                                                       \ | ||||
|   friend T operator OP( const T& lhs, const U& rhs )                    \ | ||||
|     { T nrv( lhs ); nrv OP##= rhs; return nrv; }                        \ | ||||
| };                                                                      \ | ||||
|                                                                         \ | ||||
| template <class T, class U, class B = ::boost::detail::empty_base<T> >  \ | ||||
| struct BOOST_OPERATOR2_LEFT(NAME) : B                                   \ | ||||
| {                                                                       \ | ||||
|   friend T operator OP( const U& lhs, const T& rhs )                    \ | ||||
|     { T nrv( lhs ); nrv OP##= rhs; return nrv; }                        \ | ||||
| };                                                                      \ | ||||
|                                                                         \ | ||||
| template <class T, class B = ::boost::detail::empty_base<T> >           \ | ||||
| struct NAME##1 : B                                                      \ | ||||
| {                                                                       \ | ||||
|   friend T operator OP( const T& lhs, const T& rhs )                    \ | ||||
|     { T nrv( lhs ); nrv OP##= rhs; return nrv; }                        \ | ||||
| }; | ||||
|  | ||||
| #else // defined(BOOST_HAS_NRVO) || defined(BOOST_FORCE_SYMMETRIC_OPERATORS) | ||||
|  | ||||
| // For compilers without NRVO the following code is optimal, but not | ||||
| // symmetric!  Note that the implementation of | ||||
| // BOOST_OPERATOR2_LEFT(NAME) only looks cool, but doesn't provide | ||||
| // optimization opportunities to the compiler :) | ||||
|  | ||||
| #define BOOST_BINARY_OPERATOR_COMMUTATIVE( NAME, OP )                   \ | ||||
| template <class T, class U, class B = ::boost::detail::empty_base<T> >  \ | ||||
| struct NAME##2 : B                                                      \ | ||||
| {                                                                       \ | ||||
|   friend T operator OP( T lhs, const U& rhs ) { return lhs OP##= rhs; } \ | ||||
|   friend T operator OP( const U& lhs, T rhs ) { return rhs OP##= lhs; } \ | ||||
| };                                                                      \ | ||||
|                                                                         \ | ||||
| template <class T, class B = ::boost::detail::empty_base<T> >           \ | ||||
| struct NAME##1 : B                                                      \ | ||||
| {                                                                       \ | ||||
|   friend T operator OP( T lhs, const T& rhs ) { return lhs OP##= rhs; } \ | ||||
| }; | ||||
|  | ||||
| #define BOOST_BINARY_OPERATOR_NON_COMMUTATIVE( NAME, OP )               \ | ||||
| template <class T, class U, class B = ::boost::detail::empty_base<T> >  \ | ||||
| struct NAME##2 : B                                                      \ | ||||
| {                                                                       \ | ||||
|   friend T operator OP( T lhs, const U& rhs ) { return lhs OP##= rhs; } \ | ||||
| };                                                                      \ | ||||
|                                                                         \ | ||||
| template <class T, class U, class B = ::boost::detail::empty_base<T> >  \ | ||||
| struct BOOST_OPERATOR2_LEFT(NAME) : B                                   \ | ||||
| {                                                                       \ | ||||
|   friend T operator OP( const U& lhs, const T& rhs )                    \ | ||||
|     { return T( lhs ) OP##= rhs; }                                      \ | ||||
| };                                                                      \ | ||||
|                                                                         \ | ||||
| template <class T, class B = ::boost::detail::empty_base<T> >           \ | ||||
| struct NAME##1 : B                                                      \ | ||||
| {                                                                       \ | ||||
|   friend T operator OP( T lhs, const T& rhs ) { return lhs OP##= rhs; } \ | ||||
| }; | ||||
|  | ||||
| #endif // defined(BOOST_HAS_NRVO) || defined(BOOST_FORCE_SYMMETRIC_OPERATORS) | ||||
|  | ||||
| BOOST_BINARY_OPERATOR_COMMUTATIVE( multipliable, * ) | ||||
| BOOST_BINARY_OPERATOR_COMMUTATIVE( addable, + ) | ||||
| BOOST_BINARY_OPERATOR_NON_COMMUTATIVE( subtractable, - ) | ||||
| BOOST_BINARY_OPERATOR_NON_COMMUTATIVE( dividable, / ) | ||||
| BOOST_BINARY_OPERATOR_NON_COMMUTATIVE( modable, % ) | ||||
| BOOST_BINARY_OPERATOR_COMMUTATIVE( xorable, ^ ) | ||||
| BOOST_BINARY_OPERATOR_COMMUTATIVE( andable, & ) | ||||
| BOOST_BINARY_OPERATOR_COMMUTATIVE( orable, | ) | ||||
|  | ||||
| #undef BOOST_BINARY_OPERATOR_COMMUTATIVE | ||||
| #undef BOOST_BINARY_OPERATOR_NON_COMMUTATIVE | ||||
| #undef BOOST_OPERATOR2_LEFT | ||||
|  | ||||
| //  incrementable and decrementable contributed by Jeremy Siek | ||||
|  | ||||
| template <class T, class B = ::boost::detail::empty_base<T> > | ||||
| struct incrementable : B | ||||
| { | ||||
|   friend T operator++(T& x, int) | ||||
|   { | ||||
|     incrementable_type nrv(x); | ||||
|     ++x; | ||||
|     return nrv; | ||||
|   } | ||||
| private: // The use of this typedef works around a Borland bug | ||||
|   typedef T incrementable_type; | ||||
| }; | ||||
|  | ||||
| template <class T, class B = ::boost::detail::empty_base<T> > | ||||
| struct decrementable : B | ||||
| { | ||||
|   friend T operator--(T& x, int) | ||||
|   { | ||||
|     decrementable_type nrv(x); | ||||
|     --x; | ||||
|     return nrv; | ||||
|   } | ||||
| private: // The use of this typedef works around a Borland bug | ||||
|   typedef T decrementable_type; | ||||
| }; | ||||
|  | ||||
| //  Iterator operator classes (contributed by Jeremy Siek) ------------------// | ||||
|  | ||||
| template <class T, class P, class B = ::boost::detail::empty_base<T> > | ||||
| struct dereferenceable : B | ||||
| { | ||||
|   P operator->() const | ||||
|   {  | ||||
|     return &*static_cast<const T&>(*this);  | ||||
|   } | ||||
| }; | ||||
|  | ||||
| template <class T, class I, class R, class B = ::boost::detail::empty_base<T> > | ||||
| struct indexable : B | ||||
| { | ||||
|   R operator[](I n) const | ||||
|   { | ||||
|     return *(static_cast<const T&>(*this) + n); | ||||
|   } | ||||
| }; | ||||
|  | ||||
| //  More operator classes (contributed by Daryle Walker) --------------------// | ||||
| //  (NRVO-friendly implementation contributed by Daniel Frey) ---------------// | ||||
|  | ||||
| #if defined(BOOST_HAS_NRVO) || defined(BOOST_FORCE_SYMMETRIC_OPERATORS) | ||||
|  | ||||
| #define BOOST_BINARY_OPERATOR( NAME, OP )                                     \ | ||||
| template <class T, class U, class B = ::boost::detail::empty_base<T> >        \ | ||||
| struct NAME##2 : B                                                            \ | ||||
| {                                                                             \ | ||||
|   friend T operator OP( const T& lhs, const U& rhs )                          \ | ||||
|     { T nrv( lhs ); nrv OP##= rhs; return nrv; }                              \ | ||||
| };                                                                            \ | ||||
|                                                                               \ | ||||
| template <class T, class B = ::boost::detail::empty_base<T> >                 \ | ||||
| struct NAME##1 : B                                                            \ | ||||
| {                                                                             \ | ||||
|   friend T operator OP( const T& lhs, const T& rhs )                          \ | ||||
|     { T nrv( lhs ); nrv OP##= rhs; return nrv; }                              \ | ||||
| }; | ||||
|  | ||||
| #else // defined(BOOST_HAS_NRVO) || defined(BOOST_FORCE_SYMMETRIC_OPERATORS) | ||||
|  | ||||
| #define BOOST_BINARY_OPERATOR( NAME, OP )                                     \ | ||||
| template <class T, class U, class B = ::boost::detail::empty_base<T> >        \ | ||||
| struct NAME##2 : B                                                            \ | ||||
| {                                                                             \ | ||||
|   friend T operator OP( T lhs, const U& rhs ) { return lhs OP##= rhs; }       \ | ||||
| };                                                                            \ | ||||
|                                                                               \ | ||||
| template <class T, class B = ::boost::detail::empty_base<T> >                 \ | ||||
| struct NAME##1 : B                                                            \ | ||||
| {                                                                             \ | ||||
|   friend T operator OP( T lhs, const T& rhs ) { return lhs OP##= rhs; }       \ | ||||
| }; | ||||
|  | ||||
| #endif // defined(BOOST_HAS_NRVO) || defined(BOOST_FORCE_SYMMETRIC_OPERATORS) | ||||
|  | ||||
| BOOST_BINARY_OPERATOR( left_shiftable, << ) | ||||
| BOOST_BINARY_OPERATOR( right_shiftable, >> ) | ||||
|  | ||||
| #undef BOOST_BINARY_OPERATOR | ||||
|  | ||||
| template <class T, class U, class B = ::boost::detail::empty_base<T> > | ||||
| struct equivalent2 : B | ||||
| { | ||||
|   friend bool operator==(const T& x, const U& y) | ||||
|   { | ||||
|     return !static_cast<bool>(x < y) && !static_cast<bool>(x > y); | ||||
|   } | ||||
| }; | ||||
|  | ||||
| template <class T, class B = ::boost::detail::empty_base<T> > | ||||
| struct equivalent1 : B | ||||
| { | ||||
|   friend bool operator==(const T&x, const T&y) | ||||
|   { | ||||
|     return !static_cast<bool>(x < y) && !static_cast<bool>(y < x); | ||||
|   } | ||||
| }; | ||||
|  | ||||
| template <class T, class U, class B = ::boost::detail::empty_base<T> > | ||||
| struct partially_ordered2 : B | ||||
| { | ||||
|   friend bool operator<=(const T& x, const U& y) | ||||
|     { return static_cast<bool>(x < y) || static_cast<bool>(x == y); } | ||||
|   friend bool operator>=(const T& x, const U& y) | ||||
|     { return static_cast<bool>(x > y) || static_cast<bool>(x == y); } | ||||
|   friend bool operator>(const U& x, const T& y) | ||||
|     { return y < x; } | ||||
|   friend bool operator<(const U& x, const T& y) | ||||
|     { return y > x; } | ||||
|   friend bool operator<=(const U& x, const T& y) | ||||
|     { return static_cast<bool>(y > x) || static_cast<bool>(y == x); } | ||||
|   friend bool operator>=(const U& x, const T& y) | ||||
|     { return static_cast<bool>(y < x) || static_cast<bool>(y == x); } | ||||
| }; | ||||
|  | ||||
| template <class T, class B = ::boost::detail::empty_base<T> > | ||||
| struct partially_ordered1 : B | ||||
| { | ||||
|   friend bool operator>(const T& x, const T& y) | ||||
|     { return y < x; } | ||||
|   friend bool operator<=(const T& x, const T& y) | ||||
|     { return static_cast<bool>(x < y) || static_cast<bool>(x == y); } | ||||
|   friend bool operator>=(const T& x, const T& y) | ||||
|     { return static_cast<bool>(y < x) || static_cast<bool>(x == y); } | ||||
| }; | ||||
|  | ||||
| //  Combined operator classes (contributed by Daryle Walker) ----------------// | ||||
|  | ||||
| template <class T, class U, class B = ::boost::detail::empty_base<T> > | ||||
| struct totally_ordered2 | ||||
|     : less_than_comparable2<T, U | ||||
|     , equality_comparable2<T, U, B | ||||
|       > > {}; | ||||
|  | ||||
| template <class T, class B = ::boost::detail::empty_base<T> > | ||||
| struct totally_ordered1 | ||||
|     : less_than_comparable1<T | ||||
|     , equality_comparable1<T, B | ||||
|       > > {}; | ||||
|  | ||||
| template <class T, class U, class B = ::boost::detail::empty_base<T> > | ||||
| struct additive2 | ||||
|     : addable2<T, U | ||||
|     , subtractable2<T, U, B | ||||
|       > > {}; | ||||
|  | ||||
| template <class T, class B = ::boost::detail::empty_base<T> > | ||||
| struct additive1 | ||||
|     : addable1<T | ||||
|     , subtractable1<T, B | ||||
|       > > {}; | ||||
|  | ||||
| template <class T, class U, class B = ::boost::detail::empty_base<T> > | ||||
| struct multiplicative2 | ||||
|     : multipliable2<T, U | ||||
|     , dividable2<T, U, B | ||||
|       > > {}; | ||||
|  | ||||
| template <class T, class B = ::boost::detail::empty_base<T> > | ||||
| struct multiplicative1 | ||||
|     : multipliable1<T | ||||
|     , dividable1<T, B | ||||
|       > > {}; | ||||
|  | ||||
| template <class T, class U, class B = ::boost::detail::empty_base<T> > | ||||
| struct integer_multiplicative2 | ||||
|     : multiplicative2<T, U | ||||
|     , modable2<T, U, B | ||||
|       > > {}; | ||||
|  | ||||
| template <class T, class B = ::boost::detail::empty_base<T> > | ||||
| struct integer_multiplicative1 | ||||
|     : multiplicative1<T | ||||
|     , modable1<T, B | ||||
|       > > {}; | ||||
|  | ||||
| template <class T, class U, class B = ::boost::detail::empty_base<T> > | ||||
| struct arithmetic2 | ||||
|     : additive2<T, U | ||||
|     , multiplicative2<T, U, B | ||||
|       > > {}; | ||||
|  | ||||
| template <class T, class B = ::boost::detail::empty_base<T> > | ||||
| struct arithmetic1 | ||||
|     : additive1<T | ||||
|     , multiplicative1<T, B | ||||
|       > > {}; | ||||
|  | ||||
| template <class T, class U, class B = ::boost::detail::empty_base<T> > | ||||
| struct integer_arithmetic2 | ||||
|     : additive2<T, U | ||||
|     , integer_multiplicative2<T, U, B | ||||
|       > > {}; | ||||
|  | ||||
| template <class T, class B = ::boost::detail::empty_base<T> > | ||||
| struct integer_arithmetic1 | ||||
|     : additive1<T | ||||
|     , integer_multiplicative1<T, B | ||||
|       > > {}; | ||||
|  | ||||
| template <class T, class U, class B = ::boost::detail::empty_base<T> > | ||||
| struct bitwise2 | ||||
|     : xorable2<T, U | ||||
|     , andable2<T, U | ||||
|     , orable2<T, U, B | ||||
|       > > > {}; | ||||
|  | ||||
| template <class T, class B = ::boost::detail::empty_base<T> > | ||||
| struct bitwise1 | ||||
|     : xorable1<T | ||||
|     , andable1<T | ||||
|     , orable1<T, B | ||||
|       > > > {}; | ||||
|  | ||||
| template <class T, class B = ::boost::detail::empty_base<T> > | ||||
| struct unit_steppable | ||||
|     : incrementable<T | ||||
|     , decrementable<T, B | ||||
|       > > {}; | ||||
|  | ||||
| template <class T, class U, class B = ::boost::detail::empty_base<T> > | ||||
| struct shiftable2 | ||||
|     : left_shiftable2<T, U | ||||
|     , right_shiftable2<T, U, B | ||||
|       > > {}; | ||||
|  | ||||
| template <class T, class B = ::boost::detail::empty_base<T> > | ||||
| struct shiftable1 | ||||
|     : left_shiftable1<T | ||||
|     , right_shiftable1<T, B | ||||
|       > > {}; | ||||
|  | ||||
| template <class T, class U, class B = ::boost::detail::empty_base<T> > | ||||
| struct ring_operators2 | ||||
|     : additive2<T, U | ||||
|     , subtractable2_left<T, U | ||||
|     , multipliable2<T, U, B | ||||
|       > > > {}; | ||||
|  | ||||
| template <class T, class B = ::boost::detail::empty_base<T> > | ||||
| struct ring_operators1 | ||||
|     : additive1<T | ||||
|     , multipliable1<T, B | ||||
|       > > {}; | ||||
|  | ||||
| template <class T, class U, class B = ::boost::detail::empty_base<T> > | ||||
| struct ordered_ring_operators2 | ||||
|     : ring_operators2<T, U | ||||
|     , totally_ordered2<T, U, B | ||||
|       > > {}; | ||||
|  | ||||
| template <class T, class B = ::boost::detail::empty_base<T> > | ||||
| struct ordered_ring_operators1 | ||||
|     : ring_operators1<T | ||||
|     , totally_ordered1<T, B | ||||
|       > > {}; | ||||
|  | ||||
| template <class T, class U, class B = ::boost::detail::empty_base<T> > | ||||
| struct field_operators2 | ||||
|     : ring_operators2<T, U | ||||
|     , dividable2<T, U | ||||
|     , dividable2_left<T, U, B | ||||
|       > > > {}; | ||||
|  | ||||
| template <class T, class B = ::boost::detail::empty_base<T> > | ||||
| struct field_operators1 | ||||
|     : ring_operators1<T | ||||
|     , dividable1<T, B | ||||
|       > > {}; | ||||
|  | ||||
| template <class T, class U, class B = ::boost::detail::empty_base<T> > | ||||
| struct ordered_field_operators2 | ||||
|     : field_operators2<T, U | ||||
|     , totally_ordered2<T, U, B | ||||
|       > > {}; | ||||
|  | ||||
| template <class T, class B = ::boost::detail::empty_base<T> > | ||||
| struct ordered_field_operators1 | ||||
|     : field_operators1<T | ||||
|     , totally_ordered1<T, B | ||||
|       > > {}; | ||||
|  | ||||
| template <class T, class U, class B = ::boost::detail::empty_base<T> > | ||||
| struct euclidian_ring_operators2 | ||||
|     : ring_operators2<T, U | ||||
|     , dividable2<T, U | ||||
|     , dividable2_left<T, U | ||||
|     , modable2<T, U | ||||
|     , modable2_left<T, U, B | ||||
|       > > > > > {}; | ||||
|  | ||||
| template <class T, class B = ::boost::detail::empty_base<T> > | ||||
| struct euclidian_ring_operators1 | ||||
|     : ring_operators1<T | ||||
|     , dividable1<T | ||||
|     , modable1<T, B | ||||
|       > > > {}; | ||||
|  | ||||
| template <class T, class U, class B = ::boost::detail::empty_base<T> > | ||||
| struct ordered_euclidian_ring_operators2 | ||||
|     : totally_ordered2<T, U | ||||
|     , euclidian_ring_operators2<T, U, B | ||||
|       > > {}; | ||||
|  | ||||
| template <class T, class B = ::boost::detail::empty_base<T> > | ||||
| struct ordered_euclidian_ring_operators1 | ||||
|     : totally_ordered1<T | ||||
|     , euclidian_ring_operators1<T, B | ||||
|       > > {}; | ||||
|  | ||||
| template <class T, class U, class B = ::boost::detail::empty_base<T> > | ||||
| struct euclidean_ring_operators2 | ||||
|     : ring_operators2<T, U | ||||
|     , dividable2<T, U | ||||
|     , dividable2_left<T, U | ||||
|     , modable2<T, U | ||||
|     , modable2_left<T, U, B | ||||
|       > > > > > {}; | ||||
|  | ||||
| template <class T, class B = ::boost::detail::empty_base<T> > | ||||
| struct euclidean_ring_operators1 | ||||
|     : ring_operators1<T | ||||
|     , dividable1<T | ||||
|     , modable1<T, B | ||||
|       > > > {}; | ||||
|  | ||||
| template <class T, class U, class B = ::boost::detail::empty_base<T> > | ||||
| struct ordered_euclidean_ring_operators2 | ||||
|     : totally_ordered2<T, U | ||||
|     , euclidean_ring_operators2<T, U, B | ||||
|       > > {}; | ||||
|  | ||||
| template <class T, class B = ::boost::detail::empty_base<T> > | ||||
| struct ordered_euclidean_ring_operators1 | ||||
|     : totally_ordered1<T | ||||
|     , euclidean_ring_operators1<T, B | ||||
|       > > {}; | ||||
|  | ||||
| template <class T, class P, class B = ::boost::detail::empty_base<T> > | ||||
| struct input_iteratable | ||||
|     : equality_comparable1<T | ||||
|     , incrementable<T | ||||
|     , dereferenceable<T, P, B | ||||
|       > > > {}; | ||||
|  | ||||
| template <class T, class B = ::boost::detail::empty_base<T> > | ||||
| struct output_iteratable | ||||
|     : incrementable<T, B | ||||
|       > {}; | ||||
|  | ||||
| template <class T, class P, class B = ::boost::detail::empty_base<T> > | ||||
| struct forward_iteratable | ||||
|     : input_iteratable<T, P, B | ||||
|       > {}; | ||||
|  | ||||
| template <class T, class P, class B = ::boost::detail::empty_base<T> > | ||||
| struct bidirectional_iteratable | ||||
|     : forward_iteratable<T, P | ||||
|     , decrementable<T, B | ||||
|       > > {}; | ||||
|  | ||||
| //  To avoid repeated derivation from equality_comparable, | ||||
| //  which is an indirect base class of bidirectional_iterable, | ||||
| //  random_access_iteratable must not be derived from totally_ordered1 | ||||
| //  but from less_than_comparable1 only. (Helmut Zeisel, 02-Dec-2001) | ||||
| template <class T, class P, class D, class R, class B = ::boost::detail::empty_base<T> > | ||||
| struct random_access_iteratable | ||||
|     : bidirectional_iteratable<T, P | ||||
|     , less_than_comparable1<T | ||||
|     , additive2<T, D | ||||
|     , indexable<T, D, R, B | ||||
|       > > > > {}; | ||||
|  | ||||
| #ifndef BOOST_NO_OPERATORS_IN_NAMESPACE | ||||
| } // namespace boost | ||||
| #endif // BOOST_NO_OPERATORS_IN_NAMESPACE | ||||
|  | ||||
|  | ||||
| // BOOST_IMPORT_TEMPLATE1 .. BOOST_IMPORT_TEMPLATE4 - | ||||
| // | ||||
| // When BOOST_NO_OPERATORS_IN_NAMESPACE is defined we need a way to import an | ||||
| // operator template into the boost namespace. BOOST_IMPORT_TEMPLATE1 is used | ||||
| // for one-argument forms of operator templates; BOOST_IMPORT_TEMPLATE2 for | ||||
| // two-argument forms. Note that these macros expect to be invoked from within | ||||
| // boost. | ||||
|  | ||||
| #ifndef BOOST_NO_OPERATORS_IN_NAMESPACE | ||||
|  | ||||
|   // The template is already in boost so we have nothing to do. | ||||
| # define BOOST_IMPORT_TEMPLATE4(template_name) | ||||
| # define BOOST_IMPORT_TEMPLATE3(template_name) | ||||
| # define BOOST_IMPORT_TEMPLATE2(template_name) | ||||
| # define BOOST_IMPORT_TEMPLATE1(template_name) | ||||
|  | ||||
| #else // BOOST_NO_OPERATORS_IN_NAMESPACE | ||||
|  | ||||
| #  ifndef BOOST_NO_USING_TEMPLATE | ||||
|  | ||||
|      // Bring the names in with a using-declaration | ||||
|      // to avoid stressing the compiler. | ||||
| #    define BOOST_IMPORT_TEMPLATE4(template_name) using ::template_name; | ||||
| #    define BOOST_IMPORT_TEMPLATE3(template_name) using ::template_name; | ||||
| #    define BOOST_IMPORT_TEMPLATE2(template_name) using ::template_name; | ||||
| #    define BOOST_IMPORT_TEMPLATE1(template_name) using ::template_name; | ||||
|  | ||||
| #  else | ||||
|  | ||||
|      // Otherwise, because a Borland C++ 5.5 bug prevents a using declaration | ||||
|      // from working, we are forced to use inheritance for that compiler. | ||||
| #    define BOOST_IMPORT_TEMPLATE4(template_name)                                             \ | ||||
|      template <class T, class U, class V, class W, class B = ::boost::detail::empty_base<T> > \ | ||||
|      struct template_name : ::template_name<T, U, V, W, B> {}; | ||||
|  | ||||
| #    define BOOST_IMPORT_TEMPLATE3(template_name)                                    \ | ||||
|      template <class T, class U, class V, class B = ::boost::detail::empty_base<T> > \ | ||||
|      struct template_name : ::template_name<T, U, V, B> {}; | ||||
|  | ||||
| #    define BOOST_IMPORT_TEMPLATE2(template_name)                           \ | ||||
|      template <class T, class U, class B = ::boost::detail::empty_base<T> > \ | ||||
|      struct template_name : ::template_name<T, U, B> {}; | ||||
|  | ||||
| #    define BOOST_IMPORT_TEMPLATE1(template_name)                  \ | ||||
|      template <class T, class B = ::boost::detail::empty_base<T> > \ | ||||
|      struct template_name : ::template_name<T, B> {}; | ||||
|  | ||||
| #  endif // BOOST_NO_USING_TEMPLATE | ||||
|  | ||||
| #endif // BOOST_NO_OPERATORS_IN_NAMESPACE | ||||
|  | ||||
| // | ||||
| // Here's where we put it all together, defining the xxxx forms of the templates | ||||
| // in namespace boost. We also define specializations of is_chained_base<> for | ||||
| // the xxxx, xxxx1, and xxxx2 templates, importing them into boost:: as | ||||
| // necessary. | ||||
| // | ||||
|  | ||||
| // is_chained_base<> - a traits class used to distinguish whether an operator | ||||
| // template argument is being used for base class chaining, or is specifying a | ||||
| // 2nd argument type. | ||||
|  | ||||
| namespace boost { | ||||
| // A type parameter is used instead of a plain bool because Borland's compiler | ||||
| // didn't cope well with the more obvious non-type template parameter. | ||||
| namespace detail { | ||||
|   struct true_t {}; | ||||
|   struct false_t {}; | ||||
| } // namespace detail | ||||
|  | ||||
| // Unspecialized version assumes that most types are not being used for base | ||||
| // class chaining. We specialize for the operator templates defined in this | ||||
| // library. | ||||
| template<class T> struct is_chained_base { | ||||
|   typedef ::boost::detail::false_t value; | ||||
| }; | ||||
|  | ||||
| } // namespace boost | ||||
|  | ||||
| // Import a 4-type-argument operator template into boost (if necessary) and | ||||
| // provide a specialization of 'is_chained_base<>' for it. | ||||
| # define BOOST_OPERATOR_TEMPLATE4(template_name4)                     \ | ||||
|   BOOST_IMPORT_TEMPLATE4(template_name4)                              \ | ||||
|   template<class T, class U, class V, class W, class B>               \ | ||||
|   struct is_chained_base< ::boost::template_name4<T, U, V, W, B> > {  \ | ||||
|     typedef ::boost::detail::true_t value;                            \ | ||||
|   }; | ||||
|  | ||||
| // Import a 3-type-argument operator template into boost (if necessary) and | ||||
| // provide a specialization of 'is_chained_base<>' for it. | ||||
| # define BOOST_OPERATOR_TEMPLATE3(template_name3)                     \ | ||||
|   BOOST_IMPORT_TEMPLATE3(template_name3)                              \ | ||||
|   template<class T, class U, class V, class B>                        \ | ||||
|   struct is_chained_base< ::boost::template_name3<T, U, V, B> > {     \ | ||||
|     typedef ::boost::detail::true_t value;                            \ | ||||
|   }; | ||||
|  | ||||
| // Import a 2-type-argument operator template into boost (if necessary) and | ||||
| // provide a specialization of 'is_chained_base<>' for it. | ||||
| # define BOOST_OPERATOR_TEMPLATE2(template_name2)                  \ | ||||
|   BOOST_IMPORT_TEMPLATE2(template_name2)                           \ | ||||
|   template<class T, class U, class B>                              \ | ||||
|   struct is_chained_base< ::boost::template_name2<T, U, B> > {     \ | ||||
|     typedef ::boost::detail::true_t value;                         \ | ||||
|   }; | ||||
|  | ||||
| // Import a 1-type-argument operator template into boost (if necessary) and | ||||
| // provide a specialization of 'is_chained_base<>' for it. | ||||
| # define BOOST_OPERATOR_TEMPLATE1(template_name1)                  \ | ||||
|   BOOST_IMPORT_TEMPLATE1(template_name1)                           \ | ||||
|   template<class T, class B>                                       \ | ||||
|   struct is_chained_base< ::boost::template_name1<T, B> > {        \ | ||||
|     typedef ::boost::detail::true_t value;                         \ | ||||
|   }; | ||||
|  | ||||
| // BOOST_OPERATOR_TEMPLATE(template_name) defines template_name<> such that it | ||||
| // can be used for specifying both 1-argument and 2-argument forms. Requires the | ||||
| // existence of two previously defined class templates named '<template_name>1' | ||||
| // and '<template_name>2' which must implement the corresponding 1- and 2- | ||||
| // argument forms. | ||||
| // | ||||
| // The template type parameter O == is_chained_base<U>::value is used to | ||||
| // distinguish whether the 2nd argument to <template_name> is being used for | ||||
| // base class chaining from another boost operator template or is describing a | ||||
| // 2nd operand type. O == true_t only when U is actually an another operator | ||||
| // template from the library. Partial specialization is used to select an | ||||
| // implementation in terms of either '<template_name>1' or '<template_name>2'. | ||||
| // | ||||
|  | ||||
| # define BOOST_OPERATOR_TEMPLATE(template_name)                    \ | ||||
| template <class T                                                  \ | ||||
|          ,class U = T                                              \ | ||||
|          ,class B = ::boost::detail::empty_base<T>                 \ | ||||
|          ,class O = typename is_chained_base<U>::value             \ | ||||
|          >                                                         \ | ||||
| struct template_name : template_name##2<T, U, B> {};               \ | ||||
|                                                                    \ | ||||
| template<class T, class U, class B>                                \ | ||||
| struct template_name<T, U, B, ::boost::detail::true_t>             \ | ||||
|   : template_name##1<T, U> {};                                     \ | ||||
|                                                                    \ | ||||
| template <class T, class B>                                        \ | ||||
| struct template_name<T, T, B, ::boost::detail::false_t>            \ | ||||
|   : template_name##1<T, B> {};                                     \ | ||||
|                                                                    \ | ||||
| template<class T, class U, class B, class O>                       \ | ||||
| struct is_chained_base< ::boost::template_name<T, U, B, O> > {     \ | ||||
|   typedef ::boost::detail::true_t value;                           \ | ||||
| };                                                                 \ | ||||
|                                                                    \ | ||||
| BOOST_OPERATOR_TEMPLATE2(template_name##2)                         \ | ||||
| BOOST_OPERATOR_TEMPLATE1(template_name##1) | ||||
|  | ||||
|  | ||||
|  | ||||
| namespace boost { | ||||
|      | ||||
| BOOST_OPERATOR_TEMPLATE(less_than_comparable) | ||||
| BOOST_OPERATOR_TEMPLATE(equality_comparable) | ||||
| BOOST_OPERATOR_TEMPLATE(multipliable) | ||||
| BOOST_OPERATOR_TEMPLATE(addable) | ||||
| BOOST_OPERATOR_TEMPLATE(subtractable) | ||||
| BOOST_OPERATOR_TEMPLATE2(subtractable2_left) | ||||
| BOOST_OPERATOR_TEMPLATE(dividable) | ||||
| BOOST_OPERATOR_TEMPLATE2(dividable2_left) | ||||
| BOOST_OPERATOR_TEMPLATE(modable) | ||||
| BOOST_OPERATOR_TEMPLATE2(modable2_left) | ||||
| BOOST_OPERATOR_TEMPLATE(xorable) | ||||
| BOOST_OPERATOR_TEMPLATE(andable) | ||||
| BOOST_OPERATOR_TEMPLATE(orable) | ||||
|  | ||||
| BOOST_OPERATOR_TEMPLATE1(incrementable) | ||||
| BOOST_OPERATOR_TEMPLATE1(decrementable) | ||||
|  | ||||
| BOOST_OPERATOR_TEMPLATE2(dereferenceable) | ||||
| BOOST_OPERATOR_TEMPLATE3(indexable) | ||||
|  | ||||
| BOOST_OPERATOR_TEMPLATE(left_shiftable) | ||||
| BOOST_OPERATOR_TEMPLATE(right_shiftable) | ||||
| BOOST_OPERATOR_TEMPLATE(equivalent) | ||||
| BOOST_OPERATOR_TEMPLATE(partially_ordered) | ||||
|  | ||||
| BOOST_OPERATOR_TEMPLATE(totally_ordered) | ||||
| BOOST_OPERATOR_TEMPLATE(additive) | ||||
| BOOST_OPERATOR_TEMPLATE(multiplicative) | ||||
| BOOST_OPERATOR_TEMPLATE(integer_multiplicative) | ||||
| BOOST_OPERATOR_TEMPLATE(arithmetic) | ||||
| BOOST_OPERATOR_TEMPLATE(integer_arithmetic) | ||||
| BOOST_OPERATOR_TEMPLATE(bitwise) | ||||
| BOOST_OPERATOR_TEMPLATE1(unit_steppable) | ||||
| BOOST_OPERATOR_TEMPLATE(shiftable) | ||||
| BOOST_OPERATOR_TEMPLATE(ring_operators) | ||||
| BOOST_OPERATOR_TEMPLATE(ordered_ring_operators) | ||||
| BOOST_OPERATOR_TEMPLATE(field_operators) | ||||
| BOOST_OPERATOR_TEMPLATE(ordered_field_operators) | ||||
| BOOST_OPERATOR_TEMPLATE(euclidian_ring_operators) | ||||
| BOOST_OPERATOR_TEMPLATE(ordered_euclidian_ring_operators) | ||||
| BOOST_OPERATOR_TEMPLATE(euclidean_ring_operators) | ||||
| BOOST_OPERATOR_TEMPLATE(ordered_euclidean_ring_operators) | ||||
| BOOST_OPERATOR_TEMPLATE2(input_iteratable) | ||||
| BOOST_OPERATOR_TEMPLATE1(output_iteratable) | ||||
| BOOST_OPERATOR_TEMPLATE2(forward_iteratable) | ||||
| BOOST_OPERATOR_TEMPLATE2(bidirectional_iteratable) | ||||
| BOOST_OPERATOR_TEMPLATE4(random_access_iteratable) | ||||
|  | ||||
| #undef BOOST_OPERATOR_TEMPLATE | ||||
| #undef BOOST_OPERATOR_TEMPLATE4 | ||||
| #undef BOOST_OPERATOR_TEMPLATE3 | ||||
| #undef BOOST_OPERATOR_TEMPLATE2 | ||||
| #undef BOOST_OPERATOR_TEMPLATE1 | ||||
| #undef BOOST_IMPORT_TEMPLATE1 | ||||
| #undef BOOST_IMPORT_TEMPLATE2 | ||||
| #undef BOOST_IMPORT_TEMPLATE3 | ||||
| #undef BOOST_IMPORT_TEMPLATE4 | ||||
|  | ||||
| // The following 'operators' classes can only be used portably if the derived class | ||||
| // declares ALL of the required member operators. | ||||
| template <class T, class U> | ||||
| struct operators2 | ||||
|     : totally_ordered2<T,U | ||||
|     , integer_arithmetic2<T,U | ||||
|     , bitwise2<T,U | ||||
|       > > > {}; | ||||
|  | ||||
| template <class T, class U = T> | ||||
| struct operators : operators2<T, U> {}; | ||||
|  | ||||
| template <class T> struct operators<T, T> | ||||
|     : totally_ordered<T | ||||
|     , integer_arithmetic<T | ||||
|     , bitwise<T | ||||
|     , unit_steppable<T | ||||
|       > > > > {}; | ||||
|  | ||||
| //  Iterator helper classes (contributed by Jeremy Siek) -------------------// | ||||
| //  (Input and output iterator helpers contributed by Daryle Walker) -------// | ||||
| //  (Changed to use combined operator classes by Daryle Walker) ------------// | ||||
| template <class T, | ||||
|           class V, | ||||
|           class D = std::ptrdiff_t, | ||||
|           class P = V const *, | ||||
|           class R = V const &> | ||||
| struct input_iterator_helper | ||||
|   : input_iteratable<T, P | ||||
|   , std::iterator<std::input_iterator_tag, V, D, P, R | ||||
|     > > {}; | ||||
|  | ||||
| template<class T> | ||||
| struct output_iterator_helper | ||||
|   : output_iteratable<T | ||||
|   , std::iterator<std::output_iterator_tag, void, void, void, void | ||||
|   > > | ||||
| { | ||||
|   T& operator*()  { return static_cast<T&>(*this); } | ||||
|   T& operator++() { return static_cast<T&>(*this); } | ||||
| }; | ||||
|  | ||||
| template <class T, | ||||
|           class V, | ||||
|           class D = std::ptrdiff_t, | ||||
|           class P = V*, | ||||
|           class R = V&> | ||||
| struct forward_iterator_helper | ||||
|   : forward_iteratable<T, P | ||||
|   , std::iterator<std::forward_iterator_tag, V, D, P, R | ||||
|     > > {}; | ||||
|  | ||||
| template <class T, | ||||
|           class V, | ||||
|           class D = std::ptrdiff_t, | ||||
|           class P = V*, | ||||
|           class R = V&> | ||||
| struct bidirectional_iterator_helper | ||||
|   : bidirectional_iteratable<T, P | ||||
|   , std::iterator<std::bidirectional_iterator_tag, V, D, P, R | ||||
|     > > {}; | ||||
|  | ||||
| template <class T, | ||||
|           class V,  | ||||
|           class D = std::ptrdiff_t, | ||||
|           class P = V*, | ||||
|           class R = V&> | ||||
| struct random_access_iterator_helper | ||||
|   : random_access_iteratable<T, P, D, R | ||||
|   , std::iterator<std::random_access_iterator_tag, V, D, P, R | ||||
|     > > | ||||
| { | ||||
|   friend D requires_difference_operator(const T& x, const T& y) { | ||||
|     return x - y; | ||||
|   } | ||||
| }; // random_access_iterator_helper | ||||
|  | ||||
| } // namespace boost | ||||
|  | ||||
| #if defined(__sgi) && !defined(__GNUC__) | ||||
| #pragma reset woff 1234 | ||||
| #endif | ||||
|  | ||||
| #endif // BOOST_OPERATORS_V1_HPP | ||||
| @@ -9,13 +9,16 @@ | ||||
| #ifndef BOOST_UTILITY_HPP | ||||
| #define BOOST_UTILITY_HPP | ||||
|  | ||||
| #include <boost/utility/addressof.hpp> | ||||
| // Use of this header is discouraged and it will be deprecated. | ||||
| // Please include one or more of the headers below instead. | ||||
|  | ||||
| #include <boost/utility/base_from_member.hpp> | ||||
| #include <boost/utility/binary.hpp> | ||||
| #include <boost/utility/enable_if.hpp> | ||||
| #include <boost/utility/identity_type.hpp> | ||||
| #include <boost/checked_delete.hpp> | ||||
| #include <boost/next_prior.hpp> | ||||
| #include <boost/noncopyable.hpp> | ||||
|  | ||||
| #include <boost/core/addressof.hpp> | ||||
| #include <boost/core/enable_if.hpp> | ||||
| #include <boost/core/checked_delete.hpp> | ||||
| #include <boost/core/noncopyable.hpp> | ||||
|  | ||||
| #endif  // BOOST_UTILITY_HPP | ||||
|   | ||||
| @@ -47,11 +47,11 @@ | ||||
| //         {} | ||||
| // This macro should only persist within this file. | ||||
|  | ||||
| #define BOOST_PRIVATE_CTR_DEF( z, n, data )                            \ | ||||
|     template < BOOST_PP_ENUM_PARAMS(n, typename T) >                   \ | ||||
|     explicit base_from_member( BOOST_PP_ENUM_BINARY_PARAMS(n, T, x) )  \ | ||||
|         : member( BOOST_PP_ENUM_PARAMS(n, x) )                         \ | ||||
|         {}                                                             \ | ||||
| #define BOOST_PRIVATE_CTR_DEF( z, n, data )                   \ | ||||
|     template < BOOST_PP_ENUM_PARAMS(n, typename T) >          \ | ||||
|     base_from_member( BOOST_PP_ENUM_BINARY_PARAMS(n, T, x) )  \ | ||||
|         : member( BOOST_PP_ENUM_PARAMS(n, x) )                \ | ||||
|         {}                                                    \ | ||||
|     /**/ | ||||
|  | ||||
|  | ||||
| @@ -142,7 +142,8 @@ protected: | ||||
|         : member() | ||||
|         {} | ||||
|  | ||||
|     BOOST_PP_REPEAT_FROM_TO( 1, BOOST_PP_INC(BOOST_BASE_FROM_MEMBER_MAX_ARITY), | ||||
|     template < typename T0 > explicit base_from_member( T0 x0 ) : member( x0 ) {} | ||||
|     BOOST_PP_REPEAT_FROM_TO( 2, BOOST_PP_INC(BOOST_BASE_FROM_MEMBER_MAX_ARITY), | ||||
|      BOOST_PRIVATE_CTR_DEF, _ ) | ||||
| #endif | ||||
|  | ||||
|   | ||||
| @@ -33,8 +33,12 @@ bool equal_pointees ( OptionalPointee const& x, OptionalPointee const& y ) | ||||
| } | ||||
|  | ||||
| template<class OptionalPointee> | ||||
| struct equal_pointees_t : std::binary_function<OptionalPointee,OptionalPointee,bool> | ||||
| struct equal_pointees_t | ||||
| { | ||||
|   typedef bool result_type; | ||||
|   typedef OptionalPointee first_argument_type; | ||||
|   typedef OptionalPointee second_argument_type; | ||||
|  | ||||
|   bool operator() ( OptionalPointee const& x, OptionalPointee const& y ) const | ||||
|     { return equal_pointees(x,y) ; } | ||||
| } ; | ||||
| @@ -56,8 +60,12 @@ bool less_pointees ( OptionalPointee const& x, OptionalPointee const& y ) | ||||
| } | ||||
|  | ||||
| template<class OptionalPointee> | ||||
| struct less_pointees_t : std::binary_function<OptionalPointee,OptionalPointee,bool> | ||||
| struct less_pointees_t | ||||
| { | ||||
|   typedef bool result_type; | ||||
|   typedef OptionalPointee first_argument_type; | ||||
|   typedef OptionalPointee second_argument_type; | ||||
|  | ||||
|   bool operator() ( OptionalPointee const& x, OptionalPointee const& y ) const | ||||
|     { return less_pointees(x,y) ; } | ||||
| } ; | ||||
|   | ||||
							
								
								
									
										58
									
								
								include/boost/utility/detail/minstd_rand.hpp
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										58
									
								
								include/boost/utility/detail/minstd_rand.hpp
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,58 @@ | ||||
| #ifndef BOOST_UTILITY_DETAIL_MINSTD_RAND_HPP_INCLUDED | ||||
| #define BOOST_UTILITY_DETAIL_MINSTD_RAND_HPP_INCLUDED | ||||
|  | ||||
| // Copyright 2017 Peter Dimov | ||||
| // | ||||
| // 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 | ||||
| // | ||||
| // An implementation of minstd_rand that does not require | ||||
| // the Random library | ||||
|  | ||||
| #include <boost/cstdint.hpp> | ||||
|  | ||||
| namespace boost | ||||
| { | ||||
| namespace detail | ||||
| { | ||||
|  | ||||
| class minstd_rand | ||||
| { | ||||
| private: | ||||
|  | ||||
|     boost::uint_least32_t x_; | ||||
|  | ||||
|     enum { a = 48271, m = 2147483647 }; | ||||
|  | ||||
| public: | ||||
|  | ||||
|     minstd_rand(): x_( 1 ) | ||||
|     { | ||||
|     } | ||||
|  | ||||
|     explicit minstd_rand( boost::uint_least32_t x ): x_( x % m ) | ||||
|     { | ||||
|         if( x_ == 0 ) | ||||
|         { | ||||
|             x_ = 1; | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     boost::uint_least32_t operator()() | ||||
|     { | ||||
|         boost::uint_least64_t y = x_; | ||||
|  | ||||
|         y = ( a * y ) % m; | ||||
|  | ||||
|         x_ = static_cast<boost::uint_least32_t>( y ); | ||||
|  | ||||
|         return x_; | ||||
|     } | ||||
| }; | ||||
|  | ||||
| } // namespace detail | ||||
| } // namespace boost | ||||
|  | ||||
| #endif // #ifndef BOOST_UTILITY_DETAIL_MINSTD_RAND_HPP_INCLUDED | ||||
| @@ -25,16 +25,16 @@ | ||||
| #if !BOOST_WORKAROUND(__BORLANDC__, BOOST_TESTED_AT(0x551)) | ||||
| template<typename F BOOST_PP_ENUM_TRAILING_PARAMS(BOOST_PP_ITERATION(),typename T)> | ||||
| struct tr1_result_of<F(BOOST_RESULT_OF_ARGS)> | ||||
|     : mpl::if_< | ||||
|           mpl::or_< is_pointer<F>, is_member_function_pointer<F> > | ||||
|     : conditional< | ||||
|         is_pointer<F>::value || is_member_function_pointer<F>::value | ||||
|         , boost::detail::tr1_result_of_impl< | ||||
|             typename remove_cv<F>::type, | ||||
|             typename remove_cv<F>::type(BOOST_RESULT_OF_ARGS), | ||||
|             (boost::detail::has_result_type<F>::value)> | ||||
|             (boost::detail::result_of_has_result_type<F>::value)> | ||||
|         , boost::detail::tr1_result_of_impl< | ||||
|             F, | ||||
|             F(BOOST_RESULT_OF_ARGS), | ||||
|             (boost::detail::has_result_type<F>::value)> >::type { }; | ||||
|             (boost::detail::result_of_has_result_type<F>::value)> >::type { }; | ||||
| #endif | ||||
|  | ||||
| #ifdef BOOST_RESULT_OF_USE_DECLTYPE | ||||
| @@ -46,7 +46,7 @@ struct result_of<F(BOOST_RESULT_OF_ARGS)> | ||||
| #ifdef BOOST_RESULT_OF_USE_TR1_WITH_DECLTYPE_FALLBACK | ||||
| template<typename F BOOST_PP_ENUM_TRAILING_PARAMS(BOOST_PP_ITERATION(),typename T)> | ||||
| struct result_of<F(BOOST_RESULT_OF_ARGS)> | ||||
|     : mpl::if_<mpl::or_<detail::has_result_type<F>, detail::has_result<F> >, | ||||
|     : conditional<detail::result_of_has_result_type<F>::value || detail::result_of_has_result<F>::value, | ||||
|                tr1_result_of<F(BOOST_RESULT_OF_ARGS)>, | ||||
|                detail::cpp0x_result_of<F(BOOST_RESULT_OF_ARGS)> >::type { }; | ||||
| #endif // BOOST_RESULT_OF_USE_TR1_WITH_DECLTYPE_FALLBACK | ||||
| @@ -57,8 +57,8 @@ namespace detail { | ||||
|  | ||||
| template<typename F BOOST_PP_ENUM_TRAILING_PARAMS(BOOST_PP_ITERATION(),typename T)> | ||||
| struct cpp0x_result_of<F(BOOST_PP_ENUM_PARAMS(BOOST_PP_ITERATION(),T))> | ||||
|     : mpl::if_< | ||||
|           is_member_function_pointer<F> | ||||
|     : conditional< | ||||
|           is_member_function_pointer<F>::value | ||||
|         , detail::tr1_result_of_impl< | ||||
|             typename remove_cv<F>::type, | ||||
|             typename remove_cv<F>::type(BOOST_PP_ENUM_PARAMS(BOOST_PP_ITERATION(),T)), false | ||||
| @@ -82,25 +82,22 @@ struct BOOST_PP_CAT(result_of_callable_fun_2_, BOOST_PP_ITERATION())<R(BOOST_PP_ | ||||
| }; | ||||
|  | ||||
| template<typename F> | ||||
| struct BOOST_PP_CAT(result_of_callable_fun_, BOOST_PP_ITERATION()); | ||||
| struct BOOST_PP_CAT(result_of_callable_fun_, BOOST_PP_ITERATION()) | ||||
|   : BOOST_PP_CAT(result_of_callable_fun_2_, BOOST_PP_ITERATION())<F> | ||||
| {}; | ||||
|  | ||||
| template<typename F> | ||||
| struct BOOST_PP_CAT(result_of_callable_fun_, BOOST_PP_ITERATION())<F *> | ||||
|   : BOOST_PP_CAT(result_of_callable_fun_2_, BOOST_PP_ITERATION())<F> | ||||
| {}; | ||||
|  | ||||
| template<typename F> | ||||
| struct BOOST_PP_CAT(result_of_callable_fun_, BOOST_PP_ITERATION())<F &> | ||||
|   : BOOST_PP_CAT(result_of_callable_fun_2_, BOOST_PP_ITERATION())<F> | ||||
| {}; | ||||
|  | ||||
| template<typename F> | ||||
| struct BOOST_PP_CAT(result_of_select_call_wrapper_type_, BOOST_PP_ITERATION()) | ||||
|   : mpl::eval_if< | ||||
|         is_class<typename remove_reference<F>::type>, | ||||
|   : conditional< | ||||
|         is_class<typename remove_reference<F>::type>::value, | ||||
|         result_of_wrap_callable_class<F>, | ||||
|         mpl::identity<BOOST_PP_CAT(result_of_callable_fun_, BOOST_PP_ITERATION())<typename remove_cv<F>::type> > | ||||
|     > | ||||
|         type_identity<BOOST_PP_CAT(result_of_callable_fun_, BOOST_PP_ITERATION())<typename remove_cv<typename remove_reference<F>::type>::type> > | ||||
|     >::type | ||||
| {}; | ||||
|  | ||||
| template<typename F BOOST_PP_ENUM_TRAILING_PARAMS(BOOST_PP_ITERATION(), typename T)> | ||||
| @@ -111,7 +108,7 @@ struct BOOST_PP_CAT(result_of_is_callable_, BOOST_PP_ITERATION()) { | ||||
|             (boost::declval<wrapper_t>()(BOOST_PP_ENUM_BINARY_PARAMS(BOOST_PP_ITERATION(), boost::declval<T, >() BOOST_PP_INTERCEPT)), result_of_weird_type()) | ||||
|         )) | ||||
|     ); | ||||
|     typedef mpl::bool_<value> type; | ||||
|     typedef integral_constant<bool, value> type; | ||||
| }; | ||||
|  | ||||
| template<typename F BOOST_PP_ENUM_TRAILING_PARAMS(BOOST_PP_ITERATION(),typename T)> | ||||
|   | ||||
							
								
								
									
										95
									
								
								include/boost/utility/ostream_string.hpp
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										95
									
								
								include/boost/utility/ostream_string.hpp
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,95 @@ | ||||
| /* | ||||
| Copyright 2019 Glen Joseph Fernandes | ||||
| (glenjofe@gmail.com) | ||||
|  | ||||
| Distributed under the Boost Software License, Version 1.0. | ||||
| (http://www.boost.org/LICENSE_1_0.txt) | ||||
| */ | ||||
| #ifndef BOOST_UTILITY_OSTREAM_STRING_HPP | ||||
| #define BOOST_UTILITY_OSTREAM_STRING_HPP | ||||
|  | ||||
| #include <boost/config.hpp> | ||||
| #include <iosfwd> | ||||
| #include <cstddef> | ||||
|  | ||||
| namespace boost { | ||||
| namespace detail { | ||||
|  | ||||
| template<class charT, class traits> | ||||
| inline std::size_t | ||||
| oss_put(std::basic_ostream<charT, traits>& os, const charT* data, | ||||
|     std::size_t size) | ||||
| { | ||||
|     return static_cast<std::size_t>(os.rdbuf()->sputn(data, size)); | ||||
| } | ||||
|  | ||||
| template<class charT, class traits> | ||||
| inline bool | ||||
| oss_fill(std::basic_ostream<charT, traits>& os, std::size_t size) | ||||
| { | ||||
|     charT c = os.fill(); | ||||
|     charT fill[] = { c, c, c, c, c, c, c, c }; | ||||
|     enum { | ||||
|         chunk = sizeof fill / sizeof(charT) | ||||
|     }; | ||||
|     for (; size > chunk; size -= chunk) { | ||||
|         if (boost::detail::oss_put(os, fill, chunk) != chunk) { | ||||
|             return false; | ||||
|         } | ||||
|     } | ||||
|     return boost::detail::oss_put(os, fill, size) == size; | ||||
| } | ||||
|  | ||||
| template<class charT, class traits> | ||||
| class oss_guard { | ||||
| public: | ||||
|     explicit oss_guard(std::basic_ostream<charT, traits>& os) BOOST_NOEXCEPT | ||||
|         : os_(&os) { } | ||||
|     ~oss_guard() BOOST_NOEXCEPT_IF(false) { | ||||
|         if (os_) { | ||||
|             os_->setstate(std::basic_ostream<charT, traits>::badbit); | ||||
|         } | ||||
|     } | ||||
|     void release() BOOST_NOEXCEPT { | ||||
|         os_ = 0; | ||||
|     } | ||||
| private: | ||||
|     oss_guard(const oss_guard&); | ||||
|     oss_guard& operator=(const oss_guard&); | ||||
|     std::basic_ostream<charT, traits>* os_; | ||||
| }; | ||||
|  | ||||
| } /* detail */ | ||||
|  | ||||
| template<class charT, class traits> | ||||
| inline std::basic_ostream<charT, traits>& | ||||
| ostream_string(std::basic_ostream<charT, traits>& os, const charT* data, | ||||
|     std::size_t size) | ||||
| { | ||||
|     typedef std::basic_ostream<charT, traits> stream; | ||||
|     detail::oss_guard<charT, traits> guard(os); | ||||
|     typename stream::sentry entry(os); | ||||
|     if (entry) { | ||||
|         std::size_t width = static_cast<std::size_t>(os.width()); | ||||
|         if (width <= size) { | ||||
|             if (detail::oss_put(os, data, size) != size) { | ||||
|                 return os; | ||||
|             } | ||||
|         } else if ((os.flags() & stream::adjustfield) == stream::left) { | ||||
|             if (detail::oss_put(os, data, size) != size || | ||||
|                 !detail::oss_fill(os, width - size)) { | ||||
|                 return os; | ||||
|             } | ||||
|         } else if (!detail::oss_fill(os, width - size) || | ||||
|             detail::oss_put(os, data, size) != size) { | ||||
|             return os; | ||||
|         } | ||||
|         os.width(0); | ||||
|     } | ||||
|     guard.release(); | ||||
|     return os; | ||||
| } | ||||
|  | ||||
| } /* boost */ | ||||
|  | ||||
| #endif | ||||
| @@ -18,19 +18,16 @@ | ||||
| #include <boost/preprocessor/repetition/enum_shifted_params.hpp> | ||||
| #include <boost/preprocessor/facilities/intercept.hpp> | ||||
| #include <boost/detail/workaround.hpp> | ||||
| #include <boost/mpl/has_xxx.hpp> | ||||
| #include <boost/mpl/if.hpp> | ||||
| #include <boost/mpl/eval_if.hpp> | ||||
| #include <boost/mpl/bool.hpp> | ||||
| #include <boost/mpl/identity.hpp> | ||||
| #include <boost/mpl/or.hpp> | ||||
| #include <boost/type_traits/is_class.hpp> | ||||
| #include <boost/type_traits/is_pointer.hpp> | ||||
| #include <boost/type_traits/is_member_function_pointer.hpp> | ||||
| #include <boost/type_traits/remove_cv.hpp> | ||||
| #include <boost/type_traits/remove_reference.hpp> | ||||
| #include <boost/utility/declval.hpp> | ||||
| #include <boost/utility/enable_if.hpp> | ||||
| #include <boost/type_traits/declval.hpp> | ||||
| #include <boost/type_traits/conditional.hpp> | ||||
| #include <boost/type_traits/type_identity.hpp> | ||||
| #include <boost/type_traits/integral_constant.hpp> | ||||
| #include <boost/core/enable_if.hpp> | ||||
|  | ||||
| #ifndef BOOST_RESULT_OF_NUM_ARGS | ||||
| #  define BOOST_RESULT_OF_NUM_ARGS 16 | ||||
| @@ -47,10 +44,6 @@ | ||||
|   BOOST_RESULT_OF_USE_TR1_WITH_DECLTYPE_FALLBACK cannot be defined at the same time. | ||||
| #endif | ||||
|  | ||||
| #if defined(BOOST_RESULT_OF_USE_TR1_WITH_DECLTYPE_FALLBACK) && defined(BOOST_MPL_CFG_NO_HAS_XXX_TEMPLATE) | ||||
| #  error Cannot fallback to decltype if BOOST_MPL_CFG_NO_HAS_XXX_TEMPLATE is not defined. | ||||
| #endif | ||||
|  | ||||
| #ifndef BOOST_RESULT_OF_USE_TR1 | ||||
| #  ifndef BOOST_RESULT_OF_USE_DECLTYPE | ||||
| #    ifndef BOOST_RESULT_OF_USE_TR1_WITH_DECLTYPE_FALLBACK | ||||
| @@ -71,11 +64,40 @@ template<typename F> struct tr1_result_of; // a TR1-style implementation of resu | ||||
| #if !defined(BOOST_NO_SFINAE) | ||||
| namespace detail { | ||||
|  | ||||
| BOOST_MPL_HAS_XXX_TRAIT_DEF(result_type) | ||||
| typedef char result_of_yes_type;      // sizeof(result_of_yes_type) == 1 | ||||
| typedef char (&result_of_no_type)[2]; // sizeof(result_of_no_type)  == 2 | ||||
|  | ||||
| template<class T> struct result_of_has_type {}; | ||||
|  | ||||
| template<class T> struct result_of_has_result_type_impl | ||||
| { | ||||
|     template<class U> static result_of_yes_type f( result_of_has_type<typename U::result_type>* ); | ||||
|     template<class U> static result_of_no_type f( ... ); | ||||
|  | ||||
|     typedef boost::integral_constant<bool, sizeof(f<T>(0)) == sizeof(result_of_yes_type)> type; | ||||
| }; | ||||
|  | ||||
| template<class T> struct result_of_has_result_type: result_of_has_result_type_impl<T>::type | ||||
| { | ||||
| }; | ||||
|  | ||||
| // Work around a nvcc bug by only defining has_result when it's needed. | ||||
| #ifdef BOOST_RESULT_OF_USE_TR1_WITH_DECLTYPE_FALLBACK | ||||
| BOOST_MPL_HAS_XXX_TEMPLATE_DEF(result) | ||||
|  | ||||
| template<template<class> class C> struct result_of_has_template {}; | ||||
|  | ||||
| template<class T> struct result_of_has_result_impl | ||||
| { | ||||
|     template<class U> static result_of_yes_type f( result_of_has_template<U::template result>* ); | ||||
|     template<class U> static result_of_no_type f( ... ); | ||||
|  | ||||
|     typedef boost::integral_constant<bool, sizeof(f<T>(0)) == sizeof(result_of_yes_type)> type; | ||||
| }; | ||||
|  | ||||
| template<class T> struct result_of_has_result: result_of_has_result_impl<T>::type | ||||
| { | ||||
| }; | ||||
|  | ||||
| #endif | ||||
|  | ||||
| template<typename F, typename FArgs, bool HasResultType> struct tr1_result_of_impl; | ||||
| @@ -97,9 +119,6 @@ struct result_of_weird_type { | ||||
|   friend result_of_private_type operator,(result_of_private_type, result_of_weird_type); | ||||
| }; | ||||
|  | ||||
| typedef char result_of_yes_type;      // sizeof(result_of_yes_type) == 1 | ||||
| typedef char (&result_of_no_type)[2]; // sizeof(result_of_no_type)  == 2 | ||||
|  | ||||
| template<typename T> | ||||
| result_of_no_type result_of_is_private_type(T const &); | ||||
| result_of_yes_type result_of_is_private_type(result_of_private_type); | ||||
| @@ -180,10 +199,10 @@ struct tr1_result_of_impl<F, FArgs, true> | ||||
| }; | ||||
|  | ||||
| template<typename FArgs> | ||||
| struct is_function_with_no_args : mpl::false_ {}; | ||||
| struct is_function_with_no_args : false_type {}; | ||||
|  | ||||
| template<typename F> | ||||
| struct is_function_with_no_args<F(void)> : mpl::true_ {}; | ||||
| struct is_function_with_no_args<F(void)> : true_type {}; | ||||
|  | ||||
| template<typename F, typename FArgs> | ||||
| struct result_of_nested_result : F::template result<FArgs> | ||||
| @@ -191,7 +210,7 @@ struct result_of_nested_result : F::template result<FArgs> | ||||
|  | ||||
| template<typename F, typename FArgs> | ||||
| struct tr1_result_of_impl<F, FArgs, false> | ||||
|   : mpl::if_<is_function_with_no_args<FArgs>, | ||||
|   : conditional<is_function_with_no_args<FArgs>::value, | ||||
|              result_of_void_impl<F>, | ||||
|              result_of_nested_result<F, FArgs> >::type | ||||
| {}; | ||||
| @@ -201,6 +220,11 @@ struct tr1_result_of_impl<F, FArgs, false> | ||||
| #define BOOST_PP_ITERATION_PARAMS_1 (3,(0,BOOST_RESULT_OF_NUM_ARGS,<boost/utility/detail/result_of_iterate.hpp>)) | ||||
| #include BOOST_PP_ITERATE() | ||||
|  | ||||
| #if 0 | ||||
| // inform dependency trackers, as they can't see through macro includes | ||||
| #include <boost/utility/detail/result_of_iterate.hpp> | ||||
| #endif | ||||
|  | ||||
| #else | ||||
| #  define BOOST_NO_RESULT_OF 1 | ||||
| #endif | ||||
|   | ||||
| @@ -1,5 +1,6 @@ | ||||
| /* | ||||
|    Copyright (c) Marshall Clow 2012-2015. | ||||
|    Copyright (c) Glen Joseph Fernandes 2019 (glenjofe@gmail.com) | ||||
|  | ||||
|    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) | ||||
| @@ -17,6 +18,7 @@ | ||||
|  | ||||
| #include <boost/config.hpp> | ||||
| #include <boost/detail/workaround.hpp> | ||||
| #include <boost/utility/ostream_string.hpp> | ||||
| #include <boost/utility/string_ref_fwd.hpp> | ||||
| #include <boost/throw_exception.hpp> | ||||
|  | ||||
| @@ -27,6 +29,11 @@ | ||||
| #include <string> | ||||
| #include <iosfwd> | ||||
|  | ||||
| #if defined(BOOST_NO_CXX11_DEFAULTED_FUNCTIONS) || (defined(BOOST_GCC) && ((BOOST_GCC+0) / 100) <= 406) | ||||
| // GCC 4.6 cannot handle a defaulted function with noexcept specifier | ||||
| #define BOOST_STRING_REF_NO_CXX11_DEFAULTED_NOEXCEPT_FUNCTIONS | ||||
| #endif | ||||
|  | ||||
| namespace boost { | ||||
|  | ||||
|     namespace detail { | ||||
| @@ -57,26 +64,44 @@ namespace boost { | ||||
|         static BOOST_CONSTEXPR_OR_CONST size_type npos = size_type(-1); | ||||
|  | ||||
|         // construct/copy | ||||
|         BOOST_CONSTEXPR basic_string_ref () | ||||
|         BOOST_CONSTEXPR basic_string_ref () BOOST_NOEXCEPT | ||||
|             : ptr_(NULL), len_(0) {} | ||||
|  | ||||
|         BOOST_CONSTEXPR basic_string_ref (const basic_string_ref &rhs) | ||||
|         // by defaulting these functions, basic_string_ref becomes | ||||
|         //  trivially copy/move constructible. | ||||
|         BOOST_CONSTEXPR basic_string_ref (const basic_string_ref &rhs) BOOST_NOEXCEPT | ||||
| #ifndef BOOST_STRING_REF_NO_CXX11_DEFAULTED_NOEXCEPT_FUNCTIONS | ||||
|             = default; | ||||
| #else | ||||
|             : ptr_(rhs.ptr_), len_(rhs.len_) {} | ||||
| #endif | ||||
|  | ||||
|         basic_string_ref& operator=(const basic_string_ref &rhs) { | ||||
|         basic_string_ref& operator=(const basic_string_ref &rhs) BOOST_NOEXCEPT | ||||
| #ifndef BOOST_STRING_REF_NO_CXX11_DEFAULTED_NOEXCEPT_FUNCTIONS | ||||
|             = default; | ||||
| #else | ||||
|             { | ||||
|             ptr_ = rhs.ptr_; | ||||
|             len_ = rhs.len_; | ||||
|             return *this; | ||||
|             } | ||||
| #endif | ||||
|  | ||||
|         basic_string_ref(const charT* str) | ||||
|         basic_string_ref(const charT* str) BOOST_NOEXCEPT | ||||
|             : ptr_(str), len_(traits::length(str)) {} | ||||
|  | ||||
|         template<typename Allocator> | ||||
|         basic_string_ref(const std::basic_string<charT, traits, Allocator>& str) | ||||
|             : ptr_(str.data()), len_(str.length()) {} | ||||
|  | ||||
|         BOOST_CONSTEXPR basic_string_ref(const charT* str, size_type len) | ||||
| // #if !defined(BOOST_NO_CXX11_RVALUE_REFERENCES) && !defined(BOOST_NO_CXX11_DELETED_FUNCTIONS) | ||||
| //         // Constructing a string_ref from a temporary string is a bad idea | ||||
| //         template<typename Allocator> | ||||
| //         basic_string_ref(      std::basic_string<charT, traits, Allocator>&&) | ||||
| //             = delete; | ||||
| // #endif | ||||
|  | ||||
|         BOOST_CONSTEXPR basic_string_ref(const charT* str, size_type len) BOOST_NOEXCEPT | ||||
|             : ptr_(str), len_(len) {} | ||||
|  | ||||
| #ifndef BOOST_NO_CXX11_EXPLICIT_CONVERSION_OPERATORS | ||||
| @@ -139,9 +164,7 @@ namespace boost { | ||||
|         basic_string_ref substr(size_type pos, size_type n=npos) const { | ||||
|             if ( pos > size()) | ||||
|                 BOOST_THROW_EXCEPTION( std::out_of_range ( "string_ref::substr" ) ); | ||||
|             if ( n == npos || pos + n > size()) | ||||
|                 n = size () - pos; | ||||
|             return basic_string_ref ( data() + pos, n ); | ||||
|             return basic_string_ref(data() + pos, (std::min)(size() - pos, n)); | ||||
|             } | ||||
|  | ||||
|         int compare(basic_string_ref x) const { | ||||
| @@ -160,6 +183,7 @@ namespace boost { | ||||
|             } | ||||
|  | ||||
|         size_type find(basic_string_ref s) const { | ||||
|             if (s.empty()) return 0; | ||||
|             const_iterator iter = std::search ( this->cbegin (), this->cend (), | ||||
|                                                 s.cbegin (), s.cend (), traits::eq ); | ||||
|             return iter == this->cend () ? npos : std::distance ( this->cbegin (), iter ); | ||||
| @@ -172,15 +196,16 @@ namespace boost { | ||||
|             } | ||||
|  | ||||
|         size_type rfind(basic_string_ref s) const { | ||||
|             if (s.empty()) return 0; | ||||
|             const_reverse_iterator iter = std::search ( this->crbegin (), this->crend (), | ||||
|                                                 s.crbegin (), s.crend (), traits::eq ); | ||||
|             return iter == this->crend () ? npos : reverse_distance ( this->crbegin (), iter ); | ||||
|             return iter == this->crend () ? npos : (std::distance(iter, this->crend()) - s.size()); | ||||
|             } | ||||
|  | ||||
|         size_type rfind(charT c) const { | ||||
|             const_reverse_iterator iter = std::find_if ( this->crbegin (), this->crend (), | ||||
|                                     detail::string_ref_traits_eq<charT, traits> ( c )); | ||||
|             return iter == this->crend () ? npos : reverse_distance ( this->crbegin (), iter ); | ||||
|             return iter == this->crend () ? npos : (this->size() - 1 - std::distance(this->crbegin(), iter)); | ||||
|             } | ||||
|  | ||||
|         size_type find_first_of(charT c) const { return  find (c); } | ||||
| @@ -195,7 +220,7 @@ namespace boost { | ||||
|         size_type find_last_of(basic_string_ref s) const { | ||||
|             const_reverse_iterator iter = std::find_first_of | ||||
|                 ( this->crbegin (), this->crend (), s.cbegin (), s.cend (), traits::eq ); | ||||
|             return iter == this->crend () ? npos : reverse_distance ( this->crbegin (), iter); | ||||
|             return iter == this->crend () ? npos : (this->size() - 1 - std::distance(this->crbegin(), iter)); | ||||
|             } | ||||
|  | ||||
|         size_type find_first_not_of(basic_string_ref s) const { | ||||
| @@ -212,21 +237,17 @@ namespace boost { | ||||
|  | ||||
|         size_type find_last_not_of(basic_string_ref s) const { | ||||
|             const_reverse_iterator iter = find_not_of ( this->crbegin (), this->crend (), s ); | ||||
|             return iter == this->crend () ? npos : reverse_distance ( this->crbegin (), iter ); | ||||
|             return iter == this->crend () ? npos : (this->size() - 1 - std::distance(this->crbegin(), iter)); | ||||
|             } | ||||
|  | ||||
|         size_type find_last_not_of(charT c) const { | ||||
|             for ( const_reverse_iterator iter = this->crbegin (); iter != this->crend (); ++iter ) | ||||
|                 if ( !traits::eq ( c, *iter )) | ||||
|                     return reverse_distance ( this->crbegin (), iter ); | ||||
|                     return this->size() - 1 - std::distance(this->crbegin(), iter); | ||||
|             return npos; | ||||
|             } | ||||
|  | ||||
|     private: | ||||
|         template <typename r_iter> | ||||
|         size_type reverse_distance ( r_iter first, r_iter last ) const { | ||||
|             return len_ - 1 - std::distance ( first, last ); | ||||
|             } | ||||
|  | ||||
|         template <typename Iterator> | ||||
|         Iterator find_not_of ( Iterator first, Iterator last, basic_string_ref s ) const { | ||||
| @@ -402,52 +423,11 @@ namespace boost { | ||||
|         return basic_string_ref<charT, traits>(x) >= y; | ||||
|         } | ||||
|  | ||||
|     namespace detail { | ||||
|  | ||||
|         template<class charT, class traits> | ||||
|         inline void insert_fill_chars(std::basic_ostream<charT, traits>& os, std::size_t n) { | ||||
|             enum { chunk_size = 8 }; | ||||
|             charT fill_chars[chunk_size]; | ||||
|             std::fill_n(fill_chars, static_cast< std::size_t >(chunk_size), os.fill()); | ||||
|             for (; n >= chunk_size && os.good(); n -= chunk_size) | ||||
|                 os.write(fill_chars, static_cast< std::size_t >(chunk_size)); | ||||
|             if (n > 0 && os.good()) | ||||
|                 os.write(fill_chars, n); | ||||
|             } | ||||
|  | ||||
|         template<class charT, class traits> | ||||
|         void insert_aligned(std::basic_ostream<charT, traits>& os, const basic_string_ref<charT,traits>& str) { | ||||
|             const std::size_t size = str.size(); | ||||
|             const std::size_t alignment_size = static_cast< std::size_t >(os.width()) - size; | ||||
|             const bool align_left = (os.flags() & std::basic_ostream<charT, traits>::adjustfield) == std::basic_ostream<charT, traits>::left; | ||||
|             if (!align_left) { | ||||
|                 detail::insert_fill_chars(os, alignment_size); | ||||
|                 if (os.good()) | ||||
|                     os.write(str.data(), size); | ||||
|                 } | ||||
|             else { | ||||
|                 os.write(str.data(), size); | ||||
|                 if (os.good()) | ||||
|                     detail::insert_fill_chars(os, alignment_size); | ||||
|                 } | ||||
|             } | ||||
|  | ||||
|         } // namespace detail | ||||
|  | ||||
|     // Inserter | ||||
|     template<class charT, class traits> | ||||
|     inline std::basic_ostream<charT, traits>& | ||||
|     operator<<(std::basic_ostream<charT, traits>& os, const basic_string_ref<charT,traits>& str) { | ||||
|         if (os.good()) { | ||||
|             const std::size_t size = str.size(); | ||||
|             const std::size_t w = static_cast< std::size_t >(os.width()); | ||||
|             if (w <= size) | ||||
|                 os.write(str.data(), size); | ||||
|             else | ||||
|                 detail::insert_aligned(os, str); | ||||
|             os.width(0); | ||||
|             } | ||||
|         return os; | ||||
|         return boost::ostream_string(os, str.data(), str.size()); | ||||
|         } | ||||
|  | ||||
| #if 0 | ||||
|   | ||||
| @@ -1,6 +1,7 @@ | ||||
| /* | ||||
|    <20> Copyright (c) Marshall Clow 2012-2015. | ||||
|    <20> Copyright Beman Dawes 2015 | ||||
|    Copyright (c) Marshall Clow 2012-2015. | ||||
|    Copyright (c) Beman Dawes 2015 | ||||
|    Copyright (c) Glen Joseph Fernandes 2019 (glenjofe@gmail.com) | ||||
|  | ||||
|    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) | ||||
| @@ -19,8 +20,10 @@ | ||||
|  | ||||
| #include <boost/config.hpp> | ||||
| #include <boost/detail/workaround.hpp> | ||||
| #include <boost/utility/ostream_string.hpp> | ||||
| #include <boost/utility/string_view_fwd.hpp> | ||||
| #include <boost/throw_exception.hpp> | ||||
| #include <boost/container_hash/hash_fwd.hpp> | ||||
|  | ||||
| #include <cstddef> | ||||
| #include <stdexcept> | ||||
| @@ -30,6 +33,11 @@ | ||||
| #include <cstring> | ||||
| #include <iosfwd> | ||||
|  | ||||
| #if defined(BOOST_NO_CXX11_DEFAULTED_FUNCTIONS) || (defined(BOOST_GCC) && ((BOOST_GCC+0) / 100) <= 406) | ||||
| // GCC 4.6 cannot handle a defaulted function with noexcept specifier | ||||
| #define BOOST_STRING_VIEW_NO_CXX11_DEFAULTED_NOEXCEPT_FUNCTIONS | ||||
| #endif | ||||
|  | ||||
| namespace boost { | ||||
|  | ||||
|     namespace detail { | ||||
| @@ -38,7 +46,7 @@ namespace boost { | ||||
|         class string_view_traits_eq { | ||||
|         public: | ||||
|             string_view_traits_eq ( charT ch ) : ch_(ch) {} | ||||
|             bool operator () ( charT val ) const { return traits::eq ( ch_, val ); } | ||||
|             bool operator()( charT val ) const { return traits::eq (ch_, val); } | ||||
|             charT ch_; | ||||
|             }; | ||||
|         } | ||||
| @@ -47,37 +55,54 @@ namespace boost { | ||||
|     class basic_string_view { | ||||
|     public: | ||||
|       // types | ||||
|       typedef traits traits_type; | ||||
|       typedef charT value_type; | ||||
|       typedef charT* pointer; | ||||
|       typedef const charT* const_pointer; | ||||
|       typedef charT& reference; | ||||
|       typedef const charT& const_reference; | ||||
|       typedef const_pointer const_iterator; // impl-defined | ||||
|       typedef const_iterator iterator; | ||||
|       typedef traits                                traits_type; | ||||
|       typedef charT                                 value_type; | ||||
|       typedef charT*                                pointer; | ||||
|       typedef const charT*                          const_pointer; | ||||
|       typedef charT&                                reference; | ||||
|       typedef const charT&                          const_reference; | ||||
|       typedef const_pointer                         const_iterator; // impl-defined | ||||
|       typedef const_iterator                        iterator; | ||||
|       typedef std::reverse_iterator<const_iterator> const_reverse_iterator; | ||||
|       typedef const_reverse_iterator reverse_iterator; | ||||
|       typedef std::size_t size_type; | ||||
|       typedef std::ptrdiff_t difference_type; | ||||
|       static BOOST_CONSTEXPR_OR_CONST size_type npos = size_type(-1); | ||||
|       typedef const_reverse_iterator                reverse_iterator; | ||||
|       typedef std::size_t                           size_type; | ||||
|       typedef std::ptrdiff_t                        difference_type; | ||||
|       static BOOST_CONSTEXPR_OR_CONST size_type     npos = size_type(-1); | ||||
|  | ||||
|       // construct/copy | ||||
|       BOOST_CONSTEXPR basic_string_view() BOOST_NOEXCEPT | ||||
|         : ptr_(NULL), len_(0) {} | ||||
|  | ||||
|       // by defaulting these functions, basic_string_ref becomes | ||||
|       //  trivially copy/move constructible. | ||||
|       BOOST_CONSTEXPR basic_string_view(const basic_string_view &rhs) BOOST_NOEXCEPT | ||||
| #ifndef BOOST_STRING_VIEW_NO_CXX11_DEFAULTED_NOEXCEPT_FUNCTIONS | ||||
|         = default; | ||||
| #else | ||||
|         : ptr_(rhs.ptr_), len_(rhs.len_) {} | ||||
| #endif | ||||
|  | ||||
|       basic_string_view& operator=(const basic_string_view &rhs) BOOST_NOEXCEPT { | ||||
|       basic_string_view& operator=(const basic_string_view &rhs) BOOST_NOEXCEPT | ||||
| #ifndef BOOST_STRING_VIEW_NO_CXX11_DEFAULTED_NOEXCEPT_FUNCTIONS | ||||
|             = default; | ||||
| #else | ||||
|         { | ||||
|         ptr_ = rhs.ptr_; | ||||
|         len_ = rhs.len_; | ||||
|         return *this; | ||||
|         } | ||||
| #endif | ||||
|  | ||||
|       template<typename Allocator> | ||||
|         basic_string_view(const std::basic_string<charT, traits, | ||||
|           Allocator>& str) BOOST_NOEXCEPT | ||||
|         : ptr_(str.data()), len_(str.length()) {} | ||||
|         basic_string_view(const std::basic_string<charT, traits, Allocator>& str) BOOST_NOEXCEPT | ||||
|           : ptr_(str.data()), len_(str.length()) {} | ||||
|  | ||||
| // #if !defined(BOOST_NO_CXX11_RVALUE_REFERENCES) && !defined(BOOST_NO_CXX11_DELETED_FUNCTIONS) | ||||
| //       // Constructing a string_view from a temporary string is a bad idea | ||||
| //       template<typename Allocator> | ||||
| //         basic_string_view(      std::basic_string<charT, traits, Allocator>&&) | ||||
| //           = delete; | ||||
| // #endif | ||||
|  | ||||
|       BOOST_CONSTEXPR basic_string_view(const charT* str) | ||||
|         : ptr_(str), len_(traits::length(str)) {} | ||||
| @@ -86,33 +111,31 @@ namespace boost { | ||||
|         : ptr_(str), len_(len) {} | ||||
|  | ||||
|         // iterators | ||||
|         BOOST_CONSTEXPR const_iterator   begin() const BOOST_NOEXCEPT {  return ptr_; } | ||||
|         BOOST_CONSTEXPR const_iterator  cbegin() const BOOST_NOEXCEPT {  return ptr_; } | ||||
|         BOOST_CONSTEXPR const_iterator     end() const BOOST_NOEXCEPT {  return ptr_ + len_; } | ||||
|         BOOST_CONSTEXPR const_iterator    cend() const BOOST_NOEXCEPT {  return ptr_ + len_; } | ||||
|                 const_reverse_iterator  rbegin() const BOOST_NOEXCEPT {  return const_reverse_iterator (end()); } | ||||
|                 const_reverse_iterator crbegin() const BOOST_NOEXCEPT {  return const_reverse_iterator (end()); } | ||||
|                 const_reverse_iterator    rend() const BOOST_NOEXCEPT {  return const_reverse_iterator (begin()); } | ||||
|                 const_reverse_iterator   crend() const BOOST_NOEXCEPT {  return const_reverse_iterator (begin()); } | ||||
|         BOOST_CONSTEXPR const_iterator   begin() const BOOST_NOEXCEPT { return ptr_; } | ||||
|         BOOST_CONSTEXPR const_iterator  cbegin() const BOOST_NOEXCEPT { return ptr_; } | ||||
|         BOOST_CONSTEXPR const_iterator     end() const BOOST_NOEXCEPT { return ptr_ + len_; } | ||||
|         BOOST_CONSTEXPR const_iterator    cend() const BOOST_NOEXCEPT { return ptr_ + len_; } | ||||
|                 const_reverse_iterator  rbegin() const BOOST_NOEXCEPT { return const_reverse_iterator(end()); } | ||||
|                 const_reverse_iterator crbegin() const BOOST_NOEXCEPT { return const_reverse_iterator(end()); } | ||||
|                 const_reverse_iterator    rend() const BOOST_NOEXCEPT { return const_reverse_iterator(begin()); } | ||||
|                 const_reverse_iterator   crend() const BOOST_NOEXCEPT { return const_reverse_iterator(begin()); } | ||||
|  | ||||
|         // capacity | ||||
|         BOOST_CONSTEXPR size_type size()     const BOOST_NOEXCEPT {  return len_; } | ||||
|         BOOST_CONSTEXPR size_type length()   const BOOST_NOEXCEPT {  return len_; } | ||||
|         BOOST_CONSTEXPR size_type max_size() const BOOST_NOEXCEPT {  return len_; } | ||||
|         BOOST_CONSTEXPR bool empty()         const BOOST_NOEXCEPT {  return len_ == 0; } | ||||
|         BOOST_CONSTEXPR size_type size()     const BOOST_NOEXCEPT { return len_; } | ||||
|         BOOST_CONSTEXPR size_type length()   const BOOST_NOEXCEPT { return len_; } | ||||
|         BOOST_CONSTEXPR size_type max_size() const BOOST_NOEXCEPT { return len_; } | ||||
|         BOOST_CONSTEXPR bool empty()         const BOOST_NOEXCEPT { return len_ == 0; } | ||||
|  | ||||
|         // element access | ||||
|         BOOST_CONSTEXPR const_reference operator[](size_type pos) const { return ptr_[pos]; } | ||||
|         BOOST_CONSTEXPR const_reference operator[](size_type pos) const BOOST_NOEXCEPT { return ptr_[pos]; } | ||||
|  | ||||
|         BOOST_CONSTEXPR const_reference at(size_t pos) const { | ||||
|             if ( pos >= len_ ) | ||||
|                 BOOST_THROW_EXCEPTION( std::out_of_range ( "boost::string_view::at" ) ); | ||||
|             return ptr_[pos]; | ||||
|             return pos >= len_ ? BOOST_THROW_EXCEPTION(std::out_of_range("boost::string_view::at")), ptr_[0] : ptr_[pos]; | ||||
|             } | ||||
|  | ||||
|         BOOST_CONSTEXPR const_reference front() const { return ptr_[0]; } | ||||
|         BOOST_CONSTEXPR const_reference back()  const { return ptr_[len_-1]; } | ||||
|         BOOST_CONSTEXPR const_pointer data()  const BOOST_NOEXCEPT { return ptr_; } | ||||
|         BOOST_CONSTEXPR const_reference front() const                { return ptr_[0]; } | ||||
|         BOOST_CONSTEXPR const_reference back()  const                { return ptr_[len_-1]; } | ||||
|         BOOST_CONSTEXPR const_pointer data()    const BOOST_NOEXCEPT { return ptr_; } | ||||
|  | ||||
|         // modifiers | ||||
|         void clear() BOOST_NOEXCEPT { len_ = 0; }          // Boost extension | ||||
| @@ -135,9 +158,7 @@ namespace boost { | ||||
|             std::swap(len_, s.len_); | ||||
|             } | ||||
|  | ||||
|  | ||||
|         // basic_string_view string operations | ||||
|   | ||||
| #ifndef BOOST_NO_CXX11_EXPLICIT_CONVERSION_OPERATORS | ||||
|         template<typename Allocator> | ||||
|         explicit operator std::basic_string<charT, traits, Allocator>() const { | ||||
| @@ -147,71 +168,78 @@ namespace boost { | ||||
|  | ||||
| #ifndef BOOST_NO_CXX11_FUNCTION_TEMPLATE_DEFAULT_ARGS | ||||
|         template<typename Allocator = std::allocator<charT> > | ||||
|         std::basic_string<charT, traits> to_string(const Allocator& a = Allocator()) const { | ||||
|         std::basic_string<charT, traits, Allocator> to_string(const Allocator& a = Allocator()) const { | ||||
|             return std::basic_string<charT, traits, Allocator>(begin(), end(), a); | ||||
|             } | ||||
| #else | ||||
|         std::basic_string<charT, traits> to_string() const { | ||||
|             return std::basic_string<charT, traits>(begin(), end()); | ||||
|             } | ||||
|  | ||||
|         template<typename Allocator> | ||||
|         std::basic_string<charT, traits, Allocator> to_string(const Allocator& a) const { | ||||
|             return std::basic_string<charT, traits, Allocator>(begin(), end(), a); | ||||
|             } | ||||
| #endif | ||||
|  | ||||
|         size_type copy( charT* s, size_type n, size_type pos = 0 ) const { | ||||
|             if ( pos > size()) | ||||
|                 BOOST_THROW_EXCEPTION( std::out_of_range ( "string_view::copy" ) ); | ||||
|         size_type copy(charT* s, size_type n, size_type pos=0) const { | ||||
|             if (pos > size()) | ||||
|                 BOOST_THROW_EXCEPTION(std::out_of_range("string_view::copy" )); | ||||
|             size_type rlen = (std::min)(n, len_ - pos); | ||||
|             // use std::copy(begin() + pos, begin() + pos + rlen, s) rather than | ||||
|             // std::copy_n(begin() + pos, rlen, s) to support pre-C++11 standard libraries | ||||
|             std::copy(begin() + pos, begin() + pos + rlen, s); | ||||
|     		traits_type::copy(s, data() + pos, rlen); | ||||
|             return rlen; | ||||
|             } | ||||
|  | ||||
|         BOOST_CXX14_CONSTEXPR basic_string_view substr(size_type pos, size_type n=npos) const { | ||||
|             if ( pos > size()) | ||||
|                 BOOST_THROW_EXCEPTION( std::out_of_range ( "string_view::substr" ) ); | ||||
|             if ( n == npos || pos + n > size()) | ||||
|                 n = size () - pos; | ||||
|             return basic_string_view ( data() + pos, n ); | ||||
|             return basic_string_view(data() + pos, (std::min)(size() - pos, n)); | ||||
|             } | ||||
|  | ||||
|         BOOST_CXX14_CONSTEXPR int compare(basic_string_view x) const BOOST_NOEXCEPT { | ||||
|             const int cmp = traits::compare ( ptr_, x.ptr_, (std::min)(len_, x.len_)); | ||||
|             return cmp != 0 ? cmp : ( len_ == x.len_ ? 0 : len_ < x.len_ ? -1 : 1 ); | ||||
|             const int cmp = traits::compare(ptr_, x.ptr_, (std::min)(len_, x.len_)); | ||||
|             return cmp != 0 ? cmp : (len_ == x.len_ ? 0 : len_ < x.len_ ? -1 : 1); | ||||
|             } | ||||
|  | ||||
|         BOOST_CXX14_CONSTEXPR int compare(size_type pos1, size_type n1, basic_string_view x) | ||||
|           const BOOST_NOEXCEPT { | ||||
|             return substr(pos1, n1).compare(x); | ||||
|             } | ||||
|  | ||||
|         BOOST_CXX14_CONSTEXPR int compare(size_type pos1, size_type n1, | ||||
|           basic_string_view x, size_type pos2, size_type n2) const { | ||||
|             return substr(pos1, n1).compare(x.substr(pos2, n2)); | ||||
|             } | ||||
|  | ||||
|         BOOST_CXX14_CONSTEXPR int compare(const charT* x) const { | ||||
|             return compare(basic_string_view(x)); | ||||
|             } | ||||
|  | ||||
|         BOOST_CXX14_CONSTEXPR int compare(size_type pos1, size_type n1, const charT* x) const { | ||||
|             return substr(pos1, n1).compare(basic_string_view(x)); | ||||
|             } | ||||
|  | ||||
|         BOOST_CXX14_CONSTEXPR int compare(size_type pos1, size_type n1, | ||||
|           const charT* x, size_type n2) const { | ||||
|             return substr(pos1, n1).compare(basic_string_view(x, n2)); | ||||
|             } | ||||
|  | ||||
|         //  Searches | ||||
|  | ||||
|         BOOST_CONSTEXPR bool starts_with(charT c) const {  // Boost extension | ||||
|             return !empty() && traits::eq ( c, front()); | ||||
|             }   | ||||
|         BOOST_CONSTEXPR bool starts_with(basic_string_view x) const {  // Boost extension | ||||
|             return len_ >= x.len_ && traits::compare ( ptr_, x.ptr_, x.len_ ) == 0; | ||||
|         BOOST_CONSTEXPR bool starts_with(charT c) const BOOST_NOEXCEPT {              // Boost extension | ||||
|             return !empty() && traits::eq(c, front()); | ||||
|             } | ||||
|  | ||||
|         BOOST_CONSTEXPR bool ends_with(charT c) const { | ||||
|             return !empty() && traits::eq ( c, back());  // Boost extension | ||||
|         BOOST_CONSTEXPR bool starts_with(basic_string_view x) const BOOST_NOEXCEPT {  // Boost extension | ||||
|             return len_ >= x.len_ && traits::compare(ptr_, x.ptr_, x.len_) == 0; | ||||
|             } | ||||
|         BOOST_CONSTEXPR bool ends_with(basic_string_view x) const {  // Boost extension | ||||
|             return len_ >= x.len_ && traits::compare ( ptr_ + len_ - x.len_, | ||||
|               x.ptr_, x.len_ ) == 0; | ||||
|  | ||||
|         BOOST_CONSTEXPR bool ends_with(charT c) const BOOST_NOEXCEPT {                // Boost extension | ||||
|             return !empty() && traits::eq(c, back()); | ||||
|             } | ||||
|  | ||||
|         BOOST_CONSTEXPR bool ends_with(basic_string_view x) const BOOST_NOEXCEPT {    // Boost extension | ||||
|             return len_ >= x.len_ && | ||||
|                traits::compare(ptr_ + len_ - x.len_, x.ptr_, x.len_) == 0; | ||||
|             } | ||||
|  | ||||
|         //  find | ||||
| @@ -220,26 +248,41 @@ namespace boost { | ||||
|               return npos; | ||||
|             if (s.empty()) | ||||
|               return pos; | ||||
|             const_iterator iter = std::search(this->cbegin() + pos, this->cend(), | ||||
|                                                s.cbegin (), s.cend (), traits::eq ); | ||||
|             return iter == this->cend () ? npos : std::distance ( this->cbegin (), iter ); | ||||
|             if (s.size() > size() - pos) | ||||
|                 return npos; | ||||
|             const charT* cur = ptr_ + pos; | ||||
|             const charT* last = cend() - s.size() + 1; | ||||
|             for (; cur != last ; ++cur) { | ||||
|                 cur = traits::find(cur, last - cur, s[0]); | ||||
|                 if (!cur) | ||||
|                     return npos; | ||||
|                 if (traits::compare(cur, s.cbegin(), s.size()) == 0) | ||||
|                     return cur - ptr_; | ||||
|             } | ||||
|         BOOST_CXX14_CONSTEXPR size_type find(charT c, size_type pos = 0) const BOOST_NOEXCEPT | ||||
|             { return find(basic_string_view(&c, 1), pos); } | ||||
|         BOOST_CXX14_CONSTEXPR size_type find(const charT* s, size_type pos, size_type n) const | ||||
|             return npos; | ||||
|             } | ||||
|         BOOST_CXX14_CONSTEXPR size_type find(charT c, size_type pos = 0) const BOOST_NOEXCEPT { | ||||
|             if (pos > size()) | ||||
|               return npos; | ||||
|             const charT* ret_ptr = traits::find(ptr_ + pos, len_ - pos, c); | ||||
|             if (ret_ptr) | ||||
|               return ret_ptr - ptr_; | ||||
|             return npos; | ||||
|             } | ||||
|         BOOST_CXX14_CONSTEXPR size_type find(const charT* s, size_type pos, size_type n) const BOOST_NOEXCEPT | ||||
|             { return find(basic_string_view(s, n), pos); } | ||||
|         BOOST_CXX14_CONSTEXPR size_type find(const charT* s, size_type pos = 0) const | ||||
|         BOOST_CXX14_CONSTEXPR size_type find(const charT* s, size_type pos = 0) const BOOST_NOEXCEPT | ||||
|             { return find(basic_string_view(s), pos); } | ||||
|  | ||||
|         //  rfind | ||||
|         BOOST_CXX14_CONSTEXPR size_type rfind(basic_string_view s, size_type pos = npos) const BOOST_NOEXCEPT { | ||||
|             if (len_ < s.len_) | ||||
|               return npos; | ||||
|             if (pos > len_ - s.len_)  | ||||
|             if (pos > len_ - s.len_) | ||||
|               pos = len_ - s.len_; | ||||
|             if (s.len_ == 0u)     // an empty string is always found | ||||
|               return pos; | ||||
|             for (const charT* cur = ptr_ + pos;; --cur) { | ||||
|             for (const charT* cur = ptr_ + pos; ; --cur) { | ||||
|                 if (traits::compare(cur, s.ptr_, s.len_) == 0) | ||||
|                   return cur - ptr_; | ||||
|                 if (cur == ptr_) | ||||
| @@ -248,9 +291,9 @@ namespace boost { | ||||
|             } | ||||
|         BOOST_CXX14_CONSTEXPR size_type rfind(charT c, size_type pos = npos) const BOOST_NOEXCEPT | ||||
|             { return rfind(basic_string_view(&c, 1), pos); } | ||||
|         BOOST_CXX14_CONSTEXPR size_type rfind(const charT* s, size_type pos, size_type n) const | ||||
|         BOOST_CXX14_CONSTEXPR size_type rfind(const charT* s, size_type pos, size_type n) const BOOST_NOEXCEPT | ||||
|             { return rfind(basic_string_view(s, n), pos); } | ||||
|         BOOST_CXX14_CONSTEXPR size_type rfind(const charT* s, size_type pos = npos) const | ||||
|         BOOST_CXX14_CONSTEXPR size_type rfind(const charT* s, size_type pos = npos) const BOOST_NOEXCEPT | ||||
|             { return rfind(basic_string_view(s), pos); } | ||||
|  | ||||
|         //  find_first_of | ||||
| @@ -262,10 +305,10 @@ namespace boost { | ||||
|             return iter == this->cend () ? npos : std::distance ( this->cbegin (), iter ); | ||||
|             } | ||||
|         BOOST_CXX14_CONSTEXPR size_type find_first_of(charT c, size_type pos = 0) const BOOST_NOEXCEPT | ||||
|             { return find_first_of(basic_string_view(&c, 1), pos); } | ||||
|         BOOST_CXX14_CONSTEXPR size_type find_first_of(const charT* s, size_type pos, size_type n) const | ||||
|             { return find(c, pos); } | ||||
|         BOOST_CXX14_CONSTEXPR size_type find_first_of(const charT* s, size_type pos, size_type n) const BOOST_NOEXCEPT | ||||
|             { return find_first_of(basic_string_view(s, n), pos); } | ||||
|         BOOST_CXX14_CONSTEXPR size_type find_first_of(const charT* s, size_type pos = 0) const | ||||
|         BOOST_CXX14_CONSTEXPR size_type find_first_of(const charT* s, size_type pos = 0) const BOOST_NOEXCEPT | ||||
|             { return find_first_of(basic_string_view(s), pos); } | ||||
|  | ||||
|         //  find_last_of | ||||
| @@ -282,9 +325,9 @@ namespace boost { | ||||
|             } | ||||
|         BOOST_CXX14_CONSTEXPR size_type find_last_of(charT c, size_type pos = npos) const BOOST_NOEXCEPT | ||||
|             { return find_last_of(basic_string_view(&c, 1), pos); } | ||||
|         BOOST_CXX14_CONSTEXPR size_type find_last_of(const charT* s, size_type pos, size_type n) const | ||||
|         BOOST_CXX14_CONSTEXPR size_type find_last_of(const charT* s, size_type pos, size_type n) const BOOST_NOEXCEPT | ||||
|             { return find_last_of(basic_string_view(s, n), pos); } | ||||
|         BOOST_CXX14_CONSTEXPR size_type find_last_of(const charT* s, size_type pos = npos) const | ||||
|         BOOST_CXX14_CONSTEXPR size_type find_last_of(const charT* s, size_type pos = npos) const BOOST_NOEXCEPT | ||||
|             { return find_last_of(basic_string_view(s), pos); } | ||||
|  | ||||
|         //  find_first_not_of | ||||
| @@ -298,15 +341,15 @@ namespace boost { | ||||
|             } | ||||
|         BOOST_CXX14_CONSTEXPR size_type find_first_not_of(charT c, size_type pos = 0) const BOOST_NOEXCEPT | ||||
|             { return find_first_not_of(basic_string_view(&c, 1), pos); } | ||||
|         BOOST_CXX14_CONSTEXPR size_type find_first_not_of(const charT* s, size_type pos, size_type n) const | ||||
|         BOOST_CXX14_CONSTEXPR size_type find_first_not_of(const charT* s, size_type pos, size_type n) const BOOST_NOEXCEPT | ||||
|             { return find_first_not_of(basic_string_view(s, n), pos); } | ||||
|         BOOST_CXX14_CONSTEXPR size_type find_first_not_of(const charT* s, size_type pos = 0) const | ||||
|         BOOST_CXX14_CONSTEXPR size_type find_first_not_of(const charT* s, size_type pos = 0) const BOOST_NOEXCEPT | ||||
|             { return find_first_not_of(basic_string_view(s), pos); } | ||||
|  | ||||
|         //  find_last_not_of | ||||
|         BOOST_CXX14_CONSTEXPR size_type find_last_not_of(basic_string_view s, size_type pos = npos) const BOOST_NOEXCEPT { | ||||
|             if (pos >= len_) | ||||
|               pos = len_ - 1;; | ||||
|               pos = len_ - 1; | ||||
|             if (s.len_ == 0u) | ||||
|               return pos; | ||||
|             pos = len_ - (pos+1); | ||||
| @@ -315,27 +358,26 @@ namespace boost { | ||||
|             } | ||||
|         BOOST_CXX14_CONSTEXPR size_type find_last_not_of(charT c, size_type pos = npos) const BOOST_NOEXCEPT | ||||
|             { return find_last_not_of(basic_string_view(&c, 1), pos); } | ||||
|         BOOST_CXX14_CONSTEXPR size_type find_last_not_of(const charT* s, size_type pos, size_type n) const | ||||
|         BOOST_CXX14_CONSTEXPR size_type find_last_not_of(const charT* s, size_type pos, size_type n) const BOOST_NOEXCEPT | ||||
|             { return find_last_not_of(basic_string_view(s, n), pos); } | ||||
|         BOOST_CXX14_CONSTEXPR size_type find_last_not_of(const charT* s, size_type pos = npos) const | ||||
|         BOOST_CXX14_CONSTEXPR size_type find_last_not_of(const charT* s, size_type pos = npos) const BOOST_NOEXCEPT | ||||
|             { return find_last_not_of(basic_string_view(s), pos); } | ||||
|  | ||||
|     private: | ||||
|         template <typename r_iter> | ||||
|         size_type reverse_distance ( r_iter first, r_iter last ) const { | ||||
|         size_type reverse_distance(r_iter first, r_iter last) const BOOST_NOEXCEPT { | ||||
|         // Portability note here: std::distance is not NOEXCEPT, but calling it with a string_view::reverse_iterator will not throw. | ||||
|             return len_ - 1 - std::distance ( first, last ); | ||||
|             } | ||||
|  | ||||
|         template <typename Iterator> | ||||
|         Iterator find_not_of ( Iterator first, Iterator last, basic_string_view s ) const { | ||||
|             for ( ; first != last ; ++first ) | ||||
|                 if ( 0 == traits::find ( s.ptr_, s.len_, *first )) | ||||
|         Iterator find_not_of(Iterator first, Iterator last, basic_string_view s) const BOOST_NOEXCEPT { | ||||
|             for (; first != last ; ++first) | ||||
|                 if ( 0 == traits::find(s.ptr_, s.len_, *first)) | ||||
|                     return first; | ||||
|             return last; | ||||
|             } | ||||
|  | ||||
|  | ||||
|  | ||||
|         const charT *ptr_; | ||||
|         std::size_t len_; | ||||
|         }; | ||||
| @@ -344,240 +386,199 @@ namespace boost { | ||||
| //  Comparison operators | ||||
| //  Equality | ||||
|     template<typename charT, typename traits> | ||||
|     inline bool operator==(basic_string_view<charT, traits> x, | ||||
|       basic_string_view<charT, traits> y) BOOST_NOEXCEPT { | ||||
|         if ( x.size () != y.size ()) return false; | ||||
|     inline BOOST_CXX14_CONSTEXPR bool operator==(basic_string_view<charT, traits> x, | ||||
|                            basic_string_view<charT, traits> y) BOOST_NOEXCEPT { | ||||
|         if (x.size () != y.size ()) return false; | ||||
|         return x.compare(y) == 0; | ||||
|         } | ||||
|  | ||||
| //  Inequality | ||||
|     template<typename charT, typename traits> | ||||
|     inline bool operator!=(basic_string_view<charT, traits> x, | ||||
|       basic_string_view<charT, traits> y) BOOST_NOEXCEPT {  | ||||
|     inline BOOST_CXX14_CONSTEXPR bool operator!=(basic_string_view<charT, traits> x, | ||||
|                            basic_string_view<charT, traits> y) BOOST_NOEXCEPT { | ||||
|         if ( x.size () != y.size ()) return true; | ||||
|         return x.compare(y) != 0; | ||||
|         } | ||||
|  | ||||
| //  Less than | ||||
|     template<typename charT, typename traits> | ||||
|     inline bool operator<(basic_string_view<charT, traits> x, | ||||
|       basic_string_view<charT, traits> y) BOOST_NOEXCEPT {  | ||||
|     inline BOOST_CXX14_CONSTEXPR bool operator<(basic_string_view<charT, traits> x, | ||||
|                           basic_string_view<charT, traits> y) BOOST_NOEXCEPT { | ||||
|         return x.compare(y) < 0; | ||||
|         } | ||||
|  | ||||
| //  Greater than | ||||
|     template<typename charT, typename traits> | ||||
|     inline bool operator>(basic_string_view<charT, traits> x, | ||||
|       basic_string_view<charT, traits> y) BOOST_NOEXCEPT {  | ||||
|     inline BOOST_CXX14_CONSTEXPR bool operator>(basic_string_view<charT, traits> x, | ||||
|                           basic_string_view<charT, traits> y) BOOST_NOEXCEPT { | ||||
|         return x.compare(y) > 0; | ||||
|         } | ||||
|  | ||||
| //  Less than or equal to | ||||
|     template<typename charT, typename traits> | ||||
|     inline bool operator<=(basic_string_view<charT, traits> x, | ||||
|       basic_string_view<charT, traits> y) BOOST_NOEXCEPT {  | ||||
|     inline BOOST_CXX14_CONSTEXPR bool operator<=(basic_string_view<charT, traits> x, | ||||
|                            basic_string_view<charT, traits> y) BOOST_NOEXCEPT { | ||||
|         return x.compare(y) <= 0; | ||||
|         } | ||||
|  | ||||
| //  Greater than or equal to | ||||
|     template<typename charT, typename traits> | ||||
|     inline bool operator>=(basic_string_view<charT, traits> x, | ||||
|       basic_string_view<charT, traits> y) BOOST_NOEXCEPT {  | ||||
|     inline BOOST_CXX14_CONSTEXPR bool operator>=(basic_string_view<charT, traits> x, | ||||
|                            basic_string_view<charT, traits> y) BOOST_NOEXCEPT { | ||||
|         return x.compare(y) >= 0; | ||||
|         } | ||||
|  | ||||
| // "sufficient additional overloads of comparison functions" | ||||
|     template<typename charT, typename traits, typename Allocator> | ||||
|     inline bool operator==(basic_string_view<charT, traits> x, | ||||
|       const std::basic_string<charT, traits, Allocator> & y) BOOST_NOEXCEPT {  | ||||
|     inline BOOST_CXX14_CONSTEXPR bool operator==(basic_string_view<charT, traits> x, | ||||
|                      const std::basic_string<charT, traits, Allocator> & y) BOOST_NOEXCEPT { | ||||
|         return x == basic_string_view<charT, traits>(y); | ||||
|         } | ||||
|  | ||||
|     template<typename charT, typename traits, typename Allocator> | ||||
|     inline bool operator==(const std::basic_string<charT, traits, Allocator> & x, | ||||
|       basic_string_view<charT, traits> y) BOOST_NOEXCEPT {  | ||||
|     inline BOOST_CXX14_CONSTEXPR bool operator==(const std::basic_string<charT, traits, Allocator> & x, | ||||
|                                  basic_string_view<charT, traits> y) BOOST_NOEXCEPT { | ||||
|         return basic_string_view<charT, traits>(x) == y; | ||||
|         } | ||||
|  | ||||
|     template<typename charT, typename traits> | ||||
|     inline bool operator==(basic_string_view<charT, traits> x, | ||||
|       const charT * y) BOOST_NOEXCEPT {  | ||||
|     inline BOOST_CXX14_CONSTEXPR bool operator==(basic_string_view<charT, traits> x, | ||||
|                                               const charT * y) BOOST_NOEXCEPT { | ||||
|         return x == basic_string_view<charT, traits>(y); | ||||
|         } | ||||
|  | ||||
|     template<typename charT, typename traits> | ||||
|     inline bool operator==(const charT * x, | ||||
|       basic_string_view<charT, traits> y) BOOST_NOEXCEPT {  | ||||
|     inline BOOST_CXX14_CONSTEXPR bool operator==(const charT * x, | ||||
|                            basic_string_view<charT, traits> y) BOOST_NOEXCEPT { | ||||
|         return basic_string_view<charT, traits>(x) == y; | ||||
|         } | ||||
|  | ||||
|     template<typename charT, typename traits, typename Allocator> | ||||
|     inline bool operator!=(basic_string_view<charT, traits> x, | ||||
|       const std::basic_string<charT, traits, Allocator> & y) BOOST_NOEXCEPT {  | ||||
|     inline BOOST_CXX14_CONSTEXPR bool operator!=(basic_string_view<charT, traits> x, | ||||
|                      const std::basic_string<charT, traits, Allocator> & y) BOOST_NOEXCEPT { | ||||
|         return x != basic_string_view<charT, traits>(y); | ||||
|         } | ||||
|  | ||||
|     template<typename charT, typename traits, typename Allocator> | ||||
|     inline bool operator!=(const std::basic_string<charT, traits, Allocator> & x, | ||||
|       basic_string_view<charT, traits> y) BOOST_NOEXCEPT {  | ||||
|     inline BOOST_CXX14_CONSTEXPR bool operator!=(const std::basic_string<charT, traits, Allocator> & x, | ||||
|                                  basic_string_view<charT, traits> y) BOOST_NOEXCEPT { | ||||
|         return basic_string_view<charT, traits>(x) != y; | ||||
|         } | ||||
|  | ||||
|     template<typename charT, typename traits> | ||||
|     inline bool operator!=(basic_string_view<charT, traits> x, | ||||
|       const charT * y) BOOST_NOEXCEPT {  | ||||
|     inline BOOST_CXX14_CONSTEXPR bool operator!=(basic_string_view<charT, traits> x, | ||||
|                            const charT * y) BOOST_NOEXCEPT { | ||||
|         return x != basic_string_view<charT, traits>(y); | ||||
|         } | ||||
|  | ||||
|     template<typename charT, typename traits> | ||||
|     inline bool operator!=(const charT * x, | ||||
|       basic_string_view<charT, traits> y) BOOST_NOEXCEPT {  | ||||
|     inline BOOST_CXX14_CONSTEXPR bool operator!=(const charT * x, | ||||
|                            basic_string_view<charT, traits> y) BOOST_NOEXCEPT { | ||||
|         return basic_string_view<charT, traits>(x) != y; | ||||
|         } | ||||
|  | ||||
|     template<typename charT, typename traits, typename Allocator> | ||||
|     inline bool operator<(basic_string_view<charT, traits> x, | ||||
|       const std::basic_string<charT, traits, Allocator> & y) BOOST_NOEXCEPT {  | ||||
|     inline BOOST_CXX14_CONSTEXPR bool operator<(basic_string_view<charT, traits> x, | ||||
|                     const std::basic_string<charT, traits, Allocator> & y) BOOST_NOEXCEPT { | ||||
|         return x < basic_string_view<charT, traits>(y); | ||||
|         } | ||||
|  | ||||
|     template<typename charT, typename traits, typename Allocator> | ||||
|     inline bool operator<(const std::basic_string<charT, traits, Allocator> & x, | ||||
|       basic_string_view<charT, traits> y) BOOST_NOEXCEPT {  | ||||
|     inline BOOST_CXX14_CONSTEXPR bool operator<(const std::basic_string<charT, traits, Allocator> & x, | ||||
|                                 basic_string_view<charT, traits> y) BOOST_NOEXCEPT { | ||||
|         return basic_string_view<charT, traits>(x) < y; | ||||
|         } | ||||
|  | ||||
|     template<typename charT, typename traits> | ||||
|     inline bool operator<(basic_string_view<charT, traits> x, | ||||
|       const charT * y) BOOST_NOEXCEPT {  | ||||
|     inline BOOST_CXX14_CONSTEXPR bool operator<(basic_string_view<charT, traits> x, | ||||
|                           const charT * y) BOOST_NOEXCEPT { | ||||
|         return x < basic_string_view<charT, traits>(y); | ||||
|         } | ||||
|  | ||||
|     template<typename charT, typename traits> | ||||
|     inline bool operator<(const charT * x, | ||||
|       basic_string_view<charT, traits> y) BOOST_NOEXCEPT {  | ||||
|     inline BOOST_CXX14_CONSTEXPR bool operator<(const charT * x, | ||||
|                           basic_string_view<charT, traits> y) BOOST_NOEXCEPT { | ||||
|         return basic_string_view<charT, traits>(x) < y; | ||||
|         } | ||||
|  | ||||
|     template<typename charT, typename traits, typename Allocator> | ||||
|     inline bool operator>(basic_string_view<charT, traits> x, | ||||
|       const std::basic_string<charT, traits, Allocator> & y) BOOST_NOEXCEPT {  | ||||
|     inline BOOST_CXX14_CONSTEXPR bool operator>(basic_string_view<charT, traits> x, | ||||
|                     const std::basic_string<charT, traits, Allocator> & y) BOOST_NOEXCEPT { | ||||
|         return x > basic_string_view<charT, traits>(y); | ||||
|         } | ||||
|  | ||||
|     template<typename charT, typename traits, typename Allocator> | ||||
|     inline bool operator>(const std::basic_string<charT, traits, Allocator> & x, | ||||
|       basic_string_view<charT, traits> y) BOOST_NOEXCEPT {  | ||||
|     inline BOOST_CXX14_CONSTEXPR bool operator>(const std::basic_string<charT, traits, Allocator> & x, | ||||
|                                 basic_string_view<charT, traits> y) BOOST_NOEXCEPT { | ||||
|         return basic_string_view<charT, traits>(x) > y; | ||||
|         } | ||||
|  | ||||
|     template<typename charT, typename traits> | ||||
|     inline bool operator>(basic_string_view<charT, traits> x, | ||||
|       const charT * y) BOOST_NOEXCEPT {  | ||||
|     inline BOOST_CXX14_CONSTEXPR bool operator>(basic_string_view<charT, traits> x, | ||||
|                           const charT * y) BOOST_NOEXCEPT { | ||||
|         return x > basic_string_view<charT, traits>(y); | ||||
|         } | ||||
|  | ||||
|     template<typename charT, typename traits> | ||||
|     inline bool operator>(const charT * x, | ||||
|       basic_string_view<charT, traits> y) BOOST_NOEXCEPT {  | ||||
|     inline BOOST_CXX14_CONSTEXPR bool operator>(const charT * x, | ||||
|                           basic_string_view<charT, traits> y) BOOST_NOEXCEPT { | ||||
|         return basic_string_view<charT, traits>(x) > y; | ||||
|         } | ||||
|  | ||||
|     template<typename charT, typename traits, typename Allocator> | ||||
|     inline bool operator<=(basic_string_view<charT, traits> x, | ||||
|       const std::basic_string<charT, traits, Allocator> & y) BOOST_NOEXCEPT {  | ||||
|     inline BOOST_CXX14_CONSTEXPR bool operator<=(basic_string_view<charT, traits> x, | ||||
|                      const std::basic_string<charT, traits, Allocator> & y) BOOST_NOEXCEPT { | ||||
|         return x <= basic_string_view<charT, traits>(y); | ||||
|         } | ||||
|  | ||||
|     template<typename charT, typename traits, typename Allocator> | ||||
|     inline bool operator<=(const std::basic_string<charT, traits, Allocator> & x, | ||||
|       basic_string_view<charT, traits> y) BOOST_NOEXCEPT {  | ||||
|     inline BOOST_CXX14_CONSTEXPR bool operator<=(const std::basic_string<charT, traits, Allocator> & x, | ||||
|                                  basic_string_view<charT, traits> y) BOOST_NOEXCEPT { | ||||
|         return basic_string_view<charT, traits>(x) <= y; | ||||
|         } | ||||
|  | ||||
|     template<typename charT, typename traits> | ||||
|     inline bool operator<=(basic_string_view<charT, traits> x, | ||||
|       const charT * y) BOOST_NOEXCEPT {  | ||||
|     inline BOOST_CXX14_CONSTEXPR bool operator<=(basic_string_view<charT, traits> x, | ||||
|                            const charT * y) BOOST_NOEXCEPT { | ||||
|         return x <= basic_string_view<charT, traits>(y); | ||||
|         } | ||||
|  | ||||
|     template<typename charT, typename traits> | ||||
|     inline bool operator<=(const charT * x, | ||||
|       basic_string_view<charT, traits> y) BOOST_NOEXCEPT {  | ||||
|     inline BOOST_CXX14_CONSTEXPR bool operator<=(const charT * x, | ||||
|                            basic_string_view<charT, traits> y) BOOST_NOEXCEPT { | ||||
|         return basic_string_view<charT, traits>(x) <= y; | ||||
|         } | ||||
|  | ||||
|     template<typename charT, typename traits, typename Allocator> | ||||
|     inline bool operator>=(basic_string_view<charT, traits> x, | ||||
|       const std::basic_string<charT, traits, Allocator> & y) BOOST_NOEXCEPT {  | ||||
|     inline BOOST_CXX14_CONSTEXPR bool operator>=(basic_string_view<charT, traits> x, | ||||
|                      const std::basic_string<charT, traits, Allocator> & y) BOOST_NOEXCEPT { | ||||
|         return x >= basic_string_view<charT, traits>(y); | ||||
|         } | ||||
|  | ||||
|     template<typename charT, typename traits, typename Allocator> | ||||
|     inline bool operator>=(const std::basic_string<charT, traits, Allocator> & x, | ||||
|       basic_string_view<charT, traits> y) BOOST_NOEXCEPT {  | ||||
|     inline BOOST_CXX14_CONSTEXPR bool operator>=(const std::basic_string<charT, traits, Allocator> & x, | ||||
|                                  basic_string_view<charT, traits> y) BOOST_NOEXCEPT { | ||||
|         return basic_string_view<charT, traits>(x) >= y; | ||||
|         } | ||||
|  | ||||
|     template<typename charT, typename traits> | ||||
|     inline bool operator>=(basic_string_view<charT, traits> x, | ||||
|       const charT * y) BOOST_NOEXCEPT {  | ||||
|     inline BOOST_CXX14_CONSTEXPR bool operator>=(basic_string_view<charT, traits> x, | ||||
|                            const charT * y) BOOST_NOEXCEPT { | ||||
|         return x >= basic_string_view<charT, traits>(y); | ||||
|         } | ||||
|  | ||||
|     template<typename charT, typename traits> | ||||
|     inline bool operator>=(const charT * x, | ||||
|       basic_string_view<charT, traits> y) BOOST_NOEXCEPT {  | ||||
|     inline BOOST_CXX14_CONSTEXPR bool operator>=(const charT * x, | ||||
|                            basic_string_view<charT, traits> y) BOOST_NOEXCEPT { | ||||
|         return basic_string_view<charT, traits>(x) >= y; | ||||
|         } | ||||
|  | ||||
|     namespace detail { | ||||
|  | ||||
|         template<class charT, class traits> | ||||
|         inline void insert_fill_chars(std::basic_ostream<charT, traits>& os, std::size_t n) { | ||||
|             enum { chunk_size = 8 }; | ||||
|             charT fill_chars[chunk_size]; | ||||
|             std::fill_n(fill_chars, static_cast< std::size_t >(chunk_size), os.fill()); | ||||
|             for (; n >= chunk_size && os.good(); n -= chunk_size) | ||||
|                 os.write(fill_chars, static_cast< std::size_t >(chunk_size)); | ||||
|             if (n > 0 && os.good()) | ||||
|                 os.write(fill_chars, n); | ||||
|             } | ||||
|  | ||||
|         template<class charT, class traits> | ||||
|         void insert_aligned(std::basic_ostream<charT, traits>& os, const basic_string_view<charT,traits>& str) { | ||||
|             const std::size_t size = str.size(); | ||||
|             const std::size_t alignment_size = static_cast< std::size_t >(os.width()) - size; | ||||
|             const bool align_left = (os.flags() & std::basic_ostream<charT, traits>::adjustfield) == std::basic_ostream<charT, traits>::left; | ||||
|             if (!align_left) { | ||||
|                 detail::insert_fill_chars(os, alignment_size); | ||||
|                 if (os.good()) | ||||
|                     os.write(str.data(), size); | ||||
|                 } | ||||
|             else { | ||||
|                 os.write(str.data(), size); | ||||
|                 if (os.good()) | ||||
|                     detail::insert_fill_chars(os, alignment_size); | ||||
|                 } | ||||
|             } | ||||
|  | ||||
|         } // namespace detail | ||||
|  | ||||
|     // Inserter | ||||
|     template<class charT, class traits> | ||||
|     inline std::basic_ostream<charT, traits>& | ||||
|     operator<<(std::basic_ostream<charT, traits>& os, | ||||
|       const basic_string_view<charT,traits>& str) { | ||||
|         if (os.good()) { | ||||
|             const std::size_t size = str.size(); | ||||
|             const std::size_t w = static_cast< std::size_t >(os.width()); | ||||
|             if (w <= size) | ||||
|                 os.write(str.data(), size); | ||||
|             else | ||||
|                 detail::insert_aligned(os, str); | ||||
|             os.width(0); | ||||
|             } | ||||
|         return os; | ||||
|         return boost::ostream_string(os, str.data(), str.size()); | ||||
|         } | ||||
|  | ||||
| #if 0 | ||||
| @@ -651,6 +652,10 @@ namespace boost { | ||||
|         } | ||||
| #endif | ||||
|  | ||||
|     template <class charT, class traits> | ||||
|     std::size_t hash_value(basic_string_view<charT, traits> s) { | ||||
|         return boost::hash_range(s.begin(), s.end()); | ||||
|         } | ||||
| } | ||||
|  | ||||
| #if 0 | ||||
|   | ||||
| @@ -20,17 +20,18 @@ | ||||
| 				<a href="call_traits.htm">call_traits</a><br> | ||||
| 				<a href="../core/doc/html/core/checked_delete.html">checked_delete</a> (moved to the Boost.Core library)<br> | ||||
| 				<a href="doc/html/compressed_pair.html">compressed_pair</a><br> | ||||
| 				<a href="doc/html/declval.html">declval</a><br> | ||||
| 				<a href="../type_traits/doc/html/boost_typetraits/reference/declval.html">declval</a> (moved to the Boost.TypeTraits library)<br> | ||||
| 				<a href="../core/doc/html/core/enable_if.html">enable_if</a> (moved to the Boost.Core library)<br> | ||||
| 				<a href="in_place_factories.html">in_place_factory</a><br> | ||||
| 				<a href="iterator_adaptors.htm">iterator_adaptors</a><br> | ||||
| 				<a href="generator_iterator.htm">generator iterator adaptors</a><br> | ||||
| 				<a href="utility.htm#functions_next_prior">next/prior</a><br> | ||||
| 				<a href="../iterator/doc/generator_iterator.htm">generator iterator adaptors</a> (moved to the Boost.Iterator library)<br> | ||||
| 				<a href="../iterator/doc/html/iterator/algorithms/next_prior.html">next/prior</a> (moved to the Boost.Iterator library)<br> | ||||
| 				<a href="../core/doc/html/core/noncopyable.html">noncopyable</a> (moved to the Boost.Core library)<br> | ||||
| 				<a href="operators.htm">operators</a><br> | ||||
| 				<a href="utility.htm#result_of">result_of</a><br> | ||||
| 				<a href="throw_exception.html">throw_exception</a><br> | ||||
| 				<a href="utility.htm">utility</a><br> | ||||
|             <a href="doc/html/ostream_string.html">ostream_string</a><br> | ||||
|             <a href="doc/html/string_ref.html">string_ref</a><br> | ||||
|             <a href="value_init.htm">value_init</a><br> | ||||
|          </p> | ||||
|   | ||||
| @@ -1,406 +0,0 @@ | ||||
| //  (C) Copyright David Abrahams 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) | ||||
|  | ||||
| //  See http://www.boost.org for most recent version including documentation. | ||||
|  | ||||
| //  Revision History | ||||
| //  1  Apr 2001 Fixes for ICL; use BOOST_STATIC_CONSTANT | ||||
| //  11 Feb 2001 Fixes for Borland (David Abrahams) | ||||
| //  23 Jan 2001 Added test for wchar_t (David Abrahams) | ||||
| //  23 Jan 2001 Now statically selecting a test for signed numbers to avoid | ||||
| //              warnings with fancy compilers. Added commentary and | ||||
| //              additional dumping of traits data for tested types (David | ||||
| //              Abrahams). | ||||
| //  21 Jan 2001 Initial version (David Abrahams) | ||||
|  | ||||
| #include <boost/detail/numeric_traits.hpp> | ||||
| #include <cassert> | ||||
| #include <boost/type_traits.hpp> | ||||
| #include <boost/static_assert.hpp> | ||||
| #include <boost/cstdint.hpp> | ||||
| #include <boost/utility.hpp> | ||||
| #include <boost/lexical_cast.hpp> | ||||
| #include <climits> | ||||
| #include <typeinfo> | ||||
| #include <iostream> | ||||
| #include <string> | ||||
| #ifndef BOOST_NO_LIMITS | ||||
| # include <limits> | ||||
| #endif | ||||
|  | ||||
| // ================================================================================= | ||||
| // template class complement_traits<Number> -- | ||||
| // | ||||
| //    statically computes the max and min for 1s and 2s-complement binary | ||||
| //    numbers. This helps on platforms without <limits> support. It also shows | ||||
| //    an example of a recursive template that works with MSVC! | ||||
| // | ||||
|  | ||||
| template <unsigned size> struct complement; // forward | ||||
|  | ||||
| // The template complement, below, does all the real work, using "poor man's | ||||
| // partial specialization". We need complement_traits_aux<> so that MSVC doesn't | ||||
| // complain about undefined min/max as we're trying to recursively define them.  | ||||
| template <class Number, unsigned size> | ||||
| struct complement_traits_aux | ||||
| { | ||||
|     BOOST_STATIC_CONSTANT(Number, max = complement<size>::template traits<Number>::max); | ||||
|     BOOST_STATIC_CONSTANT(Number, min = complement<size>::template traits<Number>::min); | ||||
| }; | ||||
|  | ||||
| template <unsigned size> | ||||
| struct complement | ||||
| { | ||||
|     template <class Number> | ||||
|     struct traits | ||||
|     { | ||||
|      private: | ||||
|         // indirection through complement_traits_aux necessary to keep MSVC happy | ||||
|         typedef complement_traits_aux<Number, size - 1> prev; | ||||
|      public: | ||||
| #if defined(__GNUC__) && __GNUC__ == 4 && __GNUC_MINOR__ == 0 && __GNUC_PATCHLEVEL__ == 2 | ||||
|         // GCC 4.0.2 ICEs on these C-style casts | ||||
|         BOOST_STATIC_CONSTANT(Number, max = | ||||
|                             Number((prev::max) << CHAR_BIT) | ||||
|                             + Number(UCHAR_MAX)); | ||||
|         BOOST_STATIC_CONSTANT(Number, min = Number((prev::min) << CHAR_BIT)); | ||||
| #else | ||||
|         // Avoid left shifting negative integers, use multiplication instead | ||||
|         BOOST_STATIC_CONSTANT(Number, shift = 1u << CHAR_BIT); | ||||
|         BOOST_STATIC_CONSTANT(Number, max = | ||||
|                             Number(Number(prev::max) * shift) | ||||
|                             + Number(UCHAR_MAX)); | ||||
|         BOOST_STATIC_CONSTANT(Number, min = Number(Number(prev::min) * shift)); | ||||
| #endif | ||||
|     }; | ||||
| }; | ||||
|  | ||||
| // Template class complement_base<> -- defines values for min and max for | ||||
| // complement<1>, at the deepest level of recursion. Uses "poor man's partial | ||||
| // specialization" again. | ||||
| template <bool is_signed> struct complement_base; | ||||
|  | ||||
| template <> struct complement_base<false> | ||||
| { | ||||
|     template <class Number> | ||||
|     struct values | ||||
|     { | ||||
|         BOOST_STATIC_CONSTANT(Number, min = 0); | ||||
|         BOOST_STATIC_CONSTANT(Number, max = UCHAR_MAX); | ||||
|     }; | ||||
| }; | ||||
|  | ||||
| template <> struct complement_base<true> | ||||
| { | ||||
|     template <class Number> | ||||
|     struct values | ||||
|     { | ||||
|         BOOST_STATIC_CONSTANT(Number, min = SCHAR_MIN); | ||||
|         BOOST_STATIC_CONSTANT(Number, max = SCHAR_MAX); | ||||
|     }; | ||||
| }; | ||||
|  | ||||
| // Base specialization of complement, puts an end to the recursion. | ||||
| template <> | ||||
| struct complement<1> | ||||
| { | ||||
|     template <class Number> | ||||
|     struct traits | ||||
|     { | ||||
|         BOOST_STATIC_CONSTANT(bool, is_signed = boost::detail::is_signed<Number>::value); | ||||
|         BOOST_STATIC_CONSTANT(Number, min = | ||||
|                             complement_base<is_signed>::template values<Number>::min); | ||||
|         BOOST_STATIC_CONSTANT(Number, max = | ||||
|                             complement_base<is_signed>::template values<Number>::max); | ||||
|     }; | ||||
| }; | ||||
|  | ||||
| // Now here's the "pretty" template you're intended to actually use. | ||||
| //   complement_traits<Number>::min, complement_traits<Number>::max are the | ||||
| //   minimum and maximum values of Number if Number is a built-in integer type. | ||||
| template <class Number> | ||||
| struct complement_traits | ||||
| { | ||||
|     BOOST_STATIC_CONSTANT(Number, max = (complement_traits_aux<Number, sizeof(Number)>::max)); | ||||
|     BOOST_STATIC_CONSTANT(Number, min = (complement_traits_aux<Number, sizeof(Number)>::min)); | ||||
| }; | ||||
|  | ||||
| // ================================================================================= | ||||
|  | ||||
| // Support for streaming various numeric types in exactly the format I want. I | ||||
| // needed this in addition to all the assertions so that I could see exactly | ||||
| // what was going on. | ||||
| // | ||||
| // Numbers go through a 2-stage conversion process (by default, though, no real | ||||
| // conversion). | ||||
| // | ||||
| template <class T> struct stream_as { | ||||
|     typedef T t1; | ||||
|     typedef T t2; | ||||
| }; | ||||
|  | ||||
| // char types first get converted to unsigned char, then to unsigned. | ||||
| template <> struct stream_as<char> { | ||||
|     typedef unsigned char t1; | ||||
|     typedef unsigned t2; | ||||
| }; | ||||
| template <> struct stream_as<unsigned char> { | ||||
|     typedef unsigned char t1; typedef unsigned t2; | ||||
| }; | ||||
| template <> struct stream_as<signed char>  { | ||||
|     typedef unsigned char t1; typedef unsigned t2; | ||||
| }; | ||||
|  | ||||
| #if defined(BOOST_MSVC_STD_ITERATOR) // No intmax streaming built-in | ||||
|  | ||||
| // With this library implementation, __int64 and __uint64 get streamed as strings | ||||
| template <> struct stream_as<boost::uintmax_t> { | ||||
|     typedef std::string t1; | ||||
|     typedef std::string t2; | ||||
| }; | ||||
|  | ||||
| template <> struct stream_as<boost::intmax_t>  { | ||||
|     typedef std::string t1; | ||||
|     typedef std::string t2; | ||||
| }; | ||||
| #endif | ||||
|  | ||||
| // Standard promotion process for streaming | ||||
| template <class T> struct promote | ||||
| { | ||||
|     static typename stream_as<T>::t1 from(T x) { | ||||
|         typedef typename stream_as<T>::t1 t1; | ||||
|         return t1(x); | ||||
|     } | ||||
| }; | ||||
|  | ||||
| #if defined(BOOST_MSVC_STD_ITERATOR) // No intmax streaming built-in | ||||
|  | ||||
| // On this platform, stream them as long/unsigned long if they fit. | ||||
| // Otherwise, write a string. | ||||
| template <> struct promote<boost::uintmax_t> { | ||||
|     std::string static from(const boost::uintmax_t x) { | ||||
|         if (x > ULONG_MAX) | ||||
|             return std::string("large unsigned value"); | ||||
|         else | ||||
|             return boost::lexical_cast<std::string>((unsigned long)x); | ||||
|     } | ||||
| }; | ||||
| template <> struct promote<boost::intmax_t> { | ||||
|     std::string static from(const boost::intmax_t x) { | ||||
|         if (x > boost::intmax_t(ULONG_MAX)) | ||||
|             return std::string("large positive signed value"); | ||||
|         else if (x >= 0) | ||||
|             return boost::lexical_cast<std::string>((unsigned long)x); | ||||
|          | ||||
|         if (x < boost::intmax_t(LONG_MIN)) | ||||
|             return std::string("large negative signed value"); | ||||
|         else | ||||
|             return boost::lexical_cast<std::string>((long)x); | ||||
|     } | ||||
| }; | ||||
| #endif | ||||
|  | ||||
| // This is the function which converts types to the form I want to stream them in. | ||||
| template <class T> | ||||
| typename stream_as<T>::t2 stream_number(T x) | ||||
| { | ||||
|     return promote<T>::from(x); | ||||
| } | ||||
| // ================================================================================= | ||||
|  | ||||
| // | ||||
| // Tests for built-in signed and unsigned types | ||||
| // | ||||
|  | ||||
| // Tag types for selecting tests | ||||
| struct unsigned_tag {}; | ||||
| struct signed_tag {}; | ||||
|  | ||||
| // Tests for unsigned numbers. The extra default Number parameter works around | ||||
| // an MSVC bug. | ||||
| template <class Number> | ||||
| void test_aux(unsigned_tag, Number*) | ||||
| { | ||||
|     typedef typename boost::detail::numeric_traits<Number>::difference_type difference_type; | ||||
|     BOOST_STATIC_ASSERT(!boost::detail::is_signed<Number>::value); | ||||
|     BOOST_STATIC_ASSERT( | ||||
|         (sizeof(Number) < sizeof(boost::intmax_t)) | ||||
|         | (boost::is_same<difference_type, boost::intmax_t>::value)); | ||||
|  | ||||
| #if defined(__GNUC__) && __GNUC__ == 4 && __GNUC_MINOR__ == 0 && __GNUC_PATCHLEVEL__ == 2 | ||||
|     // GCC 4.0.2 ICEs on this C-style cases | ||||
|     BOOST_STATIC_ASSERT((complement_traits<Number>::max) > Number(0)); | ||||
|     BOOST_STATIC_ASSERT((complement_traits<Number>::min) == Number(0)); | ||||
| #else | ||||
|     // Force casting to Number here to work around the fact that it's an enum on MSVC | ||||
|     BOOST_STATIC_ASSERT(Number(complement_traits<Number>::max) > Number(0)); | ||||
|     BOOST_STATIC_ASSERT(Number(complement_traits<Number>::min) == Number(0)); | ||||
| #endif | ||||
|  | ||||
|     const Number max = complement_traits<Number>::max; | ||||
|     const Number min = complement_traits<Number>::min; | ||||
|      | ||||
|     const Number test_max = (sizeof(Number) < sizeof(boost::intmax_t)) | ||||
|         ? max | ||||
|         : max / 2 - 1; | ||||
|  | ||||
|     std::cout << std::hex << "(unsigned) min = " << stream_number(min) << ", max = " | ||||
|               << stream_number(max) << "..." << std::flush; | ||||
|     std::cout << "difference_type = " << typeid(difference_type).name() << "..." | ||||
|               << std::flush; | ||||
|      | ||||
|     difference_type d1 = boost::detail::numeric_distance(Number(0), test_max); | ||||
|     difference_type d2 = boost::detail::numeric_distance(test_max, Number(0)); | ||||
|      | ||||
|     std::cout << "0->" << stream_number(test_max) << "==" << std::dec << stream_number(d1) << "; " | ||||
|               << std::hex << stream_number(test_max) << "->0==" << std::dec << stream_number(d2) << "..." << std::flush; | ||||
|  | ||||
|     assert(d1 == difference_type(test_max)); | ||||
|     assert(d2 == -difference_type(test_max)); | ||||
| } | ||||
|  | ||||
| // Tests for signed numbers. The extra default Number parameter works around an | ||||
| // MSVC bug. | ||||
| struct out_of_range_tag {}; | ||||
| struct in_range_tag {}; | ||||
|  | ||||
| // This test morsel gets executed for numbers whose difference will always be | ||||
| // representable in intmax_t | ||||
| template <class Number> | ||||
| void signed_test(in_range_tag, Number*) | ||||
| { | ||||
|     BOOST_STATIC_ASSERT(boost::detail::is_signed<Number>::value); | ||||
|     typedef typename boost::detail::numeric_traits<Number>::difference_type difference_type; | ||||
|     const Number max = complement_traits<Number>::max; | ||||
|     const Number min = complement_traits<Number>::min; | ||||
|      | ||||
|     difference_type d1 = boost::detail::numeric_distance(min, max); | ||||
|     difference_type d2 = boost::detail::numeric_distance(max, min); | ||||
|  | ||||
|     std::cout << stream_number(min) << "->" << stream_number(max) << "=="; | ||||
|     std::cout << std::dec << stream_number(d1) << "; "; | ||||
|     std::cout << std::hex << stream_number(max) << "->" << stream_number(min) | ||||
|               << "==" << std::dec << stream_number(d2) << "..." << std::flush; | ||||
|     assert(d1 == difference_type(max) - difference_type(min)); | ||||
|     assert(d2 == difference_type(min) - difference_type(max)); | ||||
| } | ||||
|  | ||||
| // This test morsel gets executed for numbers whose difference may exceed the | ||||
| // capacity of intmax_t. | ||||
| template <class Number> | ||||
| void signed_test(out_of_range_tag, Number*) | ||||
| { | ||||
|     BOOST_STATIC_ASSERT(boost::detail::is_signed<Number>::value); | ||||
|     typedef typename boost::detail::numeric_traits<Number>::difference_type difference_type; | ||||
|     const Number max = complement_traits<Number>::max; | ||||
|     const Number min = complement_traits<Number>::min; | ||||
|  | ||||
|     difference_type min_distance = complement_traits<difference_type>::min; | ||||
|     difference_type max_distance = complement_traits<difference_type>::max; | ||||
|  | ||||
|     const Number n1 = Number(min + max_distance); | ||||
|     const Number n2 = Number(max + min_distance); | ||||
|     difference_type d1 = boost::detail::numeric_distance(min, n1); | ||||
|     difference_type d2 = boost::detail::numeric_distance(max, n2); | ||||
|  | ||||
|     std::cout << stream_number(min) << "->" << stream_number(n1) << "=="; | ||||
|     std::cout << std::dec << stream_number(d1) << "; "; | ||||
|     std::cout << std::hex << stream_number(max) << "->" << stream_number(n2) | ||||
|               << "==" << std::dec << stream_number(d2) << "..." << std::flush; | ||||
|     assert(d1 == max_distance); | ||||
|     assert(d2 == min_distance); | ||||
| } | ||||
|  | ||||
| template <class Number> | ||||
| void test_aux(signed_tag, Number*) | ||||
| { | ||||
|     typedef typename boost::detail::numeric_traits<Number>::difference_type difference_type; | ||||
|     BOOST_STATIC_ASSERT(boost::detail::is_signed<Number>::value); | ||||
|     BOOST_STATIC_ASSERT( | ||||
|         (sizeof(Number) < sizeof(boost::intmax_t)) | ||||
|         | (boost::is_same<difference_type, Number>::value)); | ||||
|  | ||||
| #if defined(__GNUC__) && __GNUC__ == 4 && __GNUC_MINOR__ == 0 && __GNUC_PATCHLEVEL__ == 2 | ||||
|     // GCC 4.0.2 ICEs on this cast | ||||
|     BOOST_STATIC_ASSERT((complement_traits<Number>::max) > Number(0)); | ||||
|     BOOST_STATIC_ASSERT((complement_traits<Number>::min) < Number(0)); | ||||
| #else | ||||
|     // Force casting to Number here to work around the fact that it's an enum on MSVC | ||||
|     BOOST_STATIC_ASSERT(Number(complement_traits<Number>::max) > Number(0)); | ||||
|     BOOST_STATIC_ASSERT(Number(complement_traits<Number>::min) < Number(0)); | ||||
| #endif     | ||||
|     const Number max = complement_traits<Number>::max; | ||||
|     const Number min = complement_traits<Number>::min; | ||||
|      | ||||
|     std::cout << std::hex << "min = " << stream_number(min) << ", max = " | ||||
|               << stream_number(max) << "..." << std::flush; | ||||
|     std::cout << "difference_type = " << typeid(difference_type).name() << "..." | ||||
|               << std::flush; | ||||
|  | ||||
|     typedef typename boost::detail::if_true< | ||||
|                           (sizeof(Number) < sizeof(boost::intmax_t))> | ||||
|                         ::template then< | ||||
|                           in_range_tag, | ||||
|                           out_of_range_tag | ||||
|                         >::type | ||||
|         range_tag; | ||||
|     signed_test<Number>(range_tag(), 0); | ||||
| } | ||||
|  | ||||
|  | ||||
| // Test for all numbers. The extra default Number parameter works around an MSVC | ||||
| // bug. | ||||
| template <class Number> | ||||
| void test(Number* = 0) | ||||
| { | ||||
|     std::cout << "testing " << typeid(Number).name() << ":\n" | ||||
| #ifndef BOOST_NO_LIMITS_COMPILE_TIME_CONSTANTS | ||||
|               << "is_signed: " << (std::numeric_limits<Number>::is_signed ? "true\n" : "false\n") | ||||
|               << "is_bounded: " << (std::numeric_limits<Number>::is_bounded ? "true\n" : "false\n") | ||||
|               << "digits: " << std::numeric_limits<Number>::digits << "\n" | ||||
| #endif | ||||
|               << "..." << std::flush; | ||||
|  | ||||
|     // factoring out difference_type for the assert below confused Borland :( | ||||
|     typedef boost::detail::is_signed< | ||||
| #if !defined(BOOST_MSVC) || BOOST_MSVC > 1300 | ||||
|         typename | ||||
| #endif | ||||
|         boost::detail::numeric_traits<Number>::difference_type | ||||
|         > is_signed; | ||||
|     BOOST_STATIC_ASSERT(is_signed::value); | ||||
|  | ||||
|     typedef typename boost::detail::if_true< | ||||
|         boost::detail::is_signed<Number>::value | ||||
|         >::template then<signed_tag, unsigned_tag>::type signedness; | ||||
|      | ||||
|     test_aux<Number>(signedness(), 0); | ||||
|     std::cout << "passed" << std::endl; | ||||
| } | ||||
|  | ||||
| int main() | ||||
| { | ||||
|     test<char>(); | ||||
|     test<unsigned char>(); | ||||
|     test<signed char>(); | ||||
|     test<wchar_t>(); | ||||
|     test<short>(); | ||||
|     test<unsigned short>(); | ||||
|     test<int>(); | ||||
|     test<unsigned int>(); | ||||
|     test<long>(); | ||||
|     test<unsigned long>(); | ||||
| #if defined(BOOST_HAS_LONG_LONG) && !defined(BOOST_NO_INTEGRAL_INT64_T) | ||||
|     test< ::boost::long_long_type>(); | ||||
|     test< ::boost::ulong_long_type>(); | ||||
| #elif defined(BOOST_MSVC) | ||||
|     // The problem of not having compile-time static class constants other than | ||||
|     // enums prevents this from working, since values get truncated. | ||||
|     // test<boost::uintmax_t>(); | ||||
|     // test<boost::intmax_t>(); | ||||
| #endif | ||||
|     return 0; | ||||
| } | ||||
| @@ -1586,7 +1586,7 @@ T operator+( T lhs, const T& rhs ) | ||||
|     <h3><a name="a_demo">Arithmetic Operators Demonstration</a> and Test | ||||
|     Program</h3> | ||||
|  | ||||
|     <p>The <cite><a href="operators_test.cpp">operators_test.cpp</a></cite> | ||||
|     <p>The <cite><a href="test/operators_test.cpp">operators_test.cpp</a></cite> | ||||
|     program demonstrates the use of the arithmetic operator templates, and | ||||
|     can also be used to verify correct operation. Check the compiler status | ||||
|     report for the test results with selected platforms.</p> | ||||
| @@ -1667,8 +1667,8 @@ T operator+( T lhs, const T& rhs ) | ||||
|  | ||||
|         <td><code>P operator->() const</code></td> | ||||
|  | ||||
|         <td><code>(&*i)</code>. Return convertible to | ||||
|         <code>P</code>.</td> | ||||
|         <td><code>*i</code>. Address of the returned value convertible | ||||
|         to <code>P</code>.</td> | ||||
|       </tr> | ||||
|  | ||||
|       <tr> | ||||
| @@ -1998,7 +1998,7 @@ struct function_output_iterator | ||||
|  | ||||
|     <h3><a name="i_demo">Iterator Demonstration</a> and Test Program</h3> | ||||
|  | ||||
|     <p>The <cite><a href="iterators_test.cpp">iterators_test.cpp</a></cite> | ||||
|     <p>The <cite><a href="test/iterators_test.cpp">iterators_test.cpp</a></cite> | ||||
|     program demonstrates the use of the iterator templates, and can also be | ||||
|     used to verify correct operation. The following is the custom iterator | ||||
|     defined in the test program. It demonstrates a correct (though trivial) | ||||
| @@ -2064,7 +2064,7 @@ public: | ||||
|       <dt><a href="http://www.boost.org/people/beman_dawes.html">Beman Dawes</a></dt> | ||||
|  | ||||
|       <dd>Contributed <cite><a href= | ||||
|       "operators_test.cpp">operators_test.cpp</a></cite>.</dd> | ||||
|       "test/operators_test.cpp">operators_test.cpp</a></cite>.</dd> | ||||
|  | ||||
|       <dt><a href="http://www.boost.org/people/daryle_walker.html">Daryle Walker</a></dt> | ||||
|  | ||||
|   | ||||
| @@ -1,322 +0,0 @@ | ||||
| <html> | ||||
|  | ||||
| <head> | ||||
| <meta http-equiv="Content-Type" content="text/html; charset=windows-1252"> | ||||
| <meta name="GENERATOR" content="Microsoft FrontPage 4.0"> | ||||
| <meta name="ProgId" content="FrontPage.Editor.Document"> | ||||
| <title>Shared Container Iterator Documentation</title> | ||||
| </head> | ||||
|  | ||||
| <body bgcolor="#FFFFFF" text="#000000"> | ||||
|  | ||||
| <img src="../../boost.png" alt="boost.png (6897 bytes)" | ||||
| align="center" width="277" height="86"> | ||||
|  | ||||
| <h1>Shared Container Iterator</h1> | ||||
|  | ||||
| Defined in header | ||||
| <a href="../../boost/shared_container_iterator.hpp">boost/shared_container_iterator.hpp</a> | ||||
|  | ||||
| <p> | ||||
| The purpose of the shared container iterator is to attach the lifetime | ||||
| of a container to the lifetime of its iterators. In other words, the | ||||
| container will not be deleted until after all its iterators are | ||||
| destroyed.  The shared container iterator is typically used to | ||||
| implement functions that return iterators over a range of objects that | ||||
| only need to exist for the lifetime of the iterators.  By returning a | ||||
| pair of shared iterators from a function, the callee can return a | ||||
| heap-allocated range of objects whose lifetime is automatically managed. | ||||
| <p> | ||||
| The shared container iterator augments an iterator over a shared | ||||
| container.  It maintains a reference count on the shared  | ||||
| container. If only shared container iterators hold references to | ||||
| the container, the container's lifetime will end when the last shared | ||||
| container iterator over it is destroyed.  In any case, the shared | ||||
| container is guaranteed to persist beyond the lifetime of all | ||||
| the iterators. In all other ways, the | ||||
| shared container iterator behaves the same as its base iterator. | ||||
|  | ||||
|  | ||||
| <h2>Synopsis</h2> | ||||
|  | ||||
| <pre> | ||||
| namespace boost { | ||||
|   template <typename <a href="http://www.sgi.com/tech/stl/Container.html">Container</a>> | ||||
|   class shared_container_iterator; | ||||
|  | ||||
|   template <typename <a href="http://www.sgi.com/tech/stl/Container.html">Container</a>> | ||||
|   shared_container_iterator<Container> | ||||
|   make_shared_container_iterator(typename Container::iterator base,  | ||||
|     boost::shared_ptr<Container> const& container); | ||||
|  | ||||
|   std::pair< | ||||
|     typename shared_container_iterator<Container>, | ||||
|     typename shared_container_iterator<Container> | ||||
|   > | ||||
|   make_shared_container_range(boost::shared_ptr<Container> const& container); | ||||
| } | ||||
| </pre> | ||||
|  | ||||
| <hr> | ||||
|  | ||||
| <h2><a name="generator">The Shared Container Iterator Type</a></h2> | ||||
|  | ||||
| <pre> | ||||
| template <typename Container> class shared_container_iterator; | ||||
| </pre> | ||||
|  | ||||
| The class template <tt>shared_container_iterator</tt>  | ||||
| is the shared container iterator type.  The <tt>Container</tt> template | ||||
| type argument must model the | ||||
| <a href="http://www.sgi.com/tech/stl/Container.html">Container</a> | ||||
| concept. | ||||
|  | ||||
| <h3>Example</h3> | ||||
|  | ||||
| <p> | ||||
| The following example illustrates how to create an iterator that  | ||||
| regulates the lifetime of a reference counted <tt>std::vector</tt>. | ||||
| Though the original shared pointer <tt>ints</tt> ceases to exist | ||||
| after <tt>set_range()</tt> returns, the | ||||
| <tt>shared_counter_iterator</tt> objects maintain references to the | ||||
|       underlying vector and thereby extend the container's lifetime. | ||||
| <p> | ||||
| <a href="./shared_iterator_example1.cpp">shared_iterator_example1.cpp</a>: | ||||
| <PRE> | ||||
| <font color="#008040">#include "shared_container_iterator.hpp"</font> | ||||
| <font color="#008040">#include "boost/shared_ptr.hpp"</font> | ||||
| <font color="#008040">#include <algorithm></font> | ||||
| <font color="#008040">#include <iostream></font> | ||||
| <font color="#008040">#include <vector></font> | ||||
|  | ||||
| <B>typedef</B> boost::shared_container_iterator< std::vector<<B>int</B>> > iterator; | ||||
|  | ||||
|  | ||||
| <B>void</B> set_range(iterator& i, iterator& end)  { | ||||
|  | ||||
|   boost::shared_ptr< std::vector<<B>int</B>> > ints(<B>new</B> std::vector<<B>int</B>>()); | ||||
|    | ||||
|   ints->push_back(<font color="#0000A0">0</font>); | ||||
|   ints->push_back(<font color="#0000A0">1</font>); | ||||
|   ints->push_back(<font color="#0000A0">2</font>); | ||||
|   ints->push_back(<font color="#0000A0">3</font>); | ||||
|   ints->push_back(<font color="#0000A0">4</font>); | ||||
|   ints->push_back(<font color="#0000A0">5</font>); | ||||
|    | ||||
|   i = iterator(ints->begin(),ints); | ||||
|   end = iterator(ints->end(),ints); | ||||
| } | ||||
|  | ||||
|  | ||||
| <B>int</B> main() { | ||||
|  | ||||
|   iterator i,end; | ||||
|  | ||||
|   set_range(i,end); | ||||
|  | ||||
|   std::copy(i,end,std::ostream_iterator<<B>int</B>>(std::cout,<font color="#0000FF">","</font>)); | ||||
|   std::cout.put(<font color="#0000FF">'\n'</font>); | ||||
|  | ||||
|   <B>return</B> <font color="#0000A0">0</font>; | ||||
| } | ||||
| </PRE> | ||||
|  | ||||
| The output from this part is: | ||||
| <pre> | ||||
| 0,1,2,3,4,5, | ||||
| </pre> | ||||
|  | ||||
| <h3>Template Parameters</h3> | ||||
|  | ||||
| <Table border> | ||||
| <TR> | ||||
| <TH>Parameter</TH><TH>Description</TH> | ||||
| </TR> | ||||
|  | ||||
| <TR> | ||||
| <TD><a | ||||
| href="http://www.sgi.com/tech/stl/Container.html"><tt>Container</tt></a></TD> | ||||
| <TD>The type of the container that we wish to iterate over. It must be  | ||||
| a model of the  | ||||
| <a href="http://www.sgi.com/tech/stl/Container.html"><tt>Container</tt></a> | ||||
| concept. | ||||
| </TD> | ||||
| </TR> | ||||
| </Table> | ||||
|  | ||||
| <h3>Model of</h3> | ||||
|  | ||||
| The <tt>shared_container_iterator<Container></tt> type models the | ||||
| same iterator concept as the base iterator | ||||
|     (<tt>Container::iterator</tt>). | ||||
|  | ||||
| <h3>Members</h3> | ||||
|  | ||||
| The shared container iterator type implements the member functions and | ||||
| operators required of the <a | ||||
| href="http://www.sgi.com/tech/stl/RandomAccessIterator.html">Random Access Iterator</a> | ||||
| concept, though only operations defined for the base iterator will be valid. | ||||
| In addition it has the following constructor: | ||||
|  | ||||
| <pre> | ||||
| shared_container_iterator(Container::iterator const& it, | ||||
|                           boost::shared_ptr<Container> const& container) | ||||
| </pre> | ||||
|  | ||||
| <p> | ||||
| <hr> | ||||
| <p> | ||||
|  | ||||
|  | ||||
| <h2><a name="make_iterator">The Shared Container Iterator Object Generator</a></h2> | ||||
|  | ||||
| <pre> | ||||
| template <typename Container> | ||||
| shared_container_iterator<Container> | ||||
| make_shared_container_iterator(Container::iterator base, | ||||
|                                boost::shared_ptr<Container> const& container) | ||||
| </pre> | ||||
|  | ||||
| This function provides an alternative to directly constructing a | ||||
| shared container iterator.  Using the object generator, a shared | ||||
| container iterator can be created and passed to a function without | ||||
| explicitly specifying its type. | ||||
|  | ||||
| <h3>Example</h3> | ||||
|  | ||||
| This example, similar to the previous, uses  | ||||
| <tt>make_shared_container_iterator()</tt> to create the iterators. | ||||
|  | ||||
| <p> | ||||
| <a href="./shared_iterator_example2.cpp">shared_iterator_example2.cpp</a>: | ||||
|  | ||||
| <PRE> | ||||
| <font color="#008040">#include "shared_container_iterator.hpp"</font> | ||||
| <font color="#008040">#include "boost/shared_ptr.hpp"</font> | ||||
| <font color="#008040">#include <algorithm></font> | ||||
| <font color="#008040">#include <iterator></font> | ||||
| <font color="#008040">#include <iostream></font> | ||||
| <font color="#008040">#include <vector></font> | ||||
|  | ||||
|  | ||||
| <B>template</B> <<B>typename</B> Iterator> | ||||
| <B>void</B> print_range_nl (Iterator begin, Iterator end) { | ||||
|   <B>typedef</B> <B>typename</B> std::iterator_traits<Iterator>::value_type val; | ||||
|   std::copy(begin,end,std::ostream_iterator<val>(std::cout,<font color="#0000FF">","</font>)); | ||||
|   std::cout.put(<font color="#0000FF">'\n'</font>); | ||||
| } | ||||
|  | ||||
|  | ||||
| <B>int</B> main() { | ||||
|  | ||||
|   <B>typedef</B> boost::shared_ptr< std::vector<<B>int</B>> > ints_t; | ||||
|   { | ||||
|     ints_t ints(<B>new</B> std::vector<<B>int</B>>()); | ||||
|  | ||||
|     ints->push_back(<font color="#0000A0">0</font>); | ||||
|     ints->push_back(<font color="#0000A0">1</font>); | ||||
|     ints->push_back(<font color="#0000A0">2</font>); | ||||
|     ints->push_back(<font color="#0000A0">3</font>); | ||||
|     ints->push_back(<font color="#0000A0">4</font>); | ||||
|     ints->push_back(<font color="#0000A0">5</font>); | ||||
|  | ||||
|     print_range_nl(boost::make_shared_container_iterator(ints->begin(),ints), | ||||
| 		   boost::make_shared_container_iterator(ints->end(),ints)); | ||||
|   } | ||||
|    | ||||
|  | ||||
|  | ||||
|   <B>return</B> <font color="#0000A0">0</font>; | ||||
| } | ||||
| </PRE> | ||||
|  | ||||
| Observe that the <tt>shared_container_iterator</tt> type is never | ||||
| explicitly named. The output from this example is the same as the previous. | ||||
|  | ||||
| <h2><a name="make_range">The Shared Container Iterator Range Generator</a></h2> | ||||
|  | ||||
| <pre> | ||||
| template <typename Container> | ||||
| std::pair< | ||||
|   shared_container_iterator<Container>, | ||||
|   shared_container_iterator<Container> | ||||
| > | ||||
| make_shared_container_range(boost::shared_ptr<Container> const& container); | ||||
| </pre> | ||||
|  | ||||
| Class <tt>shared_container_iterator</tt> is meant primarily to return, | ||||
| using iterators, a range of values that we can guarantee will be alive as  | ||||
| long as the iterators are. This is a convenience | ||||
| function to do just that. It is equivalent to | ||||
|  | ||||
| <pre> | ||||
| std::make_pair(make_shared_container_iterator(container->begin(),container), | ||||
|                make_shared_container_iterator(container->end(),container)); | ||||
| </pre> | ||||
|  | ||||
| <h3>Example</h3> | ||||
|  | ||||
| In the following example, a range of values is returned as a pair of | ||||
| <tt>shared_container_iterator</tt> objects.   | ||||
|  | ||||
|  | ||||
| <p> | ||||
| <a href="./shared_iterator_example3.cpp">shared_iterator_example3.cpp</a>: | ||||
|  | ||||
| <PRE> | ||||
| <font color="#008040">#include "shared_container_iterator.hpp"</font> | ||||
| <font color="#008040">#include "boost/shared_ptr.hpp"</font> | ||||
| <font color="#008040">#include "boost/tuple/tuple.hpp" // for boost::tie</font> | ||||
| <font color="#008040">#include <algorithm>              // for std::copy</font> | ||||
| <font color="#008040">#include <iostream>              </font> | ||||
| <font color="#008040">#include <vector></font> | ||||
|  | ||||
|  | ||||
| <B>typedef</B> boost::shared_container_iterator< std::vector<<B>int</B>> > iterator;  | ||||
|  | ||||
| std::pair<iterator,iterator> | ||||
| return_range() { | ||||
|   boost::shared_ptr< std::vector<<B>int</B>> > range(<B>new</B> std::vector<<B>int</B>>()); | ||||
|   range->push_back(<font color="#0000A0">0</font>); | ||||
|   range->push_back(<font color="#0000A0">1</font>); | ||||
|   range->push_back(<font color="#0000A0">2</font>); | ||||
|   range->push_back(<font color="#0000A0">3</font>); | ||||
|   range->push_back(<font color="#0000A0">4</font>); | ||||
|   range->push_back(<font color="#0000A0">5</font>); | ||||
|   <B>return</B> boost::make_shared_container_range(range); | ||||
| } | ||||
|  | ||||
|  | ||||
| <B>int</B> main() { | ||||
|  | ||||
|  | ||||
|   iterator i,end; | ||||
|    | ||||
|   boost::tie(i,end) = return_range(); | ||||
|  | ||||
|   std::copy(i,end,std::ostream_iterator<<B>int</B>>(std::cout,<font color="#0000FF">","</font>)); | ||||
|   std::cout.put(<font color="#0000FF">'\n'</font>); | ||||
|  | ||||
|   <B>return</B> <font color="#0000A0">0</font>; | ||||
| } | ||||
| </PRE> | ||||
|  | ||||
| Though the <tt>range</tt> object only lives for the duration of the | ||||
| <tt>return_range</tt> call, the reference counted | ||||
| <tt>std::vector</tt> will live until <tt>i</tt> and <tt>end</tt> | ||||
| are both destroyed.  The output from this example is the same as | ||||
| the previous two. | ||||
|  | ||||
|  | ||||
| <hr> | ||||
| <!-- hhmts start --> | ||||
| Last modified: Mon Aug 11 11:27:03 EST 2003 | ||||
| <!-- hhmts end --> | ||||
| <p><EFBFBD> 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)</p> | ||||
|  | ||||
| </body> | ||||
|  | ||||
| </html> | ||||
| @@ -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; | ||||
| } | ||||
| @@ -1,64 +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) | ||||
|  | ||||
| //  Shared container iterator adaptor  | ||||
| //  Author: Ronald Garcia | ||||
| //  See http://boost.org/libs/utility/shared_container_iterator.html  | ||||
| //  for documentation.  | ||||
|  | ||||
| // | ||||
| // shared_iterator_test.cpp - Regression tests for shared_container_iterator. | ||||
| // | ||||
|  | ||||
|  | ||||
| #include "boost/shared_container_iterator.hpp" | ||||
| #include "boost/shared_ptr.hpp" | ||||
| #include <vector> | ||||
| #include <cassert> | ||||
|  | ||||
| struct resource { | ||||
|   static int count; | ||||
|   resource() { ++count; } | ||||
|   resource(resource const&) { ++count; } | ||||
|   ~resource() { --count; } | ||||
| }; | ||||
| int resource::count = 0; | ||||
|  | ||||
| typedef std::vector<resource> resources_t; | ||||
|  | ||||
| typedef boost::shared_container_iterator< resources_t > iterator; | ||||
|  | ||||
|  | ||||
| void set_range(iterator& i, iterator& end)  { | ||||
|  | ||||
|   boost::shared_ptr< resources_t > objs(new resources_t()); | ||||
|  | ||||
|   for (int j = 0; j != 6; ++j) | ||||
|     objs->push_back(resource()); | ||||
|    | ||||
|   i = iterator(objs->begin(),objs); | ||||
|   end = iterator(objs->end(),objs); | ||||
|   assert(resource::count == 6); | ||||
| } | ||||
|  | ||||
|  | ||||
| int main() { | ||||
|  | ||||
|   assert(resource::count == 0); | ||||
|    | ||||
|   { | ||||
|     iterator i; | ||||
|     { | ||||
|       iterator end; | ||||
|       set_range(i,end); | ||||
|       assert(resource::count == 6); | ||||
|     } | ||||
|     assert(resource::count == 6); | ||||
|   } | ||||
|   assert(resource::count == 0); | ||||
|    | ||||
|   return 0; | ||||
| } | ||||
| @@ -8,41 +8,39 @@ | ||||
| # bring in rules for testing | ||||
| import testing ; | ||||
|  | ||||
| alias unit_test_framework | ||||
|     : # sources | ||||
|         /boost//unit_test_framework | ||||
|     ;         | ||||
| run base_from_member_test.cpp ; | ||||
| run base_from_member_ref_test.cpp ; | ||||
|  | ||||
| # Please keep the tests ordered by filename | ||||
| test-suite utility | ||||
|     : | ||||
|         [ run ../base_from_member_test.cpp ] | ||||
|         [ run ../base_from_member_ref_test.cpp ] | ||||
|         [ run ../binary_test.cpp ] | ||||
|         [ run ../call_traits_test.cpp : -u ] | ||||
|         [ run ../compressed_pair_test.cpp ../../test/build//boost_test_exec_monitor/<link>static : -u ] | ||||
|         [ run ../iterators_test.cpp ../../test/build//boost_test_exec_monitor/<link>static ] | ||||
|         [ run next_prior_test.cpp ../../test/build//boost_test_exec_monitor/<link>static ] | ||||
|         [ run ../numeric_traits_test.cpp ] | ||||
|         [ run ../operators_test.cpp ../../test/build//boost_test_exec_monitor/<link>static ] | ||||
|         [ compile result_of_test.cpp ] | ||||
|         [ run ../shared_iterator_test.cpp ] | ||||
|         [ run string_ref_test1.cpp unit_test_framework ] | ||||
|         [ run string_ref_test2.cpp unit_test_framework ] | ||||
|         [ run string_ref_test_io.cpp unit_test_framework ] | ||||
|         [ run string_view_test1.cpp unit_test_framework ] | ||||
|         [ run string_view_test2.cpp unit_test_framework ] | ||||
|         [ run string_view_test3.cpp ] | ||||
|         [ run string_view_test_io.cpp unit_test_framework ] | ||||
|         [ run ../value_init_test.cpp ] | ||||
|         [ run ../value_init_workaround_test.cpp ] | ||||
|         [ run ../initialized_test.cpp ] | ||||
|         [ compile-fail ../value_init_test_fail1.cpp ] | ||||
|         [ compile-fail ../value_init_test_fail2.cpp ] | ||||
|         [ compile-fail ../value_init_test_fail3.cpp ] | ||||
|         [ compile-fail ../initialized_test_fail1.cpp ] | ||||
|         [ compile-fail ../initialized_test_fail2.cpp ] | ||||
| run binary_test.cpp ; | ||||
|  | ||||
|         [ run ../generator_iterator_test.cpp ] | ||||
|     ; | ||||
| run call_traits_test.cpp : -u ; | ||||
|  | ||||
| run compressed_pair_test.cpp ; | ||||
| run compressed_pair_final_test.cpp ; | ||||
|  | ||||
| run iterators_test.cpp ; | ||||
|  | ||||
| run operators_test.cpp ; | ||||
|  | ||||
| compile result_of_test.cpp ; | ||||
|  | ||||
| # compile-fail string_ref_from_rvalue.cpp ; | ||||
| run string_ref_test1.cpp ; | ||||
| run string_ref_test2.cpp ; | ||||
| run string_ref_test_io.cpp ; | ||||
| # compile-fail string_view_from_rvalue.cpp ; | ||||
| compile string_view_constexpr_test1.cpp ; | ||||
| run string_view_test1.cpp ; | ||||
| run string_view_test2.cpp ; | ||||
| run string_view_test_io.cpp ; | ||||
|  | ||||
| run value_init_test.cpp ; | ||||
| run value_init_workaround_test.cpp ; | ||||
| run initialized_test.cpp ; | ||||
| compile-fail value_init_test_fail1.cpp ; | ||||
| compile-fail value_init_test_fail2.cpp ; | ||||
| compile-fail value_init_test_fail3.cpp ; | ||||
| compile-fail initialized_test_fail1.cpp ; | ||||
| compile-fail initialized_test_fail2.cpp ; | ||||
|  | ||||
| run ostream_string_test.cpp ; | ||||
|   | ||||
| @@ -10,7 +10,7 @@ | ||||
| 
 | ||||
| #include <boost/utility/base_from_member.hpp> | ||||
| 
 | ||||
| #include <boost/detail/lightweight_test.hpp> | ||||
| #include <boost/core/lightweight_test.hpp> | ||||
| 
 | ||||
| struct foo : boost::base_from_member<int&> | ||||
| { | ||||
| @@ -10,15 +10,14 @@ | ||||
| //  14 Jun 2003  Adjusted code for Boost.Test changes (Daryle Walker)
 | ||||
| //  29 Aug 2001  Initial Version (Daryle Walker)
 | ||||
| 
 | ||||
| #include <boost/test/minimal.hpp>  // for BOOST_CHECK, main
 | ||||
| #include <boost/core/lightweight_test.hpp> | ||||
| 
 | ||||
| #include <boost/config.hpp>       // for BOOST_NO_MEMBER_TEMPLATES
 | ||||
| #include <boost/cstdlib.hpp>      // for boost::exit_success
 | ||||
| #include <boost/noncopyable.hpp>  // for boost::noncopyable
 | ||||
| 
 | ||||
| #include <boost/utility/base_from_member.hpp>  // for boost::base_from_member
 | ||||
| 
 | ||||
| #include <functional>  // for std::binary_function, std::less
 | ||||
| #include <functional>  // for std::less
 | ||||
| #include <iostream>    // for std::cout (std::ostream, std::endl indirectly)
 | ||||
| #include <set>         // for std::set
 | ||||
| #include <typeinfo>    // for std::type_info
 | ||||
| @@ -46,7 +45,6 @@ template < typename T > | ||||
| 
 | ||||
| // A custom comparison type is needed
 | ||||
| struct object_id_compare | ||||
|     : std::binary_function<object_id, object_id, bool> | ||||
| { | ||||
|     bool  operator ()( object_id const &a, object_id const &b ) const; | ||||
| 
 | ||||
| @@ -173,13 +171,13 @@ object_registrar  obj_reg; | ||||
| 
 | ||||
| // Main functionality
 | ||||
| int | ||||
| test_main( int , char * [] ) | ||||
| main() | ||||
| { | ||||
|     BOOST_CHECK( obj_reg.db_.empty() ); | ||||
|     BOOST_CHECK( obj_reg.defrauders_in_.empty() ); | ||||
|     BOOST_CHECK( obj_reg.defrauders_out_.empty() ); | ||||
|     BOOST_CHECK( obj_reg.overeager_.empty() ); | ||||
|     BOOST_CHECK( obj_reg.overkilled_.empty() ); | ||||
|     BOOST_TEST( obj_reg.db_.empty() ); | ||||
|     BOOST_TEST( obj_reg.defrauders_in_.empty() ); | ||||
|     BOOST_TEST( obj_reg.defrauders_out_.empty() ); | ||||
|     BOOST_TEST( obj_reg.overeager_.empty() ); | ||||
|     BOOST_TEST( obj_reg.overkilled_.empty() ); | ||||
| 
 | ||||
|     // Make a separate block to examine pre- and post-effects
 | ||||
|     { | ||||
| @@ -187,20 +185,20 @@ test_main( int , char * [] ) | ||||
|         using std::endl; | ||||
| 
 | ||||
|         bad_class  bc; | ||||
|         BOOST_CHECK( obj_reg.db_.size() == 3 ); | ||||
|         BOOST_CHECK( obj_reg.defrauders_in_.size() == 1 ); | ||||
|         BOOST_TEST( obj_reg.db_.size() == 3 ); | ||||
|         BOOST_TEST( obj_reg.defrauders_in_.size() == 1 ); | ||||
| 
 | ||||
|         good_class_1  gc1; | ||||
|         BOOST_CHECK( obj_reg.db_.size() == 6 ); | ||||
|         BOOST_CHECK( obj_reg.defrauders_in_.size() == 1 ); | ||||
|         BOOST_TEST( obj_reg.db_.size() == 6 ); | ||||
|         BOOST_TEST( obj_reg.defrauders_in_.size() == 1 ); | ||||
| 
 | ||||
|         good_class_2  gc2; | ||||
|         BOOST_CHECK( obj_reg.db_.size() == 11 ); | ||||
|         BOOST_CHECK( obj_reg.defrauders_in_.size() == 1 ); | ||||
|         BOOST_TEST( obj_reg.db_.size() == 11 ); | ||||
|         BOOST_TEST( obj_reg.defrauders_in_.size() == 1 ); | ||||
| 
 | ||||
|         BOOST_CHECK( obj_reg.defrauders_out_.empty() ); | ||||
|         BOOST_CHECK( obj_reg.overeager_.empty() ); | ||||
|         BOOST_CHECK( obj_reg.overkilled_.empty() ); | ||||
|         BOOST_TEST( obj_reg.defrauders_out_.empty() ); | ||||
|         BOOST_TEST( obj_reg.overeager_.empty() ); | ||||
|         BOOST_TEST( obj_reg.overkilled_.empty() ); | ||||
| 
 | ||||
|         // Getting the addresses of the objects ensure
 | ||||
|         // that they're used, and not optimized away.
 | ||||
| @@ -209,13 +207,13 @@ test_main( int , char * [] ) | ||||
|         cout << "Object 'gc2' is at " << &gc2 << '.' << endl; | ||||
|     } | ||||
| 
 | ||||
|     BOOST_CHECK( obj_reg.db_.empty() ); | ||||
|     BOOST_CHECK( obj_reg.defrauders_in_.size() == 1 ); | ||||
|     BOOST_CHECK( obj_reg.defrauders_out_.size() == 1 ); | ||||
|     BOOST_CHECK( obj_reg.overeager_.empty() ); | ||||
|     BOOST_CHECK( obj_reg.overkilled_.empty() ); | ||||
|     BOOST_TEST( obj_reg.db_.empty() ); | ||||
|     BOOST_TEST( obj_reg.defrauders_in_.size() == 1 ); | ||||
|     BOOST_TEST( obj_reg.defrauders_out_.size() == 1 ); | ||||
|     BOOST_TEST( obj_reg.overeager_.empty() ); | ||||
|     BOOST_TEST( obj_reg.overkilled_.empty() ); | ||||
| 
 | ||||
|     return boost::exit_success; | ||||
|     return boost::report_errors(); | ||||
| } | ||||
| 
 | ||||
| 
 | ||||
| @@ -6,7 +6,7 @@ | ||||
|     http://www.boost.org/LICENSE_1_0.txt)
 | ||||
| ==============================================================================*/ | ||||
| 
 | ||||
| #include <boost/test/minimal.hpp> | ||||
| #include <boost/core/lightweight_test.hpp> | ||||
| #include <boost/utility/binary.hpp> | ||||
| #include <algorithm> | ||||
| #include <cstddef> | ||||
| @@ -614,34 +614,34 @@ typedef char (&unsigned_long_int_id_type)[unsigned_long_int_id]; | ||||
| unsigned_int_id_type      binary_type_checker( unsigned int ); | ||||
| unsigned_long_int_id_type binary_type_checker( unsigned long int ); | ||||
| 
 | ||||
| int test_main( int, char *[] ) | ||||
| int main() | ||||
| { | ||||
|   BOOST_CHECK( is_ascending_from_0_array( unsigned_ints_1_bit ) ); | ||||
|   BOOST_CHECK( is_ascending_from_0_array( unsigned_ints_2_bits ) ); | ||||
|   BOOST_CHECK( is_ascending_from_0_array( unsigned_ints_3_bits ) ); | ||||
|   BOOST_CHECK( is_ascending_from_0_array( unsigned_ints_4_bits ) ); | ||||
|   BOOST_CHECK( is_ascending_from_0_array( unsigned_ints_5_bits ) ); | ||||
|   BOOST_CHECK( is_ascending_from_0_array( unsigned_ints_6_bits ) ); | ||||
|   BOOST_CHECK( is_ascending_from_0_array( unsigned_ints_7_bits ) ); | ||||
|   BOOST_CHECK( is_ascending_from_0_array( unsigned_ints_8_bits ) ); | ||||
|   BOOST_TEST( is_ascending_from_0_array( unsigned_ints_1_bit ) ); | ||||
|   BOOST_TEST( is_ascending_from_0_array( unsigned_ints_2_bits ) ); | ||||
|   BOOST_TEST( is_ascending_from_0_array( unsigned_ints_3_bits ) ); | ||||
|   BOOST_TEST( is_ascending_from_0_array( unsigned_ints_4_bits ) ); | ||||
|   BOOST_TEST( is_ascending_from_0_array( unsigned_ints_5_bits ) ); | ||||
|   BOOST_TEST( is_ascending_from_0_array( unsigned_ints_6_bits ) ); | ||||
|   BOOST_TEST( is_ascending_from_0_array( unsigned_ints_7_bits ) ); | ||||
|   BOOST_TEST( is_ascending_from_0_array( unsigned_ints_8_bits ) ); | ||||
| 
 | ||||
|   BOOST_CHECK( std::equal( &random_unsigned_ints_hex[0] | ||||
|   BOOST_TEST( std::equal( &random_unsigned_ints_hex[0] | ||||
|                          , random_unsigned_ints_hex + num_random_test_values | ||||
|                          , &random_unsigned_ints_binary[0] | ||||
|                          ) | ||||
|              ); | ||||
| 
 | ||||
|   BOOST_CHECK(    sizeof( binary_type_checker( BOOST_BINARY_U( 110100 1010 ) ) ) | ||||
|   BOOST_TEST(    sizeof( binary_type_checker( BOOST_BINARY_U( 110100 1010 ) ) ) | ||||
|                == unsigned_int_id | ||||
|              ); | ||||
| 
 | ||||
|   BOOST_CHECK(    sizeof( binary_type_checker( BOOST_BINARY_UL( 11110 ) ) ) | ||||
|   BOOST_TEST(    sizeof( binary_type_checker( BOOST_BINARY_UL( 11110 ) ) ) | ||||
|                == unsigned_long_int_id | ||||
|              ); | ||||
| 
 | ||||
|   BOOST_CHECK(    sizeof( binary_type_checker( BOOST_BINARY_LU( 10 0001 ) ) ) | ||||
|   BOOST_TEST(    sizeof( binary_type_checker( BOOST_BINARY_LU( 10 0001 ) ) ) | ||||
|                == unsigned_long_int_id | ||||
|              ); | ||||
| 
 | ||||
|   return 0; | ||||
|   return boost::report_errors(); | ||||
| } | ||||
							
								
								
									
										55
									
								
								test/compressed_pair_final_test.cpp
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										55
									
								
								test/compressed_pair_final_test.cpp
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,55 @@ | ||||
| /* | ||||
| Copyright 2018 Glen Joseph Fernandes | ||||
| (glenjofe@gmail.com) | ||||
|  | ||||
| Distributed under the Boost Software License, Version 1.0. | ||||
| (http://www.boost.org/LICENSE_1_0.txt) | ||||
| */ | ||||
| #include <boost/config.hpp> | ||||
| #if !defined(BOOST_NO_CXX11_FINAL) | ||||
| #include <boost/compressed_pair.hpp> | ||||
| #include <boost/core/lightweight_test.hpp> | ||||
|  | ||||
| struct type1 { | ||||
|     operator bool() const { | ||||
|         return false; | ||||
|     } | ||||
| }; | ||||
|  | ||||
| struct type2 final { | ||||
|     operator bool() const { | ||||
|         return false; | ||||
|     } | ||||
| }; | ||||
|  | ||||
| #if !defined(BOOST_IS_FINAL) | ||||
| namespace boost { | ||||
|  | ||||
| template<> | ||||
| struct is_final<type2> | ||||
|     : true_type { }; | ||||
|  | ||||
| } /* boost*/ | ||||
| #endif | ||||
|  | ||||
| template<class T1, class T2> | ||||
| void test() | ||||
| { | ||||
|     boost::compressed_pair<T1, T2> p; | ||||
|     BOOST_TEST(!p.first()); | ||||
|     BOOST_TEST(!p.second()); | ||||
| } | ||||
|  | ||||
| int main() | ||||
| { | ||||
|     test<type1, type2>(); | ||||
|     test<type2, type1>(); | ||||
|     test<type2, type2>(); | ||||
|     return boost::report_errors(); | ||||
| } | ||||
| #else | ||||
| int main() | ||||
| { | ||||
|     return 0; | ||||
| } | ||||
| #endif | ||||
| @@ -14,7 +14,7 @@ | ||||
| #include <cassert> | ||||
| 
 | ||||
| #include <boost/compressed_pair.hpp> | ||||
| #include <boost/test/test_tools.hpp> | ||||
| #include <boost/core/lightweight_test.hpp> | ||||
| 
 | ||||
| using namespace boost; | ||||
| 
 | ||||
| @@ -79,47 +79,47 @@ void compressed_pair_tester<T1, T2>::test(first_param_type p1, second_param_type | ||||
|    // first param construct:
 | ||||
|    boost::compressed_pair<T1,T2> cp2(p1); | ||||
|    cp2.second() = p2; | ||||
|    BOOST_CHECK(cp2.first() == p1); | ||||
|    BOOST_CHECK(cp2.second() == p2); | ||||
|    BOOST_TEST(cp2.first() == p1); | ||||
|    BOOST_TEST(cp2.second() == p2); | ||||
|    // second param construct:
 | ||||
|    boost::compressed_pair<T1,T2> cp3(p2); | ||||
|    cp3.first() = p1; | ||||
|    BOOST_CHECK(cp3.second() == p2); | ||||
|    BOOST_CHECK(cp3.first() == p1); | ||||
|    BOOST_TEST(cp3.second() == p2); | ||||
|    BOOST_TEST(cp3.first() == p1); | ||||
|    // both param construct:
 | ||||
|    boost::compressed_pair<T1,T2> cp4(p1, p2); | ||||
|    BOOST_CHECK(cp4.first() == p1); | ||||
|    BOOST_CHECK(cp4.second() == p2); | ||||
|    BOOST_TEST(cp4.first() == p1); | ||||
|    BOOST_TEST(cp4.second() == p2); | ||||
|    boost::compressed_pair<T1,T2> cp5(p3, p4); | ||||
|    BOOST_CHECK(cp5.first() == p3); | ||||
|    BOOST_CHECK(cp5.second() == p4); | ||||
|    BOOST_TEST(cp5.first() == p3); | ||||
|    BOOST_TEST(cp5.second() == p4); | ||||
|    // check const members:
 | ||||
|    const boost::compressed_pair<T1,T2>& cpr1 = cp4; | ||||
|    BOOST_CHECK(cpr1.first() == p1); | ||||
|    BOOST_CHECK(cpr1.second() == p2); | ||||
|    BOOST_TEST(cpr1.first() == p1); | ||||
|    BOOST_TEST(cpr1.second() == p2); | ||||
| 
 | ||||
|    // copy construct:
 | ||||
|    boost::compressed_pair<T1,T2> cp6(cp4); | ||||
|    BOOST_CHECK(cp6.first() == p1); | ||||
|    BOOST_CHECK(cp6.second() == p2); | ||||
|    BOOST_TEST(cp6.first() == p1); | ||||
|    BOOST_TEST(cp6.second() == p2); | ||||
|    // assignment:
 | ||||
|    cp1 = cp4; | ||||
|    BOOST_CHECK(cp1.first() == p1); | ||||
|    BOOST_CHECK(cp1.second() == p2); | ||||
|    BOOST_TEST(cp1.first() == p1); | ||||
|    BOOST_TEST(cp1.second() == p2); | ||||
|    cp1 = cp5; | ||||
|    BOOST_CHECK(cp1.first() == p3); | ||||
|    BOOST_CHECK(cp1.second() == p4); | ||||
|    BOOST_TEST(cp1.first() == p3); | ||||
|    BOOST_TEST(cp1.second() == p4); | ||||
|    // swap:
 | ||||
|    cp4.swap(cp5); | ||||
|    BOOST_CHECK(cp4.first() == p3); | ||||
|    BOOST_CHECK(cp4.second() == p4); | ||||
|    BOOST_CHECK(cp5.first() == p1); | ||||
|    BOOST_CHECK(cp5.second() == p2); | ||||
|    BOOST_TEST(cp4.first() == p3); | ||||
|    BOOST_TEST(cp4.second() == p4); | ||||
|    BOOST_TEST(cp5.first() == p1); | ||||
|    BOOST_TEST(cp5.second() == p2); | ||||
|    swap(cp4,cp5); | ||||
|    BOOST_CHECK(cp4.first() == p1); | ||||
|    BOOST_CHECK(cp4.second() == p2); | ||||
|    BOOST_CHECK(cp5.first() == p3); | ||||
|    BOOST_CHECK(cp5.second() == p4); | ||||
|    BOOST_TEST(cp4.first() == p1); | ||||
|    BOOST_TEST(cp4.second() == p2); | ||||
|    BOOST_TEST(cp5.first() == p3); | ||||
|    BOOST_TEST(cp5.second() == p4); | ||||
| } | ||||
| 
 | ||||
| //
 | ||||
| @@ -148,20 +148,20 @@ void compressed_pair_reference_tester<T1, T2>::test(first_param_type p1, second_ | ||||
| #endif | ||||
|    // both param construct:
 | ||||
|    boost::compressed_pair<T1,T2> cp4(p1, p2); | ||||
|    BOOST_CHECK(cp4.first() == p1); | ||||
|    BOOST_CHECK(cp4.second() == p2); | ||||
|    BOOST_TEST(cp4.first() == p1); | ||||
|    BOOST_TEST(cp4.second() == p2); | ||||
|    boost::compressed_pair<T1,T2> cp5(p3, p4); | ||||
|    BOOST_CHECK(cp5.first() == p3); | ||||
|    BOOST_CHECK(cp5.second() == p4); | ||||
|    BOOST_TEST(cp5.first() == p3); | ||||
|    BOOST_TEST(cp5.second() == p4); | ||||
|    // check const members:
 | ||||
|    const boost::compressed_pair<T1,T2>& cpr1 = cp4; | ||||
|    BOOST_CHECK(cpr1.first() == p1); | ||||
|    BOOST_CHECK(cpr1.second() == p2); | ||||
|    BOOST_TEST(cpr1.first() == p1); | ||||
|    BOOST_TEST(cpr1.second() == p2); | ||||
| 
 | ||||
|    // copy construct:
 | ||||
|    boost::compressed_pair<T1,T2> cp6(cp4); | ||||
|    BOOST_CHECK(cp6.first() == p1); | ||||
|    BOOST_CHECK(cp6.second() == p2); | ||||
|    BOOST_TEST(cp6.first() == p1); | ||||
|    BOOST_TEST(cp6.second() == p2); | ||||
|    // assignment:
 | ||||
|    // VC6 bug:
 | ||||
|    // When second() is an empty class, VC6 performs the
 | ||||
| @@ -174,8 +174,8 @@ void compressed_pair_reference_tester<T1, T2>::test(first_param_type p1, second_ | ||||
|    // settings - some generate the problem others do not.
 | ||||
|    cp4.first() = p3; | ||||
|    cp4.second() = p4; | ||||
|    BOOST_CHECK(cp4.first() == p3); | ||||
|    BOOST_CHECK(cp4.second() == p4); | ||||
|    BOOST_TEST(cp4.first() == p3); | ||||
|    BOOST_TEST(cp4.second() == p4); | ||||
| } | ||||
| //
 | ||||
| // supplimentary tests for case where first arg only is a reference type:
 | ||||
| @@ -199,8 +199,8 @@ void compressed_pair_reference1_tester<T1, T2>::test(first_param_type p1, second | ||||
|    // first param construct:
 | ||||
|    boost::compressed_pair<T1,T2> cp2(p1); | ||||
|    cp2.second() = p2; | ||||
|    BOOST_CHECK(cp2.first() == p1); | ||||
|    BOOST_CHECK(cp2.second() == p2); | ||||
|    BOOST_TEST(cp2.first() == p1); | ||||
|    BOOST_TEST(cp2.second() == p2); | ||||
| #endif | ||||
| } | ||||
| //
 | ||||
| @@ -225,8 +225,8 @@ void compressed_pair_reference2_tester<T1, T2>::test(first_param_type p1, second | ||||
|    // second param construct:
 | ||||
|    boost::compressed_pair<T1,T2> cp3(p2); | ||||
|    cp3.first() = p1; | ||||
|    BOOST_CHECK(cp3.second() == p2); | ||||
|    BOOST_CHECK(cp3.first() == p1); | ||||
|    BOOST_TEST(cp3.second() == p2); | ||||
|    BOOST_TEST(cp3.first() == p1); | ||||
| #endif | ||||
| } | ||||
| 
 | ||||
| @@ -253,14 +253,14 @@ void compressed_pair_array1_tester<T1, T2>::test(first_param_type p1, second_par | ||||
|    // second param construct:
 | ||||
|    boost::compressed_pair<T1,T2> cp3(p2); | ||||
|    cp3.first()[0] = p1[0]; | ||||
|    BOOST_CHECK(cp3.second() == p2); | ||||
|    BOOST_CHECK(cp3.first()[0] == p1[0]); | ||||
|    BOOST_TEST(cp3.second() == p2); | ||||
|    BOOST_TEST(cp3.first()[0] == p1[0]); | ||||
|    // check const members:
 | ||||
|    const boost::compressed_pair<T1,T2>& cpr1 = cp3; | ||||
|    BOOST_CHECK(cpr1.first()[0] == p1[0]); | ||||
|    BOOST_CHECK(cpr1.second() == p2); | ||||
|    BOOST_TEST(cpr1.first()[0] == p1[0]); | ||||
|    BOOST_TEST(cpr1.second() == p2); | ||||
| 
 | ||||
|    BOOST_CHECK(sizeof(T1) == sizeof(cp1.first())); | ||||
|    BOOST_TEST(sizeof(T1) == sizeof(cp1.first())); | ||||
| } | ||||
| 
 | ||||
| template <class T1, class T2> | ||||
| @@ -283,14 +283,14 @@ void compressed_pair_array2_tester<T1, T2>::test(first_param_type p1, second_par | ||||
|    // first param construct:
 | ||||
|    boost::compressed_pair<T1,T2> cp2(p1); | ||||
|    cp2.second()[0] = p2[0]; | ||||
|    BOOST_CHECK(cp2.first() == p1); | ||||
|    BOOST_CHECK(cp2.second()[0] == p2[0]); | ||||
|    BOOST_TEST(cp2.first() == p1); | ||||
|    BOOST_TEST(cp2.second()[0] == p2[0]); | ||||
|    // check const members:
 | ||||
|    const boost::compressed_pair<T1,T2>& cpr1 = cp2; | ||||
|    BOOST_CHECK(cpr1.first() == p1); | ||||
|    BOOST_CHECK(cpr1.second()[0] == p2[0]); | ||||
|    BOOST_TEST(cpr1.first() == p1); | ||||
|    BOOST_TEST(cpr1.second()[0] == p2[0]); | ||||
| 
 | ||||
|    BOOST_CHECK(sizeof(T2) == sizeof(cp1.second())); | ||||
|    BOOST_TEST(sizeof(T2) == sizeof(cp1.second())); | ||||
| } | ||||
| 
 | ||||
| template <class T1, class T2> | ||||
| @@ -312,18 +312,18 @@ void compressed_pair_array_tester<T1, T2>::test(first_param_type p1, second_para | ||||
|    boost::compressed_pair<T1,T2> cp1; | ||||
|    cp1.first()[0] = p1[0]; | ||||
|    cp1.second()[0] = p2[0]; | ||||
|    BOOST_CHECK(cp1.first()[0] == p1[0]); | ||||
|    BOOST_CHECK(cp1.second()[0] == p2[0]); | ||||
|    BOOST_TEST(cp1.first()[0] == p1[0]); | ||||
|    BOOST_TEST(cp1.second()[0] == p2[0]); | ||||
|    // check const members:
 | ||||
|    const boost::compressed_pair<T1,T2>& cpr1 = cp1; | ||||
|    BOOST_CHECK(cpr1.first()[0] == p1[0]); | ||||
|    BOOST_CHECK(cpr1.second()[0] == p2[0]); | ||||
|    BOOST_TEST(cpr1.first()[0] == p1[0]); | ||||
|    BOOST_TEST(cpr1.second()[0] == p2[0]); | ||||
| 
 | ||||
|    BOOST_CHECK(sizeof(T1) == sizeof(cp1.first())); | ||||
|    BOOST_CHECK(sizeof(T2) == sizeof(cp1.second())); | ||||
|    BOOST_TEST(sizeof(T1) == sizeof(cp1.first())); | ||||
|    BOOST_TEST(sizeof(T2) == sizeof(cp1.second())); | ||||
| } | ||||
| 
 | ||||
| int test_main(int, char *[]) | ||||
| int main() | ||||
| { | ||||
|    // declare some variables to pass to the tester:
 | ||||
|    non_empty1 ne1(2); | ||||
| @@ -383,13 +383,5 @@ int test_main(int, char *[]) | ||||
|    compressed_pair_array2_tester<empty_POD_UDT,non_empty2[2]>::test(e1, nea3, e1, nea4); | ||||
|    // T1 == T2, both non-empty
 | ||||
|    compressed_pair_array_tester<non_empty1[2],non_empty1[2]>::test(nea1, nea1, nea2, nea2); | ||||
|    return 0; | ||||
|    return boost::report_errors(); | ||||
| } | ||||
| 
 | ||||
| 
 | ||||
| unsigned int expected_failures = 0; | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| @@ -9,7 +9,7 @@ | ||||
| // 2 May 2010 (Created) Niels Dekker
 | ||||
| 
 | ||||
| #include <boost/utility/value_init.hpp> | ||||
| #include <boost/detail/lightweight_test.hpp> | ||||
| #include <boost/core/lightweight_test.hpp> | ||||
| 
 | ||||
| #include <string> | ||||
| 
 | ||||
| @@ -12,11 +12,9 @@ | ||||
| //            library (Daryle Walker)
 | ||||
| //  12 Dec 99 Initial version with iterator operators (Jeremy Siek)
 | ||||
| 
 | ||||
| #define  BOOST_INCLUDE_MAIN | ||||
| #include <boost/test/test_tools.hpp>  // for main
 | ||||
| #include <boost/core/lightweight_test.hpp> | ||||
| 
 | ||||
| #include <boost/config.hpp>     // for BOOST_STATIC_CONSTANT
 | ||||
| #include <boost/cstdlib.hpp>    // for boost::exit_success
 | ||||
| #include <boost/operators.hpp>  // for boost::random_access_iterator_helper
 | ||||
| 
 | ||||
| #include <cstddef>    // for std::ptrdiff_t, std::size_t
 | ||||
| @@ -126,7 +124,7 @@ typename test_opr<T, R, P>::iter_type const | ||||
| 
 | ||||
| // Main testing function
 | ||||
| int | ||||
| test_main( int , char * [] ) | ||||
| main() | ||||
| { | ||||
|     using std::string; | ||||
| 
 | ||||
| @@ -136,7 +134,7 @@ test_main( int , char * [] ) | ||||
|     test1_type::master_test( "non-const string" ); | ||||
|     test2_type::master_test( "const string" ); | ||||
| 
 | ||||
|     return boost::exit_success; | ||||
|     return boost::report_errors(); | ||||
| } | ||||
| 
 | ||||
| // Tests for all of the operators added by random_access_iterator_helper
 | ||||
| @@ -174,7 +172,7 @@ test_opr<T, R, P>::post_increment_test | ||||
|         oss << *i++ << ' '; | ||||
|     } | ||||
| 
 | ||||
|     BOOST_CHECK( oss.str() == "apple orange pear peach grape plum "); | ||||
|     BOOST_TEST( oss.str() == "apple orange pear peach grape plum "); | ||||
| } | ||||
| 
 | ||||
| // Test post-decrement
 | ||||
| @@ -193,7 +191,7 @@ test_opr<T, R, P>::post_decrement_test | ||||
|         oss << *i << ' '; | ||||
|     } | ||||
| 
 | ||||
|     BOOST_CHECK( oss.str() == "plum grape peach pear orange apple "); | ||||
|     BOOST_TEST( oss.str() == "plum grape peach pear orange apple "); | ||||
| } | ||||
| 
 | ||||
| // Test indirect structure referral
 | ||||
| @@ -211,7 +209,7 @@ test_opr<T, R, P>::indirect_referral_test | ||||
|         oss << i->size() << ' '; | ||||
|     } | ||||
| 
 | ||||
|     BOOST_CHECK( oss.str() == "5 6 4 5 5 4 "); | ||||
|     BOOST_TEST( oss.str() == "5 6 4 5 5 4 "); | ||||
| } | ||||
| 
 | ||||
| // Test offset addition
 | ||||
| @@ -230,7 +228,7 @@ test_opr<T, R, P>::offset_addition_test | ||||
|         oss << *i << ' '; | ||||
|     } | ||||
| 
 | ||||
|     BOOST_CHECK( oss.str() == "apple pear grape "); | ||||
|     BOOST_TEST( oss.str() == "apple pear grape "); | ||||
| } | ||||
| 
 | ||||
| // Test offset addition, in reverse order
 | ||||
| @@ -249,7 +247,7 @@ test_opr<T, R, P>::reverse_offset_addition_test | ||||
|         oss << *i << ' '; | ||||
|     } | ||||
| 
 | ||||
|     BOOST_CHECK( oss.str() == "apple pear grape "); | ||||
|     BOOST_TEST( oss.str() == "apple pear grape "); | ||||
| } | ||||
| 
 | ||||
| // Test offset subtraction
 | ||||
| @@ -272,7 +270,7 @@ test_opr<T, R, P>::offset_subtraction_test | ||||
|         } | ||||
|     } | ||||
| 
 | ||||
|     BOOST_CHECK( oss.str() == "grape pear apple "); | ||||
|     BOOST_TEST( oss.str() == "grape pear apple "); | ||||
| } | ||||
| 
 | ||||
| // Test comparisons
 | ||||
| @@ -296,10 +294,10 @@ test_opr<T, R, P>::comparison_test | ||||
|         { | ||||
|             ptrdiff_t const  j_offset = j - fruit_begin; | ||||
| 
 | ||||
|             BOOST_CHECK( (i != j) == (i_offset != j_offset) ); | ||||
|             BOOST_CHECK( (i > j) == (i_offset > j_offset) ); | ||||
|             BOOST_CHECK( (i <= j) == (i_offset <= j_offset) ); | ||||
|             BOOST_CHECK( (i >= j) == (i_offset >= j_offset) ); | ||||
|             BOOST_TEST( (i != j) == (i_offset != j_offset) ); | ||||
|             BOOST_TEST( (i > j) == (i_offset > j_offset) ); | ||||
|             BOOST_TEST( (i <= j) == (i_offset <= j_offset) ); | ||||
|             BOOST_TEST( (i >= j) == (i_offset >= j_offset) ); | ||||
|         } | ||||
|     } | ||||
|     cout << std::endl; | ||||
| @@ -320,5 +318,5 @@ test_opr<T, R, P>::indexing_test | ||||
|         oss << fruit_begin[ k ] << ' '; | ||||
|     } | ||||
| 
 | ||||
|     BOOST_CHECK( oss.str() == "apple orange pear peach grape plum "); | ||||
|     BOOST_TEST( oss.str() == "apple orange pear peach grape plum "); | ||||
| } | ||||
| @@ -1,15 +0,0 @@ | ||||
| <?xml version="1.0" encoding="utf-8"?> | ||||
| <Project ToolsVersion="4.0" xmlns="http://schemas.microsoft.com/developer/msbuild/2003"> | ||||
|   <ImportGroup Label="PropertySheets" /> | ||||
|   <PropertyGroup Label="UserMacros" /> | ||||
|   <PropertyGroup /> | ||||
|   <ItemDefinitionGroup> | ||||
|     <ClCompile> | ||||
|       <AdditionalIncludeDirectories>../../../../..</AdditionalIncludeDirectories> | ||||
|     </ClCompile> | ||||
|     <PostBuildEvent> | ||||
|       <Command>"$(TargetDir)\$(TargetName).exe"</Command> | ||||
|     </PostBuildEvent> | ||||
|   </ItemDefinitionGroup> | ||||
|   <ItemGroup /> | ||||
| </Project> | ||||
| @@ -1,22 +0,0 @@ | ||||
|  | ||||
| Microsoft Visual Studio Solution File, Format Version 12.00 | ||||
| # Visual Studio 14 | ||||
| VisualStudioVersion = 14.0.22823.1 | ||||
| MinimumVisualStudioVersion = 10.0.40219.1 | ||||
| Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "string_view_test3", "string_view_test3\string_view_test3.vcxproj", "{4921E3AB-4466-4592-BA7A-3460AD616956}" | ||||
| EndProject | ||||
| Global | ||||
| 	GlobalSection(SolutionConfigurationPlatforms) = preSolution | ||||
| 		Debug|x86 = Debug|x86 | ||||
| 		Release|x86 = Release|x86 | ||||
| 	EndGlobalSection | ||||
| 	GlobalSection(ProjectConfigurationPlatforms) = postSolution | ||||
| 		{4921E3AB-4466-4592-BA7A-3460AD616956}.Debug|x86.ActiveCfg = Debug|Win32 | ||||
| 		{4921E3AB-4466-4592-BA7A-3460AD616956}.Debug|x86.Build.0 = Debug|Win32 | ||||
| 		{4921E3AB-4466-4592-BA7A-3460AD616956}.Release|x86.ActiveCfg = Release|Win32 | ||||
| 		{4921E3AB-4466-4592-BA7A-3460AD616956}.Release|x86.Build.0 = Release|Win32 | ||||
| 	EndGlobalSection | ||||
| 	GlobalSection(SolutionProperties) = preSolution | ||||
| 		HideSolutionNode = FALSE | ||||
| 	EndGlobalSection | ||||
| EndGlobal | ||||
| @@ -1,90 +0,0 @@ | ||||
| <?xml version="1.0" encoding="utf-8"?> | ||||
| <Project DefaultTargets="Build" ToolsVersion="14.0" xmlns="http://schemas.microsoft.com/developer/msbuild/2003"> | ||||
|   <ItemGroup Label="ProjectConfigurations"> | ||||
|     <ProjectConfiguration Include="Debug|Win32"> | ||||
|       <Configuration>Debug</Configuration> | ||||
|       <Platform>Win32</Platform> | ||||
|     </ProjectConfiguration> | ||||
|     <ProjectConfiguration Include="Release|Win32"> | ||||
|       <Configuration>Release</Configuration> | ||||
|       <Platform>Win32</Platform> | ||||
|     </ProjectConfiguration> | ||||
|   </ItemGroup> | ||||
|   <PropertyGroup Label="Globals"> | ||||
|     <ProjectGuid>{4921E3AB-4466-4592-BA7A-3460AD616956}</ProjectGuid> | ||||
|     <Keyword>Win32Proj</Keyword> | ||||
|     <RootNamespace>string_view_test3</RootNamespace> | ||||
|   </PropertyGroup> | ||||
|   <Import Project="$(VCTargetsPath)\Microsoft.Cpp.Default.props" /> | ||||
|   <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'" Label="Configuration"> | ||||
|     <ConfigurationType>Application</ConfigurationType> | ||||
|     <UseDebugLibraries>true</UseDebugLibraries> | ||||
|     <PlatformToolset>v140</PlatformToolset> | ||||
|     <CharacterSet>Unicode</CharacterSet> | ||||
|   </PropertyGroup> | ||||
|   <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release|Win32'" Label="Configuration"> | ||||
|     <ConfigurationType>Application</ConfigurationType> | ||||
|     <UseDebugLibraries>false</UseDebugLibraries> | ||||
|     <PlatformToolset>v140</PlatformToolset> | ||||
|     <WholeProgramOptimization>true</WholeProgramOptimization> | ||||
|     <CharacterSet>Unicode</CharacterSet> | ||||
|   </PropertyGroup> | ||||
|   <Import Project="$(VCTargetsPath)\Microsoft.Cpp.props" /> | ||||
|   <ImportGroup Label="ExtensionSettings"> | ||||
|   </ImportGroup> | ||||
|   <ImportGroup Label="Shared"> | ||||
|   </ImportGroup> | ||||
|   <ImportGroup Label="PropertySheets" Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'"> | ||||
|     <Import Project="$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props" Condition="exists('$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props')" Label="LocalAppDataPlatform" /> | ||||
|     <Import Project="..\common.props" /> | ||||
|   </ImportGroup> | ||||
|   <ImportGroup Label="PropertySheets" Condition="'$(Configuration)|$(Platform)'=='Release|Win32'"> | ||||
|     <Import Project="$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props" Condition="exists('$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props')" Label="LocalAppDataPlatform" /> | ||||
|     <Import Project="..\common.props" /> | ||||
|   </ImportGroup> | ||||
|   <PropertyGroup Label="UserMacros" /> | ||||
|   <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'"> | ||||
|     <LinkIncremental>true</LinkIncremental> | ||||
|   </PropertyGroup> | ||||
|   <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release|Win32'"> | ||||
|     <LinkIncremental>false</LinkIncremental> | ||||
|   </PropertyGroup> | ||||
|   <ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'"> | ||||
|     <ClCompile> | ||||
|       <PrecompiledHeader> | ||||
|       </PrecompiledHeader> | ||||
|       <WarningLevel>Level3</WarningLevel> | ||||
|       <Optimization>Disabled</Optimization> | ||||
|       <PreprocessorDefinitions>WIN32;_DEBUG;_CONSOLE;%(PreprocessorDefinitions)</PreprocessorDefinitions> | ||||
|       <SDLCheck>true</SDLCheck> | ||||
|     </ClCompile> | ||||
|     <Link> | ||||
|       <SubSystem>Console</SubSystem> | ||||
|       <GenerateDebugInformation>true</GenerateDebugInformation> | ||||
|     </Link> | ||||
|   </ItemDefinitionGroup> | ||||
|   <ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Release|Win32'"> | ||||
|     <ClCompile> | ||||
|       <WarningLevel>Level3</WarningLevel> | ||||
|       <PrecompiledHeader> | ||||
|       </PrecompiledHeader> | ||||
|       <Optimization>MaxSpeed</Optimization> | ||||
|       <FunctionLevelLinking>true</FunctionLevelLinking> | ||||
|       <IntrinsicFunctions>true</IntrinsicFunctions> | ||||
|       <PreprocessorDefinitions>WIN32;NDEBUG;_CONSOLE;%(PreprocessorDefinitions)</PreprocessorDefinitions> | ||||
|       <SDLCheck>true</SDLCheck> | ||||
|     </ClCompile> | ||||
|     <Link> | ||||
|       <SubSystem>Console</SubSystem> | ||||
|       <GenerateDebugInformation>true</GenerateDebugInformation> | ||||
|       <EnableCOMDATFolding>true</EnableCOMDATFolding> | ||||
|       <OptimizeReferences>true</OptimizeReferences> | ||||
|     </Link> | ||||
|   </ItemDefinitionGroup> | ||||
|   <ItemGroup> | ||||
|     <ClCompile Include="..\..\string_view_test3.cpp" /> | ||||
|   </ItemGroup> | ||||
|   <Import Project="$(VCTargetsPath)\Microsoft.Cpp.targets" /> | ||||
|   <ImportGroup Label="ExtensionTargets"> | ||||
|   </ImportGroup> | ||||
| </Project> | ||||
| @@ -1,97 +0,0 @@ | ||||
| // Boost test program for next() and prior() utilities. | ||||
|  | ||||
| // Copyright 2003 Daniel Walker.  Use, modification, and distribution | ||||
| // are subject to the Boost Software License, Version 1.0. (See | ||||
| // accompanying file LICENSE_1_0.txt or a copy at | ||||
| // http://www.boost.org/LICENSE_1_0.txt.) | ||||
|  | ||||
| // See http://www.boost.org/libs/utility for documentation. | ||||
|  | ||||
| // Revision History 13 Dec 2003 Initial Version (Daniel Walker) | ||||
|  | ||||
| // next() and prior() are replacements for operator+ and operator- for | ||||
| // non-random-access iterators. The semantics of these operators are | ||||
| // such that after executing j = i + n, std::distance(i, j) equals | ||||
| // n. Tests are provided to ensure next() has the same | ||||
| // result. Parallel tests are provided for prior(). The tests call | ||||
| // next() and prior() several times. next() and prior() are very | ||||
| // simple functions, though, and it would be very strange if these | ||||
| // tests were to fail. | ||||
|  | ||||
| #define BOOST_INCLUDE_MAIN | ||||
| #include <boost/test/test_tools.hpp> | ||||
|  | ||||
| #include <list> | ||||
| #include <vector> | ||||
|  | ||||
| #include <boost/next_prior.hpp> | ||||
|  | ||||
| template<class RandomAccessIterator, class ForwardIterator> | ||||
| bool plus_one_test(RandomAccessIterator first, RandomAccessIterator last, ForwardIterator first2) | ||||
| { | ||||
|     RandomAccessIterator i = first; | ||||
|     ForwardIterator j = first2; | ||||
|     while(i != last) | ||||
|         i = i + 1, j = boost::next(j); | ||||
|     return std::distance(first, i) == std::distance(first2, j); | ||||
| } | ||||
|  | ||||
| template<class RandomAccessIterator, class ForwardIterator> | ||||
| bool plus_n_test(RandomAccessIterator first, RandomAccessIterator last, ForwardIterator first2) | ||||
| { | ||||
|     RandomAccessIterator i = first; | ||||
|     ForwardIterator j = first2; | ||||
|     for(int n = 0; i != last; ++n) | ||||
|         i = first + n, j = boost::next(first2, n); | ||||
|     return std::distance(first, i) == std::distance(first2, j); | ||||
| } | ||||
|  | ||||
| template<class RandomAccessIterator, class BidirectionalIterator> | ||||
| bool minus_one_test(RandomAccessIterator first, RandomAccessIterator last, BidirectionalIterator last2) | ||||
| { | ||||
|     RandomAccessIterator i = last; | ||||
|     BidirectionalIterator j = last2; | ||||
|     while(i != first) | ||||
|         i = i - 1, j = boost::prior(j); | ||||
|     return std::distance(i, last) == std::distance(j, last2); | ||||
| } | ||||
|  | ||||
| template<class RandomAccessIterator, class BidirectionalIterator> | ||||
| bool minus_n_test(RandomAccessIterator first, RandomAccessIterator last, BidirectionalIterator last2) | ||||
| { | ||||
|     RandomAccessIterator i = last; | ||||
|     BidirectionalIterator j = last2; | ||||
|     for(int n = 0; i != first; ++n) | ||||
|         i = last - n, j = boost::prior(last2, n); | ||||
|     return std::distance(i, last) == std::distance(j, last2); | ||||
| } | ||||
|  | ||||
| template<class Iterator, class Distance> | ||||
| bool minus_n_unsigned_test(Iterator first, Iterator last, Distance size) | ||||
| { | ||||
|     Iterator i = boost::prior(last, size); | ||||
|     return i == first; | ||||
| } | ||||
|  | ||||
| int test_main(int, char*[]) | ||||
| { | ||||
|     std::vector<int> x(8); | ||||
|     std::list<int> y(x.begin(), x.end()); | ||||
|  | ||||
|     // Tests with iterators | ||||
|     BOOST_REQUIRE(plus_one_test(x.begin(), x.end(), y.begin())); | ||||
|     BOOST_REQUIRE(plus_n_test(x.begin(), x.end(), y.begin())); | ||||
|     BOOST_REQUIRE(minus_one_test(x.begin(), x.end(), y.end())); | ||||
|     BOOST_REQUIRE(minus_n_test(x.begin(), x.end(), y.end())); | ||||
|     BOOST_REQUIRE(minus_n_unsigned_test(x.begin(), x.end(), x.size())); | ||||
|     BOOST_REQUIRE(minus_n_unsigned_test(y.begin(), y.end(), y.size())); | ||||
|  | ||||
|     // Tests with integers | ||||
|     BOOST_REQUIRE(boost::next(5) == 6); | ||||
|     BOOST_REQUIRE(boost::next(5, 7) == 12); | ||||
|     BOOST_REQUIRE(boost::prior(5) == 4); | ||||
|     BOOST_REQUIRE(boost::prior(5, 7) == -2); | ||||
|     BOOST_REQUIRE(boost::prior(5, 7u) == -2); | ||||
|  | ||||
|     return 0; | ||||
| } | ||||
| @@ -21,13 +21,10 @@ | ||||
| //  12 Dec 99 Minor update, output confirmation message.
 | ||||
| //  15 Nov 99 Initial version
 | ||||
| 
 | ||||
| #define BOOST_INCLUDE_MAIN | ||||
| 
 | ||||
| #include <boost/config.hpp>                      // for BOOST_MSVC
 | ||||
| #include <boost/cstdlib.hpp>                     // for boost::exit_success
 | ||||
| #include <boost/operators.hpp>                   // for the tested items
 | ||||
| #include <boost/random/linear_congruential.hpp>  // for boost::minstd_rand
 | ||||
| #include <boost/test/test_tools.hpp>             // for main
 | ||||
| #include <boost/utility/detail/minstd_rand.hpp>  // for boost::detail::minstd_rand
 | ||||
| #include <boost/core/lightweight_test.hpp> | ||||
| 
 | ||||
| #include <iostream>  // for std::cout (std::endl indirectly)
 | ||||
| 
 | ||||
| @@ -38,11 +35,9 @@ namespace | ||||
|     int true_value(int x) { return x; } | ||||
|     long true_value(long x) { return x; } | ||||
|     signed char true_value(signed char x) { return x; } | ||||
|     short true_value(short x) { return x; } | ||||
|     unsigned int true_value(unsigned int x) { return x; } | ||||
|     unsigned long true_value(unsigned long x) { return x; } | ||||
|     unsigned char true_value(unsigned char x) { return x; } | ||||
|     unsigned short true_value(unsigned short x) { return x; } | ||||
| 
 | ||||
|     // verify the minimum requirements for some operators
 | ||||
|     class convertible_to_bool | ||||
| @@ -313,17 +308,17 @@ namespace | ||||
|     template <class X1, class Y1, class X2, class Y2> | ||||
|     void sanity_check(X1 x1, Y1 y1, X2 x2, Y2 y2) | ||||
|     { | ||||
|         BOOST_CHECK( true_value(y1) == true_value(y2) ); | ||||
|         BOOST_CHECK( true_value(x1) == true_value(x2) ); | ||||
|         BOOST_TEST( true_value(y1) == true_value(y2) ); | ||||
|         BOOST_TEST( true_value(x1) == true_value(x2) ); | ||||
|     } | ||||
| 
 | ||||
|     template <class X1, class Y1, class X2, class Y2> | ||||
|     void test_less_than_comparable_aux(X1 x1, Y1 y1, X2 x2, Y2 y2) | ||||
|     { | ||||
|         BOOST_CHECK( static_cast<bool>(x1 < y1) == static_cast<bool>(x2 < y2) ); | ||||
|         BOOST_CHECK( static_cast<bool>(x1 <= y1) == static_cast<bool>(x2 <= y2) ); | ||||
|         BOOST_CHECK( static_cast<bool>(x1 >= y1) == static_cast<bool>(x2 >= y2) ); | ||||
|         BOOST_CHECK( static_cast<bool>(x1 > y1) == static_cast<bool>(x2 > y2) ); | ||||
|         BOOST_TEST( static_cast<bool>(x1 < y1) == static_cast<bool>(x2 < y2) ); | ||||
|         BOOST_TEST( static_cast<bool>(x1 <= y1) == static_cast<bool>(x2 <= y2) ); | ||||
|         BOOST_TEST( static_cast<bool>(x1 >= y1) == static_cast<bool>(x2 >= y2) ); | ||||
|         BOOST_TEST( static_cast<bool>(x1 > y1) == static_cast<bool>(x2 > y2) ); | ||||
|     } | ||||
|      | ||||
|     template <class X1, class Y1, class X2, class Y2> | ||||
| @@ -337,8 +332,8 @@ namespace | ||||
|     template <class X1, class Y1, class X2, class Y2> | ||||
|     void test_equality_comparable_aux(X1 x1, Y1 y1, X2 x2, Y2 y2) | ||||
|     { | ||||
|         BOOST_CHECK( static_cast<bool>(x1 == y1) == static_cast<bool>(x2 == y2) ); | ||||
|         BOOST_CHECK( static_cast<bool>(x1 != y1) == static_cast<bool>(x2 != y2) ); | ||||
|         BOOST_TEST( static_cast<bool>(x1 == y1) == static_cast<bool>(x2 == y2) ); | ||||
|         BOOST_TEST( static_cast<bool>(x1 != y1) == static_cast<bool>(x2 != y2) ); | ||||
|     } | ||||
|      | ||||
|     template <class X1, class Y1, class X2, class Y2> | ||||
| @@ -352,7 +347,7 @@ namespace | ||||
|     template <class X1, class Y1, class X2, class Y2> | ||||
|     void test_multipliable_aux(X1 x1, Y1 y1, X2 x2, Y2 y2) | ||||
|     { | ||||
|         BOOST_CHECK( (x1 * y1).value() == (x2 * y2) ); | ||||
|         BOOST_TEST( (x1 * y1).value() == (x2 * y2) ); | ||||
|     } | ||||
|      | ||||
|     template <class X1, class Y1, class X2, class Y2> | ||||
| @@ -366,7 +361,7 @@ namespace | ||||
|   template <class A, class B> | ||||
|   void test_value_equality(A a, B b) | ||||
|   { | ||||
|       BOOST_CHECK(a.value() == b); | ||||
|       BOOST_TEST(a.value() == b); | ||||
|   } | ||||
|    | ||||
| #define TEST_OP_R(op) test_value_equality(x1 op y1, x2 op y2) | ||||
| @@ -492,16 +487,16 @@ namespace | ||||
|     void test_incrementable(X1 x1, X2 x2) | ||||
|     { | ||||
|         sanity_check( x1, x1, x2, x2 ); | ||||
|         BOOST_CHECK( (x1++).value() == x2++ ); | ||||
|         BOOST_CHECK( x1.value() == x2 ); | ||||
|         BOOST_TEST( (x1++).value() == x2++ ); | ||||
|         BOOST_TEST( x1.value() == x2 ); | ||||
|     } | ||||
|      | ||||
|     template <class X1, class X2> | ||||
|     void test_decrementable(X1 x1, X2 x2) | ||||
|     { | ||||
|         sanity_check( x1, x1, x2, x2 ); | ||||
|         BOOST_CHECK( (x1--).value() == x2-- ); | ||||
|         BOOST_CHECK( x1.value() == x2 ); | ||||
|         BOOST_TEST( (x1--).value() == x2-- ); | ||||
|         BOOST_TEST( x1.value() == x2 ); | ||||
|     } | ||||
|      | ||||
|     template <class X1, class Y1, class X2, class Y2> | ||||
| @@ -534,7 +529,7 @@ namespace | ||||
|     template <class Big, class Small> | ||||
|     struct tester | ||||
|     { | ||||
|         void operator()(boost::minstd_rand& randomizer) const | ||||
|         void operator()(boost::detail::minstd_rand& randomizer) const | ||||
|         { | ||||
|             Big    b1 = Big( randomizer() ); | ||||
|             Big    b2 = Big( randomizer() ); | ||||
| @@ -548,7 +543,7 @@ namespace | ||||
|     template <class Big, class Small> | ||||
|     struct tester_left | ||||
|     { | ||||
|         void operator()(boost::minstd_rand& randomizer) const | ||||
|         void operator()(boost::detail::minstd_rand& randomizer) const | ||||
|         { | ||||
|             Big    b1 = Big( randomizer() ); | ||||
|             Small  s = Small( randomizer() ); | ||||
| @@ -605,10 +600,10 @@ template Wrapped6<unsigned long, unsigned char>; | ||||
| template Wrapped6<unsigned int, unsigned char>; | ||||
| #endif | ||||
| 
 | ||||
| #define PRIVATE_EXPR_TEST(e, t)  BOOST_CHECK( ((e), (t)) ) | ||||
| #define PRIVATE_EXPR_TEST(e, t)  BOOST_TEST( ((e), (t)) ) | ||||
| 
 | ||||
| int | ||||
| test_main( int , char * [] ) | ||||
| main() | ||||
| { | ||||
|     using std::cout; | ||||
|     using std::endl; | ||||
| @@ -622,7 +617,7 @@ test_main( int , char * [] ) | ||||
|      | ||||
|     for (int n = 0; n < 1000; ++n)  // was 10,000 but took too long (Beman)
 | ||||
|     { | ||||
|         boost::minstd_rand r; | ||||
|         boost::detail::minstd_rand r; | ||||
|         tester<long, int>()(r); | ||||
|         tester<long, signed char>()(r); | ||||
|         tester<long, long>()(r); | ||||
| @@ -650,22 +645,22 @@ test_main( int , char * [] ) | ||||
|     MyInt i2(2); | ||||
|     MyInt i; | ||||
| 
 | ||||
|     BOOST_CHECK( i1.value() == 1 ); | ||||
|     BOOST_CHECK( i2.value() == 2 ); | ||||
|     BOOST_CHECK( i.value() == 0 ); | ||||
|     BOOST_TEST( i1.value() == 1 ); | ||||
|     BOOST_TEST( i2.value() == 2 ); | ||||
|     BOOST_TEST( i.value() == 0 ); | ||||
| 
 | ||||
|     cout << "Created MyInt objects.\n"; | ||||
| 
 | ||||
|     PRIVATE_EXPR_TEST( (i = i2), (i.value() == 2) ); | ||||
| 
 | ||||
|     BOOST_CHECK( static_cast<bool>(i2 == i) ); | ||||
|     BOOST_CHECK( static_cast<bool>(i1 != i2) ); | ||||
|     BOOST_CHECK( static_cast<bool>(i1 <  i2) ); | ||||
|     BOOST_CHECK( static_cast<bool>(i1 <= i2) ); | ||||
|     BOOST_CHECK( static_cast<bool>(i <= i2) ); | ||||
|     BOOST_CHECK( static_cast<bool>(i2 >  i1) ); | ||||
|     BOOST_CHECK( static_cast<bool>(i2 >= i1) ); | ||||
|     BOOST_CHECK( static_cast<bool>(i2 >= i) ); | ||||
|     BOOST_TEST( static_cast<bool>(i2 == i) ); | ||||
|     BOOST_TEST( static_cast<bool>(i1 != i2) ); | ||||
|     BOOST_TEST( static_cast<bool>(i1 <  i2) ); | ||||
|     BOOST_TEST( static_cast<bool>(i1 <= i2) ); | ||||
|     BOOST_TEST( static_cast<bool>(i <= i2) ); | ||||
|     BOOST_TEST( static_cast<bool>(i2 >  i1) ); | ||||
|     BOOST_TEST( static_cast<bool>(i2 >= i1) ); | ||||
|     BOOST_TEST( static_cast<bool>(i2 >= i) ); | ||||
| 
 | ||||
|     PRIVATE_EXPR_TEST( (i = i1 + i2), (i.value() == 3) ); | ||||
|     PRIVATE_EXPR_TEST( (i = i + i2), (i.value() == 5) ); | ||||
| @@ -689,86 +684,86 @@ test_main( int , char * [] ) | ||||
|     MyLong j2(2); | ||||
|     MyLong j; | ||||
| 
 | ||||
|     BOOST_CHECK( j1.value() == 1 ); | ||||
|     BOOST_CHECK( j2.value() == 2 ); | ||||
|     BOOST_CHECK( j.value() == 0 ); | ||||
|     BOOST_TEST( j1.value() == 1 ); | ||||
|     BOOST_TEST( j2.value() == 2 ); | ||||
|     BOOST_TEST( j.value() == 0 ); | ||||
| 
 | ||||
|     cout << "Created MyLong objects.\n"; | ||||
| 
 | ||||
|     PRIVATE_EXPR_TEST( (j = j2), (j.value() == 2) ); | ||||
|      | ||||
|     BOOST_CHECK( static_cast<bool>(j2 == j) ); | ||||
|     BOOST_CHECK( static_cast<bool>(2 == j) ); | ||||
|     BOOST_CHECK( static_cast<bool>(j2 == 2) ); | ||||
|     BOOST_CHECK( static_cast<bool>(j == j2) ); | ||||
|     BOOST_CHECK( static_cast<bool>(j1 != j2) ); | ||||
|     BOOST_CHECK( static_cast<bool>(j1 != 2) ); | ||||
|     BOOST_CHECK( static_cast<bool>(1 != j2) ); | ||||
|     BOOST_CHECK( static_cast<bool>(j1 <  j2) ); | ||||
|     BOOST_CHECK( static_cast<bool>(1 <  j2) ); | ||||
|     BOOST_CHECK( static_cast<bool>(j1 <  2) ); | ||||
|     BOOST_CHECK( static_cast<bool>(j1 <= j2) ); | ||||
|     BOOST_CHECK( static_cast<bool>(1 <= j2) ); | ||||
|     BOOST_CHECK( static_cast<bool>(j1 <= j) ); | ||||
|     BOOST_CHECK( static_cast<bool>(j <= j2) ); | ||||
|     BOOST_CHECK( static_cast<bool>(2 <= j2) ); | ||||
|     BOOST_CHECK( static_cast<bool>(j <= 2) ); | ||||
|     BOOST_CHECK( static_cast<bool>(j2 >  j1) ); | ||||
|     BOOST_CHECK( static_cast<bool>(2 >  j1) ); | ||||
|     BOOST_CHECK( static_cast<bool>(j2 >  1) ); | ||||
|     BOOST_CHECK( static_cast<bool>(j2 >= j1) ); | ||||
|     BOOST_CHECK( static_cast<bool>(2 >= j1) ); | ||||
|     BOOST_CHECK( static_cast<bool>(j2 >= 1) ); | ||||
|     BOOST_CHECK( static_cast<bool>(j2 >= j) ); | ||||
|     BOOST_CHECK( static_cast<bool>(2 >= j) ); | ||||
|     BOOST_CHECK( static_cast<bool>(j2 >= 2) ); | ||||
|     BOOST_TEST( static_cast<bool>(j2 == j) ); | ||||
|     BOOST_TEST( static_cast<bool>(2 == j) ); | ||||
|     BOOST_TEST( static_cast<bool>(j2 == 2) ); | ||||
|     BOOST_TEST( static_cast<bool>(j == j2) ); | ||||
|     BOOST_TEST( static_cast<bool>(j1 != j2) ); | ||||
|     BOOST_TEST( static_cast<bool>(j1 != 2) ); | ||||
|     BOOST_TEST( static_cast<bool>(1 != j2) ); | ||||
|     BOOST_TEST( static_cast<bool>(j1 <  j2) ); | ||||
|     BOOST_TEST( static_cast<bool>(1 <  j2) ); | ||||
|     BOOST_TEST( static_cast<bool>(j1 <  2) ); | ||||
|     BOOST_TEST( static_cast<bool>(j1 <= j2) ); | ||||
|     BOOST_TEST( static_cast<bool>(1 <= j2) ); | ||||
|     BOOST_TEST( static_cast<bool>(j1 <= j) ); | ||||
|     BOOST_TEST( static_cast<bool>(j <= j2) ); | ||||
|     BOOST_TEST( static_cast<bool>(2 <= j2) ); | ||||
|     BOOST_TEST( static_cast<bool>(j <= 2) ); | ||||
|     BOOST_TEST( static_cast<bool>(j2 >  j1) ); | ||||
|     BOOST_TEST( static_cast<bool>(2 >  j1) ); | ||||
|     BOOST_TEST( static_cast<bool>(j2 >  1) ); | ||||
|     BOOST_TEST( static_cast<bool>(j2 >= j1) ); | ||||
|     BOOST_TEST( static_cast<bool>(2 >= j1) ); | ||||
|     BOOST_TEST( static_cast<bool>(j2 >= 1) ); | ||||
|     BOOST_TEST( static_cast<bool>(j2 >= j) ); | ||||
|     BOOST_TEST( static_cast<bool>(2 >= j) ); | ||||
|     BOOST_TEST( static_cast<bool>(j2 >= 2) ); | ||||
| 
 | ||||
|     BOOST_CHECK( static_cast<bool>((j1 + 2) == 3) ); | ||||
|     BOOST_CHECK( static_cast<bool>((1 + j2) == 3) ); | ||||
|     BOOST_TEST( static_cast<bool>((j1 + 2) == 3) ); | ||||
|     BOOST_TEST( static_cast<bool>((1 + j2) == 3) ); | ||||
|     PRIVATE_EXPR_TEST( (j = j1 + j2), (j.value() == 3) ); | ||||
|      | ||||
|     BOOST_CHECK( static_cast<bool>((j + 2) == 5) ); | ||||
|     BOOST_CHECK( static_cast<bool>((3 + j2) == 5) ); | ||||
|     BOOST_TEST( static_cast<bool>((j + 2) == 5) ); | ||||
|     BOOST_TEST( static_cast<bool>((3 + j2) == 5) ); | ||||
|     PRIVATE_EXPR_TEST( (j = j + j2), (j.value() == 5) ); | ||||
|      | ||||
|     BOOST_CHECK( static_cast<bool>((j - 1) == 4) ); | ||||
|     BOOST_TEST( static_cast<bool>((j - 1) == 4) ); | ||||
|     PRIVATE_EXPR_TEST( (j = j - j1), (j.value() == 4) ); | ||||
|      | ||||
|     BOOST_CHECK( static_cast<bool>((j * 2) == 8) ); | ||||
|     BOOST_CHECK( static_cast<bool>((4 * j2) == 8) ); | ||||
|     BOOST_TEST( static_cast<bool>((j * 2) == 8) ); | ||||
|     BOOST_TEST( static_cast<bool>((4 * j2) == 8) ); | ||||
|     PRIVATE_EXPR_TEST( (j = j * j2), (j.value() == 8) ); | ||||
|      | ||||
|     BOOST_CHECK( static_cast<bool>((j / 2) == 4) ); | ||||
|     BOOST_TEST( static_cast<bool>((j / 2) == 4) ); | ||||
|     PRIVATE_EXPR_TEST( (j = j / j2), (j.value() == 4) ); | ||||
|      | ||||
|     BOOST_CHECK( static_cast<bool>((j % 3) == 1) ); | ||||
|     BOOST_TEST( static_cast<bool>((j % 3) == 1) ); | ||||
|     PRIVATE_EXPR_TEST( (j = j % ( j - j1 )), (j.value() == 1) ); | ||||
|      | ||||
|     PRIVATE_EXPR_TEST( (j = j2 + j2), (j.value() == 4) ); | ||||
|      | ||||
|     BOOST_CHECK( static_cast<bool>((1 | j2 | j) == 7) ); | ||||
|     BOOST_CHECK( static_cast<bool>((j1 | 2 | j) == 7) ); | ||||
|     BOOST_CHECK( static_cast<bool>((j1 | j2 | 4) == 7) ); | ||||
|     BOOST_TEST( static_cast<bool>((1 | j2 | j) == 7) ); | ||||
|     BOOST_TEST( static_cast<bool>((j1 | 2 | j) == 7) ); | ||||
|     BOOST_TEST( static_cast<bool>((j1 | j2 | 4) == 7) ); | ||||
|     PRIVATE_EXPR_TEST( (j = j1 | j2 | j), (j.value() == 7) ); | ||||
|      | ||||
|     BOOST_CHECK( static_cast<bool>((7 & j2) == 2) ); | ||||
|     BOOST_CHECK( static_cast<bool>((j & 2) == 2) ); | ||||
|     BOOST_TEST( static_cast<bool>((7 & j2) == 2) ); | ||||
|     BOOST_TEST( static_cast<bool>((j & 2) == 2) ); | ||||
|     PRIVATE_EXPR_TEST( (j = j & j2), (j.value() == 2) ); | ||||
|      | ||||
|     PRIVATE_EXPR_TEST( (j = j | j1), (j.value() == 3) ); | ||||
|      | ||||
|     BOOST_CHECK( static_cast<bool>((3 ^ j1) == 2) ); | ||||
|     BOOST_CHECK( static_cast<bool>((j ^ 1) == 2) ); | ||||
|     BOOST_TEST( static_cast<bool>((3 ^ j1) == 2) ); | ||||
|     BOOST_TEST( static_cast<bool>((j ^ 1) == 2) ); | ||||
|     PRIVATE_EXPR_TEST( (j = j ^ j1), (j.value() == 2) ); | ||||
|      | ||||
|     PRIVATE_EXPR_TEST( (j = ( j + j1 ) * ( j2 | j1 )), (j.value() == 9) ); | ||||
| 
 | ||||
|     BOOST_CHECK( static_cast<bool>((j1 << 2) == 4) ); | ||||
|     BOOST_CHECK( static_cast<bool>((j2 << 1) == 4) ); | ||||
|     BOOST_TEST( static_cast<bool>((j1 << 2) == 4) ); | ||||
|     BOOST_TEST( static_cast<bool>((j2 << 1) == 4) ); | ||||
|     PRIVATE_EXPR_TEST( (j = j1 << j2), (j.value() == 4) ); | ||||
| 
 | ||||
|     BOOST_CHECK( static_cast<bool>((j >> 2) == 1) ); | ||||
|     BOOST_CHECK( static_cast<bool>((j2 >> 1) == 1) ); | ||||
|     BOOST_TEST( static_cast<bool>((j >> 2) == 1) ); | ||||
|     BOOST_TEST( static_cast<bool>((j2 >> 1) == 1) ); | ||||
|     PRIVATE_EXPR_TEST( (j = j2 >> j1), (j.value() == 1) ); | ||||
|      | ||||
|     cout << "Performed tests on MyLong objects.\n"; | ||||
| @@ -777,22 +772,22 @@ test_main( int , char * [] ) | ||||
|     MyChar k2(2); | ||||
|     MyChar k; | ||||
| 
 | ||||
|     BOOST_CHECK( k1.value() == 1 ); | ||||
|     BOOST_CHECK( k2.value() == 2 ); | ||||
|     BOOST_CHECK( k.value() == 0 ); | ||||
|     BOOST_TEST( k1.value() == 1 ); | ||||
|     BOOST_TEST( k2.value() == 2 ); | ||||
|     BOOST_TEST( k.value() == 0 ); | ||||
| 
 | ||||
|     cout << "Created MyChar objects.\n"; | ||||
| 
 | ||||
|     PRIVATE_EXPR_TEST( (k = k2), (k.value() == 2) ); | ||||
| 
 | ||||
|     BOOST_CHECK( static_cast<bool>(k2 == k) ); | ||||
|     BOOST_CHECK( static_cast<bool>(k1 != k2) ); | ||||
|     BOOST_CHECK( static_cast<bool>(k1 <  k2) ); | ||||
|     BOOST_CHECK( static_cast<bool>(k1 <= k2) ); | ||||
|     BOOST_CHECK( static_cast<bool>(k <= k2) ); | ||||
|     BOOST_CHECK( static_cast<bool>(k2 >  k1) ); | ||||
|     BOOST_CHECK( static_cast<bool>(k2 >= k1) ); | ||||
|     BOOST_CHECK( static_cast<bool>(k2 >= k) ); | ||||
|     BOOST_TEST( static_cast<bool>(k2 == k) ); | ||||
|     BOOST_TEST( static_cast<bool>(k1 != k2) ); | ||||
|     BOOST_TEST( static_cast<bool>(k1 <  k2) ); | ||||
|     BOOST_TEST( static_cast<bool>(k1 <= k2) ); | ||||
|     BOOST_TEST( static_cast<bool>(k <= k2) ); | ||||
|     BOOST_TEST( static_cast<bool>(k2 >  k1) ); | ||||
|     BOOST_TEST( static_cast<bool>(k2 >= k1) ); | ||||
|     BOOST_TEST( static_cast<bool>(k2 >= k) ); | ||||
|      | ||||
|     cout << "Performed tests on MyChar objects.\n"; | ||||
| 
 | ||||
| @@ -800,39 +795,39 @@ test_main( int , char * [] ) | ||||
|     MyShort l2(2); | ||||
|     MyShort l; | ||||
| 
 | ||||
|     BOOST_CHECK( l1.value() == 1 ); | ||||
|     BOOST_CHECK( l2.value() == 2 ); | ||||
|     BOOST_CHECK( l.value() == 0 ); | ||||
|     BOOST_TEST( l1.value() == 1 ); | ||||
|     BOOST_TEST( l2.value() == 2 ); | ||||
|     BOOST_TEST( l.value() == 0 ); | ||||
| 
 | ||||
|     cout << "Created MyShort objects.\n"; | ||||
| 
 | ||||
|     PRIVATE_EXPR_TEST( (l = l2), (l.value() == 2) ); | ||||
|      | ||||
|     BOOST_CHECK( static_cast<bool>(l2 == l) ); | ||||
|     BOOST_CHECK( static_cast<bool>(2 == l) ); | ||||
|     BOOST_CHECK( static_cast<bool>(l2 == 2) ); | ||||
|     BOOST_CHECK( static_cast<bool>(l == l2) ); | ||||
|     BOOST_CHECK( static_cast<bool>(l1 != l2) ); | ||||
|     BOOST_CHECK( static_cast<bool>(l1 != 2) ); | ||||
|     BOOST_CHECK( static_cast<bool>(1 != l2) ); | ||||
|     BOOST_CHECK( static_cast<bool>(l1 <  l2) ); | ||||
|     BOOST_CHECK( static_cast<bool>(1 <  l2) ); | ||||
|     BOOST_CHECK( static_cast<bool>(l1 <  2) ); | ||||
|     BOOST_CHECK( static_cast<bool>(l1 <= l2) ); | ||||
|     BOOST_CHECK( static_cast<bool>(1 <= l2) ); | ||||
|     BOOST_CHECK( static_cast<bool>(l1 <= l) ); | ||||
|     BOOST_CHECK( static_cast<bool>(l <= l2) ); | ||||
|     BOOST_CHECK( static_cast<bool>(2 <= l2) ); | ||||
|     BOOST_CHECK( static_cast<bool>(l <= 2) ); | ||||
|     BOOST_CHECK( static_cast<bool>(l2 >  l1) ); | ||||
|     BOOST_CHECK( static_cast<bool>(2 >  l1) ); | ||||
|     BOOST_CHECK( static_cast<bool>(l2 >  1) ); | ||||
|     BOOST_CHECK( static_cast<bool>(l2 >= l1) ); | ||||
|     BOOST_CHECK( static_cast<bool>(2 >= l1) ); | ||||
|     BOOST_CHECK( static_cast<bool>(l2 >= 1) ); | ||||
|     BOOST_CHECK( static_cast<bool>(l2 >= l) ); | ||||
|     BOOST_CHECK( static_cast<bool>(2 >= l) ); | ||||
|     BOOST_CHECK( static_cast<bool>(l2 >= 2) ); | ||||
|     BOOST_TEST( static_cast<bool>(l2 == l) ); | ||||
|     BOOST_TEST( static_cast<bool>(2 == l) ); | ||||
|     BOOST_TEST( static_cast<bool>(l2 == 2) ); | ||||
|     BOOST_TEST( static_cast<bool>(l == l2) ); | ||||
|     BOOST_TEST( static_cast<bool>(l1 != l2) ); | ||||
|     BOOST_TEST( static_cast<bool>(l1 != 2) ); | ||||
|     BOOST_TEST( static_cast<bool>(1 != l2) ); | ||||
|     BOOST_TEST( static_cast<bool>(l1 <  l2) ); | ||||
|     BOOST_TEST( static_cast<bool>(1 <  l2) ); | ||||
|     BOOST_TEST( static_cast<bool>(l1 <  2) ); | ||||
|     BOOST_TEST( static_cast<bool>(l1 <= l2) ); | ||||
|     BOOST_TEST( static_cast<bool>(1 <= l2) ); | ||||
|     BOOST_TEST( static_cast<bool>(l1 <= l) ); | ||||
|     BOOST_TEST( static_cast<bool>(l <= l2) ); | ||||
|     BOOST_TEST( static_cast<bool>(2 <= l2) ); | ||||
|     BOOST_TEST( static_cast<bool>(l <= 2) ); | ||||
|     BOOST_TEST( static_cast<bool>(l2 >  l1) ); | ||||
|     BOOST_TEST( static_cast<bool>(2 >  l1) ); | ||||
|     BOOST_TEST( static_cast<bool>(l2 >  1) ); | ||||
|     BOOST_TEST( static_cast<bool>(l2 >= l1) ); | ||||
|     BOOST_TEST( static_cast<bool>(2 >= l1) ); | ||||
|     BOOST_TEST( static_cast<bool>(l2 >= 1) ); | ||||
|     BOOST_TEST( static_cast<bool>(l2 >= l) ); | ||||
|     BOOST_TEST( static_cast<bool>(2 >= l) ); | ||||
|     BOOST_TEST( static_cast<bool>(l2 >= 2) ); | ||||
|      | ||||
|     cout << "Performed tests on MyShort objects.\n"; | ||||
|      | ||||
| @@ -842,44 +837,44 @@ test_main( int , char * [] ) | ||||
|     MyDoubleInt di; | ||||
|     MyDoubleInt tmp; | ||||
| 
 | ||||
|     BOOST_CHECK( di1.value() == 1 ); | ||||
|     BOOST_CHECK( di2.value() == 2 ); | ||||
|     BOOST_CHECK( di2.value() == 2 ); | ||||
|     BOOST_CHECK( di.value() == 0 ); | ||||
|     BOOST_TEST( di1.value() == 1 ); | ||||
|     BOOST_TEST( di2.value() == 2 ); | ||||
|     BOOST_TEST( di2.value() == 2 ); | ||||
|     BOOST_TEST( di.value() == 0 ); | ||||
| 
 | ||||
|     cout << "Created MyDoubleInt objects.\n"; | ||||
| 
 | ||||
|     PRIVATE_EXPR_TEST( (di = di2), (di.value() == 2) ); | ||||
|      | ||||
|     BOOST_CHECK( static_cast<bool>(di2 == di) ); | ||||
|     BOOST_CHECK( static_cast<bool>(2 == di) ); | ||||
|     BOOST_CHECK( static_cast<bool>(di == 2) ); | ||||
|     BOOST_CHECK( static_cast<bool>(di1 < di2) ); | ||||
|     BOOST_CHECK( static_cast<bool>(1 < di2) ); | ||||
|     BOOST_CHECK( static_cast<bool>(di1 <= di2) ); | ||||
|     BOOST_CHECK( static_cast<bool>(1 <= di2) ); | ||||
|     BOOST_CHECK( static_cast<bool>(di2 > di1) ); | ||||
|     BOOST_CHECK( static_cast<bool>(di2 > 1) ); | ||||
|     BOOST_CHECK( static_cast<bool>(di2 >= di1) ); | ||||
|     BOOST_CHECK( static_cast<bool>(di2 >= 1) ); | ||||
|     BOOST_CHECK( static_cast<bool>(di1 / di2 == half) ); | ||||
|     BOOST_CHECK( static_cast<bool>(di1 / 2 == half) ); | ||||
|     BOOST_CHECK( static_cast<bool>(1 / di2 == half) ); | ||||
|     BOOST_TEST( static_cast<bool>(di2 == di) ); | ||||
|     BOOST_TEST( static_cast<bool>(2 == di) ); | ||||
|     BOOST_TEST( static_cast<bool>(di == 2) ); | ||||
|     BOOST_TEST( static_cast<bool>(di1 < di2) ); | ||||
|     BOOST_TEST( static_cast<bool>(1 < di2) ); | ||||
|     BOOST_TEST( static_cast<bool>(di1 <= di2) ); | ||||
|     BOOST_TEST( static_cast<bool>(1 <= di2) ); | ||||
|     BOOST_TEST( static_cast<bool>(di2 > di1) ); | ||||
|     BOOST_TEST( static_cast<bool>(di2 > 1) ); | ||||
|     BOOST_TEST( static_cast<bool>(di2 >= di1) ); | ||||
|     BOOST_TEST( static_cast<bool>(di2 >= 1) ); | ||||
|     BOOST_TEST( static_cast<bool>(di1 / di2 == half) ); | ||||
|     BOOST_TEST( static_cast<bool>(di1 / 2 == half) ); | ||||
|     BOOST_TEST( static_cast<bool>(1 / di2 == half) ); | ||||
|     PRIVATE_EXPR_TEST( (tmp=di1), static_cast<bool>((tmp/=2) == half) ); | ||||
|     PRIVATE_EXPR_TEST( (tmp=di1), static_cast<bool>((tmp/=di2) == half) ); | ||||
|     BOOST_CHECK( static_cast<bool>(di1 * di2 == di2) ); | ||||
|     BOOST_CHECK( static_cast<bool>(di1 * 2 == di2) ); | ||||
|     BOOST_CHECK( static_cast<bool>(1 * di2 == di2) ); | ||||
|     BOOST_TEST( static_cast<bool>(di1 * di2 == di2) ); | ||||
|     BOOST_TEST( static_cast<bool>(di1 * 2 == di2) ); | ||||
|     BOOST_TEST( static_cast<bool>(1 * di2 == di2) ); | ||||
|     PRIVATE_EXPR_TEST( (tmp=di1), static_cast<bool>((tmp*=2) == di2) ); | ||||
|     PRIVATE_EXPR_TEST( (tmp=di1), static_cast<bool>((tmp*=di2) == di2) ); | ||||
|     BOOST_CHECK( static_cast<bool>(di2 - di1 == di1) ); | ||||
|     BOOST_CHECK( static_cast<bool>(di2 - 1 == di1) ); | ||||
|     BOOST_CHECK( static_cast<bool>(2 - di1 == di1) ); | ||||
|     BOOST_TEST( static_cast<bool>(di2 - di1 == di1) ); | ||||
|     BOOST_TEST( static_cast<bool>(di2 - 1 == di1) ); | ||||
|     BOOST_TEST( static_cast<bool>(2 - di1 == di1) ); | ||||
|     PRIVATE_EXPR_TEST( (tmp=di2), static_cast<bool>((tmp-=1) == di1) ); | ||||
|     PRIVATE_EXPR_TEST( (tmp=di2), static_cast<bool>((tmp-=di1) == di1) ); | ||||
|     BOOST_CHECK( static_cast<bool>(di1 + di1 == di2) ); | ||||
|     BOOST_CHECK( static_cast<bool>(di1 + 1 == di2) ); | ||||
|     BOOST_CHECK( static_cast<bool>(1 + di1 == di2) ); | ||||
|     BOOST_TEST( static_cast<bool>(di1 + di1 == di2) ); | ||||
|     BOOST_TEST( static_cast<bool>(di1 + 1 == di2) ); | ||||
|     BOOST_TEST( static_cast<bool>(1 + di1 == di2) ); | ||||
|     PRIVATE_EXPR_TEST( (tmp=di1), static_cast<bool>((tmp+=1) == di2) ); | ||||
|     PRIVATE_EXPR_TEST( (tmp=di1), static_cast<bool>((tmp+=di1) == di2) ); | ||||
| 
 | ||||
| @@ -890,52 +885,52 @@ test_main( int , char * [] ) | ||||
|     MyLongInt li; | ||||
|     MyLongInt tmp2; | ||||
| 
 | ||||
|     BOOST_CHECK( li1.value() == 1 ); | ||||
|     BOOST_CHECK( li2.value() == 2 ); | ||||
|     BOOST_CHECK( li.value() == 0 ); | ||||
|     BOOST_TEST( li1.value() == 1 ); | ||||
|     BOOST_TEST( li2.value() == 2 ); | ||||
|     BOOST_TEST( li.value() == 0 ); | ||||
| 
 | ||||
|     cout << "Created MyLongInt objects.\n"; | ||||
| 
 | ||||
|     PRIVATE_EXPR_TEST( (li = li2), (li.value() == 2) ); | ||||
|      | ||||
|     BOOST_CHECK( static_cast<bool>(li2 == li) ); | ||||
|     BOOST_CHECK( static_cast<bool>(2 == li) ); | ||||
|     BOOST_CHECK( static_cast<bool>(li == 2) ); | ||||
|     BOOST_CHECK( static_cast<bool>(li1 < li2) ); | ||||
|     BOOST_CHECK( static_cast<bool>(1 < li2) ); | ||||
|     BOOST_CHECK( static_cast<bool>(li1 <= li2) ); | ||||
|     BOOST_CHECK( static_cast<bool>(1 <= li2) ); | ||||
|     BOOST_CHECK( static_cast<bool>(li2 > li1) ); | ||||
|     BOOST_CHECK( static_cast<bool>(li2 > 1) ); | ||||
|     BOOST_CHECK( static_cast<bool>(li2 >= li1) ); | ||||
|     BOOST_CHECK( static_cast<bool>(li2 >= 1) ); | ||||
|     BOOST_CHECK( static_cast<bool>(li1 % li2 == li1) ); | ||||
|     BOOST_CHECK( static_cast<bool>(li1 % 2 == li1) ); | ||||
|     BOOST_CHECK( static_cast<bool>(1 % li2 == li1) ); | ||||
|     BOOST_TEST( static_cast<bool>(li2 == li) ); | ||||
|     BOOST_TEST( static_cast<bool>(2 == li) ); | ||||
|     BOOST_TEST( static_cast<bool>(li == 2) ); | ||||
|     BOOST_TEST( static_cast<bool>(li1 < li2) ); | ||||
|     BOOST_TEST( static_cast<bool>(1 < li2) ); | ||||
|     BOOST_TEST( static_cast<bool>(li1 <= li2) ); | ||||
|     BOOST_TEST( static_cast<bool>(1 <= li2) ); | ||||
|     BOOST_TEST( static_cast<bool>(li2 > li1) ); | ||||
|     BOOST_TEST( static_cast<bool>(li2 > 1) ); | ||||
|     BOOST_TEST( static_cast<bool>(li2 >= li1) ); | ||||
|     BOOST_TEST( static_cast<bool>(li2 >= 1) ); | ||||
|     BOOST_TEST( static_cast<bool>(li1 % li2 == li1) ); | ||||
|     BOOST_TEST( static_cast<bool>(li1 % 2 == li1) ); | ||||
|     BOOST_TEST( static_cast<bool>(1 % li2 == li1) ); | ||||
|     PRIVATE_EXPR_TEST( (tmp2=li1), static_cast<bool>((tmp2%=2) == li1) ); | ||||
|     PRIVATE_EXPR_TEST( (tmp2=li1), static_cast<bool>((tmp2%=li2) == li1) ); | ||||
|     BOOST_CHECK( static_cast<bool>(li1 / li2 == 0) ); | ||||
|     BOOST_CHECK( static_cast<bool>(li1 / 2 == 0) ); | ||||
|     BOOST_CHECK( static_cast<bool>(1 / li2 == 0) ); | ||||
|     BOOST_TEST( static_cast<bool>(li1 / li2 == 0) ); | ||||
|     BOOST_TEST( static_cast<bool>(li1 / 2 == 0) ); | ||||
|     BOOST_TEST( static_cast<bool>(1 / li2 == 0) ); | ||||
|     PRIVATE_EXPR_TEST( (tmp2=li1), static_cast<bool>((tmp2/=2) == 0) ); | ||||
|     PRIVATE_EXPR_TEST( (tmp2=li1), static_cast<bool>((tmp2/=li2) == 0) ); | ||||
|     BOOST_CHECK( static_cast<bool>(li1 * li2 == li2) ); | ||||
|     BOOST_CHECK( static_cast<bool>(li1 * 2 == li2) ); | ||||
|     BOOST_CHECK( static_cast<bool>(1 * li2 == li2) ); | ||||
|     BOOST_TEST( static_cast<bool>(li1 * li2 == li2) ); | ||||
|     BOOST_TEST( static_cast<bool>(li1 * 2 == li2) ); | ||||
|     BOOST_TEST( static_cast<bool>(1 * li2 == li2) ); | ||||
|     PRIVATE_EXPR_TEST( (tmp2=li1), static_cast<bool>((tmp2*=2) == li2) ); | ||||
|     PRIVATE_EXPR_TEST( (tmp2=li1), static_cast<bool>((tmp2*=li2) == li2) ); | ||||
|     BOOST_CHECK( static_cast<bool>(li2 - li1 == li1) ); | ||||
|     BOOST_CHECK( static_cast<bool>(li2 - 1 == li1) ); | ||||
|     BOOST_CHECK( static_cast<bool>(2 - li1 == li1) ); | ||||
|     BOOST_TEST( static_cast<bool>(li2 - li1 == li1) ); | ||||
|     BOOST_TEST( static_cast<bool>(li2 - 1 == li1) ); | ||||
|     BOOST_TEST( static_cast<bool>(2 - li1 == li1) ); | ||||
|     PRIVATE_EXPR_TEST( (tmp2=li2), static_cast<bool>((tmp2-=1) == li1) ); | ||||
|     PRIVATE_EXPR_TEST( (tmp2=li2), static_cast<bool>((tmp2-=li1) == li1) ); | ||||
|     BOOST_CHECK( static_cast<bool>(li1 + li1 == li2) ); | ||||
|     BOOST_CHECK( static_cast<bool>(li1 + 1 == li2) ); | ||||
|     BOOST_CHECK( static_cast<bool>(1 + li1 == li2) ); | ||||
|     BOOST_TEST( static_cast<bool>(li1 + li1 == li2) ); | ||||
|     BOOST_TEST( static_cast<bool>(li1 + 1 == li2) ); | ||||
|     BOOST_TEST( static_cast<bool>(1 + li1 == li2) ); | ||||
|     PRIVATE_EXPR_TEST( (tmp2=li1), static_cast<bool>((tmp2+=1) == li2) ); | ||||
|     PRIVATE_EXPR_TEST( (tmp2=li1), static_cast<bool>((tmp2+=li1) == li2) ); | ||||
| 
 | ||||
|     cout << "Performed tests on MyLongInt objects.\n"; | ||||
| 
 | ||||
|     return boost::exit_success; | ||||
|     return boost::report_errors(); | ||||
| } | ||||
							
								
								
									
										136
									
								
								test/ostream_string_test.cpp
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										136
									
								
								test/ostream_string_test.cpp
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,136 @@ | ||||
| /* | ||||
| Copyright 2019 Glen Joseph Fernandes | ||||
| (glenjofe@gmail.com) | ||||
|  | ||||
| Distributed under the Boost Software License, Version 1.0. | ||||
| (http://www.boost.org/LICENSE_1_0.txt) | ||||
| */ | ||||
| #include <boost/core/lightweight_test.hpp> | ||||
| #include <boost/utility/ostream_string.hpp> | ||||
| #include <sstream> | ||||
| #include <string> | ||||
|  | ||||
| int main() | ||||
| { | ||||
|     { | ||||
|         std::ostringstream os; | ||||
|         os.width(1); | ||||
|         os.fill('.'); | ||||
|         os.setf(std::ios_base::left, std::ios_base::adjustfield); | ||||
|         boost::ostream_string(os, "xy", 2); | ||||
|         BOOST_TEST(os.good()); | ||||
|         BOOST_TEST(os.width() == 0); | ||||
|         BOOST_TEST(os.str() == "xy"); | ||||
|     } | ||||
|     { | ||||
|         std::wostringstream os; | ||||
|         os.width(1); | ||||
|         os.fill('.'); | ||||
|         os.setf(std::ios_base::left, std::ios_base::adjustfield); | ||||
|         boost::ostream_string(os, L"xy", 2); | ||||
|         BOOST_TEST(os.good()); | ||||
|         BOOST_TEST(os.width() == 0); | ||||
|         BOOST_TEST(os.str() == L"xy"); | ||||
|     } | ||||
|     { | ||||
|         std::ostringstream os; | ||||
|         os.width(1); | ||||
|         os.fill('.'); | ||||
|         os.setf(std::ios_base::right, std::ios_base::adjustfield); | ||||
|         boost::ostream_string(os, "xy", 2); | ||||
|         BOOST_TEST(os.good()); | ||||
|         BOOST_TEST(os.width() == 0); | ||||
|         BOOST_TEST(os.str() == "xy"); | ||||
|     } | ||||
|     { | ||||
|         std::wostringstream os; | ||||
|         os.width(1); | ||||
|         os.fill('.'); | ||||
|         os.setf(std::ios_base::right, std::ios_base::adjustfield); | ||||
|         boost::ostream_string(os, L"xy", 2); | ||||
|         BOOST_TEST(os.good()); | ||||
|         BOOST_TEST(os.width() == 0); | ||||
|         BOOST_TEST(os.str() == L"xy"); | ||||
|     } | ||||
|     { | ||||
|         std::ostringstream os; | ||||
|         os.width(4); | ||||
|         os.fill('.'); | ||||
|         os.setf(std::ios_base::left, std::ios_base::adjustfield); | ||||
|         boost::ostream_string(os, "xy", 2); | ||||
|         BOOST_TEST(os.good()); | ||||
|         BOOST_TEST(os.width() == 0); | ||||
|         BOOST_TEST(os.str() == "xy.."); | ||||
|     } | ||||
|     { | ||||
|         std::wostringstream os; | ||||
|         os.width(4); | ||||
|         os.fill(L'.'); | ||||
|         os.setf(std::ios_base::left, std::ios_base::adjustfield); | ||||
|         boost::ostream_string(os, L"xy", 2); | ||||
|         BOOST_TEST(os.good()); | ||||
|         BOOST_TEST(os.width() == 0); | ||||
|         BOOST_TEST(os.str() == L"xy.."); | ||||
|     } | ||||
|     { | ||||
|         std::ostringstream os; | ||||
|         os.width(4); | ||||
|         os.fill('.'); | ||||
|         os.setf(std::ios_base::right, std::ios_base::adjustfield); | ||||
|         boost::ostream_string(os, "xy", 2); | ||||
|         BOOST_TEST(os.good()); | ||||
|         BOOST_TEST(os.width() == 0); | ||||
|         BOOST_TEST(os.str() == "..xy"); | ||||
|     } | ||||
|     { | ||||
|         std::wostringstream os; | ||||
|         os.width(4); | ||||
|         os.fill(L'.'); | ||||
|         os.setf(std::ios_base::right, std::ios_base::adjustfield); | ||||
|         boost::ostream_string(os, L"xy", 2); | ||||
|         BOOST_TEST(os.good()); | ||||
|         BOOST_TEST(os.width() == 0); | ||||
|         BOOST_TEST(os.str() == L"..xy"); | ||||
|     } | ||||
|     { | ||||
|         std::ostringstream os; | ||||
|         os.width(12); | ||||
|         os.fill('.'); | ||||
|         os.setf(std::ios_base::left, std::ios_base::adjustfield); | ||||
|         boost::ostream_string(os, "xy", 2); | ||||
|         BOOST_TEST(os.good()); | ||||
|         BOOST_TEST(os.width() == 0); | ||||
|         BOOST_TEST(os.str() == "xy.........."); | ||||
|     } | ||||
|     { | ||||
|         std::wostringstream os; | ||||
|         os.width(12); | ||||
|         os.fill(L'.'); | ||||
|         os.setf(std::ios_base::left, std::ios_base::adjustfield); | ||||
|         boost::ostream_string(os, L"xy", 2); | ||||
|         BOOST_TEST(os.good()); | ||||
|         BOOST_TEST(os.width() == 0); | ||||
|         BOOST_TEST(os.str() == L"xy.........."); | ||||
|     } | ||||
|     { | ||||
|         std::ostringstream os; | ||||
|         os.width(12); | ||||
|         os.fill('.'); | ||||
|         os.setf(std::ios_base::right, std::ios_base::adjustfield); | ||||
|         boost::ostream_string(os, "xy", 2); | ||||
|         BOOST_TEST(os.good()); | ||||
|         BOOST_TEST(os.width() == 0); | ||||
|         BOOST_TEST(os.str() == "..........xy"); | ||||
|     } | ||||
|     { | ||||
|         std::wostringstream os; | ||||
|         os.width(12); | ||||
|         os.fill(L'.'); | ||||
|         os.setf(std::ios_base::right, std::ios_base::adjustfield); | ||||
|         boost::ostream_string(os, L"xy", 2); | ||||
|         BOOST_TEST(os.good()); | ||||
|         BOOST_TEST(os.width() == 0); | ||||
|         BOOST_TEST(os.str() == L"..........xy"); | ||||
|     } | ||||
|     return boost::report_errors(); | ||||
| } | ||||
| @@ -297,6 +297,12 @@ int main() | ||||
|   BOOST_STATIC_ASSERT((is_same<result_of<const no_result_type_or_result_template<void>(void)>::type, cv_overload_check<const int> >::value)); | ||||
|   BOOST_STATIC_ASSERT((is_same<result_of<volatile no_result_type_or_result_template<void>(void)>::type, cv_overload_check<volatile int> >::value)); | ||||
|   BOOST_STATIC_ASSERT((is_same<result_of<const volatile no_result_type_or_result_template<void>(void)>::type, cv_overload_check<const volatile int> >::value)); | ||||
|  | ||||
|   BOOST_STATIC_ASSERT((is_same<result_of<func_ptr&(char, float)>::type, int>::value)); | ||||
|   BOOST_STATIC_ASSERT((is_same<result_of<func_ptr const&(char, float)>::type, int>::value)); | ||||
|   BOOST_STATIC_ASSERT((is_same<result_of<int_result_of&(double)>::type, int>::value)); | ||||
|   BOOST_STATIC_ASSERT((is_same<result_of<int_result_of const&(double)>::type, int>::value)); | ||||
|  | ||||
| #if !defined(BOOST_NO_CXX11_RVALUE_REFERENCES) | ||||
|   BOOST_STATIC_ASSERT((is_same<result_of<no_result_type_or_result(int&&)>::type, short>::value)); | ||||
|   BOOST_STATIC_ASSERT((is_same<result_of<no_result_type_or_result(int&)>::type, int>::value)); | ||||
|   | ||||
							
								
								
									
										26
									
								
								test/string_ref_from_rvalue.cpp
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										26
									
								
								test/string_ref_from_rvalue.cpp
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,26 @@ | ||||
| /* | ||||
|    Copyright (c) Marshall Clow 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) | ||||
|  | ||||
|     For more information, see http://www.boost.org | ||||
| */ | ||||
|  | ||||
| #include <iostream> | ||||
| #include <algorithm> | ||||
| #include <string> | ||||
|  | ||||
| #include <boost/utility/string_ref.hpp> | ||||
|  | ||||
| #if defined(BOOST_NO_CXX11_RVALUE_REFERENCES) || defined(BOOST_NO_CXX11_DELETED_FUNCTIONS) | ||||
| #error "Unsupported test" | ||||
| #endif | ||||
|  | ||||
| std::string makeatemp() { return "abc"; } | ||||
|  | ||||
| int main() | ||||
| { | ||||
|   boost::basic_string_ref<char> sv(makeatemp()); | ||||
|   return 0; | ||||
| } | ||||
| @@ -13,17 +13,16 @@ | ||||
|  | ||||
| #include <boost/utility/string_ref.hpp> | ||||
|  | ||||
| #define BOOST_TEST_MAIN | ||||
| #include <boost/test/unit_test.hpp> | ||||
| #include <boost/core/lightweight_test.hpp> | ||||
|  | ||||
| typedef boost::string_ref string_ref; | ||||
|  | ||||
| //  Should be equal | ||||
| void interop ( const std::string &str, string_ref ref ) { | ||||
| //  BOOST_CHECK ( str == ref ); | ||||
|     BOOST_CHECK ( str.size () == ref.size ()); | ||||
|     BOOST_CHECK ( std::equal ( str.begin (),  str.end (),  ref.begin ())); | ||||
|     BOOST_CHECK ( std::equal ( str.rbegin (), str.rend (), ref.rbegin ())); | ||||
| //  BOOST_TEST ( str == ref ); | ||||
|     BOOST_TEST ( str.size () == ref.size ()); | ||||
|     BOOST_TEST ( std::equal ( str.begin (),  str.end (),  ref.begin ())); | ||||
|     BOOST_TEST ( std::equal ( str.rbegin (), str.rend (), ref.rbegin ())); | ||||
|     } | ||||
|  | ||||
| void null_tests ( const char *p ) { | ||||
| @@ -34,10 +33,10 @@ void null_tests ( const char *p ) { | ||||
|     string_ref sr4 ( p ); | ||||
|     sr4.clear (); | ||||
|  | ||||
|     BOOST_CHECK ( sr1 == sr2 ); | ||||
|     BOOST_CHECK ( sr1 == sr3 ); | ||||
|     BOOST_CHECK ( sr2 == sr3 ); | ||||
|     BOOST_CHECK ( sr1 == sr4 ); | ||||
|     BOOST_TEST ( sr1 == sr2 ); | ||||
|     BOOST_TEST ( sr1 == sr3 ); | ||||
|     BOOST_TEST ( sr2 == sr3 ); | ||||
|     BOOST_TEST ( sr1 == sr4 ); | ||||
|     } | ||||
|  | ||||
| //  make sure that substrings work just like strings | ||||
| @@ -94,7 +93,7 @@ const char *test_strings [] = { | ||||
|     NULL | ||||
|     }; | ||||
|  | ||||
| BOOST_AUTO_TEST_CASE( test_main ) | ||||
| int main() | ||||
| { | ||||
|     const char **p = &test_strings[0]; | ||||
|  | ||||
| @@ -106,4 +105,6 @@ BOOST_AUTO_TEST_CASE( test_main ) | ||||
|  | ||||
|         p++; | ||||
|         } | ||||
|  | ||||
|     return boost::report_errors(); | ||||
| } | ||||
|   | ||||
| @@ -12,8 +12,7 @@ | ||||
|  | ||||
| #include <boost/utility/string_ref.hpp> | ||||
|  | ||||
| #define BOOST_TEST_MAIN | ||||
| #include <boost/test/unit_test.hpp> | ||||
| #include <boost/core/lightweight_test.hpp> | ||||
|  | ||||
| typedef boost::string_ref string_ref; | ||||
|  | ||||
| @@ -24,27 +23,27 @@ void ends_with ( const char *arg ) { | ||||
|     const char *p = arg; | ||||
|  | ||||
|     while ( *p ) { | ||||
|         BOOST_CHECK ( sr.ends_with ( p )); | ||||
|         BOOST_TEST ( sr.ends_with ( p )); | ||||
|         ++p; | ||||
|         } | ||||
|  | ||||
|     while ( !sr2.empty ()) { | ||||
|         BOOST_CHECK ( sr.ends_with ( sr2 )); | ||||
|         BOOST_TEST ( sr.ends_with ( sr2 )); | ||||
|         sr2.remove_prefix (1); | ||||
|         } | ||||
|  | ||||
|     sr2 = arg; | ||||
|     while ( !sr2.empty ()) { | ||||
|         BOOST_CHECK ( sr.ends_with ( sr2 )); | ||||
|         BOOST_TEST ( sr.ends_with ( sr2 )); | ||||
|         sr2.remove_prefix (1); | ||||
|         } | ||||
|  | ||||
|     char ch = sz == 0 ? '\0' : arg [ sz - 1 ]; | ||||
|     sr2 = arg; | ||||
|     if ( sz > 0 ) | ||||
|       BOOST_CHECK ( sr2.ends_with ( ch )); | ||||
|     BOOST_CHECK ( !sr2.ends_with ( ++ch )); | ||||
|     BOOST_CHECK ( sr2.ends_with ( string_ref ())); | ||||
|       BOOST_TEST ( sr2.ends_with ( ch )); | ||||
|     BOOST_TEST ( !sr2.ends_with ( ++ch )); | ||||
|     BOOST_TEST ( sr2.ends_with ( string_ref ())); | ||||
|     } | ||||
|  | ||||
| void starts_with ( const char *arg ) { | ||||
| @@ -54,21 +53,21 @@ void starts_with ( const char *arg ) { | ||||
|     const char *p = arg + std::strlen ( arg ) - 1; | ||||
|     while ( p >= arg ) { | ||||
|         std::string foo ( arg, p + 1 ); | ||||
|         BOOST_CHECK ( sr.starts_with ( foo )); | ||||
|         BOOST_TEST ( sr.starts_with ( foo )); | ||||
|         --p; | ||||
|         } | ||||
|  | ||||
|     while ( !sr2.empty ()) { | ||||
|         BOOST_CHECK ( sr.starts_with ( sr2 )); | ||||
|         BOOST_TEST ( sr.starts_with ( sr2 )); | ||||
|         sr2.remove_suffix (1); | ||||
|         } | ||||
|  | ||||
|     char ch = *arg; | ||||
|     sr2 = arg; | ||||
|   if ( sz > 0 ) | ||||
|     BOOST_CHECK ( sr2.starts_with ( ch )); | ||||
|     BOOST_CHECK ( !sr2.starts_with ( ++ch )); | ||||
|     BOOST_CHECK ( sr2.starts_with ( string_ref ())); | ||||
|     BOOST_TEST ( sr2.starts_with ( ch )); | ||||
|     BOOST_TEST ( !sr2.starts_with ( ++ch )); | ||||
|     BOOST_TEST ( sr2.starts_with ( string_ref ())); | ||||
|     } | ||||
|  | ||||
| void reverse ( const char *arg ) { | ||||
| @@ -78,14 +77,14 @@ void reverse ( const char *arg ) { | ||||
|     string_ref sr2 ( string1 ); | ||||
|     std::string string2 ( sr2.rbegin (), sr2.rend ()); | ||||
|  | ||||
|     BOOST_CHECK ( std::equal ( sr2.rbegin (), sr2.rend (), arg )); | ||||
|     BOOST_CHECK ( string2 == arg ); | ||||
|     BOOST_CHECK ( std::equal ( sr1.begin (), sr1.end (), string2.begin ())); | ||||
|     BOOST_TEST ( std::equal ( sr2.rbegin (), sr2.rend (), arg )); | ||||
|     BOOST_TEST ( string2 == arg ); | ||||
|     BOOST_TEST ( std::equal ( sr1.begin (), sr1.end (), string2.begin ())); | ||||
|     } | ||||
|  | ||||
| //	This helper function eliminates signed vs. unsigned warnings | ||||
| // This helper function eliminates signed vs. unsigned warnings | ||||
| string_ref::size_type ptr_diff ( const char *res, const char *base ) { | ||||
|     BOOST_CHECK ( res >= base ); | ||||
|     BOOST_TEST ( res >= base ); | ||||
|     return static_cast<string_ref::size_type> ( res - base ); | ||||
|     } | ||||
|  | ||||
| @@ -94,12 +93,16 @@ void find ( const char *arg ) { | ||||
|     string_ref sr2; | ||||
|     const char *p; | ||||
|  | ||||
| //	When we search for the empty string, we find it at position 0 | ||||
|     BOOST_TEST ( sr1.find (sr2) == 0 ); | ||||
|     BOOST_TEST ( sr1.rfind(sr2) == 0 ); | ||||
|  | ||||
| //  Look for each character in the string(searching from the start) | ||||
|     p = arg; | ||||
|     sr1 = arg; | ||||
|     while ( *p ) { | ||||
|       string_ref::size_type pos = sr1.find(*p); | ||||
|       BOOST_CHECK ( pos != string_ref::npos && ( pos <= ptr_diff ( p, arg ))); | ||||
|       BOOST_TEST ( pos != string_ref::npos && ( pos <= ptr_diff ( p, arg ))); | ||||
|       ++p; | ||||
|       } | ||||
|  | ||||
| @@ -108,17 +111,17 @@ void find ( const char *arg ) { | ||||
|     sr1 = arg; | ||||
|     while ( *p ) { | ||||
|       string_ref::size_type pos = sr1.rfind(*p); | ||||
|       BOOST_CHECK ( pos != string_ref::npos && pos < sr1.size () && ( pos >= ptr_diff ( p, arg ))); | ||||
|       BOOST_TEST ( pos != string_ref::npos && pos < sr1.size () && ( pos >= ptr_diff ( p, arg ))); | ||||
|       ++p; | ||||
|       } | ||||
|  | ||||
| //	Look for pairs on characters (searching from the start) | ||||
| // Look for pairs on characters (searching from the start) | ||||
|     sr1 = arg; | ||||
|     p = arg; | ||||
|     while ( *p && *(p+1)) { | ||||
|         string_ref sr3 ( p, 2 ); | ||||
|         string_ref::size_type pos = sr1.find ( sr3 ); | ||||
|         BOOST_CHECK ( pos != string_ref::npos && pos <= static_cast<string_ref::size_type>( p - arg )); | ||||
|         BOOST_TEST ( pos != string_ref::npos && pos <= static_cast<string_ref::size_type>( p - arg )); | ||||
|         p++; | ||||
|         } | ||||
|  | ||||
| @@ -129,9 +132,9 @@ void find ( const char *arg ) { | ||||
|     for ( int ch = 1; ch < 256; ++ch ) { | ||||
|         string_ref::size_type pos = sr1.find(ch); | ||||
|         const char *strp = std::strchr ( arg, ch ); | ||||
|         BOOST_CHECK (( strp == NULL ) == ( pos == string_ref::npos )); | ||||
|         BOOST_TEST (( strp == NULL ) == ( pos == string_ref::npos )); | ||||
|         if ( strp != NULL ) | ||||
|             BOOST_CHECK ( ptr_diff ( strp, arg ) == pos ); | ||||
|             BOOST_TEST ( ptr_diff ( strp, arg ) == pos ); | ||||
|     } | ||||
|  | ||||
|     sr1 = arg; | ||||
| @@ -141,9 +144,9 @@ void find ( const char *arg ) { | ||||
|     for ( int ch = 1; ch < 256; ++ch ) { | ||||
|         string_ref::size_type pos = sr1.rfind(ch); | ||||
|         const char *strp = std::strrchr ( arg, ch ); | ||||
|         BOOST_CHECK (( strp == NULL ) == ( pos == string_ref::npos )); | ||||
|         BOOST_TEST (( strp == NULL ) == ( pos == string_ref::npos )); | ||||
|         if ( strp != NULL ) | ||||
|             BOOST_CHECK ( ptr_diff ( strp, arg ) == pos ); | ||||
|             BOOST_TEST ( ptr_diff ( strp, arg ) == pos ); | ||||
|     } | ||||
|  | ||||
|  | ||||
| @@ -152,7 +155,7 @@ void find ( const char *arg ) { | ||||
|     sr1 = arg; | ||||
|     while ( !sr1.empty ()) { | ||||
|         string_ref::size_type pos = sr1.find(*p); | ||||
|         BOOST_CHECK ( pos == 0 ); | ||||
|         BOOST_TEST ( pos == 0 ); | ||||
|         sr1.remove_prefix (1); | ||||
|         ++p; | ||||
|         } | ||||
| @@ -162,7 +165,7 @@ void find ( const char *arg ) { | ||||
|     p    = arg + std::strlen ( arg ) - 1; | ||||
|     while ( !sr1.empty ()) { | ||||
|         string_ref::size_type pos = sr1.rfind(*p); | ||||
|         BOOST_CHECK ( pos == sr1.size () - 1 ); | ||||
|         BOOST_TEST ( pos == sr1.size () - 1 ); | ||||
|         sr1.remove_suffix (1); | ||||
|         --p; | ||||
|         } | ||||
| @@ -172,7 +175,7 @@ void find ( const char *arg ) { | ||||
|     p    = arg; | ||||
|     while ( !sr1.empty ()) { | ||||
|         string_ref::size_type pos = sr1.find_first_of(*p); | ||||
|         BOOST_CHECK ( pos == 0 ); | ||||
|         BOOST_TEST ( pos == 0 ); | ||||
|         sr1.remove_prefix (1); | ||||
|         ++p; | ||||
|         } | ||||
| @@ -183,7 +186,7 @@ void find ( const char *arg ) { | ||||
|     p    = arg + std::strlen ( arg ) - 1; | ||||
|     while ( !sr1.empty ()) { | ||||
|         string_ref::size_type pos = sr1.find_last_of(*p); | ||||
|         BOOST_CHECK ( pos == sr1.size () - 1 ); | ||||
|         BOOST_TEST ( pos == sr1.size () - 1 ); | ||||
|         sr1.remove_suffix (1); | ||||
|         --p; | ||||
|         } | ||||
| @@ -192,8 +195,8 @@ void find ( const char *arg ) { | ||||
|     sr1 = arg; | ||||
|     sr2 = arg; | ||||
|     while ( !sr1.empty() ) { | ||||
|         BOOST_CHECK ( sr1.find_first_of ( sr2 )     == 0 ); | ||||
|         BOOST_CHECK ( sr1.find_first_not_of ( sr2 ) == string_ref::npos ); | ||||
|         BOOST_TEST ( sr1.find_first_of ( sr2 )     == 0 ); | ||||
|         BOOST_TEST ( sr1.find_first_not_of ( sr2 ) == string_ref::npos ); | ||||
|         sr1.remove_prefix ( 1 ); | ||||
|         } | ||||
|  | ||||
| @@ -202,14 +205,14 @@ void find ( const char *arg ) { | ||||
|     while ( *p ) { | ||||
|         string_ref::size_type pos1 = sr1.find_first_of(*p); | ||||
|         string_ref::size_type pos2 = sr1.find_first_not_of(*p); | ||||
|         BOOST_CHECK ( pos1 != string_ref::npos && pos1 < sr1.size () && pos1 <= ptr_diff ( p, arg )); | ||||
|         BOOST_TEST ( pos1 != string_ref::npos && pos1 < sr1.size () && pos1 <= ptr_diff ( p, arg )); | ||||
|         if ( pos2 != string_ref::npos ) { | ||||
|             for ( size_t i = 0 ; i < pos2; ++i ) | ||||
|                 BOOST_CHECK ( sr1[i] == *p ); | ||||
|             BOOST_CHECK ( sr1 [ pos2 ] != *p ); | ||||
|                 BOOST_TEST ( sr1[i] == *p ); | ||||
|             BOOST_TEST ( sr1 [ pos2 ] != *p ); | ||||
|             } | ||||
|  | ||||
|         BOOST_CHECK ( pos2 != pos1 ); | ||||
|         BOOST_TEST ( pos2 != pos1 ); | ||||
|         ++p; | ||||
|         } | ||||
|  | ||||
| @@ -217,8 +220,8 @@ void find ( const char *arg ) { | ||||
|     sr1 = arg; | ||||
|     sr2 = arg; | ||||
|     while ( !sr1.empty() ) { | ||||
|         BOOST_CHECK ( sr1.find_last_of ( sr2 )     == ( sr1.size () - 1 )); | ||||
|         BOOST_CHECK ( sr1.find_last_not_of ( sr2 ) == string_ref::npos ); | ||||
|         BOOST_TEST ( sr1.find_last_of ( sr2 )     == ( sr1.size () - 1 )); | ||||
|         BOOST_TEST ( sr1.find_last_not_of ( sr2 ) == string_ref::npos ); | ||||
|         sr1.remove_suffix ( 1 ); | ||||
|         } | ||||
|  | ||||
| @@ -227,15 +230,15 @@ void find ( const char *arg ) { | ||||
|     while ( *p ) { | ||||
|         string_ref::size_type pos1 = sr1.find_last_of(*p); | ||||
|         string_ref::size_type pos2 = sr1.find_last_not_of(*p); | ||||
|         BOOST_CHECK ( pos1 != string_ref::npos && pos1 < sr1.size () && pos1 >= ptr_diff ( p, arg )); | ||||
|         BOOST_CHECK ( pos2 == string_ref::npos || pos1 < sr1.size ()); | ||||
|         BOOST_TEST ( pos1 != string_ref::npos && pos1 < sr1.size () && pos1 >= ptr_diff ( p, arg )); | ||||
|         BOOST_TEST ( pos2 == string_ref::npos || pos1 < sr1.size ()); | ||||
|         if ( pos2 != string_ref::npos ) { | ||||
|             for ( size_t i = sr1.size () -1 ; i > pos2; --i ) | ||||
|                 BOOST_CHECK ( sr1[i] == *p ); | ||||
|             BOOST_CHECK ( sr1 [ pos2 ] != *p ); | ||||
|                 BOOST_TEST ( sr1[i] == *p ); | ||||
|             BOOST_TEST ( sr1 [ pos2 ] != *p ); | ||||
|             } | ||||
|  | ||||
|         BOOST_CHECK ( pos2 != pos1 ); | ||||
|         BOOST_TEST ( pos2 != pos1 ); | ||||
|         ++p; | ||||
|         } | ||||
|  | ||||
| @@ -249,13 +252,13 @@ void to_string ( const char *arg ) { | ||||
|  | ||||
|     str1.assign ( arg ); | ||||
|     sr1 = arg; | ||||
| //	str2 = sr1.to_string<std::allocator<char> > (); | ||||
| // str2 = sr1.to_string<std::allocator<char> > (); | ||||
|     str2 = sr1.to_string (); | ||||
|     BOOST_CHECK ( str1 == str2 ); | ||||
|     BOOST_TEST ( str1 == str2 ); | ||||
|  | ||||
| #ifndef BOOST_NO_CXX11_EXPLICIT_CONVERSION_OPERATORS | ||||
|     std::string str3 = static_cast<std::string> ( sr1 ); | ||||
|     BOOST_CHECK ( str1 == str3 ); | ||||
|     BOOST_TEST ( str1 == str3 ); | ||||
| #endif | ||||
|     } | ||||
|  | ||||
| @@ -266,28 +269,28 @@ void compare ( const char *arg ) { | ||||
|  | ||||
|     str1.assign ( arg ); | ||||
|     sr1 = arg; | ||||
|     BOOST_CHECK ( sr1  == sr1);	    // compare string_ref and string_ref | ||||
|     BOOST_CHECK ( sr1  == str1);	// compare string and string_ref | ||||
|     BOOST_CHECK ( str1 == sr1 );	// compare string_ref and string | ||||
|     BOOST_CHECK ( sr1  == arg );	// compare string_ref and pointer | ||||
|     BOOST_CHECK ( arg  == sr1 );	// compare pointer and string_ref | ||||
|     BOOST_TEST ( sr1  == sr1);     // compare string_ref and string_ref | ||||
|     BOOST_TEST ( sr1  == str1);    // compare string and string_ref | ||||
|     BOOST_TEST ( str1 == sr1 );    // compare string_ref and string | ||||
|     BOOST_TEST ( sr1  == arg );    // compare string_ref and pointer | ||||
|     BOOST_TEST ( arg  == sr1 );    // compare pointer and string_ref | ||||
|  | ||||
|     if ( sr1.size () > 0 ) { | ||||
|         (*str1.rbegin())++; | ||||
|         BOOST_CHECK ( sr1  != str1 ); | ||||
|         BOOST_CHECK ( str1 != sr1 ); | ||||
|         BOOST_CHECK ( sr1 < str1 ); | ||||
|         BOOST_CHECK ( sr1 <= str1 ); | ||||
|         BOOST_CHECK ( str1 > sr1 ); | ||||
|         BOOST_CHECK ( str1 >= sr1 ); | ||||
|         BOOST_TEST ( sr1  != str1 ); | ||||
|         BOOST_TEST ( str1 != sr1 ); | ||||
|         BOOST_TEST ( sr1 < str1 ); | ||||
|         BOOST_TEST ( sr1 <= str1 ); | ||||
|         BOOST_TEST ( str1 > sr1 ); | ||||
|         BOOST_TEST ( str1 >= sr1 ); | ||||
|  | ||||
|         (*str1.rbegin()) -= 2; | ||||
|         BOOST_CHECK ( sr1  != str1 ); | ||||
|         BOOST_CHECK ( str1 != sr1 ); | ||||
|         BOOST_CHECK ( sr1 > str1 ); | ||||
|         BOOST_CHECK ( sr1 >= str1 ); | ||||
|         BOOST_CHECK ( str1 < sr1 ); | ||||
|         BOOST_CHECK ( str1 <= sr1 ); | ||||
|         BOOST_TEST ( sr1  != str1 ); | ||||
|         BOOST_TEST ( str1 != sr1 ); | ||||
|         BOOST_TEST ( sr1 > str1 ); | ||||
|         BOOST_TEST ( sr1 >= str1 ); | ||||
|         BOOST_TEST ( str1 < sr1 ); | ||||
|         BOOST_TEST ( str1 <= sr1 ); | ||||
|         } | ||||
|     } | ||||
|  | ||||
| @@ -301,7 +304,7 @@ const char *test_strings [] = { | ||||
|     NULL | ||||
|     }; | ||||
|  | ||||
| BOOST_AUTO_TEST_CASE( test_main ) | ||||
| int main() | ||||
| { | ||||
|     const char **p = &test_strings[0]; | ||||
|  | ||||
| @@ -315,4 +318,6 @@ BOOST_AUTO_TEST_CASE( test_main ) | ||||
|  | ||||
|         p++; | ||||
|         } | ||||
|  | ||||
|     return boost::report_errors(); | ||||
| } | ||||
|   | ||||
| @@ -12,8 +12,6 @@ | ||||
|  * \brief  This header contains tests for stream operations of \c basic_string_ref. | ||||
|  */ | ||||
|  | ||||
| #define BOOST_TEST_MODULE string_ref_test_io | ||||
|  | ||||
| #include <boost/utility/string_ref.hpp> | ||||
|  | ||||
| #include <iomanip> | ||||
| @@ -23,23 +21,10 @@ | ||||
| #include <string> | ||||
|  | ||||
| #include <boost/config.hpp> | ||||
| #include <boost/mpl/vector.hpp> | ||||
| #include <boost/test/unit_test.hpp> | ||||
| #include <boost/core/lightweight_test.hpp> | ||||
|  | ||||
| typedef boost::mpl::vector< | ||||
|     char | ||||
| #if !defined(BOOST_NO_STD_WSTRING) && !defined(BOOST_NO_STD_WSTREAMBUF) && !defined(BOOST_NO_INTRINSIC_WCHAR_T) | ||||
|     , wchar_t | ||||
| #endif | ||||
| /* Current implementations seem to be missing codecvt facets to convert chars to char16_t and char32_t even though the types are available. | ||||
| #if !defined(BOOST_NO_CXX11_CHAR16_T) | ||||
|     , char16_t | ||||
| #endif | ||||
| #if !defined(BOOST_NO_CXX11_CHAR32_T) | ||||
|     , char32_t | ||||
| #endif | ||||
| */ | ||||
| >::type char_types; | ||||
|  | ||||
| static const char* test_strings[] = | ||||
| { | ||||
| @@ -72,10 +57,10 @@ struct context | ||||
| }; | ||||
|  | ||||
| // Test regular output | ||||
| BOOST_AUTO_TEST_CASE_TEMPLATE(string_ref_output, CharT, char_types) | ||||
| template<class CharT> | ||||
| void test_string_ref_output() | ||||
| { | ||||
|     typedef CharT char_type; | ||||
|     typedef std::basic_string< char_type > string_type; | ||||
|     typedef std::basic_ostringstream< char_type > ostream_type; | ||||
|     typedef boost::basic_string_ref< char_type > string_ref_type; | ||||
|  | ||||
| @@ -83,14 +68,14 @@ BOOST_AUTO_TEST_CASE_TEMPLATE(string_ref_output, CharT, char_types) | ||||
|  | ||||
|     ostream_type strm; | ||||
|     strm << string_ref_type(ctx.abcd); | ||||
|     BOOST_CHECK(strm.str() == ctx.abcd); | ||||
|     BOOST_TEST(strm.str() == ctx.abcd); | ||||
| } | ||||
|  | ||||
| // Test support for padding | ||||
| BOOST_AUTO_TEST_CASE_TEMPLATE(padding, CharT, char_types) | ||||
| template<class CharT> | ||||
| void test_padding() | ||||
| { | ||||
|     typedef CharT char_type; | ||||
|     typedef std::basic_string< char_type > string_type; | ||||
|     typedef std::basic_ostringstream< char_type > ostream_type; | ||||
|     typedef boost::basic_string_ref< char_type > string_ref_type; | ||||
|  | ||||
| @@ -104,7 +89,7 @@ BOOST_AUTO_TEST_CASE_TEMPLATE(padding, CharT, char_types) | ||||
|         ostream_type strm_correct; | ||||
|         strm_correct << ctx.begin << std::setw(8) << ctx.abcd << ctx.end; | ||||
|  | ||||
|         BOOST_CHECK(strm_ref.str() == strm_correct.str()); | ||||
|         BOOST_TEST(strm_ref.str() == strm_correct.str()); | ||||
|     } | ||||
|  | ||||
|     // Test for long padding | ||||
| @@ -115,7 +100,7 @@ BOOST_AUTO_TEST_CASE_TEMPLATE(padding, CharT, char_types) | ||||
|         ostream_type strm_correct; | ||||
|         strm_correct << ctx.begin << std::setw(100) << ctx.abcd << ctx.end; | ||||
|  | ||||
|         BOOST_CHECK(strm_ref.str() == strm_correct.str()); | ||||
|         BOOST_TEST(strm_ref.str() == strm_correct.str()); | ||||
|     } | ||||
|  | ||||
|     // Test that short width does not truncate the string | ||||
| @@ -126,15 +111,15 @@ BOOST_AUTO_TEST_CASE_TEMPLATE(padding, CharT, char_types) | ||||
|         ostream_type strm_correct; | ||||
|         strm_correct << ctx.begin << std::setw(1) << ctx.abcd << ctx.end; | ||||
|  | ||||
|         BOOST_CHECK(strm_ref.str() == strm_correct.str()); | ||||
|         BOOST_TEST(strm_ref.str() == strm_correct.str()); | ||||
|     } | ||||
| } | ||||
|  | ||||
| // Test support for padding fill | ||||
| BOOST_AUTO_TEST_CASE_TEMPLATE(padding_fill, CharT, char_types) | ||||
| template<class CharT> | ||||
| void test_padding_fill() | ||||
| { | ||||
|     typedef CharT char_type; | ||||
|     typedef std::basic_string< char_type > string_type; | ||||
|     typedef std::basic_ostringstream< char_type > ostream_type; | ||||
|     typedef boost::basic_string_ref< char_type > string_ref_type; | ||||
|  | ||||
| @@ -146,14 +131,14 @@ BOOST_AUTO_TEST_CASE_TEMPLATE(padding_fill, CharT, char_types) | ||||
|     ostream_type strm_correct; | ||||
|     strm_correct << ctx.begin << std::setfill(static_cast< char_type >('x')) << std::setw(8) << ctx.abcd << ctx.end; | ||||
|  | ||||
|     BOOST_CHECK(strm_ref.str() == strm_correct.str()); | ||||
|     BOOST_TEST(strm_ref.str() == strm_correct.str()); | ||||
| } | ||||
|  | ||||
| // Test support for alignment | ||||
| BOOST_AUTO_TEST_CASE_TEMPLATE(alignment, CharT, char_types) | ||||
| template<class CharT> | ||||
| void test_alignment() | ||||
| { | ||||
|     typedef CharT char_type; | ||||
|     typedef std::basic_string< char_type > string_type; | ||||
|     typedef std::basic_ostringstream< char_type > ostream_type; | ||||
|     typedef boost::basic_string_ref< char_type > string_ref_type; | ||||
|  | ||||
| @@ -167,7 +152,7 @@ BOOST_AUTO_TEST_CASE_TEMPLATE(alignment, CharT, char_types) | ||||
|         ostream_type strm_correct; | ||||
|         strm_correct << ctx.begin << std::left << std::setw(8) << ctx.abcd << ctx.end; | ||||
|  | ||||
|         BOOST_CHECK(strm_ref.str() == strm_correct.str()); | ||||
|         BOOST_TEST(strm_ref.str() == strm_correct.str()); | ||||
|     } | ||||
|  | ||||
|     // Right alignment | ||||
| @@ -178,6 +163,22 @@ BOOST_AUTO_TEST_CASE_TEMPLATE(alignment, CharT, char_types) | ||||
|         ostream_type strm_correct; | ||||
|         strm_correct << ctx.begin << std::right << std::setw(8) << ctx.abcd << ctx.end; | ||||
|  | ||||
|         BOOST_CHECK(strm_ref.str() == strm_correct.str()); | ||||
|         BOOST_TEST(strm_ref.str() == strm_correct.str()); | ||||
|     } | ||||
| } | ||||
|  | ||||
| template<class CharT> | ||||
| void test() | ||||
| { | ||||
|     test_string_ref_output<CharT>(); | ||||
|     test_padding<CharT>(); | ||||
|     test_padding_fill<CharT>(); | ||||
|     test_alignment<CharT>(); | ||||
| } | ||||
|  | ||||
| int main() | ||||
| { | ||||
|     test<char>(); | ||||
|     test<wchar_t>(); | ||||
|     return boost::report_errors(); | ||||
| } | ||||
|   | ||||
							
								
								
									
										114
									
								
								test/string_view_constexpr_test1.cpp
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										114
									
								
								test/string_view_constexpr_test1.cpp
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,114 @@ | ||||
| /* | ||||
|    Copyright (c) Marshall Clow 2017-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) | ||||
|  | ||||
|     For more information, see http://www.boost.org | ||||
| */ | ||||
|  | ||||
| #include <new>        // for placement new | ||||
| #include <iostream> | ||||
| #include <cstddef>    // for NULL, std::size_t, std::ptrdiff_t | ||||
| #include <cstring>    // for std::strchr and std::strcmp | ||||
| #include <cstdlib>    // for std::malloc and std::free | ||||
|  | ||||
| #include <boost/config.hpp> | ||||
| #include <boost/utility/string_view.hpp> | ||||
|  | ||||
| #if __cplusplus >= 201402L | ||||
| struct constexpr_char_traits | ||||
| { | ||||
|     typedef char		    char_type; | ||||
|     typedef int   			int_type; | ||||
|     typedef std::streamoff	off_type; | ||||
|     typedef std::streampos	pos_type; | ||||
|     typedef std::mbstate_t	state_type; | ||||
|  | ||||
|     static void assign(char_type& c1, const char_type& c2) noexcept { c1 = c2; } | ||||
|     static constexpr bool eq(char_type c1, char_type c2) noexcept   { return c1 == c2; } | ||||
|     static constexpr bool lt(char_type c1, char_type c2) noexcept   { return c1 < c2; } | ||||
|  | ||||
|     static constexpr int              compare(const char_type* s1, const char_type* s2, size_t n) noexcept; | ||||
|     static constexpr size_t           length(const char_type* s) noexcept; | ||||
|     static constexpr const char_type* find(const char_type* s, size_t n, const char_type& a) noexcept; | ||||
|     static constexpr char_type*       move(char_type* s1, const char_type* s2, size_t n) noexcept; | ||||
|     static constexpr char_type*       copy(char_type* s1, const char_type* s2, size_t n) noexcept; | ||||
|     static constexpr char_type*       assign(char_type* s, size_t n, char_type a) noexcept; | ||||
|  | ||||
|     static constexpr int_type  not_eof(int_type c) noexcept { return eq_int_type(c, eof()) ? ~eof() : c; } | ||||
|     static constexpr char_type to_char_type(int_type c) noexcept              { return char_type(c); } | ||||
|     static constexpr int_type  to_int_type(char_type c) noexcept              { return int_type(c); } | ||||
|     static constexpr bool      eq_int_type(int_type c1, int_type c2) noexcept { return c1 == c2; } | ||||
|     static constexpr int_type  eof() noexcept                                 { return EOF; } | ||||
| }; | ||||
|  | ||||
| //	yields: | ||||
| //		0 if for each i in [0,n), X::eq(s1[i],s2[i]) is true;  | ||||
| //		else, a negative value if, for some j in [0,n), X::lt(s1[j],s2[j]) is true and | ||||
| //			for each i in [0,j) X::eq(s2[i],s2[i]) is true; | ||||
| //		else a positive value. | ||||
| constexpr int constexpr_char_traits::compare(const char_type* s1, const char_type* s2, size_t n) noexcept | ||||
| { | ||||
|     for (; n != 0; --n, ++s1, ++s2) | ||||
|     { | ||||
|         if (lt(*s1, *s2)) | ||||
|             return -1; | ||||
|         if (lt(*s2, *s1)) | ||||
|             return 1; | ||||
|     } | ||||
|     return 0; | ||||
| } | ||||
|  | ||||
| //	yields: the smallest i such that X::eq(s[i],charT()) is true. | ||||
| constexpr size_t constexpr_char_traits::length(const char_type* s) noexcept | ||||
| { | ||||
|     size_t len = 0; | ||||
|     for (; !eq(*s, char_type(0)); ++s) | ||||
|         ++len; | ||||
|     return len; | ||||
| } | ||||
|  | ||||
| typedef boost::basic_string_view<char, constexpr_char_traits> string_view; | ||||
|  | ||||
| int main() | ||||
| { | ||||
|     constexpr string_view sv1; | ||||
|     constexpr string_view sv2{"abc", 3}; // ptr, len | ||||
|     constexpr string_view sv3{"def"}; 	 // ptr | ||||
|  | ||||
| 	constexpr const char *s1 = ""; | ||||
| 	constexpr const char *s2 = "abc"; | ||||
| 	 | ||||
| 	static_assert( (sv1 == sv1), "" ); | ||||
| 	 | ||||
| 	static_assert(!(sv1 == sv2), "" );     | ||||
| 	static_assert( (sv1 != sv2), "" );     | ||||
| 	static_assert( (sv1 <  sv2), "" );     | ||||
| 	static_assert( (sv1 <= sv2), "" );     | ||||
| 	static_assert(!(sv1 >  sv2), "" );     | ||||
| 	static_assert(!(sv1 >= sv2), "" );     | ||||
|  | ||||
| 	static_assert(!(s1 == sv2), "" );     | ||||
| 	static_assert( (s1 != sv2), "" );     | ||||
| 	static_assert( (s1 <  sv2), "" );     | ||||
| 	static_assert( (s1 <= sv2), "" );     | ||||
| 	static_assert(!(s1 >  sv2), "" );     | ||||
| 	static_assert(!(s1 >= sv2), "" );     | ||||
|  | ||||
| 	static_assert(!(sv1 == s2), "" );     | ||||
| 	static_assert( (sv1 != s2), "" );     | ||||
| 	static_assert( (sv1 <  s2), "" );     | ||||
| 	static_assert( (sv1 <= s2), "" );     | ||||
| 	static_assert(!(sv1 >  s2), "" );     | ||||
| 	static_assert(!(sv1 >= s2), "" );     | ||||
|  | ||||
| 	static_assert( sv1.compare(sv2)  < 0, "" );     | ||||
| 	static_assert( sv1.compare(sv1) == 0, "" );     | ||||
| 	static_assert( sv3.compare(sv1)  > 0, "" );     | ||||
|  | ||||
| 	static_assert( sv1.compare(s2)  < 0, "" );     | ||||
| 	static_assert( sv1.compare(s1) == 0, "" );     | ||||
| 	static_assert( sv3.compare(s1)  > 0, "" );     | ||||
| } | ||||
| #endif | ||||
							
								
								
									
										26
									
								
								test/string_view_from_rvalue.cpp
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										26
									
								
								test/string_view_from_rvalue.cpp
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,26 @@ | ||||
| /* | ||||
|    Copyright (c) Marshall Clow 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) | ||||
|  | ||||
|     For more information, see http://www.boost.org | ||||
| */ | ||||
|  | ||||
| #include <iostream> | ||||
| #include <algorithm> | ||||
| #include <string> | ||||
|  | ||||
| #include <boost/utility/string_view.hpp> | ||||
|  | ||||
| #if defined(BOOST_NO_CXX11_RVALUE_REFERENCES) || defined(BOOST_NO_CXX11_DELETED_FUNCTIONS) | ||||
| #error "Unsupported test" | ||||
| #endif | ||||
|  | ||||
| std::string makeatemp() { return "abc"; } | ||||
|  | ||||
| int main() | ||||
| { | ||||
|   boost::basic_string_view<char> sv(makeatemp()); | ||||
|   return 0; | ||||
| } | ||||
| @@ -7,27 +7,23 @@ | ||||
|     For more information, see http://www.boost.org | ||||
| */ | ||||
|  | ||||
| #ifndef _SCL_SECURE_NO_WARNINGS | ||||
| # define _SCL_SECURE_NO_WARNINGS | ||||
| #endif | ||||
|  | ||||
| #include <iostream> | ||||
| #include <algorithm> | ||||
| #include <string> | ||||
|  | ||||
| #include <boost/utility/string_view.hpp> | ||||
| #include <boost/container_hash/hash.hpp> | ||||
|  | ||||
| #define BOOST_TEST_MAIN | ||||
| #include <boost/test/unit_test.hpp> | ||||
| #include <boost/core/lightweight_test.hpp> | ||||
|  | ||||
| typedef boost::string_view string_view; | ||||
|  | ||||
| //  Should be equal | ||||
| void interop ( const std::string &str, string_view ref ) { | ||||
| //  BOOST_CHECK ( str == ref ); | ||||
|     BOOST_CHECK ( str.size () == ref.size ()); | ||||
|     BOOST_CHECK ( std::equal ( str.begin (),  str.end (),  ref.begin ())); | ||||
|     BOOST_CHECK ( std::equal ( str.rbegin (), str.rend (), ref.rbegin ())); | ||||
| //  BOOST_TEST ( str == ref ); | ||||
|     BOOST_TEST ( str.size () == ref.size ()); | ||||
|     BOOST_TEST ( std::equal ( str.begin (),  str.end (),  ref.begin ())); | ||||
|     BOOST_TEST ( std::equal ( str.rbegin (), str.rend (), ref.rbegin ())); | ||||
|     } | ||||
|  | ||||
| void null_tests ( const char *p ) { | ||||
| @@ -38,10 +34,10 @@ void null_tests ( const char *p ) { | ||||
|     string_view sr4 ( p ); | ||||
|     sr4.clear (); | ||||
|  | ||||
|     BOOST_CHECK ( sr1 == sr2 ); | ||||
|     BOOST_CHECK ( sr1 == sr3 ); | ||||
|     BOOST_CHECK ( sr2 == sr3 ); | ||||
|     BOOST_CHECK ( sr1 == sr4 ); | ||||
|     BOOST_TEST ( sr1 == sr2 ); | ||||
|     BOOST_TEST ( sr1 == sr3 ); | ||||
|     BOOST_TEST ( sr2 == sr3 ); | ||||
|     BOOST_TEST ( sr1 == sr4 ); | ||||
|     } | ||||
|  | ||||
| //  make sure that substrings work just like strings | ||||
| @@ -90,6 +86,14 @@ void test_remove ( const std::string &str ) { | ||||
|       } | ||||
|     } | ||||
|  | ||||
| void test_hash(const std::string& str) { | ||||
|     string_view ref = str; | ||||
|     BOOST_TEST(boost::hash_value(ref) == boost::hash_value(str)); | ||||
|     boost::hash<std::string> hstr; | ||||
|     boost::hash<string_view> hsv; | ||||
|     BOOST_TEST(hsv(ref) == hstr(str)); | ||||
|     } | ||||
|  | ||||
| const char *test_strings [] = { | ||||
|     "", | ||||
|     "1", | ||||
| @@ -98,7 +102,7 @@ const char *test_strings [] = { | ||||
|     NULL | ||||
|     }; | ||||
|  | ||||
| BOOST_AUTO_TEST_CASE( test_main ) | ||||
| int main() | ||||
| { | ||||
|     const char **p = &test_strings[0]; | ||||
|  | ||||
| @@ -107,7 +111,10 @@ BOOST_AUTO_TEST_CASE( test_main ) | ||||
|         test_substr ( *p ); | ||||
|         test_remove ( *p ); | ||||
|         null_tests ( *p ); | ||||
|         test_hash( *p ); | ||||
|  | ||||
|         p++; | ||||
|         } | ||||
|  | ||||
|     return boost::report_errors(); | ||||
| } | ||||
|   | ||||
| @@ -7,17 +7,16 @@ | ||||
|     For more information, see http://www.boost.org | ||||
| */ | ||||
|  | ||||
| #ifndef _SCL_SECURE_NO_WARNINGS | ||||
| # define _SCL_SECURE_NO_WARNINGS | ||||
| #endif | ||||
|  | ||||
| #include <new>        // for placement new | ||||
| #include <iostream> | ||||
| #include <cstring>    // for std::strchr | ||||
| #include <cstddef>    // for NULL, std::size_t, std::ptrdiff_t | ||||
| #include <cstring>    // for std::strchr and std::strcmp | ||||
| #include <cstdlib>    // for std::malloc and std::free | ||||
|  | ||||
| #include <boost/utility/string_view.hpp> | ||||
| #include <boost/config.hpp> | ||||
|  | ||||
| #define BOOST_TEST_MAIN | ||||
| #include <boost/test/unit_test.hpp> | ||||
| #include <boost/core/lightweight_test.hpp> | ||||
|  | ||||
| typedef boost::string_view string_view; | ||||
|  | ||||
| @@ -28,27 +27,27 @@ void ends_with ( const char *arg ) { | ||||
|     const char *p = arg; | ||||
|  | ||||
|     while ( *p ) { | ||||
|         BOOST_CHECK ( sr.ends_with ( p )); | ||||
|         BOOST_TEST ( sr.ends_with ( p )); | ||||
|         ++p; | ||||
|         } | ||||
|  | ||||
|     while ( !sr2.empty ()) { | ||||
|         BOOST_CHECK ( sr.ends_with ( sr2 )); | ||||
|         BOOST_TEST ( sr.ends_with ( sr2 )); | ||||
|         sr2.remove_prefix (1); | ||||
|         } | ||||
|  | ||||
|     sr2 = arg; | ||||
|     while ( !sr2.empty ()) { | ||||
|         BOOST_CHECK ( sr.ends_with ( sr2 )); | ||||
|         BOOST_TEST ( sr.ends_with ( sr2 )); | ||||
|         sr2.remove_prefix (1); | ||||
|         } | ||||
|  | ||||
|     char ch = sz == 0 ? '\0' : arg [ sz - 1 ]; | ||||
|     sr2 = arg; | ||||
|     if ( sz > 0 ) | ||||
|       BOOST_CHECK ( sr2.ends_with ( ch )); | ||||
|     BOOST_CHECK ( !sr2.ends_with ( ++ch )); | ||||
|     BOOST_CHECK ( sr2.ends_with ( string_view ())); | ||||
|       BOOST_TEST ( sr2.ends_with ( ch )); | ||||
|     BOOST_TEST ( !sr2.ends_with ( ++ch )); | ||||
|     BOOST_TEST ( sr2.ends_with ( string_view())); | ||||
|     } | ||||
|  | ||||
| void starts_with ( const char *arg ) { | ||||
| @@ -58,21 +57,21 @@ void starts_with ( const char *arg ) { | ||||
|     const char *p = arg + std::strlen ( arg ) - 1; | ||||
|     while ( p >= arg ) { | ||||
|         std::string foo ( arg, p + 1 ); | ||||
|         BOOST_CHECK ( sr.starts_with ( foo )); | ||||
|         BOOST_TEST ( sr.starts_with ( foo )); | ||||
|         --p; | ||||
|         } | ||||
|  | ||||
|     while ( !sr2.empty ()) { | ||||
|         BOOST_CHECK ( sr.starts_with ( sr2 )); | ||||
|         BOOST_TEST ( sr.starts_with ( sr2 )); | ||||
|         sr2.remove_suffix (1); | ||||
|         } | ||||
|  | ||||
|     char ch = *arg; | ||||
|     sr2 = arg; | ||||
|   if ( sz > 0 ) | ||||
|     BOOST_CHECK ( sr2.starts_with ( ch )); | ||||
|     BOOST_CHECK ( !sr2.starts_with ( ++ch )); | ||||
|     BOOST_CHECK ( sr2.starts_with ( string_view ())); | ||||
|     BOOST_TEST ( sr2.starts_with ( ch )); | ||||
|     BOOST_TEST ( !sr2.starts_with ( ++ch )); | ||||
|     BOOST_TEST ( sr2.starts_with ( string_view ())); | ||||
|     } | ||||
|  | ||||
| void reverse ( const char *arg ) { | ||||
| @@ -82,14 +81,14 @@ void reverse ( const char *arg ) { | ||||
|     string_view sr2 ( string1 ); | ||||
|     std::string string2 ( sr2.rbegin (), sr2.rend ()); | ||||
|  | ||||
|     BOOST_CHECK ( std::equal ( sr2.rbegin (), sr2.rend (), arg )); | ||||
|     BOOST_CHECK ( string2 == arg ); | ||||
|     BOOST_CHECK ( std::equal ( sr1.begin (), sr1.end (), string2.begin ())); | ||||
|     BOOST_TEST ( std::equal ( sr2.rbegin (), sr2.rend (), arg )); | ||||
|     BOOST_TEST ( string2 == arg ); | ||||
|     BOOST_TEST ( std::equal ( sr1.begin (), sr1.end (), string2.begin ())); | ||||
|     } | ||||
|  | ||||
| //	This helper function eliminates signed vs. unsigned warnings | ||||
| //  This helper function eliminates signed vs. unsigned warnings | ||||
| string_view::size_type ptr_diff ( const char *res, const char *base ) { | ||||
|     BOOST_CHECK ( res >= base ); | ||||
|     BOOST_TEST ( res >= base ); | ||||
|     return static_cast<string_view::size_type> ( res - base ); | ||||
|     } | ||||
|  | ||||
| @@ -98,12 +97,16 @@ void find ( const char *arg ) { | ||||
|     string_view sr2; | ||||
|     const char *p; | ||||
|  | ||||
| //	When we search for the empty string, we find it at position 0 | ||||
|     BOOST_TEST ( sr1.find (sr2) == 0 ); | ||||
|     BOOST_TEST ( sr1.rfind(sr2) == 0 ); | ||||
|  | ||||
| //  Look for each character in the string(searching from the start) | ||||
|     p = arg; | ||||
|     sr1 = arg; | ||||
|     while ( *p ) { | ||||
|       string_view::size_type pos = sr1.find(*p); | ||||
|       BOOST_CHECK ( pos != string_view::npos && ( pos <= ptr_diff ( p, arg ))); | ||||
|       BOOST_TEST ( pos != string_view::npos && ( pos <= ptr_diff ( p, arg ))); | ||||
|       ++p; | ||||
|       } | ||||
|  | ||||
| @@ -112,17 +115,17 @@ void find ( const char *arg ) { | ||||
|     sr1 = arg; | ||||
|     while ( *p ) { | ||||
|       string_view::size_type pos = sr1.rfind(*p); | ||||
|       BOOST_CHECK ( pos != string_view::npos && pos < sr1.size () && ( pos >= ptr_diff ( p, arg ))); | ||||
|       BOOST_TEST ( pos != string_view::npos && pos < sr1.size () && ( pos >= ptr_diff ( p, arg ))); | ||||
|       ++p; | ||||
|       } | ||||
|  | ||||
| //	Look for pairs on characters (searching from the start) | ||||
| //  Look for pairs on characters (searching from the start) | ||||
|     sr1 = arg; | ||||
|     p = arg; | ||||
|     while ( *p && *(p+1)) { | ||||
|         string_view sr3 ( p, 2 ); | ||||
|         string_view::size_type pos = sr1.find ( sr3 ); | ||||
|         BOOST_CHECK ( pos != string_view::npos && pos <= static_cast<string_view::size_type>( p - arg )); | ||||
|         BOOST_TEST ( pos != string_view::npos && pos <= static_cast<string_view::size_type>( p - arg )); | ||||
|         p++; | ||||
|         } | ||||
|  | ||||
| @@ -130,29 +133,24 @@ void find ( const char *arg ) { | ||||
|     p = arg; | ||||
| //  for all possible chars, see if we find them in the right place. | ||||
| //  Note that strchr will/might do the _wrong_ thing if we search for NULL | ||||
|  | ||||
|     for ( unsigned char ch = 1u; ; ++ch ) { | ||||
|     for ( int ch = 1; ch < 256; ++ch ) { | ||||
|         string_view::size_type pos = sr1.find(ch); | ||||
|         const char *strp = std::strchr ( arg, ch ); | ||||
|         BOOST_CHECK (( strp == NULL ) == ( pos == string_view::npos )); | ||||
|         BOOST_TEST (( strp == NULL ) == ( pos == string_view::npos )); | ||||
|         if ( strp != NULL ) | ||||
|             BOOST_CHECK ( ptr_diff ( strp, arg ) == pos ); | ||||
|         if (ch == 255u) | ||||
|             break; | ||||
|         } | ||||
|             BOOST_TEST ( ptr_diff ( strp, arg ) == pos ); | ||||
|     } | ||||
|  | ||||
|     sr1 = arg; | ||||
|     p = arg; | ||||
| //  for all possible chars, see if we find them in the right place. | ||||
| //  Note that strchr will/might do the _wrong_ thing if we search for NULL | ||||
|     for ( unsigned char ch = 1u; ; ++ch ) { | ||||
|     for ( int ch = 1; ch < 256; ++ch ) { | ||||
|         string_view::size_type pos = sr1.rfind(ch); | ||||
|         const char *strp = std::strrchr ( arg, ch ); | ||||
|         BOOST_CHECK (( strp == NULL ) == ( pos == string_view::npos )); | ||||
|         BOOST_TEST (( strp == NULL ) == ( pos == string_view::npos )); | ||||
|         if ( strp != NULL ) | ||||
|             BOOST_CHECK ( ptr_diff ( strp, arg ) == pos ); | ||||
|         if (ch == 255u) | ||||
|             break; | ||||
|             BOOST_TEST ( ptr_diff ( strp, arg ) == pos ); | ||||
|     } | ||||
|  | ||||
|  | ||||
| @@ -161,7 +159,7 @@ void find ( const char *arg ) { | ||||
|     sr1 = arg; | ||||
|     while ( !sr1.empty ()) { | ||||
|         string_view::size_type pos = sr1.find(*p); | ||||
|         BOOST_CHECK ( pos == 0 ); | ||||
|         BOOST_TEST ( pos == 0 ); | ||||
|         sr1.remove_prefix (1); | ||||
|         ++p; | ||||
|         } | ||||
| @@ -171,7 +169,7 @@ void find ( const char *arg ) { | ||||
|     p    = arg + std::strlen ( arg ) - 1; | ||||
|     while ( !sr1.empty ()) { | ||||
|         string_view::size_type pos = sr1.rfind(*p); | ||||
|         BOOST_CHECK ( pos == sr1.size () - 1 ); | ||||
|         BOOST_TEST ( pos == sr1.size () - 1 ); | ||||
|         sr1.remove_suffix (1); | ||||
|         --p; | ||||
|         } | ||||
| @@ -181,7 +179,7 @@ void find ( const char *arg ) { | ||||
|     p    = arg; | ||||
|     while ( !sr1.empty ()) { | ||||
|         string_view::size_type pos = sr1.find_first_of(*p); | ||||
|         BOOST_CHECK ( pos == 0 ); | ||||
|         BOOST_TEST ( pos == 0 ); | ||||
|         sr1.remove_prefix (1); | ||||
|         ++p; | ||||
|         } | ||||
| @@ -192,7 +190,7 @@ void find ( const char *arg ) { | ||||
|     p    = arg + std::strlen ( arg ) - 1; | ||||
|     while ( !sr1.empty ()) { | ||||
|         string_view::size_type pos = sr1.find_last_of(*p); | ||||
|         BOOST_CHECK ( pos == sr1.size () - 1 ); | ||||
|         BOOST_TEST ( pos == sr1.size () - 1 ); | ||||
|         sr1.remove_suffix (1); | ||||
|         --p; | ||||
|         } | ||||
| @@ -201,8 +199,8 @@ void find ( const char *arg ) { | ||||
|     sr1 = arg; | ||||
|     sr2 = arg; | ||||
|     while ( !sr1.empty() ) { | ||||
|         BOOST_CHECK ( sr1.find_first_of ( sr2 )     == 0 ); | ||||
|         BOOST_CHECK ( sr1.find_first_not_of ( sr2 ) == string_view::npos ); | ||||
|         BOOST_TEST ( sr1.find_first_of ( sr2 )     == 0 ); | ||||
|         BOOST_TEST ( sr1.find_first_not_of ( sr2 ) == string_view::npos ); | ||||
|         sr1.remove_prefix ( 1 ); | ||||
|         } | ||||
|  | ||||
| @@ -211,14 +209,14 @@ void find ( const char *arg ) { | ||||
|     while ( *p ) { | ||||
|         string_view::size_type pos1 = sr1.find_first_of(*p); | ||||
|         string_view::size_type pos2 = sr1.find_first_not_of(*p); | ||||
|         BOOST_CHECK ( pos1 != string_view::npos && pos1 < sr1.size () && pos1 <= ptr_diff ( p, arg )); | ||||
|         BOOST_TEST ( pos1 != string_view::npos && pos1 < sr1.size () && pos1 <= ptr_diff ( p, arg )); | ||||
|         if ( pos2 != string_view::npos ) { | ||||
|             for ( size_t i = 0 ; i < pos2; ++i ) | ||||
|                 BOOST_CHECK ( sr1[i] == *p ); | ||||
|             BOOST_CHECK ( sr1 [ pos2 ] != *p ); | ||||
|                 BOOST_TEST ( sr1[i] == *p ); | ||||
|             BOOST_TEST ( sr1 [ pos2 ] != *p ); | ||||
|             } | ||||
|  | ||||
|         BOOST_CHECK ( pos2 != pos1 ); | ||||
|         BOOST_TEST ( pos2 != pos1 ); | ||||
|         ++p; | ||||
|         } | ||||
|  | ||||
| @@ -226,8 +224,8 @@ void find ( const char *arg ) { | ||||
|     sr1 = arg; | ||||
|     sr2 = arg; | ||||
|     while ( !sr1.empty() ) { | ||||
|         BOOST_CHECK ( sr1.find_last_of ( sr2 )     == ( sr1.size () - 1 )); | ||||
|         BOOST_CHECK ( sr1.find_last_not_of ( sr2 ) == string_view::npos ); | ||||
|         BOOST_TEST ( sr1.find_last_of ( sr2 )     == ( sr1.size () - 1 )); | ||||
|         BOOST_TEST ( sr1.find_last_not_of ( sr2 ) == string_view::npos ); | ||||
|         sr1.remove_suffix ( 1 ); | ||||
|         } | ||||
|  | ||||
| @@ -236,20 +234,100 @@ void find ( const char *arg ) { | ||||
|     while ( *p ) { | ||||
|         string_view::size_type pos1 = sr1.find_last_of(*p); | ||||
|         string_view::size_type pos2 = sr1.find_last_not_of(*p); | ||||
|         BOOST_CHECK ( pos1 != string_view::npos && pos1 < sr1.size () && pos1 >= ptr_diff ( p, arg )); | ||||
|         BOOST_CHECK ( pos2 == string_view::npos || pos1 < sr1.size ()); | ||||
|         BOOST_TEST ( pos1 != string_view::npos && pos1 < sr1.size () && pos1 >= ptr_diff ( p, arg )); | ||||
|         BOOST_TEST ( pos2 == string_view::npos || pos1 < sr1.size ()); | ||||
|         if ( pos2 != string_view::npos ) { | ||||
|             for ( size_t i = sr1.size () -1 ; i > pos2; --i ) | ||||
|                 BOOST_CHECK ( sr1[i] == *p ); | ||||
|             BOOST_CHECK ( sr1 [ pos2 ] != *p ); | ||||
|                 BOOST_TEST ( sr1[i] == *p ); | ||||
|             BOOST_TEST ( sr1 [ pos2 ] != *p ); | ||||
|             } | ||||
|  | ||||
|         BOOST_CHECK ( pos2 != pos1 ); | ||||
|         BOOST_TEST ( pos2 != pos1 ); | ||||
|         ++p; | ||||
|         } | ||||
|  | ||||
|     } | ||||
|  | ||||
| template <typename T> | ||||
| class custom_allocator { | ||||
| public: | ||||
|     typedef T value_type; | ||||
|     typedef T* pointer; | ||||
|     typedef const T* const_pointer; | ||||
|     typedef void* void_pointer; | ||||
|     typedef const void* const_void_pointer; | ||||
|     typedef std::size_t size_type; | ||||
|     typedef std::ptrdiff_t difference_type; | ||||
|     typedef T& reference; | ||||
|     typedef const T& const_reference; | ||||
|  | ||||
|     template<class U> | ||||
|     struct rebind { | ||||
|         typedef custom_allocator<U> other; | ||||
|         }; | ||||
|  | ||||
|     custom_allocator() BOOST_NOEXCEPT {} | ||||
|     template <typename U> | ||||
|     custom_allocator(custom_allocator<U> const&) BOOST_NOEXCEPT {} | ||||
|  | ||||
|     pointer allocate(size_type n) const { | ||||
|         return static_cast<pointer>(std::malloc(sizeof(value_type) * n)); | ||||
|         } | ||||
|     void deallocate(pointer p, size_type) const BOOST_NOEXCEPT { | ||||
|         std::free(p); | ||||
|         } | ||||
|  | ||||
|     pointer address(reference value) const BOOST_NOEXCEPT { | ||||
|         return &value; | ||||
|         } | ||||
|  | ||||
|     const_pointer address(const_reference value) const BOOST_NOEXCEPT { | ||||
|         return &value; | ||||
|         } | ||||
|  | ||||
|     BOOST_CONSTEXPR size_type max_size() const BOOST_NOEXCEPT { | ||||
|         return (~(size_type)0u) / sizeof(value_type); | ||||
|         } | ||||
|  | ||||
| #if !defined(BOOST_NO_CXX11_RVALUE_REFERENCES) | ||||
| #if !defined(BOOST_NO_CXX11_VARIADIC_TEMPLATES) | ||||
|     template <class U, class... Args> | ||||
|     void construct(U* ptr, Args&&... args) const { | ||||
|         ::new((void*)ptr) U(static_cast<Args&&>(args)...); | ||||
|         } | ||||
| #else | ||||
|     template <class U, class V> | ||||
|     void construct(U* ptr, V&& value) const { | ||||
|         ::new((void*)ptr) U(static_cast<V&&>(value)); | ||||
|         } | ||||
| #endif | ||||
| #else | ||||
|     template <class U, class V> | ||||
|     void construct(U* ptr, const V& value) const { | ||||
|         ::new((void*)ptr) U(value); | ||||
|         } | ||||
| #endif | ||||
|  | ||||
|     template <class U> | ||||
|     void construct(U* ptr) const { | ||||
|         ::new((void*)ptr) U(); | ||||
|         } | ||||
|  | ||||
|     template <class U> | ||||
|     void destroy(U* ptr) const { | ||||
|         (void)ptr; | ||||
|         ptr->~U(); | ||||
|         } | ||||
|     }; | ||||
|  | ||||
| template <typename T, typename U> | ||||
| BOOST_CONSTEXPR bool operator==(const custom_allocator<T> &, const custom_allocator<U> &) BOOST_NOEXCEPT { | ||||
|     return true; | ||||
|     } | ||||
| template <typename T, typename U> | ||||
| BOOST_CONSTEXPR bool operator!=(const custom_allocator<T> &, const custom_allocator<U> &) BOOST_NOEXCEPT { | ||||
|     return false; | ||||
|     } | ||||
|  | ||||
| void to_string ( const char *arg ) { | ||||
|     string_view sr1; | ||||
| @@ -258,14 +336,17 @@ void to_string ( const char *arg ) { | ||||
|  | ||||
|     str1.assign ( arg ); | ||||
|     sr1 = arg; | ||||
| //	str2 = sr1.to_string<std::allocator<char> > (); | ||||
| //  str2 = sr1.to_string<std::allocator<char> > (); | ||||
|     str2 = sr1.to_string (); | ||||
|     BOOST_CHECK ( str1 == str2 ); | ||||
|     BOOST_TEST ( str1 == str2 ); | ||||
|  | ||||
| //#ifndef BOOST_NO_CXX11_EXPLICIT_CONVERSION_OPERATORS | ||||
| //    std::string str3 = static_cast<std::string> ( sr1 ); | ||||
| //    BOOST_CHECK ( str1 == str3 ); | ||||
| //#endif | ||||
|     std::basic_string<char, std::char_traits<char>, custom_allocator<char> > str3 = sr1.to_string(custom_allocator<char>()); | ||||
|     BOOST_TEST ( std::strcmp(str1.c_str(), str3.c_str()) == 0 ); | ||||
|  | ||||
| #ifndef BOOST_NO_CXX11_EXPLICIT_CONVERSION_OPERATORS | ||||
|     std::string str4 = static_cast<std::string> ( sr1 ); | ||||
|     BOOST_TEST ( str1 == str4 ); | ||||
| #endif | ||||
|     } | ||||
|  | ||||
| void compare ( const char *arg ) { | ||||
| @@ -275,28 +356,28 @@ void compare ( const char *arg ) { | ||||
|  | ||||
|     str1.assign ( arg ); | ||||
|     sr1 = arg; | ||||
|     BOOST_CHECK ( sr1  == sr1);	    // compare string_view and string_view | ||||
|     BOOST_CHECK ( sr1  == str1);	// compare string and string_view | ||||
|     BOOST_CHECK ( str1 == sr1 );	// compare string_view and string | ||||
|     BOOST_CHECK ( sr1  == arg );	// compare string_view and pointer | ||||
|     BOOST_CHECK ( arg  == sr1 );	// compare pointer and string_view | ||||
|     BOOST_TEST ( sr1  == sr1);    // compare string_view and string_view | ||||
|     BOOST_TEST ( sr1  == str1);   // compare string and string_view | ||||
|     BOOST_TEST ( str1 == sr1 );   // compare string_view and string | ||||
|     BOOST_TEST ( sr1  == arg );   // compare string_view and pointer | ||||
|     BOOST_TEST ( arg  == sr1 );   // compare pointer and string_view | ||||
|  | ||||
|     if ( sr1.size () > 0 ) { | ||||
|         (*str1.rbegin())++; | ||||
|         BOOST_CHECK ( sr1  != str1 ); | ||||
|         BOOST_CHECK ( str1 != sr1 ); | ||||
|         BOOST_CHECK ( sr1 < str1 ); | ||||
|         BOOST_CHECK ( sr1 <= str1 ); | ||||
|         BOOST_CHECK ( str1 > sr1 ); | ||||
|         BOOST_CHECK ( str1 >= sr1 ); | ||||
|         BOOST_TEST ( sr1  != str1 ); | ||||
|         BOOST_TEST ( str1 != sr1 ); | ||||
|         BOOST_TEST ( sr1 < str1 ); | ||||
|         BOOST_TEST ( sr1 <= str1 ); | ||||
|         BOOST_TEST ( str1 > sr1 ); | ||||
|         BOOST_TEST ( str1 >= sr1 ); | ||||
|  | ||||
|         (*str1.rbegin()) -= 2; | ||||
|         BOOST_CHECK ( sr1  != str1 ); | ||||
|         BOOST_CHECK ( str1 != sr1 ); | ||||
|         BOOST_CHECK ( sr1 > str1 ); | ||||
|         BOOST_CHECK ( sr1 >= str1 ); | ||||
|         BOOST_CHECK ( str1 < sr1 ); | ||||
|         BOOST_CHECK ( str1 <= sr1 ); | ||||
|         BOOST_TEST ( sr1  != str1 ); | ||||
|         BOOST_TEST ( str1 != sr1 ); | ||||
|         BOOST_TEST ( sr1 > str1 ); | ||||
|         BOOST_TEST ( sr1 >= str1 ); | ||||
|         BOOST_TEST ( str1 < sr1 ); | ||||
|         BOOST_TEST ( str1 <= sr1 ); | ||||
|         } | ||||
|     } | ||||
|  | ||||
| @@ -310,7 +391,7 @@ const char *test_strings [] = { | ||||
|     NULL | ||||
|     }; | ||||
|  | ||||
| BOOST_AUTO_TEST_CASE( test_main ) | ||||
| int main() | ||||
| { | ||||
|     const char **p = &test_strings[0]; | ||||
|  | ||||
| @@ -324,4 +405,6 @@ BOOST_AUTO_TEST_CASE( test_main ) | ||||
|  | ||||
|         p++; | ||||
|         } | ||||
|  | ||||
|     return boost::report_errors(); | ||||
| } | ||||
|   | ||||
| @@ -1,482 +0,0 @@ | ||||
| /* | ||||
|    <20> Copyright Beman Dawes 2015 | ||||
|  | ||||
|    Distributed under the Boost Software License, Version 1.0 | ||||
|    See http://www.boost.org/LICENSE_1_0.txt | ||||
|  | ||||
|    For more information, see http://www.boost.org | ||||
| */ | ||||
|  | ||||
| #ifndef _SCL_SECURE_NO_WARNINGS | ||||
| # define _SCL_SECURE_NO_WARNINGS | ||||
| #endif | ||||
|  | ||||
| #include <boost/utility/string_view.hpp> | ||||
|  | ||||
| #include <iostream> | ||||
| #include <algorithm> | ||||
| #include <string> | ||||
|  | ||||
| #define BOOST_LIGHTWEIGHT_TEST_OSTREAM std::cout | ||||
| #include <boost/core/lightweight_test.hpp> | ||||
| #include <boost/detail/lightweight_main.hpp> | ||||
|  | ||||
| namespace | ||||
| { | ||||
|   void swap_test() | ||||
|   { | ||||
|     std::cout << "swap test..." << std::endl; | ||||
|  | ||||
|     std::string s1("abcdefg"); | ||||
|     boost::string_view sv1(s1); | ||||
|     std::string s2("xyz"); | ||||
|     boost::string_view sv2(s2); | ||||
|     std::string s3; | ||||
|     boost::string_view sv3(s3); | ||||
|  | ||||
|     boost::string_view sv1_org(sv1); | ||||
|     boost::string_view sv2_org(sv2); | ||||
|     boost::string_view sv3_org(sv3); | ||||
|  | ||||
|     sv1.swap(sv2); | ||||
|     BOOST_TEST_EQ(sv1.data(), sv2_org.data()); | ||||
|     BOOST_TEST_EQ(sv2.data(), sv1_org.data()); | ||||
|     BOOST_TEST_EQ(sv1.size(), sv2_org.size()); | ||||
|     BOOST_TEST_EQ(sv2.size(), sv1_org.size()); | ||||
|     sv1.swap(sv2); | ||||
|     BOOST_TEST_EQ(sv1.data(), sv1_org.data()); | ||||
|     BOOST_TEST_EQ(sv2.data(), sv2_org.data()); | ||||
|     BOOST_TEST_EQ(sv1.size(), sv1_org.size()); | ||||
|     BOOST_TEST_EQ(sv2.size(), sv2_org.size()); | ||||
|  | ||||
|     sv3.swap(sv1); | ||||
|     BOOST_TEST_EQ(sv3.data(), sv1_org.data()); | ||||
|     BOOST_TEST_EQ(sv1.data(), sv3_org.data()); | ||||
|     BOOST_TEST_EQ(sv3.size(), sv1_org.size()); | ||||
|     BOOST_TEST_EQ(sv1.size(), sv3_org.size()); | ||||
|     sv3.swap(sv1); | ||||
|     BOOST_TEST_EQ(sv1.data(), sv1_org.data()); | ||||
|     BOOST_TEST_EQ(sv3.data(), sv3_org.data()); | ||||
|     BOOST_TEST_EQ(sv1.size(), sv1_org.size()); | ||||
|     BOOST_TEST_EQ(sv3.size(), sv3_org.size()); | ||||
|   } | ||||
|  | ||||
|   void copy_test() | ||||
|   { | ||||
|     std::cout << "copy test..." << std::endl; | ||||
|  | ||||
|     std::string s1("abcdefg"); | ||||
|     boost::string_view sv1(s1); | ||||
|     const std::size_t sz = 128u; | ||||
|     char a[sz]; | ||||
|  | ||||
|     std::fill(a, a + sz, 'x'); | ||||
|     sv1.copy(a, sv1.size()); | ||||
|     BOOST_TEST(std::memcmp(sv1.data(), &a, sv1.size()) == 0); | ||||
|     const char* p; | ||||
|     for (p = a + sv1.size(); | ||||
|       p != a + sz && *p == 'x'; ++p) {} | ||||
|     BOOST_TEST(p == a + sz); | ||||
|  | ||||
|     std::fill(a, a + sz, 'x'); | ||||
|     sv1.copy(a, sv1.size()-2, 2); | ||||
|     BOOST_TEST(std::memcmp(sv1.data()+2, &a, sv1.size()-2) == 0); | ||||
|     for (p = a + sv1.size() - 2; | ||||
|       p != a + sz && *p == 'x'; ++p) {} | ||||
|     BOOST_TEST(p == a + sz); | ||||
|   } | ||||
|  | ||||
|   void compare_test() | ||||
|   { | ||||
|     std::cout << "compare test..." << std::endl; | ||||
|  | ||||
|   } | ||||
|  | ||||
|   void find_test() | ||||
|   { | ||||
|     std::cout << "find test..." << std::endl; | ||||
|  | ||||
|     //  find - test two modified and two new signatures | ||||
|     std::string s1("ababcab"); | ||||
|     boost::string_view sv1(s1); | ||||
|     std::string s2("abc"); | ||||
|     boost::string_view sv2(s2); | ||||
|     std::string s3; | ||||
|     boost::string_view sv3(s3); | ||||
|  | ||||
|     //  first signature | ||||
|     BOOST_TEST_EQ(sv3.find(sv3), s3.find(s3));            // both strings empty | ||||
|     BOOST_TEST_EQ(sv1.find(sv3), s1.find(s3));            // search string empty | ||||
|     BOOST_TEST_EQ(sv3.find(sv2), s3.find(s2));            // searched string empty | ||||
|     BOOST_TEST_EQ(sv1.find(sv3, sizeof(s1) + 2), s1.find(s3, sizeof(s1) + 2)); | ||||
|     BOOST_TEST_EQ(sv1.find(sv3, sizeof(s1) + 1), s1.find(s3, sizeof(s1) + 1)); | ||||
|     BOOST_TEST_EQ(sv1.find(sv3, sizeof(s1)), s1.find(s3, sizeof(s1))); | ||||
|     BOOST_TEST_EQ(sv1.find(sv3, sizeof(s1)-  1), s1.find(s3, sizeof(s1)-  1)); | ||||
|  | ||||
|     BOOST_TEST_EQ(sv1.find(sv2), s1.find(s2)); | ||||
|     for (std::string::size_type i = 0; i <= sizeof(s1) + 1; ++i) | ||||
|     { | ||||
|       //std::cout << i << std::endl; | ||||
|       BOOST_TEST_EQ(sv1.find(sv2, i), s1.find(s2, i)); | ||||
|     } | ||||
|     for (std::string::size_type i = 0; i <= sizeof(s1) + 1; ++i) | ||||
|     { | ||||
|       //std::cout << i << std::endl; | ||||
|       BOOST_TEST_EQ(sv1.find(sv3, i), s1.find(s3, i)); | ||||
|     } | ||||
|  | ||||
|     //  second signature | ||||
|     for (std::string::size_type i = 0; i <= sizeof(s1) + 1; ++i) | ||||
|     { | ||||
|       //std::cout << i << std::endl; | ||||
|       BOOST_TEST_EQ(sv1.find('b', i), s1.find('b', i)); | ||||
|     } | ||||
|  | ||||
|     //  third signature | ||||
|     for (std::string::size_type i = 0; i <= sizeof(s1) + 1; ++i) | ||||
|       for (std::string::size_type j = 0; j <= 4; ++j) | ||||
|       { | ||||
|         //std::cout << i << " " << j << std::endl; | ||||
|         BOOST_TEST_EQ(sv1.find("abc", i, j), s1.find("abc", i, j)); | ||||
|       } | ||||
|  | ||||
|     //  fourth signature | ||||
|     BOOST_TEST_EQ(sv1.find("abc"), s1.find("abc")); | ||||
|     for (std::string::size_type i = 0; i <= sizeof(s1) + 1; ++i) | ||||
|       BOOST_TEST_EQ(sv1.find("abc", i), s1.find("abc", i)); | ||||
|   } | ||||
|  | ||||
|   void rfind_test() | ||||
|   { | ||||
|     std::cout << "rfind test..." << std::endl; | ||||
|  | ||||
|     //  rfind - test two modified and two new signatures | ||||
|     std::string s1("ababcab"); | ||||
|     boost::string_view sv1(s1); | ||||
|     std::string s2("ab"); | ||||
|     boost::string_view sv2(s2); | ||||
|     std::string s3; | ||||
|     boost::string_view sv3(s3); | ||||
|  | ||||
|      //  first signature | ||||
|     BOOST_TEST_EQ(sv3.rfind(sv3), s3.rfind(s3));          // both strings empty | ||||
|     BOOST_TEST_EQ(sv1.rfind(sv3), s1.rfind(s3));          // search string empty | ||||
|     BOOST_TEST_EQ(sv3.rfind(sv2), s3.rfind(s2));          // searched string empty | ||||
|     BOOST_TEST_EQ(sv1.find(sv3, s1.size() + 2), s1.find(s3, s1.size() + 2)); | ||||
|     BOOST_TEST_EQ(sv1.find(sv3, s1.size() + 1), s1.find(s3, s1.size() + 1)); | ||||
|     BOOST_TEST_EQ(sv1.rfind(sv3, s1.size()), s1.rfind(s3, s1.size())); | ||||
|     BOOST_TEST_EQ(sv1.rfind(sv3, s1.size()-  1), s1.rfind(s3, s1.size()-  1)); | ||||
|  | ||||
|     BOOST_TEST_EQ(sv1.rfind(sv2), s1.rfind(s2)); | ||||
|     for (std::string::size_type i = s1.size(); i <= s1.size(); --i) | ||||
|     { | ||||
|       // std::cout << i << ": " << sv1.rfind(sv2, i) << " " << s1.rfind(s2, i) << std::endl; | ||||
|       BOOST_TEST_EQ(sv1.rfind(sv2, i), s1.rfind(s2, i)); | ||||
|     } | ||||
|     for (std::string::size_type i = 0; i <= s1.size() + 1; ++i) | ||||
|     { | ||||
|       //std::cout << i << std::endl; | ||||
|       BOOST_TEST_EQ(sv1.rfind(sv3, i), s1.rfind(s3, i)); | ||||
|     } | ||||
|  | ||||
|     //  second signature | ||||
|     for (std::string::size_type i = 0; i <= s1.size() + 1; ++i) | ||||
|     { | ||||
|       //std::cout << i << std::endl; | ||||
|       BOOST_TEST_EQ(sv1.rfind('b', i), s1.rfind('b', i)); | ||||
|     } | ||||
|  | ||||
|     //  third signature | ||||
|     for (std::string::size_type i = 0; i <= s1.size() + 1; ++i) | ||||
|       for (std::string::size_type j = 0; j <= 4; ++j) | ||||
|       { | ||||
|         //std::cout << i << " " << j << std::endl; | ||||
|         BOOST_TEST_EQ(sv1.rfind("abc", i, j), s1.rfind("abc", i, j)); | ||||
|       } | ||||
|  | ||||
|     //  fourth signature | ||||
|     BOOST_TEST_EQ(sv1.rfind("abc"), s1.rfind("abc")); | ||||
|     for (std::string::size_type i = 0; i <= s1.size() + 1; ++i) | ||||
|       BOOST_TEST_EQ(sv1.rfind("abc", i), s1.rfind("abc", i)); | ||||
|   } | ||||
|  | ||||
|   void find_first_of_test() | ||||
|   { | ||||
|     std::cout << "find_first_of test..." << std::endl; | ||||
|  | ||||
|     //  find_first_of - test two modified and two new signatures | ||||
|     std::string s1("Hello World!"); | ||||
|     boost::string_view sv1(s1); | ||||
|     std::string s2("o"); | ||||
|     boost::string_view sv2(s2); | ||||
|     const char* s2c = "Good Bye"; | ||||
|     boost::string_view sv2c(s2c); | ||||
|     std::string s3; | ||||
|     boost::string_view sv3(s3); | ||||
|  | ||||
|     //  smoke test | ||||
|     BOOST_TEST_EQ(sv1.find_first_of(sv2), s1.find_first_of(s2)); | ||||
|     BOOST_TEST_EQ(sv1.find_first_of(sv2, 5), s1.find_first_of(s2, 5)); | ||||
|     BOOST_TEST_EQ(sv1.find_first_of(s2c), s1.find_first_of(s2c)); | ||||
|     BOOST_TEST_EQ(sv1.find_first_of(s2c, 0, 4), s1.find_first_of(s2c, 0, 4)); | ||||
|  | ||||
|     //  first signature | ||||
|     BOOST_TEST_EQ(sv3.find_first_of(sv3), s3.find_first_of(s3));  // both strings empty | ||||
|     BOOST_TEST_EQ(sv1.find_first_of(sv3), s1.find_first_of(s3));  // search string empty | ||||
|     BOOST_TEST_EQ(sv3.find_first_of(sv2), s3.find_first_of(s2));  // searched string empty | ||||
|     BOOST_TEST_EQ(sv1.find_first_of(sv3, s1.size() + 2), s1.find_first_of(s3, s1.size() + 2)); | ||||
|     BOOST_TEST_EQ(sv1.find_first_of(sv3, s1.size() + 1), s1.find_first_of(s3, s1.size() + 1)); | ||||
|     BOOST_TEST_EQ(sv1.find_first_of(sv3, s1.size()), s1.find_first_of(s3, s1.size())); | ||||
|     BOOST_TEST_EQ(sv1.find_first_of(sv3, s1.size() -  1), s1.find_first_of(s3, s1.size() -  1)); | ||||
|  | ||||
|     BOOST_TEST_EQ(sv1.find_first_of(sv2), s1.find_first_of(s2)); | ||||
|     for (std::string::size_type i = 0; i <= s1.size() + 1; ++i) | ||||
|     { | ||||
|       //std::cout << i << ": " << sv1.find_first_of(sv2, i) << " " << s1.find_first_of(s2, i) << std::endl; | ||||
|       BOOST_TEST_EQ(sv1.find_first_of(sv2, i), s1.find_first_of(s2, i)); | ||||
|     } | ||||
|     for (std::string::size_type i = 0; i <= s1.size() + 1; ++i) | ||||
|     { | ||||
|       //std::cout << i << ": " << sv1.find_first_of(sv3, i) << " " << s1.find_first_of(s3, i) << std::endl; | ||||
|       BOOST_TEST_EQ(sv1.find_first_of(sv3, i), s1.find_first_of(s3, i)); | ||||
|     } | ||||
|  | ||||
|     //  second signature | ||||
|     for (std::string::size_type i = 0; i <= s1.size() + 1; ++i) | ||||
|     { | ||||
|       //std::cout << i << ": " << sv1.find_first_of('o', i) << " " << s1.find_first_of('o', i) << std::endl; | ||||
|       BOOST_TEST_EQ(sv1.find_first_of('o', i), s1.find_first_of('o', i)); | ||||
|     } | ||||
|  | ||||
|     //  third signature | ||||
|     for (std::string::size_type i = 0; i <= s1.size() + 1; ++i) | ||||
|       for (std::string::size_type j = 0; j <= std::strlen(s2c) + 1; ++j) | ||||
|       { | ||||
|         //std::cout << i << "," << j << ": " << sv1.find_first_of(s2c, i, j) << " " << s1.find_first_of(s2c, i, j) << std::endl; | ||||
|         BOOST_TEST_EQ(sv1.find_first_of(s2c, i, j), s1.find_first_of(s2c, i, j)); | ||||
|       } | ||||
|  | ||||
|     //  fourth signature | ||||
|     BOOST_TEST_EQ(sv1.find_first_of(s2c), s1.find_first_of(s2c)); | ||||
|     for (std::string::size_type i = 0; i <= s1.size() + 1; ++i) | ||||
|     { | ||||
|       //std::cout << i << ": " << sv1.find_first_of(s2c, i) << " " << s1.find_first_of(s2c, i) << std::endl; | ||||
|       BOOST_TEST_EQ(sv1.find_first_of(s2c, i), s1.find_first_of(s2c, i));   | ||||
|     } | ||||
|   } | ||||
|  | ||||
|   void find_last_of_test() | ||||
|   { | ||||
|     std::cout << "find_last_of test..." << std::endl; | ||||
|  | ||||
|     //  find_last_of - test two modified and two new signatures | ||||
|     std::string s1("Hello World!"); | ||||
|     boost::string_view sv1(s1); | ||||
|     std::string s2("o"); | ||||
|     boost::string_view sv2(s2); | ||||
|     const char* s2c = "Good Bye"; | ||||
|     boost::string_view sv2c(s2c); | ||||
|     std::string s3; | ||||
|     boost::string_view sv3(s3); | ||||
|  | ||||
|     //  smoke test | ||||
|     BOOST_TEST_EQ(sv1.find_last_of(sv2), s1.find_last_of(s2)); | ||||
|     BOOST_TEST_EQ(sv1.find_last_of(sv2, 5), s1.find_last_of(s2, 5)); | ||||
|     BOOST_TEST_EQ(sv1.find_last_of(s2c), s1.find_last_of(s2c)); | ||||
|     BOOST_TEST_EQ(sv1.find_last_of(s2c, 0, 4), s1.find_last_of(s2c, 0, 4)); | ||||
|  | ||||
|     //  first signature | ||||
|     BOOST_TEST_EQ(sv3.find_last_of(sv3), s3.find_last_of(s3));  // both strings empty | ||||
|     BOOST_TEST_EQ(sv1.find_last_of(sv3), s1.find_last_of(s3));  // search string empty | ||||
|     BOOST_TEST_EQ(sv3.find_last_of(sv2), s3.find_last_of(s2));  // searched string empty | ||||
|     BOOST_TEST_EQ(sv1.find_last_of(sv3, s1.size() + 2), s1.find_last_of(s3, s1.size() + 2)); | ||||
|     BOOST_TEST_EQ(sv1.find_last_of(sv3, s1.size() + 1), s1.find_last_of(s3, s1.size() + 1)); | ||||
|     BOOST_TEST_EQ(sv1.find_last_of(sv3, s1.size()), s1.find_last_of(s3, s1.size())); | ||||
|     BOOST_TEST_EQ(sv1.find_last_of(sv3, s1.size() -  1), s1.find_last_of(s3, s1.size() -  1)); | ||||
|  | ||||
|     BOOST_TEST_EQ(sv1.find_last_of(sv2), s1.find_last_of(s2)); | ||||
|     for (std::string::size_type i = 0; i <= s1.size() + 1; ++i) | ||||
|     { | ||||
|       //std::cout << i << ": " << sv1.find_last_of(sv2, i) << " " << s1.find_last_of(s2, i) << std::endl; | ||||
|       BOOST_TEST_EQ(sv1.find_last_of(sv2, i), s1.find_last_of(s2, i)); | ||||
|     } | ||||
|     for (std::string::size_type i = 0; i <= s1.size() + 1; ++i) | ||||
|     { | ||||
|       //std::cout << i << ": " << sv1.find_last_of(sv3, i) << " " << s1.find_last_of(s3, i) << std::endl; | ||||
|       BOOST_TEST_EQ(sv1.find_last_of(sv3, i), s1.find_last_of(s3, i)); | ||||
|     } | ||||
|  | ||||
|     //  second signature | ||||
|     for (std::string::size_type i = 0; i <= s1.size() + 1; ++i) | ||||
|     { | ||||
|       //std::cout << i << ": " << sv1.find_last_of('o', i) << " " << s1.find_last_of('o', i) << std::endl; | ||||
|       BOOST_TEST_EQ(sv1.find_last_of('o', i), s1.find_last_of('o', i)); | ||||
|     } | ||||
|  | ||||
|     //  third signature | ||||
|     for (std::string::size_type i = 0; i <= s1.size() + 1; ++i) | ||||
|       for (std::string::size_type j = 0; j <= std::strlen(s2c) + 1; ++j) | ||||
|       { | ||||
|         //std::cout << i << "," << j << ": " << sv1.find_last_of(s2c, i, j) << " " << s1.find_last_of(s2c, i, j) << std::endl; | ||||
|         BOOST_TEST_EQ(sv1.find_last_of(s2c, i, j), s1.find_last_of(s2c, i, j)); | ||||
|       } | ||||
|  | ||||
|     //  fourth signature | ||||
|     BOOST_TEST_EQ(sv1.find_last_of(s2c), s1.find_last_of(s2c)); | ||||
|     for (std::string::size_type i = 0; i <= s1.size() + 1; ++i) | ||||
|     { | ||||
|       //std::cout << i << ": " << sv1.find_last_of(s2c, i) << " " << s1.find_last_of(s2c, i) << std::endl; | ||||
|       BOOST_TEST_EQ(sv1.find_last_of(s2c, i), s1.find_last_of(s2c, i));   | ||||
|     } | ||||
|   } | ||||
|  | ||||
|   void find_first_not_of_test() | ||||
|   { | ||||
|     std::cout << "find_first_not_of test..." << std::endl; | ||||
|  | ||||
|     //  find_first_not_of - test two modified and two new signatures | ||||
|     std::string s1("Hello World!"); | ||||
|     boost::string_view sv1(s1); | ||||
|     std::string s2("o"); | ||||
|     boost::string_view sv2(s2); | ||||
|     const char* s2c = "Good Bye"; | ||||
|     boost::string_view sv2c(s2c); | ||||
|     std::string s3; | ||||
|     boost::string_view sv3(s3); | ||||
|  | ||||
|     //  smoke test | ||||
|     BOOST_TEST_EQ(sv1.find_first_not_of(sv2), s1.find_first_not_of(s2)); | ||||
|     BOOST_TEST_EQ(sv1.find_first_not_of(sv2, 5), s1.find_first_not_of(s2, 5)); | ||||
|     BOOST_TEST_EQ(sv1.find_first_not_of(s2c), s1.find_first_not_of(s2c)); | ||||
|     BOOST_TEST_EQ(sv1.find_first_not_of(s2c, 0, 4), s1.find_first_not_of(s2c, 0, 4)); | ||||
|  | ||||
|     //  first signature | ||||
|     BOOST_TEST_EQ(sv3.find_first_not_of(sv3), s3.find_first_not_of(s3));  // both strings empty | ||||
|     BOOST_TEST_EQ(sv1.find_first_not_of(sv3), s1.find_first_not_of(s3));  // search string empty | ||||
|     BOOST_TEST_EQ(sv3.find_first_not_of(sv2), s3.find_first_not_of(s2));  // searched string empty | ||||
|     BOOST_TEST_EQ(sv1.find_first_not_of(sv3, s1.size() + 2), s1.find_first_not_of(s3, s1.size() + 2)); | ||||
|     BOOST_TEST_EQ(sv1.find_first_not_of(sv3, s1.size() + 1), s1.find_first_not_of(s3, s1.size() + 1)); | ||||
|     BOOST_TEST_EQ(sv1.find_first_not_of(sv3, s1.size()), s1.find_first_not_of(s3, s1.size())); | ||||
|     BOOST_TEST_EQ(sv1.find_first_not_of(sv3, s1.size() -  1), s1.find_first_not_of(s3, s1.size() -  1)); | ||||
|  | ||||
|     BOOST_TEST_EQ(sv1.find_first_not_of(sv2), s1.find_first_not_of(s2)); | ||||
|     for (std::string::size_type i = 0; i <= s1.size() + 1; ++i) | ||||
|     { | ||||
|       //std::cout << i << ": " << sv1.find_first_not_of(sv2, i) << " " << s1.find_first_not_of(s2, i) << std::endl; | ||||
|       BOOST_TEST_EQ(sv1.find_first_not_of(sv2, i), s1.find_first_not_of(s2, i)); | ||||
|     } | ||||
|     for (std::string::size_type i = 0; i <= s1.size() + 1; ++i) | ||||
|     { | ||||
|       //std::cout << i << ": " << sv1.find_first_not_of(sv3, i) << " " << s1.find_first_not_of(s3, i) << std::endl; | ||||
|       BOOST_TEST_EQ(sv1.find_first_not_of(sv3, i), s1.find_first_not_of(s3, i)); | ||||
|     } | ||||
|  | ||||
|     //  second signature | ||||
|     for (std::string::size_type i = 0; i <= s1.size() + 1; ++i) | ||||
|     { | ||||
|       //std::cout << i << ": " << sv1.find_first_not_of('o', i) << " " << s1.find_first_not_of('o', i) << std::endl; | ||||
|       BOOST_TEST_EQ(sv1.find_first_not_of('o', i), s1.find_first_not_of('o', i)); | ||||
|     } | ||||
|  | ||||
|     //  third signature | ||||
|     for (std::string::size_type i = 0; i <= s1.size() + 1; ++i) | ||||
|       for (std::string::size_type j = 0; j <= std::strlen(s2c) + 1; ++j) | ||||
|       { | ||||
|         //std::cout << i << "," << j << ": " << sv1.find_first_not_of(s2c, i, j) << " " << s1.find_first_not_of(s2c, i, j) << std::endl; | ||||
|         BOOST_TEST_EQ(sv1.find_first_not_of(s2c, i, j), s1.find_first_not_of(s2c, i, j)); | ||||
|       } | ||||
|  | ||||
|     //  fourth signature | ||||
|     BOOST_TEST_EQ(sv1.find_first_not_of(s2c), s1.find_first_not_of(s2c)); | ||||
|     for (std::string::size_type i = 0; i <= s1.size() + 1; ++i) | ||||
|     { | ||||
|       //std::cout << i << ": " << sv1.find_first_not_of(s2c, i) << " " << s1.find_first_not_of(s2c, i) << std::endl; | ||||
|       BOOST_TEST_EQ(sv1.find_first_not_of(s2c, i), s1.find_first_not_of(s2c, i));   | ||||
|     } | ||||
|   } | ||||
|  | ||||
|   void find_last_not_of_test() | ||||
|   { | ||||
|     std::cout << "find_last_not_of test..." << std::endl; | ||||
|  | ||||
|     //  find_last_not_of - test two modified and two new signatures | ||||
|     std::string s1("Hello World!"); | ||||
|     boost::string_view sv1(s1); | ||||
|     std::string s2("o"); | ||||
|     boost::string_view sv2(s2); | ||||
|     const char* s2c = "Good Bye"; | ||||
|     boost::string_view sv2c(s2c); | ||||
|     std::string s3; | ||||
|     boost::string_view sv3(s3); | ||||
|  | ||||
|     //  smoke test | ||||
|     BOOST_TEST_EQ(sv1.find_last_not_of(sv2), s1.find_last_not_of(s2)); | ||||
|     BOOST_TEST_EQ(sv1.find_last_not_of(sv2, 5), s1.find_last_not_of(s2, 5)); | ||||
|     BOOST_TEST_EQ(sv1.find_last_not_of(s2c), s1.find_last_not_of(s2c)); | ||||
|     BOOST_TEST_EQ(sv1.find_last_not_of(s2c, 0, 4), s1.find_last_not_of(s2c, 0, 4)); | ||||
|  | ||||
|     //  first signature | ||||
|     BOOST_TEST_EQ(sv3.find_last_not_of(sv3), s3.find_last_not_of(s3));  // both strings empty | ||||
|     BOOST_TEST_EQ(sv1.find_last_not_of(sv3), s1.find_last_not_of(s3));  // search string empty | ||||
|     BOOST_TEST_EQ(sv3.find_last_not_of(sv2), s3.find_last_not_of(s2));  // searched string empty | ||||
|     BOOST_TEST_EQ(sv1.find_last_not_of(sv3, s1.size() + 2), s1.find_last_not_of(s3, s1.size() + 2)); | ||||
|     BOOST_TEST_EQ(sv1.find_last_not_of(sv3, s1.size() + 1), s1.find_last_not_of(s3, s1.size() + 1)); | ||||
|     BOOST_TEST_EQ(sv1.find_last_not_of(sv3, s1.size()), s1.find_last_not_of(s3, s1.size())); | ||||
|     BOOST_TEST_EQ(sv1.find_last_not_of(sv3, s1.size() -  1), s1.find_last_not_of(s3, s1.size() -  1)); | ||||
|  | ||||
|     BOOST_TEST_EQ(sv1.find_last_not_of(sv2), s1.find_last_not_of(s2)); | ||||
|     for (std::string::size_type i = 0; i <= s1.size() + 1; ++i) | ||||
|     { | ||||
|       //std::cout << i << ": " << sv1.find_last_not_of(sv2, i) << " " << s1.find_last_not_of(s2, i) << std::endl; | ||||
|       BOOST_TEST_EQ(sv1.find_last_not_of(sv2, i), s1.find_last_not_of(s2, i)); | ||||
|     } | ||||
|     for (std::string::size_type i = 0; i <= s1.size() + 1; ++i) | ||||
|     { | ||||
|       //std::cout << i << ": " << sv1.find_last_not_of(sv3, i) << " " << s1.find_last_not_of(s3, i) << std::endl; | ||||
|       BOOST_TEST_EQ(sv1.find_last_not_of(sv3, i), s1.find_last_not_of(s3, i)); | ||||
|     } | ||||
|  | ||||
|     //  second signature | ||||
|     for (std::string::size_type i = 0; i <= s1.size() + 1; ++i) | ||||
|     { | ||||
|       //std::cout << i << ": " << sv1.find_last_not_of('o', i) << " " << s1.find_last_not_of('o', i) << std::endl; | ||||
|       BOOST_TEST_EQ(sv1.find_last_not_of('o', i), s1.find_last_not_of('o', i)); | ||||
|     } | ||||
|  | ||||
|     //  third signature | ||||
|     for (std::string::size_type i = 0; i <= s1.size() + 1; ++i) | ||||
|       for (std::string::size_type j = 0; j <= std::strlen(s2c) + 1; ++j) | ||||
|       { | ||||
|         //std::cout << i << "," << j << ": " << sv1.find_last_not_of(s2c, i, j) << " " << s1.find_last_not_of(s2c, i, j) << std::endl; | ||||
|         BOOST_TEST_EQ(sv1.find_last_not_of(s2c, i, j), s1.find_last_not_of(s2c, i, j)); | ||||
|       } | ||||
|  | ||||
|     //  fourth signature | ||||
|     BOOST_TEST_EQ(sv1.find_last_not_of(s2c), s1.find_last_not_of(s2c)); | ||||
|     for (std::string::size_type i = 0; i <= s1.size() + 1; ++i) | ||||
|     { | ||||
|       //std::cout << i << ": " << sv1.find_last_not_of(s2c, i) << " " << s1.find_last_not_of(s2c, i) << std::endl; | ||||
|       BOOST_TEST_EQ(sv1.find_last_not_of(s2c, i), s1.find_last_not_of(s2c, i));   | ||||
|     } | ||||
|   } | ||||
|  | ||||
| }  // unnamed namespace | ||||
|  | ||||
| int cpp_main(int argc, char* argv[]) | ||||
| { | ||||
|   //  verify traits_type and const_pointer typedefs compile OK | ||||
|   BOOST_TEST(boost::string_view::traits_type::eq('x', 'x')); | ||||
|   BOOST_TEST_EQ(sizeof(boost::string_view::const_pointer), sizeof(&argc)); | ||||
|  | ||||
|   swap_test(); | ||||
|   copy_test(); | ||||
|   compare_test(); | ||||
|   find_test(); | ||||
|   rfind_test(); | ||||
|   find_first_of_test(); | ||||
|   find_last_of_test(); | ||||
|   find_first_not_of_test(); | ||||
|   find_last_not_of_test(); | ||||
|  | ||||
|   return boost::report_errors(); | ||||
| } | ||||
| @@ -5,15 +5,13 @@ | ||||
|  *          http://www.boost.org/LICENSE_1_0.txt) | ||||
|  */ | ||||
| /*! | ||||
|  * \file   string_view_test_io.cpp | ||||
|  * \file   string_ref_test_io.cpp | ||||
|  * \author Andrey Semashev | ||||
|  * \date   26.05.2013 | ||||
|  * | ||||
|  * \brief  This header contains tests for stream operations of \c basic_string_view. | ||||
|  * \brief  This header contains tests for stream operations of \c basic_string_ref. | ||||
|  */ | ||||
|  | ||||
| #define BOOST_TEST_MODULE string_view_test_io | ||||
|  | ||||
| #include <boost/utility/string_view.hpp> | ||||
|  | ||||
| #include <iomanip> | ||||
| @@ -23,23 +21,10 @@ | ||||
| #include <string> | ||||
|  | ||||
| #include <boost/config.hpp> | ||||
| #include <boost/mpl/vector.hpp> | ||||
| #include <boost/test/unit_test.hpp> | ||||
| #include <boost/core/lightweight_test.hpp> | ||||
|  | ||||
| typedef boost::mpl::vector< | ||||
|     char | ||||
| #if !defined(BOOST_NO_STD_WSTRING) && !defined(BOOST_NO_STD_WSTREAMBUF) && !defined(BOOST_NO_INTRINSIC_WCHAR_T) | ||||
|     , wchar_t | ||||
| #endif | ||||
| /* Current implementations seem to be missing codecvt facets to convert chars to char16_t and char32_t even though the types are available. | ||||
| #if !defined(BOOST_NO_CXX11_CHAR16_T) | ||||
|     , char16_t | ||||
| #endif | ||||
| #if !defined(BOOST_NO_CXX11_CHAR32_T) | ||||
|     , char32_t | ||||
| #endif | ||||
| */ | ||||
| >::type char_types; | ||||
|  | ||||
| static const char* test_strings[] = | ||||
| { | ||||
| @@ -72,10 +57,10 @@ struct context | ||||
| }; | ||||
|  | ||||
| // Test regular output | ||||
| BOOST_AUTO_TEST_CASE_TEMPLATE(string_view_output, CharT, char_types) | ||||
| template<class CharT> | ||||
| void test_string_view_output() | ||||
| { | ||||
|     typedef CharT char_type; | ||||
|     //typedef std::basic_string< char_type > string_type; | ||||
|     typedef std::basic_ostringstream< char_type > ostream_type; | ||||
|     typedef boost::basic_string_view< char_type > string_view_type; | ||||
|  | ||||
| @@ -83,14 +68,14 @@ BOOST_AUTO_TEST_CASE_TEMPLATE(string_view_output, CharT, char_types) | ||||
|  | ||||
|     ostream_type strm; | ||||
|     strm << string_view_type(ctx.abcd); | ||||
|     BOOST_CHECK(strm.str() == ctx.abcd); | ||||
|     BOOST_TEST(strm.str() == ctx.abcd); | ||||
| } | ||||
|  | ||||
| // Test support for padding | ||||
| BOOST_AUTO_TEST_CASE_TEMPLATE(padding, CharT, char_types) | ||||
| template<class CharT> | ||||
| void test_padding() | ||||
| { | ||||
|     typedef CharT char_type; | ||||
|     //typedef std::basic_string< char_type > string_type; | ||||
|     typedef std::basic_ostringstream< char_type > ostream_type; | ||||
|     typedef boost::basic_string_view< char_type > string_view_type; | ||||
|  | ||||
| @@ -98,62 +83,62 @@ BOOST_AUTO_TEST_CASE_TEMPLATE(padding, CharT, char_types) | ||||
|  | ||||
|     // Test for padding | ||||
|     { | ||||
|         ostream_type strm_view; | ||||
|         strm_view << ctx.begin << std::setw(8) << string_view_type(ctx.abcd) << ctx.end; | ||||
|         ostream_type strm_ref; | ||||
|         strm_ref << ctx.begin << std::setw(8) << string_view_type(ctx.abcd) << ctx.end; | ||||
|  | ||||
|         ostream_type strm_correct; | ||||
|         strm_correct << ctx.begin << std::setw(8) << ctx.abcd << ctx.end; | ||||
|  | ||||
|         BOOST_CHECK(strm_view.str() == strm_correct.str()); | ||||
|         BOOST_TEST(strm_ref.str() == strm_correct.str()); | ||||
|     } | ||||
|  | ||||
|     // Test for long padding | ||||
|     { | ||||
|         ostream_type strm_view; | ||||
|         strm_view << ctx.begin << std::setw(100) << string_view_type(ctx.abcd) << ctx.end; | ||||
|         ostream_type strm_ref; | ||||
|         strm_ref << ctx.begin << std::setw(100) << string_view_type(ctx.abcd) << ctx.end; | ||||
|  | ||||
|         ostream_type strm_correct; | ||||
|         strm_correct << ctx.begin << std::setw(100) << ctx.abcd << ctx.end; | ||||
|  | ||||
|         BOOST_CHECK(strm_view.str() == strm_correct.str()); | ||||
|         BOOST_TEST(strm_ref.str() == strm_correct.str()); | ||||
|     } | ||||
|  | ||||
|     // Test that short width does not truncate the string | ||||
|     { | ||||
|         ostream_type strm_view; | ||||
|         strm_view << ctx.begin << std::setw(1) << string_view_type(ctx.abcd) << ctx.end; | ||||
|         ostream_type strm_ref; | ||||
|         strm_ref << ctx.begin << std::setw(1) << string_view_type(ctx.abcd) << ctx.end; | ||||
|  | ||||
|         ostream_type strm_correct; | ||||
|         strm_correct << ctx.begin << std::setw(1) << ctx.abcd << ctx.end; | ||||
|  | ||||
|         BOOST_CHECK(strm_view.str() == strm_correct.str()); | ||||
|         BOOST_TEST(strm_ref.str() == strm_correct.str()); | ||||
|     } | ||||
| } | ||||
|  | ||||
| // Test support for padding fill | ||||
| BOOST_AUTO_TEST_CASE_TEMPLATE(padding_fill, CharT, char_types) | ||||
| template<class CharT> | ||||
| void test_padding_fill() | ||||
| { | ||||
|     typedef CharT char_type; | ||||
|     //typedef std::basic_string< char_type > string_type; | ||||
|     typedef std::basic_ostringstream< char_type > ostream_type; | ||||
|     typedef boost::basic_string_view< char_type > string_view_type; | ||||
|  | ||||
|     context< char_type > ctx; | ||||
|  | ||||
|     ostream_type strm_view; | ||||
|     strm_view << ctx.begin << std::setfill(static_cast< char_type >('x')) << std::setw(8) << string_view_type(ctx.abcd) << ctx.end; | ||||
|     ostream_type strm_ref; | ||||
|     strm_ref << ctx.begin << std::setfill(static_cast< char_type >('x')) << std::setw(8) << string_view_type(ctx.abcd) << ctx.end; | ||||
|  | ||||
|     ostream_type strm_correct; | ||||
|     strm_correct << ctx.begin << std::setfill(static_cast< char_type >('x')) << std::setw(8) << ctx.abcd << ctx.end; | ||||
|  | ||||
|     BOOST_CHECK(strm_view.str() == strm_correct.str()); | ||||
|     BOOST_TEST(strm_ref.str() == strm_correct.str()); | ||||
| } | ||||
|  | ||||
| // Test support for alignment | ||||
| BOOST_AUTO_TEST_CASE_TEMPLATE(alignment, CharT, char_types) | ||||
| template<class CharT> | ||||
| void test_alignment() | ||||
| { | ||||
|     typedef CharT char_type; | ||||
|     //typedef std::basic_string< char_type > string_type; | ||||
|     typedef std::basic_ostringstream< char_type > ostream_type; | ||||
|     typedef boost::basic_string_view< char_type > string_view_type; | ||||
|  | ||||
| @@ -161,23 +146,39 @@ BOOST_AUTO_TEST_CASE_TEMPLATE(alignment, CharT, char_types) | ||||
|  | ||||
|     // Left alignment | ||||
|     { | ||||
|         ostream_type strm_view; | ||||
|         strm_view << ctx.begin << std::left << std::setw(8) << string_view_type(ctx.abcd) << ctx.end; | ||||
|         ostream_type strm_ref; | ||||
|         strm_ref << ctx.begin << std::left << std::setw(8) << string_view_type(ctx.abcd) << ctx.end; | ||||
|  | ||||
|         ostream_type strm_correct; | ||||
|         strm_correct << ctx.begin << std::left << std::setw(8) << ctx.abcd << ctx.end; | ||||
|  | ||||
|         BOOST_CHECK(strm_view.str() == strm_correct.str()); | ||||
|         BOOST_TEST(strm_ref.str() == strm_correct.str()); | ||||
|     } | ||||
|  | ||||
|     // Right alignment | ||||
|     { | ||||
|         ostream_type strm_view; | ||||
|         strm_view << ctx.begin << std::right << std::setw(8) << string_view_type(ctx.abcd) << ctx.end; | ||||
|         ostream_type strm_ref; | ||||
|         strm_ref << ctx.begin << std::right << std::setw(8) << string_view_type(ctx.abcd) << ctx.end; | ||||
|  | ||||
|         ostream_type strm_correct; | ||||
|         strm_correct << ctx.begin << std::right << std::setw(8) << ctx.abcd << ctx.end; | ||||
|  | ||||
|         BOOST_CHECK(strm_view.str() == strm_correct.str()); | ||||
|         BOOST_TEST(strm_ref.str() == strm_correct.str()); | ||||
|     } | ||||
| } | ||||
|  | ||||
| template<class CharT> | ||||
| void test() | ||||
| { | ||||
|     test_string_view_output<CharT>(); | ||||
|     test_padding<CharT>(); | ||||
|     test_padding_fill<CharT>(); | ||||
|     test_alignment<CharT>(); | ||||
| } | ||||
|  | ||||
| int main() | ||||
| { | ||||
|     test<char>(); | ||||
|     test<wchar_t>(); | ||||
|     return boost::report_errors(); | ||||
| } | ||||
|   | ||||
| @@ -16,13 +16,12 @@ | ||||
| #include <string> | ||||
| 
 | ||||
| #include "boost/utility/value_init.hpp" | ||||
| #include <boost/shared_ptr.hpp> | ||||
| 
 | ||||
| #ifdef __BORLANDC__ | ||||
| #pragma hdrstop | ||||
| #endif | ||||
| 
 | ||||
| #include <boost/detail/lightweight_test.hpp> | ||||
| #include <boost/core/lightweight_test.hpp> | ||||
| 
 | ||||
| //
 | ||||
| // Sample POD type
 | ||||
| @@ -270,9 +269,12 @@ bool test ( T const& y, T const& z ) | ||||
|   boost::value_initialized<T> copy2; | ||||
|   copy2 = x; | ||||
|   BOOST_TEST ( boost::get(copy2) == boost::get(x) ) ; | ||||
|    | ||||
|   boost::shared_ptr<boost::value_initialized<T> > ptr( new boost::value_initialized<T> ); | ||||
|   BOOST_TEST ( y == *ptr ) ; | ||||
| 
 | ||||
|   { | ||||
|     boost::value_initialized<T> * ptr = new boost::value_initialized<T>; | ||||
|     BOOST_TEST ( y == *ptr ) ; | ||||
|     delete ptr; | ||||
|   } | ||||
| 
 | ||||
| #if !BOOST_WORKAROUND(BOOST_MSVC, < 1300) | ||||
|   boost::value_initialized<T const> cx ; | ||||
| @@ -287,7 +289,7 @@ bool test ( T const& y, T const& z ) | ||||
|   return boost::detail::test_errors() == errors_before_test ; | ||||
| } | ||||
| 
 | ||||
| int main(int, char **) | ||||
| int main() | ||||
| { | ||||
|   BOOST_TEST ( test( 0,1234 ) ) ; | ||||
|   BOOST_TEST ( test( 0.0,12.34 ) ) ; | ||||
| @@ -17,9 +17,7 @@ | ||||
| #pragma hdrstop | ||||
| #endif | ||||
| 
 | ||||
| #include "boost/test/minimal.hpp" | ||||
| 
 | ||||
| int test_main(int, char **) | ||||
| int main() | ||||
| { | ||||
|   boost::value_initialized<int> const x_c ; | ||||
| 
 | ||||
| @@ -27,11 +25,3 @@ int test_main(int, char **) | ||||
| 
 | ||||
|   return 0; | ||||
| } | ||||
| 
 | ||||
| 
 | ||||
| unsigned int expected_failures = 0; | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| @@ -17,9 +17,7 @@ | ||||
| #pragma hdrstop | ||||
| #endif | ||||
| 
 | ||||
| #include "boost/test/minimal.hpp" | ||||
| 
 | ||||
| int test_main(int, char **) | ||||
| int main() | ||||
| { | ||||
|   boost::value_initialized<int const> cx ; | ||||
| 
 | ||||
| @@ -27,10 +25,3 @@ int test_main(int, char **) | ||||
| 
 | ||||
|   return 0; | ||||
| } | ||||
| 
 | ||||
| unsigned int expected_failures = 0; | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| @@ -17,9 +17,7 @@ | ||||
| #pragma hdrstop | ||||
| #endif | ||||
| 
 | ||||
| #include "boost/test/minimal.hpp" | ||||
| 
 | ||||
| int test_main(int, char **) | ||||
| int main() | ||||
| { | ||||
|   boost::value_initialized<int const> const cx_c ; | ||||
| 
 | ||||
| @@ -27,11 +25,3 @@ int test_main(int, char **) | ||||
| 
 | ||||
|   return 0; | ||||
| } | ||||
| 
 | ||||
| 
 | ||||
| unsigned int expected_failures = 0; | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| @@ -75,6 +75,24 @@ namespace | ||||
|     return true; | ||||
|   } | ||||
| 
 | ||||
|   struct int_pair_struct | ||||
|   { | ||||
|     int first; | ||||
|     int second; | ||||
|   }; | ||||
| 
 | ||||
|   typedef int int_pair_struct::*ptr_to_member_type; | ||||
| 
 | ||||
|   struct ptr_to_member_struct | ||||
|   { | ||||
|     ptr_to_member_type data; | ||||
|   }; | ||||
| 
 | ||||
|   bool is_value_initialized(const ptr_to_member_struct& arg) | ||||
|   { | ||||
|     return arg.data == 0; | ||||
|   } | ||||
| 
 | ||||
|   template <typename T> | ||||
|   bool is_value_initialized(const T(& arg)[2]) | ||||
|   { | ||||
| @@ -132,7 +150,8 @@ int main() | ||||
|   const unsigned num_failures = | ||||
|     FAILED_TO_VALUE_INITIALIZE(boost::value_initialized<derived_struct>()) + | ||||
|     FAILED_TO_VALUE_INITIALIZE(boost::value_initialized<virtual_destructor_holder[2]>()) + | ||||
| 	FAILED_TO_VALUE_INITIALIZE(boost::value_initialized<private_int_array_pair>()); | ||||
|     FAILED_TO_VALUE_INITIALIZE(boost::value_initialized<private_int_array_pair>()) + | ||||
|     FAILED_TO_VALUE_INITIALIZE(boost::value_initialized<ptr_to_member_struct>()); | ||||
| 
 | ||||
| #ifdef BOOST_DETAIL_VALUE_INIT_WORKAROUND_SUGGESTED | ||||
|   // One or more failures are expected.
 | ||||
							
								
								
									
										41
									
								
								utility.htm
									
									
									
									
									
								
							
							
						
						
									
										41
									
								
								utility.htm
									
									
									
									
									
								
							| @@ -17,7 +17,7 @@ | ||||
| 				Function templates <a href="../core/doc/html/core/checked_delete.html">checked_delete() and  | ||||
| 					checked_array_delete()</a> (moved to the Boost.Core library)</li> | ||||
| 			<li> | ||||
| 				Function templates <a href="#functions_next_prior">next() and prior()</a></li> | ||||
| 				Function templates <a href="../iterator/doc/html/iterator/algorithms/next_prior.html">next() and prior()</a> (moved to the Boost.Iterator library)</li> | ||||
| 			<li> | ||||
| 				Class <a href="../core/doc/html/core/noncopyable.html">noncopyable</a> (moved to the Boost.Core library)</li> | ||||
| 			<li> | ||||
| @@ -28,45 +28,6 @@ | ||||
|                         <li><a href="index.html">Other utilities not part of <code>utility.hpp</code></a></li> | ||||
| 		</ul> | ||||
| 		<h2> | ||||
| 			<a name="functions_next_prior">Function</a> templates next() and prior()</h2> | ||||
| 		<p>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 <code>itr+1</code> inside  | ||||
| 			a template restricts the iterator category to random access iterators.</p> | ||||
| 		<p>The next() and prior() functions provide a simple way around these problems:</p> | ||||
| 		<blockquote> | ||||
| 			<pre>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; | ||||
| }</pre> | ||||
| 		</blockquote> | ||||
| 		<p>Usage is simple:</p> | ||||
| 		<blockquote> | ||||
| 			<pre>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);</pre> | ||||
| 		</blockquote> | ||||
|                 <p>The distance from the given iterator should be supplied as an absolute value. For | ||||
| 			example, the iterator four iterators prior to the given iterator <code>p</code> | ||||
| 			may be obtained by <code>prior(p, 4)</code>.</p> | ||||
| 		<p>Contributed by <a href="http://www.boost.org/people/dave_abrahams.htm">Dave Abrahams</a>.  Two-argument versions by Daniel Walker.</p> | ||||
|  | ||||
|                 <h2><a name="result_of">Class template | ||||
|                 result_of</a></h2> <p>The class template | ||||
|   | ||||
		Reference in New Issue
	
	Block a user