jdk-24/test/langtools/tools/javac/processing/model/element/TestNames.java
Aggelos Biboudis 8aa50288a1 8302344: Compiler Implementation for Unnamed patterns and variables (Preview)
8307444: java.lang.AssertionError when using unnamed patterns
8307482: Compiler should accept var _ in nested patterns in switch case
8307007: Implementation for javax.lang.model for unnamed variables (Preview)
8308312: Compiler should fail when a local variable declaration does not include an Identifier and does not have an initializer
8308309: Compiler should accept mixed masked and unmasked variables in lambda parameters

Co-authored-by: Jan Lahoda <jlahoda@openjdk.org>
Co-authored-by: Aggelos Biboudis <abimpoudis@openjdk.org>
Reviewed-by: vromero, darcy
2023-05-22 08:52:36 +00:00

133 lines
4.1 KiB
Java

/*
* Copyright (c) 2006, 2015, Oracle and/or its affiliates. All rights reserved.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
*
* This code is free software; you can redistribute it and/or modify it
* under the terms of the GNU General Public License version 2 only, as
* published by the Free Software Foundation.
*
* This code is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
* version 2 for more details (a copy is included in the LICENSE file that
* accompanied this code).
*
* You should have received a copy of the GNU General Public License version
* 2 along with this work; if not, write to the Free Software Foundation,
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
*
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
* or visit www.oracle.com if you need additional information or have any
* questions.
*/
/*
* @test
* @bug 6380016
* @summary Test that the constraints guaranteed by the Filer and maintained
* @author Joseph D. Darcy
* @library /tools/javac/lib
* @modules java.compiler
* jdk.compiler
* @build JavacTestingAbstractProcessor TestNames
* @compile -processor TestNames -proc:only TestNames.java
*/
import java.util.Set;
import javax.annotation.processing.*;
import javax.lang.model.element.*;
import java.io.*;
/**
* Basic tests of semantics of javax.lang.model.element.Name
*/
public class TestNames extends JavacTestingAbstractProcessor {
private int round = 0;
String stringStringName = "java.lang.String";
Name stringName = null;
public boolean process(Set<? extends TypeElement> annotations,
RoundEnvironment roundEnv) {
round++;
if (!roundEnv.processingOver()) {
boolean failed = false;
switch(round) {
case 1:
TypeElement stringMirror = eltUtils.getTypeElement(stringStringName);
stringName = stringMirror.getQualifiedName();
Name stringPseudoName = Pseudonym.getName(stringName.toString());
if (stringName.equals(stringPseudoName))
failed = true;
if (!stringName.contentEquals(stringStringName))
failed = true;
if (!stringName.contentEquals(stringPseudoName))
failed = true;
// Force another round with a new context
try (PrintWriter pw = new PrintWriter(filer.createSourceFile("Foo").openWriter())) {
pw.println("public class Foo {}");
} catch (IOException ioe) {
throw new RuntimeException();
}
break;
case 2:
Name stringStringAsName = eltUtils.getName(stringStringName);
TypeElement stringMirror2 = eltUtils.getTypeElement(stringStringName);
Name stringName2 = stringMirror2.getQualifiedName();
if (stringStringAsName != stringName ||
stringName != stringName2)
failed = true;
break;
default:
throw new RuntimeException("Unexpected round " + round);
}
if (failed)
throw new RuntimeException("Invalid name equality checks.");
}
return true;
}
private static class Pseudonym implements Name {
private String name;
private Pseudonym(String name) {
this.name = name;
}
public static Pseudonym getName(String name) {
return new Pseudonym(name);
}
public boolean contentEquals(CharSequence cs) {
return name.contentEquals(cs);
}
public char charAt(int index) {
return name.charAt(index);
}
public int length() {
return name.length();
}
public CharSequence subSequence(int start, int end) {
return name.subSequence(start, end);
}
public String toString() {
return name;
}
}
}