@angular-devkit/build-optimizer 0.13.4 → 0.13.8
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/package.json
CHANGED
|
@@ -54,6 +54,13 @@ function findTopLevelFunctions(parentNode) {
|
|
|
54
54
|
if (!innerNode) {
|
|
55
55
|
return;
|
|
56
56
|
}
|
|
57
|
+
if ((ts.isFunctionExpression(innerNode) || ts.isArrowFunction(innerNode))
|
|
58
|
+
&& ts.isParenthesizedExpression(node)) {
|
|
59
|
+
// pure functions can be wrapped in parentizes
|
|
60
|
+
// we should not add pure comments to this sort of syntax.
|
|
61
|
+
// example var foo = (() => x)
|
|
62
|
+
return;
|
|
63
|
+
}
|
|
57
64
|
if (noPureComment) {
|
|
58
65
|
if (ts.isNewExpression(innerNode)) {
|
|
59
66
|
topLevelFunctions.add(node);
|
|
@@ -83,4 +90,4 @@ function findTopLevelFunctions(parentNode) {
|
|
|
83
90
|
return topLevelFunctions;
|
|
84
91
|
}
|
|
85
92
|
exports.findTopLevelFunctions = findTopLevelFunctions;
|
|
86
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
93
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"prefix-functions.js","sourceRoot":"./","sources":["packages/angular_devkit/build_optimizer/src/transforms/prefix-functions.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Google Inc. All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\nimport * as ts from 'typescript';\nimport { addPureComment, hasPureComment } from '../helpers/ast-utils';\n\nexport function getPrefixFunctionsTransformer(): ts.TransformerFactory<ts.SourceFile> {\n  return (context: ts.TransformationContext): ts.Transformer<ts.SourceFile> => {\n    const transformer: ts.Transformer<ts.SourceFile> = (sf: ts.SourceFile) => {\n\n      const topLevelFunctions = findTopLevelFunctions(sf);\n\n      const visitor: ts.Visitor = (node: ts.Node): ts.Node => {\n        // Add pure function comment to top level functions.\n        if (topLevelFunctions.has(node)) {\n          const newNode = addPureComment(node);\n\n          // Replace node with modified one.\n          return ts.visitEachChild(newNode, visitor, context);\n        }\n\n        // Otherwise return node as is.\n        return ts.visitEachChild(node, visitor, context);\n      };\n\n      return ts.visitNode(sf, visitor);\n    };\n\n    return transformer;\n  };\n}\n\nexport function findTopLevelFunctions(parentNode: ts.Node): Set<ts.Node> {\n  const topLevelFunctions = new Set<ts.Node>();\n\n  function cb(node: ts.Node) {\n    // Stop recursing into this branch if it's a definition construct.\n    // These are function expression, function declaration, class, or arrow function (lambda).\n    // The body of these constructs will not execute when loading the module, so we don't\n    // need to mark function calls inside them as pure.\n    // Class static initializers in ES2015 are an exception we don't cover. They would need similar\n    // processing as enums to prevent property setting from causing the class to be retained.\n    if (ts.isFunctionDeclaration(node)\n      || ts.isFunctionExpression(node)\n      || ts.isClassDeclaration(node)\n      || ts.isArrowFunction(node)\n      || ts.isMethodDeclaration(node)\n    ) {\n      return;\n    }\n\n    let noPureComment = !hasPureComment(node);\n    let innerNode = node;\n    while (innerNode && ts.isParenthesizedExpression(innerNode)) {\n      innerNode = innerNode.expression;\n      noPureComment = noPureComment && !hasPureComment(innerNode);\n    }\n\n    if (!innerNode) {\n      return;\n    }\n\n    if ((ts.isFunctionExpression(innerNode) || ts.isArrowFunction(innerNode))\n      && ts.isParenthesizedExpression(node)) {\n        // pure functions can be wrapped in parentizes\n        // we should not add pure comments to this sort of syntax.\n        // example var foo = (() => x)\n      return;\n    }\n\n    if (noPureComment) {\n      if (ts.isNewExpression(innerNode)) {\n        topLevelFunctions.add(node);\n      } else if (ts.isCallExpression(innerNode)) {\n        let expression: ts.Expression = innerNode.expression;\n        while (expression && ts.isParenthesizedExpression(expression)) {\n          expression = expression.expression;\n        }\n        if (expression) {\n          if (ts.isFunctionExpression(expression)) {\n            // Skip IIFE's with arguments\n            // This could be improved to check if there are any references to variables\n            if (innerNode.arguments.length === 0) {\n              topLevelFunctions.add(node);\n            }\n          } else {\n            topLevelFunctions.add(node);\n          }\n        }\n      }\n    }\n\n    ts.forEachChild(innerNode, cb);\n  }\n\n  ts.forEachChild(parentNode, cb);\n\n  return topLevelFunctions;\n}\n"]}
|