You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

ClientRpcVisitor.java 3.2KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182
  1. /*
  2. * Copyright 2000-2014 Vaadin Ltd.
  3. *
  4. * Licensed under the Apache License, Version 2.0 (the "License"); you may not
  5. * use this file except in compliance with the License. You may obtain a copy of
  6. * the License at
  7. *
  8. * http://www.apache.org/licenses/LICENSE-2.0
  9. *
  10. * Unless required by applicable law or agreed to in writing, software
  11. * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
  12. * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
  13. * License for the specific language governing permissions and limitations under
  14. * the License.
  15. */
  16. package com.vaadin.server.widgetsetutils.metadata;
  17. import java.util.Set;
  18. import com.google.gwt.core.ext.TreeLogger;
  19. import com.google.gwt.core.ext.TreeLogger.Type;
  20. import com.google.gwt.core.ext.UnableToCompleteException;
  21. import com.google.gwt.core.ext.typeinfo.JClassType;
  22. import com.google.gwt.core.ext.typeinfo.JMethod;
  23. import com.google.gwt.core.ext.typeinfo.JType;
  24. import com.vaadin.shared.annotations.NoLayout;
  25. public class ClientRpcVisitor extends TypeVisitor {
  26. @Override
  27. public void visitClientRpc(TreeLogger logger, JClassType type,
  28. ConnectorBundle bundle) throws UnableToCompleteException {
  29. checkGenericType(logger, type);
  30. Set<? extends JClassType> hierarchy = type
  31. .getFlattenedSupertypeHierarchy();
  32. for (JClassType subType : hierarchy) {
  33. JMethod[] methods = subType.getMethods();
  34. for (JMethod method : methods) {
  35. checkReturnType(logger, method);
  36. bundle.setNeedsInvoker(type, method);
  37. bundle.setNeedsParamTypes(type, method);
  38. if (method.getAnnotation(NoLayout.class) != null) {
  39. bundle.setNeedsNoLayoutRpcMethod(type, method);
  40. }
  41. JType[] parameterTypes = method.getParameterTypes();
  42. for (JType paramType : parameterTypes) {
  43. bundle.setNeedsSerialize(paramType);
  44. }
  45. }
  46. }
  47. }
  48. public static void checkGenericType(TreeLogger logger, JClassType type)
  49. throws UnableToCompleteException {
  50. if (type.isGenericType() != null) {
  51. logger.log(Type.ERROR,
  52. "Type " + type.getParameterizedQualifiedSourceName()
  53. + "is parameterizied generic. RPC proxy "
  54. + "for parameterizied types is not supported.");
  55. throw new UnableToCompleteException();
  56. }
  57. }
  58. public static void checkReturnType(TreeLogger logger, JMethod method)
  59. throws UnableToCompleteException {
  60. if (!method.getReturnType().getQualifiedSourceName().equals("void")) {
  61. logger.log(
  62. Type.ERROR,
  63. "The method "
  64. + method.getEnclosingType()
  65. .getQualifiedSourceName()
  66. + "."
  67. + method.getName()
  68. + " returns "
  69. + method.getReturnType().getQualifiedSourceName()
  70. + " but only void is supported for methods in RPC interfaces.");
  71. throw new UnableToCompleteException();
  72. }
  73. }
  74. }