summaryrefslogtreecommitdiffstats
path: root/src
diff options
context:
space:
mode:
Diffstat (limited to 'src')
-rw-r--r--src/com/itmill/toolkit/terminal/gwt/server/DebugUtilities.java138
1 files changed, 122 insertions, 16 deletions
diff --git a/src/com/itmill/toolkit/terminal/gwt/server/DebugUtilities.java b/src/com/itmill/toolkit/terminal/gwt/server/DebugUtilities.java
index ee3661563e..978899be1d 100644
--- a/src/com/itmill/toolkit/terminal/gwt/server/DebugUtilities.java
+++ b/src/com/itmill/toolkit/terminal/gwt/server/DebugUtilities.java
@@ -1,15 +1,20 @@
package com.itmill.toolkit.terminal.gwt.server;
+import java.util.HashMap;
import java.util.Iterator;
+import java.util.Map;
import java.util.Stack;
import com.itmill.toolkit.terminal.Sizeable;
+import com.itmill.toolkit.ui.AbstractOrderedLayout;
import com.itmill.toolkit.ui.Component;
import com.itmill.toolkit.ui.ComponentContainer;
+import com.itmill.toolkit.ui.CustomComponent;
import com.itmill.toolkit.ui.CustomLayout;
import com.itmill.toolkit.ui.GridLayout;
import com.itmill.toolkit.ui.OrderedLayout;
import com.itmill.toolkit.ui.Panel;
+import com.itmill.toolkit.ui.VerticalLayout;
import com.itmill.toolkit.ui.Window;
import com.itmill.toolkit.ui.GridLayout.Area;
@@ -55,7 +60,8 @@ public class DebugUtilities {
return valid;
}
- private static void showError(String msg, Stack<ComponentInfo> attributes) {
+ private static void showError(String msg, Stack<ComponentInfo> attributes,
+ boolean widthError) {
StringBuffer err = new StringBuffer();
err.append("IT MILL Toolkit DEBUG\n");
@@ -67,7 +73,7 @@ public class DebugUtilities {
}
while (!attributes.empty()) {
ci = attributes.pop();
- showComponent(ci.component, ci.info, err, indent);
+ showComponent(ci.component, ci.info, err, indent, widthError);
}
}
@@ -86,9 +92,17 @@ public class DebugUtilities {
Stack<ComponentInfo> attributes = null;
if (hasRelativeHeight(component) && hasUndefinedHeight(parent)) {
- if (parent instanceof OrderedLayout) {
- OrderedLayout ol = (OrderedLayout) parent;
- if (ol.getOrientation() == OrderedLayout.ORIENTATION_VERTICAL) {
+ if (parent instanceof AbstractOrderedLayout) {
+ AbstractOrderedLayout ol = (AbstractOrderedLayout) parent;
+ int orientation = OrderedLayout.ORIENTATION_HORIZONTAL;
+
+ if (ol instanceof OrderedLayout) {
+ orientation = ((OrderedLayout) ol).getOrientation();
+ } else if (ol instanceof VerticalLayout) {
+ orientation = OrderedLayout.ORIENTATION_VERTICAL;
+ }
+
+ if (orientation == OrderedLayout.ORIENTATION_VERTICAL) {
msg = "Relative height for component inside non sized vertical ordered layout.";
attributes = getHeightAttributes(component);
} else if (!hasNonRelativeHeightComponent(ol)) {
@@ -124,7 +138,7 @@ public class DebugUtilities {
}
if (msg != null) {
- showError(msg, attributes);
+ showError(msg, attributes, false);
}
return (msg == null);
@@ -136,9 +150,17 @@ public class DebugUtilities {
Stack<ComponentInfo> attributes = null;
if (hasRelativeWidth(component) && hasUndefinedWidth(parent)) {
- if (parent instanceof OrderedLayout) {
- OrderedLayout ol = (OrderedLayout) parent;
- if (ol.getOrientation() == OrderedLayout.ORIENTATION_HORIZONTAL) {
+ if (parent instanceof AbstractOrderedLayout) {
+ AbstractOrderedLayout ol = (AbstractOrderedLayout) parent;
+ int orientation = OrderedLayout.ORIENTATION_HORIZONTAL;
+
+ if (ol instanceof OrderedLayout) {
+ orientation = ((OrderedLayout) ol).getOrientation();
+ } else if (ol instanceof VerticalLayout) {
+ orientation = OrderedLayout.ORIENTATION_VERTICAL;
+ }
+
+ if (orientation == OrderedLayout.ORIENTATION_HORIZONTAL) {
msg = "Relative width for component inside non sized horizontal ordered layout.";
attributes = getWidthAttributes(component);
} else if (!hasNonRelativeWidthComponent(ol)) {
@@ -174,7 +196,7 @@ public class DebugUtilities {
}
if (msg != null) {
- showError(msg, attributes);
+ showError(msg, attributes, true);
}
return (msg == null);
@@ -251,17 +273,26 @@ public class DebugUtilities {
}
private static void showComponent(Component component, String attribute,
- StringBuffer err, StringBuilder indent) {
+ StringBuffer err, StringBuilder indent, boolean widthError) {
+
+ FileLocation createLoc = creationLocations.get(component);
+
+ FileLocation sizeLoc;
+ if (widthError) {
+ sizeLoc = widthLocations.get(component);
+ } else {
+ sizeLoc = heightLocations.get(component);
+ }
+
err.append(indent);
indent.append(" ");
err.append("- ");
err.append(component.getClass().getSimpleName());
err.append("/").append(Integer.toHexString(component.hashCode()));
- err.append(" (");
if (component.getCaption() != null) {
- err.append("\"");
+ err.append(" \"");
err.append(component.getCaption());
err.append("\"");
}
@@ -271,10 +302,20 @@ public class DebugUtilities {
err.append(component.getDebugId());
}
- err.append(")");
+ if (createLoc != null) {
+ err.append(", created at (" + createLoc.file + ":"
+ + createLoc.lineNumber + ")");
+
+ }
+
if (attribute != null) {
err.append(" (");
err.append(attribute);
+ if (sizeLoc != null) {
+ err.append(", set at (" + sizeLoc.file + ":"
+ + sizeLoc.lineNumber + ")");
+ }
+
err.append(")");
}
err.append("\n");
@@ -285,7 +326,8 @@ public class DebugUtilities {
return component.getHeight() + " %";
}
- private static boolean hasNonRelativeHeightComponent(OrderedLayout ol) {
+ private static boolean hasNonRelativeHeightComponent(
+ AbstractOrderedLayout ol) {
Iterator it = ol.getComponentIterator();
while (it.hasNext()) {
if (!hasRelativeHeight((Component) it.next())) {
@@ -319,7 +361,7 @@ public class DebugUtilities {
.getHeight() > 0);
}
- private static boolean hasNonRelativeWidthComponent(OrderedLayout ol) {
+ private static boolean hasNonRelativeWidthComponent(AbstractOrderedLayout ol) {
Iterator it = ol.getComponentIterator();
while (it.hasNext()) {
if (!hasRelativeWidth((Component) it.next())) {
@@ -355,4 +397,68 @@ public class DebugUtilities {
}
+ private static Map<Object, FileLocation> creationLocations = new HashMap<Object, FileLocation>();
+ private static Map<Object, FileLocation> widthLocations = new HashMap<Object, FileLocation>();
+ private static Map<Object, FileLocation> heightLocations = new HashMap<Object, FileLocation>();
+
+ public static class FileLocation {
+ public String method;
+ public String file;
+ public String className;
+ public String classNameSimple;
+ public int lineNumber;
+
+ public FileLocation(StackTraceElement traceElement) {
+ file = traceElement.getFileName();
+ className = traceElement.getClassName();
+ classNameSimple = className
+ .substring(className.lastIndexOf('.') + 1);
+ lineNumber = traceElement.getLineNumber();
+ method = traceElement.getMethodName();
+ }
+ }
+
+ public static void setCreationLocation(Object object) {
+ setLocation(creationLocations, object);
+ }
+
+ public static void setWidthLocation(Object object) {
+ setLocation(widthLocations, object);
+ }
+
+ public static void setHeightLocation(Object object) {
+ setLocation(heightLocations, object);
+ }
+
+ private static void setLocation(Map<Object, FileLocation> map, Object object) {
+ StackTraceElement[] traceLines = Thread.currentThread().getStackTrace();
+ for (StackTraceElement traceElement : traceLines) {
+ Class cls;
+ try {
+ String className = traceElement.getClassName();
+ if (className.startsWith("java.")
+ || className.startsWith("sun.")) {
+ continue;
+ }
+
+ cls = Class.forName(className);
+ if (cls == DebugUtilities.class || cls == Thread.class) {
+ continue;
+ }
+
+ if (Component.class.isAssignableFrom(cls)
+ && !CustomComponent.class.isAssignableFrom(cls)) {
+ continue;
+ }
+ FileLocation cl = new FileLocation(traceElement);
+ map.put(object, cl);
+ return;
+ } catch (Exception e) {
+ // TODO Auto-generated catch block
+ e.printStackTrace();
+ }
+
+ }
+ }
+
}