From 7efa1d6ec145aa48fc75fbdc9e403faf478e7f96 Mon Sep 17 00:00:00 2001 From: Leif Åstrand Date: Thu, 8 Jan 2015 22:21:42 +0200 Subject: Handle generated method flags in a unified way (#15373) Refactor existing functionality without functional changes to make it easier to add support for the @BackgroundMessage annotation added in a separate commit. Change-Id: I27454ba44af4b7b3b7beccf29b12e22bf9f75a86 --- .../ConnectorBundleLoaderFactory.java | 61 ++++++---------------- .../widgetsetutils/metadata/ClientRpcVisitor.java | 4 +- .../widgetsetutils/metadata/ConnectorBundle.java | 52 ++++++++---------- .../widgetsetutils/metadata/ServerRpcVisitor.java | 14 ++++- .../com/vaadin/client/metadata/TypeDataStore.java | 51 +++++++++--------- 5 files changed, 79 insertions(+), 103 deletions(-) diff --git a/client-compiler/src/com/vaadin/server/widgetsetutils/ConnectorBundleLoaderFactory.java b/client-compiler/src/com/vaadin/server/widgetsetutils/ConnectorBundleLoaderFactory.java index f946d87638..884852f7c8 100644 --- a/client-compiler/src/com/vaadin/server/widgetsetutils/ConnectorBundleLoaderFactory.java +++ b/client-compiler/src/com/vaadin/server/widgetsetutils/ConnectorBundleLoaderFactory.java @@ -55,6 +55,7 @@ import com.vaadin.client.metadata.OnStateChangeMethod; import com.vaadin.client.metadata.ProxyHandler; import com.vaadin.client.metadata.TypeData; import com.vaadin.client.metadata.TypeDataStore; +import com.vaadin.client.metadata.TypeDataStore.MethodAttribute; import com.vaadin.client.ui.UnknownComponentConnector; import com.vaadin.server.widgetsetutils.metadata.ClientRpcVisitor; import com.vaadin.server.widgetsetutils.metadata.ConnectorBundle; @@ -67,7 +68,6 @@ import com.vaadin.server.widgetsetutils.metadata.ServerRpcVisitor; import com.vaadin.server.widgetsetutils.metadata.StateInitVisitor; import com.vaadin.server.widgetsetutils.metadata.TypeVisitor; import com.vaadin.server.widgetsetutils.metadata.WidgetInitVisitor; -import com.vaadin.shared.annotations.Delayed; import com.vaadin.shared.annotations.DelegateToWidget; import com.vaadin.shared.annotations.NoLayout; import com.vaadin.shared.communication.ClientRpc; @@ -502,8 +502,7 @@ public class ConnectorBundleLoaderFactory extends Generator { writeInvokers(logger, w, bundle); writeParamTypes(w, bundle); writeProxys(w, bundle); - writeDelayedInfo(w, bundle); - writeNoLayoutRpcMethods(w, bundle); + writeMethodAttributes(logger, w, bundle); w.println("%s(store);", loadNativeJsMethodName); @@ -516,22 +515,6 @@ public class ConnectorBundleLoaderFactory extends Generator { writeOnStateChangeHandlers(logger, w, bundle); } - private void writeNoLayoutRpcMethods(SplittingSourceWriter w, - ConnectorBundle bundle) { - Map> needsNoLayout = bundle - .getNeedsNoLayoutRpcMethods(); - for (Entry> entry : needsNoLayout.entrySet()) { - JClassType type = entry.getKey(); - - for (JMethod method : entry.getValue()) { - w.println("store.setNoLayoutRpcMethod(%s, \"%s\");", - getClassLiteralString(type), method.getName()); - } - - w.splitIfNeeded(); - } - } - private void writeOnStateChangeHandlers(TreeLogger logger, SplittingSourceWriter w, ConnectorBundle bundle) throws UnableToCompleteException { @@ -740,32 +723,20 @@ public class ConnectorBundleLoaderFactory extends Generator { } } - private void writeDelayedInfo(SplittingSourceWriter w, - ConnectorBundle bundle) { - Map> needsDelayedInfo = bundle - .getNeedsDelayedInfo(); - Set>> entrySet = needsDelayedInfo - .entrySet(); - for (Entry> entry : entrySet) { - JClassType type = entry.getKey(); - Set methods = entry.getValue(); - for (JMethod method : methods) { - Delayed annotation = method.getAnnotation(Delayed.class); - if (annotation != null) { - w.print("store.setDelayed("); - writeClassLiteral(w, type); - w.print(", \""); - w.print(escape(method.getName())); - w.println("\");"); - - if (annotation.lastOnly()) { - w.print("store.setLastOnly("); - writeClassLiteral(w, type); - w.print(", \""); - w.print(escape(method.getName())); - w.println("\");"); - } - + private void writeMethodAttributes(TreeLogger logger, + SplittingSourceWriter w, ConnectorBundle bundle) { + for (Entry>> typeEntry : bundle + .getMethodAttributes().entrySet()) { + JClassType type = typeEntry.getKey(); + for (Entry> methodEntry : typeEntry + .getValue().entrySet()) { + JMethod method = methodEntry.getKey(); + Set attributes = methodEntry.getValue(); + for (MethodAttribute attribute : attributes) { + w.println("store.setMethodAttribute(%s, \"%s\", %s.%s);", + getClassLiteralString(type), method.getName(), + MethodAttribute.class.getCanonicalName(), + attribute.name()); w.splitIfNeeded(); } } diff --git a/client-compiler/src/com/vaadin/server/widgetsetutils/metadata/ClientRpcVisitor.java b/client-compiler/src/com/vaadin/server/widgetsetutils/metadata/ClientRpcVisitor.java index 1df3d78588..992a012005 100644 --- a/client-compiler/src/com/vaadin/server/widgetsetutils/metadata/ClientRpcVisitor.java +++ b/client-compiler/src/com/vaadin/server/widgetsetutils/metadata/ClientRpcVisitor.java @@ -24,6 +24,7 @@ import com.google.gwt.core.ext.UnableToCompleteException; import com.google.gwt.core.ext.typeinfo.JClassType; import com.google.gwt.core.ext.typeinfo.JMethod; import com.google.gwt.core.ext.typeinfo.JType; +import com.vaadin.client.metadata.TypeDataStore.MethodAttribute; import com.vaadin.shared.annotations.NoLayout; public class ClientRpcVisitor extends TypeVisitor { @@ -41,7 +42,8 @@ public class ClientRpcVisitor extends TypeVisitor { bundle.setNeedsInvoker(type, method); bundle.setNeedsParamTypes(type, method); if (method.getAnnotation(NoLayout.class) != null) { - bundle.setNeedsNoLayoutRpcMethod(type, method); + bundle.setMethodAttribute(type, method, + MethodAttribute.NO_LAYOUT); } JType[] parameterTypes = method.getParameterTypes(); diff --git a/client-compiler/src/com/vaadin/server/widgetsetutils/metadata/ConnectorBundle.java b/client-compiler/src/com/vaadin/server/widgetsetutils/metadata/ConnectorBundle.java index 31f59ddee4..405925a920 100644 --- a/client-compiler/src/com/vaadin/server/widgetsetutils/metadata/ConnectorBundle.java +++ b/client-compiler/src/com/vaadin/server/widgetsetutils/metadata/ConnectorBundle.java @@ -43,6 +43,7 @@ import com.vaadin.client.ComponentConnector; import com.vaadin.client.ServerConnector; import com.vaadin.client.communication.JSONSerializer; import com.vaadin.client.connectors.AbstractRendererConnector; +import com.vaadin.client.metadata.TypeDataStore.MethodAttribute; import com.vaadin.client.ui.UnknownComponentConnector; import com.vaadin.shared.communication.ClientRpc; import com.vaadin.shared.communication.ServerRpc; @@ -71,9 +72,9 @@ public class ConnectorBundle { private final Map> needsReturnType = new HashMap>(); private final Map> needsInvoker = new HashMap>(); private final Map> needsParamTypes = new HashMap>(); - private final Map> needsDelayedInfo = new HashMap>(); private final Map> needsOnStateChange = new HashMap>(); - private final Map> needsNoLayoutRpcMethods = new HashMap>(); + + private final Map>> methodAttributes = new HashMap>>(); private final Set needsProperty = new HashSet(); private final Map> needsDelegateToWidget = new HashMap>(); @@ -525,23 +526,35 @@ public class ConnectorBundle { return Collections.unmodifiableSet(needsProxySupport); } - public void setNeedsDelayedInfo(JClassType type, JMethod method) { - if (!isNeedsDelayedInfo(type, method)) { - addMapping(needsDelayedInfo, type, method); + public void setMethodAttribute(JClassType type, JMethod method, + MethodAttribute methodAttribute) { + if (!hasMethodAttribute(type, method, methodAttribute)) { + Map> typeData = methodAttributes + .get(type); + if (typeData == null) { + typeData = new HashMap>(); + methodAttributes.put(type, typeData); + } + + addMapping(typeData, method, methodAttribute); } } - private boolean isNeedsDelayedInfo(JClassType type, JMethod method) { - if (hasMapping(needsDelayedInfo, type, method)) { + private boolean hasMethodAttribute(JClassType type, JMethod method, + MethodAttribute methodAttribute) { + Map> typeData = methodAttributes + .get(type); + if (typeData != null && hasMapping(typeData, method, methodAttribute)) { return true; } else { return previousBundle != null - && previousBundle.isNeedsDelayedInfo(type, method); + && previousBundle.hasMethodAttribute(type, method, + methodAttribute); } } - public Map> getNeedsDelayedInfo() { - return Collections.unmodifiableMap(needsDelayedInfo); + public Map>> getMethodAttributes() { + return Collections.unmodifiableMap(methodAttributes); } public void setNeedsSerialize(JType type) { @@ -635,25 +648,6 @@ public class ConnectorBundle { return Collections.unmodifiableMap(needsOnStateChange); } - public void setNeedsNoLayoutRpcMethod(JClassType type, JMethod method) { - if (!isNeedsNoLayoutRpcMethod(type, method)) { - addMapping(needsNoLayoutRpcMethods, type, method); - } - } - - private boolean isNeedsNoLayoutRpcMethod(JClassType type, JMethod method) { - if (hasMapping(needsNoLayoutRpcMethods, type, method)) { - return true; - } else { - return previousBundle != null - && previousBundle.isNeedsNoLayoutRpcMethod(type, method); - } - } - - public Map> getNeedsNoLayoutRpcMethods() { - return Collections.unmodifiableMap(needsNoLayoutRpcMethods); - } - public static JMethod findInheritedMethod(JClassType type, String methodName, JType... params) { diff --git a/client-compiler/src/com/vaadin/server/widgetsetutils/metadata/ServerRpcVisitor.java b/client-compiler/src/com/vaadin/server/widgetsetutils/metadata/ServerRpcVisitor.java index 6ad0d2fd98..a1852d5b32 100644 --- a/client-compiler/src/com/vaadin/server/widgetsetutils/metadata/ServerRpcVisitor.java +++ b/client-compiler/src/com/vaadin/server/widgetsetutils/metadata/ServerRpcVisitor.java @@ -23,6 +23,8 @@ import com.google.gwt.core.ext.UnableToCompleteException; import com.google.gwt.core.ext.typeinfo.JClassType; import com.google.gwt.core.ext.typeinfo.JMethod; import com.google.gwt.core.ext.typeinfo.JType; +import com.vaadin.client.metadata.TypeDataStore.MethodAttribute; +import com.vaadin.shared.annotations.Delayed; public class ServerRpcVisitor extends TypeVisitor { @Override @@ -38,7 +40,17 @@ public class ServerRpcVisitor extends TypeVisitor { JMethod[] methods = subType.getMethods(); for (JMethod method : methods) { ClientRpcVisitor.checkReturnType(logger, method); - bundle.setNeedsDelayedInfo(type, method); + + Delayed delayed = method.getAnnotation(Delayed.class); + if (delayed != null) { + bundle.setMethodAttribute(type, method, + MethodAttribute.DELAYED); + if (delayed.lastOnly()) { + bundle.setMethodAttribute(type, method, + MethodAttribute.LAST_ONLY); + } + } + bundle.setNeedsParamTypes(type, method); JType[] parameterTypes = method.getParameterTypes(); diff --git a/client/src/com/vaadin/client/metadata/TypeDataStore.java b/client/src/com/vaadin/client/metadata/TypeDataStore.java index 6d46ed1365..e3db0ccded 100644 --- a/client/src/com/vaadin/client/metadata/TypeDataStore.java +++ b/client/src/com/vaadin/client/metadata/TypeDataStore.java @@ -28,6 +28,10 @@ import com.vaadin.client.communication.JSONSerializer; import com.vaadin.shared.annotations.NoLayout; public class TypeDataStore { + public static enum MethodAttribute { + DELAYED, LAST_ONLY, NO_LAYOUT; + } + private static final String CONSTRUCTOR_NAME = "!new"; private final FastStringMap> identifiers = FastStringMap.create(); @@ -47,9 +51,8 @@ public class TypeDataStore { private final FastStringMap>> onStateChangeMethods = FastStringMap .create(); - private final FastStringSet delayedMethods = FastStringSet.create(); - private final FastStringSet lastOnlyMethods = FastStringSet.create(); - private final FastStringSet noLayoutRpcMethods = FastStringSet.create(); + private final FastStringMap methodAttributes = FastStringMap + .create(); private final FastStringMap returnTypes = FastStringMap.create(); private final FastStringMap invokers = FastStringMap.create(); @@ -213,20 +216,29 @@ public class TypeDataStore { } public static boolean isDelayed(Method method) { - return get().delayedMethods.contains(method.getLookupKey()); + return hasMethodAttribute(method, MethodAttribute.DELAYED); } - public void setDelayed(Class type, String methodName) { - delayedMethods.add(getType(type).getMethod(methodName).getLookupKey()); + private static boolean hasMethodAttribute(Method method, + MethodAttribute attribute) { + FastStringSet attributes = get().methodAttributes.get(method + .getLookupKey()); + return attributes != null && attributes.contains(attribute.name()); } - public static boolean isLastOnly(Method method) { - return get().lastOnlyMethods.contains(method.getLookupKey()); + public void setMethodAttribute(Class type, String methodName, + MethodAttribute attribute) { + String key = getType(type).getMethod(methodName).getLookupKey(); + FastStringSet attributes = methodAttributes.get(key); + if (attributes == null) { + attributes = FastStringSet.create(); + methodAttributes.put(key, attributes); + } + attributes.add(attribute.name()); } - public void setLastOnly(Class clazz, String methodName) { - lastOnlyMethods - .add(getType(clazz).getMethod(methodName).getLookupKey()); + public static boolean isLastOnly(Method method) { + return hasMethodAttribute(method, MethodAttribute.LAST_ONLY); } /** @@ -450,22 +462,7 @@ public class TypeDataStore { * otherwise false */ public static boolean isNoLayoutRpcMethod(Method method) { - return get().noLayoutRpcMethods.contains(method.getLookupKey()); - } - - /** - * Defines that a method is annotated with {@link NoLayout}. - * - * @since 7.4 - * - * @param type - * the where the method is defined - * @param methodName - * the name of the method - */ - public void setNoLayoutRpcMethod(Class type, String methodName) { - noLayoutRpcMethods.add(new Method(getType(type), methodName) - .getLookupKey()); + return hasMethodAttribute(method, MethodAttribute.NO_LAYOUT); } /** -- cgit v1.2.3