langtools/test/tools/javac/lambda/FunctionalInterfaceConversionTest.java
author mcimadamore
Fri, 30 Nov 2012 15:14:25 +0000
changeset 14723 46aa71a5e4e0
child 15040 99fd9483d3f0
permissions -rw-r--r--
8004102: Add support for generic functional descriptors Summary: Method references are allowed to have a generic functional interface descriptor target Reviewed-by: jjg
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
14723
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
     1
/*
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
     2
 * Copyright (c) 2012, Oracle and/or its affiliates. All rights reserved.
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
     3
 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
     4
 *
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
     5
 * This code is free software; you can redistribute it and/or modify it
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
     6
 * under the terms of the GNU General Public License version 2 only, as
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
     7
 * published by the Free Software Foundation.
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
     8
 *
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
     9
 * This code is distributed in the hope that it will be useful, but WITHOUT
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
    10
 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
    11
 * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
    12
 * version 2 for more details (a copy is included in the LICENSE file that
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
    13
 * accompanied this code).
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
    14
 *
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
    15
 * You should have received a copy of the GNU General Public License version
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
    16
 * 2 along with this work; if not, write to the Free Software Foundation,
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
    17
 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
    18
 *
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
    19
 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
    20
 * or visit www.oracle.com if you need additional information or have any
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
    21
 * questions.
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
    22
 */
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
    23
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
    24
/**
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
    25
 * @test
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
    26
 * @bug 8003280 8004102
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
    27
 * @summary Add lambda tests
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
    28
 *  perform several automated checks in lambda conversion, esp. around accessibility
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
    29
 * @author  Maurizio Cimadamore
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
    30
 * @run main FunctionalInterfaceConversionTest
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
    31
 */
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
    32
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
    33
import com.sun.source.util.JavacTask;
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
    34
import java.net.URI;
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
    35
import java.util.Arrays;
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
    36
import javax.tools.Diagnostic;
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
    37
import javax.tools.JavaCompiler;
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
    38
import javax.tools.JavaFileObject;
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
    39
import javax.tools.SimpleJavaFileObject;
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
    40
import javax.tools.StandardJavaFileManager;
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
    41
import javax.tools.ToolProvider;
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
    42
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
    43
