[FunctionTypes] Testing for a general callable type.
data:image/s3,"s3://crabby-images/1379d/1379dc714fafac665a659b90fb3a1e204c34b3e4" alt=""
Hi All Is there anything in Boost to help me test for a general type being callable with a specific signature? I've found Boost.FuncionTypes, which seems to be confined to *builtin* callable types, but has made me aware that all the const/volatile/reference variations might make a general test more complicated than I first thought. Any pointers much appreciated. Thx, Rob.
data:image/s3,"s3://crabby-images/2f3da/2f3dad7b0ca4d6dd20913ce4922ba6526c47edad" alt=""
2013/3/22 Robert Jones
Hi All
Is there anything in Boost to help me test for a general type being callable with a specific signature? I've found Boost.FuncionTypes, which seems to be confined to *builtin* callable types, but has made me aware that all the const/volatile/reference variations might make a general test more complicated than I first thought.
Any pointers much appreciated.
Thx,
Just pushed to github: https://github.com/jamboree/boost.has_call (previous `can_be_called`) HTH
data:image/s3,"s3://crabby-images/1379d/1379dc714fafac665a659b90fb3a1e204c34b3e4" alt=""
On Fri, Mar 22, 2013 at 1:15 PM, TONGARI
Just pushed to github: https://github.com/jamboree/boost.has_call
(previous `can_be_called`)
Blimey Tongari, that looks like you wrote all that lot in response to my
query, in which case my thanks, just the job! It appears it was as I suspected not entirely straightforward. Rob,
data:image/s3,"s3://crabby-images/382f0/382f0c8958fe2532da2f4129629fa25a9910ed14" alt=""
On 22 March 2013 08:15, TONGARI
It doesn't seem to work with default arguments. :-(
Here is my test case (under gcc 4.7.2 -std=c++0x):
#include "boost/type_traits/has_call.hpp"
#include <cassert>
template
data:image/s3,"s3://crabby-images/60568/60568644568131b315f1aceb227f6c698306822c" alt=""
On Mon, Mar 25, 2013 at 12:22 PM, Nevin Liber
On 22 March 2013 08:15, TONGARI
wrote: It doesn't seem to work with default arguments. :-(
Here is my test case (under gcc 4.7.2 -std=c++0x):
#include "boost/type_traits/has_call.hpp" #include <cassert>
template
bool HasCall(F const&) { return boost::has_call ::value; } void DefaultVal(int = 0) {}
int main() { assert(HasCall
(DefaultVal)); }
That's because the type of DefaultVal is void ( int ). Function types cannot encode the default'ness of parameters. - Jeff
data:image/s3,"s3://crabby-images/2f3da/2f3dad7b0ca4d6dd20913ce4922ba6526c47edad" alt=""
2013/3/26 Jeffrey Lee Hellrung, Jr.
On Mon, Mar 25, 2013 at 12:22 PM, Nevin Liber
wrote: On 22 March 2013 08:15, TONGARI
wrote: It doesn't seem to work with default arguments. :-(
Here is my test case (under gcc 4.7.2 -std=c++0x):
#include "boost/type_traits/has_call.hpp" #include <cassert>
template
bool HasCall(F const&) { return boost::has_call ::value; } void DefaultVal(int = 0) {}
int main() { assert(HasCall
(DefaultVal)); } That's because the type of DefaultVal is void ( int ). Function types cannot encode the default'ness of parameters.
Yes. Instead, the following works:
struct F
{
void operator()(int = 0){}
};
...
assert(HasCall
data:image/s3,"s3://crabby-images/1379d/1379dc714fafac665a659b90fb3a1e204c34b3e4" alt=""
On 25 March 2013 20:48, Jeffrey Lee Hellrung, Jr. < jeffrey.hellrung@gmail.com> wrote:
That's because the type of DefaultVal is void ( int ). Function types cannot encode the default'ness of parameters.
How about this example? This fails to compile for me, with a template
instantiation ambiguity. Any thoughts?
Thx, Rob.
#include "boost/type_traits/has_call.hpp"
#include <cassert>
template
data:image/s3,"s3://crabby-images/2f3da/2f3dad7b0ca4d6dd20913ce4922ba6526c47edad" alt=""
2013/4/23 Robert Jones
On 25 March 2013 20:48, Jeffrey Lee Hellrung, Jr. < jeffrey.hellrung@gmail.com> wrote:
That's because the type of DefaultVal is void ( int ). Function types cannot encode the default'ness of parameters.
How about this example? This fails to compile for me, with a template instantiation ambiguity. Any thoughts?
Thx, Rob.
#include "boost/type_traits/has_call.hpp" #include <cassert>
template
bool HasCall(F const&) { return boost::has_call ::value; } void DefaultVal(int) {}
int main() { assert(HasCallboost::dont_care(int)(DefaultVal)); }
Sorry, it was a bug in C++11 mode. It's fixed on my github now, please check. https://github.com/jamboree/boost.has_call Seems that I missed the testcase for 'dont_care', will add later...
data:image/s3,"s3://crabby-images/20c93/20c93342bf0a3501e5cc7f0c522c71f6ccc12f58" alt=""
On 13-03-22 06:15 AM, TONGARI wrote:
On 2013/3/22, Robert Jones wrote:
Hi All
Is there anything in Boost to help me test for a general type being callable with a specific signature? I've found Boost.FuncionTypes, which seems to be confined to *builtin* callable types, but has made me aware that all the const/volatile/reference variations might make a general test more complicated than I first thought.
Any pointers much appreciated.
Thx,
Just pushed to github: https://github.com/jamboree/boost.has_call
(previous `can_be_called`)
This appears to owe a debt to: http://www.boost.org/doc/libs/1_53_0/doc/html/proto/appendices.html#boost_pr... ... so you should have an attribution somewhere. Apologies if I missed it. -- Eric Niebler Boost.org
data:image/s3,"s3://crabby-images/4c7b9/4c7b9bd8946b1f3eed8d419f0fcb06b0aa29e242" alt=""
On 13-03-22 06:15 AM, TONGARI wrote:
Just pushed to github: https://github.com/jamboree/boost.has_call
(previous `can_be_called`) This appears to owe a debt to: http://www.boost.org/doc/libs/1_53_0/doc/html/proto/appendices.html#boost_pr...
... so you should have an attribution somewhere. Apologies if I missed it. Agreed. I had written my own implementation of this trait based on the referenced appendix from Boost.Proto's documentation, but the one
On 03/26/2013 01:44 AM, Eric Niebler wrote: provided here is more robust than mine. Is it possible that it will be submitted for inclusion into Boost.TypeTraits? It would be nice to have it generally available at some point in the future. Jason
data:image/s3,"s3://crabby-images/2f3da/2f3dad7b0ca4d6dd20913ce4922ba6526c47edad" alt=""
2013/3/26 Jason Roehm
On 03/26/2013 01:44 AM, Eric Niebler wrote:
On 13-03-22 06:15 AM, TONGARI wrote:
Just pushed to github: https://github.com/jamboree/**boost.has_callhttps://github.com/jamboree/boost.has_call
(previous `can_be_called`) This appears to owe a debt to: http://www.boost.org/doc/libs/**1_53_0/doc/html/proto/** appendices.html#boost_proto.**appendices.implementation.**function_arityhttp://www.boost.org/doc/libs/1_53_0/doc/html/proto/appendices.html#boost_pr...
... so you should have an attribution somewhere. Apologies if I missed it.
Agreed. I had written my own implementation of this trait based on the referenced appendix from Boost.Proto's documentation, but the one provided here is more robust than mine. Is it possible that it will be submitted for inclusion into Boost.TypeTraits?
That's what I'd like to see. Maybe I should contact the maintainer of Boost.TypeTraits. ...before that I should write the doc first, alas! It would be nice to have it generally available at some point in the future.
Agreed :)
data:image/s3,"s3://crabby-images/2f3da/2f3dad7b0ca4d6dd20913ce4922ba6526c47edad" alt=""
2013/3/26 Eric Niebler
On 13-03-22 06:15 AM, TONGARI wrote:
On 2013/3/22, Robert Jones wrote:
Hi All
Is there anything in Boost to help me test for a general type being callable with a specific signature? I've found Boost.FuncionTypes, which seems to be confined to *builtin* callable types, but has made me aware that all the const/volatile/reference variations might make a general test more complicated than I first thought.
Any pointers much appreciated.
Thx,
Just pushed to github: https://github.com/jamboree/boost.has_call
(previous `can_be_called`)
This appears to owe a debt to:
http://www.boost.org/doc/libs/1_53_0/doc/html/proto/appendices.html#boost_pr...
... so you should have an attribution somewhere. Apologies if I missed it.
Noted. https://github.com/jamboree/boost.has_call/commit/1c06c41c7d2f88102d61a86904...
participants (6)
-
Eric Niebler
-
Jason Roehm
-
Jeffrey Lee Hellrung, Jr.
-
Nevin Liber
-
Robert Jones
-
TONGARI