/** * Copyright (c) 2016-present, Facebook, Inc. * All rights reserved. * * This source code is licensed under the BSD-style license found in the * LICENSE file in the root directory of this source tree. An additional grant * of patent rights can be found in the PATENTS file in the same directory. */ 'use strict'; /*eslint no-console-disallow: "off"*/ /*global React ReactDOM Table StringInterner StackRegistry AggrowData Aggrow preLoadedCapture:true*/ function RefVisitor(refs,id){ this.refs=refs; this.id=id; } RefVisitor.prototype={ moveToEdge:function moveToEdge(name){ var ref=this.refs[this.id]; if(ref&&ref.edges){ var edges=ref.edges; for(var edgeId in edges){ if(edges[edgeId]===name){ this.id=edgeId; return this; } } } this.id=undefined; return this; }, moveToFirst:function moveToFirst(callback){ var ref=this.refs[this.id]; if(ref&&ref.edges){ var edges=ref.edges; for(var edgeId in edges){ this.id=edgeId; if(callback(edges[edgeId],this)){ return this; } } } this.id=undefined; return this; }, forEachEdge:function forEachEdge(callback){ var ref=this.refs[this.id]; if(ref&&ref.edges){ var edges=ref.edges; var visitor=new RefVisitor(this.refs,undefined); for(var edgeId in edges){ visitor.id=edgeId; callback(edges[edgeId],visitor); } } }, getType:function getType(){ var ref=this.refs[this.id]; if(ref){ return ref.type; } return undefined; }, getRef:function getRef(){ return this.refs[this.id]; }, clone:function clone(){ return new RefVisitor(this.refs,this.id); }, isDefined:function isDefined(){ return!!this.id; }, getValue:function getValue(){var _this=this; var ref=this.refs[this.id]; if(ref){ if(ref.type==='string'){ if(ref.value){ return ref.value; }else{var _ret=function(){ var rope=[]; _this.forEachEdge(function(name,visitor){ if(name&&name.startsWith('[')&&name.endsWith(']')){ var index=parseInt(name.substring(1,name.length-1),10); rope[index]=visitor.getValue(); } }); return{v:rope.join('')};}();if(typeof _ret==="object")return _ret.v; } }else if(ref.type==='ScriptExecutable'|| ref.type==='EvalExecutable'|| ref.type==='ProgramExecutable'){ return ref.value.url+':'+ref.value.line+':'+ref.value.col; }else if(ref.type==='FunctionExecutable'){ return ref.value.name+'@'+ref.value.url+':'+ref.value.line+':'+ref.value.col; }else if(ref.type==='NativeExecutable'){ return ref.value.function+' '+ref.value.constructor+' '+ref.value.name; }else if(ref.type==='Function'){ var executable=this.clone().moveToEdge('@Executable'); if(executable.id){ return executable.getRef().type+' '+executable.getValue(); } } } return'#none'; }}; function forEachRef(refs,callback){ var visitor=new RefVisitor(refs,undefined); for(var id in refs){ visitor.id=id; callback(visitor); } } function firstRef(refs,callback){ for(var id in refs){ var ref=refs[id]; if(callback(id,ref)){ return new RefVisitor(refs,id); } } return new RefVisitor(refs,undefined); } function getInternalInstanceName(visitor){ var type=visitor.clone().moveToEdge('_currentElement').moveToEdge('type'); if(type.getType()==='string'){// element.type is string return type.getValue(); }else if(type.getType()==='Function'){// element.type is function var displayName=type.clone().moveToEdge('displayName'); if(displayName.isDefined()){ return displayName.getValue();// element.type.displayName } var name=type.clone().moveToEdge('name'); if(name.isDefined()){ return name.getValue();// element.type.name } type.moveToEdge('@Executable'); if(type.getType()==='FunctionExecutable'){ return type.getRef().value.name;// element.type symbolicated name } } return'#unknown'; } function buildReactComponentTree(visitor,registry,strings){ var ref=visitor.getRef(); if(ref.reactTree||ref.reactParent===undefined){ return;// has one or doesn't need one } var parentVisitor=ref.reactParent; if(parentVisitor===null){ ref.reactTree=registry.insert(registry.root,strings.intern(getInternalInstanceName(visitor))); }else if(parentVisitor){ var parentRef=parentVisitor.getRef(); buildReactComponentTree(parentVisitor,registry,strings); var relativeName=getInternalInstanceName(visitor); if(ref.reactKey){ relativeName=ref.reactKey+': '+relativeName; } ref.reactTree=registry.insert(parentRef.reactTree,strings.intern(relativeName)); }else{ throw'non react instance parent of react instance'; } } function markReactComponentTree(refs,registry,strings){ // annotate all refs that are react internal instances with their parent and name // ref.reactParent = visitor that points to parent instance, // null if we know it's an instance, but don't have a parent yet // ref.reactKey = if a key is used to distinguish siblings forEachRef(refs,function(visitor){ var visitorClone=visitor.clone();// visitor will get stomped on next iteration var ref=visitor.getRef(); visitor.forEachEdge(function(edgeName,edgeVisitor){ var edgeRef=edgeVisitor.getRef(); if(edgeRef){ if(edgeName==='_renderedChildren'){ if(ref.reactParent===undefined){ // ref is react component, even if we don't have a parent yet ref.reactParent=null; } edgeVisitor.forEachEdge(function(childName,childVisitor){ var childRef=childVisitor.getRef(); if(childRef&&childName.startsWith('.')){ childRef.reactParent=visitorClone; childRef.reactKey=childName; } }); }else if(edgeName==='_renderedComponent'){ if(ref.reactParent===undefined){ ref.reactParent=null; } edgeRef.reactParent=visitorClone; } } }); }); // build tree of react internal instances (since that's what has the structure) // fill in ref.reactTree = path registry node forEachRef(refs,function(visitor){ buildReactComponentTree(visitor,registry,strings); }); // hook in components by looking at their _reactInternalInstance fields forEachRef(refs,function(visitor){ var ref=visitor.getRef(); var instanceRef=visitor.moveToEdge('_reactInternalInstance').getRef(); if(instanceRef){ ref.reactTree=instanceRef.reactTree; } }); } function functionUrlFileName(visitor){ var executable=visitor.clone().moveToEdge('@Executable'); var ref=executable.getRef(); if(ref&&ref.value&&ref.value.url){ var url=ref.value.url; var file=url.substring(url.lastIndexOf('/')+1); if(file.endsWith('.js')){ file=file.substring(0,file.length-3); } return file; } return undefined; } function markModules(refs){ var modules=firstRef(refs,function(id,ref){return ref.type==='CallbackGlobalObject';}); modules.moveToEdge('require'); modules.moveToFirst(function(name,visitor){return visitor.getType()==='JSActivation';}); modules.moveToEdge('modules'); modules.forEachEdge(function(name,visitor){ var ref=visitor.getRef(); visitor.moveToEdge('exports'); if(visitor.getType()==='Object'){ visitor.moveToFirst(function(memberName,member){return member.getType()==='Function';}); if(visitor.isDefined()){ ref.module=functionUrlFileName(visitor); } }else if(visitor.getType()==='Function'){ var displayName=visitor.clone().moveToEdge('displayName'); if(displayName.isDefined()){ ref.module=displayName.getValue(); } ref.module=functionUrlFileName(visitor); } if(ref&&!ref.module){ ref.module='#unknown '+name; } }); } function registerPathToRoot(refs,registry,strings){ markReactComponentTree(refs,registry,strings); markModules(refs); var breadth=[]; forEachRef(refs,function(visitor){ var ref=visitor.getRef(); if(ref.type==='CallbackGlobalObject'){ ref.rootPath=registry.insert(registry.root,strings.intern(ref.type)); breadth.push(visitor.clone()); } });var _loop=function _loop(){ var nextBreadth=[];var _loop2=function _loop2( i){ var visitor=breadth[i]; var ref=visitor.getRef(); visitor.forEachEdge(function(edgeName,edgeVisitor){ var edgeRef=edgeVisitor.getRef(); if(edgeRef&&edgeRef.rootPath===undefined){ var pathName=edgeRef.type; if(edgeName){ pathName=edgeName+': '+pathName; } edgeRef.rootPath=registry.insert(ref.rootPath,strings.intern(pathName)); nextBreadth.push(edgeVisitor.clone()); // copy module and react tree forward if(edgeRef.module===undefined){ edgeRef.module=ref.module; } if(edgeRef.reactTree===undefined){ edgeRef.reactTree=ref.reactTree; } } });};for(var i=0;i0){_loop(); } } function registerCapture(data,captureId,capture,stacks,strings){ // NB: capture.refs is potentially VERY large, so we try to avoid making // copies, even if iteration is a bit more annoying. var rowCount=0; for(var id in capture.refs){// eslint-disable-line no-unused-vars rowCount++; } for(var _id in capture.markedBlocks){// eslint-disable-line no-unused-vars rowCount++; } var inserter=data.rowInserter(rowCount); registerPathToRoot(capture.refs,stacks,strings); var noneString=strings.intern('#none'); var noneStack=stacks.insert(stacks.root,noneString); forEachRef(capture.refs,function(visitor){ // want to data.append(value, value, value), not IDs var ref=visitor.getRef(); var id=visitor.id; inserter.insertRow( parseInt(id,16), ref.type, ref.size, captureId, ref.rootPath===undefined?noneStack:ref.rootPath, ref.reactTree===undefined?noneStack:ref.reactTree, visitor.getValue(), ref.module===undefined?'#none':ref.module); }); for(var _id2 in capture.markedBlocks){ var block=capture.markedBlocks[_id2]; inserter.insertRow( parseInt(_id2,16), 'Marked Block Overhead', block.capacity-block.size, captureId, noneStack, noneStack, 'capacity: '+block.capacity+', size: '+block.size+', granularity: '+block.cellSize, '#none'); } inserter.done(); } if(preLoadedCapture){ var strings=StringInterner(); var stacks=new StackRegistry(); var columns=[ {name:'id',type:'int'}, {name:'type',type:'string',strings:strings}, {name:'size',type:'int'}, {name:'trace',type:'string',strings:strings}, {name:'path',type:'stack',stacks:stacks}, {name:'react',type:'stack',stacks:stacks}, {name:'value',type:'string',strings:strings}, {name:'module',type:'string',strings:strings}]; var data=new AggrowData(columns); registerCapture(data,'trace',preLoadedCapture,stacks,strings); preLoadedCapture=undefined;// let GG clean up the capture var aggrow=new Aggrow(data); aggrow.addPointerExpander('Id','id'); var typeExpander=aggrow.addStringExpander('Type','type'); aggrow.addNumberExpander('Size','size'); aggrow.addStringExpander('Trace','trace'); var pathExpander=aggrow.addStackExpander('Path','path',strings.get); var reactExpander=aggrow.addStackExpander('React Tree','react',strings.get); var valueExpander=aggrow.addStringExpander('Value','value'); var moduleExpander=aggrow.addStringExpander('Module','module'); aggrow.expander.setActiveExpanders([ pathExpander, reactExpander, moduleExpander, typeExpander, valueExpander]); var sizeAggregator=aggrow.addSumAggregator('Size','size'); var countAggregator=aggrow.addCountAggregator('Count'); aggrow.expander.setActiveAggregators([ sizeAggregator, countAggregator]); ReactDOM.render(React.createElement(Table,{aggrow:aggrow.expander}),document.body); } //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../src/heapCapture.js"],"names":["RefVisitor","refs","id","prototype","moveToEdge","name","ref","edges","edgeId","undefined","moveToFirst","callback","forEachEdge","visitor","getType","type","getRef","clone","isDefined","getValue","value","rope","startsWith","endsWith","index","parseInt","substring","length","join","url","line","col","function","constructor","executable","forEachRef","firstRef","getInternalInstanceName","displayName","buildReactComponentTree","registry","strings","reactTree","reactParent","parentVisitor","insert","root","intern","parentRef","relativeName","reactKey","markReactComponentTree","visitorClone","edgeName","edgeVisitor","edgeRef","childName","childVisitor","childRef","instanceRef","functionUrlFileName","file","lastIndexOf","markModules","modules","memberName","member","module","registerPathToRoot","breadth","rootPath","push","nextBreadth","i","pathName","registerCapture","data","captureId","capture","stacks","rowCount","markedBlocks","inserter","rowInserter","noneString","noneStack","insertRow","size","block","capacity","cellSize","done","preLoadedCapture","StringInterner","StackRegistry","columns","AggrowData","aggrow","Aggrow","addPointerExpander","typeExpander","addStringExpander","addNumberExpander","pathExpander","addStackExpander","get","reactExpander","valueExpander","moduleExpander","expander","setActiveExpanders","sizeAggregator","addSumAggregator","countAggregator","addCountAggregator","setActiveAggregators","ReactDOM","render","document","body"],"mappings":"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","file":"heapCapture.js","sourcesContent":["/**\n * Copyright (c) 2016-present, Facebook, Inc.\n * All rights reserved.\n *\n * This source code is licensed under the BSD-style license found in the\n * LICENSE file in the root directory of this source tree. An additional grant\n * of patent rights can be found in the PATENTS file in the same directory.\n */\n'use strict';\n/*eslint no-console-disallow: \"off\"*/\n/*global React ReactDOM Table StringInterner StackRegistry AggrowData Aggrow preLoadedCapture:true*/\n\nfunction RefVisitor(refs, id) {\n  this.refs = refs;\n  this.id = id;\n}\n\nRefVisitor.prototype = {\n  moveToEdge: function moveToEdge(name) {\n    const ref = this.refs[this.id];\n    if (ref && ref.edges) {\n      const edges = ref.edges;\n      for (const edgeId in edges) {\n        if (edges[edgeId] === name) {\n          this.id = edgeId;\n          return this;\n        }\n      }\n    }\n    this.id = undefined;\n    return this;\n  },\n  moveToFirst: function moveToFirst(callback) {\n    const ref = this.refs[this.id];\n    if (ref && ref.edges) {\n      const edges = ref.edges;\n      for (const edgeId in edges) {\n        this.id = edgeId;\n        if (callback(edges[edgeId], this)) {\n          return this;\n        }\n      }\n    }\n    this.id = undefined;\n    return this;\n  },\n  forEachEdge: function forEachEdge(callback) {\n    const ref = this.refs[this.id];\n    if (ref && ref.edges) {\n      const edges = ref.edges;\n      const visitor = new RefVisitor(this.refs, undefined);\n      for (const edgeId in edges) {\n        visitor.id = edgeId;\n        callback(edges[edgeId], visitor);\n      }\n    }\n  },\n  getType: function getType() {\n    const ref = this.refs[this.id];\n    if (ref) {\n      return ref.type;\n    }\n    return undefined;\n  },\n  getRef: function getRef() {\n    return this.refs[this.id];\n  },\n  clone: function clone() {\n    return new RefVisitor(this.refs, this.id);\n  },\n  isDefined: function isDefined() {\n    return !!this.id;\n  },\n  getValue: function getValue() {\n    const ref = this.refs[this.id];\n    if (ref) {\n      if (ref.type === 'string') {\n        if (ref.value) {\n          return ref.value;\n        } else {\n          const rope = [];\n          this.forEachEdge((name, visitor) => {\n            if (name && name.startsWith('[') && name.endsWith(']')) {\n              const index = parseInt(name.substring(1, name.length - 1), 10);\n              rope[index] = visitor.getValue();\n            }\n          });\n          return rope.join('');\n        }\n      } else if (ref.type === 'ScriptExecutable'\n              || ref.type === 'EvalExecutable'\n              || ref.type === 'ProgramExecutable') {\n        return ref.value.url + ':' + ref.value.line + ':' + ref.value.col;\n      } else if (ref.type === 'FunctionExecutable') {\n        return ref.value.name + '@' + ref.value.url + ':' + ref.value.line + ':' + ref.value.col;\n      } else if (ref.type === 'NativeExecutable') {\n        return ref.value.function + ' ' + ref.value.constructor + ' ' + ref.value.name;\n      } else if (ref.type === 'Function') {\n        const executable = this.clone().moveToEdge('@Executable');\n        if (executable.id) {\n          return executable.getRef().type + ' ' + executable.getValue();\n        }\n      }\n    }\n    return '#none';\n  }\n};\n\nfunction forEachRef(refs, callback) {\n  const visitor = new RefVisitor(refs, undefined);\n  for (const id in refs) {\n    visitor.id = id;\n    callback(visitor);\n  }\n}\n\nfunction firstRef(refs, callback) {\n  for (const id in refs) {\n    const ref = refs[id];\n    if (callback(id, ref)) {\n      return new RefVisitor(refs, id);\n    }\n  }\n  return new RefVisitor(refs, undefined);\n}\n\nfunction getInternalInstanceName(visitor) {\n  const type = visitor.clone().moveToEdge('_currentElement').moveToEdge('type');\n  if (type.getType() === 'string') { // element.type is string\n    return type.getValue();\n  } else if (type.getType() === 'Function') { // element.type is function\n    const displayName = type.clone().moveToEdge('displayName');\n    if (displayName.isDefined()) {\n      return displayName.getValue(); // element.type.displayName\n    }\n    const name = type.clone().moveToEdge('name');\n    if (name.isDefined()) {\n      return name.getValue(); // element.type.name\n    }\n    type.moveToEdge('@Executable');\n    if (type.getType() === 'FunctionExecutable') {\n      return type.getRef().value.name;  // element.type symbolicated name\n    }\n  }\n  return '#unknown';\n}\n\nfunction buildReactComponentTree(visitor, registry, strings) {\n  const ref = visitor.getRef();\n  if (ref.reactTree || ref.reactParent === undefined) {\n    return; // has one or doesn't need one\n  }\n  const parentVisitor = ref.reactParent;\n  if (parentVisitor === null) {\n    ref.reactTree = registry.insert(registry.root, strings.intern(getInternalInstanceName(visitor)));\n  } else if (parentVisitor) {\n    const parentRef = parentVisitor.getRef();\n    buildReactComponentTree(parentVisitor, registry, strings);\n    let relativeName = getInternalInstanceName(visitor);\n    if (ref.reactKey) {\n      relativeName = ref.reactKey + ': ' + relativeName;\n    }\n    ref.reactTree = registry.insert(parentRef.reactTree, strings.intern(relativeName));\n  } else {\n    throw 'non react instance parent of react instance';\n  }\n}\n\nfunction markReactComponentTree(refs, registry, strings) {\n  // annotate all refs that are react internal instances with their parent and name\n  // ref.reactParent = visitor that points to parent instance,\n  //   null if we know it's an instance, but don't have a parent yet\n  // ref.reactKey = if a key is used to distinguish siblings\n  forEachRef(refs, (visitor) => {\n    const visitorClone = visitor.clone(); // visitor will get stomped on next iteration\n    const ref = visitor.getRef();\n    visitor.forEachEdge((edgeName, edgeVisitor) => {\n      const edgeRef = edgeVisitor.getRef();\n      if (edgeRef) {\n        if (edgeName === '_renderedChildren') {\n          if (ref.reactParent === undefined) {\n            // ref is react component, even if we don't have a parent yet\n            ref.reactParent = null;\n          }\n          edgeVisitor.forEachEdge((childName, childVisitor) => {\n            const childRef = childVisitor.getRef();\n            if (childRef && childName.startsWith('.')) {\n              childRef.reactParent = visitorClone;\n              childRef.reactKey = childName;\n            }\n          });\n        } else if (edgeName === '_renderedComponent') {\n          if (ref.reactParent === undefined) {\n            ref.reactParent = null;\n          }\n          edgeRef.reactParent = visitorClone;\n        }\n      }\n    });\n  });\n  // build tree of react internal instances (since that's what has the structure)\n  // fill in ref.reactTree = path registry node\n  forEachRef(refs, (visitor) => {\n    buildReactComponentTree(visitor, registry, strings);\n  });\n  // hook in components by looking at their _reactInternalInstance fields\n  forEachRef(refs, (visitor) => {\n    const ref = visitor.getRef();\n    const instanceRef = visitor.moveToEdge('_reactInternalInstance').getRef();\n    if (instanceRef) {\n      ref.reactTree = instanceRef.reactTree;\n    }\n  });\n}\n\nfunction functionUrlFileName(visitor) {\n  const executable = visitor.clone().moveToEdge('@Executable');\n  const ref = executable.getRef();\n  if (ref && ref.value && ref.value.url) {\n    const url = ref.value.url;\n    let file = url.substring(url.lastIndexOf('/') + 1);\n    if (file.endsWith('.js')) {\n      file = file.substring(0, file.length - 3);\n    }\n    return file;\n  }\n  return undefined;\n}\n\nfunction markModules(refs) {\n  const modules = firstRef(refs, (id, ref) => ref.type === 'CallbackGlobalObject');\n  modules.moveToEdge('require');\n  modules.moveToFirst((name, visitor) => visitor.getType() === 'JSActivation');\n  modules.moveToEdge('modules');\n  modules.forEachEdge((name, visitor) => {\n    const ref = visitor.getRef();\n    visitor.moveToEdge('exports');\n    if (visitor.getType() === 'Object') {\n      visitor.moveToFirst((memberName, member) => member.getType() === 'Function');\n      if (visitor.isDefined()) {\n        ref.module = functionUrlFileName(visitor);\n      }\n    } else if (visitor.getType() === 'Function') {\n      const displayName = visitor.clone().moveToEdge('displayName');\n      if (displayName.isDefined()) {\n        ref.module = displayName.getValue();\n      }\n      ref.module = functionUrlFileName(visitor);\n    }\n    if (ref && !ref.module) {\n      ref.module = '#unknown ' + name;\n    }\n  });\n}\n\nfunction registerPathToRoot(refs, registry, strings) {\n  markReactComponentTree(refs, registry, strings);\n  markModules(refs);\n  let breadth = [];\n  forEachRef(refs, (visitor) => {\n    const ref = visitor.getRef();\n    if (ref.type === 'CallbackGlobalObject') {\n      ref.rootPath = registry.insert(registry.root, strings.intern(ref.type));\n      breadth.push(visitor.clone());\n    }\n  });\n  while (breadth.length > 0) {\n    const nextBreadth = [];\n    for (let i = 0; i < breadth.length; i++) {\n      const visitor = breadth[i];\n      const ref = visitor.getRef();\n      visitor.forEachEdge((edgeName, edgeVisitor) => {\n        const edgeRef = edgeVisitor.getRef();\n        if (edgeRef && edgeRef.rootPath === undefined) {\n          let pathName = edgeRef.type;\n          if (edgeName) {\n            pathName = edgeName + ': ' + pathName;\n          }\n          edgeRef.rootPath = registry.insert(ref.rootPath, strings.intern(pathName));\n          nextBreadth.push(edgeVisitor.clone());\n          // copy module and react tree forward\n          if (edgeRef.module === undefined) {\n            edgeRef.module = ref.module;\n          }\n          if (edgeRef.reactTree === undefined) {\n            edgeRef.reactTree = ref.reactTree;\n          }\n        }\n      });\n    }\n    breadth = nextBreadth;\n  }\n}\n\nfunction registerCapture(data, captureId, capture, stacks, strings) {\n  // NB: capture.refs is potentially VERY large, so we try to avoid making\n  // copies, even if iteration is a bit more annoying.\n  let rowCount = 0;\n  for (const id in capture.refs) { // eslint-disable-line no-unused-vars\n    rowCount++;\n  }\n  for (const id in capture.markedBlocks) { // eslint-disable-line no-unused-vars\n    rowCount++;\n  }\n  const inserter = data.rowInserter(rowCount);\n  registerPathToRoot(capture.refs, stacks, strings);\n  const noneString = strings.intern('#none');\n  const noneStack = stacks.insert(stacks.root, noneString);\n  forEachRef(capture.refs, (visitor) => {\n    // want to data.append(value, value, value), not IDs\n    const ref = visitor.getRef();\n    const id = visitor.id;\n    inserter.insertRow(\n      parseInt(id, 16),\n      ref.type,\n      ref.size,\n      captureId,\n      ref.rootPath === undefined ? noneStack : ref.rootPath,\n      ref.reactTree === undefined ? noneStack : ref.reactTree,\n      visitor.getValue(),\n      ref.module === undefined ? '#none' : ref.module,\n    );\n  });\n  for (const id in capture.markedBlocks) {\n    const block = capture.markedBlocks[id];\n    inserter.insertRow(\n      parseInt(id, 16),\n      'Marked Block Overhead',\n      block.capacity - block.size,\n      captureId,\n      noneStack,\n      noneStack,\n      'capacity: ' + block.capacity + ', size: ' + block.size + ', granularity: ' + block.cellSize,\n      '#none',\n    );\n  }\n  inserter.done();\n}\n\nif (preLoadedCapture) {\n  const strings = StringInterner();\n  const stacks =  new StackRegistry();\n  const columns = [\n    { name: 'id', type: 'int' },\n    { name: 'type', type: 'string', strings: strings },\n    { name: 'size', type: 'int' },\n    { name: 'trace', type: 'string', strings: strings },\n    { name: 'path', type: 'stack', stacks: stacks },\n    { name: 'react', type: 'stack', stacks: stacks },\n    { name: 'value', type: 'string', strings: strings },\n    { name: 'module', type: 'string', strings: strings },\n  ];\n  const data = new AggrowData(columns);\n  registerCapture(data, 'trace', preLoadedCapture, stacks, strings);\n  preLoadedCapture = undefined; // let GG clean up the capture\n  const aggrow = new Aggrow(data);\n  aggrow.addPointerExpander('Id', 'id');\n  const typeExpander = aggrow.addStringExpander('Type', 'type');\n  aggrow.addNumberExpander('Size', 'size');\n  aggrow.addStringExpander('Trace', 'trace');\n  const pathExpander = aggrow.addStackExpander('Path', 'path', strings.get);\n  const reactExpander = aggrow.addStackExpander('React Tree', 'react', strings.get);\n  const valueExpander = aggrow.addStringExpander('Value', 'value');\n  const moduleExpander = aggrow.addStringExpander('Module', 'module');\n  aggrow.expander.setActiveExpanders([\n    pathExpander,\n    reactExpander,\n    moduleExpander,\n    typeExpander,\n    valueExpander,\n  ]);\n  const sizeAggregator = aggrow.addSumAggregator('Size', 'size');\n  const countAggregator = aggrow.addCountAggregator('Count');\n  aggrow.expander.setActiveAggregators([\n    sizeAggregator,\n    countAggregator,\n  ]);\n  ReactDOM.render(<Table aggrow={aggrow.expander} />, document.body);\n}\n"]} // @generated