ts2famix 1.4.1 → 2.0.1

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