|
Lines 66-73
Link Here
|
| 66 |
*/ |
66 |
*/ |
| 67 |
protected ICleanUpFix createFix(CompilationUnit compilationUnit) throws CoreException { |
67 |
protected ICleanUpFix createFix(CompilationUnit compilationUnit) throws CoreException { |
| 68 |
boolean addAnotations= isEnabled(CleanUpConstants.ADD_MISSING_ANNOTATIONS); |
68 |
boolean addAnotations= isEnabled(CleanUpConstants.ADD_MISSING_ANNOTATIONS); |
|
|
69 |
boolean addOverride= isEnabled(CleanUpConstants.ADD_MISSING_ANNOTATIONS_OVERRIDE); |
| 69 |
return Java50Fix.createCleanUp(compilationUnit, |
70 |
return Java50Fix.createCleanUp(compilationUnit, |
| 70 |
addAnotations && isEnabled(CleanUpConstants.ADD_MISSING_ANNOTATIONS_OVERRIDE), |
71 |
addAnotations && addOverride, |
|
|
72 |
addAnotations && addOverride && isEnabled(CleanUpConstants.ADD_MISSING_ANNOTATIONS_OVERRIDE_FOR_INTERFACE_METHOD_IMPLEMENTATION), |
| 71 |
addAnotations && isEnabled(CleanUpConstants.ADD_MISSING_ANNOTATIONS_DEPRECATED), |
73 |
addAnotations && isEnabled(CleanUpConstants.ADD_MISSING_ANNOTATIONS_DEPRECATED), |
| 72 |
isEnabled(CleanUpConstants.VARIABLE_DECLARATION_USE_TYPE_ARGUMENTS_FOR_RAW_TYPE_REFERENCES)); |
74 |
isEnabled(CleanUpConstants.VARIABLE_DECLARATION_USE_TYPE_ARGUMENTS_FOR_RAW_TYPE_REFERENCES)); |
| 73 |
} |
75 |
} |
|
Lines 79-94
Link Here
|
| 79 |
if (compilationUnit == null) |
81 |
if (compilationUnit == null) |
| 80 |
return null; |
82 |
return null; |
| 81 |
|
83 |
|
|
|
84 |
boolean addAnnotations= isEnabled(CleanUpConstants.ADD_MISSING_ANNOTATIONS); |
| 85 |
boolean addOverride= isEnabled(CleanUpConstants.ADD_MISSING_ANNOTATIONS_OVERRIDE); |
| 82 |
return Java50Fix.createCleanUp(compilationUnit, problems, |
86 |
return Java50Fix.createCleanUp(compilationUnit, problems, |
| 83 |
isEnabled(CleanUpConstants.ADD_MISSING_ANNOTATIONS) && isEnabled(CleanUpConstants.ADD_MISSING_ANNOTATIONS_OVERRIDE), |
87 |
addAnnotations && addOverride, |
| 84 |
isEnabled(CleanUpConstants.ADD_MISSING_ANNOTATIONS) && isEnabled(CleanUpConstants.ADD_MISSING_ANNOTATIONS_DEPRECATED), |
88 |
addAnnotations && addOverride && isEnabled(CleanUpConstants.ADD_MISSING_ANNOTATIONS_OVERRIDE_FOR_INTERFACE_METHOD_IMPLEMENTATION), |
|
|
89 |
addAnnotations && isEnabled(CleanUpConstants.ADD_MISSING_ANNOTATIONS_DEPRECATED), |
| 85 |
isEnabled(CleanUpConstants.VARIABLE_DECLARATION_USE_TYPE_ARGUMENTS_FOR_RAW_TYPE_REFERENCES)); |
90 |
isEnabled(CleanUpConstants.VARIABLE_DECLARATION_USE_TYPE_ARGUMENTS_FOR_RAW_TYPE_REFERENCES)); |
| 86 |
} |
91 |
} |
| 87 |
|
92 |
|
| 88 |
private Map getRequiredOptions() { |
93 |
private Map getRequiredOptions() { |
| 89 |
Map result= new Hashtable(); |
94 |
Map result= new Hashtable(); |
| 90 |
if (isEnabled(CleanUpConstants.ADD_MISSING_ANNOTATIONS) && isEnabled(CleanUpConstants.ADD_MISSING_ANNOTATIONS_OVERRIDE)) |
95 |
if (isEnabled(CleanUpConstants.ADD_MISSING_ANNOTATIONS) && isEnabled(CleanUpConstants.ADD_MISSING_ANNOTATIONS_OVERRIDE)) { |
| 91 |
result.put(JavaCore.COMPILER_PB_MISSING_OVERRIDE_ANNOTATION, JavaCore.WARNING); |
96 |
result.put(JavaCore.COMPILER_PB_MISSING_OVERRIDE_ANNOTATION, JavaCore.WARNING); |
|
|
97 |
if (isEnabled(CleanUpConstants.ADD_MISSING_ANNOTATIONS_OVERRIDE_FOR_INTERFACE_METHOD_IMPLEMENTATION)) { |
| 98 |
result.put(JavaCore.COMPILER_PB_MISSING_OVERRIDE_ANNOTATION_FOR_INTERFACE_METHOD_IMPLEMENTATION, JavaCore.ENABLED); |
| 99 |
} |
| 100 |
} |
| 92 |
|
101 |
|
| 93 |
if (isEnabled(CleanUpConstants.ADD_MISSING_ANNOTATIONS) && isEnabled(CleanUpConstants.ADD_MISSING_ANNOTATIONS_DEPRECATED)) |
102 |
if (isEnabled(CleanUpConstants.ADD_MISSING_ANNOTATIONS) && isEnabled(CleanUpConstants.ADD_MISSING_ANNOTATIONS_DEPRECATED)) |
| 94 |
result.put(JavaCore.COMPILER_PB_MISSING_DEPRECATED_ANNOTATION, JavaCore.WARNING); |
103 |
result.put(JavaCore.COMPILER_PB_MISSING_DEPRECATED_ANNOTATION, JavaCore.WARNING); |
|
Lines 104-111
Link Here
|
| 104 |
*/ |
113 |
*/ |
| 105 |
public String[] getStepDescriptions() { |
114 |
public String[] getStepDescriptions() { |
| 106 |
List result= new ArrayList(); |
115 |
List result= new ArrayList(); |
| 107 |
if (isEnabled(CleanUpConstants.ADD_MISSING_ANNOTATIONS) && isEnabled(CleanUpConstants.ADD_MISSING_ANNOTATIONS_OVERRIDE)) |
116 |
if (isEnabled(CleanUpConstants.ADD_MISSING_ANNOTATIONS) && isEnabled(CleanUpConstants.ADD_MISSING_ANNOTATIONS_OVERRIDE)) { |
| 108 |
result.add(MultiFixMessages.Java50MultiFix_AddMissingOverride_description); |
117 |
result.add(MultiFixMessages.Java50MultiFix_AddMissingOverride_description); |
|
|
118 |
if (isEnabled(CleanUpConstants.ADD_MISSING_ANNOTATIONS_OVERRIDE_FOR_INTERFACE_METHOD_IMPLEMENTATION)) { |
| 119 |
result.add("Add missing '@Override' annotations to implementations of interface methods"); |
| 120 |
} |
| 121 |
} |
| 109 |
if (isEnabled(CleanUpConstants.ADD_MISSING_ANNOTATIONS) && isEnabled(CleanUpConstants.ADD_MISSING_ANNOTATIONS_DEPRECATED)) |
122 |
if (isEnabled(CleanUpConstants.ADD_MISSING_ANNOTATIONS) && isEnabled(CleanUpConstants.ADD_MISSING_ANNOTATIONS_DEPRECATED)) |
| 110 |
result.add(MultiFixMessages.Java50MultiFix_AddMissingDeprecated_description); |
123 |
result.add(MultiFixMessages.Java50MultiFix_AddMissingDeprecated_description); |
| 111 |
if (isEnabled(CleanUpConstants.VARIABLE_DECLARATION_USE_TYPE_ARGUMENTS_FOR_RAW_TYPE_REFERENCES)) |
124 |
if (isEnabled(CleanUpConstants.VARIABLE_DECLARATION_USE_TYPE_ARGUMENTS_FOR_RAW_TYPE_REFERENCES)) |
|
Lines 128-138
Link Here
|
| 128 |
} |
141 |
} |
| 129 |
buf.append(" public void foo() {}\n"); //$NON-NLS-1$ |
142 |
buf.append(" public void foo() {}\n"); //$NON-NLS-1$ |
| 130 |
buf.append("}\n"); //$NON-NLS-1$ |
143 |
buf.append("}\n"); //$NON-NLS-1$ |
| 131 |
buf.append("class ESub extends E {\n"); //$NON-NLS-1$ |
144 |
buf.append("class ESub extends E implements Runnable {\n"); //$NON-NLS-1$ |
| 132 |
if (isEnabled(CleanUpConstants.ADD_MISSING_ANNOTATIONS) && isEnabled(CleanUpConstants.ADD_MISSING_ANNOTATIONS_OVERRIDE)) { |
145 |
if (isEnabled(CleanUpConstants.ADD_MISSING_ANNOTATIONS) && isEnabled(CleanUpConstants.ADD_MISSING_ANNOTATIONS_OVERRIDE)) { |
| 133 |
buf.append(" @Override\n"); //$NON-NLS-1$ |
146 |
buf.append(" @Override\n"); //$NON-NLS-1$ |
| 134 |
} |
147 |
} |
| 135 |
buf.append(" public void foo() {}\n"); //$NON-NLS-1$ |
148 |
buf.append(" public void foo() {}\n"); //$NON-NLS-1$ |
|
|
149 |
if (isEnabled(CleanUpConstants.ADD_MISSING_ANNOTATIONS) |
| 150 |
&& isEnabled(CleanUpConstants.ADD_MISSING_ANNOTATIONS_OVERRIDE) |
| 151 |
&& isEnabled(CleanUpConstants.ADD_MISSING_ANNOTATIONS_OVERRIDE_FOR_INTERFACE_METHOD_IMPLEMENTATION)) { |
| 152 |
buf.append(" @Override\n"); //$NON-NLS-1$ |
| 153 |
} |
| 154 |
buf.append(" public void run() {}\n"); //$NON-NLS-1$ |
| 136 |
buf.append("}\n"); //$NON-NLS-1$ |
155 |
buf.append("}\n"); //$NON-NLS-1$ |
| 137 |
|
156 |
|
| 138 |
return buf.toString(); |
157 |
return buf.toString(); |
|
Lines 144-157
Link Here
|
| 144 |
public boolean canFix(ICompilationUnit compilationUnit, IProblemLocation problem) { |
163 |
public boolean canFix(ICompilationUnit compilationUnit, IProblemLocation problem) { |
| 145 |
int id= problem.getProblemId(); |
164 |
int id= problem.getProblemId(); |
| 146 |
|
165 |
|
| 147 |
if (Java50Fix.isMissingOverrideAnnotationProblem(id)) |
166 |
if (Java50Fix.isMissingOverrideAnnotationProblem(id)) { |
| 148 |
return isEnabled(CleanUpConstants.ADD_MISSING_ANNOTATIONS) && isEnabled(CleanUpConstants.ADD_MISSING_ANNOTATIONS_OVERRIDE); |
167 |
if (isEnabled(CleanUpConstants.ADD_MISSING_ANNOTATIONS) && isEnabled(CleanUpConstants.ADD_MISSING_ANNOTATIONS_OVERRIDE)) { |
| 149 |
|
168 |
return ! Java50Fix.isMissingOverrideAnnotationInterfaceProblem(id) || isEnabled(CleanUpConstants.ADD_MISSING_ANNOTATIONS_OVERRIDE_FOR_INTERFACE_METHOD_IMPLEMENTATION); |
| 150 |
if (Java50Fix.isMissingDeprecationProblem(id)) |
169 |
} |
|
|
170 |
|
| 171 |
} else if (Java50Fix.isMissingDeprecationProblem(id)) { |
| 151 |
return isEnabled(CleanUpConstants.ADD_MISSING_ANNOTATIONS) && isEnabled(CleanUpConstants.ADD_MISSING_ANNOTATIONS_DEPRECATED); |
172 |
return isEnabled(CleanUpConstants.ADD_MISSING_ANNOTATIONS) && isEnabled(CleanUpConstants.ADD_MISSING_ANNOTATIONS_DEPRECATED); |
| 152 |
|
173 |
|
| 153 |
if (Java50Fix.isRawTypeReferenceProblem(id)) |
174 |
} else if (Java50Fix.isRawTypeReferenceProblem(id)) { |
| 154 |
return isEnabled(CleanUpConstants.VARIABLE_DECLARATION_USE_TYPE_ARGUMENTS_FOR_RAW_TYPE_REFERENCES); |
175 |
return isEnabled(CleanUpConstants.VARIABLE_DECLARATION_USE_TYPE_ARGUMENTS_FOR_RAW_TYPE_REFERENCES); |
|
|
176 |
} |
| 155 |
|
177 |
|
| 156 |
return false; |
178 |
return false; |
| 157 |
} |
179 |
} |
|
Lines 162-176
Link Here
|
| 162 |
public int computeNumberOfFixes(CompilationUnit compilationUnit) { |
184 |
public int computeNumberOfFixes(CompilationUnit compilationUnit) { |
| 163 |
int result= 0; |
185 |
int result= 0; |
| 164 |
|
186 |
|
| 165 |
boolean addMissingOverride= isEnabled(CleanUpConstants.ADD_MISSING_ANNOTATIONS) && isEnabled(CleanUpConstants.ADD_MISSING_ANNOTATIONS_OVERRIDE); |
187 |
boolean addAnnotations= isEnabled(CleanUpConstants.ADD_MISSING_ANNOTATIONS); |
| 166 |
boolean addMissingDeprecated= isEnabled(CleanUpConstants.ADD_MISSING_ANNOTATIONS) && isEnabled(CleanUpConstants.ADD_MISSING_ANNOTATIONS_DEPRECATED); |
188 |
boolean addMissingOverride= addAnnotations && isEnabled(CleanUpConstants.ADD_MISSING_ANNOTATIONS_OVERRIDE); |
|
|
189 |
boolean addMissingOverrideInterfaceMethods= addMissingOverride && isEnabled(CleanUpConstants.ADD_MISSING_ANNOTATIONS_OVERRIDE_FOR_INTERFACE_METHOD_IMPLEMENTATION); |
| 190 |
boolean addMissingDeprecated= addAnnotations && isEnabled(CleanUpConstants.ADD_MISSING_ANNOTATIONS_DEPRECATED); |
| 167 |
boolean useTypeArgs= isEnabled(CleanUpConstants.VARIABLE_DECLARATION_USE_TYPE_ARGUMENTS_FOR_RAW_TYPE_REFERENCES); |
191 |
boolean useTypeArgs= isEnabled(CleanUpConstants.VARIABLE_DECLARATION_USE_TYPE_ARGUMENTS_FOR_RAW_TYPE_REFERENCES); |
| 168 |
|
192 |
|
| 169 |
IProblem[] problems= compilationUnit.getProblems(); |
193 |
IProblem[] problems= compilationUnit.getProblems(); |
| 170 |
for (int i= 0; i < problems.length; i++) { |
194 |
for (int i= 0; i < problems.length; i++) { |
| 171 |
int id= problems[i].getID(); |
195 |
int id= problems[i].getID(); |
| 172 |
if (addMissingOverride && Java50Fix.isMissingOverrideAnnotationProblem(id)) |
196 |
if (addMissingOverride && Java50Fix.isMissingOverrideAnnotationProblem(id)) |
| 173 |
result++; |
197 |
if (! Java50Fix.isMissingOverrideAnnotationInterfaceProblem(id) || addMissingOverrideInterfaceMethods) |
|
|
198 |
result++; |
| 174 |
if (addMissingDeprecated && Java50Fix.isMissingDeprecationProblem(id)) |
199 |
if (addMissingDeprecated && Java50Fix.isMissingDeprecationProblem(id)) |
| 175 |
result++; |
200 |
result++; |
| 176 |
if (useTypeArgs && Java50Fix.isRawTypeReferenceProblem(id)) |
201 |
if (useTypeArgs && Java50Fix.isRawTypeReferenceProblem(id)) |