public class FunctionalInterfaceConversionTest {
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
    44
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
    45
    enum PackageKind {
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
    46
        NO_PKG(""),
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
    47
        PKG_A("a");
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
    48
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
    49
        String pkg;
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
    50
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
    51
        PackageKind(String pkg) {
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
    52
            this.pkg = pkg;
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
    53
        }
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
    54
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
    55
        String getPkgDecl() {
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
    56
            return this == NO_PKG ?
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
    57
                "" :
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
    58
                "package " + pkg + ";";
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
    59
        }
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
    60
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
    61
        String getImportStat() {
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
    62
            return this == NO_PKG ?
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
    63
                "" :
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
    64
                "import " + pkg + ".*;";
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
    65
        }
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
    66
    }
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
    67
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
    68
    enum SamKind {
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
    69
        CLASS("public class Sam {  }"),
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
    70
        ABSTACT_CLASS("public abstract class Sam {  }"),
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
    71
        ANNOTATION("public @interface Sam {  }"),
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
    72
        ENUM("public enum Sam { }"),
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
    73
        INTERFACE("public interface Sam { \n #METH; \n }");
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
    74
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
    75
        String sam_str;
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
    76
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
    77
        SamKind(String sam_str) {
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
    78
            this.sam_str = sam_str;
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
    79
        }
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
    80
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
    81
        String getSam(String methStr) {
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
    82
            return sam_str.replaceAll("#METH", methStr);
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
    83
        }
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
    84
    }
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
    85
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
    86
    enum ModifierKind {
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
    87
        PUBLIC("public"),
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
    88
        PACKAGE("");
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
    89
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
    90
        String modifier_str;
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
    91
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
    92
        ModifierKind(String modifier_str) {
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
    93
            this.modifier_str = modifier_str;
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
    94
        }
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
    95
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
    96
        boolean stricterThan(ModifierKind that) {
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
    97
            return this.ordinal() > that.ordinal();
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
    98
        }
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
    99
    }
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
   100
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
   101
    enum TypeKind {
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
   102
        EXCEPTION("Exception"),
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
   103
        PKG_CLASS("PackageClass");
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
   104
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
   105
        String typeStr;
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
   106
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
   107
        private TypeKind(String typeStr) {
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
   108
            this.typeStr = typeStr;
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
   109
        }
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
   110
    }
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
   111
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
   112
    enum ExprKind {
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
   113
        LAMBDA("x -> null"),
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
   114
        MREF("this::m");
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
   115
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
   116
        String exprStr;
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
   117
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
   118
        private ExprKind(String exprStr) {
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
   119
            this.exprStr = exprStr;
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
   120
        }
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
   121
    }
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
   122
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
   123
    enum MethodKind {
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
   124
        NONE(""),
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
   125
        NON_GENERIC("public abstract #R m(#ARG s) throws #T;"),
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
   126
        GENERIC("public abstract <X> #R m(#ARG s) throws #T;");
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
   127
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
   128
        String methodTemplate;
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
   129
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
   130
        private MethodKind(String methodTemplate) {
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
   131
            this.methodTemplate = methodTemplate;
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
   132
        }
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
   133
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
   134
        String getMethod(TypeKind retType, TypeKind argType, TypeKind thrownType) {
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
   135
            return methodTemplate.replaceAll("#R", retType.typeStr).
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
   136
                    replaceAll("#ARG", argType.typeStr).
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
   137
                    replaceAll("#T", thrownType.typeStr);
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
   138
        }
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
   139
    }
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
   140
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
   141
    public static void main(String[] args) throws Exception {
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
   142
        final JavaCompiler comp = ToolProvider.getSystemJavaCompiler();
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
   143
        StandardJavaFileManager fm = comp.getStandardFileManager(null, null, null);
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
   144
        for (PackageKind samPkg : PackageKind.values()) {
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
   145
            for (ModifierKind modKind : ModifierKind.values()) {
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
   146
                for (SamKind samKind : SamKind.values()) {
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
   147
                    for (MethodKind samMeth : MethodKind.values()) {
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
   148
                        for (MethodKind clientMeth : MethodKind.values()) {
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
   149
                            for (TypeKind retType : TypeKind.values()) {
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
   150
                                for (TypeKind argType : TypeKind.values()) {
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
   151
                                    for (TypeKind thrownType : TypeKind.values()) {
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
   152
                                        for (ExprKind exprKind : ExprKind.values()) {
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
   153
                                            new FunctionalInterfaceConversionTest(samPkg, modKind, samKind,
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
   154
                                                    samMeth, clientMeth, retType, argType, thrownType, exprKind).test(comp, fm);
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
   155
                                        }
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
   156
                                    }
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
   157
                                }
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
   158
                            }
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
   159
                        }
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
   160
                    }
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
   161
                }
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
   162
            }
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
   163
        }
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
   164
    }
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
   165
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
   166
    PackageKind samPkg;
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
   167
    ModifierKind modKind;
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
   168
    SamKind samKind;
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
   169
    MethodKind samMeth;
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
   170
    MethodKind clientMeth;
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
   171
    TypeKind retType;
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
   172
    TypeKind argType;
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
   173
    TypeKind thrownType;
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
   174
    ExprKind exprKind;
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
   175
    DiagnosticChecker dc;
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
   176
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
   177
    SourceFile samSourceFile = new SourceFile("Sam.java", "#P \n #C") {
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
   178
        public String toString() {
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
   179
            return template.replaceAll("#P", samPkg.getPkgDecl()).
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
   180
                    replaceAll("#C", samKind.getSam(samMeth.getMethod(retType, argType, thrownType)));
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
   181
        }
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
   182
    };
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
   183
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
   184
    SourceFile pkgClassSourceFile = new SourceFile("PackageClass.java",
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
   185
                                                   "#P\n #M class PackageClass extends Exception { }") {
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
   186
        public String toString() {
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
   187
            return template.replaceAll("#P", samPkg.getPkgDecl()).
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
   188
                    replaceAll("#M", modKind.modifier_str);
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
   189
        }
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
   190
    };
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
   191
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
   192
    SourceFile clientSourceFile = new SourceFile("Client.java",
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
   193
                                                 "#I\n abstract class Client { \n" +
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
   194
                                                 "  Sam s = #E;\n" +
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
   195
                                                 "  #M \n }") {
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
   196
        public String toString() {
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
   197
            return template.replaceAll("#I", samPkg.getImportStat())
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
   198
                    .replaceAll("#E", exprKind.exprStr)
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
   199
                    .replaceAll("#M", clientMeth.getMethod(retType, argType, thrownType));
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
   200
        }
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
   201
    };
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
   202
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
   203
    FunctionalInterfaceConversionTest(PackageKind samPkg, ModifierKind modKind, SamKind samKind,
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
   204
            MethodKind samMeth, MethodKind clientMeth, TypeKind retType, TypeKind argType,
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
   205
            TypeKind thrownType, ExprKind exprKind) {
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
   206
        this.samPkg = samPkg;
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
   207
        this.modKind = modKind;
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
   208
        this.samKind = samKind;
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
   209
        this.samMeth = samMeth;
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
   210
        this.clientMeth = clientMeth;
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
   211
        this.retType = retType;
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
   212
        this.argType = argType;
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
   213
        this.thrownType = thrownType;
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
   214
        this.exprKind = exprKind;
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
   215
        this.dc = new DiagnosticChecker();
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
   216
    }
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
   217
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
   218
    void test(JavaCompiler comp, StandardJavaFileManager fm) throws Exception {
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
   219
        JavacTask ct = (JavacTask)comp.getTask(null, fm, dc,
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
   220
                null, null, Arrays.asList(samSourceFile, pkgClassSourceFile, clientSourceFile));
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
   221
        ct.analyze();
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
   222
        if (dc.errorFound == checkSamConversion()) {
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
   223
            throw new AssertionError(samSourceFile + "\n\n" + pkgClassSourceFile + "\n\n" + clientSourceFile);
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
   224
        }
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
   225
    }
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
   226
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
   227
    boolean checkSamConversion() {
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
   228
        if (samKind != SamKind.INTERFACE) {
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
   229
            //sam type must be an interface
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
   230
            return false;
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
   231
        } else if (samMeth == MethodKind.NONE) {
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
   232
            //interface must have at least a method
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
   233
            return false;
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
   234
        } else if (exprKind == ExprKind.LAMBDA &&
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
   235
                samMeth != MethodKind.NON_GENERIC) {
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
   236
            //target method for lambda must be non-generic
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
   237
            return false;
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
   238
        } else if (exprKind == ExprKind.MREF &&
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
   239
                clientMeth == MethodKind.NONE) {
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
   240
            return false;
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
   241
        } else if (samPkg != PackageKind.NO_PKG &&
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
   242
                modKind != ModifierKind.PUBLIC &&
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
   243
                (retType == TypeKind.PKG_CLASS ||
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
   244
                argType == TypeKind.PKG_CLASS ||
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
   245
                thrownType == TypeKind.PKG_CLASS)) {
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
   246
            //target must not contain inaccessible types
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
   247
            return false;
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
   248
        } else {
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
   249
            return true;
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
   250
        }
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
   251
    }
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
   252
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
   253
    abstract class SourceFile extends SimpleJavaFileObject {
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
   254
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
   255
        protected String template;
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
   256
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
   257
        public SourceFile(String filename, String template) {
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
   258
            super(URI.create("myfo:/" + filename), JavaFileObject.Kind.SOURCE);
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
   259
            this.template = template;
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
   260
        }
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
   261
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
   262
        @Override
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
   263
        public CharSequence getCharContent(boolean ignoreEncodingErrors) {
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
   264
            return toString();
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
   265
        }
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
   266
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
   267
        public abstract String toString();
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
   268
    }
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
   269
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
   270
    static class DiagnosticChecker implements javax.tools.DiagnosticListener<JavaFileObject> {
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
   271
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
   272
        boolean errorFound = false;
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
   273
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
   274
        public void report(Diagnostic<? extends JavaFileObject> diagnostic) {
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
   275
            if (diagnostic.getKind() == Diagnostic.Kind.ERROR) {
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
   276
                errorFound = true;
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
   277
            }
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
   278
        }
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
   279
    }
46aa71a5e4e0 8004102: Add support for generic functional descriptors
mcimadamore
parents:
diff changeset
   280
}