src/share/jaxws_classes/com/sun/xml/internal/ws/model/AbstractWrapperBeanGenerator.java

Thu, 31 Aug 2017 15:18:52 +0800

author
aoqi
date
Thu, 31 Aug 2017 15:18:52 +0800
changeset 637
9c07ef4934dd
parent 368
0989ad8c0860
parent 0
373ffda63c9a
permissions
-rw-r--r--

merge

aoqi@0 1 /*
aoqi@0 2 * Copyright (c) 1997, 2012, Oracle and/or its affiliates. All rights reserved.
aoqi@0 3 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
aoqi@0 4 *
aoqi@0 5 * This code is free software; you can redistribute it and/or modify it
aoqi@0 6 * under the terms of the GNU General Public License version 2 only, as
aoqi@0 7 * published by the Free Software Foundation. Oracle designates this
aoqi@0 8 * particular file as subject to the "Classpath" exception as provided
aoqi@0 9 * by Oracle in the LICENSE file that accompanied this code.
aoqi@0 10 *
aoqi@0 11 * This code is distributed in the hope that it will be useful, but WITHOUT
aoqi@0 12 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
aoqi@0 13 * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
aoqi@0 14 * version 2 for more details (a copy is included in the LICENSE file that
aoqi@0 15 * accompanied this code).
aoqi@0 16 *
aoqi@0 17 * You should have received a copy of the GNU General Public License version
aoqi@0 18 * 2 along with this work; if not, write to the Free Software Foundation,
aoqi@0 19 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
aoqi@0 20 *
aoqi@0 21 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
aoqi@0 22 * or visit www.oracle.com if you need additional information or have any
aoqi@0 23 * questions.
aoqi@0 24 */
aoqi@0 25
aoqi@0 26 package com.sun.xml.internal.ws.model;
aoqi@0 27
aoqi@0 28 import com.sun.istack.internal.NotNull;
aoqi@0 29 import com.sun.xml.internal.bind.v2.model.annotation.AnnotationReader;
aoqi@0 30 import com.sun.xml.internal.bind.v2.model.nav.Navigator;
aoqi@0 31 import com.sun.xml.internal.ws.spi.db.BindingHelper;
aoqi@0 32 import com.sun.xml.internal.ws.util.StringUtils;
aoqi@0 33
aoqi@0 34 import javax.jws.WebParam;
aoqi@0 35 import javax.jws.WebResult;
aoqi@0 36 import javax.xml.bind.annotation.*;
aoqi@0 37 import javax.xml.bind.annotation.adapters.XmlJavaTypeAdapter;
aoqi@0 38 import javax.xml.ws.WebServiceException;
aoqi@0 39 import java.lang.annotation.Annotation;
aoqi@0 40 import java.lang.reflect.InvocationHandler;
aoqi@0 41 import java.lang.reflect.Method;
aoqi@0 42 import java.lang.reflect.Proxy;
aoqi@0 43 import java.util.*;
aoqi@0 44 import java.util.logging.Logger;
aoqi@0 45
aoqi@0 46 /**
aoqi@0 47 * Finds request/response wrapper and exception bean memebers.
aoqi@0 48 *
aoqi@0 49 * <p>
aoqi@0 50 * It uses JAXB's {@link AnnotationReader}, {@link Navigator} so that
aoqi@0 51 * tools can use this with annotation processing, and the runtime can use this with
aoqi@0 52 * reflection.
aoqi@0 53 *
aoqi@0 54 * @author Jitendra Kotamraju
aoqi@0 55 */
aoqi@0 56 public abstract class AbstractWrapperBeanGenerator<T,C,M,A extends Comparable> {
aoqi@0 57
aoqi@0 58 private static final Logger LOGGER = Logger.getLogger(AbstractWrapperBeanGenerator.class.getName());
aoqi@0 59
aoqi@0 60 private static final String RETURN = "return";
aoqi@0 61 private static final String EMTPY_NAMESPACE_ID = "";
aoqi@0 62
aoqi@0 63 private static final Class[] jaxbAnns = new Class[] {
aoqi@0 64 XmlAttachmentRef.class, XmlMimeType.class, XmlJavaTypeAdapter.class,
aoqi@0 65 XmlList.class, XmlElement.class
aoqi@0 66 };
aoqi@0 67
aoqi@0 68 private static final Set<String> skipProperties = new HashSet<String>();
aoqi@0 69 static{
aoqi@0 70 skipProperties.add("getCause");
aoqi@0 71 skipProperties.add("getLocalizedMessage");
aoqi@0 72 skipProperties.add("getClass");
aoqi@0 73 skipProperties.add("getStackTrace");
aoqi@0 74 skipProperties.add("getSuppressed"); // JDK 7 adds this
aoqi@0 75 }
aoqi@0 76
aoqi@0 77 private final AnnotationReader<T,C,?,M> annReader;
aoqi@0 78 private final Navigator<T,C,?,M> nav;
aoqi@0 79 private final BeanMemberFactory<T,A> factory;
aoqi@0 80
aoqi@0 81 protected AbstractWrapperBeanGenerator(AnnotationReader<T,C,?,M> annReader,
aoqi@0 82 Navigator<T,C,?,M> nav, BeanMemberFactory<T,A> factory) {
aoqi@0 83 this.annReader = annReader;
aoqi@0 84 this.nav = nav;
aoqi@0 85 this.factory = factory;
aoqi@0 86 }
aoqi@0 87
aoqi@0 88 public static interface BeanMemberFactory<T,A> {
aoqi@0 89 A createWrapperBeanMember(T paramType, String paramName, List<Annotation> jaxbAnnotations);
aoqi@0 90 }
aoqi@0 91
aoqi@0 92 // Collects the JAXB annotations on a method
aoqi@0 93 private List<Annotation> collectJAXBAnnotations(M method) {
aoqi@0 94 List<Annotation> jaxbAnnotation = new ArrayList<Annotation>();
aoqi@0 95 for(Class jaxbClass : jaxbAnns) {
aoqi@0 96 Annotation ann = annReader.getMethodAnnotation(jaxbClass, method, null);
aoqi@0 97 if (ann != null) {
aoqi@0 98 jaxbAnnotation.add(ann);
aoqi@0 99 }
aoqi@0 100 }
aoqi@0 101 return jaxbAnnotation;
aoqi@0 102 }
aoqi@0 103
aoqi@0 104 // Collects the JAXB annotations on a parameter
aoqi@0 105 private List<Annotation> collectJAXBAnnotations(M method, int paramIndex) {
aoqi@0 106 List<Annotation> jaxbAnnotation = new ArrayList<Annotation>();
aoqi@0 107 for(Class jaxbClass : jaxbAnns) {
aoqi@0 108 Annotation ann = annReader.getMethodParameterAnnotation(jaxbClass, method, paramIndex, null);
aoqi@0 109 if (ann != null) {
aoqi@0 110 jaxbAnnotation.add(ann);
aoqi@0 111 }
aoqi@0 112 }
aoqi@0 113 return jaxbAnnotation;
aoqi@0 114 }
aoqi@0 115
aoqi@0 116 protected abstract T getSafeType(T type);
aoqi@0 117
aoqi@0 118 /**
aoqi@0 119 * Returns Holder's value type.
aoqi@0 120 *
aoqi@0 121 * @return null if it not a Holder, otherwise return Holder's value type
aoqi@0 122 */
aoqi@0 123 protected abstract T getHolderValueType(T type);
aoqi@0 124
aoqi@0 125 protected abstract boolean isVoidType(T type);
aoqi@0 126
aoqi@0 127 /**
aoqi@0 128 * Computes request bean members for a method. Collects all IN and INOUT
aoqi@0 129 * parameters as request bean fields. In this process, if a parameter
aoqi@0 130 * has any known JAXB annotations they are collected as well.
aoqi@0 131 * Special processing for @XmlElement annotation is done.
aoqi@0 132 *
aoqi@0 133 * @param method SEI method for which request bean members are computed
aoqi@0 134 * @return List of request bean members
aoqi@0 135 */
aoqi@0 136 public List<A> collectRequestBeanMembers(M method) {
aoqi@0 137
aoqi@0 138 List<A> requestMembers = new ArrayList<A>();
aoqi@0 139 int paramIndex = -1;
aoqi@0 140
aoqi@0 141 for (T param : nav.getMethodParameters(method)) {
aoqi@0 142 paramIndex++;
aoqi@0 143 WebParam webParam = annReader.getMethodParameterAnnotation(WebParam.class, method, paramIndex, null);
aoqi@0 144 if (webParam != null && (webParam.header() || webParam.mode().equals(WebParam.Mode.OUT))) {
aoqi@0 145 continue;
aoqi@0 146 }
aoqi@0 147 T holderType = getHolderValueType(param);
aoqi@0 148 // if (holderType != null && webParam != null && webParam.mode().equals(WebParam.Mode.IN)) {
aoqi@0 149 // // Should we flag an error - holder cannot be IN part ??
aoqi@0 150 // continue;
aoqi@0 151 // }
aoqi@0 152
aoqi@0 153 T paramType = (holderType != null) ? holderType : getSafeType(param);
aoqi@0 154 String paramName = (webParam != null && webParam.name().length() > 0)
aoqi@0 155 ? webParam.name() : "arg"+paramIndex;
aoqi@0 156 String paramNamespace = (webParam != null && webParam.targetNamespace().length() > 0)
aoqi@0 157 ? webParam.targetNamespace() : EMTPY_NAMESPACE_ID;
aoqi@0 158
aoqi@0 159 // Collect JAXB annotations on a parameter
aoqi@0 160 List<Annotation> jaxbAnnotation = collectJAXBAnnotations(method, paramIndex);
aoqi@0 161
aoqi@0 162 // If a parameter contains @XmlElement, process it.
aoqi@0 163 processXmlElement(jaxbAnnotation, paramName, paramNamespace, paramType);
aoqi@0 164 A member = factory.createWrapperBeanMember(paramType,
aoqi@0 165 getPropertyName(paramName), jaxbAnnotation);
aoqi@0 166 requestMembers.add(member);
aoqi@0 167 }
aoqi@0 168 return requestMembers;
aoqi@0 169 }
aoqi@0 170
aoqi@0 171 /**
aoqi@0 172 * Computes response bean members for a method. Collects all OUT and INOUT
aoqi@0 173 * parameters as response bean fields. In this process, if a parameter
aoqi@0 174 * has any known JAXB annotations they are collected as well.
aoqi@0 175 * Special processing for @XmlElement annotation is done.
aoqi@0 176 *
aoqi@0 177 * @param method SEI method for which response bean members are computed
aoqi@0 178 * @return List of response bean members
aoqi@0 179 */
aoqi@0 180 public List<A> collectResponseBeanMembers(M method) {
aoqi@0 181
aoqi@0 182 List<A> responseMembers = new ArrayList<A>();
aoqi@0 183
aoqi@0 184 // return that need to be part response wrapper bean
aoqi@0 185 String responseElementName = RETURN;
aoqi@0 186 String responseNamespace = EMTPY_NAMESPACE_ID;
aoqi@0 187 boolean isResultHeader = false;
aoqi@0 188 WebResult webResult = annReader.getMethodAnnotation(WebResult.class, method ,null);
aoqi@0 189 if (webResult != null) {
aoqi@0 190 if (webResult.name().length() > 0) {
aoqi@0 191 responseElementName = webResult.name();
aoqi@0 192 }
aoqi@0 193 if (webResult.targetNamespace().length() > 0) {
aoqi@0 194 responseNamespace = webResult.targetNamespace();
aoqi@0 195 }
aoqi@0 196 isResultHeader = webResult.header();
aoqi@0 197 }
aoqi@0 198 T returnType = getSafeType(nav.getReturnType(method));
aoqi@0 199 if (!isVoidType(returnType) && !isResultHeader) {
aoqi@0 200 List<Annotation> jaxbRespAnnotations = collectJAXBAnnotations(method);
aoqi@0 201 processXmlElement(jaxbRespAnnotations, responseElementName, responseNamespace, returnType);
aoqi@0 202 responseMembers.add(factory.createWrapperBeanMember(returnType, getPropertyName(responseElementName), jaxbRespAnnotations));
aoqi@0 203 }
aoqi@0 204
aoqi@0 205 // Now parameters that need to be part response wrapper bean
aoqi@0 206 int paramIndex = -1;
aoqi@0 207 for (T param : nav.getMethodParameters(method)) {
aoqi@0 208 paramIndex++;
aoqi@0 209
aoqi@0 210 T paramType = getHolderValueType(param);
aoqi@0 211 WebParam webParam = annReader.getMethodParameterAnnotation(WebParam.class, method, paramIndex, null);
aoqi@0 212 if (paramType == null || (webParam != null && webParam.header())) {
aoqi@0 213 continue; // not a holder or a header - so don't add it
aoqi@0 214 }
aoqi@0 215
aoqi@0 216 String paramName = (webParam != null && webParam.name().length() > 0)
aoqi@0 217 ? webParam.name() : "arg"+paramIndex;
aoqi@0 218 String paramNamespace = (webParam != null && webParam.targetNamespace().length() > 0)
aoqi@0 219 ? webParam.targetNamespace() : EMTPY_NAMESPACE_ID;
aoqi@0 220 List<Annotation> jaxbAnnotation = collectJAXBAnnotations(method, paramIndex);
aoqi@0 221 processXmlElement(jaxbAnnotation, paramName, paramNamespace, paramType);
aoqi@0 222 A member = factory.createWrapperBeanMember(paramType,
aoqi@0 223 getPropertyName(paramName), jaxbAnnotation);
aoqi@0 224 responseMembers.add(member);
aoqi@0 225 }
aoqi@0 226
aoqi@0 227 return responseMembers;
aoqi@0 228 }
aoqi@0 229
aoqi@0 230 private void processXmlElement(List<Annotation> jaxb, String elemName, String elemNS, T type) {
aoqi@0 231 XmlElement elemAnn = null;
aoqi@0 232 for (Annotation a : jaxb) {
aoqi@0 233 if (a.annotationType() == XmlElement.class) {
aoqi@0 234 elemAnn = (XmlElement) a;
aoqi@0 235 jaxb.remove(a);
aoqi@0 236 break;
aoqi@0 237 }
aoqi@0 238 }
aoqi@0 239 String name = (elemAnn != null && !elemAnn.name().equals("##default"))
aoqi@0 240 ? elemAnn.name() : elemName;
aoqi@0 241
aoqi@0 242 String ns = (elemAnn != null && !elemAnn.namespace().equals("##default"))
aoqi@0 243 ? elemAnn.namespace() : elemNS;
aoqi@0 244
aoqi@0 245 boolean nillable = nav.isArray(type)
aoqi@0 246 || (elemAnn != null && elemAnn.nillable());
aoqi@0 247
aoqi@0 248 boolean required = elemAnn != null && elemAnn.required();
aoqi@0 249 XmlElementHandler handler = new XmlElementHandler(name, ns, nillable, required);
aoqi@0 250 XmlElement elem = (XmlElement) Proxy.newProxyInstance(this.getClass().getClassLoader(), new Class<?>[]{XmlElement.class}, handler);
aoqi@0 251 jaxb.add(elem);
aoqi@0 252 }
aoqi@0 253
aoqi@0 254
aoqi@0 255 private static class XmlElementHandler implements InvocationHandler {
aoqi@0 256 private String name;
aoqi@0 257 private String namespace;
aoqi@0 258 private boolean nillable;
aoqi@0 259 private boolean required;
aoqi@0 260
aoqi@0 261 XmlElementHandler(String name, String namespace, boolean nillable,
aoqi@0 262 boolean required) {
aoqi@0 263 this.name = name;
aoqi@0 264 this.namespace = namespace;
aoqi@0 265 this.nillable = nillable;
aoqi@0 266 this.required = required;
aoqi@0 267 }
aoqi@0 268
aoqi@0 269 public Object invoke(Object proxy, Method method, Object[] args) throws Throwable {
aoqi@0 270 String methodName = method.getName();
aoqi@0 271 if (methodName.equals("name")) {
aoqi@0 272 return name;
aoqi@0 273 } else if (methodName.equals("namespace")) {
aoqi@0 274 return namespace;
aoqi@0 275 } else if (methodName.equals("nillable")) {
aoqi@0 276 return nillable;
aoqi@0 277 } else if (methodName.equals("required")) {
aoqi@0 278 return required;
aoqi@0 279 } else {
aoqi@0 280 throw new WebServiceException("Not handling "+methodName);
aoqi@0 281 }
aoqi@0 282 }
aoqi@0 283 }
aoqi@0 284
aoqi@0 285 /**
aoqi@0 286 * Computes and sorts exception bean members for a given exception as per
aoqi@0 287 * the 3.7 section of the spec. It takes all getter properties in the
aoqi@0 288 * exception and its superclasses(except getCause, getLocalizedMessage,
aoqi@0 289 * getStackTrace, getClass). The returned collection is sorted based
aoqi@0 290 * on the property names.
aoqi@0 291 *
aoqi@0 292 * <p>
aoqi@0 293 * But if the exception has @XmlType its values are honored. Only the
aoqi@0 294 * propOrder properties are considered. The returned collection is sorted
aoqi@0 295 * as per the given propOrder.
aoqi@0 296 *
aoqi@0 297 * @param exception
aoqi@0 298 * @return list of properties in the correct order for an exception bean
aoqi@0 299 */
aoqi@0 300 public Collection<A> collectExceptionBeanMembers(C exception) {
aoqi@0 301 return collectExceptionBeanMembers(exception, true);
aoqi@0 302 }
aoqi@0 303
aoqi@0 304 /**
aoqi@0 305 * Computes and sorts exception bean members for a given exception as per
aoqi@0 306 * the 3.7 section of the spec. It takes all getter properties in the
aoqi@0 307 * exception and its superclasses(except getCause, getLocalizedMessage,
aoqi@0 308 * getStackTrace, getClass). The returned collection is sorted based
aoqi@0 309 * on the property names.
aoqi@0 310 *
aoqi@0 311 * <p>
aoqi@0 312 * But if the exception has @XmlType its values are honored. Only the
aoqi@0 313 * propOrder properties are considered. The returned collection is sorted
aoqi@0 314 * as per the given propOrder.
aoqi@0 315 *
aoqi@0 316 * @param exception
aoqi@0 317 * @param decapitalize if true, all the property names are decapitalized
aoqi@0 318 *
aoqi@0 319 * @return list of properties in the correct order for an exception bean
aoqi@0 320 */
aoqi@0 321 public Collection<A> collectExceptionBeanMembers(C exception, boolean decapitalize ) {
aoqi@0 322 TreeMap<String, A> fields = new TreeMap<String, A>();
aoqi@0 323 getExceptionProperties(exception, fields, decapitalize);
aoqi@0 324
aoqi@0 325 // Consider only the @XmlType(propOrder) properties
aoqi@0 326 XmlType xmlType = annReader.getClassAnnotation(XmlType.class, exception, null);
aoqi@0 327 if (xmlType != null) {
aoqi@0 328 String[] propOrder = xmlType.propOrder();
aoqi@0 329 // If not the default order of properties, use that propOrder
aoqi@0 330 if (propOrder.length > 0 && propOrder[0].length() != 0) {
aoqi@0 331 List<A> list = new ArrayList<A>();
aoqi@0 332 for(String prop : propOrder) {
aoqi@0 333 A a = fields.get(prop);
aoqi@0 334 if (a != null) {
aoqi@0 335 list.add(a);
aoqi@0 336 } else {
aoqi@0 337 throw new WebServiceException("Exception "+exception+
aoqi@0 338 " has @XmlType and its propOrder contains unknown property "+prop);
aoqi@0 339 }
aoqi@0 340 }
aoqi@0 341 return list;
aoqi@0 342 }
aoqi@0 343 }
aoqi@0 344
aoqi@0 345 return fields.values();
aoqi@0 346 }
aoqi@0 347
aoqi@0 348
aoqi@0 349 private void getExceptionProperties(C exception, TreeMap<String, A> fields, boolean decapitalize) {
aoqi@0 350 C sc = nav.getSuperClass(exception);
aoqi@0 351 if (sc != null) {
aoqi@0 352 getExceptionProperties(sc, fields, decapitalize);
aoqi@0 353 }
aoqi@0 354 Collection<? extends M> methods = nav.getDeclaredMethods(exception);
aoqi@0 355
aoqi@0 356 for (M method : methods) {
aoqi@0 357
aoqi@0 358 // 2.1.x is doing the following: no final static, transient, non-public
aoqi@0 359 // transient cannot used as modifier for method, so not doing it now
aoqi@0 360 if (!nav.isPublicMethod(method)
aoqi@0 361 || (nav.isStaticMethod(method) && nav.isFinalMethod(method))) {
aoqi@0 362 continue;
aoqi@0 363 }
aoqi@0 364
aoqi@0 365 if (!nav.isPublicMethod(method)) {
aoqi@0 366 continue;
aoqi@0 367 }
aoqi@0 368
aoqi@0 369 String name = nav.getMethodName(method);
aoqi@0 370
aoqi@0 371 if (!(name.startsWith("get") || name.startsWith("is")) || skipProperties.contains(name) ||
aoqi@0 372 name.equals("get") || name.equals("is")) {
aoqi@0 373 // Don't bother with invalid propertyNames.
aoqi@0 374 continue;
aoqi@0 375 }
aoqi@0 376
aoqi@0 377 T returnType = getSafeType(nav.getReturnType(method));
aoqi@0 378 if (nav.getMethodParameters(method).length == 0) {
aoqi@0 379 String fieldName = name.startsWith("get") ? name.substring(3) : name.substring(2);
aoqi@0 380 if (decapitalize) fieldName = StringUtils.decapitalize(fieldName);
aoqi@0 381 fields.put(fieldName, factory.createWrapperBeanMember(returnType, fieldName, Collections.<Annotation>emptyList()));
aoqi@0 382 }
aoqi@0 383 }
aoqi@0 384
aoqi@0 385 }
aoqi@0 386
aoqi@0 387 /**
aoqi@0 388 * Gets the property name by mangling using JAX-WS rules
aoqi@0 389 * @param name to be mangled
aoqi@0 390 * @return property name
aoqi@0 391 */
aoqi@0 392 private static String getPropertyName(String name) {
aoqi@0 393 String propertyName = BindingHelper.mangleNameToVariableName(name);
aoqi@0 394 //We wont have to do this if JAXBRIContext.mangleNameToVariableName() takes
aoqi@0 395 //care of mangling java identifiers
aoqi@0 396 return getJavaReservedVarialbeName(propertyName);
aoqi@0 397 }
aoqi@0 398
aoqi@0 399
aoqi@0 400 //TODO MOVE Names.java to runtime (instead of doing the following)
aoqi@0 401 /*
aoqi@0 402 * See if its a java keyword name, if so then mangle the name
aoqi@0 403 */
aoqi@0 404 private static @NotNull String getJavaReservedVarialbeName(@NotNull String name) {
aoqi@0 405 String reservedName = reservedWords.get(name);
aoqi@0 406 return reservedName == null ? name : reservedName;
aoqi@0 407 }
aoqi@0 408
aoqi@0 409 private static final Map<String, String> reservedWords;
aoqi@0 410
aoqi@0 411 static {
aoqi@0 412 reservedWords = new HashMap<String, String>();
aoqi@0 413 reservedWords.put("abstract", "_abstract");
aoqi@0 414 reservedWords.put("assert", "_assert");
aoqi@0 415 reservedWords.put("boolean", "_boolean");
aoqi@0 416 reservedWords.put("break", "_break");
aoqi@0 417 reservedWords.put("byte", "_byte");
aoqi@0 418 reservedWords.put("case", "_case");
aoqi@0 419 reservedWords.put("catch", "_catch");
aoqi@0 420 reservedWords.put("char", "_char");
aoqi@0 421 reservedWords.put("class", "_class");
aoqi@0 422 reservedWords.put("const", "_const");
aoqi@0 423 reservedWords.put("continue", "_continue");
aoqi@0 424 reservedWords.put("default", "_default");
aoqi@0 425 reservedWords.put("do", "_do");
aoqi@0 426 reservedWords.put("double", "_double");
aoqi@0 427 reservedWords.put("else", "_else");
aoqi@0 428 reservedWords.put("extends", "_extends");
aoqi@0 429 reservedWords.put("false", "_false");
aoqi@0 430 reservedWords.put("final", "_final");
aoqi@0 431 reservedWords.put("finally", "_finally");
aoqi@0 432 reservedWords.put("float", "_float");
aoqi@0 433 reservedWords.put("for", "_for");
aoqi@0 434 reservedWords.put("goto", "_goto");
aoqi@0 435 reservedWords.put("if", "_if");
aoqi@0 436 reservedWords.put("implements", "_implements");
aoqi@0 437 reservedWords.put("import", "_import");
aoqi@0 438 reservedWords.put("instanceof", "_instanceof");
aoqi@0 439 reservedWords.put("int", "_int");
aoqi@0 440 reservedWords.put("interface", "_interface");
aoqi@0 441 reservedWords.put("long", "_long");
aoqi@0 442 reservedWords.put("native", "_native");
aoqi@0 443 reservedWords.put("new", "_new");
aoqi@0 444 reservedWords.put("null", "_null");
aoqi@0 445 reservedWords.put("package", "_package");
aoqi@0 446 reservedWords.put("private", "_private");
aoqi@0 447 reservedWords.put("protected", "_protected");
aoqi@0 448 reservedWords.put("public", "_public");
aoqi@0 449 reservedWords.put("return", "_return");
aoqi@0 450 reservedWords.put("short", "_short");
aoqi@0 451 reservedWords.put("static", "_static");
aoqi@0 452 reservedWords.put("strictfp", "_strictfp");
aoqi@0 453 reservedWords.put("super", "_super");
aoqi@0 454 reservedWords.put("switch", "_switch");
aoqi@0 455 reservedWords.put("synchronized", "_synchronized");
aoqi@0 456 reservedWords.put("this", "_this");
aoqi@0 457 reservedWords.put("throw", "_throw");
aoqi@0 458 reservedWords.put("throws", "_throws");
aoqi@0 459 reservedWords.put("transient", "_transient");
aoqi@0 460 reservedWords.put("true", "_true");
aoqi@0 461 reservedWords.put("try", "_try");
aoqi@0 462 reservedWords.put("void", "_void");
aoqi@0 463 reservedWords.put("volatile", "_volatile");
aoqi@0 464 reservedWords.put("while", "_while");
aoqi@0 465 reservedWords.put("enum", "_enum");
aoqi@0 466 }
aoqi@0 467
aoqi@0 468 }

mercurial