[IdentityType] Const omission undocumented.
data:image/s3,"s3://crabby-images/9f2ce/9f2ce6bcdee28533e33d367ed002fb136e17e03a" alt=""
#include
data:image/s3,"s3://crabby-images/3cdde/3cdde99a33dd10faf821fade4b762c93ab4a4310" alt=""
On 16/11/2013 01:02, Mostafa wrote:
#include
#include <utility> int main() { BOOST_IDENTITY_TYPE(( std::pair
const )) x; // This compiles, so the const qualification in the // above macro parameter is ignored. x = std::make_pair(0,1); return 0; }
The omission of const qualification in BOOST_IDENTITY_TYPE types is undocumented. This omission maybe deduced from the documented implementation, but, as noted, that is not part of the library api and is subject to change. I therefore propose that this behaviour be documented as part of the library's public api.
That looks like a bug.
data:image/s3,"s3://crabby-images/47e0b/47e0bc2e0848a41f8693159ce37ac939cc5939ae" alt=""
On Sat, Nov 16, 2013 at 11:18 AM, Mathias Gaunard
On 16/11/2013 01:02, Mostafa wrote:
#include
#include <utility> int main() { BOOST_IDENTITY_TYPE(( std::pair
const )) x; // This compiles, so the const qualification in the // above macro parameter is ignored. x = std::make_pair(0,1); return 0; }
The omission of const qualification in BOOST_IDENTITY_TYPE types is undocumented. This omission maybe deduced from the documented implementation, but, as noted, that is not part of the library api and is subject to change. I therefore propose that this behaviour be documented as part of the library's public api.
That looks like a bug.
Is there a way to extract the cv-qualifier from a function parameter
type at compile-time?
some_mata_function
data:image/s3,"s3://crabby-images/2f3a7/2f3a71cbdf809f126bec5afac8abbdf7ff830e30" alt=""
2013/12/3 Lorenzo Caminiti
On Sat, Nov 16, 2013 at 11:18 AM, Mathias Gaunard
wrote: On 16/11/2013 01:02, Mostafa wrote:
#include
#include <utility> int main() { BOOST_IDENTITY_TYPE(( std::pair
const )) x; // This compiles, so the const qualification in the // above macro parameter is ignored. x = std::make_pair(0,1); return 0; }
The omission of const qualification in BOOST_IDENTITY_TYPE types is undocumented. This omission maybe deduced from the documented implementation, but, as noted, that is not part of the library api and is subject to change. I therefore propose that this behaviour be documented as part of the library's public api.
That looks like a bug.
Is there a way to extract the cv-qualifier from a function parameter type at compile-time?
some_mata_function
::type // evaluates to `int const` not just `int` Right now I do the following which looses the cv-qualifier (I also tried to program my own meta-functions but I wan't able to retain the cv-qualifier).
boost::function_traits
::arg1_type // evaluates to `int` and not to `int conat` :(
how about (not tested):
boost::remove_reference< boost::function_traits
data:image/s3,"s3://crabby-images/9f2ce/9f2ce6bcdee28533e33d367ed002fb136e17e03a" alt=""
On Tue, 03 Dec 2013 11:23:46 -0800, Krzysztof Czainski <1czajnik@gmail.com> wrote:
2013/12/3 Lorenzo Caminiti
On Sat, Nov 16, 2013 at 11:18 AM, Mathias Gaunard
wrote: On 16/11/2013 01:02, Mostafa wrote:
#include
#include <utility> int main() { BOOST_IDENTITY_TYPE(( std::pair
const )) x; // This compiles, so the const qualification in the // above macro parameter is ignored. x = std::make_pair(0,1); return 0; }
The omission of const qualification in BOOST_IDENTITY_TYPE types is undocumented. This omission maybe deduced from the documented implementation, but, as noted, that is not part of the library api
and
is subject to change. I therefore propose that this behaviour be documented as part of the library's public api.
That looks like a bug.
Is there a way to extract the cv-qualifier from a function parameter type at compile-time?
some_mata_function
::type // evaluates to `int const` not just `int` Right now I do the following which looses the cv-qualifier (I also tried to program my own meta-functions but I wan't able to retain the cv-qualifier).
boost::function_traits
::arg1_type // evaluates to `int` and not to `int conat` :( how about (not tested): boost::remove_reference< boost::function_traits
::arg1_type >::type
Pointers should be used instead. References will lead to bugs because of
reference collapsing when add_reference is used. For example:
BOOST_IDENTITY_TYPE(( std::pair
data:image/s3,"s3://crabby-images/47e0b/47e0bc2e0848a41f8693159ce37ac939cc5939ae" alt=""
On Tue, Dec 3, 2013 at 1:39 PM, Mostafa
On Tue, 03 Dec 2013 11:23:46 -0800, Krzysztof Czainski <1czajnik@gmail.com>
2013/12/3 Lorenzo Caminiti
On Sat, Nov 16, 2013 at 11:18 AM, Mathias Gaunard
wrote: On 16/11/2013 01:02, Mostafa wrote: That looks like a bug.
Is there a way to extract the cv-qualifier from a function parameter type at compile-time?
how about (not tested): boost::remove_reference< boost::function_traits
::arg1_type >::type Pointers should be used instead. References will lead to bugs because of reference collapsing when add_reference is used. For example:
BOOST_IDENTITY_TYPE(( std::pair
& )) x; will be incorrectly deduced as std::pair
I can't change the tokens "(int const)" because these are specified by the user of BOOST_IDENTITY_TYPE(tokens) (and I cannot inspect them within the outermost parenthesis without variadic macros, which is the point of Boost.IdentityType). So I cannot do (int const&), (int const*), etc :( --Lorenzo
participants (4)
-
Krzysztof Czainski
-
Lorenzo Caminiti
-
Mathias Gaunard
-
Mostafa