boost::range vs && (rvalue ref)
data:image/s3,"s3://crabby-images/b4dc1/b4dc1b534f71751e661fc924049fee8bfe43d846" alt=""
Passing range by ref (&) is fine, but using (&&) results in and error. Any
ideas?
#include
data:image/s3,"s3://crabby-images/a3cae/a3cae14df8bc5e6a8b2aa907396120d185a05a6d" alt=""
Passing range by ref (&) is fine, but using (&&) results in and error. Any ideas?
[snip]
When you pass by T&&, the deduced type of T will include the reference. (So e.g. if you have a T&& argument and you pass in an int rvalue, T will be deduced as 'const int&'. If you pass an int lvalue, T will be deduced as 'int&'. This is in contrast to a regular reference, like T&, where if you pass an int lvalue, T will be deduced as just 'int'). Range metafunctions don't accept references to range types as their input; you must pass the range type itself. So, you must call remove_reference<> on the deduced type 'T' prior to passing it to a range metafunction. I wonder if we should change the range metafunctions to accept references to range types, and do the reference stripping themselves? Regards, Nate
data:image/s3,"s3://crabby-images/4782d/4782d3994261d04366069f7f5b7a7d737d904c87" alt=""
On 11-01-2013 04:37, Nathan Ridge wrote:
Passing range by ref (&) is fine, but using (&&) results in and error. Any ideas?
[snip]
When you pass by T&&, the deduced type of T will include the reference. (So e.g. if you have a T&& argument and you pass in an int rvalue, T will be deduced as 'const int&'. If you pass an int lvalue, T will be deduced as 'int&'. This is in contrast to a regular reference, like T&, where if you pass an int lvalue, T will be deduced as just 'int').
Range metafunctions don't accept references to range types as their input; you must pass the range type itself.
So, you must call remove_reference<> on the deduced type 'T' prior to passing it to a range metafunction.
I wonder if we should change the range metafunctions to accept references to range types, and do the reference stripping themselves?
I think we should. This has come up before. -Thorsten
data:image/s3,"s3://crabby-images/b4dc1/b4dc1b534f71751e661fc924049fee8bfe43d846" alt=""
Thorsten Ottosen wrote:
On 11-01-2013 04:37, Nathan Ridge wrote:
Passing range by ref (&) is fine, but using (&&) results in and error. Any ideas?
[snip]
When you pass by T&&, the deduced type of T will include the reference. (So e.g. if you have a T&& argument and you pass in an int rvalue, T will be deduced as 'const int&'. If you pass an int lvalue, T will be deduced as 'int&'. This is in contrast to a regular reference, like T&, where if you pass an int lvalue, T will be deduced as just 'int').
Range metafunctions don't accept references to range types as their input; you must pass the range type itself.
So, you must call remove_reference<> on the deduced type 'T' prior to passing it to a range metafunction.
I wonder if we should change the range metafunctions to accept references to range types, and do the reference stripping themselves?
I think we should. This has come up before.
-Thorsten
My objective is to support this common type of usage: template<typename out_t> F (out_t & o) { } F (boost::make_iterator_range (blah.begin(), blah.end()));
data:image/s3,"s3://crabby-images/a3cae/a3cae14df8bc5e6a8b2aa907396120d185a05a6d" alt=""
Thorsten Ottosen wrote:
On 1--1--013 4::7,, Nathan Ridge wrote:
Passing range by ref (&) is fine, but using (&&) results in and error. Any ideas?
[snip]
[snip]
Range metafunctions don't accept references to range types as their input; you must pass the range type itself.
So, you must call remove_reference<> on the deduced type 'T' prior to passing it to a range metafunction.
I wonder if we should change the range metafunctions to accept references to range types, and do the reference stripping themselves?
I think we should. This has come up before.
-Thorsten
My objective is to support this common type of usage:
template<typename out_t> F (out_t & o) { }
F (boost::make_iterator_range (blah.begin(), blah.end()));
I filed https://svn.boost.org/trac/boost/ticket/885 .
In the meantime, you can use the remove_reference workaround I mentioned,
as follows:
template<typename out_t>
void F (out_t && o)
{
typedef typename boost::range_value
participants (3)
-
Nathan Ridge
-
Neal Becker
-
Thorsten Ottosen