mirror of
https://gitflic.ru/project/openide/openide.git
synced 2026-02-05 08:06:56 +07:00
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
33 lines
1.3 KiB
Java
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);
|
|
}
|
|
} |