(function(){
if (typeof JSROOT != "object") {
var e1 =
new Error(
"httptextlog.js requires JSROOT to be already loaded");
e1.source = "httptextlog.js";
throw e1;
}
function MakeMsgListRequest(hitem, item) {
var arg = "&max=1000";
if ('last-id' in item) arg+= "&id="+item['last-id'];
return 'exe.json.gz?method=Select' + arg;
}
function AfterMsgListRequest(hitem, item, obj) {
delete item['last-id'];
return;
}
if (obj['_typename'] != 'TList') return;
obj['_typename'] = "TMsgList";
if (obj.arr.length>0) {
item['last-id'] = obj.arr[0].fString;
if (!('clear' in item))
item['clear'] = function() { delete this['last-id']; }
}
}
function DrawMsgList(divid, lst, opt) {
var painter = new JSROOT.TBasePainter();
painter.SetDivId(divid);
painter.
Draw =
function(lst) {
var frame = d3.select("#" + this.divid);
var main = frame.select("div");
if (main.empty())
main = frame.append("div")
.style('max-width','100%')
.style('max-height','100%')
.style('overflow','auto');
var old = main.selectAll("pre");
var newsize = old.size() + lst.arr.length - 1;
if (newsize > 1000)
old.select(
function(d,i) {
return i < newsize - 1000 ?
this :
null; }).
remove();
for (var i=lst.arr.length-1;i>0;i--)
main.append("pre").html(lst.arr[i].fString);
this.SetDivId(this.divid);
}
painter.RedrawObject = function(obj) {
return true;
}
painter.Draw(lst);
return painter.DrawingReady();
}
JSROOT.addDrawFunc({name:"TMsgList", icon:"img_text", make_request:MakeMsgListRequest, after_request:AfterMsgListRequest, func:DrawMsgList, opt:"list"});
})();