Files
openide/java/java-tests/testData/inspection/optionalChains/beforeStreamJava9.java
Tagir Valeev a8259d29d2 OptionalRefactoringUtil: do not suggest opt.map().stream() -> opt.stream().flatMap() if operation may have side-effect
Side-effect is allowed for Optional.map, but not allowed for Stream.flatMap, and actually may cause a semantics change
Fixes IDEA-207178 Incorrect simplification of optional suggested by inspection
2019-02-15 12:27:18 +07:00

33 lines
1.3 KiB
Java

// "Fix all 'Optional call chain can be simplified' problems in file" "true"
import java.util.Optional;
import java.util.stream.IntStream;
import java.util.stream.Stream;
public final class MyClass {
interface Person {
Optional<String> name();
}
public static void testStream(Person p, Optional<Integer> opt) {
p.name().map(Stream::of).or<caret>Else(Stream.empty()).forEach(System.out::println);
p.name().map(n -> Stream.of(n.trim())).orElseGet(() -> Stream.empty()).forEach(System.out::println);
p.name().map(n -> Stream.of(n.split(""))).orElse(Stream.empty()).forEach(System.out::println);
p.name().map(n -> IntStream.of(n.length())).orElseGet(IntStream::empty).forEach(System.out::println);
p.name().map(String::chars).orElseGet(IntStream::empty).forEach(System.out::println);
p.name().map(n -> n.isEmpty() ? Stream.empty() : Stream.of(n)).orElseGet(Stream::empty).forEach(System.out::println);
p.name().map(m -> createStream(m)).orElse(Stream.empty());
p.name().map(m -> createStreamSideEffect(m)).orElse(Stream.empty());
Stream<Integer> stream = opt.map(Stream::of).orElseGet(Stream::empty);
}
static Stream<String> createStream(String s) {
return Stream.of(s, s);
}
static Stream<String> createStreamSideEffect(String s) {
System.out.println(s);
return Stream.of(s, s);
}
}