diff options
author | Leif Åstrand <leif@vaadin.com> | 2013-11-05 15:41:45 +0200 |
---|---|---|
committer | Leif Åstrand <leif@vaadin.com> | 2013-11-05 15:41:45 +0200 |
commit | e0e00befc848c242f986ba5cd993ae8610a7fa83 (patch) | |
tree | f45826d089932e534add7f91fb267eeaceed9c34 | |
parent | a2f255448e6a755892a97b7df9fc2b65efc5dccc (diff) | |
download | vaadin-framework-e0e00befc848c242f986ba5cd993ae8610a7fa83.tar.gz vaadin-framework-e0e00befc848c242f986ba5cd993ae8610a7fa83.zip |
Improve error message in createWidget() (#12901)
Change-Id: If456a2be242754bcd1e0a8c5be00062a4355af35
-rw-r--r-- | client/src/com/vaadin/client/ui/AbstractComponentConnector.java | 19 |
1 files changed, 15 insertions, 4 deletions
diff --git a/client/src/com/vaadin/client/ui/AbstractComponentConnector.java b/client/src/com/vaadin/client/ui/AbstractComponentConnector.java index 6f98e29d03..8fdaf0a5be 100644 --- a/client/src/com/vaadin/client/ui/AbstractComponentConnector.java +++ b/client/src/com/vaadin/client/ui/AbstractComponentConnector.java @@ -15,6 +15,7 @@ */ package com.vaadin.client.ui; +import com.google.gwt.core.client.GWT; import com.google.gwt.core.client.JsArrayString; import com.google.gwt.dom.client.Element; import com.google.gwt.user.client.ui.Focusable; @@ -68,8 +69,16 @@ public abstract class AbstractComponentConnector extends AbstractConnector /** * Creates and returns the widget for this VPaintableWidget. This method * should only be called once when initializing the paintable. + * <p> + * You should typically not override this method since the framework by + * default generates an implementation that uses {@link GWT#create(Class)} + * to create a widget of the same type as returned by the most specific + * override of {@link #getWidget()}. If you do override the method, you + * can't call <code>super.createWidget()</code> since the metadata needed + * for that implementation is not generated if there's an override of the + * method. * - * @return + * @return a new widget instance to use for this component connector */ protected Widget createWidget() { Type type = TypeData.getType(getClass()); @@ -79,10 +88,12 @@ public abstract class AbstractComponentConnector extends AbstractConnector return (Widget) instance; } catch (NoDataException e) { throw new IllegalStateException( - "There is no information about the widget for " + "Default implementation of createWidget() does not work for " + Util.getSimpleName(this) - + ". Did you remember to compile the right widgetset?", - e); + + ". This might be caused by explicitely using " + + "super.createWidget(), using a widget type with " + + "generics or some unspecified problem with the " + + "widgetset compilation.", e); } } |