ho qualcosa di simile:annidata Lambda Capture in C++
// think of Synonym as a set/vector of values
// the purpose of this function is to filter out elements from the 2 synonyms/sets,
// that are not related (similar to SQL inner join) - modifier modifies vars
void Clauses::modifies(Synonym& modifiers, Synonym& modifiedVars, UnaryPredicate isModifies) {
// filter out any modifiers that does not modify (is related to) any of the variables in modifiedVar (left join)
modifiers.removeIf([modifiedVars, &isModifies](int line) -> bool {
return modifiedVars.none([line, &isModifies](int v) -> bool {
return isModifies(line, v);
});
});
// filter out any candidate modifiedVars that is not modified by any modifiers (right join)
modifiedVars.removeIf([modifiers, &isModifies](int varIndex) -> bool {
return modifiers.none([varIndex, &isModifies](int line) -> bool {
return isModifies(line, varIndex);
});
});
// result is an something like an SQL inner join
}
Il problema è che Visual Studio si lamenta che:
Error 1 error C3480: 'PQL::Clauses::`anonymous-namespace'::<lambda1>::isModifies': a lambda capture variable must be from an enclosing function scope h:\dropbox\sch\cs3202\spa_cpp\spa\pql.cpp 78
Error 2 error C2665: 'PQL::Clauses::`anonymous-namespace'::<lambda3>::<lambda3>' : none of the 2 overloads could convert all the argument types h:\dropbox\sch\cs3202\spa_cpp\spa\pql.cpp 78
...
In origine, il codice non passa i predicati/condizioni come riferimenti, ma letto da qualche parte ho pensato che avevo bisogno, ma non è sembrato cambiare nulla
modifiers.removeIf([modifiedVars, isModifies] ...
UPDATE: Sto usando VS2010 per questo progetto
Sembra un bug di Visual Studio. GCC e Clang accettano questo tipo di cattura. –
Quale versione di Visual Studio? [Le funzioni lambda annidate perdono l'ambito] (http://connect.microsoft.com/VisualStudio/feedback/details/537366/c-nested-lambda-functions-lose-scope) sembra l'errore. –
@JesseGood Ah, mi sono appena reso conto che non sono a casa e qui sto usando VS2010 piuttosto che l'ultimo Ct VS2012. –