aboutsummaryrefslogtreecommitdiff
path: root/sandbox/testAppNevena/Front/node_modules/@schematics/angular/utility/ng-ast-utils.js
diff options
context:
space:
mode:
authorDanijel Andjelkovic <adanijel99@gmail.com>2022-03-01 21:54:41 +0100
committerDanijel Andjelkovic <adanijel99@gmail.com>2022-03-01 21:54:41 +0100
commit6c8128f9fd5a5d0be115806c35a21b3d683df8d6 (patch)
treef46c2f6b3b9b294ff32bd75c08ccdc9e7a8cc4ef /sandbox/testAppNevena/Front/node_modules/@schematics/angular/utility/ng-ast-utils.js
parent2400b84e95913665da6279114168148444b8f9ab (diff)
parent7d3640f824f46490b47bd95f1c5a16644f712068 (diff)
Merge branch 'dev' of http://gitlab.pmf.kg.ac.rs/igrannonica/neuronstellar into logo
Diffstat (limited to 'sandbox/testAppNevena/Front/node_modules/@schematics/angular/utility/ng-ast-utils.js')
-rw-r--r--sandbox/testAppNevena/Front/node_modules/@schematics/angular/utility/ng-ast-utils.js94
1 files changed, 94 insertions, 0 deletions
diff --git a/sandbox/testAppNevena/Front/node_modules/@schematics/angular/utility/ng-ast-utils.js b/sandbox/testAppNevena/Front/node_modules/@schematics/angular/utility/ng-ast-utils.js
new file mode 100644
index 00000000..687a3254
--- /dev/null
+++ b/sandbox/testAppNevena/Front/node_modules/@schematics/angular/utility/ng-ast-utils.js
@@ -0,0 +1,94 @@
+"use strict";
+/**
+ * @license
+ * Copyright Google LLC All Rights Reserved.
+ *
+ * Use of this source code is governed by an MIT-style license that can be
+ * found in the LICENSE file at https://angular.io/license
+ */
+var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
+ if (k2 === undefined) k2 = k;
+ Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } });
+}) : (function(o, m, k, k2) {
+ if (k2 === undefined) k2 = k;
+ o[k2] = m[k];
+}));
+var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
+}) : function(o, v) {
+ o["default"] = v;
+});
+var __importStar = (this && this.__importStar) || function (mod) {
+ if (mod && mod.__esModule) return mod;
+ var result = {};
+ if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
+ __setModuleDefault(result, mod);
+ return result;
+};
+Object.defineProperty(exports, "__esModule", { value: true });
+exports.getAppModulePath = exports.findBootstrapModulePath = exports.findBootstrapModuleCall = void 0;
+const core_1 = require("@angular-devkit/core");
+const schematics_1 = require("@angular-devkit/schematics");
+const path_1 = require("path");
+const ts = __importStar(require("../third_party/github.com/Microsoft/TypeScript/lib/typescript"));
+const ast_utils_1 = require("../utility/ast-utils");
+function findBootstrapModuleCall(host, mainPath) {
+ const mainBuffer = host.read(mainPath);
+ if (!mainBuffer) {
+ throw new schematics_1.SchematicsException(`Main file (${mainPath}) not found`);
+ }
+ const mainText = mainBuffer.toString('utf-8');
+ const source = ts.createSourceFile(mainPath, mainText, ts.ScriptTarget.Latest, true);
+ const allNodes = (0, ast_utils_1.getSourceNodes)(source);
+ let bootstrapCall = null;
+ for (const node of allNodes) {
+ let bootstrapCallNode = null;
+ bootstrapCallNode = (0, ast_utils_1.findNode)(node, ts.SyntaxKind.Identifier, 'bootstrapModule');
+ // Walk up the parent until CallExpression is found.
+ while (bootstrapCallNode &&
+ bootstrapCallNode.parent &&
+ bootstrapCallNode.parent.kind !== ts.SyntaxKind.CallExpression) {
+ bootstrapCallNode = bootstrapCallNode.parent;
+ }
+ if (bootstrapCallNode !== null &&
+ bootstrapCallNode.parent !== undefined &&
+ bootstrapCallNode.parent.kind === ts.SyntaxKind.CallExpression) {
+ bootstrapCall = bootstrapCallNode.parent;
+ break;
+ }
+ }
+ return bootstrapCall;
+}
+exports.findBootstrapModuleCall = findBootstrapModuleCall;
+function findBootstrapModulePath(host, mainPath) {
+ const bootstrapCall = findBootstrapModuleCall(host, mainPath);
+ if (!bootstrapCall) {
+ throw new schematics_1.SchematicsException('Bootstrap call not found');
+ }
+ const bootstrapModule = bootstrapCall.arguments[0];
+ const mainBuffer = host.read(mainPath);
+ if (!mainBuffer) {
+ throw new schematics_1.SchematicsException(`Client app main file (${mainPath}) not found`);
+ }
+ const mainText = mainBuffer.toString('utf-8');
+ const source = ts.createSourceFile(mainPath, mainText, ts.ScriptTarget.Latest, true);
+ const allNodes = (0, ast_utils_1.getSourceNodes)(source);
+ const bootstrapModuleRelativePath = allNodes
+ .filter(ts.isImportDeclaration)
+ .filter((imp) => {
+ return (0, ast_utils_1.findNode)(imp, ts.SyntaxKind.Identifier, bootstrapModule.getText());
+ })
+ .map((imp) => {
+ const modulePathStringLiteral = imp.moduleSpecifier;
+ return modulePathStringLiteral.text;
+ })[0];
+ return bootstrapModuleRelativePath;
+}
+exports.findBootstrapModulePath = findBootstrapModulePath;
+function getAppModulePath(host, mainPath) {
+ const moduleRelativePath = findBootstrapModulePath(host, mainPath);
+ const mainDir = (0, path_1.dirname)(mainPath);
+ const modulePath = (0, core_1.normalize)(`/${mainDir}/${moduleRelativePath}.ts`);
+ return modulePath;
+}
+exports.getAppModulePath = getAppModulePath;