summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorLeif Åstrand <leif@vaadin.com>2013-04-22 16:49:10 +0300
committerVaadin Code Review <review@vaadin.com>2013-04-23 13:15:12 +0000
commit8700691bece5642617d0b031ebc6c5ab33a2118e (patch)
tree74fd3d1aa22372646e6f9df1d576f34992ec7f90
parent33e114bd3bb6e764e0e503a69c305ec4322aaa6a (diff)
downloadvaadin-framework-8700691bece5642617d0b031ebc6c5ab33a2118e.tar.gz
vaadin-framework-8700691bece5642617d0b031ebc6c5ab33a2118e.zip
Use java.util.logging for the debug window (#11657)
Change-Id: I1c3e49591253244948d8ce15c8d05170dd49a03a
-rw-r--r--client/src/com/vaadin/Vaadin.gwt.xml8
-rw-r--r--client/src/com/vaadin/client/debug/internal/ConsoleAdapter.java17
-rw-r--r--client/src/com/vaadin/client/debug/internal/HierarchySection.java5
-rw-r--r--client/src/com/vaadin/client/debug/internal/Level.java26
-rw-r--r--client/src/com/vaadin/client/debug/internal/LogSection.java79
-rw-r--r--client/src/com/vaadin/client/debug/internal/NetworkSection.java5
-rw-r--r--client/src/com/vaadin/client/debug/internal/Section.java2
-rw-r--r--client/src/com/vaadin/client/debug/internal/VDebugWindow.java24
8 files changed, 73 insertions, 93 deletions
diff --git a/client/src/com/vaadin/Vaadin.gwt.xml b/client/src/com/vaadin/Vaadin.gwt.xml
index 6529743503..7316a77292 100644
--- a/client/src/com/vaadin/Vaadin.gwt.xml
+++ b/client/src/com/vaadin/Vaadin.gwt.xml
@@ -12,7 +12,13 @@
<inherits name="com.google.gwt.http.HTTP" />
<inherits name="com.google.gwt.json.JSON" />
-
+
+ <inherits name="com.google.gwt.logging.Logging" />
+ <!-- Firebug handler is deprecated but for some reason still enabled by default -->
+ <set-property name="gwt.logging.firebugHandler" value="DISABLED" />
+ <!-- Disable popup logging as we have our own popup logger -->
+ <set-property name="gwt.logging.popupHandler" value="DISABLED" />
+
<inherits name="com.vaadin.VaadinBrowserSpecificOverrides" />
<source path="client" />
diff --git a/client/src/com/vaadin/client/debug/internal/ConsoleAdapter.java b/client/src/com/vaadin/client/debug/internal/ConsoleAdapter.java
index 4b9e831ec5..9397e27906 100644
--- a/client/src/com/vaadin/client/debug/internal/ConsoleAdapter.java
+++ b/client/src/com/vaadin/client/debug/internal/ConsoleAdapter.java
@@ -16,6 +16,8 @@
package com.vaadin.client.debug.internal;
import java.util.Set;
+import java.util.logging.Level;
+import java.util.logging.Logger;
import com.google.gwt.core.shared.GWT;
import com.google.gwt.event.shared.UmbrellaException;
@@ -51,11 +53,7 @@ public class ConsoleAdapter implements Console {
@Override
public void log(String msg) {
- window.log(Level.LOG, msg);
-
- GWT.log(msg);
- consoleLog(msg);
- System.out.println(msg);
+ getLogger().log(Level.INFO, msg);
}
@Override
@@ -81,11 +79,8 @@ public class ConsoleAdapter implements Console {
if (msg == null) {
msg = "null";
}
- window.log(Level.ERROR, msg);
- GWT.log(msg);
- consoleErr(msg);
- System.out.println(msg);
+ getLogger().log(Level.SEVERE, msg);
}
@Override
@@ -187,4 +182,8 @@ public class ConsoleAdapter implements Console {
$wnd.console.log(msg);
}
}-*/;
+
+ private static Logger getLogger() {
+ return Logger.getLogger(ConsoleAdapter.class.getName());
+ }
}
diff --git a/client/src/com/vaadin/client/debug/internal/HierarchySection.java b/client/src/com/vaadin/client/debug/internal/HierarchySection.java
index 7b43f551e3..b09038cf97 100644
--- a/client/src/com/vaadin/client/debug/internal/HierarchySection.java
+++ b/client/src/com/vaadin/client/debug/internal/HierarchySection.java
@@ -146,11 +146,6 @@ class HierarchySection implements Section {
stopFind();
}
- @Override
- public void log(Level level, String msg) {
- // NOP
- }
-
private void generateWidgetset() {
content.clear();
diff --git a/client/src/com/vaadin/client/debug/internal/Level.java b/client/src/com/vaadin/client/debug/internal/Level.java
deleted file mode 100644
index 3ce314d5cb..0000000000
--- a/client/src/com/vaadin/client/debug/internal/Level.java
+++ /dev/null
@@ -1,26 +0,0 @@
-/*
- * Copyright 2000-2013 Vaadin Ltd.
- *
- * Licensed under the Apache License, Version 2.0 (the "License"); you may not
- * use this file except in compliance with the License. You may obtain a copy of
- * the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
- * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
- * License for the specific language governing permissions and limitations under
- * the License.
- */
-package com.vaadin.client.debug.internal;
-
-/**
- * Log level for debug messages.
- *
- * @since 7.1
- * @author Vaadin Ltd
- */
-enum Level {
- DEBUG, LOG, WARNING, ERROR
-}
diff --git a/client/src/com/vaadin/client/debug/internal/LogSection.java b/client/src/com/vaadin/client/debug/internal/LogSection.java
index 0285524558..105ef55c32 100644
--- a/client/src/com/vaadin/client/debug/internal/LogSection.java
+++ b/client/src/com/vaadin/client/debug/internal/LogSection.java
@@ -15,9 +15,16 @@
*/
package com.vaadin.client.debug.internal;
+import java.util.logging.Formatter;
+import java.util.logging.Handler;
+import java.util.logging.Level;
+import java.util.logging.LogRecord;
+import java.util.logging.Logger;
+
import com.google.gwt.dom.client.Element;
import com.google.gwt.event.dom.client.ClickEvent;
import com.google.gwt.event.dom.client.ClickHandler;
+import com.google.gwt.logging.client.HtmlLogFormatter;
import com.google.gwt.storage.client.Storage;
import com.google.gwt.user.client.DOM;
import com.google.gwt.user.client.Timer;
@@ -39,6 +46,50 @@ import com.vaadin.client.ValueMap;
*/
class LogSection implements Section {
+ private final class LogSectionHandler extends Handler {
+ private LogSectionHandler() {
+ setLevel(Level.ALL);
+ setFormatter(new HtmlLogFormatter(true) {
+ @Override
+ protected String getHtmlPrefix(LogRecord event) {
+ return "";
+ }
+
+ @Override
+ protected String getHtmlSuffix(LogRecord event) {
+ return "";
+ }
+
+ @Override
+ protected String getRecordInfo(LogRecord event, String newline) {
+ return "";
+ }
+ });
+ }
+
+ @Override
+ public void publish(LogRecord record) {
+ if (!isLoggable(record)) {
+ return;
+ }
+
+ Formatter formatter = getFormatter();
+ String msg = formatter.format(record);
+
+ addRow(record.getLevel(), msg);
+ }
+
+ @Override
+ public void close() {
+ // Nothing to do
+ }
+
+ @Override
+ public void flush() {
+ // Nothing todo
+ }
+ }
+
// If scroll is not locked, content will be scrolled after delay
private static final int SCROLL_DELAY = 100;
private Timer scrollTimer = null;
@@ -112,6 +163,8 @@ class LogSection implements Section {
}
});
+ // Add handler to the root logger
+ Logger.getLogger("").addHandler(new LogSectionHandler());
}
/**
@@ -262,20 +315,19 @@ class LogSection implements Section {
* needed, and scrolls new row into view if scroll lock is not active.
*
* @param level
- * @param category
* @param msg
* @return
*/
- private Element addRow(Level level, String category, String msg) {
+ private Element addRow(Level level, String msg) {
int sinceReset = VDebugWindow.getMillisSinceReset();
int sinceStart = VDebugWindow.getMillisSinceStart();
Element row = DOM.createDiv();
row.addClassName(VDebugWindow.STYLENAME + "-row");
- row.addClassName(level.name());
+ row.addClassName(level.getName());
String inner = "<span class='" + VDebugWindow.STYLENAME + "-"
- + category + "'></span><span class='" + VDebugWindow.STYLENAME
+ + "'></span><span class='" + VDebugWindow.STYLENAME
+ "-time' title='"
+ VDebugWindow.getTimingTooltip(sinceStart, sinceReset) + "'>"
+ sinceReset + "ms</span><span class='"
@@ -290,29 +342,14 @@ class LogSection implements Section {
return row;
}
- /*
- * LOGGING methods follow.
- *
- * NOTE that these are still subject to change.
- */
-
- @Override
- public void log(Level level, String msg) {
- addRow(level, "none", msg);
- }
-
- public void log(Level level, String category, String msg) {
- addRow(level, category, msg);
- }
-
@Override
public void meta(ApplicationConnection ac, ValueMap meta) {
- log(Level.DEBUG, "Meta: " + meta.toSource());
+ addRow(Level.FINE, "Meta: " + meta.toSource());
}
@Override
public void uidl(ApplicationConnection ac, ValueMap uidl) {
- log(Level.DEBUG, "UIDL: " + uidl.toSource());
+ addRow(Level.FINE, "UIDL: " + uidl.toSource());
}
} \ No newline at end of file
diff --git a/client/src/com/vaadin/client/debug/internal/NetworkSection.java b/client/src/com/vaadin/client/debug/internal/NetworkSection.java
index ebdeff810f..e94791ce1f 100644
--- a/client/src/com/vaadin/client/debug/internal/NetworkSection.java
+++ b/client/src/com/vaadin/client/debug/internal/NetworkSection.java
@@ -68,11 +68,6 @@ public class NetworkSection implements Section {
}
@Override
- public void log(Level level, String msg) {
- // NOP
- }
-
- @Override
public void meta(ApplicationConnection ac, ValueMap meta) {
// NOP
}
diff --git a/client/src/com/vaadin/client/debug/internal/Section.java b/client/src/com/vaadin/client/debug/internal/Section.java
index 7c662bc035..c6b8af55e8 100644
--- a/client/src/com/vaadin/client/debug/internal/Section.java
+++ b/client/src/com/vaadin/client/debug/internal/Section.java
@@ -70,8 +70,6 @@ public interface Section {
*/
public void hide();
- public void log(Level level, String msg);
-
public void meta(ApplicationConnection ac, ValueMap meta);
public void uidl(ApplicationConnection ac, ValueMap uidl);
diff --git a/client/src/com/vaadin/client/debug/internal/VDebugWindow.java b/client/src/com/vaadin/client/debug/internal/VDebugWindow.java
index 86de1884ef..a7e22420b7 100644
--- a/client/src/com/vaadin/client/debug/internal/VDebugWindow.java
+++ b/client/src/com/vaadin/client/debug/internal/VDebugWindow.java
@@ -684,30 +684,6 @@ public final class VDebugWindow extends VOverlay {
});
}
- /*
- * LOGGING methods follow
- *
- * NOTE that these are subject to change and only implemented in the current
- * manner for compatibility.
- *
- * TODO Sections should listen to logging events in the future
- */
-
- /**
- * Called when a generic logging message is received
- *
- * @param level
- * @param msg
- */
- void log(Level level, String msg) {
- if (isClosed()) {
- return;
- }
- for (Section s : sections) {
- s.log(level, msg);
- }
- }
-
/**
* Called when the result from analyzeLayouts is received.
*