summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorArtur Signell <artur@vaadin.com>2013-01-10 20:26:10 +0000
committerVaadin Code Review <review@vaadin.com>2013-01-10 20:26:10 +0000
commit70eb314fd3f9646795d1c4784232e9d8b59b3b8b (patch)
tree6960b0445f3160c67eef8e76a8aa18ccb0ba77f5
parent1152b2c99bfd41eccf9c56dc5cba226507569ce7 (diff)
parentd9e9a7db654adb28f32cebac7b490cf8d2b2bcd1 (diff)
downloadvaadin-framework-70eb314fd3f9646795d1c4784232e9d8b59b3b8b.tar.gz
vaadin-framework-70eb314fd3f9646795d1c4784232e9d8b59b3b8b.zip
Merge "Enable overriding which connectors are in the widgetset (#10710)"
-rw-r--r--client-compiler/src/com/vaadin/server/widgetsetutils/ConnectorBundleLoaderFactory.java43
1 files changed, 36 insertions, 7 deletions
diff --git a/client-compiler/src/com/vaadin/server/widgetsetutils/ConnectorBundleLoaderFactory.java b/client-compiler/src/com/vaadin/server/widgetsetutils/ConnectorBundleLoaderFactory.java
index 09aae5b662..f8aa586064 100644
--- a/client-compiler/src/com/vaadin/server/widgetsetutils/ConnectorBundleLoaderFactory.java
+++ b/client-compiler/src/com/vaadin/server/widgetsetutils/ConnectorBundleLoaderFactory.java
@@ -757,12 +757,9 @@ public class ConnectorBundleLoaderFactory extends Generator {
connectorsByLoadStyle.put(loadStyle, new ArrayList<JClassType>());
}
- JClassType connectorType = typeOracle.getType(ServerConnector.class
- .getName());
- JClassType[] subtypes = connectorType.getSubtypes();
-
// Find all types with a valid mapping
- Collection<JClassType> selectedTypes = getMappedTypes(logger, subtypes);
+ Collection<JClassType> selectedTypes = getConnectorsForWidgetset(
+ logger, typeOracle);
// Group by load style
for (JClassType connectorSubtype : selectedTypes) {
@@ -816,8 +813,40 @@ public class ConnectorBundleLoaderFactory extends Generator {
return bundles;
}
- private Collection<JClassType> getMappedTypes(TreeLogger logger,
- JClassType[] types) throws UnableToCompleteException {
+ /**
+ * Returns the connector types that should be included in the widgetset.
+ * This method can be overridden to create a widgetset only containing
+ * selected connectors.
+ * <p>
+ * The default implementation finds all type implementing
+ * {@link ServerConnector} that have a @{@link Connect} annotation. It also
+ * checks that multiple connectors aren't connected to the same server-side
+ * class.
+ *
+ * @param logger
+ * the logger to which information can be logged
+ * @param typeOracle
+ * the type oracle that can be used for finding types
+ * @return a collection of all the connector types that should be included
+ * in the widgetset
+ * @throws UnableToCompleteException
+ * if the operation fails
+ */
+ protected Collection<JClassType> getConnectorsForWidgetset(
+ TreeLogger logger, TypeOracle typeOracle)
+ throws UnableToCompleteException {
+ JClassType serverConnectorType;
+ try {
+ serverConnectorType = typeOracle.getType(ServerConnector.class
+ .getName());
+ } catch (NotFoundException e) {
+ logger.log(Type.ERROR,
+ "Can't find " + ServerConnector.class.getName());
+ throw new UnableToCompleteException();
+ }
+
+ JClassType[] types = serverConnectorType.getSubtypes();
+
Map<String, JClassType> mappings = new HashMap<String, JClassType>();
// Keep track of what has happened to avoid logging intermediate state