ts2famix 1.4.1 → 2.0.1
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/LICENSE +1 -0
- package/README.md +30 -61
- package/dist/analyze.js +4 -2
- package/dist/analyze_functions/process_functions.js +285 -131
- package/dist/famix_functions/EntityDictionary.js +864 -231
- package/dist/famix_functions/helpers_creation.js +61 -10
- package/dist/fqn.js +160 -111
- package/dist/lib/famix/famix_JSON_exporter.js +55 -0
- package/dist/lib/famix/famix_base_element.js +18 -0
- package/dist/lib/famix/famix_repository.js +224 -0
- package/dist/lib/famix/{src/index.js → index.js} +1 -0
- package/dist/lib/famix/model/famix/access.js +40 -0
- package/dist/lib/famix/model/famix/accessor.js +17 -0
- package/dist/lib/famix/model/famix/alias.js +33 -0
- package/dist/lib/famix/model/famix/arrow_function.js +17 -0
- package/dist/lib/famix/model/famix/behavioral_entity.js +79 -0
- package/dist/lib/famix/model/famix/class.js +71 -0
- package/dist/lib/famix/model/famix/comment.js +39 -0
- package/dist/lib/famix/model/famix/concretisation.js +31 -0
- package/dist/lib/famix/model/famix/container_entity.js +126 -0
- package/dist/lib/famix/model/famix/decorator.js +32 -0
- package/dist/lib/famix/model/famix/entity.js +17 -0
- package/dist/lib/famix/model/famix/enum.js +31 -0
- package/dist/lib/famix/model/famix/enum_value.js +25 -0
- package/dist/lib/famix/model/famix/function.js +17 -0
- package/dist/lib/famix/model/famix/import_clause.js +41 -0
- package/dist/lib/famix/model/famix/index.js +86 -0
- package/dist/lib/famix/model/famix/indexed_file_anchor.js +38 -0
- package/dist/lib/famix/model/famix/inheritance.js +33 -0
- package/dist/lib/famix/model/famix/interface.js +64 -0
- package/dist/lib/famix/model/famix/invocation.js +54 -0
- package/dist/lib/famix/model/famix/method.js +67 -0
- package/dist/lib/famix/model/famix/module.js +60 -0
- package/dist/lib/famix/model/famix/named_entity.js +78 -0
- package/dist/lib/famix/model/famix/parameter.js +25 -0
- package/dist/lib/famix/model/famix/parameter_concretisation.js +44 -0
- package/dist/lib/famix/model/famix/parameter_type.js +45 -0
- package/dist/lib/famix/model/famix/parametric_arrow_function.js +31 -0
- package/dist/lib/famix/model/famix/parametric_class.js +44 -0
- package/dist/lib/famix/model/famix/parametric_function.js +31 -0
- package/dist/lib/famix/model/famix/parametric_interface.js +44 -0
- package/dist/lib/famix/model/famix/parametric_method.js +31 -0
- package/dist/lib/famix/model/famix/primitive_type.js +17 -0
- package/dist/lib/famix/model/famix/property.js +73 -0
- package/dist/lib/famix/model/famix/reference.js +33 -0
- package/dist/lib/famix/model/famix/scoping_entity.js +36 -0
- package/dist/lib/famix/model/famix/script_entity.js +29 -0
- package/dist/lib/famix/model/famix/source_anchor.js +27 -0
- package/dist/lib/famix/model/famix/source_language.js +35 -0
- package/dist/lib/famix/model/famix/sourced_entity.js +60 -0
- package/dist/lib/famix/model/famix/structural_entity.js +39 -0
- package/dist/lib/famix/model/famix/type.js +73 -0
- package/dist/lib/famix/model/famix/variable.js +24 -0
- package/dist/lib/ts-complex/cyclomatic-service.js +3 -3
- package/dist/refactorer/refactor-getter-setter.js +142 -0
- package/dist/ts2famix-cli-wrapper.js +42 -0
- package/dist/ts2famix-cli.js +8 -1
- package/dist/ts2famix-tsconfig.js +1 -0
- package/doc-uml/famix-typescript-model.puml +608 -0
- package/doc-uml/famix-typescript-model.svg +1 -0
- package/jest.config.json +2 -1
- package/package.json +13 -12
- package/src/analyze.ts +24 -23
- package/src/analyze_functions/process_functions.ts +310 -129
- package/src/famix_functions/EntityDictionary.ts +949 -271
- package/src/famix_functions/helpers_creation.ts +64 -6
- package/src/fqn.ts +169 -96
- package/{dist/lib/famix/src/famix_JSON_exporter.js → src/lib/famix/famix_JSON_exporter.ts} +16 -14
- package/src/lib/famix/famix_base_element.ts +22 -0
- package/{dist/lib/famix/src/famix_repository.js → src/lib/famix/famix_repository.ts} +96 -75
- package/src/lib/famix/model/famix/access.ts +50 -0
- package/src/lib/famix/model/famix/alias.ts +39 -0
- package/src/lib/famix/{src/model/famix/implicit_variable.ts → model/famix/arrow_function.ts} +3 -3
- package/src/lib/famix/model/famix/behavioral_entity.ts +97 -0
- package/src/lib/famix/model/famix/class.ts +85 -0
- package/src/lib/famix/model/famix/comment.ts +47 -0
- package/src/lib/famix/model/famix/concretisation.ts +40 -0
- package/src/lib/famix/model/famix/container_entity.ts +160 -0
- package/src/lib/famix/model/famix/decorator.ts +37 -0
- package/src/lib/famix/model/famix/enum.ts +30 -0
- package/src/lib/famix/model/famix/enum_value.ts +28 -0
- package/src/lib/famix/model/famix/import_clause.ts +51 -0
- package/src/lib/famix/{src/model → model}/famix/index.ts +8 -7
- package/src/lib/famix/model/famix/indexed_file_anchor.ts +46 -0
- package/src/lib/famix/model/famix/inheritance.ts +40 -0
- package/src/lib/famix/model/famix/interface.ts +75 -0
- package/src/lib/famix/model/famix/invocation.ts +65 -0
- package/src/lib/famix/model/famix/method.ts +89 -0
- package/src/lib/famix/model/famix/module.ts +71 -0
- package/src/lib/famix/model/famix/named_entity.ts +95 -0
- package/src/lib/famix/{src/model → model}/famix/parameter.ts +11 -12
- package/src/lib/famix/model/famix/parameter_concretisation.ts +51 -0
- package/src/lib/famix/model/famix/parameter_type.ts +58 -0
- package/src/lib/famix/model/famix/parametric_arrow_function.ts +32 -0
- package/src/lib/famix/model/famix/parametric_class.ts +49 -0
- package/src/lib/famix/model/famix/parametric_function.ts +32 -0
- package/src/lib/famix/model/famix/parametric_interface.ts +49 -0
- package/src/lib/famix/model/famix/parametric_method.ts +32 -0
- package/src/lib/famix/model/famix/primitive_type.ts +15 -0
- package/src/lib/famix/model/famix/property.ts +94 -0
- package/src/lib/famix/model/famix/reference.ts +40 -0
- package/src/lib/famix/model/famix/scoping_entity.ts +35 -0
- package/src/lib/famix/model/famix/script_entity.ts +34 -0
- package/src/lib/famix/model/famix/source_anchor.ts +30 -0
- package/src/lib/famix/model/famix/source_language.ts +35 -0
- package/src/lib/famix/model/famix/sourced_entity.ts +70 -0
- package/src/lib/famix/model/famix/structural_entity.ts +43 -0
- package/src/lib/famix/model/famix/type.ts +87 -0
- package/src/lib/famix/model/famix/variable.ts +27 -0
- package/src/lib/famix/package.json +1 -1
- package/src/lib/ts-complex/cyclomatic-service.ts +10 -10
- package/src/refactorer/refactor-getter-setter.ts +140 -0
- package/src/ts2famix-cli-wrapper.ts +21 -0
- package/src/ts2famix-cli.ts +8 -2
- package/tsconfig.check-tests.json +14 -0
- package/tsconfig.json +71 -69
- package/dist/famix2puml.js +0 -125
- package/dist/lib/famix/src/famix_base_element.js +0 -17
- package/dist/lib/famix/src/model/famix/access.js +0 -39
- package/dist/lib/famix/src/model/famix/accessor.js +0 -16
- package/dist/lib/famix/src/model/famix/alias.js +0 -32
- package/dist/lib/famix/src/model/famix/association.js +0 -36
- package/dist/lib/famix/src/model/famix/behavioral_entity.js +0 -81
- package/dist/lib/famix/src/model/famix/class.js +0 -70
- package/dist/lib/famix/src/model/famix/comment.js +0 -38
- package/dist/lib/famix/src/model/famix/container_entity.js +0 -125
- package/dist/lib/famix/src/model/famix/decorator.js +0 -31
- package/dist/lib/famix/src/model/famix/entity.js +0 -16
- package/dist/lib/famix/src/model/famix/enum.js +0 -30
- package/dist/lib/famix/src/model/famix/enum_value.js +0 -24
- package/dist/lib/famix/src/model/famix/function.js +0 -16
- package/dist/lib/famix/src/model/famix/implicit_variable.js +0 -16
- package/dist/lib/famix/src/model/famix/import_clause.js +0 -39
- package/dist/lib/famix/src/model/famix/index.js +0 -83
- package/dist/lib/famix/src/model/famix/indexed_file_anchor.js +0 -51
- package/dist/lib/famix/src/model/famix/inheritance.js +0 -32
- package/dist/lib/famix/src/model/famix/interface.js +0 -63
- package/dist/lib/famix/src/model/famix/invocation.js +0 -53
- package/dist/lib/famix/src/model/famix/method.js +0 -66
- package/dist/lib/famix/src/model/famix/module.js +0 -31
- package/dist/lib/famix/src/model/famix/named_entity.js +0 -77
- package/dist/lib/famix/src/model/famix/namespace.js +0 -24
- package/dist/lib/famix/src/model/famix/parameter.js +0 -24
- package/dist/lib/famix/src/model/famix/parameter_type.js +0 -24
- package/dist/lib/famix/src/model/famix/parameterizable_class.js +0 -30
- package/dist/lib/famix/src/model/famix/parameterizable_interface.js +0 -30
- package/dist/lib/famix/src/model/famix/parameterized_type.js +0 -36
- package/dist/lib/famix/src/model/famix/primitive_type.js +0 -16
- package/dist/lib/famix/src/model/famix/property.js +0 -44
- package/dist/lib/famix/src/model/famix/reference.js +0 -32
- package/dist/lib/famix/src/model/famix/scoping_entity.js +0 -35
- package/dist/lib/famix/src/model/famix/script_entity.js +0 -30
- package/dist/lib/famix/src/model/famix/source_anchor.js +0 -26
- package/dist/lib/famix/src/model/famix/source_language.js +0 -35
- package/dist/lib/famix/src/model/famix/sourced_entity.js +0 -59
- package/dist/lib/famix/src/model/famix/structural_entity.js +0 -38
- package/dist/lib/famix/src/model/famix/text_anchor.js +0 -37
- package/dist/lib/famix/src/model/famix/type.js +0 -71
- package/dist/lib/famix/src/model/famix/variable.js +0 -23
- package/doc-uml/metamodel-full.svg +0 -1
- package/doc-uml/metamodel.svg +0 -1
- package/jest.config-old.ts +0 -199
- package/plantuml.jar +0 -0
- package/src/famix2puml.ts +0 -119
- package/src/lib/famix/package-lock.json +0 -301
- package/src/lib/famix/readme.md +0 -5
- package/src/lib/famix/src/famix_JSON_exporter.ts +0 -56
- package/src/lib/famix/src/famix_base_element.ts +0 -22
- package/src/lib/famix/src/famix_repository.ts +0 -243
- package/src/lib/famix/src/model/famix/access.ts +0 -53
- package/src/lib/famix/src/model/famix/alias.ts +0 -41
- package/src/lib/famix/src/model/famix/association.ts +0 -44
- package/src/lib/famix/src/model/famix/behavioral_entity.ts +0 -107
- package/src/lib/famix/src/model/famix/class.ts +0 -86
- package/src/lib/famix/src/model/famix/comment.ts +0 -50
- package/src/lib/famix/src/model/famix/container_entity.ts +0 -165
- package/src/lib/famix/src/model/famix/decorator.ts +0 -39
- package/src/lib/famix/src/model/famix/enum.ts +0 -31
- package/src/lib/famix/src/model/famix/enum_value.ts +0 -29
- package/src/lib/famix/src/model/famix/import_clause.ts +0 -53
- package/src/lib/famix/src/model/famix/indexed_file_anchor.ts +0 -71
- package/src/lib/famix/src/model/famix/inheritance.ts +0 -42
- package/src/lib/famix/src/model/famix/interface.ts +0 -75
- package/src/lib/famix/src/model/famix/invocation.ts +0 -68
- package/src/lib/famix/src/model/famix/method.ts +0 -96
- package/src/lib/famix/src/model/famix/module.ts +0 -31
- package/src/lib/famix/src/model/famix/named_entity.ts +0 -98
- package/src/lib/famix/src/model/famix/namespace.ts +0 -28
- package/src/lib/famix/src/model/famix/parameter_type.ts +0 -33
- package/src/lib/famix/src/model/famix/parameterizable_class.ts +0 -31
- package/src/lib/famix/src/model/famix/parameterizable_interface.ts +0 -31
- package/src/lib/famix/src/model/famix/parameterized_type.ts +0 -40
- package/src/lib/famix/src/model/famix/primitive_type.ts +0 -15
- package/src/lib/famix/src/model/famix/property.ts +0 -54
- package/src/lib/famix/src/model/famix/reference.ts +0 -42
- package/src/lib/famix/src/model/famix/scoping_entity.ts +0 -35
- package/src/lib/famix/src/model/famix/script_entity.ts +0 -38
- package/src/lib/famix/src/model/famix/source_anchor.ts +0 -31
- package/src/lib/famix/src/model/famix/source_language.ts +0 -37
- package/src/lib/famix/src/model/famix/sourced_entity.ts +0 -73
- package/src/lib/famix/src/model/famix/structural_entity.ts +0 -44
- package/src/lib/famix/src/model/famix/text_anchor.ts +0 -49
- package/src/lib/famix/src/model/famix/type.ts +0 -88
- package/src/lib/famix/src/model/famix/variable.ts +0 -28
- package/src/lib/famix/tsconfig.json +0 -27
- package/src/lib/famix/tslint.json +0 -15
- /package/src/lib/famix/{src/index.ts → index.ts} +0 -0
- /package/src/lib/famix/{src/model → model}/famix/accessor.ts +0 -0
- /package/src/lib/famix/{src/model → model}/famix/entity.ts +0 -0
- /package/src/lib/famix/{src/model → model}/famix/function.ts +0 -0
|
@@ -23,47 +23,58 @@ var __importStar = (this && this.__importStar) || function (mod) {
|
|
|
23
23
|
return result;
|
|
24
24
|
};
|
|
25
25
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
26
|
-
exports.
|
|
26
|
+
exports.currentCC = exports.listOfExportMaps = exports.modules = exports.interfaces = exports.classes = exports.accessMap = exports.methodsAndFunctionsWithId = void 0;
|
|
27
|
+
exports.getModulePath = getModulePath;
|
|
28
|
+
exports.getImplementedOrExtendedInterfaces = getImplementedOrExtendedInterfaces;
|
|
29
|
+
exports.processFiles = processFiles;
|
|
30
|
+
exports.isAmbient = isAmbient;
|
|
31
|
+
exports.isNamespace = isNamespace;
|
|
32
|
+
exports.processAccesses = processAccesses;
|
|
33
|
+
exports.processImportClausesForImportEqualsDeclarations = processImportClausesForImportEqualsDeclarations;
|
|
34
|
+
exports.processImportClausesForModules = processImportClausesForModules;
|
|
35
|
+
exports.processInheritances = processInheritances;
|
|
36
|
+
exports.processInvocations = processInvocations;
|
|
37
|
+
exports.processConcretisations = processConcretisations;
|
|
27
38
|
const ts_morph_1 = require("ts-morph");
|
|
28
|
-
const Famix = __importStar(require("../lib/famix/
|
|
39
|
+
const Famix = __importStar(require("../lib/famix/model/famix"));
|
|
29
40
|
const cyclomatic_service_1 = require("../lib/ts-complex/cyclomatic-service");
|
|
30
41
|
const fs = __importStar(require("fs"));
|
|
31
42
|
const analyze_1 = require("../analyze");
|
|
43
|
+
const fqn_1 = require("../fqn");
|
|
32
44
|
exports.methodsAndFunctionsWithId = new Map(); // Maps the Famix method, constructor, getter, setter and function ids to their ts-morph method, constructor, getter, setter or function object
|
|
33
45
|
exports.accessMap = new Map(); // Maps the Famix parameter, variable, property and enum value ids to their ts-morph parameter, variable, property or enum member object
|
|
34
46
|
exports.classes = new Array(); // Array of all the classes of the source files
|
|
35
47
|
exports.interfaces = new Array(); // Array of all the interfaces of the source files
|
|
36
48
|
exports.modules = new Array(); // Array of all the source files which are modules
|
|
37
|
-
exports.
|
|
49
|
+
exports.listOfExportMaps = new Array(); // Array of all the export maps
|
|
38
50
|
/**
|
|
39
51
|
* Checks if the file has any imports or exports to be considered a module
|
|
40
52
|
* @param sourceFile A source file
|
|
41
53
|
* @returns A boolean indicating if the file is a module
|
|
42
54
|
*/
|
|
43
|
-
function
|
|
55
|
+
function isSourceFileAModule(sourceFile) {
|
|
44
56
|
return sourceFile.getImportDeclarations().length > 0 || sourceFile.getExportedDeclarations().size > 0;
|
|
45
57
|
}
|
|
46
58
|
/**
|
|
47
59
|
* Gets the path of a module to be imported
|
|
48
|
-
* @param
|
|
60
|
+
* @param importDecl An import declaration
|
|
49
61
|
* @returns The path of the module to be imported
|
|
50
62
|
*/
|
|
51
|
-
function getModulePath(
|
|
63
|
+
function getModulePath(importDecl) {
|
|
52
64
|
let path;
|
|
53
|
-
if (
|
|
54
|
-
if (
|
|
55
|
-
path =
|
|
65
|
+
if (importDecl.getModuleSpecifierSourceFile() === undefined) {
|
|
66
|
+
if (importDecl.getModuleSpecifierValue().substring(importDecl.getModuleSpecifierValue().length - 3) === ".ts") {
|
|
67
|
+
path = importDecl.getModuleSpecifierValue();
|
|
56
68
|
}
|
|
57
69
|
else {
|
|
58
|
-
path =
|
|
70
|
+
path = importDecl.getModuleSpecifierValue() + ".ts";
|
|
59
71
|
}
|
|
60
72
|
}
|
|
61
73
|
else {
|
|
62
|
-
path =
|
|
74
|
+
path = importDecl.getModuleSpecifierSourceFile().getFilePath();
|
|
63
75
|
}
|
|
64
76
|
return path;
|
|
65
77
|
}
|
|
66
|
-
exports.getModulePath = getModulePath;
|
|
67
78
|
/**
|
|
68
79
|
* Gets the interfaces implemented or extended by a class or an interface
|
|
69
80
|
* @param interfaces An array of interfaces
|
|
@@ -90,7 +101,6 @@ function getImplementedOrExtendedInterfaces(interfaces, subClass) {
|
|
|
90
101
|
});
|
|
91
102
|
return implementedOrExtendedInterfaces;
|
|
92
103
|
}
|
|
93
|
-
exports.getImplementedOrExtendedInterfaces = getImplementedOrExtendedInterfaces;
|
|
94
104
|
/**
|
|
95
105
|
* Builds a Famix model for an array of source files
|
|
96
106
|
* @param sourceFiles An array of source files
|
|
@@ -102,23 +112,24 @@ function processFiles(sourceFiles) {
|
|
|
102
112
|
if (fs.existsSync(file.getFilePath()))
|
|
103
113
|
exports.currentCC = (0, cyclomatic_service_1.calculate)(file.getFilePath());
|
|
104
114
|
else
|
|
105
|
-
exports.currentCC =
|
|
115
|
+
exports.currentCC = {};
|
|
106
116
|
processFile(file);
|
|
107
117
|
});
|
|
108
118
|
}
|
|
109
|
-
exports.processFiles = processFiles;
|
|
110
119
|
/**
|
|
111
120
|
* Builds a Famix model for a source file
|
|
112
121
|
* @param f A source file
|
|
113
122
|
*/
|
|
114
123
|
function processFile(f) {
|
|
115
|
-
const isModule =
|
|
124
|
+
const isModule = isSourceFileAModule(f);
|
|
116
125
|
if (isModule) {
|
|
117
126
|
exports.modules.push(f);
|
|
118
|
-
exports.exportedMap.push(f.getExportedDeclarations());
|
|
119
127
|
}
|
|
128
|
+
const exportMap = f.getExportedDeclarations();
|
|
129
|
+
if (exportMap)
|
|
130
|
+
exports.listOfExportMaps.push(exportMap);
|
|
120
131
|
const fmxFile = analyze_1.entityDictionary.createOrGetFamixFile(f, isModule);
|
|
121
|
-
analyze_1.logger.debug(`processFile: file: ${f.getBaseName()}, fqn = ${fmxFile.
|
|
132
|
+
analyze_1.logger.debug(`processFile: file: ${f.getBaseName()}, fqn = ${fmxFile.fullyQualifiedName}`);
|
|
122
133
|
processComments(f, fmxFile);
|
|
123
134
|
processAliases(f, fmxFile);
|
|
124
135
|
processClasses(f, fmxFile);
|
|
@@ -126,25 +137,34 @@ function processFile(f) {
|
|
|
126
137
|
processVariables(f, fmxFile);
|
|
127
138
|
processEnums(f, fmxFile);
|
|
128
139
|
processFunctions(f, fmxFile);
|
|
129
|
-
|
|
140
|
+
processModules(f, fmxFile);
|
|
141
|
+
}
|
|
142
|
+
function isAmbient(node) {
|
|
143
|
+
// An ambient module has the DeclareKeyword modifier.
|
|
144
|
+
return (node.getModifiers()?.some(modifier => modifier.getKind() === ts_morph_1.SyntaxKind.DeclareKeyword)) ?? false;
|
|
145
|
+
}
|
|
146
|
+
function isNamespace(node) {
|
|
147
|
+
// Check if the module declaration has a namespace keyword.
|
|
148
|
+
// This approach uses the getChildren() method to inspect the syntax directly.
|
|
149
|
+
return node.getChildrenOfKind(ts_morph_1.SyntaxKind.NamespaceKeyword).length > 0;
|
|
130
150
|
}
|
|
131
151
|
/**
|
|
132
|
-
* Builds a Famix model for a namespace
|
|
152
|
+
* Builds a Famix model for a module (also namespace)
|
|
133
153
|
* @param m A namespace
|
|
134
|
-
* @returns A Famix.
|
|
135
|
-
*/
|
|
136
|
-
function
|
|
137
|
-
const
|
|
138
|
-
analyze_1.logger.debug(`
|
|
139
|
-
processComments(m,
|
|
140
|
-
processAliases(m,
|
|
141
|
-
processClasses(m,
|
|
142
|
-
processInterfaces(m,
|
|
143
|
-
processVariables(m,
|
|
144
|
-
processEnums(m,
|
|
145
|
-
processFunctions(m,
|
|
146
|
-
|
|
147
|
-
return
|
|
154
|
+
* @returns A Famix.Module representing the module
|
|
155
|
+
*/
|
|
156
|
+
function processModule(m) {
|
|
157
|
+
const fmxModule = analyze_1.entityDictionary.createOrGetFamixModule(m);
|
|
158
|
+
analyze_1.logger.debug(`module: ${m.getName()}, (${m.getType().getText()}), ${fmxModule.fullyQualifiedName}`);
|
|
159
|
+
processComments(m, fmxModule);
|
|
160
|
+
processAliases(m, fmxModule);
|
|
161
|
+
processClasses(m, fmxModule);
|
|
162
|
+
processInterfaces(m, fmxModule);
|
|
163
|
+
processVariables(m, fmxModule);
|
|
164
|
+
processEnums(m, fmxModule);
|
|
165
|
+
processFunctions(m, fmxModule);
|
|
166
|
+
processModules(m, fmxModule);
|
|
167
|
+
return fmxModule;
|
|
148
168
|
}
|
|
149
169
|
/**
|
|
150
170
|
* Builds a Famix model for the aliases of a container
|
|
@@ -165,11 +185,34 @@ function processAliases(m, fmxScope) {
|
|
|
165
185
|
*/
|
|
166
186
|
function processClasses(m, fmxScope) {
|
|
167
187
|
analyze_1.logger.debug(`processClasses: ---------- Finding Classes:`);
|
|
168
|
-
m
|
|
188
|
+
const classesInArrowFunctions = getClassesDeclaredInArrowFunctions(m);
|
|
189
|
+
const classes = m.getClasses().concat(classesInArrowFunctions);
|
|
190
|
+
classes.forEach(c => {
|
|
169
191
|
const fmxClass = processClass(c);
|
|
170
192
|
fmxScope.addType(fmxClass);
|
|
171
193
|
});
|
|
172
194
|
}
|
|
195
|
+
function getArrowFunctionClasses(f) {
|
|
196
|
+
const classes = [];
|
|
197
|
+
function findClasses(node) {
|
|
198
|
+
if (node.getKind() === ts_morph_1.SyntaxKind.ClassDeclaration) {
|
|
199
|
+
classes.push(node);
|
|
200
|
+
}
|
|
201
|
+
node.getChildren().forEach(findClasses);
|
|
202
|
+
}
|
|
203
|
+
findClasses(f);
|
|
204
|
+
return classes;
|
|
205
|
+
}
|
|
206
|
+
/**
|
|
207
|
+
* ts-morph doesn't find classes in arrow functions, so we need to find them manually
|
|
208
|
+
* @param s A source file
|
|
209
|
+
* @returns the ClassDeclaration objects found in arrow functions of the source file
|
|
210
|
+
*/
|
|
211
|
+
function getClassesDeclaredInArrowFunctions(s) {
|
|
212
|
+
const arrowFunctions = s.getDescendantsOfKind(ts_morph_1.SyntaxKind.ArrowFunction);
|
|
213
|
+
const classesInArrowFunctions = arrowFunctions.map(f => getArrowFunctionClasses(f)).flat();
|
|
214
|
+
return classesInArrowFunctions;
|
|
215
|
+
}
|
|
173
216
|
/**
|
|
174
217
|
* Builds a Famix model for the interfaces of a container
|
|
175
218
|
* @param m A container (a source file or a namespace)
|
|
@@ -219,17 +262,24 @@ function processFunctions(m, fmxScope) {
|
|
|
219
262
|
const fmxFunction = processFunction(f);
|
|
220
263
|
fmxScope.addFunction(fmxFunction);
|
|
221
264
|
});
|
|
265
|
+
//find arrow functions
|
|
266
|
+
analyze_1.logger.debug(`Finding Functions:`);
|
|
267
|
+
const arrowFunctions = m.getDescendantsOfKind(ts_morph_1.SyntaxKind.ArrowFunction);
|
|
268
|
+
arrowFunctions.forEach(af => {
|
|
269
|
+
const fmxFunction = processFunction(af);
|
|
270
|
+
fmxScope.addFunction(fmxFunction);
|
|
271
|
+
});
|
|
222
272
|
}
|
|
223
273
|
/**
|
|
224
|
-
* Builds a Famix model for the
|
|
274
|
+
* Builds a Famix model for the modules of a container.
|
|
225
275
|
* @param m A container (a source file or a namespace)
|
|
226
276
|
* @param fmxScope The Famix model of the container
|
|
227
277
|
*/
|
|
228
|
-
function
|
|
229
|
-
analyze_1.logger.debug(`Finding
|
|
278
|
+
function processModules(m, fmxScope) {
|
|
279
|
+
analyze_1.logger.debug(`Finding Modules:`);
|
|
230
280
|
m.getModules().forEach(md => {
|
|
231
|
-
const
|
|
232
|
-
fmxScope.
|
|
281
|
+
const fmxModule = processModule(md);
|
|
282
|
+
fmxScope.addModule(fmxModule);
|
|
233
283
|
});
|
|
234
284
|
}
|
|
235
285
|
/**
|
|
@@ -239,19 +289,19 @@ function processNamespaces(m, fmxScope) {
|
|
|
239
289
|
*/
|
|
240
290
|
function processAlias(a) {
|
|
241
291
|
const fmxAlias = analyze_1.entityDictionary.createFamixAlias(a);
|
|
242
|
-
analyze_1.logger.debug(`Alias: ${a.getName()}, (${a.getType().getText()}), fqn = ${fmxAlias.
|
|
292
|
+
analyze_1.logger.debug(`Alias: ${a.getName()}, (${a.getType().getText()}), fqn = ${fmxAlias.fullyQualifiedName}`);
|
|
243
293
|
processComments(a, fmxAlias);
|
|
244
294
|
return fmxAlias;
|
|
245
295
|
}
|
|
246
296
|
/**
|
|
247
297
|
* Builds a Famix model for a class
|
|
248
298
|
* @param c A class
|
|
249
|
-
* @returns A Famix.Class or a Famix.
|
|
299
|
+
* @returns A Famix.Class or a Famix.ParametricClass representing the class
|
|
250
300
|
*/
|
|
251
301
|
function processClass(c) {
|
|
252
302
|
exports.classes.push(c);
|
|
253
303
|
const fmxClass = analyze_1.entityDictionary.createOrGetFamixClass(c);
|
|
254
|
-
analyze_1.logger.debug(`Class: ${c.getName()}, (${c.getType().getText()}), fqn = ${fmxClass.
|
|
304
|
+
analyze_1.logger.debug(`Class: ${c.getName()}, (${c.getType().getText()}), fqn = ${fmxClass.fullyQualifiedName}`);
|
|
255
305
|
processComments(c, fmxClass);
|
|
256
306
|
processDecorators(c, fmxClass);
|
|
257
307
|
processStructuredType(c, fmxClass);
|
|
@@ -272,12 +322,12 @@ function processClass(c) {
|
|
|
272
322
|
/**
|
|
273
323
|
* Builds a Famix model for an interface
|
|
274
324
|
* @param i An interface
|
|
275
|
-
* @returns A Famix.Interface or a Famix.
|
|
325
|
+
* @returns A Famix.Interface or a Famix.ParametricInterface representing the interface
|
|
276
326
|
*/
|
|
277
327
|
function processInterface(i) {
|
|
278
328
|
exports.interfaces.push(i);
|
|
279
329
|
const fmxInterface = analyze_1.entityDictionary.createOrGetFamixInterface(i);
|
|
280
|
-
analyze_1.logger.debug(`Interface: ${i.getName()}, (${i.getType().getText()}), fqn = ${fmxInterface.
|
|
330
|
+
analyze_1.logger.debug(`Interface: ${i.getName()}, (${i.getType().getText()}), fqn = ${fmxInterface.fullyQualifiedName}`);
|
|
281
331
|
processComments(i, fmxInterface);
|
|
282
332
|
processStructuredType(i, fmxInterface);
|
|
283
333
|
return fmxInterface;
|
|
@@ -289,7 +339,7 @@ function processInterface(i) {
|
|
|
289
339
|
*/
|
|
290
340
|
function processStructuredType(c, fmxScope) {
|
|
291
341
|
analyze_1.logger.debug(`Finding Properties and Methods:`);
|
|
292
|
-
if (fmxScope instanceof Famix.
|
|
342
|
+
if (fmxScope instanceof Famix.ParametricClass || fmxScope instanceof Famix.ParametricInterface) {
|
|
293
343
|
processTypeParameters(c, fmxScope);
|
|
294
344
|
}
|
|
295
345
|
c.getProperties().forEach(prop => {
|
|
@@ -308,15 +358,16 @@ function processStructuredType(c, fmxScope) {
|
|
|
308
358
|
*/
|
|
309
359
|
function processProperty(p) {
|
|
310
360
|
const fmxProperty = analyze_1.entityDictionary.createFamixProperty(p);
|
|
311
|
-
analyze_1.logger.debug(`property: ${p.getName()}, (${p.getType().getText()}), fqn = ${fmxProperty.
|
|
361
|
+
analyze_1.logger.debug(`property: ${p.getName()}, (${p.getType().getText()}), fqn = ${fmxProperty.fullyQualifiedName}`);
|
|
312
362
|
analyze_1.logger.debug(` ---> It's a Property${(p instanceof ts_morph_1.PropertySignature) ? "Signature" : "Declaration"}!`);
|
|
313
363
|
const ancestor = p.getFirstAncestorOrThrow();
|
|
314
364
|
analyze_1.logger.debug(` ---> Its first ancestor is a ${ancestor.getKindName()}`);
|
|
365
|
+
// decorators
|
|
315
366
|
if (!(p instanceof ts_morph_1.PropertySignature)) {
|
|
316
367
|
processDecorators(p, fmxProperty);
|
|
317
368
|
// only add access if the p's first ancestor is not a PropertyDeclaration
|
|
318
369
|
if (ancestor.getKindName() !== "PropertyDeclaration") {
|
|
319
|
-
analyze_1.logger.debug(`adding access: ${p.getName()}, (${p.getType().getText()}) Famix ${fmxProperty.
|
|
370
|
+
analyze_1.logger.debug(`adding access to map: ${p.getName()}, (${p.getType().getText()}) Famix ${fmxProperty.name} id: ${fmxProperty.id}`);
|
|
320
371
|
exports.accessMap.set(fmxProperty.id, p);
|
|
321
372
|
}
|
|
322
373
|
}
|
|
@@ -329,8 +380,8 @@ function processProperty(p) {
|
|
|
329
380
|
* @returns A Famix.Method or a Famix.Accessor representing the method or the accessor
|
|
330
381
|
*/
|
|
331
382
|
function processMethod(m) {
|
|
332
|
-
const fmxMethod = analyze_1.entityDictionary.
|
|
333
|
-
analyze_1.logger.debug(`Method: ${!(m instanceof ts_morph_1.ConstructorDeclaration) ? m.getName() : "constructor"}, (${m.getType().getText()}), parent: ${m.getParent().getName()}, fqn = ${fmxMethod.
|
|
383
|
+
const fmxMethod = analyze_1.entityDictionary.createOrGetFamixMethod(m, exports.currentCC);
|
|
384
|
+
analyze_1.logger.debug(`Method: ${!(m instanceof ts_morph_1.ConstructorDeclaration) ? m.getName() : "constructor"}, (${m.getType().getText()}), parent: ${m.getParent().getName()}, fqn = ${fmxMethod.fullyQualifiedName}`);
|
|
334
385
|
processComments(m, fmxMethod);
|
|
335
386
|
processTypeParameters(m, fmxMethod);
|
|
336
387
|
processParameters(m, fmxMethod);
|
|
@@ -353,8 +404,14 @@ function processMethod(m) {
|
|
|
353
404
|
* @returns A Famix.Function representing the function
|
|
354
405
|
*/
|
|
355
406
|
function processFunction(f) {
|
|
356
|
-
|
|
357
|
-
|
|
407
|
+
analyze_1.logger.debug(`Function: ${(f instanceof ts_morph_1.ArrowFunction ? "anonymous" : f.getName() ? f.getName() : "anonymous")}, (${f.getType().getText()}), fqn = ${(0, fqn_1.getFQN)(f)}`);
|
|
408
|
+
let fmxFunction;
|
|
409
|
+
if (f instanceof ts_morph_1.ArrowFunction) {
|
|
410
|
+
fmxFunction = analyze_1.entityDictionary.createFamixArrowFunction(f, exports.currentCC);
|
|
411
|
+
}
|
|
412
|
+
else {
|
|
413
|
+
fmxFunction = analyze_1.entityDictionary.createOrGetFamixFunction(f, exports.currentCC);
|
|
414
|
+
}
|
|
358
415
|
processComments(f, fmxFunction);
|
|
359
416
|
processAliases(f, fmxFunction);
|
|
360
417
|
processTypeParameters(f, fmxFunction);
|
|
@@ -391,22 +448,87 @@ function processParameters(m, fmxScope) {
|
|
|
391
448
|
m.getParameters().forEach(param => {
|
|
392
449
|
const fmxParam = processParameter(param);
|
|
393
450
|
fmxScope.addParameter(fmxParam);
|
|
451
|
+
// Additional handling for Parameter Properties in constructors
|
|
452
|
+
if (m instanceof ts_morph_1.ConstructorDeclaration) {
|
|
453
|
+
// Check if the parameter has any visibility modifier
|
|
454
|
+
if (param.hasModifier(ts_morph_1.SyntaxKind.PrivateKeyword) || param.hasModifier(ts_morph_1.SyntaxKind.PublicKeyword) || param.hasModifier(ts_morph_1.SyntaxKind.ProtectedKeyword) || param.hasModifier(ts_morph_1.SyntaxKind.ReadonlyKeyword)) {
|
|
455
|
+
const classOfConstructor = m.getParent();
|
|
456
|
+
analyze_1.logger.info(`Parameter Property ${param.getName()} in constructor of ${classOfConstructor.getName()}.`);
|
|
457
|
+
// Treat the parameter as a property and add it to the class
|
|
458
|
+
const fmxProperty = processParameterAsProperty(param, classOfConstructor);
|
|
459
|
+
fmxProperty.readOnly = param.hasModifier(ts_morph_1.SyntaxKind.ReadonlyKeyword);
|
|
460
|
+
}
|
|
461
|
+
}
|
|
394
462
|
});
|
|
395
463
|
}
|
|
464
|
+
// This function should create a Famix.Property model from a ParameterDeclaration
|
|
465
|
+
// You'll need to implement it according to your Famix model structure
|
|
466
|
+
function processParameterAsProperty(param, classDecl) {
|
|
467
|
+
// Convert the parameter into a Property
|
|
468
|
+
const propertyRepresentation = convertParameterToPropertyRepresentation(param);
|
|
469
|
+
// Add the property to the class so we can have a PropertyDeclaration object
|
|
470
|
+
classDecl.addProperty(propertyRepresentation);
|
|
471
|
+
const property = classDecl.getProperty(propertyRepresentation.name);
|
|
472
|
+
if (!property) {
|
|
473
|
+
throw new Error(`Property ${propertyRepresentation.name} not found in class ${classDecl.getName()}`);
|
|
474
|
+
}
|
|
475
|
+
const fmxProperty = analyze_1.entityDictionary.createFamixProperty(property);
|
|
476
|
+
if (classDecl instanceof ts_morph_1.ClassDeclaration) {
|
|
477
|
+
const fmxClass = analyze_1.entityDictionary.createOrGetFamixClass(classDecl);
|
|
478
|
+
fmxClass.addProperty(fmxProperty);
|
|
479
|
+
}
|
|
480
|
+
else {
|
|
481
|
+
throw new Error("Unexpected type ClassExpression.");
|
|
482
|
+
}
|
|
483
|
+
processComments(property, fmxProperty);
|
|
484
|
+
// remove the property from the class
|
|
485
|
+
property.remove();
|
|
486
|
+
return fmxProperty;
|
|
487
|
+
}
|
|
488
|
+
function convertParameterToPropertyRepresentation(param) {
|
|
489
|
+
// Extract name
|
|
490
|
+
const paramName = param.getName();
|
|
491
|
+
// Extract type
|
|
492
|
+
const paramType = param.getType().getText(param);
|
|
493
|
+
// Determine visibility
|
|
494
|
+
let scope;
|
|
495
|
+
if (param.hasModifier(ts_morph_1.SyntaxKind.PrivateKeyword)) {
|
|
496
|
+
scope = ts_morph_1.Scope.Private;
|
|
497
|
+
}
|
|
498
|
+
else if (param.hasModifier(ts_morph_1.SyntaxKind.ProtectedKeyword)) {
|
|
499
|
+
scope = ts_morph_1.Scope.Protected;
|
|
500
|
+
}
|
|
501
|
+
else if (param.hasModifier(ts_morph_1.SyntaxKind.PublicKeyword)) {
|
|
502
|
+
scope = ts_morph_1.Scope.Public;
|
|
503
|
+
}
|
|
504
|
+
else {
|
|
505
|
+
throw new Error(`Parameter property ${paramName} in constructor does not have a visibility modifier.`);
|
|
506
|
+
}
|
|
507
|
+
// Determine if readonly
|
|
508
|
+
const isReadonly = param.hasModifier(ts_morph_1.SyntaxKind.ReadonlyKeyword);
|
|
509
|
+
// Create a representation of the property
|
|
510
|
+
const propertyRepresentation = {
|
|
511
|
+
name: paramName,
|
|
512
|
+
type: paramType,
|
|
513
|
+
scope: scope,
|
|
514
|
+
isReadonly: isReadonly,
|
|
515
|
+
};
|
|
516
|
+
return propertyRepresentation;
|
|
517
|
+
}
|
|
396
518
|
/**
|
|
397
519
|
* Builds a Famix model for a parameter
|
|
398
|
-
* @param
|
|
520
|
+
* @param paramDecl A parameter
|
|
399
521
|
* @returns A Famix.Parameter representing the parameter
|
|
400
522
|
*/
|
|
401
|
-
function processParameter(
|
|
402
|
-
const fmxParam = analyze_1.entityDictionary.createFamixParameter(
|
|
403
|
-
analyze_1.logger.debug(`parameter: ${
|
|
404
|
-
processComments(
|
|
405
|
-
processDecorators(
|
|
406
|
-
const parent =
|
|
523
|
+
function processParameter(paramDecl) {
|
|
524
|
+
const fmxParam = analyze_1.entityDictionary.createFamixParameter(paramDecl);
|
|
525
|
+
analyze_1.logger.debug(`parameter: ${paramDecl.getName()}, (${paramDecl.getType().getText()}), fqn = ${fmxParam.fullyQualifiedName}`);
|
|
526
|
+
processComments(paramDecl, fmxParam);
|
|
527
|
+
processDecorators(paramDecl, fmxParam);
|
|
528
|
+
const parent = paramDecl.getParent();
|
|
407
529
|
if (!(parent instanceof ts_morph_1.MethodSignature)) {
|
|
408
|
-
analyze_1.logger.debug(`adding access: ${
|
|
409
|
-
exports.accessMap.set(fmxParam.id,
|
|
530
|
+
analyze_1.logger.debug(`adding access: ${paramDecl.getName()}, (${paramDecl.getType().getText()}) Famix ${fmxParam.name}`);
|
|
531
|
+
exports.accessMap.set(fmxParam.id, paramDecl);
|
|
410
532
|
}
|
|
411
533
|
return fmxParam;
|
|
412
534
|
}
|
|
@@ -419,7 +541,7 @@ function processTypeParameters(e, fmxScope) {
|
|
|
419
541
|
analyze_1.logger.debug(`Finding Type Parameters:`);
|
|
420
542
|
e.getTypeParameters().forEach(tp => {
|
|
421
543
|
const fmxParam = processTypeParameter(tp);
|
|
422
|
-
fmxScope.
|
|
544
|
+
fmxScope.addGenericParameter(fmxParam);
|
|
423
545
|
});
|
|
424
546
|
}
|
|
425
547
|
/**
|
|
@@ -429,7 +551,7 @@ function processTypeParameters(e, fmxScope) {
|
|
|
429
551
|
*/
|
|
430
552
|
function processTypeParameter(tp) {
|
|
431
553
|
const fmxTypeParameter = analyze_1.entityDictionary.createFamixParameterType(tp);
|
|
432
|
-
analyze_1.logger.debug(`type parameter: ${tp.getName()}, (${tp.getType().getText()}), fqn = ${fmxTypeParameter.
|
|
554
|
+
analyze_1.logger.debug(`type parameter: ${tp.getName()}, (${tp.getType().getText()}), fqn = ${fmxTypeParameter.fullyQualifiedName}`);
|
|
433
555
|
processComments(tp, fmxTypeParameter);
|
|
434
556
|
return fmxTypeParameter;
|
|
435
557
|
}
|
|
@@ -455,9 +577,9 @@ function processVariableStatement(v) {
|
|
|
455
577
|
*/
|
|
456
578
|
function processVariable(v) {
|
|
457
579
|
const fmxVar = analyze_1.entityDictionary.createFamixVariable(v);
|
|
458
|
-
analyze_1.logger.debug(`variable: ${v.getName()}, (${v.getType().getText()}), ${v.getInitializer() ? "initializer: " + v.getInitializer().getText() : "initializer: "}, fqn = ${fmxVar.
|
|
580
|
+
analyze_1.logger.debug(`variable: ${v.getName()}, (${v.getType().getText()}), ${v.getInitializer() ? "initializer: " + v.getInitializer().getText() : "initializer: "}, fqn = ${fmxVar.fullyQualifiedName}`);
|
|
459
581
|
processComments(v, fmxVar);
|
|
460
|
-
analyze_1.logger.debug(`adding access: ${v.getName()}, (${v.getType().getText()}) Famix ${fmxVar.
|
|
582
|
+
analyze_1.logger.debug(`adding access: ${v.getName()}, (${v.getType().getText()}) Famix ${fmxVar.name}`);
|
|
461
583
|
exports.accessMap.set(fmxVar.id, v);
|
|
462
584
|
return fmxVar;
|
|
463
585
|
}
|
|
@@ -468,7 +590,7 @@ function processVariable(v) {
|
|
|
468
590
|
*/
|
|
469
591
|
function processEnum(e) {
|
|
470
592
|
const fmxEnum = analyze_1.entityDictionary.createFamixEnum(e);
|
|
471
|
-
analyze_1.logger.debug(`enum: ${e.getName()}, (${e.getType().getText()}), fqn = ${fmxEnum.
|
|
593
|
+
analyze_1.logger.debug(`enum: ${e.getName()}, (${e.getType().getText()}), fqn = ${fmxEnum.fullyQualifiedName}`);
|
|
472
594
|
processComments(e, fmxEnum);
|
|
473
595
|
e.getMembers().forEach(m => {
|
|
474
596
|
const fmxEnumValue = processEnumValue(m);
|
|
@@ -483,9 +605,9 @@ function processEnum(e) {
|
|
|
483
605
|
*/
|
|
484
606
|
function processEnumValue(v) {
|
|
485
607
|
const fmxEnumValue = analyze_1.entityDictionary.createFamixEnumValue(v);
|
|
486
|
-
analyze_1.logger.debug(`enum value: ${v.getName()}, (${v.getType().getText()}), fqn = ${fmxEnumValue.
|
|
608
|
+
analyze_1.logger.debug(`enum value: ${v.getName()}, (${v.getType().getText()}), fqn = ${fmxEnumValue.fullyQualifiedName}`);
|
|
487
609
|
processComments(v, fmxEnumValue);
|
|
488
|
-
analyze_1.logger.debug(`adding access: ${v.getName()}, (${v.getType().getText()}) Famix ${fmxEnumValue.
|
|
610
|
+
analyze_1.logger.debug(`adding access: ${v.getName()}, (${v.getType().getText()}) Famix ${fmxEnumValue.name}`);
|
|
489
611
|
exports.accessMap.set(fmxEnumValue.id, v);
|
|
490
612
|
return fmxEnumValue;
|
|
491
613
|
}
|
|
@@ -509,7 +631,7 @@ function processDecorators(e, fmxScope) {
|
|
|
509
631
|
*/
|
|
510
632
|
function processDecorator(d, e) {
|
|
511
633
|
const fmxDec = analyze_1.entityDictionary.createOrGetFamixDecorator(d, e);
|
|
512
|
-
analyze_1.logger.debug(`decorator: ${d.getName()}, (${d.getType().getText()}), fqn = ${fmxDec.
|
|
634
|
+
analyze_1.logger.debug(`decorator: ${d.getName()}, (${d.getType().getText()}), fqn = ${fmxDec.fullyQualifiedName}`);
|
|
513
635
|
processComments(d, fmxDec);
|
|
514
636
|
return fmxDec;
|
|
515
637
|
}
|
|
@@ -548,41 +670,40 @@ function processComment(c, fmxScope) {
|
|
|
548
670
|
* @param accessMap A map of parameters, variables, properties and enum members with their id
|
|
549
671
|
*/
|
|
550
672
|
function processAccesses(accessMap) {
|
|
551
|
-
analyze_1.logger.debug(`
|
|
673
|
+
analyze_1.logger.debug(`Creating accesses:`);
|
|
552
674
|
accessMap.forEach((v, id) => {
|
|
553
|
-
analyze_1.logger.debug(`
|
|
554
|
-
try {
|
|
555
|
-
|
|
556
|
-
|
|
557
|
-
}
|
|
558
|
-
|
|
559
|
-
|
|
560
|
-
}
|
|
675
|
+
analyze_1.logger.debug(`Accesses to ${v.getName()}`);
|
|
676
|
+
// try {
|
|
677
|
+
const temp_nodes = v.findReferencesAsNodes();
|
|
678
|
+
temp_nodes.forEach(node => processNodeForAccesses(node, id));
|
|
679
|
+
// } catch (error) {
|
|
680
|
+
// logger.error(`> WARNING: got exception "${error}".\nContinuing...`);
|
|
681
|
+
// }
|
|
561
682
|
});
|
|
562
683
|
}
|
|
563
|
-
exports.processAccesses = processAccesses;
|
|
564
684
|
/**
|
|
565
685
|
* Builds a Famix model for an access on a parameter, variable, property or enum member
|
|
566
686
|
* @param n A node
|
|
567
687
|
* @param id An id of a parameter, a variable, a property or an enum member
|
|
568
688
|
*/
|
|
569
689
|
function processNodeForAccesses(n, id) {
|
|
570
|
-
try {
|
|
571
|
-
|
|
572
|
-
|
|
573
|
-
|
|
574
|
-
|
|
575
|
-
|
|
576
|
-
|
|
577
|
-
|
|
578
|
-
}
|
|
579
|
-
analyze_1.entityDictionary.createFamixAccess(n, id);
|
|
580
|
-
analyze_1.logger.debug(`processNodeForAccesses: node kind: ${n.getKindName()}, ${n.getText()}, (${n.getType().getText()})`);
|
|
581
|
-
}
|
|
582
|
-
catch (error) {
|
|
583
|
-
analyze_1.logger.error(`> WARNING: got exception ${error}. ScopeDeclaration invalid for ${n.getSymbol().getFullyQualifiedName()}. Continuing...`);
|
|
690
|
+
// try {
|
|
691
|
+
// sometimes node's first ancestor is a PropertyDeclaration, which is not an access
|
|
692
|
+
// see https://github.com/fuhrmanator/FamixTypeScriptImporter/issues/9
|
|
693
|
+
// check for a node whose first ancestor is a property declaration and bail?
|
|
694
|
+
// This may be a bug in ts-morph?
|
|
695
|
+
if (n.getFirstAncestorOrThrow().getKindName() === "PropertyDeclaration") {
|
|
696
|
+
analyze_1.logger.debug(`processNodeForAccesses: node kind: ${n.getKindName()}, ${n.getText()}, (${n.getType().getText()})'s first ancestor is a PropertyDeclaration. Skipping...`);
|
|
697
|
+
return;
|
|
584
698
|
}
|
|
585
|
-
|
|
699
|
+
analyze_1.entityDictionary.createFamixAccess(n, id);
|
|
700
|
+
analyze_1.logger.debug(`processNodeForAccesses: node kind: ${n.getKindName()}, ${n.getText()}, (${n.getType().getText()})`);
|
|
701
|
+
// } catch (error) {
|
|
702
|
+
// logger.error(`> Got exception "${error}".\nScopeDeclaration invalid for "${n.getSymbol().fullyQualifiedName}".\nContinuing...`);
|
|
703
|
+
// }
|
|
704
|
+
}
|
|
705
|
+
// exports has name -> Declaration -- the declaration can be used to find the FamixElement
|
|
706
|
+
// handle `import path = require("path")` for example
|
|
586
707
|
function processImportClausesForImportEqualsDeclarations(sourceFiles, exports) {
|
|
587
708
|
analyze_1.logger.info(`Creating import clauses from ImportEqualsDeclarations in source files:`);
|
|
588
709
|
sourceFiles.forEach(sourceFile => {
|
|
@@ -591,41 +712,39 @@ function processImportClausesForImportEqualsDeclarations(sourceFiles, exports) {
|
|
|
591
712
|
// You've found an ImportEqualsDeclaration
|
|
592
713
|
analyze_1.logger.info("Declaration Name:", node.getName());
|
|
593
714
|
analyze_1.logger.info("Module Reference Text:", node.getModuleReference().getText());
|
|
715
|
+
// what's the name of the imported entity?
|
|
716
|
+
// const importedEntity = node.getName();
|
|
594
717
|
// create a famix import clause
|
|
595
718
|
const namedImport = node.getNameNode();
|
|
596
|
-
analyze_1.entityDictionary.
|
|
597
|
-
|
|
719
|
+
analyze_1.entityDictionary.oldCreateFamixImportClause({ importDeclaration: node,
|
|
720
|
+
importerSourceFile: sourceFile,
|
|
598
721
|
moduleSpecifierFilePath: node.getModuleReference().getText(),
|
|
599
722
|
importElement: namedImport,
|
|
600
723
|
isInExports: exports.find(e => e.has(namedImport.getText())) !== undefined,
|
|
601
724
|
isDefaultExport: false });
|
|
725
|
+
// entityDictionary.createFamixImportClause(importedEntity, importingEntity);
|
|
602
726
|
}
|
|
603
727
|
});
|
|
604
728
|
});
|
|
605
729
|
}
|
|
606
|
-
exports.processImportClausesForImportEqualsDeclarations = processImportClausesForImportEqualsDeclarations;
|
|
607
730
|
/**
|
|
608
|
-
|
|
609
|
-
|
|
610
|
-
|
|
611
|
-
|
|
731
|
+
* Builds a Famix model for the import clauses of the source files which are modules
|
|
732
|
+
* @param modules An array of modules
|
|
733
|
+
* @param exports An array of maps of exported declarations
|
|
734
|
+
*/
|
|
612
735
|
function processImportClausesForModules(modules, exports) {
|
|
613
736
|
analyze_1.logger.info(`Creating import clauses from ${modules.length} modules:`);
|
|
614
737
|
modules.forEach(module => {
|
|
738
|
+
const modulePath = module.getFilePath() + module.getBaseName();
|
|
615
739
|
module.getImportDeclarations().forEach(impDecl => {
|
|
616
|
-
analyze_1.logger.
|
|
740
|
+
analyze_1.logger.info(`Importing ${impDecl.getModuleSpecifierValue()} in ${modulePath}`);
|
|
617
741
|
const path = getModulePath(impDecl);
|
|
618
742
|
impDecl.getNamedImports().forEach(namedImport => {
|
|
619
|
-
analyze_1.logger.
|
|
743
|
+
analyze_1.logger.info(`Importing (named) ${namedImport.getName()} from ${impDecl.getModuleSpecifierValue()} in ${modulePath}`);
|
|
620
744
|
const importedEntityName = namedImport.getName();
|
|
621
|
-
let importFoundInExports =
|
|
622
|
-
|
|
623
|
-
|
|
624
|
-
importFoundInExports = true;
|
|
625
|
-
}
|
|
626
|
-
});
|
|
627
|
-
analyze_1.entityDictionary.createFamixImportClause({ importDeclaration: impDecl,
|
|
628
|
-
importer: module,
|
|
745
|
+
let importFoundInExports = isInExports(exports, importedEntityName);
|
|
746
|
+
analyze_1.entityDictionary.oldCreateFamixImportClause({ importDeclaration: impDecl,
|
|
747
|
+
importerSourceFile: module,
|
|
629
748
|
moduleSpecifierFilePath: path,
|
|
630
749
|
importElement: namedImport,
|
|
631
750
|
isInExports: importFoundInExports,
|
|
@@ -633,10 +752,10 @@ function processImportClausesForModules(modules, exports) {
|
|
|
633
752
|
});
|
|
634
753
|
const defaultImport = impDecl.getDefaultImport();
|
|
635
754
|
if (defaultImport !== undefined) {
|
|
636
|
-
analyze_1.logger.
|
|
755
|
+
analyze_1.logger.info(`Importing (default) ${defaultImport.getText()} from ${impDecl.getModuleSpecifierValue()} in ${modulePath}`);
|
|
637
756
|
// call with module, impDecl.getModuleSpecifierValue(), path, defaultImport, false, true
|
|
638
|
-
analyze_1.entityDictionary.
|
|
639
|
-
|
|
757
|
+
analyze_1.entityDictionary.oldCreateFamixImportClause({ importDeclaration: impDecl,
|
|
758
|
+
importerSourceFile: module,
|
|
640
759
|
moduleSpecifierFilePath: path,
|
|
641
760
|
importElement: defaultImport,
|
|
642
761
|
isInExports: false,
|
|
@@ -644,9 +763,9 @@ function processImportClausesForModules(modules, exports) {
|
|
|
644
763
|
}
|
|
645
764
|
const namespaceImport = impDecl.getNamespaceImport();
|
|
646
765
|
if (namespaceImport !== undefined) {
|
|
647
|
-
analyze_1.logger.
|
|
648
|
-
analyze_1.entityDictionary.
|
|
649
|
-
|
|
766
|
+
analyze_1.logger.info(`Importing (namespace) ${namespaceImport.getText()} from ${impDecl.getModuleSpecifierValue()} in ${modulePath}`);
|
|
767
|
+
analyze_1.entityDictionary.oldCreateFamixImportClause({ importDeclaration: impDecl,
|
|
768
|
+
importerSourceFile: module,
|
|
650
769
|
moduleSpecifierFilePath: path,
|
|
651
770
|
importElement: namespaceImport,
|
|
652
771
|
isInExports: false,
|
|
@@ -656,12 +775,20 @@ function processImportClausesForModules(modules, exports) {
|
|
|
656
775
|
});
|
|
657
776
|
});
|
|
658
777
|
}
|
|
659
|
-
exports
|
|
778
|
+
function isInExports(exports, importedEntityName) {
|
|
779
|
+
let importFoundInExports = false;
|
|
780
|
+
exports.forEach(e => {
|
|
781
|
+
if (e.has(importedEntityName)) {
|
|
782
|
+
importFoundInExports = true;
|
|
783
|
+
}
|
|
784
|
+
});
|
|
785
|
+
return importFoundInExports;
|
|
786
|
+
}
|
|
660
787
|
/**
|
|
661
|
-
|
|
662
|
-
|
|
663
|
-
|
|
664
|
-
|
|
788
|
+
* Builds a Famix model for the inheritances of the classes and interfaces of the source files
|
|
789
|
+
* @param classes An array of classes
|
|
790
|
+
* @param interfaces An array of interfaces
|
|
791
|
+
*/
|
|
665
792
|
function processInheritances(classes, interfaces) {
|
|
666
793
|
analyze_1.logger.info(`processInheritances: Creating inheritances:`);
|
|
667
794
|
classes.forEach(cls => {
|
|
@@ -687,7 +814,6 @@ function processInheritances(classes, interfaces) {
|
|
|
687
814
|
});
|
|
688
815
|
});
|
|
689
816
|
}
|
|
690
|
-
exports.processInheritances = processInheritances;
|
|
691
817
|
/**
|
|
692
818
|
* Builds a Famix model for the invocations of the methods and functions of the source files
|
|
693
819
|
* @param methodsAndFunctionsWithId A map of methods and functions with their id
|
|
@@ -695,17 +821,18 @@ exports.processInheritances = processInheritances;
|
|
|
695
821
|
function processInvocations(methodsAndFunctionsWithId) {
|
|
696
822
|
analyze_1.logger.info(`Creating invocations:`);
|
|
697
823
|
methodsAndFunctionsWithId.forEach((m, id) => {
|
|
698
|
-
|
|
699
|
-
|
|
700
|
-
|
|
701
|
-
|
|
702
|
-
|
|
703
|
-
|
|
704
|
-
|
|
824
|
+
if (!(m instanceof ts_morph_1.ArrowFunction)) {
|
|
825
|
+
analyze_1.logger.debug(`Invocations to ${(m instanceof ts_morph_1.MethodDeclaration || m instanceof ts_morph_1.GetAccessorDeclaration || m instanceof ts_morph_1.SetAccessorDeclaration || m instanceof ts_morph_1.FunctionDeclaration) ? m.getName() : ((m instanceof ts_morph_1.ConstructorDeclaration) ? 'constructor' : (m.getName() ? m.getName() : 'anonymous'))}`);
|
|
826
|
+
try {
|
|
827
|
+
const temp_nodes = m.findReferencesAsNodes();
|
|
828
|
+
temp_nodes.forEach(node => processNodeForInvocations(node, m, id));
|
|
829
|
+
}
|
|
830
|
+
catch (error) {
|
|
831
|
+
analyze_1.logger.error(`> WARNING: got exception ${error}. Continuing...`);
|
|
832
|
+
}
|
|
705
833
|
}
|
|
706
834
|
});
|
|
707
835
|
}
|
|
708
|
-
exports.processInvocations = processInvocations;
|
|
709
836
|
/**
|
|
710
837
|
* Builds a Famix model for an invocation of a method or a function
|
|
711
838
|
* @param n A node
|
|
@@ -721,3 +848,30 @@ function processNodeForInvocations(n, m, id) {
|
|
|
721
848
|
analyze_1.logger.error(`> WARNING: got exception ${error}. ScopeDeclaration invalid for ${n.getSymbol().getFullyQualifiedName()}. Continuing...`);
|
|
722
849
|
}
|
|
723
850
|
}
|
|
851
|
+
/**
|
|
852
|
+
* Builds a Famix model for the inheritances of the classes and interfaces of the source files
|
|
853
|
+
* @param classes An array of classes
|
|
854
|
+
* @param interfaces An array of interfaces
|
|
855
|
+
*/
|
|
856
|
+
function processConcretisations(classes, interfaces, functions) {
|
|
857
|
+
analyze_1.logger.info(`processConcretisations: Creating concretisations:`);
|
|
858
|
+
classes.forEach(cls => {
|
|
859
|
+
analyze_1.logger.debug(`processConcretisations: Checking class concretisation for ${cls.getName()}`);
|
|
860
|
+
analyze_1.entityDictionary.createFamixConcretisationClassOrInterfaceSpecialisation(cls);
|
|
861
|
+
analyze_1.entityDictionary.createFamixConcretisationGenericInstantiation(cls);
|
|
862
|
+
analyze_1.entityDictionary.createFamixConcretisationInterfaceClass(cls);
|
|
863
|
+
analyze_1.entityDictionary.createFamixConcretisationTypeInstanciation(cls);
|
|
864
|
+
});
|
|
865
|
+
interfaces.forEach(inter => {
|
|
866
|
+
analyze_1.logger.debug(`processConcretisations: Checking interface concretisation for ${inter.getName()}`);
|
|
867
|
+
analyze_1.entityDictionary.createFamixConcretisationTypeInstanciation(inter);
|
|
868
|
+
analyze_1.entityDictionary.createFamixConcretisationClassOrInterfaceSpecialisation(inter);
|
|
869
|
+
});
|
|
870
|
+
functions.forEach(func => {
|
|
871
|
+
if (func instanceof ts_morph_1.FunctionDeclaration || func instanceof ts_morph_1.MethodDeclaration) {
|
|
872
|
+
analyze_1.logger.debug(`processConcretisations: Checking Method concretisation`);
|
|
873
|
+
analyze_1.entityDictionary.createFamixConcretisationFunctionInstantiation(func);
|
|
874
|
+
}
|
|
875
|
+
});
|
|
876
|
+
}
|
|
877
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"process_functions.js","sourceRoot":"","sources":["../../src/analyze_functions/process_functions.ts"],"names":[],"mappings":"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","sourcesContent":["import { ClassDeclaration, MethodDeclaration, VariableStatement, FunctionDeclaration, VariableDeclaration, InterfaceDeclaration, ParameterDeclaration, ConstructorDeclaration, MethodSignature, SourceFile, ModuleDeclaration, PropertyDeclaration, PropertySignature, Decorator, GetAccessorDeclaration, SetAccessorDeclaration, ExportedDeclarations, CommentRange, EnumDeclaration, EnumMember, TypeParameterDeclaration, TypeAliasDeclaration, SyntaxKind, FunctionExpression, Block, Identifier, ExpressionWithTypeArguments, ImportDeclaration, Node, ArrowFunction, Scope, ClassExpression } from \"ts-morph\";\nimport * as Famix from \"../lib/famix/model/famix\";\nimport { calculate } from \"../lib/ts-complex/cyclomatic-service\";\nimport * as fs from 'fs';\nimport { logger , entityDictionary } from \"../analyze\";\nimport { getFQN } from \"../fqn\";\n\nexport type AccessibleTSMorphElement = ParameterDeclaration | VariableDeclaration | PropertyDeclaration | EnumMember;\nexport type FamixID = number;\n\nexport const methodsAndFunctionsWithId = new Map<number, MethodDeclaration | ConstructorDeclaration | GetAccessorDeclaration | SetAccessorDeclaration | FunctionDeclaration | FunctionExpression | ArrowFunction>(); // Maps the Famix method, constructor, getter, setter and function ids to their ts-morph method, constructor, getter, setter or function object\n\nexport const accessMap = new Map<FamixID, AccessibleTSMorphElement>(); // Maps the Famix parameter, variable, property and enum value ids to their ts-morph parameter, variable, property or enum member object\nexport const classes = new Array<ClassDeclaration>(); // Array of all the classes of the source files\nexport const interfaces = new Array<InterfaceDeclaration>(); // Array of all the interfaces of the source files\nexport const modules = new Array<SourceFile>(); // Array of all the source files which are modules\nexport const listOfExportMaps = new Array<ReadonlyMap<string, ExportedDeclarations[]>>(); // Array of all the export maps\nexport let currentCC: { [key: string]: number }; // Stores the cyclomatic complexity metrics for the current source file\n\n/**\n * Checks if the file has any imports or exports to be considered a module\n * @param sourceFile A source file\n * @returns A boolean indicating if the file is a module\n */\nfunction isSourceFileAModule(sourceFile: SourceFile): boolean {\n    return sourceFile.getImportDeclarations().length > 0 || sourceFile.getExportedDeclarations().size > 0;\n}\n\n/**\n * Gets the path of a module to be imported\n * @param importDecl An import declaration\n * @returns The path of the module to be imported\n */\nexport function getModulePath(importDecl: ImportDeclaration): string {\n    let path: string;\n    if (importDecl.getModuleSpecifierSourceFile() === undefined) {\n        if (importDecl.getModuleSpecifierValue().substring(importDecl.getModuleSpecifierValue().length - 3) === \".ts\") {\n            path = importDecl.getModuleSpecifierValue();\n        }\n        else {\n            path = importDecl.getModuleSpecifierValue() + \".ts\";\n        }\n    }\n    else {\n        path = importDecl.getModuleSpecifierSourceFile()!.getFilePath();\n    }\n    return path;\n}\n\n/**\n * Gets the interfaces implemented or extended by a class or an interface\n * @param interfaces An array of interfaces\n * @param subClass A class or an interface\n * @returns An array of InterfaceDeclaration and ExpressionWithTypeArguments containing the interfaces implemented or extended by the subClass\n */\nexport function getImplementedOrExtendedInterfaces(interfaces: Array<InterfaceDeclaration>, subClass: ClassDeclaration | InterfaceDeclaration): Array<InterfaceDeclaration | ExpressionWithTypeArguments> {\n    let impOrExtInterfaces: Array<ExpressionWithTypeArguments>;\n    if (subClass instanceof ClassDeclaration) {\n        impOrExtInterfaces = subClass.getImplements();\n    }\n    else {\n        impOrExtInterfaces = subClass.getExtends();\n    }\n\n    const interfacesNames = interfaces.map(i => i.getName());\n    const implementedOrExtendedInterfaces = new Array<InterfaceDeclaration | ExpressionWithTypeArguments>();\n\n    impOrExtInterfaces.forEach(i => {\n        if (interfacesNames.includes(i.getExpression().getText())) {\n            implementedOrExtendedInterfaces.push(interfaces[interfacesNames.indexOf(i.getExpression().getText())]);\n        }\n        else {\n            implementedOrExtendedInterfaces.push(i);\n        }\n    });\n\n    return implementedOrExtendedInterfaces;\n}\n\n/**\n * Builds a Famix model for an array of source files\n * @param sourceFiles An array of source files\n */\nexport function processFiles(sourceFiles: Array<SourceFile>): void {\n    sourceFiles.forEach(file => {\n        logger.info(`File: >>>>>>>>>> ${file.getFilePath()}`);\n\n        // Computes the cyclomatic complexity metrics for the current source file if it exists (i.e. if it is not from a jest test)\n        if (fs.existsSync(file.getFilePath()))\n            currentCC = calculate(file.getFilePath());\n        else\n            currentCC = {};\n\n        processFile(file);\n    });\n}\n\n/**\n * Builds a Famix model for a source file\n * @param f A source file\n */\nfunction processFile(f: SourceFile): void {\n    const isModule = isSourceFileAModule(f);\n\n    if (isModule) {\n        modules.push(f);\n    }\n\n    const exportMap = f.getExportedDeclarations();\n    if (exportMap) listOfExportMaps.push(exportMap);\n\n    const fmxFile = entityDictionary.createOrGetFamixFile(f, isModule);\n\n    logger.debug(`processFile: file: ${f.getBaseName()}, fqn = ${fmxFile.fullyQualifiedName}`);\n\n    processComments(f, fmxFile);\n\n    processAliases(f, fmxFile);\n\n    processClasses(f, fmxFile);\n\n    processInterfaces(f, fmxFile);\n\n    processVariables(f, fmxFile);\n\n    processEnums(f, fmxFile);\n\n    processFunctions(f, fmxFile);\n\n    processModules(f, fmxFile);\n}\n\nexport function isAmbient(node: ModuleDeclaration): boolean {\n    // An ambient module has the DeclareKeyword modifier.\n    return (node.getModifiers()?.some(modifier => modifier.getKind() === SyntaxKind.DeclareKeyword)) ?? false;\n}\n\nexport function isNamespace(node: ModuleDeclaration): boolean {\n    // Check if the module declaration has a namespace keyword.\n    // This approach uses the getChildren() method to inspect the syntax directly.\n    return node.getChildrenOfKind(SyntaxKind.NamespaceKeyword).length > 0;\n}\n\n/**\n * Builds a Famix model for a module (also namespace)\n * @param m A namespace\n * @returns A Famix.Module representing the module\n */\nfunction processModule(m: ModuleDeclaration): Famix.Module {\n    const fmxModule = entityDictionary.createOrGetFamixModule(m);\n\n    logger.debug(`module: ${m.getName()}, (${m.getType().getText()}), ${fmxModule.fullyQualifiedName}`);\n\n    processComments(m, fmxModule);\n\n    processAliases(m, fmxModule);\n\n    processClasses(m, fmxModule);\n\n    processInterfaces(m, fmxModule);\n\n    processVariables(m, fmxModule);\n\n    processEnums(m, fmxModule);\n    \n    processFunctions(m, fmxModule);\n\n    processModules(m, fmxModule);\n\n    return fmxModule;\n}\n\ntype ContainerTypes = SourceFile | ModuleDeclaration | FunctionDeclaration | FunctionExpression | MethodDeclaration | ConstructorDeclaration | GetAccessorDeclaration | SetAccessorDeclaration | ArrowFunction;\n\ntype ScopedTypes = Famix.ScriptEntity | Famix.Module | Famix.Function | Famix.Method | Famix.Accessor;\n\n/**\n * Builds a Famix model for the aliases of a container\n * @param m A container (a source file, a namespace, a function or a method)\n * @param fmxScope The Famix model of the container\n */\nfunction processAliases(m: ContainerTypes, fmxScope: ScopedTypes): void {\n    logger.debug(`processAliases: ---------- Finding Aliases:`);\n    m.getTypeAliases().forEach(a => {\n        const fmxAlias = processAlias(a);\n        fmxScope.addAlias(fmxAlias);\n    });\n}\n\n/**\n * Builds a Famix model for the classes of a container\n * @param m A container (a source file or a namespace)\n * @param fmxScope The Famix model of the container\n */\nfunction processClasses(m: SourceFile | ModuleDeclaration, fmxScope: Famix.ScriptEntity | Famix.Module ): void {\n    logger.debug(`processClasses: ---------- Finding Classes:`);\n    const classesInArrowFunctions = getClassesDeclaredInArrowFunctions(m);\n    const classes = m.getClasses().concat(classesInArrowFunctions);\n    classes.forEach(c => {\n        const fmxClass = processClass(c);\n        fmxScope.addType(fmxClass);\n    });\n}\n\nfunction getArrowFunctionClasses(f: ArrowFunction): ClassDeclaration[] {\n    const classes: ClassDeclaration[] = [];\n\n    function findClasses(node: any) {\n        if (node.getKind() === SyntaxKind.ClassDeclaration) {\n            classes.push(node as ClassDeclaration);\n        }\n        node.getChildren().forEach(findClasses);\n    }\n\n    findClasses(f);\n    return classes;\n}\n\n/**\n * ts-morph doesn't find classes in arrow functions, so we need to find them manually\n * @param s A source file \n * @returns the ClassDeclaration objects found in arrow functions of the source file\n */\nfunction getClassesDeclaredInArrowFunctions(s: SourceFile | ModuleDeclaration): ClassDeclaration[] {\n    const arrowFunctions = s.getDescendantsOfKind(SyntaxKind.ArrowFunction);\n    const classesInArrowFunctions = arrowFunctions.map(f => getArrowFunctionClasses(f)).flat();\n    return classesInArrowFunctions;\n}\n\n/**\n * Builds a Famix model for the interfaces of a container\n * @param m A container (a source file or a namespace)\n * @param fmxScope The Famix model of the container\n */\nfunction processInterfaces(m: SourceFile | ModuleDeclaration, fmxScope: Famix.ScriptEntity | Famix.Module ): void {\n    logger.debug(`processInterfaces: ---------- Finding Interfaces:`);\n    m.getInterfaces().forEach(i => {\n        const fmxInterface = processInterface(i);\n        fmxScope.addType(fmxInterface);\n    });\n}\n\n/**\n * Builds a Famix model for the variables of a container\n * @param m A container (a source file, a namespace, a function or a method)\n * @param fmxScope The Famix model of the container\n */\nfunction processVariables(m: ContainerTypes, fmxScope: Famix.ScriptEntity | Famix.Module | Famix.Function | Famix.Method | Famix.Accessor): void {\n    logger.debug(`processVariables: ---------- Finding Variables:`);\n    m.getVariableStatements().forEach(v => {\n        const fmxVariables = processVariableStatement(v);\n        fmxVariables.forEach(fmxVariable => {\n            fmxScope.addVariable(fmxVariable);\n        });\n    });\n}\n\n/**\n * Builds a Famix model for the enums of a container\n * @param m A container (a source file, a namespace, a function or a method)\n * @param fmxScope The Famix model of the container\n */\nfunction processEnums(m: ContainerTypes, fmxScope: ScopedTypes): void {\n    logger.debug(`processEnums: ---------- Finding Enums:`);\n    m.getEnums().forEach(e => {\n        const fmxEnum = processEnum(e);\n        fmxScope.addType(fmxEnum);\n    });\n}\n\n/**\n * Builds a Famix model for the functions of a container\n * @param m A container (a source file, a namespace, a function or a method)\n * @param fmxScope The Famix model of the container\n */\nfunction processFunctions(m: ContainerTypes, fmxScope: ScopedTypes): void {\n    logger.debug(`Finding Functions:`);\n    m.getFunctions().forEach(f => {\n        const fmxFunction = processFunction(f);\n        fmxScope.addFunction(fmxFunction);\n    });\n\n    //find arrow functions\n    logger.debug(`Finding Functions:`);\n    const arrowFunctions = m.getDescendantsOfKind(SyntaxKind.ArrowFunction);\n    arrowFunctions.forEach(af => {\n        const fmxFunction = processFunction(af);\n        fmxScope.addFunction(fmxFunction);\n    })\n}\n\n/**\n * Builds a Famix model for the modules of a container.\n * @param m A container (a source file or a namespace)\n * @param fmxScope The Famix model of the container\n */\nfunction processModules(m: SourceFile | ModuleDeclaration, fmxScope: Famix.ScriptEntity | Famix.Module ): void {\n    logger.debug(`Finding Modules:`);\n    m.getModules().forEach(md => {\n        const fmxModule = processModule(md);\n        fmxScope.addModule(fmxModule);\n    });\n}\n\n/**\n * Builds a Famix model for an alias\n * @param a An alias\n * @returns A Famix.Alias representing the alias\n */\nfunction processAlias(a: TypeAliasDeclaration): Famix.Alias {\n    const fmxAlias = entityDictionary.createFamixAlias(a);\n\n    logger.debug(`Alias: ${a.getName()}, (${a.getType().getText()}), fqn = ${fmxAlias.fullyQualifiedName}`);\n\n    processComments(a, fmxAlias);\n\n    return fmxAlias;\n}\n\n/**\n * Builds a Famix model for a class\n * @param c A class\n * @returns A Famix.Class or a Famix.ParametricClass representing the class\n */\nfunction processClass(c: ClassDeclaration): Famix.Class | Famix.ParametricClass {\n    classes.push(c);\n\n    const fmxClass = entityDictionary.createOrGetFamixClass(c);\n\n    logger.debug(`Class: ${c.getName()}, (${c.getType().getText()}), fqn = ${fmxClass.fullyQualifiedName}`);\n\n    processComments(c, fmxClass);\n\n    processDecorators(c, fmxClass);\n\n    processStructuredType(c, fmxClass);\n\n    c.getConstructors().forEach(con => {\n        const fmxCon = processMethod(con);\n        fmxClass.addMethod(fmxCon);\n    });\n\n    c.getGetAccessors().forEach(acc => {\n        const fmxAcc = processMethod(acc);\n        fmxClass.addMethod(fmxAcc);\n    });\n    \n    c.getSetAccessors().forEach(acc => {\n        const fmxAcc = processMethod(acc);\n        fmxClass.addMethod(fmxAcc);\n    });\n\n    return fmxClass;\n}\n\n/**\n * Builds a Famix model for an interface\n * @param i An interface\n * @returns A Famix.Interface or a Famix.ParametricInterface representing the interface\n */\nfunction processInterface(i: InterfaceDeclaration): Famix.Interface | Famix.ParametricInterface {\n    interfaces.push(i);\n\n    const fmxInterface = entityDictionary.createOrGetFamixInterface(i);\n\n    logger.debug(`Interface: ${i.getName()}, (${i.getType().getText()}), fqn = ${fmxInterface.fullyQualifiedName}`);\n\n    processComments(i, fmxInterface);\n\n    processStructuredType(i, fmxInterface);\n\n    return fmxInterface;\n}\n\n/**\n * Builds a Famix model for the type parameters, properties and methods of a structured type\n * @param c A structured type (a class or an interface)\n * @param fmxScope The Famix model of the structured type\n */\nfunction processStructuredType(c: ClassDeclaration | InterfaceDeclaration, fmxScope: Famix.Class | Famix.ParametricClass | Famix.Interface | Famix.ParametricInterface): void {\n    logger.debug(`Finding Properties and Methods:`);\n    if (fmxScope instanceof Famix.ParametricClass || fmxScope instanceof Famix.ParametricInterface) {\n        processTypeParameters(c, fmxScope);\n    }\n\n    c.getProperties().forEach(prop => {\n        const fmxProperty = processProperty(prop);\n        fmxScope.addProperty(fmxProperty);\n    });\n\n    c.getMethods().forEach(m => {\n        const fmxMethod = processMethod(m);\n        fmxScope.addMethod(fmxMethod);\n    });\n}\n\n/**\n * Builds a Famix model for a property\n * @param p A property\n * @returns A Famix.Property representing the property\n */\nfunction processProperty(p: PropertyDeclaration | PropertySignature): Famix.Property {\n    const fmxProperty = entityDictionary.createFamixProperty(p);\n\n    logger.debug(`property: ${p.getName()}, (${p.getType().getText()}), fqn = ${fmxProperty.fullyQualifiedName}`);\n    logger.debug(` ---> It's a Property${(p instanceof PropertySignature) ? \"Signature\" : \"Declaration\"}!`);\n    const ancestor = p.getFirstAncestorOrThrow();\n    logger.debug(` ---> Its first ancestor is a ${ancestor.getKindName()}`);\n\n    // decorators\n    if (!(p instanceof PropertySignature)) {\n        processDecorators(p, fmxProperty);\n        // only add access if the p's first ancestor is not a PropertyDeclaration\n        if (ancestor.getKindName() !== \"PropertyDeclaration\") {\n            logger.debug(`adding access to map: ${p.getName()}, (${p.getType().getText()}) Famix ${fmxProperty.name} id: ${fmxProperty.id}`);\n            accessMap.set(fmxProperty.id, p);\n        }\n    }\n\n    processComments(p, fmxProperty);\n\n    return fmxProperty;\n}\n\n/**\n     * Builds a Famix model for a method or an accessor\n     * @param m A method or an accessor\n     * @returns A Famix.Method or a Famix.Accessor representing the method or the accessor\n     */\nfunction processMethod(m: MethodDeclaration | ConstructorDeclaration | MethodSignature | GetAccessorDeclaration | SetAccessorDeclaration): Famix.Method | Famix.Accessor {\n    const fmxMethod = entityDictionary.createOrGetFamixMethod(m, currentCC);\n\n    logger.debug(`Method: ${!(m instanceof ConstructorDeclaration) ? m.getName() : \"constructor\"}, (${m.getType().getText()}), parent: ${(m.getParent() as ClassDeclaration | InterfaceDeclaration).getName()}, fqn = ${fmxMethod.fullyQualifiedName}`);\n\n    processComments(m, fmxMethod);\n\n    processTypeParameters(m, fmxMethod);\n\n    processParameters(m, fmxMethod);\n\n    if (!(m instanceof MethodSignature)) {\n        processAliases(m, fmxMethod);\n\n        processVariables(m, fmxMethod);\n\n        processEnums(m, fmxMethod);\n\n        processFunctions(m, fmxMethod);\n\n        processFunctionExpressions(m, fmxMethod);\n\n        methodsAndFunctionsWithId.set(fmxMethod.id, m);\n    }\n\n    if (m instanceof MethodDeclaration || m instanceof GetAccessorDeclaration || m instanceof SetAccessorDeclaration) {\n        processDecorators(m, fmxMethod);\n    }\n\n    return fmxMethod;\n}\n\n/**\n * Builds a Famix model for a function\n * @param f A function\n * @returns A Famix.Function representing the function\n */\nfunction processFunction(f: FunctionDeclaration | FunctionExpression | ArrowFunction): Famix.Function {\n\n    logger.debug(`Function: ${(f instanceof ArrowFunction ? \"anonymous\" : f.getName() ? f.getName() : \"anonymous\")}, (${f.getType().getText()}), fqn = ${getFQN(f)}`);\n\n    let fmxFunction;\n    if( f instanceof ArrowFunction) {\n        fmxFunction = entityDictionary.createFamixArrowFunction(f, currentCC);\n    } else {\n        fmxFunction = entityDictionary.createOrGetFamixFunction(f, currentCC);\n    }\n\n    processComments(f, fmxFunction);\n\n    processAliases(f, fmxFunction);\n\n    processTypeParameters(f, fmxFunction);\n\n    processParameters(f, fmxFunction);\n\n    processVariables(f, fmxFunction);\n\n    processEnums(f, fmxFunction);\n\n    processFunctions(f, fmxFunction);\n\n    if (f instanceof FunctionDeclaration && !(f.getParent() instanceof Block)) {\n        processFunctionExpressions(f, fmxFunction);\n    }\n\n    methodsAndFunctionsWithId.set(fmxFunction.id, f);\n\n    return fmxFunction;\n}\n\n/**\n * Builds a Famix model for the function expressions of a function or a method\n * @param f A function or a method\n * @param fmxScope The Famix model of the function or the method\n */\nfunction processFunctionExpressions(f: FunctionDeclaration | MethodDeclaration | ConstructorDeclaration | GetAccessorDeclaration | SetAccessorDeclaration, fmxScope: Famix.Function | Famix.Method | Famix.Accessor): void {\n    logger.debug(`Finding Function Expressions:`);\n    const functionExpressions = f.getDescendantsOfKind(SyntaxKind.FunctionExpression);\n    functionExpressions.forEach((func) => {\n        const fmxFunc = processFunction(func);\n        fmxScope.addFunction(fmxFunc);\n    });\n}\n\n/**\n * Builds a Famix model for the parameters of a method or a function\n * @param m A method or a function\n * @param fmxScope The Famix model of the method or the function\n */\nfunction processParameters(m: MethodDeclaration | ConstructorDeclaration | MethodSignature | GetAccessorDeclaration | SetAccessorDeclaration | FunctionDeclaration | FunctionExpression | ArrowFunction, fmxScope: Famix.Method | Famix.Accessor | Famix.Function): void {\n    logger.debug(`Finding Parameters:`);\n    m.getParameters().forEach(param => {\n        const fmxParam = processParameter(param);\n        fmxScope.addParameter(fmxParam);\n        // Additional handling for Parameter Properties in constructors\n        if (m instanceof ConstructorDeclaration) {\n            // Check if the parameter has any visibility modifier\n            if (param.hasModifier(SyntaxKind.PrivateKeyword) || param.hasModifier(SyntaxKind.PublicKeyword) || param.hasModifier(SyntaxKind.ProtectedKeyword) || param.hasModifier(SyntaxKind.ReadonlyKeyword)) {\n                const classOfConstructor = m.getParent();\n                logger.info(`Parameter Property ${param.getName()} in constructor of ${classOfConstructor.getName()}.`);\n                // Treat the parameter as a property and add it to the class\n                const fmxProperty = processParameterAsProperty(param, classOfConstructor);\n                fmxProperty.readOnly = param.hasModifier(SyntaxKind.ReadonlyKeyword);\n            }\n        }\n\n    });\n}\n\n// This function should create a Famix.Property model from a ParameterDeclaration\n// You'll need to implement it according to your Famix model structure\nfunction processParameterAsProperty(param: ParameterDeclaration, classDecl: ClassDeclaration | ClassExpression): Famix.Property {\n    // Convert the parameter into a Property\n    const propertyRepresentation = convertParameterToPropertyRepresentation(param);\n\n    // Add the property to the class so we can have a PropertyDeclaration object\n    classDecl.addProperty(propertyRepresentation);\n\n    const property = classDecl.getProperty(propertyRepresentation.name);\n    if (!property) {\n        throw new Error(`Property ${propertyRepresentation.name} not found in class ${classDecl.getName()}`);\n    }\n    const fmxProperty = entityDictionary.createFamixProperty(property);\n    if (classDecl instanceof ClassDeclaration) {\n        const fmxClass = entityDictionary.createOrGetFamixClass(classDecl);\n        fmxClass.addProperty(fmxProperty);\n    } else { \n        throw new Error(\"Unexpected type ClassExpression.\");\n    }\n\n    processComments(property, fmxProperty);\n\n    // remove the property from the class\n    property.remove();\n\n    return fmxProperty;\n\n}\n\nfunction convertParameterToPropertyRepresentation(param: ParameterDeclaration) {\n    // Extract name\n    const paramName = param.getName();\n\n    // Extract type\n    const paramType = param.getType().getText(param);\n\n    // Determine visibility\n    let scope: Scope;\n    if (param.hasModifier(SyntaxKind.PrivateKeyword)) {\n        scope = Scope.Private;\n    } else if (param.hasModifier(SyntaxKind.ProtectedKeyword)) {\n        scope = Scope.Protected;\n    } else if (param.hasModifier(SyntaxKind.PublicKeyword)) {\n        scope = Scope.Public;\n    } else {\n        throw new Error(`Parameter property ${paramName} in constructor does not have a visibility modifier.`);\n    }\n\n    // Determine if readonly\n    const isReadonly = param.hasModifier(SyntaxKind.ReadonlyKeyword);\n\n    // Create a representation of the property\n    const propertyRepresentation = {\n        name: paramName,\n        type: paramType,\n        scope: scope,\n        isReadonly: isReadonly,\n    };\n\n    return propertyRepresentation;\n}\n\n/**\n * Builds a Famix model for a parameter\n * @param paramDecl A parameter\n * @returns A Famix.Parameter representing the parameter\n */\nfunction processParameter(paramDecl: ParameterDeclaration): Famix.Parameter {\n    const fmxParam = entityDictionary.createFamixParameter(paramDecl);\n\n    logger.debug(`parameter: ${paramDecl.getName()}, (${paramDecl.getType().getText()}), fqn = ${fmxParam.fullyQualifiedName}`);\n\n    processComments(paramDecl, fmxParam);\n\n    processDecorators(paramDecl, fmxParam);\n\n    const parent = paramDecl.getParent();\n\n    if (!(parent instanceof MethodSignature)) {\n        logger.debug(`adding access: ${paramDecl.getName()}, (${paramDecl.getType().getText()}) Famix ${fmxParam.name}`);\n        accessMap.set(fmxParam.id, paramDecl);\n    }\n\n    return fmxParam;\n}\n\n/**\n * Builds a Famix model for the type parameters of a class, an interface, a method or a function\n * @param e A class, an interface, a method or a function\n * @param fmxScope The Famix model of the class, the interface, the method or the function\n */\nfunction processTypeParameters(e: ClassDeclaration | InterfaceDeclaration | MethodDeclaration | ConstructorDeclaration | MethodSignature | GetAccessorDeclaration | SetAccessorDeclaration | FunctionDeclaration | FunctionExpression |ArrowFunction, fmxScope: Famix.ParametricClass | Famix.ParametricInterface | Famix.Method | Famix.Accessor | Famix.Function | Famix.ArrowFunction): void {\n    logger.debug(`Finding Type Parameters:`);\n    e.getTypeParameters().forEach(tp => {\n        const fmxParam = processTypeParameter(tp);\n        fmxScope.addGenericParameter(fmxParam);\n    });\n}\n\n/**\n * Builds a Famix model for a type parameter\n * @param tp A type parameter\n * @returns A Famix.TypeParameter representing the type parameter\n */\nfunction processTypeParameter(tp: TypeParameterDeclaration): Famix.ParameterType {\n    const fmxTypeParameter = entityDictionary.createFamixParameterType(tp);\n\n    logger.debug(`type parameter: ${tp.getName()}, (${tp.getType().getText()}), fqn = ${fmxTypeParameter.fullyQualifiedName}`);\n\n    processComments(tp, fmxTypeParameter);\n\n    return fmxTypeParameter;\n}\n\n/**\n * Builds a Famix model for the variables of a variable statement\n * @param v A variable statement\n * @returns An array of Famix.Variable representing the variables\n */\nfunction processVariableStatement(v: VariableStatement): Array<Famix.Variable> {\n    const fmxVariables = new Array<Famix.Variable>();\n\n    logger.debug(`Variable statement: ${v.getText()}, (${v.getType().getText()}), ${v.getDeclarationKindKeywords()[0]}, fqn = ${v.getDeclarations()[0].getName()}`);\n\n    v.getDeclarations().forEach(variable => {\n        const fmxVar = processVariable(variable);\n        processComments(v, fmxVar);\n        fmxVariables.push(fmxVar);\n    }); \n\n    return fmxVariables;\n}\n\n/**\n * Builds a Famix model for a variable\n * @param v A variable\n * @returns A Famix.Variable representing the variable\n */\nfunction processVariable(v: VariableDeclaration): Famix.Variable {\n    const fmxVar = entityDictionary.createFamixVariable(v);\n\n    logger.debug(`variable: ${v.getName()}, (${v.getType().getText()}), ${v.getInitializer() ? \"initializer: \" + v.getInitializer()!.getText() : \"initializer: \"}, fqn = ${fmxVar.fullyQualifiedName}`);\n\n    processComments(v, fmxVar);\n\n    logger.debug(`adding access: ${v.getName()}, (${v.getType().getText()}) Famix ${fmxVar.name}`);\n    accessMap.set(fmxVar.id, v);\n\n    return fmxVar;\n}\n\n/**\n * Builds a Famix model for an enum\n * @param e An enum\n * @returns A Famix.Enum representing the enum\n */\nfunction processEnum(e: EnumDeclaration): Famix.Enum {\n    const fmxEnum = entityDictionary.createFamixEnum(e);\n\n    logger.debug(`enum: ${e.getName()}, (${e.getType().getText()}), fqn = ${fmxEnum.fullyQualifiedName}`);\n\n    processComments(e, fmxEnum);\n\n    e.getMembers().forEach(m => {\n        const fmxEnumValue = processEnumValue(m);\n        fmxEnum.addValue(fmxEnumValue);\n    });\n\n    return fmxEnum;\n}\n\n/**\n * Builds a Famix model for an enum member\n * @param v An enum member\n * @returns A Famix.EnumValue representing the enum member\n */\nfunction processEnumValue(v: EnumMember): Famix.EnumValue {\n    const fmxEnumValue = entityDictionary.createFamixEnumValue(v);\n\n    logger.debug(`enum value: ${v.getName()}, (${v.getType().getText()}), fqn = ${fmxEnumValue.fullyQualifiedName}`);\n\n    processComments(v, fmxEnumValue);\n\n    logger.debug(`adding access: ${v.getName()}, (${v.getType().getText()}) Famix ${fmxEnumValue.name}`);\n    accessMap.set(fmxEnumValue.id, v);\n\n    return fmxEnumValue;\n}\n\n/**\n * Builds a Famix model for the decorators of a class, a method, a parameter or a property\n * @param e A class, a method, a parameter or a property\n * @param fmxScope The Famix model of the class, the method, the parameter or the property\n */\nfunction processDecorators(e: ClassDeclaration | MethodDeclaration | GetAccessorDeclaration | SetAccessorDeclaration | ParameterDeclaration | PropertyDeclaration, fmxScope: Famix.Class | Famix.ParametricClass | Famix.Method | Famix.Accessor | Famix.Parameter | Famix.Property): void {\n    logger.debug(`Finding Decorators:`);\n    e.getDecorators().forEach(dec => {\n        const fmxDec = processDecorator(dec, e);\n        fmxScope.addDecorator(fmxDec);\n    });\n}\n\n/**\n * Builds a Famix model for a decorator\n * @param d A decorator\n * @param e A class, a method, a parameter or a property\n * @returns A Famix.Decorator representing the decorator\n */\nfunction processDecorator(d: Decorator, e: ClassDeclaration | MethodDeclaration | GetAccessorDeclaration | SetAccessorDeclaration | ParameterDeclaration | PropertyDeclaration): Famix.Decorator {\n    const fmxDec = entityDictionary.createOrGetFamixDecorator(d, e);\n\n    logger.debug(`decorator: ${d.getName()}, (${d.getType().getText()}), fqn = ${fmxDec.fullyQualifiedName}`);\n\n    processComments(d, fmxDec);\n\n    return fmxDec;\n}\n\n/**\n * Builds a Famix model for the comments\n * @param e A ts-morph element\n * @param fmxScope The Famix model of the named entity\n */\nfunction processComments(e: SourceFile | ModuleDeclaration | ClassDeclaration | InterfaceDeclaration | MethodDeclaration | ConstructorDeclaration | MethodSignature | GetAccessorDeclaration | SetAccessorDeclaration | FunctionDeclaration | FunctionExpression | ParameterDeclaration | VariableDeclaration | PropertyDeclaration | PropertySignature | Decorator | EnumDeclaration | EnumMember | TypeParameterDeclaration | VariableStatement | TypeAliasDeclaration | ArrowFunction, fmxScope: Famix.NamedEntity): void {\n    logger.debug(`Process comments:`);\n    e.getLeadingCommentRanges().forEach(c => {\n        const fmxComment = processComment(c, fmxScope);\n        logger.debug(`leading comments, addComment: '${c.getText()}'`);\n        fmxScope.addComment(fmxComment); // redundant, but just in case\n    });\n    e.getTrailingCommentRanges().forEach(c => {\n        const fmxComment = processComment(c, fmxScope);\n        logger.debug(`trailing comments, addComment: '${c.getText()}'`);\n        fmxScope.addComment(fmxComment);\n    });\n}\n\n/**\n * Builds a Famix model for a comment\n * @param c A comment\n * @param fmxScope The Famix model of the comment's container\n * @returns A Famix.Comment representing the comment\n */\nfunction processComment(c: CommentRange, fmxScope: Famix.NamedEntity): Famix.Comment {\n    const isJSDoc = c.getText().startsWith(\"/**\");\n    logger.debug(`processComment: comment: ${c.getText()}, isJSDoc = ${isJSDoc}`);\n    const fmxComment = entityDictionary.createFamixComment(c, fmxScope, isJSDoc);\n\n    return fmxComment;\n}\n\n/**\n * Builds a Famix model for the accesses on the parameters, variables, properties and enum members of the source files\n * @param accessMap A map of parameters, variables, properties and enum members with their id\n */\nexport function processAccesses(accessMap: Map<FamixID, AccessibleTSMorphElement>): void {\n    logger.debug(`Creating accesses:`);\n    accessMap.forEach((v, id) => {\n        logger.debug(`Accesses to ${v.getName()}`);\n        // try {\n            const temp_nodes = v.findReferencesAsNodes() as Array<Identifier>;\n            temp_nodes.forEach(node => processNodeForAccesses(node, id));\n        // } catch (error) {\n        //     logger.error(`> WARNING: got exception \"${error}\".\\nContinuing...`);\n        // }\n    });\n}\n\n/**\n * Builds a Famix model for an access on a parameter, variable, property or enum member\n * @param n A node\n * @param id An id of a parameter, a variable, a property or an enum member\n */\nfunction processNodeForAccesses(n: Identifier, id: number): void {\n    // try {\n        // sometimes node's first ancestor is a PropertyDeclaration, which is not an access\n        // see https://github.com/fuhrmanator/FamixTypeScriptImporter/issues/9\n        // check for a node whose first ancestor is a property declaration and bail?\n        // This may be a bug in ts-morph?\n        if (n.getFirstAncestorOrThrow().getKindName() === \"PropertyDeclaration\") {\n            logger.debug(`processNodeForAccesses: node kind: ${n.getKindName()}, ${n.getText()}, (${n.getType().getText()})'s first ancestor is a PropertyDeclaration. Skipping...`);\n            return;\n        }\n        entityDictionary.createFamixAccess(n, id);\n        logger.debug(`processNodeForAccesses: node kind: ${n.getKindName()}, ${n.getText()}, (${n.getType().getText()})`);\n    // } catch (error) {\n    //     logger.error(`> Got exception \"${error}\".\\nScopeDeclaration invalid for \"${n.getSymbol().fullyQualifiedName}\".\\nContinuing...`);\n    // }\n}\n\n\n// exports has name -> Declaration -- the declaration can be used to find the FamixElement\n\n// handle `import path = require(\"path\")` for example\nexport function processImportClausesForImportEqualsDeclarations(sourceFiles: Array<SourceFile>, exports: Array<ReadonlyMap<string, ExportedDeclarations[]>>): void {\n    logger.info(`Creating import clauses from ImportEqualsDeclarations in source files:`);\n    sourceFiles.forEach(sourceFile => {\n        sourceFile.forEachDescendant(node => {\n            if (Node.isImportEqualsDeclaration(node)) {\n                // You've found an ImportEqualsDeclaration\n                logger.info(\"Declaration Name:\", node.getName());\n                logger.info(\"Module Reference Text:\", node.getModuleReference().getText());\n                // what's the name of the imported entity?\n                // const importedEntity = node.getName();\n                // create a famix import clause\n                const namedImport = node.getNameNode();\n                entityDictionary.oldCreateFamixImportClause({importDeclaration: node,\n                    importerSourceFile: sourceFile, \n                    moduleSpecifierFilePath: node.getModuleReference().getText(), \n                    importElement: namedImport, \n                    isInExports: exports.find(e => e.has(namedImport.getText())) !== undefined, \n                    isDefaultExport: false});\n                // entityDictionary.createFamixImportClause(importedEntity, importingEntity);\n            }\n        });\n    }\n    );\n}\n\n/**\n * Builds a Famix model for the import clauses of the source files which are modules\n * @param modules An array of modules\n * @param exports An array of maps of exported declarations\n */\nexport function processImportClausesForModules(modules: Array<SourceFile>, exports: Array<ReadonlyMap<string, ExportedDeclarations[]>>): void {\n    logger.info(`Creating import clauses from ${modules.length} modules:`);\n    modules.forEach(module => {\n        const modulePath = module.getFilePath() + module.getBaseName();\n        module.getImportDeclarations().forEach(impDecl => {\n            logger.info(`Importing ${impDecl.getModuleSpecifierValue()} in ${modulePath}`);\n            const path = getModulePath(impDecl);\n\n            impDecl.getNamedImports().forEach(namedImport => {\n                logger.info(`Importing (named) ${namedImport.getName()} from ${impDecl.getModuleSpecifierValue()} in ${modulePath}`);\n                const importedEntityName = namedImport.getName();\n                let importFoundInExports = isInExports(exports, importedEntityName);\n                entityDictionary.oldCreateFamixImportClause({importDeclaration: impDecl,\n                    importerSourceFile: module, \n                    moduleSpecifierFilePath: path, \n                    importElement: namedImport, \n                    isInExports: importFoundInExports, \n                    isDefaultExport: false});\n            });\n\n            const defaultImport = impDecl.getDefaultImport();\n            if (defaultImport !== undefined) {\n                logger.info(`Importing (default) ${defaultImport.getText()} from ${impDecl.getModuleSpecifierValue()} in ${modulePath}`);\n                // call with module, impDecl.getModuleSpecifierValue(), path, defaultImport, false, true\n                entityDictionary.oldCreateFamixImportClause({importDeclaration: impDecl,\n                    importerSourceFile: module,\n                    moduleSpecifierFilePath: path,\n                    importElement: defaultImport,\n                    isInExports: false,\n                    isDefaultExport: true});\n            }\n\n            const namespaceImport = impDecl.getNamespaceImport();\n            if (namespaceImport !== undefined) {\n                logger.info(`Importing (namespace) ${namespaceImport.getText()} from ${impDecl.getModuleSpecifierValue()} in ${modulePath}`);\n                entityDictionary.oldCreateFamixImportClause({importDeclaration: impDecl,\n                    importerSourceFile: module, \n                    moduleSpecifierFilePath: path, \n                    importElement: namespaceImport, \n                    isInExports: false, \n                    isDefaultExport: false});\n                // entityDictionary.createFamixImportClause(module, impDecl.getModuleSpecifierValue(), path, namespaceImport, false, false);\n            }\n        }); \n    });\n}\n\nfunction isInExports(exports: ReadonlyMap<string, ExportedDeclarations[]>[], importedEntityName: string) {\n    let importFoundInExports = false;\n    exports.forEach(e => {\n        if (e.has(importedEntityName)) {\n            importFoundInExports = true;\n        }\n    });\n    return importFoundInExports;\n}\n\n/**\n * Builds a Famix model for the inheritances of the classes and interfaces of the source files\n * @param classes An array of classes\n * @param interfaces An array of interfaces\n */\nexport function processInheritances(classes: ClassDeclaration[], interfaces: InterfaceDeclaration[]): void {\n    logger.info(`processInheritances: Creating inheritances:`);\n    classes.forEach(cls => {\n        logger.debug(`processInheritances: Checking class inheritance for ${cls.getName()}`);\n        const extClass = cls.getBaseClass();\n        if (extClass !== undefined) {\n            entityDictionary.createFamixInheritance(cls, extClass);\n            \n            logger.debug(`processInheritances: class: ${cls.getName()}, (${cls.getType().getText()}), extClass: ${extClass.getName()}, (${extClass.getType().getText()})`);\n        }\n\n        logger.debug(`processInheritances: Checking interface inheritance for ${cls.getName()}`);\n        const implementedInterfaces = getImplementedOrExtendedInterfaces(interfaces, cls);\n        implementedInterfaces.forEach(impInter => {\n            entityDictionary.createFamixInheritance(cls, impInter);\n\n            logger.debug(`processInheritances: class: ${cls.getName()}, (${cls.getType().getText()}), impInter: ${(impInter instanceof InterfaceDeclaration) ? impInter.getName() : impInter.getExpression().getText()}, (${(impInter instanceof InterfaceDeclaration) ? impInter.getType().getText() : impInter.getExpression().getText()})`);\n        });\n    });\n\n    interfaces.forEach(inter => {\n        logger.debug(`processInheritances: Checking interface inheritance for ${inter.getName()}`);\n        const extendedInterfaces = getImplementedOrExtendedInterfaces(interfaces, inter);\n        extendedInterfaces.forEach(extInter => {\n            entityDictionary.createFamixInheritance(inter, extInter);\n\n            logger.debug(`processInheritances: inter: ${inter.getName()}, (${inter.getType().getText()}), extInter: ${(extInter instanceof InterfaceDeclaration) ? extInter.getName() : extInter.getExpression().getText()}, (${(extInter instanceof InterfaceDeclaration) ? extInter.getType().getText() : extInter.getExpression().getText()})`);\n        });\n    });\n}\n\n/**\n * Builds a Famix model for the invocations of the methods and functions of the source files\n * @param methodsAndFunctionsWithId A map of methods and functions with their id\n */\nexport function processInvocations(methodsAndFunctionsWithId: Map<number, MethodDeclaration | ConstructorDeclaration | GetAccessorDeclaration | SetAccessorDeclaration | FunctionDeclaration | FunctionExpression | ArrowFunction>): void {\n    logger.info(`Creating invocations:`);\n    methodsAndFunctionsWithId.forEach((m, id) => {\n        if (!(m instanceof ArrowFunction)) {\n            logger.debug(`Invocations to ${(m instanceof MethodDeclaration || m instanceof GetAccessorDeclaration || m instanceof SetAccessorDeclaration || m instanceof FunctionDeclaration) ? m.getName() : ((m instanceof ConstructorDeclaration) ? 'constructor' : (m.getName() ? m.getName() : 'anonymous'))}`);\n            try {\n                const temp_nodes = m.findReferencesAsNodes() as Array<Identifier>;\n                temp_nodes.forEach(node => processNodeForInvocations(node, m, id));\n            } catch (error) {\n                logger.error(`> WARNING: got exception ${error}. Continuing...`);\n            }\n        }\n    });\n}\n\n/**\n * Builds a Famix model for an invocation of a method or a function\n * @param n A node\n * @param m A method or a function\n * @param id The id of the method or the function\n */\nfunction processNodeForInvocations(n: Identifier, m: MethodDeclaration | ConstructorDeclaration | GetAccessorDeclaration | SetAccessorDeclaration | FunctionDeclaration | FunctionExpression, id: number): void {\n    try {\n        entityDictionary.createFamixInvocation(n, m, id);\n\n        logger.debug(`node: node, (${n.getType().getText()})`);\n    } catch (error) {\n        logger.error(`> WARNING: got exception ${error}. ScopeDeclaration invalid for ${n.getSymbol()!.getFullyQualifiedName()}. Continuing...`);\n    }\n}\n\n/**\n * Builds a Famix model for the inheritances of the classes and interfaces of the source files\n * @param classes An array of classes\n * @param interfaces An array of interfaces\n */\nexport function processConcretisations(classes: ClassDeclaration[], interfaces: InterfaceDeclaration[], functions: Map<number, MethodDeclaration | ConstructorDeclaration | GetAccessorDeclaration | SetAccessorDeclaration | FunctionDeclaration | FunctionExpression | ArrowFunction>): void {\n    logger.info(`processConcretisations: Creating concretisations:`);\n    classes.forEach(cls => {\n        logger.debug(`processConcretisations: Checking class concretisation for ${cls.getName()}`);\n        entityDictionary.createFamixConcretisationClassOrInterfaceSpecialisation(cls);\n        entityDictionary.createFamixConcretisationGenericInstantiation(cls);\n        entityDictionary.createFamixConcretisationInterfaceClass(cls);\n        entityDictionary.createFamixConcretisationTypeInstanciation(cls); \n\n    });\n    interfaces.forEach(inter => {\n        logger.debug(`processConcretisations: Checking interface concretisation for ${inter.getName()}`);\n        entityDictionary.createFamixConcretisationTypeInstanciation(inter); \n        entityDictionary.createFamixConcretisationClassOrInterfaceSpecialisation(inter)\n    });\n    functions.forEach(func => {\n        if(func instanceof FunctionDeclaration || func instanceof MethodDeclaration ){\n            logger.debug(`processConcretisations: Checking Method concretisation`);\n            entityDictionary.createFamixConcretisationFunctionInstantiation(func);\n        }\n    })\n}\n"]}
|