Wie kann ich auch Funktionskörper in eine Transformation eines Boost Phoenix-Ausdrucks aufnehmen?Transformieren von Funktionskörpern in Boost Phoenix Expressions
Zum Beispiel habe ich auf dem faulen Funktionen Abschnitt der Boost Phoenix Starter Kit gebaut und erstellt eine faule Zusatzfunktion:
struct my_lazy_add_impl {
typedef int result_type;
template <typename T>
T operator()(T x, T y) const { return x+y; }
};
phoenix::function<my_lazy_add_impl> my_add;
bereite ich dann ein einfache Plus-zu-Minus-Transformation von einem previous question, hier gezeigt :
struct invrt:
proto::or_<
proto::when<
proto::plus<proto::_, proto::_>,
proto::functional::make_expr<proto::tag::minus>(
invrt(proto::_left), invrt(proto::_right)
)
>,
proto::otherwise<
proto::nary_expr<proto::_, proto::vararg<invrt> >
>
>
{};
wenn ich jedoch einen umgekehrten Phoenix lambda
Ausdruck anwenden, mit my_add
, auf ihre Argumente, wie unten dargestellt, so scheint es, die beabsichtigte Inversion nicht erreicht worden ist. Gibt es eine empfohlene Möglichkeit, Funktionsaufrufe in Phoenix zu implementieren, die solche Transformationen erleichtern können?
int main(int argc, char *argv[])
{
auto f = phoenix::lambda(_a = 0)[my_add(_1,_2)];
auto g = invrt()(phoenix::lambda(_a = 0)[my_add(_1,_2)]);
std::cout << f()(1,2) << std::endl; // 3
std::cout << g()(1,2) << std::endl; // 3 again; alas not -1
return 0;
}
Thankyou. Ich hatte geahnt, dass dies der richtige Weg war, aber ich wollte etwas Beruhigung, bevor ich auf die Idee kam. – user2023370
p.s. Ich denke, der "Let" -Körper könnte auch '_1 + _2' sein. – user2023370
I/Think/Sie werden feststellen, dass Sie in komplizierteren Kontexten einen neuen Bereich für Ihre Funktionskörper erstellen müssen; daher das "Let". Zumindest erinnere ich mich, dass ich diese Lektion auf die harte Tour gelernt habe, aber für das Leben von mir kann ich mich nicht mehr erinnern, warum. :-P –