data:image/s3,"s3://crabby-images/365b1/365b1df2a925fd6dea095ea076322ac3895d034e" alt=""
Hi,
I need to be explicit about a function call, but unsure quite how to
make it work, cut down example follows:
struct M
{
static
void foo() { ... }
};
struct R
{
static
void foo() { ... }
};
struct Func
{
typedef void result_type;
template
data:image/s3,"s3://crabby-images/48064/48064d72b0cc2a7ace5789b3da09cb4b9f086523" alt=""
Manfred Doudar wrote:
Hi,
I need to be explicit about a function call, but unsure quite how to make it work, cut down example follows:
struct M { static void foo() { ... } };
struct R { static void foo() { ... } };
struct Func { typedef void result_type;
template
result_type operator()(U& u) const { T::foo(); // call on either M or R // do something with 'u' } };
int main(int argc, char** argv) { using namespace boost::mpl;
typedef vector
vec; Func f; Object instance; for_each<vec>(boost::bind(&Func::operator()
, boost::ref(f), instance) ); return 0; }
Question is, what goes in at XXX above?
I was thinking something along the lines of:
boost::mpl::bindboost::mpl::_1
..but well, that doesn't work.
Try passing an argument of type M or R as a parameter:
template
data:image/s3,"s3://crabby-images/365b1/365b1df2a925fd6dea095ea076322ac3895d034e" alt=""
On Mon, 22 Feb 2010 20:51:58 -0800
Steven Watanabe
Manfred Doudar wrote:
Hi,
I need to be explicit about a function call, but unsure quite how to make it work, cut down example follows:
struct M { static void foo() { ... } };
struct R { static void foo() { ... } };
struct Func { typedef void result_type;
template
result_type operator()(U& u) const { T::foo(); // call on either M or R // do something with 'u' } };
int main(int argc, char** argv) { using namespace boost::mpl;
typedef vector
vec; Func f; Object instance; for_each<vec>(boost::bind(&Func::operator()
, boost::ref(f), instance) ); return 0; }
Question is, what goes in at XXX above?
I was thinking something along the lines of:
boost::mpl::bindboost::mpl::_1
..but well, that doesn't work.
Try passing an argument of type M or R as a parameter:
template
void operator()(const T&, U& u) const { T::foo(); } ... for_each<vec>(boost::bind(boost::ref(f), _1, instance))
Yes, I know I can do that, but I don't want to, because I don't need a T instance, I just need the type. Any ideas how I can achieve that would be appreciated. Cheers, -- Manfred
data:image/s3,"s3://crabby-images/365b1/365b1df2a925fd6dea095ea076322ac3895d034e" alt=""
On Mon, 22 Feb 2010 20:51:58 -0800
Steven Watanabe
Manfred Doudar wrote:
Hi,
using namespace boost::mpl;
typedef vector
vec; Func f; Object instance; for_each<vec>(boost::bind(&Func::operator()
, boost::ref(f), instance) );
Question is, what goes in at XXX above?
I was thinking something along the lines of:
boost::mpl::bindboost::mpl::_1
..but well, that doesn't work.
Try passing an argument of type M or R as a parameter:
template
void operator()(const T&, U& u) const { T::foo(); } ... for_each<vec>(boost::bind(boost::ref(f), _1, instance))
To both Steven & Rutger who answered - a short note of thanks. I was indeed aware of resloving the problem with the above mentioned approach, but was hoping for an explicit invocation of some kind without having to make use of a superfluous tag T in the parameter list. ..No matter. With thanks again to Steven and Rutger. Cheers, -- Manfred
data:image/s3,"s3://crabby-images/0e3bb/0e3bbe626b83317ad77cbc34946d8f9f2db3b578" alt=""
Manfred Doudar wrote:
Question is, what goes in at XXX above?
I was thinking something along the lines of:
boost::mpl::bindboost::mpl::_1
..but well, that doesn't work.
All help appreciated.
If you're in the position to use tag dispatching, one idea would be to
update Func to
struct Func
{
typedef void result_type;
template
participants (3)
-
Manfred Doudar
-
Rutger ter Borg
-
Steven Watanabe