Generate dot graph from the debug app

pull/1/head
yflory 6 years ago
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…
Cancel
Save