2
0
mirror of https://github.com/boostorg/core.git synced 2026-01-19 04:02:18 +00:00

Document is_placeholder

This commit is contained in:
Peter Dimov
2026-01-02 13:40:47 +02:00
parent 8c338d5a65
commit f3cae495d3
3 changed files with 76 additions and 0 deletions

View File

@@ -7,6 +7,12 @@
[section Revision History]
[section Changes in 1.91.0]
* The header [link core.is_placeholder `boost/is_placeholder.hpp`] has been moved from Bind to Core. ([github_issue 90])
[endsect]
[section Changes in 1.90.0]
* The implementation of `BOOST_TEST_THROWS` and `BOOST_TEST_NO_THROW` macros defined in

View File

@@ -61,6 +61,7 @@ criteria for inclusion is that the utility component be:
[include functor.qbk]
[include identity.qbk]
[include ignore_unused.qbk]
[include is_placeholder.qbk]
[include is_same.qbk]
[include launder.qbk]
[include lightweight_test.qbk]

69
doc/is_placeholder.qbk Normal file
View File

@@ -0,0 +1,69 @@
[/
Copyright 2014, 2025 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
]
[section:is_placeholder is_placeholder]
[simplesect Authors]
* Peter Dimov
[endsimplesect]
[section Header <boost/is_placeholder.hpp>]
The header `<boost/is_placeholder.hpp>` defines the class template
`boost::is_placeholder<T>`. It defines a nested integral constant
`value` which is `0` when `T` is not a `boost::bind` placeholder
type, and a positive value corresponding to the placeholder index
otherwise.
That is, `is_placeholder<_1>::value` is `1`,
`is_placeholder<_2>::value` is `2`, and so on.
`is_placeholder` can be specialized for user types. If it is,
`boost::bind` will recognize these types as placeholders.
[section Synopsis]
``
namespace boost
{
template<class T> struct is_placeholder;
}
``
[endsect]
[section Example]
``
#include <boost/is_placeholder.hpp>
#include <boost/bind.hpp>
struct arg1_type {};
constexpr arg1_type arg1{};
template<> struct boost::is_placeholder<arg1_type>
{
static constexpr int value = 1;
};
int f( int x ) { return x + 1; }
int main()
{
return boost::bind( f, arg1 )( -1 );
}
``
[endsect]
[endsect]
[endsect]