1
0
forked from boostorg/mp11

Merge branch 'develop'

This commit is contained in:
Peter Dimov
2017-05-29 15:34:42 +03:00
7 changed files with 145 additions and 11 deletions

View File

@@ -28,6 +28,7 @@ matrix:
include: include:
- os: linux - os: linux
compiler: g++-4.7
env: TOOLSET=gcc COMPILER=g++-4.7 CXXSTD=c++11 env: TOOLSET=gcc COMPILER=g++-4.7 CXXSTD=c++11
addons: addons:
apt: apt:
@@ -37,6 +38,7 @@ matrix:
- ubuntu-toolchain-r-test - ubuntu-toolchain-r-test
- os: linux - os: linux
compiler: g++-4.8
env: TOOLSET=gcc COMPILER=g++-4.8 CXXSTD=c++11 env: TOOLSET=gcc COMPILER=g++-4.8 CXXSTD=c++11
addons: addons:
apt: apt:
@@ -46,6 +48,7 @@ matrix:
- ubuntu-toolchain-r-test - ubuntu-toolchain-r-test
- os: linux - os: linux
compiler: g++-4.9
env: TOOLSET=gcc COMPILER=g++-4.9 CXXSTD=c++11 env: TOOLSET=gcc COMPILER=g++-4.9 CXXSTD=c++11
addons: addons:
apt: apt:
@@ -55,6 +58,7 @@ matrix:
- ubuntu-toolchain-r-test - ubuntu-toolchain-r-test
- os: linux - os: linux
compiler: g++-5
env: TOOLSET=gcc COMPILER=g++-5 CXXSTD=c++11 env: TOOLSET=gcc COMPILER=g++-5 CXXSTD=c++11
addons: addons:
apt: apt:
@@ -64,6 +68,7 @@ matrix:
- ubuntu-toolchain-r-test - ubuntu-toolchain-r-test
- os: linux - os: linux
compiler: g++-5
env: TOOLSET=gcc COMPILER=g++-5 CXXSTD=c++14 env: TOOLSET=gcc COMPILER=g++-5 CXXSTD=c++14
addons: addons:
apt: apt:
@@ -73,6 +78,17 @@ matrix:
- ubuntu-toolchain-r-test - ubuntu-toolchain-r-test
- os: linux - os: linux
compiler: g++-5
env: TOOLSET=gcc COMPILER=g++-5 CXXSTD=c++1z
addons:
apt:
packages:
- g++-5
sources:
- ubuntu-toolchain-r-test
- os: linux
compiler: g++-6
env: TOOLSET=gcc COMPILER=g++-6 CXXSTD=c++11 env: TOOLSET=gcc COMPILER=g++-6 CXXSTD=c++11
addons: addons:
apt: apt:
@@ -82,6 +98,7 @@ matrix:
- ubuntu-toolchain-r-test - ubuntu-toolchain-r-test
- os: linux - os: linux
compiler: g++-6
env: TOOLSET=gcc COMPILER=g++-6 CXXSTD=c++14 env: TOOLSET=gcc COMPILER=g++-6 CXXSTD=c++14
addons: addons:
apt: apt:
@@ -91,6 +108,7 @@ matrix:
- ubuntu-toolchain-r-test - ubuntu-toolchain-r-test
- os: linux - os: linux
compiler: g++-6
env: TOOLSET=gcc COMPILER=g++-6 CXXSTD=c++1z env: TOOLSET=gcc COMPILER=g++-6 CXXSTD=c++1z
addons: addons:
apt: apt:
@@ -100,6 +118,40 @@ matrix:
- ubuntu-toolchain-r-test - ubuntu-toolchain-r-test
- os: linux - os: linux
dist: trusty
compiler: g++-7
env: TOOLSET=gcc COMPILER=g++-7 CXXSTD=c++11
addons:
apt:
packages:
- g++-7
sources:
- ubuntu-toolchain-r-test
- os: linux
dist: trusty
compiler: g++-7
env: TOOLSET=gcc COMPILER=g++-7 CXXSTD=c++14
addons:
apt:
packages:
- g++-7
sources:
- ubuntu-toolchain-r-test
- os: linux
dist: trusty
compiler: g++-7
env: TOOLSET=gcc COMPILER=g++-7 CXXSTD=c++1z
addons:
apt:
packages:
- g++-7
sources:
- ubuntu-toolchain-r-test
- os: linux
compiler: clang++-3.5
env: TOOLSET=clang COMPILER=clang++-3.5 CXXSTD=c++11 env: TOOLSET=clang COMPILER=clang++-3.5 CXXSTD=c++11
addons: addons:
apt: apt:
@@ -110,6 +162,7 @@ matrix:
- llvm-toolchain-precise-3.5 - llvm-toolchain-precise-3.5
- os: linux - os: linux
compiler: clang++-3.6
env: TOOLSET=clang COMPILER=clang++-3.6 CXXSTD=c++11 env: TOOLSET=clang COMPILER=clang++-3.6 CXXSTD=c++11
addons: addons:
apt: apt:
@@ -120,6 +173,7 @@ matrix:
- llvm-toolchain-precise-3.6 - llvm-toolchain-precise-3.6
- os: linux - os: linux
compiler: clang++-3.7
env: TOOLSET=clang COMPILER=clang++-3.7 CXXSTD=c++11 env: TOOLSET=clang COMPILER=clang++-3.7 CXXSTD=c++11
addons: addons:
apt: apt:
@@ -130,6 +184,7 @@ matrix:
- llvm-toolchain-precise-3.7 - llvm-toolchain-precise-3.7
- os: linux - os: linux
compiler: clang++-3.8
env: TOOLSET=clang COMPILER=clang++-3.8 CXXSTD=c++11 env: TOOLSET=clang COMPILER=clang++-3.8 CXXSTD=c++11
addons: addons:
apt: apt:
@@ -140,6 +195,7 @@ matrix:
- llvm-toolchain-precise-3.8 - llvm-toolchain-precise-3.8
- os: linux - os: linux
compiler: clang++-3.8
env: TOOLSET=clang COMPILER=clang++-3.8 CXXSTD=c++14 env: TOOLSET=clang COMPILER=clang++-3.8 CXXSTD=c++14
addons: addons:
apt: apt:
@@ -150,6 +206,7 @@ matrix:
- llvm-toolchain-precise-3.8 - llvm-toolchain-precise-3.8
- os: linux - os: linux
compiler: clang++-3.8
env: TOOLSET=clang COMPILER=clang++-3.8 CXXSTD=c++1z env: TOOLSET=clang COMPILER=clang++-3.8 CXXSTD=c++1z
addons: addons:
apt: apt:
@@ -160,6 +217,7 @@ matrix:
- llvm-toolchain-precise-3.8 - llvm-toolchain-precise-3.8
- os: linux - os: linux
compiler: clang++-3.9
env: TOOLSET=clang COMPILER=clang++-3.9 CXXSTD=c++11 env: TOOLSET=clang COMPILER=clang++-3.9 CXXSTD=c++11
addons: addons:
apt: apt:
@@ -170,6 +228,7 @@ matrix:
- llvm-toolchain-precise-3.9 - llvm-toolchain-precise-3.9
- os: linux - os: linux
compiler: clang++-3.9
env: TOOLSET=clang COMPILER=clang++-3.9 CXXSTD=c++14 env: TOOLSET=clang COMPILER=clang++-3.9 CXXSTD=c++14
addons: addons:
apt: apt:
@@ -180,6 +239,7 @@ matrix:
- llvm-toolchain-precise-3.9 - llvm-toolchain-precise-3.9
- os: linux - os: linux
compiler: clang++-3.9
env: TOOLSET=clang COMPILER=clang++-3.9 CXXSTD=c++1z env: TOOLSET=clang COMPILER=clang++-3.9 CXXSTD=c++1z
addons: addons:
apt: apt:
@@ -189,13 +249,49 @@ matrix:
- ubuntu-toolchain-r-test - ubuntu-toolchain-r-test
- llvm-toolchain-precise-3.9 - llvm-toolchain-precise-3.9
- os: linux
compiler: clang++-4.0
env: TOOLSET=clang COMPILER=clang++-4.0 CXXSTD=c++11
addons:
apt:
packages:
- clang-4.0
sources:
- ubuntu-toolchain-r-test
- llvm-toolchain-trusty-4.0
- os: linux
compiler: clang++-4.0
env: TOOLSET=clang COMPILER=clang++-4.0 CXXSTD=c++14
addons:
apt:
packages:
- clang-4.0
sources:
- ubuntu-toolchain-r-test
- llvm-toolchain-trusty-4.0
- os: linux
compiler: clang++-4.0
env: TOOLSET=clang COMPILER=clang++-4.0 CXXSTD=c++1z
addons:
apt:
packages:
- clang-4.0
sources:
- ubuntu-toolchain-r-test
- llvm-toolchain-trusty-4.0
- os: osx - os: osx
compiler: clang++
env: TOOLSET=clang COMPILER=clang++ CXXSTD=c++11 env: TOOLSET=clang COMPILER=clang++ CXXSTD=c++11
- os: osx - os: osx
compiler: clang++
env: TOOLSET=clang COMPILER=clang++ CXXSTD=c++14 env: TOOLSET=clang COMPILER=clang++ CXXSTD=c++14
- os: osx - os: osx
compiler: clang++
env: TOOLSET=clang COMPILER=clang++ CXXSTD=c++1z env: TOOLSET=clang COMPILER=clang++ CXXSTD=c++1z
install: install:

