As far as I know, in standard C++11 (not C++14), when omitting the return type of a lambda, its return type is deduced to be:
Your code is being accepted without any warnings because the original C++11 restriction is considered a defect in the standard, which allows implementations to fix the behavior. See CWG DR975, DR1048 and N3638.
975. Restrictions on return type deduction for lambdas
[Moved to DR status at the April, 2013 meeting as part of paper N3638.]
There does not appear to be any technical difficulty that would require the current restriction that the return type of a lambda can be deduced only if the body of the lambda consists of a single return statement. In particular, multiple return statements could be permitted if they all return the same type.
1048. auto deduction and lambda return type deduction.
...
Notes from the November, 2014 meeting:
CWG agreed that the change embodied in paper N3638 should be considered to have been a DR against C++11.
In summary, DR975 proposed modifying the rules for return type deduction for lambda expressions to allow multiple return statements.
DR1048 identifies a discrepancy where the rules for deducing the return type for normal functions using the placeholder type auto
differs slightly from the rules proposed in DR975. Specifically, return type deduction for normal functions would discard top-level cv-qualifiers in all cases, where as those for lambda expressions would preserve cv-qualifiers for class types.
N3638 resolves this issue, amongst others.
I doubt there's any way to revert to the original behavior short of finding a compiler version that shipped with C++11 lambda support prior to the implementation of the DR above.
This is what I find in the C++ Draft Standard N3337:
If a lambda-expression does not include a lambda-declarator, it is as if the lambda-declarator were (). If a lambda-expression does not include a trailing-return-type, it is as if the trailing-return-type denotes the following type:
— if the compound-statement is of the form
{ attribute-specifier-seqopt
return
expression ; }the type of the returned expression after lvalue-to-rvalue conversion (4.1), array-to-pointer conversion (4.2), and function-to-pointer conversion (4.3);
— otherwise,
void
.[ Example:
auto x1 = [](int i){ return i; }; // OK: return type is int auto x2 = []{ return { 1, 2 }; }; // error: the return type is void (a // braced-init-list is not an expression)
— end example ]
The standard seems to indicate that:
Then the return type is deduced from the expression. Otherwise the return type is void
.
Some C++14 rules are available in C++11 mode, when the compiler writers considered it too complicated to implement both rules at once.