File: Marks3b.java

package info (click to toggle)
checker-framework-java 3.2.0%2Bds-3
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 23,104 kB
  • sloc: java: 145,916; xml: 839; sh: 518; makefile: 404; perl: 26
file content (32 lines) | stat: -rw-r--r-- 767 bytes parent folder | download | duplicates (3)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
import java.util.Optional;

/**
 * Test case for rule #3: "Prefer alternative APIs over Optional.isPresent() and Optional.get()."
 */
@SuppressWarnings("optional.parameter")
public class Marks3b {

    class Task {}

    class Executor {
        void runTask(Task t) {}
    }

    Executor executor = new Executor();

    void bad(Optional<Task> oTask) {
        // :: warning: (prefer.ifpresent)
        if (oTask.isPresent()) {
            executor.runTask(oTask.get());
        }
    }

    void better(Optional<Task> oTask) {
        // no warning; better code is possible but has nothing to do with Optional
        oTask.ifPresent(task -> executor.runTask(task));
    }

    void best(Optional<Task> oTask) {
        oTask.ifPresent(executor::runTask);
    }
}