View File

@@ -2029,7 +2029,7 @@
</pre> </pre>
<p> <p>
<code class="computeroutput"><span class="identifier">mp_for_each</span><span class="special">&lt;</span><span class="identifier">L</span><span class="special">&gt;(</span><span class="identifier">f</span><span class="special">)</span></code> calls <code class="computeroutput"><span class="identifier">mp_for_each</span><span class="special">&lt;</span><span class="identifier">L</span><span class="special">&gt;(</span><span class="identifier">f</span><span class="special">)</span></code> calls
<code class="computeroutput"><span class="identifier">f</span></code> with <code class="computeroutput"><span class="identifier">mp_identity</span><span class="special">&lt;</span><span class="identifier">T</span><span class="special">&gt;()</span></code> for each element <code class="computeroutput"><span class="identifier">T</span></code> <code class="computeroutput"><span class="identifier">f</span></code> with <code class="computeroutput"><span class="identifier">T</span><span class="special">()</span></code> for each element <code class="computeroutput"><span class="identifier">T</span></code>
of the list <code class="computeroutput"><span class="identifier">L</span></code>, in order. of the list <code class="computeroutput"><span class="identifier">L</span></code>, in order.
</p> </p>
<p> <p>
@@ -2504,7 +2504,7 @@
</div> </div>
</div> </div>
<table xmlns:rev="http://www.cs.rpi.edu/~gregod/boost/tools/doc/revision" width="100%"><tr> <table xmlns:rev="http://www.cs.rpi.edu/~gregod/boost/tools/doc/revision" width="100%"><tr>
<td align="left"><p><small>Last revised: May 25, 2017 at 18:31:25 GMT</small></p></td> <td align="left"><p><small>Last revised: May 28, 2017 at 23:51:44 GMT</small></p></td>
<td align="right"><div class="copyright-footer"></div></td> <td align="right"><div class="copyright-footer"></div></td>
</tr></table> </tr></table>
<hr> <hr>

