Fix flexbox trace loading problem in layout_viewer

This commit is contained in:
Shing Lyu 2016-11-08 11:21:27 +08:00
parent 4b2d80afcf
commit 22ffdf8018

View file

@ -80,17 +80,28 @@
<script src="js/formatters.min.js"></script> <script src="js/formatters.min.js"></script>
<script> <script>
function get_base(trace_node) {
if (typeof(trace_node.data.base) == "undefined" && typeof(trace_node.data.block_flow) != "undefined") {
return trace_node.data.block_flow.base;
}
else {
return trace_node.data.base;
}
}
function create_flow_tree(trace_node) { function create_flow_tree(trace_node) {
var base = get_base(trace_node);
var node = { var node = {
text: trace_node.class + " (" + trace_node.data.base.id + ")", text: trace_node.class + " (" + base.id + ")",
id: trace_node.data.base.id, id: base.id,
icon: "dummy", icon: "dummy",
href: "#diff-" + trace_node.data.base.id href: "#diff-" + base.id
}; };
var children = []; var children = [];
for (var i=0 ; i < trace_node.data.base.children.length ; ++i) { for (var i=0 ; i < base.children.length ; ++i) {
children.push(create_flow_tree(trace_node.data.base.children[i])); children.push(create_flow_tree(base.children[i]));
} }
if (children.length > 0) { if (children.length > 0) {
@ -101,13 +112,14 @@
} }
function create_flow_hash(trace_node, flow_hash) { function create_flow_hash(trace_node, flow_hash) {
flow_hash[trace_node.data.base.id] = trace_node; var base = get_base(trace_node);
flow_hash[base.id] = trace_node;
for (var i=0 ; i < trace_node.data.base.children.length ; ++i) { for (var i=0 ; i < base.children.length ; ++i) {
create_flow_hash(trace_node.data.base.children[i], flow_hash); create_flow_hash(base.children[i], flow_hash);
} }
delete trace_node.data.base.children; delete base.children;
} }
function flatten_trace(trace_node) { function flatten_trace(trace_node) {
@ -177,6 +189,10 @@
if (obj.id !== undefined) { if (obj.id !== undefined) {
return obj.id; return obj.id;
} }
if (obj.index !== undefined) {
// FlexItem and FlexLine
return obj.index;
}
return JSON.stringify(obj); return JSON.stringify(obj);
} }
}).diff(flow_left, flow_right); }).diff(flow_left, flow_right);