Quando as chaves são opcionais na sintaxe lambda do Java 8?

Eu percebo que a implementação lambda do Java 8 está sujeita a alterações, mas na construção lambda b39, descobri que chaves só podem ser omitidas quando a expressão lambda retorna um tipo não vazio. Por exemplo, isso compila:

public class Collections8 {
        public static void main(String[] args) {
                Iterable<String> names = Arrays.asList("Alice", "Bob", "Charlie");
                names.filter(e -> e.length() > 4).forEach(e -> { System.out.println(e); });
        }
}

Mas removendo as chaves assim:

names.filter(e -> e.length() > 4).forEach(e -> System.out.println(e));

dá o erro

Collections8.java:6: error: method forEach in interface Iterable<T> cannot be applied to given types;
        names.filter(e -> e.length() > 4).forEach(e -> System.out.println(e));
                                         ^
  required: Block<? super String>
  found: lambda
  reason: incompatible return type void in lambda expression
  where T is a type-variable:
    T extends Object declared in interface Iterable

Alguém pode explicar o que está acontecendo aqui?

questionAnswers(4)

yourAnswerToTheQuestion