r = error_mark_node;
   else
     {
-      /* The body of a lambda-expression is not a subexpression of the
-        enclosing expression.  Parms are to have DECL_CHAIN tsubsted,
-        which would be skipped if cp_unevaluated_operand.  */
-      cp_evaluated ev;
-
       /* Fix the type of 'this'.
         For static and xobj member functions we use this to transport the
         lambda's closure type.  It appears that in the regular case the
       /* Let finish_function set this.  */
       DECL_DECLARED_CONSTEXPR_P (fn) = false;
 
+      /* The body of a lambda-expression is not a subexpression of the
+        enclosing expression.  */
+      cp_evaluated ev;
+
       bool nested = cfun;
       if (nested)
        push_function_context ();