summaryrefslogtreecommitdiff
path: root/webapps/qooxdoo-0.6.3-sdk/frontend/framework/source/class/qx/dev/log/AlertAppender.js
blob: d800ac13ae05f607ea78a43a85286f91bf3053c2 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
/* ************************************************************************

   qooxdoo - the new era of web development

   http://qooxdoo.org

   Copyright:
     2004-2006 by 1&1 Internet AG, Germany, http://www.1and1.org
     2006 by STZ-IDA, Germany, http://www.stz-ida.de

   License:
     LGPL 2.1: http://www.gnu.org/licenses/lgpl.html

   Authors:
     * Andreas Ecker (ecker)
     * Til Schneider (til132)

************************************************************************ */

/* ************************************************************************

#module(log)

************************************************************************ */

/**
 * An appender that writes each message to a native alert().
 * <p>
 * This class does not depend on qooxdoo widgets, so it also works when there
 * are problems with widgets or when the widgets are not yet initialized.
 * <p>
 * It allows to go through the log messages step-by-step, since the alert
 * window temporarily halts the regular program execution. That way even
 * the dispose process can easily be debugged.
 */
qx.OO.defineClass("qx.dev.log.AlertAppender", qx.dev.log.Appender,
function() {
  qx.dev.log.Appender.call(this);
});


// overridden
qx.OO.changeProperty({ name:"useLongFormat", type:"boolean", defaultValue:false, allowNull:false });

// overridden
qx.Proto.appendLogEvent = function(evt) {

  // Append the message
  var text = evt.logger.getName();
  if (evt.instanceId != null) {
     text += " (" + evt.instanceId + ")";
  }

  alert("\n" + text + "\n" + this.formatLogEvent(evt));
}


// overridden
qx.Proto.dispose = function() {
  if (this.getDisposed()) {
      return true;
  }

  return qx.dev.log.Appender.prototype.dispose.call(this);
}