[type traits] Extension to operator detection -> choose your preferred naming
data:image/s3,"s3://crabby-images/16b60/16b60b7f57333781979b6ac912c12faa1ecb3a9d" alt=""
It is time to include the type trait extension to the official boost trunk.
These traits can detect if you can use a given operator with given arguments.
For example: has_plus
data:image/s3,"s3://crabby-images/56f2b/56f2b5bb1e0ecf3a6098da292b76dd2b3a349187" alt=""
On 08/23/2011 11:22 PM, Frédéric Bron wrote:
...elision by patrick... We have come to three proposed lists of names (A, B and C): https://svn.boost.org/trac/boost/wiki/GuideLines/Naming/OperatorTraitNames I have included the corresponding names of standard keywords, standard function objects from <functional>, boost Proto and boost Operators.
Please give your preference between A, B and C before Sept. 5th. C
Patrick
data:image/s3,"s3://crabby-images/21e48/21e48e49077f0339f64a6625fc291350d9d7ec54" alt=""
2011/8/24 Frédéric Bron
We have come to three proposed lists of names (A, B and C): https://svn.boost.org/trac/boost/wiki/GuideLines/Naming/OperatorTraitNames I have included the corresponding names of standard keywords, standard function objects from <functional>, boost Proto and boost Operators.
Please give your preference between A, B and C before Sept. 5th.
C, except I'd prefer has_unary_minus instead of has_negate Best, Dee
data:image/s3,"s3://crabby-images/438b1/438b1aa61e01a6b75d80ee70a25bc94e4862b16a" alt=""
We have come to three proposed lists of names (A, B and C): https://svn.boost.org/trac/boost/wiki/GuideLines/Naming/OperatorTraitNames I have included the corresponding names of standard keywords, standard function objects from <functional>, boost Proto and boost Operators.
Please give your preference between A, B and C before Sept. 5th.
C, except I'd prefer has_unary_minus instead of has_negate
LOL, well I prefer B except for has_negate where I go with C. John.
data:image/s3,"s3://crabby-images/5a716/5a716a4f2f51b6acb16479cf97e8828a78d8959b" alt=""
Frédéric Bron wrote:
We have come to three proposed lists of names (A, B and C): https://svn.boost.org/trac/boost/wiki/GuideLines/Naming/OperatorTraitNa mes I have included the corresponding names of standard keywords, standard function objects from <functional>, boost Proto and boost Operators.
Please give your preference between A, B and C before Sept. 5th.
C Regards, Thomas
data:image/s3,"s3://crabby-images/3f603/3f6036f5529d7452afcdcb6ed5b9d616a10511e0" alt=""
on Tue Aug 23 2011, Frédéric Bron
It is time to include the type trait extension to the official boost trunk. These traits can detect if you can use a given operator with given arguments.
For example: has_plus
::value is true because the following program compiles without error: double lhs; int rhs; lhs+rhs;
This checks for the ability to add lvalues. Is there a way to check for rvalues? Just curious.
We have come to three proposed lists of names (A, B and C): https://svn.boost.org/trac/boost/wiki/GuideLines/Naming/OperatorTraitNames I have included the corresponding names of standard keywords, standard function objects from <functional>, boost Proto and boost Operators.
Please give your preference between A, B and C before Sept. 5th.
C -- Dave Abrahams BoostPro Computing http://www.boostpro.com
data:image/s3,"s3://crabby-images/f50de/f50debce04ae4d88adac3c8cc86a72503c8a1272" alt=""
On Tuesday, August 23, 2011 11:22:45 PM UTC-7, Frédéric Bron wrote:
It is time to include the type trait extension to the official boost trunk. These traits can detect if you can use a given operator with given arguments.
For example: has_plus
::value is true because the following program compiles without error: double lhs; int rhs; lhs+rhs;
I just want to make the connection with the thread I opened last week: "[math][tools][units]
generic libraries not generic enough"
The point I want to make is that if there were a uniform facility to deduce
the result of a built-in operator over some arithmetic types then library
authors could do a better job at writting generic libraries on some exotic
arithmetic types and combinations, for example
multiply_typeof_helper
https://svn.boost.org/trac/boost/wiki/GuideLines/Naming/OperatorTraitNames I have included the corresponding names of standard keywords, standard function objects from <functional>, boost Proto and boost Operators.
Please give your preference between A, B and C before Sept. 5th.
Regards,
Frédéric _______________________________________________ Boost-users mailing list Boost...@lists.boost.org http://lists.boost.org/mailman/listinfo.cgi/boost-users
data:image/s3,"s3://crabby-images/16b60/16b60b7f57333781979b6ac912c12faa1ecb3a9d" alt=""
I just want to make the connection with the thread I opened last week: "[math][tools][units] generic libraries not generic enough"
The point I want to make is that if there were a uniform facility to deduce the result of a built-in operator over some arithmetic types then library authors could do a better job at writting generic libraries on some exotic arithmetic types and combinations, for example
multiply_typeof_helper
::type --> double I just wanted to make the connection between the two problems; and hopeful solve the has_operator and typeof_operator problem together.
The operator traits can detect if the operator return value can be converted to a given type but not the precise return type.
PS: what if to types can not be multiplied, etc, the has_multiplies will tell or multiplies_typeof_helper can return void, or boost::none.
has_operator_multiplies::value is false. Frédéric
data:image/s3,"s3://crabby-images/f50de/f50debce04ae4d88adac3c8cc86a72503c8a1272" alt=""
The point I want to make is that if there were a uniform facility to deduce
the result of a built-in operator over some arithmetic types then library authors could do a better job at writting generic libraries on some exotic arithmetic types and combinations, for example
multiply_typeof_helper
::type --> double I just wanted to make the connection between the two problems; and hopeful solve the has_operator and typeof_operator problem together.
The operator traits can detect if the operator return value can be converted to a given type but not the precise return type.
what do you mean by "it can't"? is that a limitation of the language? or the
library?
can't the built-in type cases by hard coded, e.g.
template<>
multiply_typeof_helper
data:image/s3,"s3://crabby-images/16b60/16b60b7f57333781979b6ac912c12faa1ecb3a9d" alt=""
The operator traits can detect if the operator return value can be converted to a given type but not the precise return type.
what do you mean by "it can't"? is that a limitation of the language? or the library?
library. I leave this for anybody who wants to propose an extension. As for myself, I will be happy to go to the end of my initial proposal. Frédéric
participants (7)
-
alfC
-
Dave Abrahams
-
Diederick C. Niehorster
-
Frédéric Bron
-
John Maddock
-
Patrick Horgan
-
Thomas Klimpel