mirror of
https://github.com/boostorg/function.git
synced 2025-06-26 12:31:33 +02:00
Compare commits
28 Commits
feature/fu
...
boost-1.75
Author | SHA1 | Date | |
---|---|---|---|
52c8fd15d1 | |||
4841cbf475 | |||
b07c2efef5 | |||
1aa3e8c8d7 | |||
7c90434317 | |||
8ec9323003 | |||
c39ca938a6 | |||
4b25a75c03 | |||
5682111fad | |||
1694b32e1b | |||
eaf2151263 | |||
d9043b76d6 | |||
2e2c44f070 | |||
7f69508eac | |||
6d811a2e72 | |||
3f6b2b6f56 | |||
439d64d8a8 | |||
3f46081c59 | |||
17716b63f2 | |||
b6b0568c88 | |||
babdbe500d | |||
db39532c45 | |||
eb09bb6fec | |||
ccc66b34d9 | |||
e7952cb242 | |||
57f4171c77 | |||
30f31f894c | |||
bfb0e4701e |
111
.travis.yml
111
.travis.yml
@ -1,10 +1,10 @@
|
|||||||
# Copyright 2016, 2017, 2018 Peter Dimov
|
# Copyright 2016-2019 Peter Dimov
|
||||||
# Distributed under the Boost Software License, Version 1.0.
|
# Distributed under the Boost Software License, Version 1.0.
|
||||||
# (See accompanying file LICENSE_1_0.txt or copy at http://boost.org/LICENSE_1_0.txt)
|
# (See accompanying file LICENSE_1_0.txt or copy at http://boost.org/LICENSE_1_0.txt)
|
||||||
|
|
||||||
language: cpp
|
language: cpp
|
||||||
|
|
||||||
sudo: false
|
dist: xenial
|
||||||
|
|
||||||
branches:
|
branches:
|
||||||
only:
|
only:
|
||||||
@ -22,10 +22,6 @@ matrix:
|
|||||||
- env: BOGUS_JOB=true
|
- env: BOGUS_JOB=true
|
||||||
|
|
||||||
include:
|
include:
|
||||||
- os: linux
|
|
||||||
compiler: g++
|
|
||||||
env: TOOLSET=gcc CXXSTD=03,11 VARIANT=debug,release
|
|
||||||
|
|
||||||
- os: linux
|
- os: linux
|
||||||
compiler: g++-4.4
|
compiler: g++-4.4
|
||||||
env: TOOLSET=gcc CXXSTD=98,0x
|
env: TOOLSET=gcc CXXSTD=98,0x
|
||||||
@ -97,7 +93,7 @@ matrix:
|
|||||||
|
|
||||||
- os: linux
|
- os: linux
|
||||||
compiler: g++-7
|
compiler: g++-7
|
||||||
env: TOOLSET=gcc CXXSTD=03,11,14,17 VARIANT=release
|
env: TOOLSET=gcc CXXSTD=03,11,14,17
|
||||||
addons:
|
addons:
|
||||||
apt:
|
apt:
|
||||||
packages:
|
packages:
|
||||||
@ -116,20 +112,38 @@ matrix:
|
|||||||
- ubuntu-toolchain-r-test
|
- ubuntu-toolchain-r-test
|
||||||
|
|
||||||
- os: linux
|
- os: linux
|
||||||
compiler: g++-7
|
compiler: g++-9
|
||||||
env: UBSAN=1 TOOLSET=gcc CXXSTD=03,11,14,17 UBSAN_OPTIONS=print_stacktrace=1 LINKFLAGS=-fuse-ld=gold
|
env: TOOLSET=gcc CXXSTD=03,11,14,17,2a
|
||||||
addons:
|
addons:
|
||||||
apt:
|
apt:
|
||||||
packages:
|
packages:
|
||||||
- g++-7
|
- g++-9
|
||||||
sources:
|
sources:
|
||||||
- ubuntu-toolchain-r-test
|
- ubuntu-toolchain-r-test
|
||||||
|
|
||||||
- os: linux
|
- os: linux
|
||||||
compiler: clang++
|
dist: bionic
|
||||||
env: TOOLSET=clang CXXSTD=03,11 VARIANT=debug,release
|
compiler: g++-10
|
||||||
|
env: TOOLSET=gcc CXXSTD=03,11,14,17,2a
|
||||||
|
addons:
|
||||||
|
apt:
|
||||||
|
packages:
|
||||||
|
- g++-10
|
||||||
|
sources:
|
||||||
|
- ubuntu-toolchain-r-test
|
||||||
|
|
||||||
- os: linux
|
- os: linux
|
||||||
|
compiler: g++-9
|
||||||
|
env: UBSAN=1 TOOLSET=gcc CXXSTD=03,11,14,17,2a UBSAN_OPTIONS=print_stacktrace=1 LINKFLAGS=-fuse-ld=gold
|
||||||
|
addons:
|
||||||
|
apt:
|
||||||
|
packages:
|
||||||
|
- g++-9
|
||||||
|
sources:
|
||||||
|
- ubuntu-toolchain-r-test
|
||||||
|
|
||||||
|
- os: linux
|
||||||
|
dist: trusty
|
||||||
compiler: /usr/bin/clang++
|
compiler: /usr/bin/clang++
|
||||||
env: TOOLSET=clang CXXSTD=03,11
|
env: TOOLSET=clang CXXSTD=03,11
|
||||||
addons:
|
addons:
|
||||||
@ -138,6 +152,7 @@ matrix:
|
|||||||
- clang-3.3
|
- clang-3.3
|
||||||
|
|
||||||
- os: linux
|
- os: linux
|
||||||
|
dist: trusty
|
||||||
compiler: /usr/bin/clang++
|
compiler: /usr/bin/clang++
|
||||||
env: TOOLSET=clang CXXSTD=03,11
|
env: TOOLSET=clang CXXSTD=03,11
|
||||||
addons:
|
addons:
|
||||||
@ -152,10 +167,8 @@ matrix:
|
|||||||
apt:
|
apt:
|
||||||
packages:
|
packages:
|
||||||
- clang-3.5
|
- clang-3.5
|
||||||
- libstdc++-4.9-dev
|
|
||||||
sources:
|
sources:
|
||||||
- ubuntu-toolchain-r-test
|
- ubuntu-toolchain-r-test
|
||||||
- llvm-toolchain-precise-3.5
|
|
||||||
|
|
||||||
- os: linux
|
- os: linux
|
||||||
compiler: clang++-3.6
|
compiler: clang++-3.6
|
||||||
@ -166,7 +179,6 @@ matrix:
|
|||||||
- clang-3.6
|
- clang-3.6
|
||||||
sources:
|
sources:
|
||||||
- ubuntu-toolchain-r-test
|
- ubuntu-toolchain-r-test
|
||||||
- llvm-toolchain-precise-3.6
|
|
||||||
|
|
||||||
- os: linux
|
- os: linux
|
||||||
compiler: clang++-3.7
|
compiler: clang++-3.7
|
||||||
@ -177,7 +189,6 @@ matrix:
|
|||||||
- clang-3.7
|
- clang-3.7
|
||||||
sources:
|
sources:
|
||||||
- ubuntu-toolchain-r-test
|
- ubuntu-toolchain-r-test
|
||||||
- llvm-toolchain-precise-3.7
|
|
||||||
|
|
||||||
- os: linux
|
- os: linux
|
||||||
compiler: clang++-3.8
|
compiler: clang++-3.8
|
||||||
@ -186,10 +197,8 @@ matrix:
|
|||||||
apt:
|
apt:
|
||||||
packages:
|
packages:
|
||||||
- clang-3.8
|
- clang-3.8
|
||||||
- libstdc++-4.9-dev
|
|
||||||
sources:
|
sources:
|
||||||
- ubuntu-toolchain-r-test
|
- ubuntu-toolchain-r-test
|
||||||
- llvm-toolchain-precise-3.8
|
|
||||||
|
|
||||||
- os: linux
|
- os: linux
|
||||||
compiler: clang++-3.9
|
compiler: clang++-3.9
|
||||||
@ -198,10 +207,8 @@ matrix:
|
|||||||
apt:
|
apt:
|
||||||
packages:
|
packages:
|
||||||
- clang-3.9
|
- clang-3.9
|
||||||
- libstdc++-4.9-dev
|
|
||||||
sources:
|
sources:
|
||||||
- ubuntu-toolchain-r-test
|
- ubuntu-toolchain-r-test
|
||||||
- llvm-toolchain-precise-3.9
|
|
||||||
|
|
||||||
- os: linux
|
- os: linux
|
||||||
compiler: clang++-4.0
|
compiler: clang++-4.0
|
||||||
@ -212,18 +219,16 @@ matrix:
|
|||||||
- clang-4.0
|
- clang-4.0
|
||||||
sources:
|
sources:
|
||||||
- ubuntu-toolchain-r-test
|
- ubuntu-toolchain-r-test
|
||||||
- llvm-toolchain-trusty-4.0
|
|
||||||
|
|
||||||
- os: linux
|
- os: linux
|
||||||
compiler: clang++-5.0
|
compiler: clang++-5.0
|
||||||
env: TOOLSET=clang CXXSTD=03,11,14,1z VARIANT=release
|
env: TOOLSET=clang CXXSTD=03,11,14,1z
|
||||||
addons:
|
addons:
|
||||||
apt:
|
apt:
|
||||||
packages:
|
packages:
|
||||||
- clang-5.0
|
- clang-5.0
|
||||||
sources:
|
sources:
|
||||||
- ubuntu-toolchain-r-test
|
- ubuntu-toolchain-r-test
|
||||||
- llvm-toolchain-trusty-5.0
|
|
||||||
|
|
||||||
- os: linux
|
- os: linux
|
||||||
compiler: clang++-6.0
|
compiler: clang++-6.0
|
||||||
@ -234,7 +239,6 @@ matrix:
|
|||||||
- clang-6.0
|
- clang-6.0
|
||||||
sources:
|
sources:
|
||||||
- ubuntu-toolchain-r-test
|
- ubuntu-toolchain-r-test
|
||||||
- llvm-toolchain-trusty-6.0
|
|
||||||
|
|
||||||
- os: linux
|
- os: linux
|
||||||
compiler: clang++-7
|
compiler: clang++-7
|
||||||
@ -245,28 +249,67 @@ matrix:
|
|||||||
- clang-7
|
- clang-7
|
||||||
sources:
|
sources:
|
||||||
- ubuntu-toolchain-r-test
|
- ubuntu-toolchain-r-test
|
||||||
- llvm-toolchain-trusty-7
|
- llvm-toolchain-xenial-7
|
||||||
|
|
||||||
- os: linux
|
- os: linux
|
||||||
compiler: clang++-5.0
|
compiler: clang++-8
|
||||||
env: UBSAN=1 TOOLSET=clang CXXSTD=03,11,14,1z UBSAN_OPTIONS=print_stacktrace=1
|
env: TOOLSET=clang CXXSTD=03,11,14,17,2a
|
||||||
addons:
|
addons:
|
||||||
apt:
|
apt:
|
||||||
packages:
|
packages:
|
||||||
- clang-5.0
|
- clang-8
|
||||||
sources:
|
sources:
|
||||||
- ubuntu-toolchain-r-test
|
- ubuntu-toolchain-r-test
|
||||||
- llvm-toolchain-trusty-5.0
|
- llvm-toolchain-xenial-8
|
||||||
|
|
||||||
- os: linux
|
- os: linux
|
||||||
|
dist: xenial
|
||||||
|
compiler: clang++-9
|
||||||
|
env: TOOLSET=clang CXXSTD=03,11,14,17,2a
|
||||||
|
addons:
|
||||||
|
apt:
|
||||||
|
packages:
|
||||||
|
- clang-9
|
||||||
|
sources:
|
||||||
|
- ubuntu-toolchain-r-test
|
||||||
|
- sourceline: 'deb https://apt.llvm.org/xenial/ llvm-toolchain-xenial-9 main'
|
||||||
|
key_url: 'https://apt.llvm.org/llvm-snapshot.gpg.key'
|
||||||
|
|
||||||
|
- os: linux
|
||||||
|
dist: xenial
|
||||||
|
compiler: clang++-10
|
||||||
|
env: TOOLSET=clang CXXSTD=03,11,14,17,2a
|
||||||
|
addons:
|
||||||
|
apt:
|
||||||
|
packages:
|
||||||
|
- clang-10
|
||||||
|
sources:
|
||||||
|
- ubuntu-toolchain-r-test
|
||||||
|
- sourceline: 'deb https://apt.llvm.org/xenial/ llvm-toolchain-xenial-10 main'
|
||||||
|
key_url: 'https://apt.llvm.org/llvm-snapshot.gpg.key'
|
||||||
|
|
||||||
|
- os: linux
|
||||||
|
compiler: clang++-8
|
||||||
|
env: UBSAN=1 TOOLSET=clang CXXSTD=03,11,14,17,2a UBSAN_OPTIONS=print_stacktrace=1
|
||||||
|
addons:
|
||||||
|
apt:
|
||||||
|
packages:
|
||||||
|
- clang-8
|
||||||
|
sources:
|
||||||
|
- ubuntu-toolchain-r-test
|
||||||
|
- llvm-toolchain-xenial-8
|
||||||
|
|
||||||
|
- os: linux
|
||||||
|
dist: trusty
|
||||||
compiler: clang++-libc++
|
compiler: clang++-libc++
|
||||||
env: TOOLSET=clang CXXSTD=03,11,14,1z VARIANT=release
|
env: TOOLSET=clang CXXSTD=03,11,14,1z
|
||||||
addons:
|
addons:
|
||||||
apt:
|
apt:
|
||||||
packages:
|
packages:
|
||||||
- libc++-dev
|
- libc++-dev
|
||||||
|
|
||||||
- os: linux
|
- os: linux
|
||||||
|
dist: trusty
|
||||||
compiler: clang++-libc++
|
compiler: clang++-libc++
|
||||||
env: UBSAN=1 TOOLSET=clang CXXSTD=03,11,14,1z UBSAN_OPTIONS=print_stacktrace=1
|
env: UBSAN=1 TOOLSET=clang CXXSTD=03,11,14,1z UBSAN_OPTIONS=print_stacktrace=1
|
||||||
addons:
|
addons:
|
||||||
@ -278,13 +321,15 @@ matrix:
|
|||||||
compiler: clang++
|
compiler: clang++
|
||||||
env: TOOLSET=clang CXXSTD=03,11,14,1z
|
env: TOOLSET=clang CXXSTD=03,11,14,1z
|
||||||
|
|
||||||
|
- os: osx
|
||||||
|
compiler: clang++
|
||||||
|
env: UBSAN=1 TOOLSET=clang CXXSTD=03,11,14,1z UBSAN_OPTIONS=print_stacktrace=1
|
||||||
|
|
||||||
install:
|
install:
|
||||||
- BOOST_BRANCH=develop && [ "$TRAVIS_BRANCH" == "master" ] && BOOST_BRANCH=master || true
|
- BOOST_BRANCH=develop && [ "$TRAVIS_BRANCH" == "master" ] && BOOST_BRANCH=master || true
|
||||||
- cd ..
|
- cd ..
|
||||||
- git clone -b $BOOST_BRANCH https://github.com/boostorg/boost.git boost-root
|
- git clone -b $BOOST_BRANCH https://github.com/boostorg/boost.git boost-root
|
||||||
- cd boost-root
|
- cd boost-root
|
||||||
- git submodule update --init tools/build
|
|
||||||
- git submodule update --init libs/config
|
|
||||||
- git submodule update --init tools/boostdep
|
- git submodule update --init tools/boostdep
|
||||||
- cp -r $TRAVIS_BUILD_DIR/* libs/function
|
- cp -r $TRAVIS_BUILD_DIR/* libs/function
|
||||||
- python tools/boostdep/depinst/depinst.py function
|
- python tools/boostdep/depinst/depinst.py function
|
||||||
@ -294,7 +339,7 @@ install:
|
|||||||
script:
|
script:
|
||||||
- |-
|
- |-
|
||||||
echo "using $TOOLSET : : $TRAVIS_COMPILER ;" > ~/user-config.jam
|
echo "using $TOOLSET : : $TRAVIS_COMPILER ;" > ~/user-config.jam
|
||||||
- ./b2 -j3 libs/function/test toolset=$TOOLSET cxxstd=$CXXSTD ${VARIANT:+variant=$VARIANT} ${UBSAN:+cxxflags=-fsanitize=undefined cxxflags=-fno-sanitize-recover=undefined linkflags=-fsanitize=undefined debug-symbols=on} ${LINKFLAGS:+linkflags=$LINKFLAGS}
|
- ./b2 -j3 libs/function/test toolset=$TOOLSET cxxstd=$CXXSTD variant=debug,release ${UBSAN:+cxxflags=-fsanitize=undefined cxxflags=-fno-sanitize-recover=undefined linkflags=-fsanitize=undefined debug-symbols=on} ${LINKFLAGS:+linkflags=$LINKFLAGS}
|
||||||
|
|
||||||
notifications:
|
notifications:
|
||||||
email:
|
email:
|
||||||
|
28
CMakeLists.txt
Normal file
28
CMakeLists.txt
Normal file
@ -0,0 +1,28 @@
|
|||||||
|
# Copyright 2019 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
|
||||||
|
|
||||||
|
# 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(BoostFunction LANGUAGES CXX)
|
||||||
|
|
||||||
|
add_library(boost_function INTERFACE)
|
||||||
|
add_library(Boost::function ALIAS boost_function)
|
||||||
|
|
||||||
|
target_include_directories(boost_function INTERFACE include)
|
||||||
|
|
||||||
|
target_link_libraries(boost_function
|
||||||
|
INTERFACE
|
||||||
|
Boost::assert
|
||||||
|
Boost::bind
|
||||||
|
Boost::config
|
||||||
|
Boost::core
|
||||||
|
Boost::integer
|
||||||
|
Boost::preprocessor
|
||||||
|
Boost::throw_exception
|
||||||
|
Boost::type_index
|
||||||
|
Boost::type_traits
|
||||||
|
Boost::typeof
|
||||||
|
)
|
11
Jamfile
11
Jamfile
@ -1,11 +0,0 @@
|
|||||||
# Boost.Function Library Jamfile
|
|
||||||
#
|
|
||||||
# Copyright (c) 2018 James E. King III
|
|
||||||
#
|
|
||||||
# Use, modification, and distribution are subject to the
|
|
||||||
# Boost Software License, Version 1.0. (See accompanying file
|
|
||||||
# LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
|
|
||||||
|
|
||||||
# please order by name to ease maintenance
|
|
||||||
build-project example ;
|
|
||||||
build-project test ;
|
|
23
LICENSE
23
LICENSE
@ -1,23 +0,0 @@
|
|||||||
Boost Software License - Version 1.0 - August 17th, 2003
|
|
||||||
|
|
||||||
Permission is hereby granted, free of charge, to any person or organization
|
|
||||||
obtaining a copy of the software and accompanying documentation covered by
|
|
||||||
this license (the "Software") to use, reproduce, display, distribute,
|
|
||||||
execute, and transmit the Software, and to prepare derivative works of the
|
|
||||||
Software, and to permit third-parties to whom the Software is furnished to
|
|
||||||
do so, all subject to the following:
|
|
||||||
|
|
||||||
The copyright notices in the Software and this entire statement, including
|
|
||||||
the above license grant, this restriction and the following disclaimer,
|
|
||||||
must be included in all copies of the Software, in whole or in part, and
|
|
||||||
all derivative works of the Software, unless such copies or derivative
|
|
||||||
works are solely in the form of machine-executable object code generated by
|
|
||||||
a source language processor.
|
|
||||||
|
|
||||||
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
||||||
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
||||||
FITNESS FOR A PARTICULAR PURPOSE, TITLE AND NON-INFRINGEMENT. IN NO EVENT
|
|
||||||
SHALL THE COPYRIGHT HOLDERS OR ANYONE DISTRIBUTING THE SOFTWARE BE LIABLE
|
|
||||||
FOR ANY DAMAGES OR OTHER LIABILITY, WHETHER IN CONTRACT, TORT OR OTHERWISE,
|
|
||||||
ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
|
|
||||||
DEALINGS IN THE SOFTWARE.
|
|
40
README.md
40
README.md
@ -1,34 +1,18 @@
|
|||||||
Function, part of collection of the [Boost C++ Libraries](http://github.com/boostorg), contains a family of class templates that are function object wrappers.
|
# Boost.Function, a polymorphic function wrapper
|
||||||
|
|
||||||
### License
|
[Boost.Function](http://boost.org/libs/function), part of the
|
||||||
|
[Boost C++ Libraries](http://boost.org), is the original implementation of the
|
||||||
|
polymorphic function wrapper `boost::function`, which was eventually accepted
|
||||||
|
into the C++11 standard as [`std::function`](https://en.cppreference.com/w/cpp/utility/functional/function).
|
||||||
|
|
||||||
Distributed under the [Boost Software License, Version 1.0](http://www.boost.org/LICENSE_1_0.txt).
|
## Currently supported compilers
|
||||||
|
|
||||||
### Properties
|
* g++ 4.4 or later
|
||||||
|
* clang++ 3.3 or later
|
||||||
|
* Visual Studio 2005-2017
|
||||||
|
|
||||||
* C++03
|
Tested on [Travis](https://travis-ci.org/boostorg/function/) and [Appveyor](https://ci.appveyor.com/project/pdimov/function/).
|
||||||
* Header-Only
|
|
||||||
|
|
||||||
### Build Status
|
## License
|
||||||
|
|
||||||
Branch | Travis | Appveyor | Coverity Scan | codecov.io | Deps | Docs | Tests |
|
|
||||||
:-------------: | ------ | -------- | ------------- | ---------- | ---- | ---- | ----- |
|
|
||||||
[`master`](https://github.com/boostorg/function/tree/master) | [](https://travis-ci.org/boostorg/function) | [](https://ci.appveyor.com/project/jeking3/function-d036y/branch/master) | [](https://scan.coverity.com/projects/boostorg-function) | [](https://codecov.io/gh/boostorg/function/branch/master)| [](https://pdimov.github.io/boostdep-report/master/function.html) | [](http://www.boost.org/doc/libs/master/doc/html/function.html) | [](http://www.boost.org/development/tests/master/developer/function.html)
|
|
||||||
[`develop`](https://github.com/boostorg/function/tree/develop) | [](https://travis-ci.org/boostorg/function) | [](https://ci.appveyor.com/project/jeking3/function-d036y/branch/develop) | [](https://scan.coverity.com/projects/boostorg-function) | [](https://codecov.io/gh/boostorg/function/branch/develop) | [](https://pdimov.github.io/boostdep-report/develop/function.html) | [](http://www.boost.org/doc/libs/develop/doc/html/function.html) | [](http://www.boost.org/development/tests/develop/developer/function.html)
|
|
||||||
|
|
||||||
### Directories
|
|
||||||
|
|
||||||
| Name | Purpose |
|
|
||||||
| ----------- | ------------------------------ |
|
|
||||||
| `doc` | documentation |
|
|
||||||
| `example` | examples |
|
|
||||||
| `include` | headers |
|
|
||||||
| `test` | unit tests |
|
|
||||||
|
|
||||||
### More information
|
|
||||||
|
|
||||||
* [Ask questions](http://stackoverflow.com/questions/ask?tags=c%2B%2B,boost,boost-function)
|
|
||||||
* [Report bugs](https://github.com/boostorg/function/issues): Be sure to mention Boost version, platform and compiler you're using. A small compilable code sample to reproduce the problem is always good as well.
|
|
||||||
* Submit your patches as pull requests against **develop** branch. Note that by submitting patches you agree to license your modifications under the [Boost Software License, Version 1.0](http://www.boost.org/LICENSE_1_0.txt).
|
|
||||||
* Discussions about the library are held on the [Boost developers mailing list](http://www.boost.org/community/groups.html#main). Be sure to read the [discussion policy](http://www.boost.org/community/policy.html) before posting and add the `[function]` tag at the beginning of the subject line.
|
|
||||||
|
|
||||||
|
Distributed under the [Boost Software License, Version 1.0](http://boost.org/LICENSE_1_0.txt).
|
||||||
|
145
appveyor.yml
145
appveyor.yml
@ -1,126 +1,69 @@
|
|||||||
# Copyright 2016, 2017 Peter Dimov
|
# Copyright 2016-2019 Peter Dimov
|
||||||
# Copyright (C) 2017, 2018 James E. King III
|
|
||||||
# Distributed under the Boost Software License, Version 1.0.
|
# Distributed under the Boost Software License, Version 1.0.
|
||||||
# (See accompanying file LICENSE_1_0.txt or copy at http://boost.org/LICENSE_1_0.txt)
|
# (See accompanying file LICENSE_1_0.txt or copy at http://boost.org/LICENSE_1_0.txt)
|
||||||
|
|
||||||
#
|
|
||||||
# Generic Appveyor build script for boostorg repositories
|
|
||||||
# See: https://github.com/jeking3/boost-ci/
|
|
||||||
#
|
|
||||||
# Instructions for customizing this script for your library:
|
|
||||||
#
|
|
||||||
# 1. Customize the compilers and language levels you want.
|
|
||||||
# 2. If you have move than include/, src/, test/, example/, examples/,
|
|
||||||
# benchmark/ or tools/ directories, set the environment variable DEPINST.
|
|
||||||
# For example if your build uses code in "bench/" and "fog/" directories:
|
|
||||||
# - DEPINST: --include bench --include fog
|
|
||||||
# 3. Enable pull request builds in your boostorg/<library> account.
|
|
||||||
#
|
|
||||||
# That's it - the script will do everything else for you.
|
|
||||||
#
|
|
||||||
|
|
||||||
version: 1.0.{build}-{branch}
|
version: 1.0.{build}-{branch}
|
||||||
|
|
||||||
shallow_clone: true
|
shallow_clone: true
|
||||||
|
|
||||||
branches:
|
branches:
|
||||||
only:
|
only:
|
||||||
- develop
|
|
||||||
- master
|
- master
|
||||||
|
- develop
|
||||||
matrix:
|
- /feature\/.*/
|
||||||
# Adding MAYFAIL to any matrix job allows it to fail but the build stays green:
|
|
||||||
allow_failures:
|
|
||||||
- MAYFAIL: true
|
|
||||||
|
|
||||||
environment:
|
environment:
|
||||||
global:
|
|
||||||
# see: http://www.boost.org/build/doc/html/bbv2/overview/invocation.html#bbv2.overview.invocation.properties
|
|
||||||
# to use the default for a given environment, comment it out; recommend you build debug and release however:
|
|
||||||
# on Windows it is important to exercise all the possibilities, especially shared vs static, however most
|
|
||||||
# libraries that care about this exercise it in their Jamfiles...
|
|
||||||
# B2_ADDRESS_MODEL: address-model=64,32
|
|
||||||
# B2_LINK: link=shared,static
|
|
||||||
# B2_THREADING: threading=multi,single
|
|
||||||
B2_VARIANT: variant=release,debug
|
|
||||||
|
|
||||||
matrix:
|
matrix:
|
||||||
- FLAVOR: Visual Studio 2017 C++2a Strict
|
- APPVEYOR_BUILD_WORKER_IMAGE: Visual Studio 2015
|
||||||
APPVEYOR_BUILD_WORKER_IMAGE: Visual Studio 2017
|
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
|
TOOLSET: msvc-14.1
|
||||||
B2_ADDRESS_MODEL: address-model=64
|
CXXSTD: 14,17
|
||||||
CXXFLAGS: cxxflags=-permissive-
|
ADDRMD: 32,64
|
||||||
CXXSTD: latest # 2a
|
- APPVEYOR_BUILD_WORKER_IMAGE: Visual Studio 2017
|
||||||
|
TOOLSET: clang-win
|
||||||
- FLAVOR: Visual Studio 2017 C++17
|
CXXSTD: 14,17
|
||||||
APPVEYOR_BUILD_WORKER_IMAGE: Visual Studio 2017
|
ADDRMD: 64
|
||||||
TOOLSET: msvc-14.1
|
- APPVEYOR_BUILD_WORKER_IMAGE: Visual Studio 2019
|
||||||
B2_ADDRESS_MODEL: address-model=64
|
TOOLSET: msvc-14.2
|
||||||
CXXSTD: 17
|
CXXSTD: 14,17
|
||||||
|
ADDRMD: 32,64
|
||||||
- FLAVOR: Visual Studio 2017 C++14 (Default)
|
- APPVEYOR_BUILD_WORKER_IMAGE: Visual Studio 2015
|
||||||
APPVEYOR_BUILD_WORKER_IMAGE: Visual Studio 2017
|
|
||||||
TOOLSET: msvc-14.1
|
|
||||||
B2_ADDRESS_MODEL: address-model=64,32
|
|
||||||
|
|
||||||
- FLAVOR: Visual Studio 2015 C++14 (Default)
|
|
||||||
APPVEYOR_BUILD_WORKER_IMAGE: Visual Studio 2015
|
|
||||||
TOOLSET: msvc-14.0
|
|
||||||
B2_ADDRESS_MODEL: address-model=64,32
|
|
||||||
|
|
||||||
- FLAVOR: Visual Studio 2010, 2012, 2013
|
|
||||||
APPVEYOR_BUILD_WORKER_IMAGE: Visual Studio 2013
|
|
||||||
TOOLSET: msvc-10.0,msvc-11.0,msvc-12.0
|
|
||||||
|
|
||||||
- FLAVOR: cygwin (32-bit)
|
|
||||||
APPVEYOR_BUILD_WORKER_IMAGE: Visual Studio 2017
|
|
||||||
ADDPATH: C:\cygwin\bin;
|
ADDPATH: C:\cygwin\bin;
|
||||||
B2_ADDRESS_MODEL: address-model=32
|
|
||||||
CXXSTD: 03,11
|
|
||||||
# https://github.com/boostorg/test/issues/144
|
|
||||||
DEFINES: define=_POSIX_C_SOURCE=200112L
|
|
||||||
THREADING: threadapi=pthread
|
|
||||||
TOOLSET: gcc
|
TOOLSET: gcc
|
||||||
|
CXXSTD: 03,11,14,1z
|
||||||
- FLAVOR: cygwin (64-bit)
|
- APPVEYOR_BUILD_WORKER_IMAGE: Visual Studio 2015
|
||||||
APPVEYOR_BUILD_WORKER_IMAGE: Visual Studio 2017
|
|
||||||
ADDPATH: C:\cygwin64\bin;
|
ADDPATH: C:\cygwin64\bin;
|
||||||
B2_ADDRESS_MODEL: address-model=64
|
|
||||||
CXXSTD: 11,17
|
|
||||||
# https://github.com/boostorg/test/issues/144
|
|
||||||
DEFINES: define=_POSIX_C_SOURCE=200112L define=__USE_ISOC99
|
|
||||||
THREADING: threadapi=pthread
|
|
||||||
TOOLSET: gcc
|
TOOLSET: gcc
|
||||||
|
CXXSTD: 03,11,14,1z
|
||||||
- FLAVOR: mingw32
|
- APPVEYOR_BUILD_WORKER_IMAGE: Visual Studio 2015
|
||||||
APPVEYOR_BUILD_WORKER_IMAGE: Visual Studio 2017
|
ADDPATH: C:\mingw\bin;
|
||||||
ARCH: i686
|
TOOLSET: gcc
|
||||||
B2_ADDRESS_MODEL: address-model=32
|
CXXSTD: 03,11,14,1z
|
||||||
CXXSTD: 03,11
|
- APPVEYOR_BUILD_WORKER_IMAGE: Visual Studio 2015
|
||||||
SCRIPT: ci\appveyor\mingw.bat
|
ADDPATH: C:\mingw-w64\x86_64-6.3.0-posix-seh-rt_v5-rev1\mingw64\bin;
|
||||||
|
TOOLSET: gcc
|
||||||
- FLAVOR: mingw64
|
CXXSTD: 03,11,14,1z
|
||||||
APPVEYOR_BUILD_WORKER_IMAGE: Visual Studio 2017
|
|
||||||
ARCH: x86_64
|
|
||||||
B2_ADDRESS_MODEL: address-model=64
|
|
||||||
CXXSTD: 11,17
|
|
||||||
DEFINES: define=__USE_ISOC99
|
|
||||||
SCRIPT: ci\appveyor\mingw.bat
|
|
||||||
|
|
||||||
install:
|
install:
|
||||||
- set SELF=%APPVEYOR_PROJECT_NAME:-=_%
|
- set BOOST_BRANCH=develop
|
||||||
- git clone https://github.com/jeking3/boost-ci.git C:\boost-ci
|
- if "%APPVEYOR_REPO_BRANCH%" == "master" set BOOST_BRANCH=master
|
||||||
- xcopy /s /e /q /i C:\boost-ci\ci .\ci
|
- cd ..
|
||||||
- ci\appveyor\install.bat
|
- git clone -b %BOOST_BRANCH% --depth 1 https://github.com/boostorg/boost.git boost-root
|
||||||
|
- cd boost-root
|
||||||
|
- git submodule update --init tools/boostdep
|
||||||
|
- xcopy /s /e /q %APPVEYOR_BUILD_FOLDER% libs\function\
|
||||||
|
- python tools/boostdep/depinst/depinst.py function
|
||||||
|
- cmd /c bootstrap
|
||||||
|
- b2 -d0 headers
|
||||||
|
|
||||||
build: off
|
build: off
|
||||||
|
|
||||||
test_script:
|
test_script:
|
||||||
- set SELF=%APPVEYOR_PROJECT_NAME:-=_%
|
|
||||||
- PATH=%ADDPATH%%PATH%
|
- PATH=%ADDPATH%%PATH%
|
||||||
# The definition of TOOLCXX omits CXXSTD= if it was not defined above
|
- if not "%CXXSTD%" == "" set CXXSTD=cxxstd=%CXXSTD%
|
||||||
- IF NOT DEFINED CXXSTD (SET TOOLCXX=toolset=%TOOLSET%) ELSE (SET TOOLCXX=toolset=%TOOLSET% cxxstd=%CXXSTD%)
|
- if not "%ADDRMD%" == "" set ADDRMD=address-model=%ADDRMD%
|
||||||
# Echo the complete build command to the build log
|
- b2 -j3 libs/function/test toolset=%TOOLSET% %CXXSTD% %ADDRMD% variant=debug,release
|
||||||
- IF NOT DEFINED SCRIPT (ECHO b2 libs/%SELF:\=/% %TOOLCXX% %CXXFLAGS% %DEFINES% %THREADING% %B2_ADDRESS_MODEL% %B2_LINK% %B2_THREADING% %B2_VARIANT% -j3)
|
|
||||||
# Now go build...
|
|
||||||
- IF DEFINED SCRIPT (call libs\%SELF%\%SCRIPT%) ELSE (b2 libs/%SELF:\=/% %TOOLCXX% %CXXFLAGS% %DEFINES% %THREADING% %B2_ADDRESS_MODEL% %B2_LINK% %B2_THREADING% %B2_VARIANT% -j3)
|
|
||||||
|
14
example/Jamfile
Normal file
14
example/Jamfile
Normal file
@ -0,0 +1,14 @@
|
|||||||
|
# Boost.Function Library example Jamfile
|
||||||
|
#
|
||||||
|
# Copyright (c) 2008 James E. King III
|
||||||
|
#
|
||||||
|
# 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
|
||||||
|
|
||||||
|
import ../../config/checks/config : requires ;
|
||||||
|
import testing ;
|
||||||
|
|
||||||
|
run bind1st.cpp : : : [ requires cxx98_binders ] ;
|
||||||
|
run int_div.cpp ;
|
||||||
|
run sum_avg.cpp ;
|
@ -1,21 +0,0 @@
|
|||||||
# Boost.Function Library example Jamfile
|
|
||||||
#
|
|
||||||
# Copyright (c) 2008 James E. King III
|
|
||||||
#
|
|
||||||
# Distributed under the Boost Software License, Version 1.0. (See accompany-
|
|
||||||
# ing file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
|
|
||||||
|
|
||||||
import ../../config/checks/config : requires ;
|
|
||||||
import os ;
|
|
||||||
import testing ;
|
|
||||||
|
|
||||||
project
|
|
||||||
: requirements
|
|
||||||
;
|
|
||||||
|
|
||||||
test-suite "function-examples"
|
|
||||||
: [ run bind1st.cpp : : : [ requires cxx98_binders ] ]
|
|
||||||
[ run int_div.cpp ]
|
|
||||||
[ run sum_avg.cpp ]
|
|
||||||
;
|
|
||||||
|
|
@ -396,16 +396,12 @@ namespace boost {
|
|||||||
functor_manager_operation_type op)
|
functor_manager_operation_type op)
|
||||||
{
|
{
|
||||||
typedef typename get_function_tag<functor_type>::type tag_type;
|
typedef typename get_function_tag<functor_type>::type tag_type;
|
||||||
switch (op) {
|
if (op == get_functor_type_tag) {
|
||||||
case get_functor_type_tag:
|
|
||||||
out_buffer.members.type.type = &boost::typeindex::type_id<functor_type>().type_info();
|
out_buffer.members.type.type = &boost::typeindex::type_id<functor_type>().type_info();
|
||||||
out_buffer.members.type.const_qualified = false;
|
out_buffer.members.type.const_qualified = false;
|
||||||
out_buffer.members.type.volatile_qualified = false;
|
out_buffer.members.type.volatile_qualified = false;
|
||||||
return;
|
} else {
|
||||||
|
|
||||||
default:
|
|
||||||
manager(in_buffer, out_buffer, op, tag_type());
|
manager(in_buffer, out_buffer, op, tag_type());
|
||||||
return;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
@ -510,16 +506,12 @@ namespace boost {
|
|||||||
functor_manager_operation_type op)
|
functor_manager_operation_type op)
|
||||||
{
|
{
|
||||||
typedef typename get_function_tag<functor_type>::type tag_type;
|
typedef typename get_function_tag<functor_type>::type tag_type;
|
||||||
switch (op) {
|
if (op == get_functor_type_tag) {
|
||||||
case get_functor_type_tag:
|
|
||||||
out_buffer.members.type.type = &boost::typeindex::type_id<functor_type>().type_info();
|
out_buffer.members.type.type = &boost::typeindex::type_id<functor_type>().type_info();
|
||||||
out_buffer.members.type.const_qualified = false;
|
out_buffer.members.type.const_qualified = false;
|
||||||
out_buffer.members.type.volatile_qualified = false;
|
out_buffer.members.type.volatile_qualified = false;
|
||||||
return;
|
} else {
|
||||||
|
|
||||||
default:
|
|
||||||
manager(in_buffer, out_buffer, op, tag_type());
|
manager(in_buffer, out_buffer, op, tag_type());
|
||||||
return;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
@ -898,11 +898,20 @@ namespace boost {
|
|||||||
{
|
{
|
||||||
if (!f.empty()) {
|
if (!f.empty()) {
|
||||||
this->vtable = f.vtable;
|
this->vtable = f.vtable;
|
||||||
if (this->has_trivial_copy_and_destroy())
|
if (this->has_trivial_copy_and_destroy()) {
|
||||||
// Don't operate on storage directly since union type doesn't relax
|
// Don't operate on storage directly since union type doesn't relax
|
||||||
// strict aliasing rules, despite of having member char type.
|
// strict aliasing rules, despite of having member char type.
|
||||||
|
# if defined(BOOST_GCC) && (BOOST_GCC >= 40700)
|
||||||
|
# pragma GCC diagnostic push
|
||||||
|
// This warning is technically correct, but we don't want to pay the price for initializing
|
||||||
|
// just to silence a warning: https://github.com/boostorg/function/issues/27
|
||||||
|
# pragma GCC diagnostic ignored "-Wmaybe-uninitialized"
|
||||||
|
# endif
|
||||||
std::memcpy(this->functor.data, f.functor.data, sizeof(boost::detail::function::function_buffer));
|
std::memcpy(this->functor.data, f.functor.data, sizeof(boost::detail::function::function_buffer));
|
||||||
else
|
# if defined(BOOST_GCC) && (BOOST_GCC >= 40700)
|
||||||
|
# pragma GCC diagnostic pop
|
||||||
|
# endif
|
||||||
|
} else
|
||||||
get_vtable()->base.manager(f.functor, this->functor,
|
get_vtable()->base.manager(f.functor, this->functor,
|
||||||
boost::detail::function::clone_functor_tag);
|
boost::detail::function::clone_functor_tag);
|
||||||
}
|
}
|
||||||
@ -987,11 +996,20 @@ namespace boost {
|
|||||||
BOOST_TRY {
|
BOOST_TRY {
|
||||||
if (!f.empty()) {
|
if (!f.empty()) {
|
||||||
this->vtable = f.vtable;
|
this->vtable = f.vtable;
|
||||||
if (this->has_trivial_copy_and_destroy())
|
if (this->has_trivial_copy_and_destroy()) {
|
||||||
// Don't operate on storage directly since union type doesn't relax
|
// Don't operate on storage directly since union type doesn't relax
|
||||||
// strict aliasing rules, despite of having member char type.
|
// strict aliasing rules, despite of having member char type.
|
||||||
|
# if defined(BOOST_GCC) && (BOOST_GCC >= 40700)
|
||||||
|
# pragma GCC diagnostic push
|
||||||
|
// This warning is technically correct, but we don't want to pay the price for initializing
|
||||||
|
// just to silence a warning: https://github.com/boostorg/function/issues/27
|
||||||
|
# pragma GCC diagnostic ignored "-Wmaybe-uninitialized"
|
||||||
|
# endif
|
||||||
std::memcpy(this->functor.data, f.functor.data, sizeof(this->functor.data));
|
std::memcpy(this->functor.data, f.functor.data, sizeof(this->functor.data));
|
||||||
else
|
# if defined(BOOST_GCC) && (BOOST_GCC >= 40700)
|
||||||
|
# pragma GCC diagnostic pop
|
||||||
|
# endif
|
||||||
|
} else
|
||||||
get_vtable()->base.manager(f.functor, this->functor,
|
get_vtable()->base.manager(f.functor, this->functor,
|
||||||
boost::detail::function::move_functor_tag);
|
boost::detail::function::move_functor_tag);
|
||||||
f.vtable = 0;
|
f.vtable = 0;
|
||||||
|
@ -13,6 +13,6 @@
|
|||||||
"Programming"
|
"Programming"
|
||||||
],
|
],
|
||||||
"maintainers": [
|
"maintainers": [
|
||||||
"Douglas Gregor <dgregor -at- cs.indiana.edu>"
|
"Peter Dimov <pdimov -at- pdimov.com>"
|
||||||
]
|
]
|
||||||
}
|
}
|
||||||
|
@ -57,3 +57,19 @@ local check14 = [ check-target-builds mixed_cxxstd/<cxxstd>14 : : <build>no ] ;
|
|||||||
|
|
||||||
run test_mixed_cxxstd.cpp mixed_cxxstd/<cxxstd>14 : : : <link>shared $(check14) : mixed_cxxstd_shared_14 ;
|
run test_mixed_cxxstd.cpp mixed_cxxstd/<cxxstd>14 : : : <link>shared $(check14) : mixed_cxxstd_shared_14 ;
|
||||||
run test_mixed_cxxstd.cpp mixed_cxxstd/<cxxstd>14 : : : <link>static $(check14) : mixed_cxxstd_static_14 ;
|
run test_mixed_cxxstd.cpp mixed_cxxstd/<cxxstd>14 : : : <link>static $(check14) : mixed_cxxstd_static_14 ;
|
||||||
|
|
||||||
|
lib return_function : return_function.cpp : <link>shared:<define>RETURN_FUNCTION_DYN_LINK=1 ;
|
||||||
|
|
||||||
|
run test_return_function.cpp return_function : : : <link>shared : return_function_shared ;
|
||||||
|
run test_return_function.cpp return_function : : : <link>static : return_function_static ;
|
||||||
|
|
||||||
|
run test_return_function.cpp return_function/<cxxstd>98 : : : <link>shared : return_function_shared_98 ;
|
||||||
|
run test_return_function.cpp return_function/<cxxstd>98 : : : <link>static : return_function_static_98 ;
|
||||||
|
|
||||||
|
run test_return_function.cpp return_function/<cxxstd>0x : : : <link>shared : return_function_shared_0x ;
|
||||||
|
run test_return_function.cpp return_function/<cxxstd>0x : : : <link>static : return_function_static_0x ;
|
||||||
|
|
||||||
|
run test_return_function.cpp return_function/<cxxstd>14 : : : <link>shared $(check14) : return_function_shared_14 ;
|
||||||
|
run test_return_function.cpp return_function/<cxxstd>14 : : : <link>static $(check14) : return_function_static_14 ;
|
||||||
|
|
||||||
|
run quick.cpp ;
|
||||||
|
49
test/cmake_subdir_test/CMakeLists.txt
Normal file
49
test/cmake_subdir_test/CMakeLists.txt
Normal file
@ -0,0 +1,49 @@
|
|||||||
|
# Copyright 2018, 2019 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
|
||||||
|
|
||||||
|
cmake_minimum_required(VERSION 3.5)
|
||||||
|
|
||||||
|
project(cmake_subdir_test LANGUAGES CXX)
|
||||||
|
|
||||||
|
add_subdirectory(../.. boostorg/function)
|
||||||
|
|
||||||
|
# boost_add_subdir
|
||||||
|
|
||||||
|
function(boost_add_subdir name)
|
||||||
|
|
||||||
|
add_subdirectory(../../../${name} boostorg/${name})
|
||||||
|
|
||||||
|
endfunction()
|
||||||
|
|
||||||
|
# primary dependencies
|
||||||
|
|
||||||
|
boost_add_subdir(assert)
|
||||||
|
boost_add_subdir(bind)
|
||||||
|
boost_add_subdir(config)
|
||||||
|
boost_add_subdir(core)
|
||||||
|
boost_add_subdir(integer)
|
||||||
|
boost_add_subdir(preprocessor)
|
||||||
|
boost_add_subdir(throw_exception)
|
||||||
|
boost_add_subdir(type_index)
|
||||||
|
boost_add_subdir(type_traits)
|
||||||
|
boost_add_subdir(typeof)
|
||||||
|
|
||||||
|
# secondary dependencies
|
||||||
|
|
||||||
|
boost_add_subdir(static_assert)
|
||||||
|
boost_add_subdir(container_hash)
|
||||||
|
boost_add_subdir(smart_ptr)
|
||||||
|
boost_add_subdir(detail)
|
||||||
|
boost_add_subdir(move)
|
||||||
|
boost_add_subdir(predef)
|
||||||
|
|
||||||
|
# --target check
|
||||||
|
|
||||||
|
add_executable(quick ../quick.cpp)
|
||||||
|
target_link_libraries(quick Boost::function Boost::core)
|
||||||
|
|
||||||
|
enable_testing()
|
||||||
|
add_test(quick quick)
|
||||||
|
|
||||||
|
add_custom_target(check COMMAND ${CMAKE_CTEST_COMMAND} --output-on-failure -C $<CONFIG>)
|
@ -5,10 +5,12 @@
|
|||||||
// 1.0. (See accompanying file LICENSE_1_0.txt or copy at
|
// 1.0. (See accompanying file LICENSE_1_0.txt or copy at
|
||||||
// http://www.boost.org/LICENSE_1_0.txt)
|
// http://www.boost.org/LICENSE_1_0.txt)
|
||||||
|
|
||||||
#include <boost/test/minimal.hpp>
|
|
||||||
#include <boost/function.hpp>
|
#include <boost/function.hpp>
|
||||||
|
#include <boost/core/lightweight_test.hpp>
|
||||||
#include <boost/ref.hpp>
|
#include <boost/ref.hpp>
|
||||||
|
|
||||||
|
#define BOOST_CHECK BOOST_TEST
|
||||||
|
|
||||||
static int forty_two() { return 42; }
|
static int forty_two() { return 42; }
|
||||||
|
|
||||||
struct Seventeen
|
struct Seventeen
|
||||||
@ -225,11 +227,11 @@ static void ref_equal_test()
|
|||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
int test_main(int, char*[])
|
int main()
|
||||||
{
|
{
|
||||||
target_test();
|
target_test();
|
||||||
equal_test();
|
equal_test();
|
||||||
ref_equal_test();
|
ref_equal_test();
|
||||||
|
|
||||||
return 0;
|
return boost::report_errors();
|
||||||
}
|
}
|
||||||
|
@ -7,12 +7,14 @@
|
|||||||
|
|
||||||
// For more information, see http://www.boost.org
|
// For more information, see http://www.boost.org
|
||||||
|
|
||||||
#include <boost/test/minimal.hpp>
|
|
||||||
#include <boost/function.hpp>
|
#include <boost/function.hpp>
|
||||||
|
#include <boost/core/lightweight_test.hpp>
|
||||||
#include <functional>
|
#include <functional>
|
||||||
#include <cassert>
|
#include <cassert>
|
||||||
#include <string>
|
#include <string>
|
||||||
|
|
||||||
|
#define BOOST_CHECK BOOST_TEST
|
||||||
|
|
||||||
using namespace boost;
|
using namespace boost;
|
||||||
using std::string;
|
using std::string;
|
||||||
using std::negate;
|
using std::negate;
|
||||||
@ -684,7 +686,7 @@ void test_construct_destroy_count()
|
|||||||
BOOST_CHECK(construction_count == destruction_count);
|
BOOST_CHECK(construction_count == destruction_count);
|
||||||
}
|
}
|
||||||
|
|
||||||
int test_main(int, char* [])
|
int main()
|
||||||
{
|
{
|
||||||
test_zero_args();
|
test_zero_args();
|
||||||
test_one_arg();
|
test_one_arg();
|
||||||
@ -693,5 +695,5 @@ int test_main(int, char* [])
|
|||||||
test_member_functions();
|
test_member_functions();
|
||||||
test_ref();
|
test_ref();
|
||||||
test_construct_destroy_count();
|
test_construct_destroy_count();
|
||||||
return 0;
|
return boost::report_errors();
|
||||||
}
|
}
|
||||||
|
@ -7,12 +7,14 @@
|
|||||||
|
|
||||||
// For more information, see http://www.boost.org
|
// For more information, see http://www.boost.org
|
||||||
|
|
||||||
#include <boost/test/minimal.hpp>
|
|
||||||
#include <boost/function.hpp>
|
#include <boost/function.hpp>
|
||||||
|
#include <boost/core/lightweight_test.hpp>
|
||||||
#include <functional>
|
#include <functional>
|
||||||
#include <string>
|
#include <string>
|
||||||
#include <utility>
|
#include <utility>
|
||||||
|
|
||||||
|
#define BOOST_CHECK BOOST_TEST
|
||||||
|
|
||||||
using boost::function;
|
using boost::function;
|
||||||
using std::string;
|
using std::string;
|
||||||
|
|
||||||
@ -792,7 +794,7 @@ static void test_move_semantics()
|
|||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
int test_main(int, char* [])
|
int main()
|
||||||
{
|
{
|
||||||
test_zero_args();
|
test_zero_args();
|
||||||
test_one_arg();
|
test_one_arg();
|
||||||
@ -807,5 +809,5 @@ int test_main(int, char* [])
|
|||||||
test_move_semantics<function<void()> >();
|
test_move_semantics<function<void()> >();
|
||||||
test_move_semantics<boost::function0<void> >();
|
test_move_semantics<boost::function0<void> >();
|
||||||
|
|
||||||
return 0;
|
return boost::report_errors();
|
||||||
}
|
}
|
||||||
|
@ -7,22 +7,12 @@
|
|||||||
|
|
||||||
// For more information, see http://www.boost.org
|
// For more information, see http://www.boost.org
|
||||||
|
|
||||||
#include <boost/test/minimal.hpp>
|
|
||||||
#include <boost/function.hpp>
|
#include <boost/function.hpp>
|
||||||
|
|
||||||
using namespace std;
|
void test()
|
||||||
using namespace boost;
|
|
||||||
|
|
||||||
int
|
|
||||||
test_main(int, char*[])
|
|
||||||
{
|
{
|
||||||
function0<int> f1;
|
boost::function0<int> f1;
|
||||||
function0<int> f2;
|
boost::function0<int> f2;
|
||||||
|
|
||||||
if (f1 == f2) {
|
if( f1 == f2 ) {}
|
||||||
}
|
|
||||||
|
|
||||||
BOOST_ERROR("This should not have compiled.");
|
|
||||||
|
|
||||||
return 0;
|
|
||||||
}
|
}
|
||||||
|
@ -7,21 +7,12 @@
|
|||||||
|
|
||||||
// For more information, see http://www.boost.org
|
// For more information, see http://www.boost.org
|
||||||
|
|
||||||
#include <boost/test/minimal.hpp>
|
|
||||||
#include <boost/function.hpp>
|
#include <boost/function.hpp>
|
||||||
|
|
||||||
using namespace std;
|
|
||||||
using namespace boost;
|
|
||||||
|
|
||||||
static int bad_fn(float f) { return static_cast<int>(f); }
|
static int bad_fn(float f) { return static_cast<int>(f); }
|
||||||
|
|
||||||
int
|
void test()
|
||||||
test_main(int, char*[])
|
|
||||||
{
|
{
|
||||||
function0<int> f1;
|
boost::function0<int> f1;
|
||||||
f1 = bad_fn;
|
f1 = bad_fn;
|
||||||
|
|
||||||
BOOST_ERROR("This should not have compiled.");
|
|
||||||
|
|
||||||
return 0;
|
|
||||||
}
|
}
|
||||||
|
@ -7,8 +7,10 @@
|
|||||||
|
|
||||||
// For more information, see http://www.boost.org
|
// For more information, see http://www.boost.org
|
||||||
|
|
||||||
#include <boost/test/minimal.hpp>
|
|
||||||
#include <boost/function.hpp>
|
#include <boost/function.hpp>
|
||||||
|
#include <boost/core/lightweight_test.hpp>
|
||||||
|
|
||||||
|
#define BOOST_CHECK BOOST_TEST
|
||||||
|
|
||||||
struct tried_to_copy { };
|
struct tried_to_copy { };
|
||||||
|
|
||||||
@ -40,7 +42,7 @@ struct MaybeThrowOnCopy {
|
|||||||
|
|
||||||
bool MaybeThrowOnCopy::throwOnCopy = false;
|
bool MaybeThrowOnCopy::throwOnCopy = false;
|
||||||
|
|
||||||
int test_main(int, char* [])
|
int main()
|
||||||
{
|
{
|
||||||
boost::function0<int> f;
|
boost::function0<int> f;
|
||||||
boost::function0<int> g;
|
boost::function0<int> g;
|
||||||
@ -56,5 +58,5 @@ int test_main(int, char* [])
|
|||||||
BOOST_CHECK(f() == 2);
|
BOOST_CHECK(f() == 2);
|
||||||
BOOST_CHECK(g() == 1);
|
BOOST_CHECK(g() == 1);
|
||||||
|
|
||||||
return 0;
|
return boost::report_errors();
|
||||||
}
|
}
|
||||||
|
21
test/quick.cpp
Normal file
21
test/quick.cpp
Normal file
@ -0,0 +1,21 @@
|
|||||||
|
// Copyright 2019 Peter Dimov
|
||||||
|
|
||||||
|
// 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/function.hpp>
|
||||||
|
#include <boost/core/lightweight_test.hpp>
|
||||||
|
|
||||||
|
static int f( int x )
|
||||||
|
{
|
||||||
|
return x + 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
int main()
|
||||||
|
{
|
||||||
|
boost::function<int(int)> fn( f );
|
||||||
|
|
||||||
|
BOOST_TEST_EQ( fn( 5 ), 6 );
|
||||||
|
|
||||||
|
return boost::report_errors();
|
||||||
|
}
|
27
test/return_function.cpp
Normal file
27
test/return_function.cpp
Normal file
@ -0,0 +1,27 @@
|
|||||||
|
|
||||||
|
// Copyright 2018 Peter Dimov.
|
||||||
|
// Distributed under the Boost Software License, Version 1.0.
|
||||||
|
|
||||||
|
#include <boost/function.hpp>
|
||||||
|
#include <boost/config.hpp>
|
||||||
|
|
||||||
|
#if defined(RETURN_FUNCTION_DYN_LINK)
|
||||||
|
# define EXPORT BOOST_SYMBOL_EXPORT
|
||||||
|
#else
|
||||||
|
# define EXPORT
|
||||||
|
#endif
|
||||||
|
|
||||||
|
int f( int x, int y )
|
||||||
|
{
|
||||||
|
return x + y;
|
||||||
|
}
|
||||||
|
|
||||||
|
EXPORT boost::function<int(int, int)> get_fn_1()
|
||||||
|
{
|
||||||
|
return f;
|
||||||
|
}
|
||||||
|
|
||||||
|
EXPORT boost::function2<int, int, int> get_fn_2()
|
||||||
|
{
|
||||||
|
return f;
|
||||||
|
}
|
@ -6,12 +6,13 @@
|
|||||||
|
|
||||||
// For more information, see http://www.boost.org
|
// For more information, see http://www.boost.org
|
||||||
|
|
||||||
|
#include <boost/function.hpp>
|
||||||
|
#include <boost/move/move.hpp>
|
||||||
|
#include <boost/core/lightweight_test.hpp>
|
||||||
#include <iostream>
|
#include <iostream>
|
||||||
#include <cstdlib>
|
#include <cstdlib>
|
||||||
|
|
||||||
#include <boost/test/minimal.hpp>
|
#define BOOST_CHECK BOOST_TEST
|
||||||
#include <boost/function.hpp>
|
|
||||||
#include <boost/move/move.hpp>
|
|
||||||
|
|
||||||
class only_movable {
|
class only_movable {
|
||||||
private:
|
private:
|
||||||
@ -63,7 +64,7 @@ int three(std::string&&) { return 1; }
|
|||||||
std::string&& four(std::string&& s) { return boost::move(s); }
|
std::string&& four(std::string&& s) { return boost::move(s); }
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
int test_main(int, char*[])
|
int main()
|
||||||
{
|
{
|
||||||
using boost::function;
|
using boost::function;
|
||||||
|
|
||||||
@ -102,5 +103,5 @@ int test_main(int, char*[])
|
|||||||
BOOST_CHECK(f4(std::string("world")) == "world");
|
BOOST_CHECK(f4(std::string("world")) == "world");
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
return 0;
|
return boost::report_errors();
|
||||||
}
|
}
|
||||||
|
21
test/test_return_function.cpp
Normal file
21
test/test_return_function.cpp
Normal file
@ -0,0 +1,21 @@
|
|||||||
|
|
||||||
|
// Copyright 2018 Peter Dimov.
|
||||||
|
// Distributed under the Boost Software License, Version 1.0.
|
||||||
|
|
||||||
|
#include <boost/function.hpp>
|
||||||
|
#include <boost/core/lightweight_test.hpp>
|
||||||
|
|
||||||
|
//
|
||||||
|
|
||||||
|
boost::function<int(int, int)> get_fn_1();
|
||||||
|
boost::function2<int, int, int> get_fn_2();
|
||||||
|
|
||||||
|
//
|
||||||
|
|
||||||
|
int main()
|
||||||
|
{
|
||||||
|
BOOST_TEST_EQ( get_fn_1()( 1, 2 ), 3 );
|
||||||
|
BOOST_TEST_EQ( get_fn_2()( 1, 2 ), 3 );
|
||||||
|
|
||||||
|
return boost::report_errors();
|
||||||
|
}
|
Reference in New Issue
Block a user