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

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879
  1. /*
  2. * Copyright 2000-2018 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.client.metadata.TypeDataStore.MethodAttribute;
  25. import com.vaadin.shared.annotations.NoLayout;
  26. public class ClientRpcVisitor extends TypeVisitor {
  27. @Override
  28. public void visitClientRpc(TreeLogger logger, JClassType type,
  29. ConnectorBundle bundle) throws UnableToCompleteException {
  30. checkGenericType(logger, type);
  31. Set<? extends JClassType> hierarchy = type
  32. .getFlattenedSupertypeHierarchy();
  33. for (JClassType subType : hierarchy) {
  34. JMethod[] methods = subType.getMethods();
  35. for (JMethod method : methods) {
  36. checkReturnType(logger, method);
  37. bundle.setNeedsInvoker(type, method);
  38. bundle.setNeedsParamTypes(type, method);
  39. if (method.getAnnotation(NoLayout.class) != null) {
  40. bundle.setMethodAttribute(type, method,
  41. MethodAttribute.NO_LAYOUT);
  42. }
  43. JType[] parameterTypes = method.getParameterTypes();
  44. for (JType paramType : parameterTypes) {
  45. bundle.setNeedsSerialize(paramType);
  46. }
  47. }
  48. }
  49. }
  50. public static void checkGenericType(TreeLogger logger, JClassType type)
  51. throws UnableToCompleteException {
  52. if (type.isGenericType() != null) {
  53. logger.log(Type.ERROR,
  54. "Type " + type.getParameterizedQualifiedSourceName()
  55. + "is parameterizied generic. RPC proxy "
  56. + "for parameterizied types is not supported.");
  57. throw new UnableToCompleteException();
  58. }
  59. }
  60. public static void checkReturnType(TreeLogger logger, JMethod method)
  61. throws UnableToCompleteException {
  62. if (!method.getReturnType().getQualifiedSourceName().equals("void")) {
  63. logger.log(Type.ERROR, "The method "
  64. + method.getEnclosingType().getQualifiedSourceName() + "."
  65. + method.getName() + " returns "
  66. + method.getReturnType().getQualifiedSourceName()
  67. + " but only void is supported for methods in RPC interfaces.");
  68. throw new UnableToCompleteException();
  69. }
  70. }
  71. }