ts2famix 1.4.1 → 2.0.0
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/README.md +1 -1
- package/dist/analyze.js +4 -2
- package/dist/analyze_functions/process_functions.js +248 -100
- package/dist/famix2puml.js +1 -0
- package/dist/famix_functions/EntityDictionary.js +661 -155
- package/dist/famix_functions/helpers_creation.js +26 -6
- package/dist/fqn.js +156 -69
- package/dist/lib/famix/src/famix_JSON_exporter.js +1 -0
- package/dist/lib/famix/src/famix_base_element.js +1 -0
- package/dist/lib/famix/src/famix_repository.js +9 -8
- package/dist/lib/famix/src/index.js +1 -0
- package/dist/lib/famix/src/model/famix/access.js +3 -2
- package/dist/lib/famix/src/model/famix/accessor.js +1 -0
- package/dist/lib/famix/src/model/famix/alias.js +2 -1
- package/dist/lib/famix/src/model/famix/arrowFunction.js +17 -0
- package/dist/lib/famix/src/model/famix/behavioral_entity.js +13 -15
- package/dist/lib/famix/src/model/famix/class.js +1 -0
- package/dist/lib/famix/src/model/famix/comment.js +2 -1
- package/dist/lib/famix/src/model/famix/concretisation.js +31 -0
- package/dist/lib/famix/src/model/famix/container_entity.js +7 -6
- package/dist/lib/famix/src/model/famix/decorator.js +2 -1
- package/dist/lib/famix/src/model/famix/entity.js +1 -0
- package/dist/lib/famix/src/model/famix/enum.js +2 -1
- package/dist/lib/famix/src/model/famix/enum_value.js +2 -1
- package/dist/lib/famix/src/model/famix/function.js +1 -0
- package/dist/lib/famix/src/model/famix/implicit_variable.js +1 -0
- package/dist/lib/famix/src/model/famix/import_clause.js +5 -3
- package/dist/lib/famix/src/model/famix/index.js +18 -11
- package/dist/lib/famix/src/model/famix/indexed_file_anchor.js +3 -2
- package/dist/lib/famix/src/model/famix/inheritance.js +3 -2
- package/dist/lib/famix/src/model/famix/interface.js +2 -1
- package/dist/lib/famix/src/model/famix/invocation.js +3 -2
- package/dist/lib/famix/src/model/famix/method.js +2 -1
- package/dist/lib/famix/src/model/famix/module.js +53 -0
- package/dist/lib/famix/src/model/famix/named_entity.js +4 -3
- package/dist/lib/famix/src/model/famix/parameter.js +2 -1
- package/dist/lib/famix/src/model/famix/parameterConcretisation.js +44 -0
- package/dist/lib/famix/src/model/famix/parameter_type.js +22 -1
- package/dist/lib/famix/src/model/famix/parametric_arrow_function.js +31 -0
- package/dist/lib/famix/src/model/famix/parametric_class.js +44 -0
- package/dist/lib/famix/src/model/famix/parametric_function.js +31 -0
- package/dist/lib/famix/src/model/famix/parametric_interface.js +44 -0
- package/dist/lib/famix/src/model/famix/parametric_method.js +31 -0
- package/dist/lib/famix/src/model/famix/primitive_type.js +1 -0
- package/dist/lib/famix/src/model/famix/property.js +91 -9
- package/dist/lib/famix/src/model/famix/reference.js +3 -2
- package/dist/lib/famix/src/model/famix/scoping_entity.js +12 -10
- package/dist/lib/famix/src/model/famix/script_entity.js +1 -2
- package/dist/lib/famix/src/model/famix/source_anchor.js +1 -0
- package/dist/lib/famix/src/model/famix/source_language.js +1 -1
- package/dist/lib/famix/src/model/famix/sourced_entity.js +2 -1
- package/dist/lib/famix/src/model/famix/structural_entity.js +1 -0
- package/dist/lib/famix/src/model/famix/text_anchor.js +1 -0
- package/dist/lib/famix/src/model/famix/type.js +6 -4
- package/dist/lib/famix/src/model/famix/variable.js +1 -0
- package/dist/lib/ts-complex/cyclomatic-service.js +2 -2
- package/dist/ts2famix-cli-wrapper.js +16 -0
- package/dist/ts2famix-cli.js +8 -1
- package/dist/ts2famix-tsconfig.js +1 -0
- package/doc-uml/famix-typescript-model.puml +559 -0
- package/doc-uml/famix-typescript-model.svg +1 -0
- package/jest.config.json +2 -1
- package/package.json +10 -10
- package/src/analyze.ts +22 -21
- package/src/analyze_functions/process_functions.ts +272 -96
- package/src/famix_functions/EntityDictionary.ts +731 -182
- package/src/famix_functions/helpers_creation.ts +28 -2
- package/src/fqn.ts +132 -10
- package/src/lib/famix/src/famix_repository.ts +9 -9
- package/src/lib/famix/src/model/famix/access.ts +2 -2
- package/src/lib/famix/src/model/famix/alias.ts +1 -1
- package/src/lib/famix/src/model/famix/arrowFunction.ts +15 -0
- package/src/lib/famix/src/model/famix/behavioral_entity.ts +12 -19
- package/src/lib/famix/src/model/famix/comment.ts +1 -1
- package/src/lib/famix/src/model/famix/concretisation.ts +42 -0
- package/src/lib/famix/src/model/famix/container_entity.ts +6 -6
- package/src/lib/famix/src/model/famix/decorator.ts +1 -1
- package/src/lib/famix/src/model/famix/enum.ts +1 -1
- package/src/lib/famix/src/model/famix/enum_value.ts +1 -1
- package/src/lib/famix/src/model/famix/import_clause.ts +4 -3
- package/src/lib/famix/src/model/famix/index.ts +8 -5
- package/src/lib/famix/src/model/famix/indexed_file_anchor.ts +2 -2
- package/src/lib/famix/src/model/famix/inheritance.ts +3 -4
- package/src/lib/famix/src/model/famix/interface.ts +1 -1
- package/src/lib/famix/src/model/famix/invocation.ts +2 -2
- package/src/lib/famix/src/model/famix/method.ts +1 -1
- package/src/lib/famix/src/model/famix/module.ts +67 -1
- package/src/lib/famix/src/model/famix/named_entity.ts +3 -3
- package/src/lib/famix/src/model/famix/parameter.ts +1 -1
- package/src/lib/famix/src/model/famix/parameterConcretisation.ts +54 -0
- package/src/lib/famix/src/model/famix/parameter_type.ts +33 -6
- package/src/lib/famix/src/model/famix/parametric_arrow_function.ts +32 -0
- package/src/lib/famix/src/model/famix/parametric_class.ts +49 -0
- package/src/lib/famix/src/model/famix/parametric_function.ts +32 -0
- package/src/lib/famix/src/model/famix/parametric_interface.ts +49 -0
- package/src/lib/famix/src/model/famix/parametric_method.ts +32 -0
- package/src/lib/famix/src/model/famix/property.ts +109 -11
- package/src/lib/famix/src/model/famix/reference.ts +2 -2
- package/src/lib/famix/src/model/famix/scoping_entity.ts +12 -11
- package/src/lib/famix/src/model/famix/script_entity.ts +0 -2
- package/src/lib/famix/src/model/famix/source_language.ts +0 -1
- package/src/lib/famix/src/model/famix/sourced_entity.ts +1 -1
- package/src/lib/famix/src/model/famix/type.ts +5 -4
- package/src/ts2famix-cli-wrapper.ts +17 -0
- package/src/ts2famix-cli.ts +7 -1
- package/tsconfig.json +5 -5
- package/dist/lib/famix/src/model/famix/association.js +0 -36
- package/dist/lib/famix/src/model/famix/namespace.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/doc-uml/metamodel-full.svg +0 -1
- package/doc-uml/metamodel.svg +0 -1
- package/plantuml.jar +0 -0
- package/src/lib/famix/src/model/famix/association.ts +0 -44
- package/src/lib/famix/src/model/famix/namespace.ts +0 -28
- 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
|
@@ -23,24 +23,36 @@ 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
39
|
const Famix = __importStar(require("../lib/famix/src/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
|
/**
|
|
@@ -63,7 +75,6 @@ function getModulePath(i) {
|
|
|
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
|
|
@@ -106,17 +116,18 @@ function processFiles(sourceFiles) {
|
|
|
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
132
|
analyze_1.logger.debug(`processFile: file: ${f.getBaseName()}, fqn = ${fmxFile.getFullyQualifiedName()}`);
|
|
122
133
|
processComments(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.getFullyQualifiedName()}`);
|
|
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
|
/**
|
|
@@ -246,7 +296,7 @@ function processAlias(a) {
|
|
|
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);
|
|
@@ -272,7 +322,7 @@ 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);
|
|
@@ -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 => {
|
|
@@ -312,11 +362,12 @@ function processProperty(p) {
|
|
|
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.getName()}`);
|
|
370
|
+
analyze_1.logger.debug(`adding access to map: ${p.getName()}, (${p.getType().getText()}) Famix ${fmxProperty.getName()} id: ${fmxProperty.id}`);
|
|
320
371
|
exports.accessMap.set(fmxProperty.id, p);
|
|
321
372
|
}
|
|
322
373
|
}
|
|
@@ -329,7 +380,7 @@ 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.
|
|
383
|
+
const fmxMethod = analyze_1.entityDictionary.createOrGetFamixMethod(m, exports.currentCC);
|
|
333
384
|
analyze_1.logger.debug(`Method: ${!(m instanceof ts_morph_1.ConstructorDeclaration) ? m.getName() : "constructor"}, (${m.getType().getText()}), parent: ${m.getParent().getName()}, fqn = ${fmxMethod.getFullyQualifiedName()}`);
|
|
334
385
|
processComments(m, fmxMethod);
|
|
335
386
|
processTypeParameters(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,8 +448,67 @@ 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, c) {
|
|
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
|
+
c.addProperty(propertyRepresentation);
|
|
471
|
+
const p = c.getProperty(propertyRepresentation.name);
|
|
472
|
+
const fmxProperty = analyze_1.entityDictionary.createFamixProperty(p);
|
|
473
|
+
if (c instanceof ts_morph_1.ClassDeclaration) {
|
|
474
|
+
const fmxClass = analyze_1.entityDictionary.createOrGetFamixClass(c);
|
|
475
|
+
fmxClass.addProperty(fmxProperty);
|
|
476
|
+
}
|
|
477
|
+
else {
|
|
478
|
+
throw new Error("Unexpected type ClassExpression.");
|
|
479
|
+
}
|
|
480
|
+
processComments(p, fmxProperty);
|
|
481
|
+
// remove the property from the class
|
|
482
|
+
p.remove();
|
|
483
|
+
return fmxProperty;
|
|
484
|
+
}
|
|
485
|
+
function convertParameterToPropertyRepresentation(param) {
|
|
486
|
+
// Extract name
|
|
487
|
+
const paramName = param.getName();
|
|
488
|
+
// Extract type
|
|
489
|
+
const paramType = param.getType().getText(param);
|
|
490
|
+
// Determine visibility
|
|
491
|
+
let scope;
|
|
492
|
+
if (param.hasModifier(ts_morph_1.SyntaxKind.PrivateKeyword)) {
|
|
493
|
+
scope = ts_morph_1.Scope.Private;
|
|
494
|
+
}
|
|
495
|
+
else if (param.hasModifier(ts_morph_1.SyntaxKind.ProtectedKeyword)) {
|
|
496
|
+
scope = ts_morph_1.Scope.Protected;
|
|
497
|
+
}
|
|
498
|
+
else if (param.hasModifier(ts_morph_1.SyntaxKind.PublicKeyword)) {
|
|
499
|
+
scope = ts_morph_1.Scope.Public;
|
|
500
|
+
}
|
|
501
|
+
// Determine if readonly
|
|
502
|
+
const isReadonly = param.hasModifier(ts_morph_1.SyntaxKind.ReadonlyKeyword);
|
|
503
|
+
// Create a representation of the property
|
|
504
|
+
const propertyRepresentation = {
|
|
505
|
+
name: paramName,
|
|
506
|
+
type: paramType,
|
|
507
|
+
scope: scope,
|
|
508
|
+
isReadonly: isReadonly,
|
|
509
|
+
};
|
|
510
|
+
return propertyRepresentation;
|
|
511
|
+
}
|
|
396
512
|
/**
|
|
397
513
|
* Builds a Famix model for a parameter
|
|
398
514
|
* @param p A parameter
|
|
@@ -419,7 +535,7 @@ function processTypeParameters(e, fmxScope) {
|
|
|
419
535
|
analyze_1.logger.debug(`Finding Type Parameters:`);
|
|
420
536
|
e.getTypeParameters().forEach(tp => {
|
|
421
537
|
const fmxParam = processTypeParameter(tp);
|
|
422
|
-
fmxScope.
|
|
538
|
+
fmxScope.addGenericParameter(fmxParam);
|
|
423
539
|
});
|
|
424
540
|
}
|
|
425
541
|
/**
|
|
@@ -548,41 +664,40 @@ function processComment(c, fmxScope) {
|
|
|
548
664
|
* @param accessMap A map of parameters, variables, properties and enum members with their id
|
|
549
665
|
*/
|
|
550
666
|
function processAccesses(accessMap) {
|
|
551
|
-
analyze_1.logger.debug(`
|
|
667
|
+
analyze_1.logger.debug(`Creating accesses:`);
|
|
552
668
|
accessMap.forEach((v, id) => {
|
|
553
|
-
analyze_1.logger.debug(`
|
|
554
|
-
try {
|
|
555
|
-
|
|
556
|
-
|
|
557
|
-
}
|
|
558
|
-
|
|
559
|
-
|
|
560
|
-
}
|
|
669
|
+
analyze_1.logger.debug(`Accesses to ${v.getName()}`);
|
|
670
|
+
// try {
|
|
671
|
+
const temp_nodes = v.findReferencesAsNodes();
|
|
672
|
+
temp_nodes.forEach(node => processNodeForAccesses(node, id));
|
|
673
|
+
// } catch (error) {
|
|
674
|
+
// logger.error(`> WARNING: got exception "${error}".\nContinuing...`);
|
|
675
|
+
// }
|
|
561
676
|
});
|
|
562
677
|
}
|
|
563
|
-
exports.processAccesses = processAccesses;
|
|
564
678
|
/**
|
|
565
679
|
* Builds a Famix model for an access on a parameter, variable, property or enum member
|
|
566
680
|
* @param n A node
|
|
567
681
|
* @param id An id of a parameter, a variable, a property or an enum member
|
|
568
682
|
*/
|
|
569
683
|
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...`);
|
|
684
|
+
// try {
|
|
685
|
+
// sometimes node's first ancestor is a PropertyDeclaration, which is not an access
|
|
686
|
+
// see https://github.com/fuhrmanator/FamixTypeScriptImporter/issues/9
|
|
687
|
+
// check for a node whose first ancestor is a property declaration and bail?
|
|
688
|
+
// This may be a bug in ts-morph?
|
|
689
|
+
if (n.getFirstAncestorOrThrow().getKindName() === "PropertyDeclaration") {
|
|
690
|
+
analyze_1.logger.debug(`processNodeForAccesses: node kind: ${n.getKindName()}, ${n.getText()}, (${n.getType().getText()})'s first ancestor is a PropertyDeclaration. Skipping...`);
|
|
691
|
+
return;
|
|
584
692
|
}
|
|
585
|
-
|
|
693
|
+
analyze_1.entityDictionary.createFamixAccess(n, id);
|
|
694
|
+
analyze_1.logger.debug(`processNodeForAccesses: node kind: ${n.getKindName()}, ${n.getText()}, (${n.getType().getText()})`);
|
|
695
|
+
// } catch (error) {
|
|
696
|
+
// logger.error(`> Got exception "${error}".\nScopeDeclaration invalid for "${n.getSymbol().getFullyQualifiedName()}".\nContinuing...`);
|
|
697
|
+
// }
|
|
698
|
+
}
|
|
699
|
+
// exports has name -> Declaration -- the declaration can be used to find the FamixElement
|
|
700
|
+
// handle `import path = require("path")` for example
|
|
586
701
|
function processImportClausesForImportEqualsDeclarations(sourceFiles, exports) {
|
|
587
702
|
analyze_1.logger.info(`Creating import clauses from ImportEqualsDeclarations in source files:`);
|
|
588
703
|
sourceFiles.forEach(sourceFile => {
|
|
@@ -591,41 +706,39 @@ function processImportClausesForImportEqualsDeclarations(sourceFiles, exports) {
|
|
|
591
706
|
// You've found an ImportEqualsDeclaration
|
|
592
707
|
analyze_1.logger.info("Declaration Name:", node.getName());
|
|
593
708
|
analyze_1.logger.info("Module Reference Text:", node.getModuleReference().getText());
|
|
709
|
+
// what's the name of the imported entity?
|
|
710
|
+
// const importedEntity = node.getName();
|
|
594
711
|
// create a famix import clause
|
|
595
712
|
const namedImport = node.getNameNode();
|
|
596
|
-
analyze_1.entityDictionary.
|
|
597
|
-
|
|
713
|
+
analyze_1.entityDictionary.oldCreateFamixImportClause({ importDeclaration: node,
|
|
714
|
+
importerSourceFile: sourceFile,
|
|
598
715
|
moduleSpecifierFilePath: node.getModuleReference().getText(),
|
|
599
716
|
importElement: namedImport,
|
|
600
717
|
isInExports: exports.find(e => e.has(namedImport.getText())) !== undefined,
|
|
601
718
|
isDefaultExport: false });
|
|
719
|
+
// entityDictionary.createFamixImportClause(importedEntity, importingEntity);
|
|
602
720
|
}
|
|
603
721
|
});
|
|
604
722
|
});
|
|
605
723
|
}
|
|
606
|
-
exports.processImportClausesForImportEqualsDeclarations = processImportClausesForImportEqualsDeclarations;
|
|
607
724
|
/**
|
|
608
|
-
|
|
609
|
-
|
|
610
|
-
|
|
611
|
-
|
|
725
|
+
* Builds a Famix model for the import clauses of the source files which are modules
|
|
726
|
+
* @param modules An array of modules
|
|
727
|
+
* @param exports An array of maps of exported declarations
|
|
728
|
+
*/
|
|
612
729
|
function processImportClausesForModules(modules, exports) {
|
|
613
730
|
analyze_1.logger.info(`Creating import clauses from ${modules.length} modules:`);
|
|
614
731
|
modules.forEach(module => {
|
|
732
|
+
const modulePath = module.getFilePath() + module.getBaseName();
|
|
615
733
|
module.getImportDeclarations().forEach(impDecl => {
|
|
616
|
-
analyze_1.logger.
|
|
734
|
+
analyze_1.logger.info(`Importing ${impDecl.getModuleSpecifierValue()} in ${modulePath}`);
|
|
617
735
|
const path = getModulePath(impDecl);
|
|
618
736
|
impDecl.getNamedImports().forEach(namedImport => {
|
|
619
|
-
analyze_1.logger.
|
|
737
|
+
analyze_1.logger.info(`Importing (named) ${namedImport.getName()} from ${impDecl.getModuleSpecifierValue()} in ${modulePath}`);
|
|
620
738
|
const importedEntityName = namedImport.getName();
|
|
621
|
-
let importFoundInExports =
|
|
622
|
-
|
|
623
|
-
|
|
624
|
-
importFoundInExports = true;
|
|
625
|
-
}
|
|
626
|
-
});
|
|
627
|
-
analyze_1.entityDictionary.createFamixImportClause({ importDeclaration: impDecl,
|
|
628
|
-
importer: module,
|
|
739
|
+
let importFoundInExports = isInExports(exports, importedEntityName);
|
|
740
|
+
analyze_1.entityDictionary.oldCreateFamixImportClause({ importDeclaration: impDecl,
|
|
741
|
+
importerSourceFile: module,
|
|
629
742
|
moduleSpecifierFilePath: path,
|
|
630
743
|
importElement: namedImport,
|
|
631
744
|
isInExports: importFoundInExports,
|
|
@@ -633,10 +746,10 @@ function processImportClausesForModules(modules, exports) {
|
|
|
633
746
|
});
|
|
634
747
|
const defaultImport = impDecl.getDefaultImport();
|
|
635
748
|
if (defaultImport !== undefined) {
|
|
636
|
-
analyze_1.logger.
|
|
749
|
+
analyze_1.logger.info(`Importing (default) ${defaultImport.getText()} from ${impDecl.getModuleSpecifierValue()} in ${modulePath}`);
|
|
637
750
|
// call with module, impDecl.getModuleSpecifierValue(), path, defaultImport, false, true
|
|
638
|
-
analyze_1.entityDictionary.
|
|
639
|
-
|
|
751
|
+
analyze_1.entityDictionary.oldCreateFamixImportClause({ importDeclaration: impDecl,
|
|
752
|
+
importerSourceFile: module,
|
|
640
753
|
moduleSpecifierFilePath: path,
|
|
641
754
|
importElement: defaultImport,
|
|
642
755
|
isInExports: false,
|
|
@@ -644,9 +757,9 @@ function processImportClausesForModules(modules, exports) {
|
|
|
644
757
|
}
|
|
645
758
|
const namespaceImport = impDecl.getNamespaceImport();
|
|
646
759
|
if (namespaceImport !== undefined) {
|
|
647
|
-
analyze_1.logger.
|
|
648
|
-
analyze_1.entityDictionary.
|
|
649
|
-
|
|
760
|
+
analyze_1.logger.info(`Importing (namespace) ${namespaceImport.getText()} from ${impDecl.getModuleSpecifierValue()} in ${modulePath}`);
|
|
761
|
+
analyze_1.entityDictionary.oldCreateFamixImportClause({ importDeclaration: impDecl,
|
|
762
|
+
importerSourceFile: module,
|
|
650
763
|
moduleSpecifierFilePath: path,
|
|
651
764
|
importElement: namespaceImport,
|
|
652
765
|
isInExports: false,
|
|
@@ -656,12 +769,20 @@ function processImportClausesForModules(modules, exports) {
|
|
|
656
769
|
});
|
|
657
770
|
});
|
|
658
771
|
}
|
|
659
|
-
exports
|
|
772
|
+
function isInExports(exports, importedEntityName) {
|
|
773
|
+
let importFoundInExports = false;
|
|
774
|
+
exports.forEach(e => {
|
|
775
|
+
if (e.has(importedEntityName)) {
|
|
776
|
+
importFoundInExports = true;
|
|
777
|
+
}
|
|
778
|
+
});
|
|
779
|
+
return importFoundInExports;
|
|
780
|
+
}
|
|
660
781
|
/**
|
|
661
|
-
|
|
662
|
-
|
|
663
|
-
|
|
664
|
-
|
|
782
|
+
* Builds a Famix model for the inheritances of the classes and interfaces of the source files
|
|
783
|
+
* @param classes An array of classes
|
|
784
|
+
* @param interfaces An array of interfaces
|
|
785
|
+
*/
|
|
665
786
|
function processInheritances(classes, interfaces) {
|
|
666
787
|
analyze_1.logger.info(`processInheritances: Creating inheritances:`);
|
|
667
788
|
classes.forEach(cls => {
|
|
@@ -687,7 +808,6 @@ function processInheritances(classes, interfaces) {
|
|
|
687
808
|
});
|
|
688
809
|
});
|
|
689
810
|
}
|
|
690
|
-
exports.processInheritances = processInheritances;
|
|
691
811
|
/**
|
|
692
812
|
* Builds a Famix model for the invocations of the methods and functions of the source files
|
|
693
813
|
* @param methodsAndFunctionsWithId A map of methods and functions with their id
|
|
@@ -695,17 +815,18 @@ exports.processInheritances = processInheritances;
|
|
|
695
815
|
function processInvocations(methodsAndFunctionsWithId) {
|
|
696
816
|
analyze_1.logger.info(`Creating invocations:`);
|
|
697
817
|
methodsAndFunctionsWithId.forEach((m, id) => {
|
|
698
|
-
|
|
699
|
-
|
|
700
|
-
|
|
701
|
-
|
|
702
|
-
|
|
703
|
-
|
|
704
|
-
|
|
818
|
+
if (!(m instanceof ts_morph_1.ArrowFunction)) {
|
|
819
|
+
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'))}`);
|
|
820
|
+
try {
|
|
821
|
+
const temp_nodes = m.findReferencesAsNodes();
|
|
822
|
+
temp_nodes.forEach(node => processNodeForInvocations(node, m, id));
|
|
823
|
+
}
|
|
824
|
+
catch (error) {
|
|
825
|
+
analyze_1.logger.error(`> WARNING: got exception ${error}. Continuing...`);
|
|
826
|
+
}
|
|
705
827
|
}
|
|
706
828
|
});
|
|
707
829
|
}
|
|
708
|
-
exports.processInvocations = processInvocations;
|
|
709
830
|
/**
|
|
710
831
|
* Builds a Famix model for an invocation of a method or a function
|
|
711
832
|
* @param n A node
|
|
@@ -721,3 +842,30 @@ function processNodeForInvocations(n, m, id) {
|
|
|
721
842
|
analyze_1.logger.error(`> WARNING: got exception ${error}. ScopeDeclaration invalid for ${n.getSymbol().getFullyQualifiedName()}. Continuing...`);
|
|
722
843
|
}
|
|
723
844
|
}
|
|
845
|
+
/**
|
|
846
|
+
* Builds a Famix model for the inheritances of the classes and interfaces of the source files
|
|
847
|
+
* @param classes An array of classes
|
|
848
|
+
* @param interfaces An array of interfaces
|
|
849
|
+
*/
|
|
850
|
+
function processConcretisations(classes, interfaces, functions) {
|
|
851
|
+
analyze_1.logger.info(`processConcretisations: Creating concretisations:`);
|
|
852
|
+
classes.forEach(cls => {
|
|
853
|
+
analyze_1.logger.debug(`processConcretisations: Checking class concretisation for ${cls.getName()}`);
|
|
854
|
+
analyze_1.entityDictionary.createFamixConcretisationClassOrInterfaceSpecialisation(cls);
|
|
855
|
+
analyze_1.entityDictionary.createFamixConcretisationGenericInstantiation(cls);
|
|
856
|
+
analyze_1.entityDictionary.createFamixConcretisationInterfaceClass(cls);
|
|
857
|
+
analyze_1.entityDictionary.createFamixConcretisationTypeInstanciation(cls);
|
|
858
|
+
});
|
|
859
|
+
interfaces.forEach(inter => {
|
|
860
|
+
analyze_1.logger.debug(`processConcretisations: Checking interface concretisation for ${inter.getName()}`);
|
|
861
|
+
analyze_1.entityDictionary.createFamixConcretisationTypeInstanciation(inter);
|
|
862
|
+
analyze_1.entityDictionary.createFamixConcretisationClassOrInterfaceSpecialisation(inter);
|
|
863
|
+
});
|
|
864
|
+
functions.forEach(func => {
|
|
865
|
+
if (func instanceof ts_morph_1.FunctionDeclaration || func instanceof ts_morph_1.MethodDeclaration) {
|
|
866
|
+
analyze_1.logger.debug(`processConcretisations: Checking Method concretisation`);
|
|
867
|
+
analyze_1.entityDictionary.createFamixConcretisationFunctionInstantiation(func);
|
|
868
|
+
}
|
|
869
|
+
});
|
|
870
|
+
}
|
|
871
|
+
//# 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/src/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: unknown; // 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 i An import declaration\n * @returns The path of the module to be imported\n */\nexport function getModulePath(i: ImportDeclaration): string {\n    let path: string;\n    if (i.getModuleSpecifierSourceFile() === undefined) {\n        if (i.getModuleSpecifierValue().substring(i.getModuleSpecifierValue().length - 3) === \".ts\") {\n            path = i.getModuleSpecifierValue();\n        }\n        else {\n            path = i.getModuleSpecifierValue() + \".ts\";\n        }\n    }\n    else {\n        path = i.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 = 0;\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.getFullyQualifiedName()}`);\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.getFullyQualifiedName()}`);\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.getFullyQualifiedName()}`);\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.getFullyQualifiedName()}`);\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.getFullyQualifiedName()}`);\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.getFullyQualifiedName()}`);\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.getName()} 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.getFullyQualifiedName()}`);\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, c: 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    c.addProperty(propertyRepresentation);\n\n    const p = c.getProperty(propertyRepresentation.name);\n    const fmxProperty = entityDictionary.createFamixProperty(p);\n    if (c instanceof ClassDeclaration) {\n        const fmxClass = entityDictionary.createOrGetFamixClass(c);\n        fmxClass.addProperty(fmxProperty);\n    } else { \n        throw new Error(\"Unexpected type ClassExpression.\");\n    }\n\n    processComments(p, fmxProperty);\n\n    // remove the property from the class\n    p.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    }\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 p A parameter\n * @returns A Famix.Parameter representing the parameter\n */\nfunction processParameter(p: ParameterDeclaration): Famix.Parameter {\n    const fmxParam = entityDictionary.createFamixParameter(p);\n\n    logger.debug(`parameter: ${p.getName()}, (${p.getType().getText()}), fqn = ${fmxParam.getFullyQualifiedName()}`);\n\n    processComments(p, fmxParam);\n\n    processDecorators(p, fmxParam);\n\n    const parent = p.getParent();\n\n    if (!(parent instanceof MethodSignature)) {\n        logger.debug(`adding access: ${p.getName()}, (${p.getType().getText()}) Famix ${fmxParam.getName()}`);\n        accessMap.set(fmxParam.id, p);\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.getFullyQualifiedName()}`);\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.getFullyQualifiedName()}`);\n\n    processComments(v, fmxVar);\n\n    logger.debug(`adding access: ${v.getName()}, (${v.getType().getText()}) Famix ${fmxVar.getName()}`);\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.getFullyQualifiedName()}`);\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.getFullyQualifiedName()}`);\n\n    processComments(v, fmxEnumValue);\n\n    logger.debug(`adding access: ${v.getName()}, (${v.getType().getText()}) Famix ${fmxEnumValue.getName()}`);\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.getFullyQualifiedName()}`);\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().getFullyQualifiedName()}\".\\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"]}
|