diff options
author | Tobi Oetiker <tobi@oetiker.ch> | 2008-11-06 15:40:55 +0100 |
---|---|---|
committer | Tobi Oetiker <tobi@oetiker.ch> | 2008-11-06 15:40:55 +0100 |
commit | d8b465e26599268b8eded0732e8f29062556997e (patch) | |
tree | f9ffd0443aa616eb4df1b461684f4aeeb53fb7b2 /qx08/source/class/tr/ui | |
parent | 996d9e92e597bc462d874b335865ff7844e2d332 (diff) | |
download | smokeping-d8b465e26599268b8eded0732e8f29062556997e.tar.gz smokeping-d8b465e26599268b8eded0732e8f29062556997e.tar.xz |
initial commit
Diffstat (limited to 'qx08/source/class/tr/ui')
-rw-r--r-- | qx08/source/class/tr/ui/ActionButton.js | 271 | ||||
-rw-r--r-- | qx08/source/class/tr/ui/Cellrenderer.js | 43 | ||||
-rw-r--r-- | qx08/source/class/tr/ui/Config.js | 196 | ||||
-rw-r--r-- | qx08/source/class/tr/ui/Footer.js | 45 | ||||
-rw-r--r-- | qx08/source/class/tr/ui/Link.js | 54 | ||||
-rw-r--r-- | qx08/source/class/tr/ui/TraceTable.js | 321 |
6 files changed, 641 insertions, 289 deletions
diff --git a/qx08/source/class/tr/ui/ActionButton.js b/qx08/source/class/tr/ui/ActionButton.js index 5d6eb5d..6b91e5d 100644 --- a/qx08/source/class/tr/ui/ActionButton.js +++ b/qx08/source/class/tr/ui/ActionButton.js @@ -5,192 +5,235 @@ /** * a widget showing the Tr graph overview */ +qx.Class.define('tr.ui.ActionButton', { + extend : qx.ui.container.Composite, + + -qx.Class.define('Tr.ui.ActionButton', -{ - extend: qx.ui.Containter. /* - ***************************************************************************** - CONSTRUCTOR - ***************************************************************************** - */ - - construct: function () { - this.base(arguments); - - this.set({ - height: 'auto', - width: 'auto', - horizontalChildrenAlign: 'left' - }); - var hbox = new qx.ui.layout.HorizontalBoxLayout; - hbox.set({ - height: 'auto', - width: 'auto', - verticalChildrenAlign: 'middle' - }); + ***************************************************************************** + CONSTRUCTOR + ***************************************************************************** + */ + + construct : function() { + this.base(arguments, new qx.ui.layout.VBox); + + // this.set({ alignX : 'left' }); + // return this; + var hbox = new qx.ui.container.Composite(new qx.ui.layout.HBox().set({ + alignY : 'middle', + spacing : 5 + })); + var lab1 = new qx.ui.basic.Label(this.tr("Host")); - lab1.set({ - paddingRight: 6 - }); + lab1.set({ paddingRight : 6 }); hbox.add(lab1); var host = new qx.ui.form.TextField(); + host.set({ - width: 200, - height: 'auto', - border: 'dark-shadow', - padding: 1 + width : 200, + padding : 1 }); + hbox.add(host); this.__host = host; var lab2 = new qx.ui.basic.Label(this.tr("Delay")); + lab2.set({ - paddingRight: 6, - paddingLeft: 12 + paddingRight : 6, + paddingLeft : 12 }); + hbox.add(lab2); - var delay = new qx.ui.form.Spinner(1,2,60); - delay.set({ - border: 'dark-shadow', - width: 45 - }); + + var delay = new qx.ui.form.Spinner(0, 2, 60); + + delay.set({ width : 45 }); hbox.add(delay); this.__delay = delay; var lab3 = new qx.ui.basic.Label(this.tr("Rounds")); + lab3.set({ - paddingRight: 6, - paddingLeft: 12 + paddingRight : 6, + paddingLeft : 12 }); + hbox.add(lab3); - var rounds = new qx.ui.form.Spinner(1,20,200); - rounds.set({ - border: 'dark-shadow', - width: 45 - }); + var rounds = new qx.ui.form.Spinner(0, 20, 200); + + rounds.set({ width : 45 }); + hbox.add(rounds); this.__rounds = rounds; var button = new qx.ui.form.Button(''); this.__button = button; - button.set({ - marginLeft: 10, - width: 60, - height: 'auto', - border: 'dark-shadow', - padding: 2 + + button.set({ + marginLeft : 10, + width : 60, + padding : 2, + center : true }); + hbox.add(button); + + var config = new qx.ui.form.Button(this.tr("Config ...")); + hbox.add(config); + + config.addListener('execute', function(e) { + qx.event.message.Bus.dispatch('tr.config', 'open'); + }); + this.add(hbox); + var info = new qx.ui.basic.Atom(); + info.set({ - marginTop: 3, - padding: 3, - textColor: 'red', - width: '100%', - height: 'auto', - backgroundColor: '#f0f0f0', - visibility: false - }); - qx.event.message.Bus.subscribe('tr.info',this.__set_info,this); + marginTop : 3, + padding : 3, + textColor : 'red', + backgroundColor : '#f0f0f0', + visibility : 'hidden' + }); + + qx.event.message.Bus.subscribe('tr.info', this.__set_info, this); this.add(info); this.__info = info; - qx.event.message.Bus.subscribe('tr.status',this.__set_status,this); - qx.event.message.Bus.dispatch('tr.status','stopped'); - - var start_trace = function(event) { - qx.event.message.Bus.dispatch('tr.cmd',{ - action: button.getUserData('action'), - host: host.getValue(), - delay: delay.getValue(), - rounds: rounds.getValue() + qx.event.message.Bus.subscribe('tr.status', this.__set_status, this); + qx.event.message.Bus.dispatch('tr.status', 'stopped'); + + var start_trace = function(event) { + qx.event.message.Bus.dispatch('tr.cmd', { + action : button.getUserData('action'), + host : host.getValue(), + delay : delay.getValue(), + rounds : rounds.getValue() }); - }; + }; + + host.addListener('keydown', function(e) { + if (e.getKeyIdentifier() == 'Enter') { + start_trace(); + } + }); -// var self=this; -// host.addEventListener('keyup',function(e){if(e.getKeyIdentifier() == 'Enter'){start_trace()}}); - host.addEventListener('execute',start_trace); - button.addEventListener('execute', start_trace ); + // host.addListener('execute', start_trace); + button.addListener('execute', start_trace); - var history = qx.client.History.getInstance(); - var history_action = function(event){ + var history = qx.bom.History.getInstance(); + + var history_action = function(event) { var targ = event.getData(); host.setValue(targ); - history.addToHistory(targ,'SmokeTrace to '+targ); - start_trace(); - } - history.addEventListener('request', history_action); + history.addToHistory(targ, 'SmokeTrace to ' + targ); + start_trace(); + }; + + history.addListener('request', history_action); // if we got called with a host on the commandline - var initial_host = qx.client.History.getInstance().getState(); - if (initial_host){ + var initial_host = qx.bom.History.getInstance().getState(); + + if (initial_host) { host.setValue(initial_host); - history.addToHistory(initial_host,'SmokeTrace to '+initial_host); + history.addToHistory(initial_host, 'SmokeTrace to ' + initial_host); + // dispatch this task once all the initializations are done - qx.client.Timer.once(start_trace,this,0); - } + qx.event.Timer.once(start_trace, this, 0); + } }, - members: { - __set_info: function(e){ + members : { + __host : null, + __delay : null, + __rounds : null, + __button : null, + __info : null, + + + /** + * TODOC + * + * @type member + * @param e {Event} TODOC + * @return {void} + */ + __set_info : function(e) { this.__info.set({ - label: e.getData(), - visibility: true + label : e.getData(), + visibility : 'visible' }); }, - __set_status: function(m){ + + + /** + * TODOC + * + * @type member + * @param m {var} TODOC + * @return {void} + */ + __set_status : function(m) { var host = this.__host; var rounds = this.__rounds; var delay = this.__delay; - with(this.__button){ - // this.debug(m.getData()); - switch(m.getData()){ + var button = this.__button; + var action = button.getUserData('action'); + + // this.debug(m.getData()); + switch(m.getData()) + { case 'starting': - if (getUserData('action') == 'go') { - setLabel(this.tr("Starting")); - this.__info.setVisibility(false); - border: 'dark-shadow' - setEnabled(false); + if (action == 'go') { + button.setLabel(this.tr("Starting")); + this.__info.setVisibility('hidden'); + + // border:'dark-shadow', + button.setEnabled(false); host.setEnabled(false); rounds.setEnabled(false); delay.setEnabled(false); } + break; + case 'stopping': - if (getUserData('action') == 'stop') { - setLabel(this.tr("Stopping")); - setEnabled(false); + if (action == 'stop') { + button.setLabel(this.tr("Stopping")); + button.setEnabled(false); host.setEnabled(false); rounds.setEnabled(false); delay.setEnabled(false); } + break; + case 'stopped': - setUserData('action','go'); - setLabel(this.tr("Go")); - setEnabled(true); + button.setUserData('action', 'go'); + button.setLabel(this.tr("Go")); + button.setEnabled(true); host.setEnabled(true); rounds.setEnabled(true); delay.setEnabled(true); break; + case 'started': - setUserData('action','stop'); - setLabel(this.tr("Stop")); - setEnabled(true); + button.setUserData('action', 'stop'); + button.setLabel(this.tr("Stop")); + button.setEnabled(true); host.setEnabled(false); rounds.setEnabled(false); delay.setEnabled(false); break; + default: - alert('Unknown Status Message: '+m.getData()); - } + this.error('Unknown Status Message: ' + m.getData()); } - } - } - - -}); - - + } + } +});
\ No newline at end of file diff --git a/qx08/source/class/tr/ui/Cellrenderer.js b/qx08/source/class/tr/ui/Cellrenderer.js index f18672d..6a89da9 100644 --- a/qx08/source/class/tr/ui/Cellrenderer.js +++ b/qx08/source/class/tr/ui/Cellrenderer.js @@ -6,6 +6,7 @@ * Tobias Oetiker ************************************************************************ */ + /* ************************************************************************ #module(Tr) ************************************************************************ */ @@ -13,34 +14,38 @@ /** * A configurable cell renderre */ +qx.Class.define('tr.ui.Cellrenderer', { + extend : qx.ui.table.cellrenderer.Number, + -qx.Class.define('Tr.ui.Cellrenderer', -{ - extend: qx.ui.table.cellrenderer.Number, /** - * Format a number with a configurable number of fraction digits - * and add optional pre and postfix. - * @param digits {Integer} how many digits should there be. Default is 0. - * @param prefix {String} optional prefix. - * @param postfix {String} optional postfix. - */ - - construct: function (digits,postfix,prefix) { - if (digits == undefined){ + * Format a number with a configurable number of fraction digits + * and add optional pre and postfix. + * @param digits {Integer} how many digits should there be. Default is 0. + * @param prefix {String} optional prefix. + * @param postfix {String} optional postfix. + */ + construct : function(digits, postfix, prefix) { + if (digits == undefined) { digits = 0; } - this.base(arguments) + + this.base(arguments); var format = new qx.util.format.NumberFormat(); + format.set({ - maximumFractionDigits: digits, - minimumFractionDigits: digits + maximumFractionDigits : digits, + minimumFractionDigits : digits }); - if (postfix != undefined){ + + if (postfix != undefined) { format.setPostfix(postfix); } - if (prefix != undefined){ + + if (prefix != undefined) { format.setPrefix(prefix); - } + } + this.setNumberFormat(format); } -}); +});
\ No newline at end of file diff --git a/qx08/source/class/tr/ui/Config.js b/qx08/source/class/tr/ui/Config.js new file mode 100644 index 0000000..5d264d2 --- /dev/null +++ b/qx08/source/class/tr/ui/Config.js @@ -0,0 +1,196 @@ +/* ************************************************************************ +#module(Tr) +#asset(qx/icon/${qx.icontheme}/22/actions/dialog-apply.png) +#asset(qx/icon/${qx.icontheme}/22/actions/dialog-close.png) + +************************************************************************ */ + +/** + * show the config options for traceroute as defined by the server + */ +qx.Class.define('tr.ui.Config', { + extend : qx.ui.window.Window, + + + + + /* + ***************************************************************************** + CONSTRUCTOR + ***************************************************************************** + */ + + construct : function() { + this.base(arguments, this.tr("Traceroute Configuration")); + var layout = new qx.ui.layout.Grid(3, 5); + layout.setColumnAlign(0, 'right', 'middle'); + layout.setColumnAlign(1, 'left', 'middle'); + layout.setColumnWidth(0, 140); + layout.setColumnWidth(1, 140); + + this.setLayout(layout); + + this.set({ + allowMaximize : false, + allowMinimize : false, + modal : true, + resizable : false, + showMaximize : false, + showMinimize : false + }); + + var self = this; + + var create_config = function(retval, exc, id) { + if (exc == null) { + self.__create_config(retval); + } else { + self.error(exc); + } + }; + + tr.Server.getInstance().callAsync(create_config, 'get_config'); + }, + + members : { + /** + * TODOC + * + * @type member + * @param data {var} TODOC + * @return {void} + */ + __create_config : function(data) { + var entries = data.length; + var status = {}; + var setdef = {}; + var r = 0; + var self = this; + + for (var k=0; k<entries; k+=2) { + (function() {* // force local scoping + var v = k + 1; + + for (var check in + { + 'default' : 0, + 'label' : 0, + 'type' : 0 + }) { + if (data[v][check] == undefined) { + self.debug('Skipping ' + data[k] + ' since there is no ' + check); + return ;* // we are inside a function, so we return instead of continue + } + } + + var def = data[v]['default']; + var widget; + var pick; + var items; + var check; + var c; + + self.add(new qx.ui.basic.Label(data[v]['label']).set({ marginRight : 5 }), { + row : r, + column : 0 + }); + + switch(data[v]['type']) + { + case 'spinner': + widget = new qx.ui.form.Spinner(data[v]['min'], def, data[v]['max']); + status[data[k]] = function() { + return widget.getValue(); + }; + + setdef[data[k]] = function() { + widget.setValue(def); + }; + + break; + + case 'select': + widget = new qx.ui.form.SelectBox(); + status[data[k]] = function() { + return widget.getValue(); + }; + + setdef[data[k]] = function() { + widget.setValue(def); + }; + + pick = data[v]['pick']; + items = pick.length; + + for (c=0; c<items; c+=2) { + widget.add(new qx.ui.form.ListItem(pick[c + 1], null, pick[c])); + } + + break; + + case 'boolean': + widget = new qx.ui.form.CheckBox(); + status[data[k]] = function() { + return widget.getChecked(); + }; + + setdef[data[k]] = function() { + widget.setChecked(def > 0); + }; + + break; + } + + self.add(widget, { + row : r, + column : 1 + }); + + r++; + })(); + + }* // this is the rest of the scoping trick + + for (var key in setdef) { + setdef[key](); + } + + var ok = new qx.ui.form.Button(this.tr("Apply")).set({ + marginTop : 10, + marginLeft : 20 + }); + + ok.addListener('execute', function(e) { + var config = {}; + + for (var key in status) { + config[key] = status[key](); + } + + self.close(); + qx.event.message.Bus.dispatch('tr.setup', config); + }); + + this.add(ok, { + row : r, + column : 0 + }); + + var cancel = new qx.ui.form.Button(this.tr("Reset")).set({ + marginTop : 10, + marginRight : 20 + }); + + cancel.addListener('execute', function(e) { + for (var key in setdef) { + setdef[key](); + } + }); + + this.add(cancel, { + row : r, + column : 1 + }); + } + } +});
\ No newline at end of file diff --git a/qx08/source/class/tr/ui/Footer.js b/qx08/source/class/tr/ui/Footer.js index 1882043..6b77aa3 100644 --- a/qx08/source/class/tr/ui/Footer.js +++ b/qx08/source/class/tr/ui/Footer.js @@ -5,41 +5,20 @@ /** * a widget showing the footer */ +qx.Class.define('tr.ui.Footer', { + extend : qx.ui.container.Composite, + + -qx.Class.define('Tr.ui.Footer', -{ - extend: qx.ui.layout.HorizontalBoxLayout, /* - ***************************************************************************** - CONSTRUCTOR - ***************************************************************************** - */ + ***************************************************************************** + CONSTRUCTOR + ***************************************************************************** + */ - construct: function (text,url) { - this.base(arguments); - this.set({ - horizontalChildrenAlign: 'right', - height: 'auto' - }); - var logo = new qx.ui.form.Button(text); - logo.set({ - textColor: '#b0b0b0', - backgroundColor: null, - font: qx.ui.core.Font.fromString('10px sans-serif'), - border: null - }); - - logo.addEventListener('execute', function(e){ - var w = new qx.client.NativeWindow(url); - w.set({ - width: 1000, - height: 800 - }); - w.open() - }); - this.add(logo); + construct : function(text, url) { + this.base(arguments, new qx.ui.layout.HBox().set({ alignX : 'right' })); + this.add(new tr.ui.Link(text, url, '#888', '10px sans-serif')); } -}); - - +});
\ No newline at end of file diff --git a/qx08/source/class/tr/ui/Link.js b/qx08/source/class/tr/ui/Link.js new file mode 100644 index 0000000..dd7f33e --- /dev/null +++ b/qx08/source/class/tr/ui/Link.js @@ -0,0 +1,54 @@ +/* ************************************************************************ +#module(Tr) +************************************************************************ */ + +/** + * A label with the ability to link out. Based on Label. + */ +qx.Class.define('tr.ui.Link', { + extend : qx.ui.basic.Label, + + + + + /* + ***************************************************************************** + CONSTRUCTOR + ***************************************************************************** + */ + + /** + * @param text {String} Initial label + * @param url {String} Where to link to + * @param color {String} Hex Color for the text + * @param font {String} Font from string representation + */ + construct : function(text, url, color, font) { + this.base(arguments, text); + + if (color) { + this.setTextColor(color); + } + + if (font) { + this.setFont(qx.bom.Font.fromString(font)); + } + + this.set({ + cursor : 'pointer', + opacity : 0.9 + }); + + this.addListener('click', function(e) { + window.open(url, '__new'); + }); + + this.addListener('mouseover', function(e) { + this.setOpacity(1); + }, this); + + this.addListener('mouseout', function(e) { + this.setOpacity(0.7); + }, this); + } +});
\ No newline at end of file diff --git a/qx08/source/class/tr/ui/TraceTable.js b/qx08/source/class/tr/ui/TraceTable.js index 446cbad..2291c2c 100644 --- a/qx08/source/class/tr/ui/TraceTable.js +++ b/qx08/source/class/tr/ui/TraceTable.js @@ -5,210 +5,285 @@ /** * a widget showing the Tr target tree */ +qx.Class.define('tr.ui.TraceTable', { + extend : qx.ui.table.Table, + + -qx.Class.define('Tr.ui.TraceTable', -{ - extend: qx.ui.table.Table, /* - ***************************************************************************** + ***************************************************************************** CONSTRUCTOR - ***************************************************************************** - */ + ***************************************************************************** + */ - - construct: function () { - + construct : function() { var tableModel = new qx.ui.table.model.Simple(); this.__tableModel = tableModel; - tableModel.setColumns([ this.tr("Hop"), this.tr("Host"),this.tr("Ip"), - this.tr("Loss [%]"), this.tr("Sent"), this.tr("Last [ms]"), //"; help syntax highliter - this.tr("Avg [ms]"), this.tr("Best [ms]"), this.tr("Worst [ms]"), this.tr("StDev [ms]") ]); + + tableModel.setColumns([ this.tr("Hop"), this.tr("Host"), this.tr("Ip"), this.tr("Loss [%]"), this.tr("Sent"), this.tr("Last [ms]"), * // "; help syntax highliter + this.tr("Avg [ms]"), this.tr("Best [ms]"), this.tr("Worst [ms]"), this.tr("StDev [ms]") ]); + var custom = { - tableColumnModel: function(obj) { + tableColumnModel : function(obj) { return new qx.ui.table.columnmodel.Resize(obj); } }; - with(this){ - base(arguments,tableModel,custom); - set({ - width: '100%', - height: '1*', - border: 'dark-shadow', - showCellFocusIndicator: false, - statusBarVisible: false - }); - }; - var tcm = this.getTableColumnModel(); + + this.base(arguments, tableModel, custom); + + this.set({ + decorator : 'main', + showCellFocusIndicator : false, + statusBarVisible : false + }); + + var tcm = this.getTableColumnModel(); this.__tcm = tcm; - tcm.setDataCellRenderer(0, new Tr.ui.Cellrenderer(1)); - tcm.setDataCellRenderer(3, new Tr.ui.Cellrenderer(0,' %')); - tcm.setDataCellRenderer(4, new Tr.ui.Cellrenderer(0)); - - var render_ms = new Tr.ui.Cellrenderer(1); + tcm.setDataCellRenderer(0, new tr.ui.Cellrenderer(1)); + tcm.setDataCellRenderer(3, new tr.ui.Cellrenderer(0, ' %')); + tcm.setDataCellRenderer(4, new tr.ui.Cellrenderer(0)); + + var render_ms = new tr.ui.Cellrenderer(1); - for (var i=5;i<10;i++){ + for (var i=5; i<10; i++) { tcm.setDataCellRenderer(i, render_ms); } - // Obtain the behavior object to manipulate var resizeBehavior = tcm.getBehavior(); + // This uses the set() method to set all attriutes at once; uses flex - resizeBehavior.set(0, { width:"2*"}); - resizeBehavior.set(1, { width:"9*"}); - resizeBehavior.set(2, { width:"5*"}); + resizeBehavior.set(0, { width : '2*' }); + resizeBehavior.set(1, { width : '9*' }); + resizeBehavior.set(2, { width : '5*' }); - for (var i=3;i<10;i++){ - resizeBehavior.set(i, { width:"3*"}); + for (var i=3; i<10; i++) { + resizeBehavior.set(i, { width : '3*' }); } - qx.event.message.Bus.subscribe('tr.cmd',this.__handle_tr,this); + + qx.event.message.Bus.subscribe('tr.cmd', this.__handle_tr, this); }, + + + /* - ***************************************************************************** - Statics - ***************************************************************************** - */ - members: { - __make_empty_row: function (){ - return ([undefined,undefined,undefined,0,0,undefined,undefined,undefined,undefined,undefined,0,0,0]); + ***************************************************************************** + Statics + ***************************************************************************** + */ + + members : { + __handle : null, + __data : null, + __delay : null, + __tableModel : null, + __tcm : null, + + + /** + * TODOC + * + * @type member + * @return {var} TODOC + */ + __make_empty_row : function() { + return ([ undefined, undefined, undefined, 0, 0, undefined, undefined, undefined, undefined, undefined, 0, 0, 0 ]); }, - __stop_table: function (){ + + + /** + * TODOC + * + * @type member + * @return {void} + */ + __stop_table : function() { var tableModel = this.__tableModel; - for (var i=0;i<10;i++){ - tableModel.setColumnSortable(i,true); + + for (var i=0; i<10; i++) { + tableModel.setColumnSortable(i, true); } - qx.event.message.Bus.dispatch('tr.status','stopped'); + + qx.event.message.Bus.dispatch('tr.status', 'stopped'); this.__handle = undefined; }, - __handle_tr: function(m){ + + + /** + * TODOC + * + * @type member + * @param m {var} TODOC + * @return {void} + */ + __handle_tr : function(m) { var self = this; - var f_hop = 0,f_host=1,f_ip=2,f_loss=3,f_snt=4,f_last=5,f_avg=6,f_best=7,f_worst=8,f_stdev=9,f_cnt=10,f_sum=11,f_sqsum=12; + var f_host = 1, f_ip = 2, f_loss = 3, f_snt = 4, f_last = 5, f_avg = 6, f_best = 7, f_worst = 8, f_stdev = 9, f_cnt = 10, f_sum = 11, f_sqsum = 12; var fill_table; - fill_table = function(retval,exc,id){ - if (exc == null){ - if ( self.__handle == undefined ) { - qx.event.message.Bus.dispatch('tr.status','started'); + + fill_table = function(retval, exc, id) { + if (exc == null) { + if (self.__handle == undefined) { + qx.event.message.Bus.dispatch('tr.status', 'started'); } + self.__handle = retval['handle']; var tableModel = self.__tableModel; var lines = retval['output'].length; var data = self.__data; var sleep = 0; - for(var i=0;i<lines;i++){ + + for (var i=0; i<lines; i++) { sleep = 0; var hop = retval['output'][i][0]; - if (hop == 'SLEEP'){ + + if (hop == 'SLEEP') { sleep = retval['output'][i][1]; - continue; - } - else if (hop == 'INFO'){ - qx.event.message.Bus.dispatch('tr.info',retval['output'][i][1]); continue; - } + } + else if (hop == 'INFO') { + qx.event.message.Bus.dispatch('tr.info', retval['output'][i][1]); + continue; + } + var host = retval['output'][i][1]; var ip = retval['output'][i][2]; var value = retval['output'][i][3]; var ii = 0; var max = data.length; - while (true){ - if ( ii == max ) break; - if ( Math.floor(data[ii][0]) > hop) break; - if ( Math.floor(data[ii][0]) == hop ){ - if ( ip == undefined ) break; - if ( ip == data[ii][2] ) break; + + while (true) { + if (ii == max) { + break; + } + + if (Math.floor(data[ii][0]) > hop) { + break; } + + if (Math.floor(data[ii][0]) == hop) { + if (ip == undefined) { + break; + } + + if (ip == data[ii][2]) { + break; + } + } + ii++; } - if (ii == max || Math.floor(data[ii][0]) > hop ){ - if (ii > 0 && Math.floor(data[ii-1][0]) == hop ){ - hop = data[ii-1][0] + 0.1; + + if (ii == max || Math.floor(data[ii][0]) > hop) { + if (ii > 0 && Math.floor(data[ii - 1][0]) == hop) { + hop = data[ii - 1][0] + 0.1; } - data.splice(ii,0,self.__make_empty_row()); + + data.splice(ii, 0, self.__make_empty_row()); data[ii][0] = hop; } var drow = data[ii]; - if (drow[f_host] == undefined && host != undefined){ + + if (drow[f_host] == undefined && host != undefined) { drow[f_host] = host; } - if (drow[f_ip] == undefined && ip != undefined){ + + if (drow[f_ip] == undefined && ip != undefined) { drow[f_ip] = ip; } + drow[f_snt]++; drow[f_last] = value; - - if (value != undefined){ + if (value != undefined) { var best = drow[f_best]; - if (best == undefined || best > value){ - drow[f_best] = value; - } - var worst = drow[f_worst]; - if (worst == undefined || worst < value){ - drow[f_worst] = value; + + if (best == undefined || best > value) { + drow[f_best] = value; } - drow[f_sum] += value; + + var worst = drow[f_worst]; + + if (worst == undefined || worst < value) { + drow[f_worst] = value; + } + + drow[f_sum] += value; var sum = drow[f_sum]; - drow[f_cnt] ++; + drow[f_cnt]++; var cnt = drow[f_cnt]; - var sqsum = drow[f_sqsum]+value*value; - drow[f_sqsum] = sqsum; - drow[f_avg] = drow[f_sum]/drow[f_cnt]; - drow[f_stdev] = Math.sqrt((cnt*sqsum-sum*sum)/(cnt*(cnt-1))) + var sqsum = drow[f_sqsum] + value * value; + drow[f_sqsum] = sqsum; + drow[f_avg] = drow[f_sum] / drow[f_cnt]; + drow[f_stdev] = Math.sqrt((cnt * sqsum - sum * sum) / (cnt * (cnt - 1))); } - drow[f_loss] = ((drow[f_snt]-drow[f_cnt])/drow[f_snt])*100; - } + + drow[f_loss] = ((drow[f_snt] - drow[f_cnt]) / drow[f_snt]) * 100; + } tableModel.setData(data); - if (retval['again']){ - var next_round = function (){Tr.Server.getInstance().callAsync( - fill_table,'run_tr',{ handle: retval['handle'], - point: retval['point']})}; - qx.client.Timer.once(next_round,self,sleep*1000); + + if (retval['again']) { + var next_round = function() { + tr.Server.getInstance().callAsync(fill_table, 'run_tr', { + handle : retval['handle'], + point : retval['point'] + }); + }; + + qx.event.Timer.once(next_round, self, sleep * 1000); } else { self.__stop_table(); } } else { - alert(exc); self.__stop_table(); - } + } }; - var stop_handler = function (data,exc,id){ - if (exc == null){ - qx.event.message.Bus.dispatch('tr.status','stopped'); + var stop_handler = function(data, exc, id) { + if (exc == null) { + qx.event.message.Bus.dispatch('tr.status', 'stopped'); + } else { + this.error(exc); } - else { - alert(exc); - } }; var cmd = m.getData(); - switch(cmd['action']){ - case 'stop': - qx.event.message.Bus.dispatch('tr.status','stopping'); - Tr.Server.getInstance().callAsync(stop_handler,'stop_tr',this.__handle); - break; - case 'go': - this.__data = []; - this.__tableModel.setData(this.__data); - this.__delay = cmd['delay']; - for (var i=0;i<10;i++){ - this.__tableModel.setColumnSortable(i,false); - } - qx.event.message.Bus.dispatch('tr.status','starting'); - Tr.Server.getInstance().callAsync(fill_table,'run_tr',{host: cmd['host'], rounds: cmd['rounds'], delay: cmd['delay']}); - break; - default: - alert('Unknown Command '+cmd['action']); + + switch(cmd['action']) + { + case 'stop': + qx.event.message.Bus.dispatch('tr.status', 'stopping'); + tr.Server.getInstance().callAsync(stop_handler, 'stop_tr', this.__handle); + break; + + case 'go': + this.__data = []; + this.__tableModel.setData(this.__data); + this.__delay = cmd['delay']; + + for (var i=0; i<10; i++) { + this.__tableModel.setColumnSortable(i, false); + } + + qx.event.message.Bus.dispatch('tr.status', 'starting'); + tr.Server.getInstance().callAsync(fill_table, 'run_tr', { + host : cmd['host'], + rounds : cmd['rounds'], + delay : cmd['delay'] + }); + + break; + + default: + this.error('Unknown Command ' + cmd['action']); } } - } -}); - - + } +});
\ No newline at end of file |