ts2famix 1.4.0 → 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.
Files changed (119) hide show
  1. package/README.md +1 -1
  2. package/dist/analyze.js +6 -3
  3. package/dist/analyze_functions/process_functions.js +248 -100
  4. package/dist/famix2puml.js +1 -0
  5. package/dist/famix_functions/EntityDictionary.js +661 -155
  6. package/dist/famix_functions/helpers_creation.js +26 -6
  7. package/dist/fqn.js +156 -69
  8. package/dist/lib/famix/src/famix_JSON_exporter.js +1 -0
  9. package/dist/lib/famix/src/famix_base_element.js +1 -0
  10. package/dist/lib/famix/src/famix_repository.js +9 -8
  11. package/dist/lib/famix/src/index.js +1 -0
  12. package/dist/lib/famix/src/model/famix/access.js +3 -2
  13. package/dist/lib/famix/src/model/famix/accessor.js +1 -0
  14. package/dist/lib/famix/src/model/famix/alias.js +2 -1
  15. package/dist/lib/famix/src/model/famix/arrowFunction.js +17 -0
  16. package/dist/lib/famix/src/model/famix/behavioral_entity.js +13 -15
  17. package/dist/lib/famix/src/model/famix/class.js +1 -0
  18. package/dist/lib/famix/src/model/famix/comment.js +2 -1
  19. package/dist/lib/famix/src/model/famix/concretisation.js +31 -0
  20. package/dist/lib/famix/src/model/famix/container_entity.js +7 -6
  21. package/dist/lib/famix/src/model/famix/decorator.js +2 -1
  22. package/dist/lib/famix/src/model/famix/entity.js +1 -0
  23. package/dist/lib/famix/src/model/famix/enum.js +2 -1
  24. package/dist/lib/famix/src/model/famix/enum_value.js +2 -1
  25. package/dist/lib/famix/src/model/famix/function.js +1 -0
  26. package/dist/lib/famix/src/model/famix/implicit_variable.js +1 -0
  27. package/dist/lib/famix/src/model/famix/import_clause.js +5 -3
  28. package/dist/lib/famix/src/model/famix/index.js +18 -11
  29. package/dist/lib/famix/src/model/famix/indexed_file_anchor.js +3 -2
  30. package/dist/lib/famix/src/model/famix/inheritance.js +3 -2
  31. package/dist/lib/famix/src/model/famix/interface.js +2 -1
  32. package/dist/lib/famix/src/model/famix/invocation.js +3 -2
  33. package/dist/lib/famix/src/model/famix/method.js +2 -1
  34. package/dist/lib/famix/src/model/famix/module.js +53 -0
  35. package/dist/lib/famix/src/model/famix/named_entity.js +4 -3
  36. package/dist/lib/famix/src/model/famix/parameter.js +2 -1
  37. package/dist/lib/famix/src/model/famix/parameterConcretisation.js +44 -0
  38. package/dist/lib/famix/src/model/famix/parameter_type.js +22 -1
  39. package/dist/lib/famix/src/model/famix/parametric_arrow_function.js +31 -0
  40. package/dist/lib/famix/src/model/famix/parametric_class.js +44 -0
  41. package/dist/lib/famix/src/model/famix/parametric_function.js +31 -0
  42. package/dist/lib/famix/src/model/famix/parametric_interface.js +44 -0
  43. package/dist/lib/famix/src/model/famix/parametric_method.js +31 -0
  44. package/dist/lib/famix/src/model/famix/primitive_type.js +1 -0
  45. package/dist/lib/famix/src/model/famix/property.js +91 -9
  46. package/dist/lib/famix/src/model/famix/reference.js +3 -2
  47. package/dist/lib/famix/src/model/famix/scoping_entity.js +12 -10
  48. package/dist/lib/famix/src/model/famix/script_entity.js +1 -2
  49. package/dist/lib/famix/src/model/famix/source_anchor.js +1 -0
  50. package/dist/lib/famix/src/model/famix/source_language.js +1 -1
  51. package/dist/lib/famix/src/model/famix/sourced_entity.js +2 -1
  52. package/dist/lib/famix/src/model/famix/structural_entity.js +1 -0
  53. package/dist/lib/famix/src/model/famix/text_anchor.js +1 -0
  54. package/dist/lib/famix/src/model/famix/type.js +6 -4
  55. package/dist/lib/famix/src/model/famix/variable.js +1 -0
  56. package/dist/lib/ts-complex/cyclomatic-service.js +2 -2
  57. package/dist/ts2famix-cli-wrapper.js +16 -0
  58. package/dist/ts2famix-cli.js +8 -1
  59. package/dist/ts2famix-tsconfig.js +1 -0
  60. package/doc-uml/famix-typescript-model.puml +559 -0
  61. package/doc-uml/famix-typescript-model.svg +1 -0
  62. package/jest.config.json +2 -1
  63. package/package.json +10 -10
  64. package/src/analyze.ts +25 -22
  65. package/src/analyze_functions/process_functions.ts +272 -96
  66. package/src/famix_functions/EntityDictionary.ts +731 -182
  67. package/src/famix_functions/helpers_creation.ts +28 -2
  68. package/src/fqn.ts +132 -10
  69. package/src/lib/famix/src/famix_repository.ts +9 -9
  70. package/src/lib/famix/src/model/famix/access.ts +2 -2
  71. package/src/lib/famix/src/model/famix/alias.ts +1 -1
  72. package/src/lib/famix/src/model/famix/arrowFunction.ts +15 -0
  73. package/src/lib/famix/src/model/famix/behavioral_entity.ts +12 -19
  74. package/src/lib/famix/src/model/famix/comment.ts +1 -1
  75. package/src/lib/famix/src/model/famix/concretisation.ts +42 -0
  76. package/src/lib/famix/src/model/famix/container_entity.ts +6 -6
  77. package/src/lib/famix/src/model/famix/decorator.ts +1 -1
  78. package/src/lib/famix/src/model/famix/enum.ts +1 -1
  79. package/src/lib/famix/src/model/famix/enum_value.ts +1 -1
  80. package/src/lib/famix/src/model/famix/import_clause.ts +4 -3
  81. package/src/lib/famix/src/model/famix/index.ts +8 -5
  82. package/src/lib/famix/src/model/famix/indexed_file_anchor.ts +2 -2
  83. package/src/lib/famix/src/model/famix/inheritance.ts +3 -4
  84. package/src/lib/famix/src/model/famix/interface.ts +1 -1
  85. package/src/lib/famix/src/model/famix/invocation.ts +2 -2
  86. package/src/lib/famix/src/model/famix/method.ts +1 -1
  87. package/src/lib/famix/src/model/famix/module.ts +67 -1
  88. package/src/lib/famix/src/model/famix/named_entity.ts +3 -3
  89. package/src/lib/famix/src/model/famix/parameter.ts +1 -1
  90. package/src/lib/famix/src/model/famix/parameterConcretisation.ts +54 -0
  91. package/src/lib/famix/src/model/famix/parameter_type.ts +33 -6
  92. package/src/lib/famix/src/model/famix/parametric_arrow_function.ts +32 -0
  93. package/src/lib/famix/src/model/famix/parametric_class.ts +49 -0
  94. package/src/lib/famix/src/model/famix/parametric_function.ts +32 -0
  95. package/src/lib/famix/src/model/famix/parametric_interface.ts +49 -0
  96. package/src/lib/famix/src/model/famix/parametric_method.ts +32 -0
  97. package/src/lib/famix/src/model/famix/property.ts +109 -11
  98. package/src/lib/famix/src/model/famix/reference.ts +2 -2
  99. package/src/lib/famix/src/model/famix/scoping_entity.ts +12 -11
  100. package/src/lib/famix/src/model/famix/script_entity.ts +0 -2
  101. package/src/lib/famix/src/model/famix/source_language.ts +0 -1
  102. package/src/lib/famix/src/model/famix/sourced_entity.ts +1 -1
  103. package/src/lib/famix/src/model/famix/type.ts +5 -4
  104. package/src/ts2famix-cli-wrapper.ts +17 -0
  105. package/src/ts2famix-cli.ts +7 -1
  106. package/tsconfig.json +5 -5
  107. package/dist/lib/famix/src/model/famix/association.js +0 -36
  108. package/dist/lib/famix/src/model/famix/namespace.js +0 -24
  109. package/dist/lib/famix/src/model/famix/parameterizable_class.js +0 -30
  110. package/dist/lib/famix/src/model/famix/parameterizable_interface.js +0 -30
  111. package/dist/lib/famix/src/model/famix/parameterized_type.js +0 -36
  112. package/doc-uml/metamodel-full.svg +0 -1
  113. package/doc-uml/metamodel.svg +0 -1
  114. package/plantuml.jar +0 -0
  115. package/src/lib/famix/src/model/famix/association.ts +0 -44
  116. package/src/lib/famix/src/model/famix/namespace.ts +0 -28
  117. package/src/lib/famix/src/model/famix/parameterizable_class.ts +0 -31
  118. package/src/lib/famix/src/model/famix/parameterizable_interface.ts +0 -31
  119. 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.processInvocations = exports.processInheritances = exports.processImportClausesForModules = exports.processImportClausesForImportEqualsDeclarations = exports.processAccesses = exports.processFiles = exports.getImplementedOrExtendedInterfaces = exports.getModulePath = exports.currentCC = exports.exportedMap = exports.modules = exports.interfaces = exports.classes = exports.accessMap = exports.methodsAndFunctionsWithId = void 0;
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.exportedMap = new Array(); // Array of all the 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 ismodule(sourceFile) {
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 = ismodule(f);
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
- processNamespaces(f, fmxFile);
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.Namespace representing the namespace
135
- */
136
- function processNamespace(m) {
137
- const fmxNamespace = analyze_1.entityDictionary.createOrGetFamixNamespace(m);
138
- analyze_1.logger.debug(`processNamespace: namespace: ${m.getName()}, (${m.getType().getText()}), ${fmxNamespace.getFullyQualifiedName()}`);
139
- processComments(m, fmxNamespace);
140
- processAliases(m, fmxNamespace);
141
- processClasses(m, fmxNamespace);
142
- processInterfaces(m, fmxNamespace);
143
- processVariables(m, fmxNamespace);
144
- processEnums(m, fmxNamespace);
145
- processFunctions(m, fmxNamespace);
146
- processNamespaces(m, fmxNamespace);
147
- return fmxNamespace;
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.getClasses().forEach(c => {
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 namespaces of a container
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 processNamespaces(m, fmxScope) {
229
- analyze_1.logger.debug(`Finding Namespaces:`);
278
+ function processModules(m, fmxScope) {
279
+ analyze_1.logger.debug(`Finding Modules:`);
230
280
  m.getModules().forEach(md => {
231
- const fmxNsp = processNamespace(md);
232
- fmxScope.addNamespace(fmxNsp);
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.ParameterizableClass representing the class
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.ParameterizableInterface representing the interface
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.ParameterizableClass || fmxScope instanceof Famix.ParameterizableInterface) {
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.createFamixMethod(m, exports.currentCC);
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
- const fmxFunction = analyze_1.entityDictionary.createFamixFunction(f, exports.currentCC);
357
- analyze_1.logger.debug(`Function: ${(f.getName()) ? f.getName() : "anonymous"}, (${f.getType().getText()}), fqn = ${fmxFunction.getFullyQualifiedName()}`);
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.addParameterType(fmxParam);
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(`processAccesses: Creating accesses:`);
667
+ analyze_1.logger.debug(`Creating accesses:`);
552
668
  accessMap.forEach((v, id) => {
553
- analyze_1.logger.debug(`processAccesses: Accesses to ${v.getName()}`);
554
- try {
555
- const temp_nodes = v.findReferencesAsNodes();
556
- temp_nodes.forEach(node => processNodeForAccesses(node, id));
557
- }
558
- catch (error) {
559
- analyze_1.logger.error(`> WARNING: got exception ${error}. Continuing...`);
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
- // sometimes node's first ancestor is a PropertyDeclaration, which is not an access
572
- // see https://github.com/fuhrmanator/FamixTypeScriptImporter/issues/9
573
- // check for a node whose first ancestor is a property declaration and bail?
574
- // This may be a bug in ts-morph?
575
- if (n.getFirstAncestorOrThrow().getKindName() === "PropertyDeclaration") {
576
- analyze_1.logger.debug(`processNodeForAccesses: node kind: ${n.getKindName()}, ${n.getText()}, (${n.getType().getText()})'s first ancestor is a PropertyDeclaration. Skipping...`);
577
- return;
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.createFamixImportClause({ importDeclaration: node,
597
- importer: sourceFile,
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
- * Builds a Famix model for the import clauses of the source files which are modules
609
- * @param modules An array of modules
610
- * @param exports An array of maps of exported declarations
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.debug(`Importing ${impDecl.getModuleSpecifierValue()}`);
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.debug(`Importing (named) ${namedImport.getName()} from ${impDecl.getModuleSpecifierValue()}`);
737
+ analyze_1.logger.info(`Importing (named) ${namedImport.getName()} from ${impDecl.getModuleSpecifierValue()} in ${modulePath}`);
620
738
  const importedEntityName = namedImport.getName();
621
- let importFoundInExports = false;
622
- exports.forEach(e => {
623
- if (e.has(importedEntityName)) {
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.debug(`Importing (default) ${defaultImport.getText()} from ${impDecl.getModuleSpecifierValue()}`);
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.createFamixImportClause({ importDeclaration: impDecl,
639
- importer: module,
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.debug(`Importing (namespace) ${namespaceImport.getText()} from ${impDecl.getModuleSpecifierValue()}`);
648
- analyze_1.entityDictionary.createFamixImportClause({ importDeclaration: impDecl,
649
- importer: module,
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.processImportClausesForModules = processImportClausesForModules;
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
- * Builds a Famix model for the inheritances of the classes and interfaces of the source files
662
- * @param classes An array of classes
663
- * @param interfaces An array of interfaces
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
- 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'))}`);
699
- try {
700
- const temp_nodes = m.findReferencesAsNodes();
701
- temp_nodes.forEach(node => processNodeForInvocations(node, m, id));
702
- }
703
- catch (error) {
704
- analyze_1.logger.error(`> WARNING: got exception ${error}. Continuing...`);
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"]}