Generate dot graph from the debug app
This commit is contained in:
parent
03e94ae598
commit
d0fc08b432
@ -958,7 +958,7 @@ define([
|
|||||||
common.autoStore.onStoreRequest = Util.mkEvent();
|
common.autoStore.onStoreRequest = Util.mkEvent();
|
||||||
|
|
||||||
common.getFullHistory = function (data, cb) {
|
common.getFullHistory = function (data, cb) {
|
||||||
postMessage("GET_FULL_HISTORY", data, cb);
|
postMessage("GET_FULL_HISTORY", data, cb, {timeout: 180000});
|
||||||
};
|
};
|
||||||
common.getHistoryRange = function (data, cb) {
|
common.getHistoryRange = function (data, cb) {
|
||||||
postMessage("GET_HISTORY_RANGE", data, cb);
|
postMessage("GET_HISTORY_RANGE", data, cb);
|
||||||
|
|||||||
@ -307,6 +307,9 @@
|
|||||||
"contacts_rooms": "Rooms",
|
"contacts_rooms": "Rooms",
|
||||||
"contacts_leaveRoom": "Leave this room",
|
"contacts_leaveRoom": "Leave this room",
|
||||||
"contacts_online": "Another user from this room is online",
|
"contacts_online": "Another user from this room is online",
|
||||||
|
"debug_getGraph":"Get the code to generate a graph of this document",
|
||||||
|
"debug_getGraphWait":"Generating the graph... Please Wait.",
|
||||||
|
"debug_getGraphText":"This is the DOT code to generate a graph of this document's history:",
|
||||||
"fm_rootName": "Documents",
|
"fm_rootName": "Documents",
|
||||||
"fm_trashName": "Trash",
|
"fm_trashName": "Trash",
|
||||||
"fm_unsortedName": "Unsorted files",
|
"fm_unsortedName": "Unsorted files",
|
||||||
|
|||||||
@ -7,10 +7,12 @@ define([
|
|||||||
'/bower_components/nthen/index.js',
|
'/bower_components/nthen/index.js',
|
||||||
'/common/sframe-common.js',
|
'/common/sframe-common.js',
|
||||||
'/common/common-interface.js',
|
'/common/common-interface.js',
|
||||||
|
'/common/hyperscript.js',
|
||||||
'/api/config',
|
'/api/config',
|
||||||
'/common/common-realtime.js',
|
'/common/common-realtime.js',
|
||||||
'/customize/messages.js',
|
'/customize/messages.js',
|
||||||
'/customize/application_config.js',
|
'/customize/application_config.js',
|
||||||
|
'/debug/chainpad.dist.js',
|
||||||
|
|
||||||
'/bower_components/secure-fabric.js/dist/fabric.min.js',
|
'/bower_components/secure-fabric.js/dist/fabric.min.js',
|
||||||
|
|
||||||
@ -26,10 +28,12 @@ define([
|
|||||||
nThen,
|
nThen,
|
||||||
SFCommon,
|
SFCommon,
|
||||||
UI,
|
UI,
|
||||||
|
h,
|
||||||
ApiConfig,
|
ApiConfig,
|
||||||
CommonRealtime,
|
CommonRealtime,
|
||||||
Messages,
|
Messages,
|
||||||
AppConfig)
|
AppConfig,
|
||||||
|
ChainWalk)
|
||||||
{
|
{
|
||||||
var APP = window.APP = {
|
var APP = window.APP = {
|
||||||
$: $,
|
$: $,
|
||||||
@ -54,6 +58,53 @@ define([
|
|||||||
var cpNfInner;
|
var cpNfInner;
|
||||||
var metadataMgr;
|
var metadataMgr;
|
||||||
var readOnly = true;
|
var readOnly = true;
|
||||||
|
var sframeChan = common.getSframeChannel();
|
||||||
|
|
||||||
|
var getGraph = function (cb) {
|
||||||
|
var chainpad = ChainWalk.create({
|
||||||
|
userName: 'debug',
|
||||||
|
initialState: '',
|
||||||
|
logLevel: 0,
|
||||||
|
noPrune: true
|
||||||
|
});
|
||||||
|
var makeGraph = function () {
|
||||||
|
var out = [
|
||||||
|
'digraph {'
|
||||||
|
];
|
||||||
|
var parseBlock = function (x) {
|
||||||
|
let c = x.getChildren();
|
||||||
|
let label = x.hashOf.slice(0,8) + ' (' + x.parentCount + ' - ' + x.recvOrder + ')';
|
||||||
|
var p = x.getParent();
|
||||||
|
if (p && p.getChildren().length === 1 && c.length === 1) {
|
||||||
|
label = '...';
|
||||||
|
let gc = c;
|
||||||
|
while (gc.length === 1) {
|
||||||
|
c = gc;
|
||||||
|
gc = c[0].getChildren();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
var nodeInfo = [' p' + x.hashOf + '[label="' + label + '"'];
|
||||||
|
if (x.isCheckpoint && label !== '...') { nodeInfo.push(',color=red,weight=0.5'); }
|
||||||
|
nodeInfo.push(']');
|
||||||
|
out.push(nodeInfo.join(''));
|
||||||
|
c.forEach(function (child) {
|
||||||
|
out.push(' p' + x.hashOf + ' -> p' + child.hashOf);
|
||||||
|
parseBlock(child);
|
||||||
|
});
|
||||||
|
};
|
||||||
|
parseBlock(chainpad.getRootBlock());
|
||||||
|
out.push('}');
|
||||||
|
return out.join('\n');
|
||||||
|
};
|
||||||
|
sframeChan.query('Q_GET_FULL_HISTORY', null, function (err, data) {
|
||||||
|
console.log(err, data);
|
||||||
|
if (err) { return void cb(err); }
|
||||||
|
data.forEach(function (m) {
|
||||||
|
chainpad.message(m);
|
||||||
|
cb(null, makeGraph())
|
||||||
|
});
|
||||||
|
}, {timeout: 180000});
|
||||||
|
};
|
||||||
|
|
||||||
var config = APP.config = {
|
var config = APP.config = {
|
||||||
readOnly: readOnly,
|
readOnly: readOnly,
|
||||||
@ -114,6 +165,31 @@ define([
|
|||||||
var $hist = common.createButton('history', true, {histConfig: histConfig});
|
var $hist = common.createButton('history', true, {histConfig: histConfig});
|
||||||
$hist.addClass('cp-hidden-if-readonly');
|
$hist.addClass('cp-hidden-if-readonly');
|
||||||
toolbar.$rightside.append($hist);
|
toolbar.$rightside.append($hist);
|
||||||
|
|
||||||
|
var $graph = common.createButton(null, true, {
|
||||||
|
icon: 'fa-bug',
|
||||||
|
title: Messages.debug_getGraph,
|
||||||
|
name: 'graph',
|
||||||
|
id: 'cp-app-debug-get-graph'
|
||||||
|
});
|
||||||
|
$graph.click(function () {
|
||||||
|
var p = h('p', [
|
||||||
|
Messages.debug_getGraphWait,
|
||||||
|
h('br'),
|
||||||
|
h('span.fa-circle-o-notch.fa-spin.fa-3x.fa-fw.fa')
|
||||||
|
]);
|
||||||
|
var code = h('code');
|
||||||
|
var content = h('div', [p, code]);
|
||||||
|
getGraph(function (err, data) {
|
||||||
|
if (err) {
|
||||||
|
return p.innerHTML = err;
|
||||||
|
}
|
||||||
|
p.innerHTML = Messages.debug_getGraph;
|
||||||
|
code.innerHTML = data;
|
||||||
|
});
|
||||||
|
UI.alert(content);
|
||||||
|
});
|
||||||
|
toolbar.$rightside.append($graph);
|
||||||
};
|
};
|
||||||
|
|
||||||
config.onReady = function (info) {
|
config.onReady = function (info) {
|
||||||
|
|||||||
@ -53,6 +53,10 @@ define([
|
|||||||
};
|
};
|
||||||
window.addEventListener('message', onMsg);
|
window.addEventListener('message', onMsg);
|
||||||
}).nThen(function (/*waitFor*/) {
|
}).nThen(function (/*waitFor*/) {
|
||||||
|
if (!window.location.hash) {
|
||||||
|
window.location.hash = localStorage[Constants.userHashKey] ||
|
||||||
|
localStorage[Constants.fileHashKey];
|
||||||
|
}
|
||||||
SFCommonO.start();
|
SFCommonO.start();
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user