View File

@@ -284,7 +284,7 @@ is `mp_size<L>`.
[section `mp_for_each<L>(f)`] [section `mp_for_each<L>(f)`]
template<class L, class F> constexpr F mp_for_each(F&& f); template<class L, class F> constexpr F mp_for_each(F&& f);
`mp_for_each<L>(f)` calls `f` with `mp_identity<T>()` for each element `T` of the list `L`, in order. `mp_for_each<L>(f)` calls `f` with `T()` for each element `T` of the list `L`, in order.
Returns `std::forward<F>(f)`. Returns `std::forward<F>(f)`.
[endsect] [endsect]

View File

@@ -325,8 +325,8 @@ template<class L, std::size_t I> struct mp_at_c_impl
} // namespace detail } // namespace detail
template<class L, std::size_t I> using mp_at_c = typename detail::mp_at_c_impl<L, I>::type; template<class L, std::size_t I> using mp_at_c = typename mp_if_c<(I < mp_size<L>::value), detail::mp_at_c_impl<L, I>, void>::type;
template<class L, class I> using mp_at = typename detail::mp_at_c_impl<L, std::size_t{ I::value }>::type; template<class L, class I> using mp_at = mp_at_c<L, std::size_t{ I::value }>;
// mp_take(_c)<L, N> // mp_take(_c)<L, N>
namespace detail namespace detail
@@ -882,7 +882,7 @@ namespace detail
template<class... T, class F> BOOST_CONSTEXPR F mp_for_each_impl( mp_list<T...>, F && f ) template<class... T, class F> BOOST_CONSTEXPR F mp_for_each_impl( mp_list<T...>, F && f )
{ {
using A = int[sizeof...(T)]; using A = int[sizeof...(T)];
return (void)A{ ((void)f(mp_identity<T>()), 0)... }, std::forward<F>(f); return (void)A{ ((void)f(T()), 0)... }, std::forward<F>(f);
} }
#if BOOST_WORKAROUND( BOOST_MSVC, <= 1800 ) #if BOOST_WORKAROUND( BOOST_MSVC, <= 1800 )

