NodeUtils.js 3.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103
  1. "use strict";
  2. const estraverse = require('estraverse');
  3. const NodeType_1 = require("./enums/NodeType");
  4. const Utils_1 = require("./Utils");
  5. class NodeUtils {
  6. static addXVerbatimPropertyToLiterals(node) {
  7. estraverse.replace(node, {
  8. enter: (node, parentNode) => {
  9. if (NodeUtils.isLiteralNode(node)) {
  10. node['x-verbatim-property'] = node.raw;
  11. }
  12. }
  13. });
  14. }
  15. static appendNode(blockScopeBody, node) {
  16. if (!NodeUtils.validateNode(node)) {
  17. return;
  18. }
  19. blockScopeBody.push(node);
  20. }
  21. static getBlockScopeNodeByIndex(node, index = 0) {
  22. if (NodeUtils.isNodeHasBlockScope(node) && node.body[index]) {
  23. return node.body[index];
  24. }
  25. return node;
  26. }
  27. static getBlockScopeOfNode(node, depth = 0) {
  28. if (!node.parentNode) {
  29. throw new ReferenceError('`parentNode` property of given node is `undefined`');
  30. }
  31. if (node.parentNode.type === NodeType_1.NodeType.Program) {
  32. return node.parentNode;
  33. }
  34. if (!Utils_1.Utils.arrayContains(NodeUtils.scopeNodes, node.parentNode.type)) {
  35. return NodeUtils.getBlockScopeOfNode(node.parentNode, depth);
  36. }
  37. if (depth > 0) {
  38. return NodeUtils.getBlockScopeOfNode(node.parentNode, --depth);
  39. }
  40. if (node.type !== NodeType_1.NodeType.BlockStatement) {
  41. return NodeUtils.getBlockScopeOfNode(node.parentNode);
  42. }
  43. return node;
  44. }
  45. static insertNodeAtIndex(blockScopeBody, node, index) {
  46. if (!NodeUtils.validateNode(node)) {
  47. return;
  48. }
  49. blockScopeBody.splice(index, 0, node);
  50. }
  51. static isBlockStatementNode(node) {
  52. return node.type === NodeType_1.NodeType.BlockStatement;
  53. }
  54. static isIdentifierNode(node) {
  55. return node.type === NodeType_1.NodeType.Identifier;
  56. }
  57. static isLiteralNode(node) {
  58. return node.type === NodeType_1.NodeType.Literal;
  59. }
  60. static isMemberExpressionNode(node) {
  61. return node.type === NodeType_1.NodeType.MemberExpression;
  62. }
  63. static isNodeHasBlockScope(node) {
  64. return node.hasOwnProperty('body');
  65. }
  66. static isProgramNode(node) {
  67. return node.type === NodeType_1.NodeType.Program;
  68. }
  69. static isPropertyNode(node) {
  70. return node.type === NodeType_1.NodeType.Property;
  71. }
  72. static isVariableDeclaratorNode(node) {
  73. return node.type === NodeType_1.NodeType.VariableDeclarator;
  74. }
  75. static parentize(node) {
  76. estraverse.replace(node, {
  77. enter: (node, parentNode) => {
  78. Object.defineProperty(node, 'parentNode', {
  79. configurable: true,
  80. enumerable: true,
  81. value: parentNode || node,
  82. writable: true
  83. });
  84. }
  85. });
  86. }
  87. static prependNode(blockScopeBody, node) {
  88. if (!NodeUtils.validateNode(node)) {
  89. return;
  90. }
  91. blockScopeBody.unshift(node);
  92. }
  93. static validateNode(node) {
  94. return !!node;
  95. }
  96. }
  97. NodeUtils.scopeNodes = [
  98. NodeType_1.NodeType.ArrowFunctionExpression,
  99. NodeType_1.NodeType.FunctionDeclaration,
  100. NodeType_1.NodeType.FunctionExpression,
  101. NodeType_1.NodeType.MethodDefinition
  102. ];
  103. exports.NodeUtils = NodeUtils;