mirror of
https://github.com/nodejs/node.git
synced 2025-05-14 21:36:02 +00:00

PR-URL: https://github.com/nodejs/node/pull/3310 Reviewed-By: Jeremiah Senkpiel <fishrock123@rocketmail.com>
26 lines
625 B
JavaScript
26 lines
625 B
JavaScript
'use strict'
|
|
|
|
module.exports = function (tree) {
|
|
return copyTree(tree, {})
|
|
}
|
|
|
|
function copyTree (tree, cache) {
|
|
if (cache[tree.path]) return cache[tree.path]
|
|
var newTree = cache[tree.path] = Object.create(tree)
|
|
copyModuleList(newTree, 'children', cache)
|
|
newTree.children.forEach(function (child) {
|
|
child.parent = newTree
|
|
})
|
|
copyModuleList(newTree, 'requires', cache)
|
|
copyModuleList(newTree, 'requiredBy', cache)
|
|
return newTree
|
|
}
|
|
|
|
function copyModuleList (tree, key, cache) {
|
|
var newList = []
|
|
tree[key].forEach(function (child) {
|
|
newList.push(copyTree(child, cache))
|
|
})
|
|
tree[key] = newList
|
|
}
|