aboutsummaryrefslogtreecommitdiffstats
path: root/server
diff options
context:
space:
mode:
authorAhmed Ashour <asashour@yahoo.com>2017-10-04 12:48:21 +0200
committerHenri Sara <henri.sara@gmail.com>2017-10-04 13:48:21 +0300
commiteda970f667f5784977b63a158b24bd1c1f28ffc4 (patch)
tree5b4aeba37bbfd0f6c8c0397783310eabcddbf3c7 /server
parent0eabcf3094dd81dbf15454145eec780130bc091c (diff)
downloadvaadin-framework-eda970f667f5784977b63a158b24bd1c1f28ffc4.tar.gz
vaadin-framework-eda970f667f5784977b63a158b24bd1c1f28ffc4.zip
Don't use synthetic methods for listener classes. (#10135)
Fixes #9504
Diffstat (limited to 'server')
-rw-r--r--server/src/main/java/com/vaadin/data/Binder.java4
-rw-r--r--server/src/main/java/com/vaadin/ui/components/grid/EditorImpl.java7
-rw-r--r--server/src/main/java/com/vaadin/ui/components/grid/GridDragEndListener.java5
-rw-r--r--server/src/main/java/com/vaadin/ui/components/grid/GridDragStartListener.java5
-rw-r--r--server/src/main/java/com/vaadin/ui/components/grid/GridDropListener.java5
-rw-r--r--server/src/main/java/com/vaadin/ui/components/grid/TreeGridDropListener.java5
-rw-r--r--server/src/main/java/com/vaadin/ui/dnd/event/DragEndListener.java17
-rw-r--r--server/src/main/java/com/vaadin/ui/dnd/event/DragStartListener.java13
-rw-r--r--server/src/main/java/com/vaadin/ui/dnd/event/DropListener.java13
-rw-r--r--server/src/main/java/com/vaadin/util/ReflectTools.java44
10 files changed, 74 insertions, 44 deletions
diff --git a/server/src/main/java/com/vaadin/data/Binder.java b/server/src/main/java/com/vaadin/data/Binder.java
index 7a2ed319c9..7f63cb3841 100644
--- a/server/src/main/java/com/vaadin/data/Binder.java
+++ b/server/src/main/java/com/vaadin/data/Binder.java
@@ -1902,7 +1902,7 @@ public class Binder<BEAN> implements Serializable {
*/
public Registration addStatusChangeListener(StatusChangeListener listener) {
return getEventRouter().addListener(StatusChangeEvent.class, listener,
- StatusChangeListener.class.getDeclaredMethods()[0]);
+ ReflectTools.getMethod(StatusChangeListener.class));
}
/**
@@ -1925,7 +1925,7 @@ public class Binder<BEAN> implements Serializable {
public Registration addValueChangeListener(
ValueChangeListener<?> listener) {
return getEventRouter().addListener(ValueChangeEvent.class, listener,
- ValueChangeListener.class.getDeclaredMethods()[0]);
+ ReflectTools.getMethod(ValueChangeListener.class));
}
/**
diff --git a/server/src/main/java/com/vaadin/ui/components/grid/EditorImpl.java b/server/src/main/java/com/vaadin/ui/components/grid/EditorImpl.java
index 502f530d9a..4d5e91b671 100644
--- a/server/src/main/java/com/vaadin/ui/components/grid/EditorImpl.java
+++ b/server/src/main/java/com/vaadin/ui/components/grid/EditorImpl.java
@@ -37,6 +37,7 @@ import com.vaadin.ui.Component;
import com.vaadin.ui.Grid;
import com.vaadin.ui.Grid.AbstractGridExtension;
import com.vaadin.ui.Grid.Column;
+import com.vaadin.util.ReflectTools;
import elemental.json.JsonObject;
@@ -338,19 +339,19 @@ public class EditorImpl<T> extends AbstractGridExtension<T>
@Override
public Registration addSaveListener(EditorSaveListener<T> listener) {
return eventRouter.addListener(EditorSaveEvent.class, listener,
- EditorSaveListener.class.getDeclaredMethods()[0]);
+ ReflectTools.getMethod(EditorSaveListener.class));
}
@Override
public Registration addCancelListener(EditorCancelListener<T> listener) {
return eventRouter.addListener(EditorCancelEvent.class, listener,
- EditorCancelListener.class.getDeclaredMethods()[0]);
+ ReflectTools.getMethod(EditorCancelListener.class));
}
@Override
public Registration addOpenListener(EditorOpenListener<T> listener) {
return eventRouter.addListener(EditorOpenEvent.class, listener,
- EditorOpenListener.class.getDeclaredMethods()[0]);
+ ReflectTools.getMethod(EditorOpenListener.class));
}
@Override
diff --git a/server/src/main/java/com/vaadin/ui/components/grid/GridDragEndListener.java b/server/src/main/java/com/vaadin/ui/components/grid/GridDragEndListener.java
index d41a58bbb6..4d2abf47e2 100644
--- a/server/src/main/java/com/vaadin/ui/components/grid/GridDragEndListener.java
+++ b/server/src/main/java/com/vaadin/ui/components/grid/GridDragEndListener.java
@@ -18,6 +18,7 @@ package com.vaadin.ui.components.grid;
import java.lang.reflect.Method;
import com.vaadin.event.ConnectorEventListener;
+import com.vaadin.util.ReflectTools;
/**
* Drop listener for HTML5 drop on a Grid row.
@@ -31,8 +32,8 @@ import com.vaadin.event.ConnectorEventListener;
@FunctionalInterface
public interface GridDragEndListener<T> extends ConnectorEventListener {
- static final Method DRAG_END_METHOD = GridDragEndListener.class
- .getDeclaredMethods()[0];
+ static final Method DRAG_END_METHOD = ReflectTools
+ .getMethod(GridDragEndListener.class);
/**
* Invoked when the user has dropped the dragged grid rows, or canceled the
diff --git a/server/src/main/java/com/vaadin/ui/components/grid/GridDragStartListener.java b/server/src/main/java/com/vaadin/ui/components/grid/GridDragStartListener.java
index 10f57e85c1..97acc34fcf 100644
--- a/server/src/main/java/com/vaadin/ui/components/grid/GridDragStartListener.java
+++ b/server/src/main/java/com/vaadin/ui/components/grid/GridDragStartListener.java
@@ -18,6 +18,7 @@ package com.vaadin.ui.components.grid;
import java.lang.reflect.Method;
import com.vaadin.event.ConnectorEventListener;
+import com.vaadin.util.ReflectTools;
/**
* Drag start listener for HTML5 drag start on a Grid row.
@@ -31,8 +32,8 @@ import com.vaadin.event.ConnectorEventListener;
@FunctionalInterface
public interface GridDragStartListener<T> extends ConnectorEventListener {
- static final Method DRAG_START_METHOD = GridDragStartListener.class
- .getDeclaredMethods()[0];
+ static final Method DRAG_START_METHOD = ReflectTools
+ .getMethod(GridDragStartListener.class);
/**
* Invoked when the user has started dragging grid's rows.
diff --git a/server/src/main/java/com/vaadin/ui/components/grid/GridDropListener.java b/server/src/main/java/com/vaadin/ui/components/grid/GridDropListener.java
index efac802ae7..2cf6ed06dd 100644
--- a/server/src/main/java/com/vaadin/ui/components/grid/GridDropListener.java
+++ b/server/src/main/java/com/vaadin/ui/components/grid/GridDropListener.java
@@ -18,6 +18,7 @@ package com.vaadin.ui.components.grid;
import java.lang.reflect.Method;
import com.vaadin.event.ConnectorEventListener;
+import com.vaadin.util.ReflectTools;
/**
* Drop listener for HTML5 drop on a Grid row.
@@ -31,8 +32,8 @@ import com.vaadin.event.ConnectorEventListener;
@FunctionalInterface
public interface GridDropListener<T> extends ConnectorEventListener {
- static final Method DROP_METHOD = GridDropListener.class
- .getDeclaredMethods()[0];
+ static final Method DROP_METHOD = ReflectTools
+ .getMethod(GridDropListener.class);
/**
* Called when drop event is fired on a Grid row.
diff --git a/server/src/main/java/com/vaadin/ui/components/grid/TreeGridDropListener.java b/server/src/main/java/com/vaadin/ui/components/grid/TreeGridDropListener.java
index d413a7b42b..5db82c6246 100644
--- a/server/src/main/java/com/vaadin/ui/components/grid/TreeGridDropListener.java
+++ b/server/src/main/java/com/vaadin/ui/components/grid/TreeGridDropListener.java
@@ -18,6 +18,7 @@ package com.vaadin.ui.components.grid;
import java.lang.reflect.Method;
import com.vaadin.event.ConnectorEventListener;
+import com.vaadin.util.ReflectTools;
/**
* Drop listener for HTML5 drop on a TreeGrid row.
@@ -31,8 +32,8 @@ import com.vaadin.event.ConnectorEventListener;
@FunctionalInterface
public interface TreeGridDropListener<T> extends ConnectorEventListener {
- static final Method DROP_METHOD = TreeGridDropListener.class
- .getDeclaredMethods()[0];
+ static final Method DROP_METHOD = ReflectTools
+ .getMethod(TreeGridDropListener.class);
/**
* Called when drop event is fired on a Grid row.
diff --git a/server/src/main/java/com/vaadin/ui/dnd/event/DragEndListener.java b/server/src/main/java/com/vaadin/ui/dnd/event/DragEndListener.java
index b8ab67279e..65c02ddc63 100644
--- a/server/src/main/java/com/vaadin/ui/dnd/event/DragEndListener.java
+++ b/server/src/main/java/com/vaadin/ui/dnd/event/DragEndListener.java
@@ -20,28 +20,29 @@ import java.lang.reflect.Method;
import com.vaadin.event.ConnectorEventListener;
import com.vaadin.ui.AbstractComponent;
import com.vaadin.ui.dnd.DragSourceExtension;
+import com.vaadin.util.ReflectTools;
/**
- * Interface to be implemented when creating a dragend listener on a drag
- * source for HTML5 drag and drop.
+ * Interface to be implemented when creating a dragend listener on a drag source
+ * for HTML5 drag and drop.
*
* @param <T>
- * Type of draggable component.
+ * Type of draggable component.
* @author Vaadin Ltd
* @see DragSourceExtension#addDragEndListener(DragEndListener)
* @since 8.1
*/
@FunctionalInterface
-public interface DragEndListener<T extends AbstractComponent> extends
- ConnectorEventListener {
- static final Method DRAGEND_METHOD = DragEndListener.class
- .getDeclaredMethods()[0];
+public interface DragEndListener<T extends AbstractComponent>
+ extends ConnectorEventListener {
+ static final Method DRAGEND_METHOD = ReflectTools
+ .getMethod(DragEndListener.class);
/**
* Called when dragend event is fired.
*
* @param event
- * Server side dragend event.
+ * Server side dragend event.
*/
void dragEnd(DragEndEvent<T> event);
}
diff --git a/server/src/main/java/com/vaadin/ui/dnd/event/DragStartListener.java b/server/src/main/java/com/vaadin/ui/dnd/event/DragStartListener.java
index 42c702f7db..db44c91637 100644
--- a/server/src/main/java/com/vaadin/ui/dnd/event/DragStartListener.java
+++ b/server/src/main/java/com/vaadin/ui/dnd/event/DragStartListener.java
@@ -20,28 +20,29 @@ import java.lang.reflect.Method;
import com.vaadin.event.ConnectorEventListener;
import com.vaadin.ui.AbstractComponent;
import com.vaadin.ui.dnd.DragSourceExtension;
+import com.vaadin.util.ReflectTools;
/**
* Interface to be implemented when creating a dragstart listener on a drag
* source for HTML5 drag and drop.
*
* @param <T>
- * Type of draggable component.
+ * Type of draggable component.
* @author Vaadin Ltd
* @see DragSourceExtension#addDragStartListener(DragStartListener)
* @since 8.1
*/
@FunctionalInterface
-public interface DragStartListener<T extends AbstractComponent> extends
- ConnectorEventListener {
- static final Method DRAGSTART_METHOD = DragStartListener.class
- .getDeclaredMethods()[0];
+public interface DragStartListener<T extends AbstractComponent>
+ extends ConnectorEventListener {
+ static final Method DRAGSTART_METHOD = ReflectTools
+ .getMethod(DragStartListener.class);
/**
* Called when dragstart event is fired.
*
* @param event
- * Server side dragstart event.
+ * Server side dragstart event.
*/
void dragStart(DragStartEvent<T> event);
}
diff --git a/server/src/main/java/com/vaadin/ui/dnd/event/DropListener.java b/server/src/main/java/com/vaadin/ui/dnd/event/DropListener.java
index 5f31676468..538c9a6580 100644
--- a/server/src/main/java/com/vaadin/ui/dnd/event/DropListener.java
+++ b/server/src/main/java/com/vaadin/ui/dnd/event/DropListener.java
@@ -20,28 +20,29 @@ import java.lang.reflect.Method;
import com.vaadin.event.ConnectorEventListener;
import com.vaadin.ui.AbstractComponent;
import com.vaadin.ui.dnd.DropTargetExtension;
+import com.vaadin.util.ReflectTools;
/**
* Interface to be implemented when creating a drop listener on a drop target
* for HTML5 drag and drop.
*
* @param <T>
- * Type of the drop target component.
+ * Type of the drop target component.
* @author Vaadin Ltd
* @see DropTargetExtension#addDropListener(DropListener)
* @since 8.1
*/
@FunctionalInterface
-public interface DropListener<T extends AbstractComponent> extends
- ConnectorEventListener {
- static final Method DROP_METHOD = DropListener.class
- .getDeclaredMethods()[0];
+public interface DropListener<T extends AbstractComponent>
+ extends ConnectorEventListener {
+ static final Method DROP_METHOD = ReflectTools
+ .getMethod(DropListener.class);
/**
* Called when drop event is fired.
*
* @param event
- * Server side drop event.
+ * Server side drop event.
*/
void drop(DropEvent<T> event);
}
diff --git a/server/src/main/java/com/vaadin/util/ReflectTools.java b/server/src/main/java/com/vaadin/util/ReflectTools.java
index daeb2384b8..b38a23b46e 100644
--- a/server/src/main/java/com/vaadin/util/ReflectTools.java
+++ b/server/src/main/java/com/vaadin/util/ReflectTools.java
@@ -82,9 +82,9 @@ public class ReflectTools implements Serializable {
* @throws IllegalArgumentException
* If the value could not be retrieved
*/
- public static Object getJavaFieldValue(Object object,
- Field field) throws IllegalArgumentException,
- IllegalAccessException, InvocationTargetException {
+ public static Object getJavaFieldValue(Object object, Field field)
+ throws IllegalArgumentException, IllegalAccessException,
+ InvocationTargetException {
PropertyDescriptor pd;
try {
pd = new PropertyDescriptor(field.getName(), object.getClass());
@@ -126,10 +126,9 @@ public class ReflectTools implements Serializable {
* @throws IllegalArgumentException
* If the value could not be retrieved
*/
- public static Object getJavaFieldValue(Object object,
- Field field, Class<?> propertyType)
- throws IllegalArgumentException, IllegalAccessException,
- InvocationTargetException {
+ public static Object getJavaFieldValue(Object object, Field field,
+ Class<?> propertyType) throws IllegalArgumentException,
+ IllegalAccessException, InvocationTargetException {
PropertyDescriptor pd;
try {
pd = new PropertyDescriptor(field.getName(), object.getClass());
@@ -173,10 +172,9 @@ public class ReflectTools implements Serializable {
* @throws InvocationTargetException
* If the value could not be assigned to the field
*/
- public static void setJavaFieldValue(Object object,
- Field field, Object value)
- throws IllegalAccessException, IllegalArgumentException,
- InvocationTargetException {
+ public static void setJavaFieldValue(Object object, Field field,
+ Object value) throws IllegalAccessException,
+ IllegalArgumentException, InvocationTargetException {
PropertyDescriptor pd;
try {
pd = new PropertyDescriptor(field.getName(), object.getClass());
@@ -322,4 +320,28 @@ public class ReflectTools implements Serializable {
}
}
+ /**
+ * Returns the first non-synthetic method of the specified
+ * {@code listenerClass}, which must have single method in the source-code.
+ *
+ * This is needed, to remove the synthetic methods added if the class is
+ * instrumented.
+ *
+ * @param listenerClass
+ * The {@link Class} of the listener, which has a single method
+ * in the source code
+ * @return the first non-synthetic method
+ * @throws IllegalStateException
+ * if the specified class does not have found method
+ * @since
+ */
+ public static Method getMethod(Class<?> listenerClass) {
+ for (Method m : listenerClass.getDeclaredMethods()) {
+ if (!m.isSynthetic()) {
+ return m;
+ }
+ }
+ throw new IllegalStateException("Class " + listenerClass.getName()
+ + " does not have a method.");
+ }
}