author | psandoz |
Mon, 25 Nov 2013 09:55:34 +0100 | |
changeset 21846 | c10feb34bc0b |
parent 14545 | 2e7bab0639b8 |
child 27319 | 030080f03e4f |
permissions | -rw-r--r-- |
14447
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
1 |
/* |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
2 |
* Copyright (c) 2010, 2012, Oracle and/or its affiliates. All rights reserved. |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
3 |
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
4 |
* |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
5 |
* This code is free software; you can redistribute it and/or modify it |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
6 |
* under the terms of the GNU General Public License version 2 only, as |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
7 |
* published by the Free Software Foundation. |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
8 |
* |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
9 |
* This code is distributed in the hope that it will be useful, but WITHOUT |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
10 |
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
11 |
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
12 |
* version 2 for more details (a copy is included in the LICENSE file that |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
13 |
* accompanied this code). |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
14 |
* |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
15 |
* You should have received a copy of the GNU General Public License version |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
16 |
* 2 along with this work; if not, write to the Free Software Foundation, |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
17 |
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
18 |
* |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
19 |
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
20 |
* or visit www.oracle.com if you need additional information or have any |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
21 |
* questions. |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
22 |
*/ |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
23 |
|
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
24 |
/* |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
25 |
* @test |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
26 |
* @bug 8000612 |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
27 |
* @summary need test program to validate javadoc resource bundles |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
28 |
*/ |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
29 |
|
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
30 |
import java.io.*; |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
31 |
import java.util.*; |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
32 |
import javax.tools.*; |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
33 |
import com.sun.tools.classfile.*; |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
34 |
|
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
35 |
/** |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
36 |
* Compare string constants in javadoc classes against keys in javadoc resource bundles. |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
37 |
*/ |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
38 |
public class CheckResourceKeys { |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
39 |
/** |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
40 |
* Main program. |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
41 |
* Options: |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
42 |
* -finddeadkeys |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
43 |
* look for keys in resource bundles that are no longer required |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
44 |
* -findmissingkeys |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
45 |
* look for keys in resource bundles that are missing |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
46 |
* |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
47 |
* @throws Exception if invoked by jtreg and errors occur |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
48 |
*/ |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
49 |
public static void main(String... args) throws Exception { |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
50 |
CheckResourceKeys c = new CheckResourceKeys(); |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
51 |
if (c.run(args)) |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
52 |
return; |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
53 |
|
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
54 |
if (is_jtreg()) |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
55 |
throw new Exception(c.errors + " errors occurred"); |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
56 |
else |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
57 |
System.exit(1); |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
58 |
} |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
59 |
|
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
60 |
static boolean is_jtreg() { |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
61 |
return (System.getProperty("test.src") != null); |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
62 |
} |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
63 |
|
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
64 |
/** |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
65 |
* Main entry point. |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
66 |
*/ |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
67 |
boolean run(String... args) throws Exception { |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
68 |
boolean findDeadKeys = false; |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
69 |
boolean findMissingKeys = false; |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
70 |
|
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
71 |
if (args.length == 0) { |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
72 |
if (is_jtreg()) { |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
73 |
findDeadKeys = true; |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
74 |
findMissingKeys = true; |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
75 |
} else { |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
76 |
System.err.println("Usage: java CheckResourceKeys <options>"); |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
77 |
System.err.println("where options include"); |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
78 |
System.err.println(" -finddeadkeys find keys in resource bundles which are no longer required"); |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
79 |
System.err.println(" -findmissingkeys find keys in resource bundles that are required but missing"); |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
80 |
return true; |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
81 |
} |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
82 |
} else { |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
83 |
for (String arg: args) { |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
84 |
if (arg.equalsIgnoreCase("-finddeadkeys")) |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
85 |
findDeadKeys = true; |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
86 |
else if (arg.equalsIgnoreCase("-findmissingkeys")) |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
87 |
findMissingKeys = true; |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
88 |
else |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
89 |
error("bad option: " + arg); |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
90 |
} |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
91 |
} |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
92 |
|
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
93 |
if (errors > 0) |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
94 |
return false; |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
95 |
|
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
96 |
Set<String> codeKeys = getCodeKeys(); |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
97 |
Set<String> resourceKeys = getResourceKeys(); |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
98 |
|
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
99 |
System.err.println("found " + codeKeys.size() + " keys in code"); |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
100 |
System.err.println("found " + resourceKeys.size() + " keys in resource bundles"); |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
101 |
|
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
102 |
if (findDeadKeys) |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
103 |
findDeadKeys(codeKeys, resourceKeys); |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
104 |
|
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
105 |
if (findMissingKeys) |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
106 |
findMissingKeys(codeKeys, resourceKeys); |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
107 |
|
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
108 |
return (errors == 0); |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
109 |
} |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
110 |
|
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
111 |
/** |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
112 |
* Find keys in resource bundles which are probably no longer required. |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
113 |
* A key is required if there is a string in the code that is a resource key, |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
114 |
* or if the key is well-known according to various pragmatic rules. |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
115 |
*/ |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
116 |
void findDeadKeys(Set<String> codeKeys, Set<String> resourceKeys) { |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
117 |
for (String rk: resourceKeys) { |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
118 |
if (codeKeys.contains(rk)) |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
119 |
continue; |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
120 |
|
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
121 |
error("Resource key not found in code: " + rk); |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
122 |
} |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
123 |
} |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
124 |
|
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
125 |
/** |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
126 |
* For all strings in the code that look like they might be |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
127 |
* a resource key, verify that a key exists. |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
128 |
*/ |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
129 |
void findMissingKeys(Set<String> codeKeys, Set<String> resourceKeys) { |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
130 |
for (String ck: codeKeys) { |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
131 |
if (resourceKeys.contains(ck)) |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
132 |
continue; |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
133 |
error("No resource for \"" + ck + "\""); |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
134 |
} |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
135 |
} |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
136 |
|
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
137 |
/** |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
138 |
* Get the set of strings from (most of) the javadoc classfiles. |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
139 |
*/ |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
140 |
Set<String> getCodeKeys() throws IOException { |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
141 |
Set<String> results = new TreeSet<String>(); |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
142 |
JavaCompiler c = ToolProvider.getSystemJavaCompiler(); |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
143 |
JavaFileManager fm = c.getStandardFileManager(null, null, null); |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
144 |
JavaFileManager.Location javadocLoc = findJavadocLocation(fm); |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
145 |
String[] pkgs = { |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
146 |
"com.sun.tools.doclets", |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
147 |
"com.sun.tools.javadoc" |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
148 |
}; |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
149 |
for (String pkg: pkgs) { |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
150 |
for (JavaFileObject fo: fm.list(javadocLoc, |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
151 |
pkg, EnumSet.of(JavaFileObject.Kind.CLASS), true)) { |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
152 |
String name = fo.getName(); |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
153 |
// ignore resource files |
14452 | 154 |
if (name.matches(".*resources.[A-Za-z_0-9]+\\.class.*")) |
14447
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
155 |
continue; |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
156 |
scan(fo, results); |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
157 |
} |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
158 |
} |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
159 |
|
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
160 |
// special handling for code strings synthesized in |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
161 |
// com.sun.tools.doclets.internal.toolkit.util.Util.getTypeName |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
162 |
String[] extras = { |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
163 |
"AnnotationType", "Class", "Enum", "Error", "Exception", "Interface" |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
164 |
}; |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
165 |
for (String s: extras) { |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
166 |
if (results.contains("doclet." + s)) |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
167 |
results.add("doclet." + s.toLowerCase()); |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
168 |
} |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
169 |
|
14545
2e7bab0639b8
6493690: javadoc should have a javax.tools.Tool service provider installed in tools.jar
jjg
parents:
14452
diff
changeset
|
170 |
// special handling for code strings synthesized in |
2e7bab0639b8
6493690: javadoc should have a javax.tools.Tool service provider installed in tools.jar
jjg
parents:
14452
diff
changeset
|
171 |
// com.sun.tools.javadoc.Messager |
2e7bab0639b8
6493690: javadoc should have a javax.tools.Tool service provider installed in tools.jar
jjg
parents:
14452
diff
changeset
|
172 |
results.add("javadoc.error.msg"); |
2e7bab0639b8
6493690: javadoc should have a javax.tools.Tool service provider installed in tools.jar
jjg
parents:
14452
diff
changeset
|
173 |
results.add("javadoc.note.msg"); |
2e7bab0639b8
6493690: javadoc should have a javax.tools.Tool service provider installed in tools.jar
jjg
parents:
14452
diff
changeset
|
174 |
results.add("javadoc.note.pos.msg"); |
2e7bab0639b8
6493690: javadoc should have a javax.tools.Tool service provider installed in tools.jar
jjg
parents:
14452
diff
changeset
|
175 |
results.add("javadoc.warning.msg"); |
2e7bab0639b8
6493690: javadoc should have a javax.tools.Tool service provider installed in tools.jar
jjg
parents:
14452
diff
changeset
|
176 |
|
14447
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
177 |
return results; |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
178 |
} |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
179 |
|
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
180 |
// depending on how the test is run, javadoc may be on bootclasspath or classpath |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
181 |
JavaFileManager.Location findJavadocLocation(JavaFileManager fm) { |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
182 |
JavaFileManager.Location[] locns = |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
183 |
{ StandardLocation.PLATFORM_CLASS_PATH, StandardLocation.CLASS_PATH }; |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
184 |
try { |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
185 |
for (JavaFileManager.Location l: locns) { |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
186 |
JavaFileObject fo = fm.getJavaFileForInput(l, |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
187 |
"com.sun.tools.javadoc.Main", JavaFileObject.Kind.CLASS); |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
188 |
if (fo != null) { |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
189 |
System.err.println("found javadoc in " + l); |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
190 |
return l; |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
191 |
} |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
192 |
} |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
193 |
} catch (IOException e) { |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
194 |
throw new Error(e); |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
195 |
} |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
196 |
throw new IllegalStateException("Cannot find javadoc"); |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
197 |
} |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
198 |
|
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
199 |
/** |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
200 |
* Get the set of strings from a class file. |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
201 |
* Only strings that look like they might be a resource key are returned. |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
202 |
*/ |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
203 |
void scan(JavaFileObject fo, Set<String> results) throws IOException { |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
204 |
//System.err.println("scan " + fo.getName()); |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
205 |
InputStream in = fo.openInputStream(); |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
206 |
try { |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
207 |
ClassFile cf = ClassFile.read(in); |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
208 |
for (ConstantPool.CPInfo cpinfo: cf.constant_pool.entries()) { |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
209 |
if (cpinfo.getTag() == ConstantPool.CONSTANT_Utf8) { |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
210 |
String v = ((ConstantPool.CONSTANT_Utf8_info) cpinfo).value; |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
211 |
if (v.matches("(doclet|main|javadoc|tag)\\.[A-Za-z0-9-_.]+")) |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
212 |
results.add(v); |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
213 |
} |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
214 |
} |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
215 |
} catch (ConstantPoolException ignore) { |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
216 |
} finally { |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
217 |
in.close(); |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
218 |
} |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
219 |
} |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
220 |
|
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
221 |
/** |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
222 |
* Get the set of keys from the javadoc resource bundles. |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
223 |
*/ |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
224 |
Set<String> getResourceKeys() { |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
225 |
String[] names = { |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
226 |
"com.sun.tools.doclets.formats.html.resources.standard", |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
227 |
"com.sun.tools.doclets.internal.toolkit.resources.doclets", |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
228 |
"com.sun.tools.javadoc.resources.javadoc", |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
229 |
}; |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
230 |
Set<String> results = new TreeSet<String>(); |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
231 |
for (String name : names) { |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
232 |
ResourceBundle b = ResourceBundle.getBundle(name); |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
233 |
results.addAll(b.keySet()); |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
234 |
} |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
235 |
return results; |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
236 |
} |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
237 |
|
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
238 |
/** |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
239 |
* Report an error. |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
240 |
*/ |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
241 |
void error(String msg) { |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
242 |
System.err.println("Error: " + msg); |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
243 |
errors++; |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
244 |
} |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
245 |
|
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
246 |
int errors; |
6f87132c2e54
8000612: Discrepancy between resources provided in javadoc resource files and resources required by code
jjg
parents:
diff
changeset
|
247 |
} |