Je voudrais appeler un membre via lambda :: bind. Malheureusement, j'ai deux membres avec le même nom mais différents types de retour. Existe-t-il un moyen d'aider lambda :: bind à déduire le bon type de retour pour un appel de fonction membre? (Bind fonctionne très bien avec déduction de type retour explicite)boost lambda :: bind type de retour sélection
#include <vector>
#include <iostream>
#include <algorithm>
#include <boost/bind.hpp>
#include <boost/lambda/lambda.hpp>
#include <boost/lambda/bind.hpp>
using namespace std;
using namespace boost;
struct A
{
A (const string & name) : m_name(name) {}
string & name() { return m_name; }
const string & name() const { return m_name; }
string m_name;
};
vector<A> av;
int main()
{
av.push_back (A ("some name"));
// compiles fine
find_if(av.begin(), av.end(), bind<const string &>(&A::name, _1) == "some name");
// error: call of overloaded 'bind(<unresolved overloaded function type>, const boost::lambda::lambda_functor<boost::lambda::placeholder<1> >&)' is ambiguous
find_if(av.begin(), av.end(), lambda::bind(&A::name, lambda::_1) == "some name");
return 0;
}
Vous venez de le rappeler le vrai problème :) Il y a un moyen de passer outre le type de retour dans lambda :: boost, mais il ne fonctionne pour l'expression lambda pas pour la liaison. voir: lambda :: ret (e) dans la référence. Malheureusement dans la situation actuelle, il n'est pas applicable ... –
psaghelyi