/** * JLS8 4.9 Intersection types */ private JavaType intersectionType(JavaType type, Set<JavaType> interfaces, Tree tree) { if (interfaces.isEmpty()) { return type; } List<String> names = new ArrayList<>(); names.add(type.name()); names.addAll(interfaces.stream().map(JavaType::name).collect(Collectors.toSet())); JavaSymbol.TypeJavaSymbol typeJavaSymbol = new JavaSymbol.TypeJavaSymbol(0, "<intersectionType of "+names.stream().collect(Collectors.joining(" & ")) + ">", semanticModel.getEnv(tree).packge); typeJavaSymbol.members = new Scope(typeJavaSymbol); IntersectionType intersectionType = new IntersectionType(typeJavaSymbol); typeJavaSymbol.type = intersectionType; Set<JavaType> superInterfaces = new HashSet<>(interfaces); if(type.symbol.isInterface()) { superInterfaces.add(type); intersectionType.supertype = symbols.objectType; } else { intersectionType.supertype = type; } intersectionType.interfaces = ImmutableList.<JavaType>builder().addAll(superInterfaces).build(); return intersectionType; }
/** * JLS8 4.9 Intersection types */ private JavaType intersectionType(JavaType type, Set<JavaType> interfaces, Tree tree) { if (interfaces.isEmpty()) { return type; } List<String> names = new ArrayList<>(); names.add(type.name()); names.addAll(interfaces.stream().map(JavaType::name).collect(Collectors.toSet())); JavaSymbol.TypeJavaSymbol typeJavaSymbol = new JavaSymbol.TypeJavaSymbol(0, "<intersectionType of "+names.stream().collect(Collectors.joining(" & ")) + ">", semanticModel.getEnv(tree).packge); typeJavaSymbol.members = new Scope(typeJavaSymbol); IntersectionType intersectionType = new IntersectionType(typeJavaSymbol); typeJavaSymbol.type = intersectionType; Set<JavaType> superInterfaces = new HashSet<>(interfaces); if(type.symbol.isInterface()) { superInterfaces.add(type); intersectionType.supertype = symbols.objectType; } else { intersectionType.supertype = type; } intersectionType.interfaces = ImmutableList.<JavaType>builder().addAll(superInterfaces).build(); return intersectionType; }
/** * Registers builtin types as symbols, so that they can be found as an usual identifiers. */ private JavaType initType(int tag, String name) { JavaSymbol.TypeJavaSymbol symbol = new JavaSymbol.TypeJavaSymbol(Flags.PUBLIC, name, rootPackage); symbol.members = new Scope(symbol); predefClass.members.enter(symbol); ((ClassJavaType) symbol.type).interfaces = ImmutableList.of(); symbol.type.tag = tag; return symbol.type; }
flag = computeClassFlags(tree); JavaSymbol.TypeJavaSymbol symbol = new JavaSymbol.TypeJavaSymbol(flag, name, env.scope.owner); symbol.declaration = tree; ((ClassTreeImpl) tree).setSymbol(symbol);
flag = computeClassFlags(tree); JavaSymbol.TypeJavaSymbol symbol = new JavaSymbol.TypeJavaSymbol(flag, name, env.scope.owner); symbol.declaration = tree; ((ClassTreeImpl) tree).setSymbol(symbol);
public Symbols(BytecodeCompleter bytecodeCompleter) { defaultPackage = new JavaSymbol.PackageJavaSymbol("", rootPackage); predefClass = new JavaSymbol.TypeJavaSymbol(Flags.PUBLIC, "", rootPackage); predefClass.members = new Scope(predefClass); ((JavaType.ClassJavaType) predefClass.type).interfaces = ImmutableList.of(); noSymbol = new JavaSymbol.TypeJavaSymbol(0, "", rootPackage); methodClass = new JavaSymbol.TypeJavaSymbol(Flags.PUBLIC, "", noSymbol); arrayClass = new JavaSymbol.TypeJavaSymbol(Flags.PUBLIC, "Array", noSymbol); JavaType.ClassJavaType arrayClassType = (JavaType.ClassJavaType) arrayClass.type; arrayClassType.supertype = objectType;
public Symbols(BytecodeCompleter bytecodeCompleter) { defaultPackage = new JavaSymbol.PackageJavaSymbol("", rootPackage); predefClass = new JavaSymbol.TypeJavaSymbol(Flags.PUBLIC, "", rootPackage); predefClass.members = new Scope(predefClass); ((ClassJavaType) predefClass.type).interfaces = ImmutableList.of(); noSymbol = new JavaSymbol.TypeJavaSymbol(0, "", rootPackage); methodClass = new JavaSymbol.TypeJavaSymbol(Flags.PUBLIC, "", noSymbol); arrayClass = new JavaSymbol.TypeJavaSymbol(Flags.PUBLIC, "Array", noSymbol); ClassJavaType arrayClassType = (ClassJavaType) arrayClass.type; arrayClassType.supertype = objectType; JavaSymbol.TypeJavaSymbol syntheticAnnotation = new JavaSymbol.TypeJavaSymbol(Flags.PUBLIC | Flags.ANNOTATION, "Synthetic", javalang); javalang.members.enter(syntheticAnnotation); bytecodeCompleter.registerClass(syntheticAnnotation);
flag = computeClassFlags(tree); JavaSymbol.TypeJavaSymbol symbol = new JavaSymbol.TypeJavaSymbol(flag, name, env.scope.owner); symbol.declaration = tree; ((ClassTreeImpl) tree).setSymbol(symbol);
public Symbols(BytecodeCompleter bytecodeCompleter) { defaultPackage = new JavaSymbol.PackageJavaSymbol("", rootPackage); predefClass = new JavaSymbol.TypeJavaSymbol(Flags.PUBLIC, "", rootPackage); predefClass.members = new Scope(predefClass); ((JavaType.ClassJavaType) predefClass.type).interfaces = ImmutableList.of(); noSymbol = new JavaSymbol.TypeJavaSymbol(0, "", rootPackage); methodClass = new JavaSymbol.TypeJavaSymbol(Flags.PUBLIC, "", noSymbol); arrayClass = new JavaSymbol.TypeJavaSymbol(Flags.PUBLIC, "Array", noSymbol); JavaType.ClassJavaType arrayClassType = (JavaType.ClassJavaType) arrayClass.type; arrayClassType.supertype = objectType;
public Symbols(BytecodeCompleter bytecodeCompleter) { defaultPackage = new JavaSymbol.PackageJavaSymbol("", rootPackage); predefClass = new JavaSymbol.TypeJavaSymbol(Flags.PUBLIC, "", rootPackage); predefClass.members = new Scope(predefClass); ((ClassJavaType) predefClass.type).interfaces = ImmutableList.of(); noSymbol = new JavaSymbol.TypeJavaSymbol(0, "", rootPackage); methodClass = new JavaSymbol.TypeJavaSymbol(Flags.PUBLIC, "", noSymbol); arrayClass = new JavaSymbol.TypeJavaSymbol(Flags.PUBLIC, "Array", noSymbol); ClassJavaType arrayClassType = (ClassJavaType) arrayClass.type; arrayClassType.supertype = objectType; JavaSymbol.TypeJavaSymbol syntheticAnnotation = new JavaSymbol.TypeJavaSymbol(Flags.PUBLIC | Flags.ANNOTATION, "Synthetic", javalang); javalang.members.enter(syntheticAnnotation); bytecodeCompleter.registerClass(syntheticAnnotation);
flag = computeClassFlags(tree); JavaSymbol.TypeJavaSymbol symbol = new JavaSymbol.TypeJavaSymbol(flag, name, env.scope.owner); symbol.declaration = tree; ((ClassTreeImpl) tree).setSymbol(symbol);
symbol = new JavaSymbol.TypeJavaSymbol(filterBytecodeFlags(flags), Convert.innerClassName(Convert.shortName(owner.getFullyQualifiedName()), shortName), owner); } else { symbol = new JavaSymbol.TypeJavaSymbol(filterBytecodeFlags(flags), shortName, enterPackage(packageName));
symbol = new JavaSymbol.TypeJavaSymbol(classFlags, name, owner, bytecodeName); } else { symbol = new JavaSymbol.TypeJavaSymbol(classFlags, shortName, enterPackage(packageName));
symbol = new JavaSymbol.TypeJavaSymbol(classFlags, name, owner, bytecodeName); } else { symbol = new JavaSymbol.TypeJavaSymbol(classFlags, shortName, enterPackage(packageName));
JavaSymbol.TypeJavaSymbol getClassSymbol(String bytecodeName, int flags) { String flatName = Convert.flatName(bytecodeName); JavaSymbol.TypeJavaSymbol symbol = classes.get(flatName); if (symbol == null) { String shortName = Convert.shortName(flatName); String packageName = Convert.packagePart(flatName); String enclosingClassName = Convert.enclosingClassName(shortName); if (StringUtils.isNotEmpty(enclosingClassName)) { //handle innerClasses symbol = new JavaSymbol.TypeJavaSymbol(filterBytecodeFlags(flags), Convert.innerClassName(shortName), getClassSymbol(Convert.fullName(packageName, enclosingClassName))); } else { symbol = new JavaSymbol.TypeJavaSymbol(filterBytecodeFlags(flags), shortName, enterPackage(packageName)); } symbol.members = new Scope(symbol); symbol.typeParameters = new Scope(symbol); // (Godin): IOException will happen without this condition in case of missing class: if (getClassLoader().getResource(Convert.bytecodeName(flatName) + ".class") != null) { symbol.completer = this; } else { LOG.error("Class not found: " + bytecodeName); ((JavaType.ClassJavaType) symbol.type).interfaces = ImmutableList.of(); ((JavaType.ClassJavaType) symbol.type).supertype = Symbols.unknownType; } classes.put(flatName, symbol); } return symbol; }
/** * Registers builtin types as symbols, so that they can be found as an usual identifiers. */ private JavaType initType(int tag, String name) { JavaSymbol.TypeJavaSymbol symbol = new JavaSymbol.TypeJavaSymbol(Flags.PUBLIC, name, rootPackage); symbol.members = new Scope(symbol); predefClass.members.enter(symbol); ((JavaType.ClassJavaType) symbol.type).interfaces = ImmutableList.of(); symbol.type.tag = tag; return symbol.type; }
/** * Registers builtin types as symbols, so that they can be found as an usual identifiers. */ private JavaType initType(int tag, String name) { JavaSymbol.TypeJavaSymbol symbol = new JavaSymbol.TypeJavaSymbol(Flags.PUBLIC, name, rootPackage); symbol.members = new Scope(symbol); predefClass.members.enter(symbol); ((JavaType.ClassJavaType) symbol.type).interfaces = ImmutableList.of(); symbol.type.tag = tag; return symbol.type; }
/** * Registers builtin types as symbols, so that they can be found as an usual identifiers. */ private JavaType initType(int tag, String name) { JavaSymbol.TypeJavaSymbol symbol = new JavaSymbol.TypeJavaSymbol(Flags.PUBLIC, name, rootPackage); symbol.members = new Scope(symbol); predefClass.members.enter(symbol); ((ClassJavaType) symbol.type).interfaces = ImmutableList.of(); symbol.type.tag = tag; return symbol.type; }