View File

@@ -48,6 +48,7 @@ run mp_product.cpp : : : $(REQ) ;
run mp_drop.cpp : : : $(REQ) ; run mp_drop.cpp : : : $(REQ) ;
run mp_iota.cpp : : : $(REQ) ; run mp_iota.cpp : : : $(REQ) ;
run mp_at.cpp : : : $(REQ) ; run mp_at.cpp : : : $(REQ) ;
run mp_at_sf.cpp : : : $(REQ) ;
run mp_take.cpp : : : $(REQ) ; run mp_take.cpp : : : $(REQ) ;
run mp_replace.cpp : : : $(REQ) ; run mp_replace.cpp : : : $(REQ) ;
run mp_replace_if.cpp : : : $(REQ) ; run mp_replace_if.cpp : : : $(REQ) ;

39
test/mp_at_sf.cpp Normal file
View File

@@ -0,0 +1,39 @@
// Copyright 2015, 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
#include <boost/mp11/utility.hpp>
#include <boost/mp11/algorithm.hpp>
#include <boost/core/lightweight_test_trait.hpp>
#include <type_traits>
using boost::mp11::mp_valid;
using boost::mp11::mp_at;
using boost::mp11::mp_size_t;
using boost::mp11::mp_list;
int main()
{
BOOST_TEST_TRAIT_FALSE((mp_valid<mp_at>));
BOOST_TEST_TRAIT_FALSE((mp_valid<mp_at, void>));
BOOST_TEST_TRAIT_FALSE((mp_valid<mp_at, void, void>));
BOOST_TEST_TRAIT_FALSE((mp_valid<mp_at, void, void, void>));
BOOST_TEST_TRAIT_FALSE((mp_valid<mp_at, void, mp_size_t<0>>));
BOOST_TEST_TRAIT_FALSE((mp_valid<mp_at, mp_list<>, mp_size_t<0>>));
BOOST_TEST_TRAIT_TRUE((mp_valid<mp_at, mp_list<void>, mp_size_t<0>>));
BOOST_TEST_TRAIT_FALSE((mp_valid<mp_at, mp_list<void>, mp_size_t<1>>));
BOOST_TEST_TRAIT_TRUE((mp_valid<mp_at, mp_list<void, void>, mp_size_t<0>>));
BOOST_TEST_TRAIT_TRUE((mp_valid<mp_at, mp_list<void, void>, mp_size_t<1>>));
BOOST_TEST_TRAIT_FALSE((mp_valid<mp_at, mp_list<void, void>, mp_size_t<2>>));
return boost::report_errors();
}

View File

@@ -14,8 +14,6 @@
#include <boost/detail/workaround.hpp> #include <boost/detail/workaround.hpp>
#include <tuple> #include <tuple>
using boost::mp11::mp_identity;
#if !defined( BOOST_NO_CXX14_CONSTEXPR ) #if !defined( BOOST_NO_CXX14_CONSTEXPR )
# define CONSTEXPR14 constexpr # define CONSTEXPR14 constexpr
#else #else
@@ -26,9 +24,9 @@ struct F
{ {
int s; int s;
CONSTEXPR14 void operator()( mp_identity<int> ) { s = s * 10 + 1; } CONSTEXPR14 void operator()( int ) { s = s * 10 + 1; }
CONSTEXPR14 void operator()( mp_identity<short> ) { s = s * 10 + 2; } CONSTEXPR14 void operator()( short ) { s = s * 10 + 2; }
CONSTEXPR14 void operator()( mp_identity<char> ) { s = s * 10 + 3; } CONSTEXPR14 void operator()( char ) { s = s * 10 + 3; }
}; };
using boost::mp11::mp_list; using boost::mp11::mp_list;