diff --git a/triqs/clef/clef.hpp b/triqs/clef/clef.hpp index ff512ac5..257aafc1 100644 --- a/triqs/clef/clef.hpp +++ b/triqs/clef/clef.hpp @@ -294,10 +294,8 @@ namespace triqs { namespace clef { template struct evaluator_node_gal<2, expr, Pairs...> { static constexpr bool is_lazy = __or(evaluator::is_lazy...); - decltype(auto) operator()(expr const &ex, - Pairs const &... pairs) const { - return op_dispatch {}(eval(std::get<0>(ex.childs), pairs...), eval(std::get<1>(ex.childs), pairs...)); - } + auto operator()(expr const& ex, Pairs const&... pairs) const + DECL_AND_RETURN(op_dispatch {}(eval(std::get<0>(ex.childs), pairs...), eval(std::get<1>(ex.childs), pairs...))); }; // the general case for more than 2 nodes. I put 1 and 2 nodes apart, just because it is the most frequent diff --git a/triqs/gfs/bz.hpp b/triqs/gfs/bz.hpp index 7aa97206..b4893999 100644 --- a/triqs/gfs/bz.hpp +++ b/triqs/gfs/bz.hpp @@ -55,8 +55,8 @@ namespace gfs { template evaluator_fnt_on_mesh(MeshType const &m, lattice::k_t const &k) { n = m.locate_neighbours(k); // TO BE IMPROVED } - //template auto operator()(F const &f) const DECL_AND_RETURN(f(k)); - template decltype(auto) operator()(F const &f) const { return f(n); } + template auto operator()(F const &f) const DECL_AND_RETURN(f(n)); + //template decltype(auto) operator()(F const &f) const { return f(n); } }; // ------------- evaluator -------------------