選択できるのは25トピックまでです。 トピックは、先頭が英数字で、英数字とダッシュ('-')を使用した35文字以内のものにしてください。

ClientRpcVisitor.java 3.4KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384
  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.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(
  64. Type.ERROR,
  65. "The method "
  66. + method.getEnclosingType()
  67. .getQualifiedSourceName()
  68. + "."
  69. + method.getName()
  70. + " returns "
  71. + method.getReturnType().getQualifiedSourceName()
  72. + " but only void is supported for methods in RPC interfaces.");
  73. throw new UnableToCompleteException();
  74. }
  75. }
  76. }