author | darcy |
Thu, 12 Jul 2018 14:13:15 -0700 | |
changeset 51047 | 860a3648c494 |
parent 51040 | e0bce2635ec5 |
child 51563 | de411d537aae |
permissions | -rw-r--r-- |
10 | 1 |
/* |
48776
107413b070b9
8194764: javac incorrectly flags deprecated for removal imports
jlahoda
parents:
48054
diff
changeset
|
2 |
* Copyright (c) 2002, 2018, Oracle and/or its affiliates. All rights reserved. |
10 | 3 |
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. |
4 |
* |
|
5 |
* This code is free software; you can redistribute it and/or modify it |
|
6 |
* under the terms of the GNU General Public License version 2 only, as |
|
5520 | 7 |
* published by the Free Software Foundation. Oracle designates this |
10 | 8 |
* particular file as subject to the "Classpath" exception as provided |
5520 | 9 |
* by Oracle in the LICENSE file that accompanied this code. |
10 | 10 |
* |
11 |
* This code is distributed in the hope that it will be useful, but WITHOUT |
|
12 |
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or |
|
13 |
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License |
|
14 |
* version 2 for more details (a copy is included in the LICENSE file that |
|
15 |
* accompanied this code). |
|
16 |
* |
|
17 |
* You should have received a copy of the GNU General Public License version |
|
18 |
* 2 along with this work; if not, write to the Free Software Foundation, |
|
19 |
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. |
|
20 |
* |
|
5520 | 21 |
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA |
22 |
* or visit www.oracle.com if you need additional information or have any |
|
23 |
* questions. |
|
10 | 24 |
*/ |
25 |
||
26 |
package com.sun.tools.javac.code; |
|
27 |
||
6721 | 28 |
import java.util.*; |
14258 | 29 |
|
6721 | 30 |
import javax.lang.model.SourceVersion; |
31 |
import static javax.lang.model.SourceVersion.*; |
|
32 |
||
14258 | 33 |
import com.sun.tools.javac.jvm.Target; |
48054
702043a4cdeb
8189749: Devise strategy for making source level checks more uniform
mcimadamore
parents:
47268
diff
changeset
|
34 |
import com.sun.tools.javac.resources.CompilerProperties.Errors; |
702043a4cdeb
8189749: Devise strategy for making source level checks more uniform
mcimadamore
parents:
47268
diff
changeset
|
35 |
import com.sun.tools.javac.resources.CompilerProperties.Fragments; |
10 | 36 |
import com.sun.tools.javac.util.*; |
48054
702043a4cdeb
8189749: Devise strategy for making source level checks more uniform
mcimadamore
parents:
47268
diff
changeset
|
37 |
import com.sun.tools.javac.util.JCDiagnostic.Error; |
702043a4cdeb
8189749: Devise strategy for making source level checks more uniform
mcimadamore
parents:
47268
diff
changeset
|
38 |
import com.sun.tools.javac.util.JCDiagnostic.Fragment; |
702043a4cdeb
8189749: Devise strategy for making source level checks more uniform
mcimadamore
parents:
47268
diff
changeset
|
39 |
|
11314 | 40 |
import static com.sun.tools.javac.main.Option.*; |
10 | 41 |
|
42 |
/** The source language version accepted. |
|
43 |
* |
|
5847
1908176fd6e3
6944312: Potential rebranding issues in openjdk/langtools repository sources
jjg
parents:
5520
diff
changeset
|
44 |
* <p><b>This is NOT part of any supported API. |
1908176fd6e3
6944312: Potential rebranding issues in openjdk/langtools repository sources
jjg
parents:
5520
diff
changeset
|
45 |
* If you write code that depends on this, you do so at your own risk. |
10 | 46 |
* This code and its internal interfaces are subject to change or |
47 |
* deletion without notice.</b> |
|
48 |
*/ |
|
49 |
public enum Source { |
|
50 |
/** 1.0 had no inner classes, and so could not pass the JCK. */ |
|
51 |
// public static final Source JDK1_0 = new Source("1.0"); |
|
52 |
||
53 |
/** 1.1 did not have strictfp, and so could not pass the JCK. */ |
|
54 |
// public static final Source JDK1_1 = new Source("1.1"); |
|
55 |
||
56 |
/** 1.2 introduced strictfp. */ |
|
57 |
JDK1_2("1.2"), |
|
58 |
||
59 |
/** 1.3 is the same language as 1.2. */ |
|
60 |
JDK1_3("1.3"), |
|
61 |
||
62 |
/** 1.4 introduced assert. */ |
|
63 |
JDK1_4("1.4"), |
|
64 |
||
65 |
/** 1.5 introduced generics, attributes, foreach, boxing, static import, |
|
66 |
* covariant return, enums, varargs, et al. */ |
|
48054
702043a4cdeb
8189749: Devise strategy for making source level checks more uniform
mcimadamore
parents:
47268
diff
changeset
|
67 |
JDK5("5"), |
10 | 68 |
|
69 |
/** 1.6 reports encoding problems as errors instead of warnings. */ |
|
48054
702043a4cdeb
8189749: Devise strategy for making source level checks more uniform
mcimadamore
parents:
47268
diff
changeset
|
70 |
JDK6("6"), |
10 | 71 |
|
10180 | 72 |
/** 1.7 introduced try-with-resources, multi-catch, string switch, etc. */ |
48054
702043a4cdeb
8189749: Devise strategy for making source level checks more uniform
mcimadamore
parents:
47268
diff
changeset
|
73 |
JDK7("7"), |
10180 | 74 |
|
22151 | 75 |
/** 1.8 lambda expressions and default methods. */ |
48054
702043a4cdeb
8189749: Devise strategy for making source level checks more uniform
mcimadamore
parents:
47268
diff
changeset
|
76 |
JDK8("8"), |
22151 | 77 |
|
43646 | 78 |
/** 1.9 modularity. */ |
48054
702043a4cdeb
8189749: Devise strategy for making source level checks more uniform
mcimadamore
parents:
47268
diff
changeset
|
79 |
JDK9("9"), |
43646 | 80 |
|
48343 | 81 |
/** 1.10 local-variable type inference (var). */ |
82 |
JDK10("10"), |
|
83 |
||
50892 | 84 |
/** 1.11 local-variable syntax for lambda parameters */ |
85 |
JDK11("11"), |
|
86 |
||
87 |
/** 12 covers the to be determined language features that will be added in JDK 12. */ |
|
88 |
JDK12("12"); |
|
10 | 89 |
|
22163 | 90 |
private static final Context.Key<Source> sourceKey = new Context.Key<>(); |
10 | 91 |
|
92 |
public static Source instance(Context context) { |
|
93 |
Source instance = context.get(sourceKey); |
|
94 |
if (instance == null) { |
|
95 |
Options options = Options.instance(context); |
|
6721 | 96 |
String sourceString = options.get(SOURCE); |
10 | 97 |
if (sourceString != null) instance = lookup(sourceString); |
98 |
if (instance == null) instance = DEFAULT; |
|
99 |
context.put(sourceKey, instance); |
|
100 |
} |
|
101 |
return instance; |
|
102 |
} |
|
103 |
||
104 |
public final String name; |
|
105 |
||
22151 | 106 |
private static final Map<String,Source> tab = new HashMap<>(); |
10 | 107 |
static { |
108 |
for (Source s : values()) { |
|
109 |
tab.put(s.name, s); |
|
110 |
} |
|
48054
702043a4cdeb
8189749: Devise strategy for making source level checks more uniform
mcimadamore
parents:
47268
diff
changeset
|
111 |
tab.put("1.5", JDK5); // Make 5 an alias for 1.5 |
702043a4cdeb
8189749: Devise strategy for making source level checks more uniform
mcimadamore
parents:
47268
diff
changeset
|
112 |
tab.put("1.6", JDK6); // Make 6 an alias for 1.6 |
702043a4cdeb
8189749: Devise strategy for making source level checks more uniform
mcimadamore
parents:
47268
diff
changeset
|
113 |
tab.put("1.7", JDK7); // Make 7 an alias for 1.7 |
702043a4cdeb
8189749: Devise strategy for making source level checks more uniform
mcimadamore
parents:
47268
diff
changeset
|
114 |
tab.put("1.8", JDK8); // Make 8 an alias for 1.8 |
702043a4cdeb
8189749: Devise strategy for making source level checks more uniform
mcimadamore
parents:
47268
diff
changeset
|
115 |
tab.put("1.9", JDK9); // Make 9 an alias for 1.9 |
702043a4cdeb
8189749: Devise strategy for making source level checks more uniform
mcimadamore
parents:
47268
diff
changeset
|
116 |
tab.put("1.10", JDK10); // Make 10 an alias for 1.10 |
48343 | 117 |
// Decline to make 1.11 an alias for 11. |
10 | 118 |
} |
119 |
||
120 |
private Source(String name) { |
|
121 |
this.name = name; |
|
122 |
} |
|
123 |
||
51047
860a3648c494
8028563: Remove javac support for 6/1.6 source and target values
darcy
parents:
51040
diff
changeset
|
124 |
public static final Source MIN = Source.JDK7; |
25445
603f0c93d5c9
8011044: Remove support for 1.5 and earlier source and target options
ntoda
parents:
25283
diff
changeset
|
125 |
|
603f0c93d5c9
8011044: Remove support for 1.5 and earlier source and target options
ntoda
parents:
25283
diff
changeset
|
126 |
private static final Source MAX = values()[values().length - 1]; |
603f0c93d5c9
8011044: Remove support for 1.5 and earlier source and target options
ntoda
parents:
25283
diff
changeset
|
127 |
|
603f0c93d5c9
8011044: Remove support for 1.5 and earlier source and target options
ntoda
parents:
25283
diff
changeset
|
128 |
public static final Source DEFAULT = MAX; |
10 | 129 |
|
130 |
public static Source lookup(String name) { |
|
131 |
return tab.get(name); |
|
132 |
} |
|
133 |
||
51040
e0bce2635ec5
8207055: Make javac -help output for -source and -target more informative
darcy
parents:
50892
diff
changeset
|
134 |
public boolean isSupported() { |
e0bce2635ec5
8207055: Make javac -help output for -source and -target more informative
darcy
parents:
50892
diff
changeset
|
135 |
return this.compareTo(MIN) >= 0; |
e0bce2635ec5
8207055: Make javac -help output for -source and -target more informative
darcy
parents:
50892
diff
changeset
|
136 |
} |
e0bce2635ec5
8207055: Make javac -help output for -source and -target more informative
darcy
parents:
50892
diff
changeset
|
137 |
|
10 | 138 |
public Target requiredTarget() { |
50892 | 139 |
if (this.compareTo(JDK12) >= 0) return Target.JDK1_12; |
48343 | 140 |
if (this.compareTo(JDK11) >= 0) return Target.JDK1_11; |
48054
702043a4cdeb
8189749: Devise strategy for making source level checks more uniform
mcimadamore
parents:
47268
diff
changeset
|
141 |
if (this.compareTo(JDK10) >= 0) return Target.JDK1_10; |
702043a4cdeb
8189749: Devise strategy for making source level checks more uniform
mcimadamore
parents:
47268
diff
changeset
|
142 |
if (this.compareTo(JDK9) >= 0) return Target.JDK1_9; |
702043a4cdeb
8189749: Devise strategy for making source level checks more uniform
mcimadamore
parents:
47268
diff
changeset
|
143 |
if (this.compareTo(JDK8) >= 0) return Target.JDK1_8; |
702043a4cdeb
8189749: Devise strategy for making source level checks more uniform
mcimadamore
parents:
47268
diff
changeset
|
144 |
if (this.compareTo(JDK7) >= 0) return Target.JDK1_7; |
702043a4cdeb
8189749: Devise strategy for making source level checks more uniform
mcimadamore
parents:
47268
diff
changeset
|
145 |
if (this.compareTo(JDK6) >= 0) return Target.JDK1_6; |
702043a4cdeb
8189749: Devise strategy for making source level checks more uniform
mcimadamore
parents:
47268
diff
changeset
|
146 |
if (this.compareTo(JDK5) >= 0) return Target.JDK1_5; |
10 | 147 |
if (this.compareTo(JDK1_4) >= 0) return Target.JDK1_4; |
148 |
return Target.JDK1_1; |
|
149 |
} |
|
150 |
||
48054
702043a4cdeb
8189749: Devise strategy for making source level checks more uniform
mcimadamore
parents:
47268
diff
changeset
|
151 |
/** |
702043a4cdeb
8189749: Devise strategy for making source level checks more uniform
mcimadamore
parents:
47268
diff
changeset
|
152 |
* Models a feature of the Java programming language. Each feature can be associated with a |
702043a4cdeb
8189749: Devise strategy for making source level checks more uniform
mcimadamore
parents:
47268
diff
changeset
|
153 |
* minimum source level, a maximum source level and a diagnostic fragment describing the feature, |
702043a4cdeb
8189749: Devise strategy for making source level checks more uniform
mcimadamore
parents:
47268
diff
changeset
|
154 |
* which is used to generate error messages of the kind {@code feature XYZ not supported in source N}. |
702043a4cdeb
8189749: Devise strategy for making source level checks more uniform
mcimadamore
parents:
47268
diff
changeset
|
155 |
*/ |
702043a4cdeb
8189749: Devise strategy for making source level checks more uniform
mcimadamore
parents:
47268
diff
changeset
|
156 |
public enum Feature { |
702043a4cdeb
8189749: Devise strategy for making source level checks more uniform
mcimadamore
parents:
47268
diff
changeset
|
157 |
|
702043a4cdeb
8189749: Devise strategy for making source level checks more uniform
mcimadamore
parents:
47268
diff
changeset
|
158 |
DIAMOND(JDK7, Fragments.FeatureDiamond, DiagKind.NORMAL), |
702043a4cdeb
8189749: Devise strategy for making source level checks more uniform
mcimadamore
parents:
47268
diff
changeset
|
159 |
MODULES(JDK9, Fragments.FeatureModules, DiagKind.PLURAL), |
702043a4cdeb
8189749: Devise strategy for making source level checks more uniform
mcimadamore
parents:
47268
diff
changeset
|
160 |
EFFECTIVELY_FINAL_VARIABLES_IN_TRY_WITH_RESOURCES(JDK9, Fragments.FeatureVarInTryWithResources, DiagKind.PLURAL), |
48776
107413b070b9
8194764: javac incorrectly flags deprecated for removal imports
jlahoda
parents:
48054
diff
changeset
|
161 |
DEPRECATION_ON_IMPORT(MIN, JDK8), |
48054
702043a4cdeb
8189749: Devise strategy for making source level checks more uniform
mcimadamore
parents:
47268
diff
changeset
|
162 |
POLY(JDK8), |
702043a4cdeb
8189749: Devise strategy for making source level checks more uniform
mcimadamore
parents:
47268
diff
changeset
|
163 |
LAMBDA(JDK8, Fragments.FeatureLambda, DiagKind.PLURAL), |
702043a4cdeb
8189749: Devise strategy for making source level checks more uniform
mcimadamore
parents:
47268
diff
changeset
|
164 |
METHOD_REFERENCES(JDK8, Fragments.FeatureMethodReferences, DiagKind.PLURAL), |
702043a4cdeb
8189749: Devise strategy for making source level checks more uniform
mcimadamore
parents:
47268
diff
changeset
|
165 |
DEFAULT_METHODS(JDK8, Fragments.FeatureDefaultMethods, DiagKind.PLURAL), |
702043a4cdeb
8189749: Devise strategy for making source level checks more uniform
mcimadamore
parents:
47268
diff
changeset
|
166 |
STATIC_INTERFACE_METHODS(JDK8, Fragments.FeatureStaticIntfMethods, DiagKind.PLURAL), |
702043a4cdeb
8189749: Devise strategy for making source level checks more uniform
mcimadamore
parents:
47268
diff
changeset
|
167 |
STATIC_INTERFACE_METHODS_INVOKE(JDK8, Fragments.FeatureStaticIntfMethodInvoke, DiagKind.PLURAL), |
702043a4cdeb
8189749: Devise strategy for making source level checks more uniform
mcimadamore
parents:
47268
diff
changeset
|
168 |
STRICT_METHOD_CLASH_CHECK(JDK8), |
702043a4cdeb
8189749: Devise strategy for making source level checks more uniform
mcimadamore
parents:
47268
diff
changeset
|
169 |
EFFECTIVELY_FINAL_IN_INNER_CLASSES(JDK8), |
702043a4cdeb
8189749: Devise strategy for making source level checks more uniform
mcimadamore
parents:
47268
diff
changeset
|
170 |
TYPE_ANNOTATIONS(JDK8, Fragments.FeatureTypeAnnotations, DiagKind.PLURAL), |
702043a4cdeb
8189749: Devise strategy for making source level checks more uniform
mcimadamore
parents:
47268
diff
changeset
|
171 |
ANNOTATIONS_AFTER_TYPE_PARAMS(JDK8, Fragments.FeatureAnnotationsAfterTypeParams, DiagKind.PLURAL), |
702043a4cdeb
8189749: Devise strategy for making source level checks more uniform
mcimadamore
parents:
47268
diff
changeset
|
172 |
REPEATED_ANNOTATIONS(JDK8, Fragments.FeatureRepeatableAnnotations, DiagKind.PLURAL), |
702043a4cdeb
8189749: Devise strategy for making source level checks more uniform
mcimadamore
parents:
47268
diff
changeset
|
173 |
INTERSECTION_TYPES_IN_CAST(JDK8, Fragments.FeatureIntersectionTypesInCast, DiagKind.PLURAL), |
702043a4cdeb
8189749: Devise strategy for making source level checks more uniform
mcimadamore
parents:
47268
diff
changeset
|
174 |
GRAPH_INFERENCE(JDK8), |
702043a4cdeb
8189749: Devise strategy for making source level checks more uniform
mcimadamore
parents:
47268
diff
changeset
|
175 |
FUNCTIONAL_INTERFACE_MOST_SPECIFIC(JDK8), |
702043a4cdeb
8189749: Devise strategy for making source level checks more uniform
mcimadamore
parents:
47268
diff
changeset
|
176 |
POST_APPLICABILITY_VARARGS_ACCESS_CHECK(JDK8), |
702043a4cdeb
8189749: Devise strategy for making source level checks more uniform
mcimadamore
parents:
47268
diff
changeset
|
177 |
MAP_CAPTURES_TO_BOUNDS(MIN, JDK7), |
702043a4cdeb
8189749: Devise strategy for making source level checks more uniform
mcimadamore
parents:
47268
diff
changeset
|
178 |
PRIVATE_SAFE_VARARGS(JDK9), |
702043a4cdeb
8189749: Devise strategy for making source level checks more uniform
mcimadamore
parents:
47268
diff
changeset
|
179 |
DIAMOND_WITH_ANONYMOUS_CLASS_CREATION(JDK9, Fragments.FeatureDiamondAndAnonClass, DiagKind.NORMAL), |
702043a4cdeb
8189749: Devise strategy for making source level checks more uniform
mcimadamore
parents:
47268
diff
changeset
|
180 |
UNDERSCORE_IDENTIFIER(MIN, JDK8), |
702043a4cdeb
8189749: Devise strategy for making source level checks more uniform
mcimadamore
parents:
47268
diff
changeset
|
181 |
PRIVATE_INTERFACE_METHODS(JDK9, Fragments.FeaturePrivateIntfMethods, DiagKind.PLURAL), |
50539
7bf4f1b5e438
8193302: Javac AssertionError: typeSig ERROR on usage of @Generated
jlahoda
parents:
49580
diff
changeset
|
182 |
LOCAL_VARIABLE_TYPE_INFERENCE(JDK10), |
7bf4f1b5e438
8193302: Javac AssertionError: typeSig ERROR on usage of @Generated
jlahoda
parents:
49580
diff
changeset
|
183 |
IMPORT_ON_DEMAND_OBSERVABLE_PACKAGES(JDK1_2, JDK8); |
48054
702043a4cdeb
8189749: Devise strategy for making source level checks more uniform
mcimadamore
parents:
47268
diff
changeset
|
184 |
|
702043a4cdeb
8189749: Devise strategy for making source level checks more uniform
mcimadamore
parents:
47268
diff
changeset
|
185 |
enum DiagKind { |
702043a4cdeb
8189749: Devise strategy for making source level checks more uniform
mcimadamore
parents:
47268
diff
changeset
|
186 |
NORMAL, |
702043a4cdeb
8189749: Devise strategy for making source level checks more uniform
mcimadamore
parents:
47268
diff
changeset
|
187 |
PLURAL; |
702043a4cdeb
8189749: Devise strategy for making source level checks more uniform
mcimadamore
parents:
47268
diff
changeset
|
188 |
} |
702043a4cdeb
8189749: Devise strategy for making source level checks more uniform
mcimadamore
parents:
47268
diff
changeset
|
189 |
|
702043a4cdeb
8189749: Devise strategy for making source level checks more uniform
mcimadamore
parents:
47268
diff
changeset
|
190 |
private final Source minLevel; |
702043a4cdeb
8189749: Devise strategy for making source level checks more uniform
mcimadamore
parents:
47268
diff
changeset
|
191 |
private final Source maxLevel; |
702043a4cdeb
8189749: Devise strategy for making source level checks more uniform
mcimadamore
parents:
47268
diff
changeset
|
192 |
private final Fragment optFragment; |
702043a4cdeb
8189749: Devise strategy for making source level checks more uniform
mcimadamore
parents:
47268
diff
changeset
|
193 |
private final DiagKind optKind; |
702043a4cdeb
8189749: Devise strategy for making source level checks more uniform
mcimadamore
parents:
47268
diff
changeset
|
194 |
|
702043a4cdeb
8189749: Devise strategy for making source level checks more uniform
mcimadamore
parents:
47268
diff
changeset
|
195 |
Feature(Source minLevel) { |
702043a4cdeb
8189749: Devise strategy for making source level checks more uniform
mcimadamore
parents:
47268
diff
changeset
|
196 |
this(minLevel, null, null); |
702043a4cdeb
8189749: Devise strategy for making source level checks more uniform
mcimadamore
parents:
47268
diff
changeset
|
197 |
} |
702043a4cdeb
8189749: Devise strategy for making source level checks more uniform
mcimadamore
parents:
47268
diff
changeset
|
198 |
|
702043a4cdeb
8189749: Devise strategy for making source level checks more uniform
mcimadamore
parents:
47268
diff
changeset
|
199 |
Feature(Source minLevel, Fragment optFragment, DiagKind optKind) { |
702043a4cdeb
8189749: Devise strategy for making source level checks more uniform
mcimadamore
parents:
47268
diff
changeset
|
200 |
this(minLevel, MAX, optFragment, optKind); |
702043a4cdeb
8189749: Devise strategy for making source level checks more uniform
mcimadamore
parents:
47268
diff
changeset
|
201 |
} |
702043a4cdeb
8189749: Devise strategy for making source level checks more uniform
mcimadamore
parents:
47268
diff
changeset
|
202 |
|
702043a4cdeb
8189749: Devise strategy for making source level checks more uniform
mcimadamore
parents:
47268
diff
changeset
|
203 |
Feature(Source minLevel, Source maxLevel) { |
702043a4cdeb
8189749: Devise strategy for making source level checks more uniform
mcimadamore
parents:
47268
diff
changeset
|
204 |
this(minLevel, maxLevel, null, null); |
702043a4cdeb
8189749: Devise strategy for making source level checks more uniform
mcimadamore
parents:
47268
diff
changeset
|
205 |
} |
702043a4cdeb
8189749: Devise strategy for making source level checks more uniform
mcimadamore
parents:
47268
diff
changeset
|
206 |
|
702043a4cdeb
8189749: Devise strategy for making source level checks more uniform
mcimadamore
parents:
47268
diff
changeset
|
207 |
Feature(Source minLevel, Source maxLevel, Fragment optFragment, DiagKind optKind) { |
702043a4cdeb
8189749: Devise strategy for making source level checks more uniform
mcimadamore
parents:
47268
diff
changeset
|
208 |
this.minLevel = minLevel; |
702043a4cdeb
8189749: Devise strategy for making source level checks more uniform
mcimadamore
parents:
47268
diff
changeset
|
209 |
this.maxLevel = maxLevel; |
702043a4cdeb
8189749: Devise strategy for making source level checks more uniform
mcimadamore
parents:
47268
diff
changeset
|
210 |
this.optFragment = optFragment; |
702043a4cdeb
8189749: Devise strategy for making source level checks more uniform
mcimadamore
parents:
47268
diff
changeset
|
211 |
this.optKind = optKind; |
702043a4cdeb
8189749: Devise strategy for making source level checks more uniform
mcimadamore
parents:
47268
diff
changeset
|
212 |
} |
702043a4cdeb
8189749: Devise strategy for making source level checks more uniform
mcimadamore
parents:
47268
diff
changeset
|
213 |
|
702043a4cdeb
8189749: Devise strategy for making source level checks more uniform
mcimadamore
parents:
47268
diff
changeset
|
214 |
public boolean allowedInSource(Source source) { |
702043a4cdeb
8189749: Devise strategy for making source level checks more uniform
mcimadamore
parents:
47268
diff
changeset
|
215 |
return source.compareTo(minLevel) >= 0 && |
702043a4cdeb
8189749: Devise strategy for making source level checks more uniform
mcimadamore
parents:
47268
diff
changeset
|
216 |
source.compareTo(maxLevel) <= 0; |
702043a4cdeb
8189749: Devise strategy for making source level checks more uniform
mcimadamore
parents:
47268
diff
changeset
|
217 |
} |
702043a4cdeb
8189749: Devise strategy for making source level checks more uniform
mcimadamore
parents:
47268
diff
changeset
|
218 |
|
49580
62b908c9f0e6
8199194: Add javac support for preview features
mcimadamore
parents:
48780
diff
changeset
|
219 |
public boolean isPlural() { |
62b908c9f0e6
8199194: Add javac support for preview features
mcimadamore
parents:
48780
diff
changeset
|
220 |
Assert.checkNonNull(optKind); |
62b908c9f0e6
8199194: Add javac support for preview features
mcimadamore
parents:
48780
diff
changeset
|
221 |
return optKind == DiagKind.PLURAL; |
62b908c9f0e6
8199194: Add javac support for preview features
mcimadamore
parents:
48780
diff
changeset
|
222 |
} |
62b908c9f0e6
8199194: Add javac support for preview features
mcimadamore
parents:
48780
diff
changeset
|
223 |
|
62b908c9f0e6
8199194: Add javac support for preview features
mcimadamore
parents:
48780
diff
changeset
|
224 |
public Fragment nameFragment() { |
62b908c9f0e6
8199194: Add javac support for preview features
mcimadamore
parents:
48780
diff
changeset
|
225 |
Assert.checkNonNull(optFragment); |
62b908c9f0e6
8199194: Add javac support for preview features
mcimadamore
parents:
48780
diff
changeset
|
226 |
return optFragment; |
62b908c9f0e6
8199194: Add javac support for preview features
mcimadamore
parents:
48780
diff
changeset
|
227 |
} |
62b908c9f0e6
8199194: Add javac support for preview features
mcimadamore
parents:
48780
diff
changeset
|
228 |
|
48054
702043a4cdeb
8189749: Devise strategy for making source level checks more uniform
mcimadamore
parents:
47268
diff
changeset
|
229 |
public Fragment fragment(String sourceName) { |
702043a4cdeb
8189749: Devise strategy for making source level checks more uniform
mcimadamore
parents:
47268
diff
changeset
|
230 |
Assert.checkNonNull(optFragment); |
702043a4cdeb
8189749: Devise strategy for making source level checks more uniform
mcimadamore
parents:
47268
diff
changeset
|
231 |
return optKind == DiagKind.NORMAL ? |
702043a4cdeb
8189749: Devise strategy for making source level checks more uniform
mcimadamore
parents:
47268
diff
changeset
|
232 |
Fragments.FeatureNotSupportedInSource(optFragment, sourceName, minLevel.name) : |
702043a4cdeb
8189749: Devise strategy for making source level checks more uniform
mcimadamore
parents:
47268
diff
changeset
|
233 |
Fragments.FeatureNotSupportedInSourcePlural(optFragment, sourceName, minLevel.name); |
702043a4cdeb
8189749: Devise strategy for making source level checks more uniform
mcimadamore
parents:
47268
diff
changeset
|
234 |
} |
702043a4cdeb
8189749: Devise strategy for making source level checks more uniform
mcimadamore
parents:
47268
diff
changeset
|
235 |
|
702043a4cdeb
8189749: Devise strategy for making source level checks more uniform
mcimadamore
parents:
47268
diff
changeset
|
236 |
public Error error(String sourceName) { |
702043a4cdeb
8189749: Devise strategy for making source level checks more uniform
mcimadamore
parents:
47268
diff
changeset
|
237 |
Assert.checkNonNull(optFragment); |
702043a4cdeb
8189749: Devise strategy for making source level checks more uniform
mcimadamore
parents:
47268
diff
changeset
|
238 |
return optKind == DiagKind.NORMAL ? |
702043a4cdeb
8189749: Devise strategy for making source level checks more uniform
mcimadamore
parents:
47268
diff
changeset
|
239 |
Errors.FeatureNotSupportedInSource(optFragment, sourceName, minLevel.name) : |
702043a4cdeb
8189749: Devise strategy for making source level checks more uniform
mcimadamore
parents:
47268
diff
changeset
|
240 |
Errors.FeatureNotSupportedInSourcePlural(optFragment, sourceName, minLevel.name); |
702043a4cdeb
8189749: Devise strategy for making source level checks more uniform
mcimadamore
parents:
47268
diff
changeset
|
241 |
} |
11143
9dbe313bfb74
7115050: Add parser support for lambda expressions
mcimadamore
parents:
10180
diff
changeset
|
242 |
} |
48054
702043a4cdeb
8189749: Devise strategy for making source level checks more uniform
mcimadamore
parents:
47268
diff
changeset
|
243 |
|
10 | 244 |
public static SourceVersion toSourceVersion(Source source) { |
245 |
switch(source) { |
|
246 |
case JDK1_2: |
|
247 |
return RELEASE_2; |
|
248 |
case JDK1_3: |
|
249 |
return RELEASE_3; |
|
250 |
case JDK1_4: |
|
251 |
return RELEASE_4; |
|
48054
702043a4cdeb
8189749: Devise strategy for making source level checks more uniform
mcimadamore
parents:
47268
diff
changeset
|
252 |
case JDK5: |
10 | 253 |
return RELEASE_5; |
48054
702043a4cdeb
8189749: Devise strategy for making source level checks more uniform
mcimadamore
parents:
47268
diff
changeset
|
254 |
case JDK6: |
10 | 255 |
return RELEASE_6; |
48054
702043a4cdeb
8189749: Devise strategy for making source level checks more uniform
mcimadamore
parents:
47268
diff
changeset
|
256 |
case JDK7: |
10 | 257 |
return RELEASE_7; |
48054
702043a4cdeb
8189749: Devise strategy for making source level checks more uniform
mcimadamore
parents:
47268
diff
changeset
|
258 |
case JDK8: |
10180 | 259 |
return RELEASE_8; |
48054
702043a4cdeb
8189749: Devise strategy for making source level checks more uniform
mcimadamore
parents:
47268
diff
changeset
|
260 |
case JDK9: |
22170
62da5257a0a7
8031360: Update langtools code base to use RELEASE_9
darcy
parents:
22167
diff
changeset
|
261 |
return RELEASE_9; |
48054
702043a4cdeb
8189749: Devise strategy for making source level checks more uniform
mcimadamore
parents:
47268
diff
changeset
|
262 |
case JDK10: |
43646 | 263 |
return RELEASE_10; |
48343 | 264 |
case JDK11: |
265 |
return RELEASE_11; |
|
50892 | 266 |
case JDK12: |
267 |
return RELEASE_12; |
|
10 | 268 |
default: |
269 |
return null; |
|
270 |
} |
|
271 |
} |
|
272 |
} |