%PDF- <> %âãÏÓ endobj 2 0 obj <> endobj 3 0 obj <>/ExtGState<>/ProcSet[/PDF/Text/ImageB/ImageC/ImageI] >>/Annots[ 28 0 R 29 0 R] /MediaBox[ 0 0 595.5 842.25] /Contents 4 0 R/Group<>/Tabs/S>> endobj ºaâÚÎΞ-ÌE1ÍØÄ÷{òò2ÿ ÛÖ^ÔÀá TÎ{¦?§®¥kuµùÕ5sLOšuY>endobj 2 0 obj<>endobj 2 0 obj<>endobj 2 0 obj<>endobj 2 0 obj<> endobj 2 0 obj<>endobj 2 0 obj<>es 3 0 R>> endobj 2 0 obj<> ox[ 0.000000 0.000000 609.600000 935.600000]/Fi endobj 3 0 obj<> endobj 7 1 obj<>/ProcSet[/PDF/Text/ImageB/ImageC/ImageI]>>/Subtype/Form>> stream
// Sometimes we need to actually do a walk from the root, because you can // have a cycle of deps that all depend on each other, but no path from root. // Also, since the ideal tree is loaded from the shrinkwrap, it had extraneous // flags set false that might now be actually extraneous, and dev/optional // flags that are also now incorrect. This method sets all flags to true, so // we can find the set that is actually extraneous. module.exports = tree => { for (const node of tree.inventory.values()) { node.extraneous = true node.dev = true node.devOptional = true node.peer = true node.optional = true } }