/* * @test /nodynamiccopyright/ * @bug 8231827 * @summary Basic pattern bindings scope test * @compile/fail/ref=DuplicateBindingTest.out -XDrawDiagnostics --enable-preview -source ${jdk.version} DuplicateBindingTest.java */ public class DuplicateBindingTest { int f; public static boolean main(String[] args) { if (args != null) { int s; if (args[0] instanceof String s) { // NOT OK. Redef same scope. } if (args[0] instanceof String f) { // OK to redef field. } } Object o1 = ""; Object o2 = ""; if (o1 instanceof String s && o2 instanceof String s) {} //error - already in scope on RHS (in scope due to LHS when true) if (o1 instanceof String s && !(o2 instanceof String s)) {} //error - already in scope on RHS (in scope due to LHS when true) if (!(o1 instanceof String s) && !(o2 instanceof String s)) {} //error - the same binding variable on LHS and RHS when false if (!(o1 instanceof String s) && (o2 instanceof String s)) {} //ok if (!(o1 instanceof String s) || o2 instanceof String s) {} //error - already in scope on RHS (in scope due to LHS when false) if (!(o1 instanceof String s) || !(o2 instanceof String s)) {} //error - already in scope on RHS (in scope due to LHS when false) if (o1 instanceof String s || o2 instanceof String s) {} //error - the same binding variable on LHS and RHS when true if (o1 instanceof String s || !(o2 instanceof String s)) {} //ok if (o1 instanceof String s ? o2 instanceof String s : true) {} //error - already in scope in the true section (due to condition when true) if (o1 instanceof String s ? true : o2 instanceof String s) {} //error - the same binding variable in condition when true and false section when true if (!(o1 instanceof String s) ? o2 instanceof String s : true) {} //error - the same binding variable in condition when false and true section when true if (args.length == 1 ? o2 instanceof String s : o2 instanceof String s) {} //error - the same binding variable in true section when true and false section when true if (o1 instanceof String s ? true : !(o2 instanceof String s)) {} //error - the same binding variable in condition when true and false section when false if (!(o1 instanceof String s) ? !(o2 instanceof String s) : true) {} //error - the same binding variable in condition when false and true section when false if (args.length == 1 ? !(o2 instanceof String s) : !(o2 instanceof String s)) {} //error - the same binding variable in true section when false and false section when false //verify that errors are reported to clashes in expression in non-conditional statements: boolean b = o1 instanceof String s && o2 instanceof String s; b = o1 instanceof String s && o2 instanceof String s; b &= o1 instanceof String s && o2 instanceof String s; assert o1 instanceof String s && o2 instanceof String s; testMethod(o1 instanceof String s && o2 instanceof String s, false); b = switch (args.length) { default -> o1 instanceof String s && o2 instanceof String s; }; b = switch (args.length) { default -> { yield o1 instanceof String s && o2 instanceof String s; } }; if (true) return o1 instanceof String s && o2 instanceof String s; //verify the bindings don't go through method invocation parameters or outside a lambda: b = ((VoidPredicate) () -> o1 instanceof String s).get() && s.isEmpty(); testMethod(o1 instanceof String s, s.isEmpty()); } static void testMethod(boolean b1, boolean b2) {} interface VoidPredicate { public boolean get(); } }