@eagleoutice/flowr 2.6.2 → 2.6.3

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 (349) hide show
  1. package/README.md +36 -34
  2. package/abstract-interpretation/data-frame/absint-visitor.js +3 -3
  3. package/abstract-interpretation/data-frame/mappers/function-mapper.d.ts +7 -7
  4. package/abstract-interpretation/data-frame/mappers/function-mapper.js +20 -16
  5. package/abstract-interpretation/data-frame/semantics.js +8 -0
  6. package/abstract-interpretation/data-frame/shape-inference.d.ts +3 -3
  7. package/abstract-interpretation/data-frame/shape-inference.js +3 -3
  8. package/abstract-interpretation/normalized-ast-fold.d.ts +1 -1
  9. package/benchmark/slicer.d.ts +1 -0
  10. package/benchmark/slicer.js +13 -12
  11. package/benchmark/summarizer/first-phase/process.js +1 -1
  12. package/benchmark/summarizer/second-phase/graph.d.ts +3 -1
  13. package/benchmark/summarizer/second-phase/graph.js +3 -1
  14. package/cli/export-quads-app.js +1 -1
  15. package/cli/repl/commands/repl-dataflow.js +2 -1
  16. package/cli/repl/commands/repl-parse.js +16 -4
  17. package/cli/repl/commands/repl-query.js +1 -1
  18. package/cli/repl/core.js +16 -13
  19. package/cli/repl/server/connection.js +2 -1
  20. package/cli/script-core/statistics-helper-core.js +2 -1
  21. package/cli/slicer-app.js +3 -4
  22. package/cli/wiki.d.ts +4 -0
  23. package/cli/wiki.js +165 -0
  24. package/config.d.ts +4 -0
  25. package/config.js +6 -0
  26. package/control-flow/cfg-dead-code.js +13 -3
  27. package/control-flow/cfg-simplification.d.ts +5 -2
  28. package/control-flow/cfg-simplification.js +3 -0
  29. package/control-flow/extract-cfg.d.ts +9 -3
  30. package/control-flow/extract-cfg.js +44 -4
  31. package/control-flow/semantic-cfg-guided-visitor.d.ts +2 -2
  32. package/control-flow/simple-visitor.js +2 -2
  33. package/control-flow/useless-loop.d.ts +3 -3
  34. package/control-flow/useless-loop.js +14 -5
  35. package/core/pipeline-executor.d.ts +3 -6
  36. package/core/pipeline-executor.js +4 -7
  37. package/core/print/normalize-printer.d.ts +1 -1
  38. package/core/print/normalize-printer.js +2 -2
  39. package/core/steps/all/core/00-parse.d.ts +1 -1
  40. package/core/steps/all/core/00-parse.js +1 -1
  41. package/core/steps/all/core/10-normalize.d.ts +3 -9
  42. package/core/steps/all/core/10-normalize.js +1 -16
  43. package/core/steps/all/core/11-normalize-tree-sitter.d.ts +2 -3
  44. package/core/steps/all/core/11-normalize-tree-sitter.js +2 -3
  45. package/core/steps/all/core/20-dataflow.d.ts +3 -4
  46. package/core/steps/all/core/20-dataflow.js +2 -2
  47. package/core/steps/all/static-slicing/00-slice.d.ts +1 -2
  48. package/core/steps/all/static-slicing/00-slice.js +1 -1
  49. package/core/steps/all/static-slicing/10-reconstruct.d.ts +8 -0
  50. package/core/steps/all/static-slicing/10-reconstruct.js +4 -1
  51. package/core/steps/pipeline/default-pipelines.d.ts +55 -56
  52. package/core/steps/pipeline/default-pipelines.js +8 -8
  53. package/dataflow/environments/clone.d.ts +0 -1
  54. package/dataflow/environments/clone.js +12 -2
  55. package/dataflow/environments/diff.js +2 -2
  56. package/dataflow/environments/overwrite.d.ts +1 -5
  57. package/dataflow/environments/overwrite.js +3 -19
  58. package/dataflow/environments/scoping.d.ts +6 -2
  59. package/dataflow/environments/scoping.js +6 -2
  60. package/dataflow/eval/resolve/resolve-argument.js +2 -2
  61. package/dataflow/eval/values/string/string-constants.d.ts +9 -3
  62. package/dataflow/eval/values/string/string-constants.js +9 -3
  63. package/dataflow/extractor.d.ts +2 -3
  64. package/dataflow/extractor.js +25 -22
  65. package/dataflow/graph/graph.d.ts +3 -9
  66. package/dataflow/graph/graph.js +0 -13
  67. package/dataflow/graph/unknown-replacement.d.ts +4 -2
  68. package/dataflow/graph/unknown-replacement.js +4 -2
  69. package/dataflow/info.d.ts +7 -0
  70. package/dataflow/info.js +21 -0
  71. package/dataflow/internal/linker.js +7 -4
  72. package/dataflow/internal/process/functions/call/argument/make-argument.d.ts +2 -2
  73. package/dataflow/internal/process/functions/call/argument/make-argument.js +2 -3
  74. package/dataflow/internal/process/functions/call/built-in/built-in-access.d.ts +1 -1
  75. package/dataflow/internal/process/functions/call/built-in/built-in-access.js +4 -4
  76. package/dataflow/internal/process/functions/call/built-in/built-in-apply.js +1 -1
  77. package/dataflow/internal/process/functions/call/built-in/built-in-assignment.js +4 -4
  78. package/dataflow/internal/process/functions/call/built-in/built-in-eval.js +6 -6
  79. package/dataflow/internal/process/functions/call/built-in/built-in-expression-list.js +1 -1
  80. package/dataflow/internal/process/functions/call/built-in/built-in-for-loop.js +1 -1
  81. package/dataflow/internal/process/functions/call/built-in/built-in-function-definition.js +1 -1
  82. package/dataflow/internal/process/functions/call/built-in/built-in-get.d.ts +1 -1
  83. package/dataflow/internal/process/functions/call/built-in/built-in-get.js +1 -1
  84. package/dataflow/internal/process/functions/call/built-in/built-in-if-then-else.js +1 -1
  85. package/dataflow/internal/process/functions/call/built-in/built-in-list.js +2 -2
  86. package/dataflow/internal/process/functions/call/built-in/built-in-pipe.js +3 -3
  87. package/dataflow/internal/process/functions/call/built-in/built-in-repeat-loop.d.ts +6 -1
  88. package/dataflow/internal/process/functions/call/built-in/built-in-repeat-loop.js +6 -1
  89. package/dataflow/internal/process/functions/call/built-in/built-in-replacement.js +2 -2
  90. package/dataflow/internal/process/functions/call/built-in/built-in-source.d.ts +15 -10
  91. package/dataflow/internal/process/functions/call/built-in/built-in-source.js +78 -75
  92. package/dataflow/internal/process/functions/call/built-in/built-in-special-bin-op.d.ts +3 -1
  93. package/dataflow/internal/process/functions/call/built-in/built-in-special-bin-op.js +3 -1
  94. package/dataflow/internal/process/functions/call/built-in/built-in-vector.js +2 -2
  95. package/dataflow/internal/process/functions/call/built-in/built-in-while-loop.js +1 -1
  96. package/dataflow/internal/process/functions/call/common.d.ts +1 -1
  97. package/dataflow/internal/process/functions/call/common.js +4 -4
  98. package/dataflow/internal/process/functions/call/default-call-handling.d.ts +3 -1
  99. package/dataflow/internal/process/functions/call/default-call-handling.js +3 -1
  100. package/dataflow/internal/process/functions/call/known-call-handling.js +3 -3
  101. package/dataflow/internal/process/functions/call/named-call-handling.js +4 -4
  102. package/dataflow/internal/process/functions/process-parameter.js +4 -4
  103. package/dataflow/origin/dfg-get-symbol-refs.d.ts +1 -1
  104. package/dataflow/origin/dfg-get-symbol-refs.js +1 -1
  105. package/dataflow/processor.d.ts +6 -11
  106. package/documentation/data/dfg/doc-data-dfg-util.d.ts +0 -2
  107. package/documentation/data/faq/faqs.js +27 -18
  108. package/documentation/data/faq/recommended-configs.d.ts +36 -0
  109. package/documentation/data/faq/recommended-configs.js +40 -0
  110. package/documentation/data/faq/wiki-faq-store.d.ts +1 -0
  111. package/documentation/data/faq/wiki-faq-store.js +10 -2
  112. package/documentation/data/server/doc-data-server-messages.js +1 -1
  113. package/documentation/doc-capabilities.d.ts +9 -0
  114. package/documentation/{print-capabilities-markdown.js → doc-capabilities.js} +18 -21
  115. package/documentation/doc-readme.d.ts +9 -0
  116. package/documentation/{print-readme.js → doc-readme.js} +31 -35
  117. package/documentation/doc-util/doc-benchmarks.d.ts +6 -4
  118. package/documentation/doc-util/doc-benchmarks.js +6 -4
  119. package/documentation/doc-util/doc-cfg.js +5 -8
  120. package/documentation/doc-util/doc-dfg.d.ts +7 -7
  121. package/documentation/doc-util/doc-dfg.js +13 -13
  122. package/documentation/doc-util/doc-escape.d.ts +6 -0
  123. package/documentation/doc-util/doc-escape.js +11 -0
  124. package/documentation/doc-util/doc-general.d.ts +22 -2
  125. package/documentation/doc-util/doc-general.js +22 -2
  126. package/documentation/doc-util/doc-normalized-ast.d.ts +10 -5
  127. package/documentation/doc-util/doc-normalized-ast.js +12 -9
  128. package/documentation/doc-util/doc-query.d.ts +12 -4
  129. package/documentation/doc-util/doc-query.js +18 -11
  130. package/documentation/doc-util/doc-search.d.ts +0 -30
  131. package/documentation/doc-util/doc-search.js +2 -73
  132. package/documentation/doc-util/doc-server-message.d.ts +5 -5
  133. package/documentation/doc-util/doc-server-message.js +4 -4
  134. package/documentation/doc-util/doc-types.d.ts +69 -32
  135. package/documentation/doc-util/doc-types.js +108 -61
  136. package/documentation/index.d.ts +9 -9
  137. package/documentation/index.js +9 -9
  138. package/documentation/issue-linting-rule.d.ts +9 -0
  139. package/documentation/{print-linter-issue.js → issue-linting-rule.js} +20 -23
  140. package/documentation/wiki-analyzer.d.ts +9 -0
  141. package/documentation/wiki-analyzer.js +412 -0
  142. package/documentation/wiki-cfg.d.ts +9 -0
  143. package/documentation/{print-cfg-wiki.js → wiki-cfg.js} +144 -160
  144. package/documentation/wiki-core.d.ts +14 -0
  145. package/documentation/{print-core-wiki.js → wiki-core.js} +164 -175
  146. package/documentation/wiki-dataflow-graph.d.ts +9 -0
  147. package/documentation/{print-dataflow-graph-wiki.js → wiki-dataflow-graph.js} +142 -172
  148. package/documentation/wiki-engine.d.ts +9 -0
  149. package/documentation/{print-engines-wiki.js → wiki-engine.js} +27 -42
  150. package/documentation/wiki-faq.d.ts +8 -0
  151. package/documentation/wiki-faq.js +22 -0
  152. package/documentation/wiki-interface.d.ts +9 -0
  153. package/documentation/{print-interface-wiki.js → wiki-interface.js} +59 -56
  154. package/documentation/wiki-linter.d.ts +9 -0
  155. package/documentation/{print-linter-wiki.js → wiki-linter.js} +52 -48
  156. package/documentation/wiki-linting-and-testing.d.ts +9 -0
  157. package/documentation/{print-linting-and-testing-wiki.js → wiki-linting-and-testing.js} +25 -32
  158. package/documentation/wiki-mk/doc-context.d.ts +186 -0
  159. package/documentation/wiki-mk/doc-context.js +84 -0
  160. package/documentation/wiki-mk/doc-maker.d.ts +95 -0
  161. package/documentation/wiki-mk/doc-maker.js +133 -0
  162. package/documentation/wiki-normalized-ast.d.ts +9 -0
  163. package/documentation/{print-normalized-ast-wiki.js → wiki-normalized-ast.js} +64 -47
  164. package/documentation/wiki-onboarding.d.ts +8 -0
  165. package/documentation/{print-onboarding-wiki.js → wiki-onboarding.js} +18 -15
  166. package/documentation/wiki-query.d.ts +9 -0
  167. package/documentation/{print-query-wiki.js → wiki-query.js} +62 -47
  168. package/documentation/wiki-search.d.ts +9 -0
  169. package/documentation/wiki-search.js +61 -0
  170. package/linter/linter-executor.js +3 -2
  171. package/linter/linter-format.d.ts +2 -2
  172. package/linter/linter-rules.d.ts +13 -17
  173. package/linter/rules/absolute-path.d.ts +1 -2
  174. package/linter/rules/absolute-path.js +2 -2
  175. package/linter/rules/dataframe-access-validation.d.ts +1 -1
  176. package/linter/rules/dataframe-access-validation.js +12 -8
  177. package/linter/rules/dead-code.d.ts +1 -1
  178. package/linter/rules/deprecated-functions.d.ts +1 -5
  179. package/linter/rules/file-path-validity.d.ts +1 -1
  180. package/linter/rules/file-path-validity.js +4 -4
  181. package/linter/rules/function-finder-util.d.ts +1 -5
  182. package/linter/rules/naming-convention.d.ts +2 -2
  183. package/linter/rules/naming-convention.js +1 -1
  184. package/linter/rules/network-functions.d.ts +1 -1
  185. package/linter/rules/network-functions.js +1 -1
  186. package/linter/rules/seeded-randomness.d.ts +3 -2
  187. package/linter/rules/seeded-randomness.js +33 -13
  188. package/linter/rules/unused-definition.d.ts +1 -1
  189. package/linter/rules/useless-loop.d.ts +2 -2
  190. package/linter/rules/useless-loop.js +2 -2
  191. package/package.json +6 -17
  192. package/project/cache/flowr-analyzer-cache.d.ts +7 -10
  193. package/project/cache/flowr-analyzer-cache.js +17 -38
  194. package/project/cache/flowr-analyzer-controlflow-cache.d.ts +34 -0
  195. package/project/cache/flowr-analyzer-controlflow-cache.js +79 -0
  196. package/project/context/flowr-analyzer-context.d.ts +30 -5
  197. package/project/context/flowr-analyzer-context.js +48 -4
  198. package/project/context/flowr-analyzer-files-context.d.ts +63 -13
  199. package/project/context/flowr-analyzer-files-context.js +110 -39
  200. package/project/context/flowr-file.d.ts +32 -10
  201. package/project/context/flowr-file.js +30 -9
  202. package/project/flowr-analyzer-builder.d.ts +22 -28
  203. package/project/flowr-analyzer-builder.js +32 -70
  204. package/project/flowr-analyzer.d.ts +55 -14
  205. package/project/flowr-analyzer.js +53 -8
  206. package/project/plugins/file-plugins/flowr-analyzer-description-file-plugin.d.ts +7 -1
  207. package/project/plugins/file-plugins/flowr-analyzer-description-file-plugin.js +13 -5
  208. package/project/plugins/file-plugins/flowr-analyzer-file-plugin.d.ts +3 -3
  209. package/project/plugins/file-plugins/flowr-analyzer-file-plugin.js +11 -5
  210. package/project/plugins/file-plugins/flowr-description-file.d.ts +3 -3
  211. package/project/plugins/file-plugins/notebooks/flowr-analyzer-jupyter-file-plugin.d.ts +22 -0
  212. package/project/plugins/file-plugins/notebooks/flowr-analyzer-jupyter-file-plugin.js +33 -0
  213. package/project/plugins/file-plugins/notebooks/flowr-analyzer-qmd-file-plugin.d.ts +22 -0
  214. package/project/plugins/file-plugins/notebooks/flowr-analyzer-qmd-file-plugin.js +33 -0
  215. package/project/plugins/file-plugins/notebooks/flowr-analyzer-rmd-file-plugin.d.ts +22 -0
  216. package/project/plugins/file-plugins/notebooks/flowr-analyzer-rmd-file-plugin.js +33 -0
  217. package/project/plugins/file-plugins/notebooks/flowr-jupyter-file.d.ts +20 -0
  218. package/project/plugins/file-plugins/notebooks/flowr-jupyter-file.js +42 -0
  219. package/project/plugins/file-plugins/notebooks/flowr-rmarkdown-file.d.ts +59 -0
  220. package/project/plugins/file-plugins/notebooks/flowr-rmarkdown-file.js +132 -0
  221. package/project/plugins/file-plugins/notebooks/notebook.d.ts +0 -0
  222. package/project/plugins/file-plugins/notebooks/notebook.js +2 -0
  223. package/project/plugins/flowr-analyzer-plugin-defaults.d.ts +5 -0
  224. package/project/plugins/flowr-analyzer-plugin-defaults.js +23 -0
  225. package/project/plugins/flowr-analyzer-plugin.d.ts +2 -0
  226. package/project/plugins/flowr-analyzer-plugin.js +2 -0
  227. package/project/plugins/loading-order-plugins/flowr-analyzer-loading-order-description-file-plugin.js +1 -1
  228. package/project/plugins/package-version-plugins/flowr-analyzer-package-versions-description-file-plugin.js +1 -1
  229. package/project/plugins/plugin-registry.d.ts +34 -0
  230. package/project/plugins/plugin-registry.js +62 -0
  231. package/project/plugins/project-discovery/flowr-analyzer-project-discovery-plugin.js +7 -1
  232. package/queries/catalog/call-context-query/call-context-query-executor.js +4 -2
  233. package/queries/catalog/call-context-query/identify-link-to-last-call-relation.d.ts +5 -2
  234. package/queries/catalog/call-context-query/identify-link-to-last-call-relation.js +25 -18
  235. package/queries/catalog/cluster-query/cluster-query-format.d.ts +1 -1
  236. package/queries/catalog/control-flow-query/control-flow-query-format.d.ts +1 -1
  237. package/queries/catalog/dataflow-lens-query/dataflow-lens-query-format.d.ts +1 -1
  238. package/queries/catalog/dataflow-query/dataflow-query-format.d.ts +1 -1
  239. package/queries/catalog/dependencies-query/dependencies-query-executor.d.ts +1 -1
  240. package/queries/catalog/dependencies-query/dependencies-query-executor.js +1 -1
  241. package/queries/catalog/dependencies-query/dependencies-query-format.d.ts +1 -1
  242. package/queries/catalog/dependencies-query/dependencies-query-format.js +1 -1
  243. package/queries/catalog/df-shape-query/df-shape-query-executor.js +1 -1
  244. package/queries/catalog/df-shape-query/df-shape-query-format.d.ts +2 -2
  245. package/queries/catalog/df-shape-query/df-shape-query-format.js +6 -5
  246. package/queries/catalog/happens-before-query/happens-before-query-executor.d.ts +2 -1
  247. package/queries/catalog/happens-before-query/happens-before-query-executor.js +2 -1
  248. package/queries/catalog/happens-before-query/happens-before-query-format.d.ts +1 -1
  249. package/queries/catalog/id-map-query/id-map-query-format.d.ts +1 -1
  250. package/queries/catalog/inspect-higher-order-query/inspect-higher-order-query-executor.d.ts +1 -1
  251. package/queries/catalog/inspect-higher-order-query/inspect-higher-order-query-executor.js +1 -1
  252. package/queries/catalog/inspect-higher-order-query/inspect-higher-order-query-format.d.ts +1 -1
  253. package/queries/catalog/linter-query/linter-query-format.d.ts +1 -1
  254. package/queries/catalog/linter-query/linter-query-format.js +13 -2
  255. package/queries/catalog/location-map-query/location-map-query-executor.js +2 -1
  256. package/queries/catalog/location-map-query/location-map-query-format.d.ts +1 -1
  257. package/queries/catalog/location-map-query/location-map-query-format.js +1 -1
  258. package/queries/catalog/normalized-ast-query/normalized-ast-query-format.d.ts +1 -1
  259. package/queries/catalog/origin-query/origin-query-format.d.ts +1 -1
  260. package/queries/catalog/project-query/project-query-executor.js +3 -1
  261. package/queries/catalog/project-query/project-query-format.d.ts +1 -1
  262. package/queries/catalog/resolve-value-query/resolve-value-query-executor.d.ts +2 -2
  263. package/queries/catalog/resolve-value-query/resolve-value-query-executor.js +2 -2
  264. package/queries/catalog/resolve-value-query/resolve-value-query-format.d.ts +1 -1
  265. package/queries/catalog/search-query/search-query-format.d.ts +1 -1
  266. package/queries/catalog/static-slice-query/static-slice-query-executor.js +1 -1
  267. package/queries/catalog/static-slice-query/static-slice-query-format.d.ts +1 -1
  268. package/queries/catalog/static-slice-query/static-slice-query-format.js +13 -1
  269. package/queries/query.d.ts +26 -18
  270. package/queries/query.js +21 -1
  271. package/r-bridge/lang-4.x/ast/model/collect.d.ts +2 -1
  272. package/r-bridge/lang-4.x/ast/model/collect.js +4 -0
  273. package/r-bridge/lang-4.x/ast/model/nodes/r-project.d.ts +29 -0
  274. package/r-bridge/lang-4.x/ast/model/nodes/r-project.js +15 -0
  275. package/r-bridge/lang-4.x/ast/model/processing/decorate.d.ts +5 -7
  276. package/r-bridge/lang-4.x/ast/model/processing/decorate.js +24 -11
  277. package/r-bridge/lang-4.x/ast/model/type.d.ts +2 -0
  278. package/r-bridge/lang-4.x/ast/model/type.js +2 -0
  279. package/r-bridge/lang-4.x/ast/parser/json/format.js +1 -1
  280. package/r-bridge/lang-4.x/ast/parser/json/parser.d.ts +9 -8
  281. package/r-bridge/lang-4.x/ast/parser/json/parser.js +11 -10
  282. package/r-bridge/lang-4.x/ast/parser/main/internal/structure/normalize-root.d.ts +4 -3
  283. package/r-bridge/lang-4.x/ast/parser/main/internal/structure/normalize-root.js +20 -11
  284. package/r-bridge/lang-4.x/tree-sitter/tree-sitter-executor.d.ts +3 -3
  285. package/r-bridge/lang-4.x/tree-sitter/tree-sitter-executor.js +5 -4
  286. package/r-bridge/lang-4.x/tree-sitter/tree-sitter-normalize.d.ts +3 -2
  287. package/r-bridge/lang-4.x/tree-sitter/tree-sitter-normalize.js +14 -5
  288. package/r-bridge/parser.d.ts +15 -5
  289. package/r-bridge/parser.js +27 -13
  290. package/r-bridge/retriever.d.ts +9 -15
  291. package/r-bridge/retriever.js +14 -5
  292. package/r-bridge/shell.d.ts +1 -1
  293. package/r-bridge/shell.js +1 -1
  294. package/reconstruct/auto-select/auto-select-defaults.d.ts +0 -1
  295. package/reconstruct/auto-select/magic-comments.js +1 -1
  296. package/reconstruct/reconstruct.d.ts +17 -9
  297. package/reconstruct/reconstruct.js +19 -8
  298. package/search/flowr-search.d.ts +12 -0
  299. package/search/search-executor/search-enrichers.d.ts +9 -2
  300. package/search/search-executor/search-enrichers.js +1 -3
  301. package/search/search-executor/search-generators.d.ts +1 -1
  302. package/search/search-executor/search-generators.js +9 -4
  303. package/slicing/criterion/collect-all.d.ts +3 -2
  304. package/slicing/criterion/collect-all.js +1 -1
  305. package/slicing/criterion/parse.js +4 -4
  306. package/statistics/features/supported/assignments/assignments.js +1 -1
  307. package/statistics/features/supported/control-flow/control-flow.js +1 -1
  308. package/statistics/features/supported/data-access/data-access.js +1 -1
  309. package/statistics/features/supported/defined-functions/defined-functions.js +1 -1
  310. package/statistics/features/supported/expression-list/statistics-expression-list.js +1 -1
  311. package/statistics/features/supported/loops/loops.js +1 -1
  312. package/statistics/features/supported/used-functions/used-functions.js +1 -1
  313. package/statistics/features/supported/variables/variables.js +1 -1
  314. package/statistics/statistics.js +3 -2
  315. package/util/assert.d.ts +4 -0
  316. package/util/assert.js +4 -0
  317. package/util/files.d.ts +1 -1
  318. package/util/files.js +1 -1
  319. package/util/mermaid/ast.d.ts +4 -3
  320. package/util/mermaid/ast.js +36 -8
  321. package/util/mermaid/cfg.js +1 -1
  322. package/util/version.js +1 -1
  323. package/documentation/print-analyzer-wiki.d.ts +0 -1
  324. package/documentation/print-analyzer-wiki.js +0 -141
  325. package/documentation/print-capabilities-markdown.d.ts +0 -1
  326. package/documentation/print-cfg-wiki.d.ts +0 -1
  327. package/documentation/print-core-wiki.d.ts +0 -5
  328. package/documentation/print-dataflow-graph-wiki.d.ts +0 -1
  329. package/documentation/print-engines-wiki.d.ts +0 -1
  330. package/documentation/print-faq-wiki.d.ts +0 -1
  331. package/documentation/print-faq-wiki.js +0 -18
  332. package/documentation/print-interface-wiki.d.ts +0 -1
  333. package/documentation/print-linter-issue.d.ts +0 -1
  334. package/documentation/print-linter-wiki.d.ts +0 -1
  335. package/documentation/print-linting-and-testing-wiki.d.ts +0 -1
  336. package/documentation/print-normalized-ast-wiki.d.ts +0 -1
  337. package/documentation/print-onboarding-wiki.d.ts +0 -1
  338. package/documentation/print-query-wiki.d.ts +0 -1
  339. package/documentation/print-readme.d.ts +0 -1
  340. package/documentation/print-search-wiki.d.ts +0 -1
  341. package/documentation/print-search-wiki.js +0 -74
  342. package/util/formats/adapter-format.d.ts +0 -6
  343. package/util/formats/adapter-format.js +0 -3
  344. package/util/formats/adapter.d.ts +0 -27
  345. package/util/formats/adapter.js +0 -58
  346. package/util/formats/adapters/r-adapter.d.ts +0 -4
  347. package/util/formats/adapters/r-adapter.js +0 -7
  348. package/util/formats/adapters/rmd-adapter.d.ts +0 -35
  349. package/util/formats/adapters/rmd-adapter.js +0 -100
@@ -1,23 +1,23 @@
1
1
  import { type EngineConfig, type FlowrConfigOptions } from '../config';
2
2
  import type { DeepWritable } from 'ts-essentials';
3
- import { fileProtocol, requestFromInput } from '../r-bridge/retriever';
4
3
  import { FlowrAnalyzer } from './flowr-analyzer';
5
4
  import type { KnownParser } from '../r-bridge/parser';
6
5
  import type { FlowrAnalyzerPlugin } from './plugins/flowr-analyzer-plugin';
7
6
  import type { NormalizeRequiredInput } from '../core/steps/all/core/10-normalize';
8
- import type { RAnalysisRequest } from './context/flowr-analyzer-files-context';
7
+ import type { BuiltInFlowrPluginName, PluginToRegister } from './plugins/plugin-registry';
9
8
  /**
10
9
  * Builder for the {@link FlowrAnalyzer}, use it to configure all analysis aspects before creating the analyzer instance
11
10
  * with {@link FlowrAnalyzerBuilder#build|`.build()`} or {@link FlowrAnalyzerBuilder#buildSync|`.buildSync()`}.
12
11
  *
13
- * You can add new files and folders to analyze using the constructor or the {@link FlowrAnalyzerBuilder#add|`.add()`} method.
12
+ * You can add new files and folders to analyze using the {@link FlowrAnalyzer#addRequest|`.addRequest()`} method on the resulting analyzer.
14
13
  * @example Let's create an analyzer for a single R script file:
15
14
  *
16
15
  * ```ts
17
16
  * const analyzer = new FlowrAnalyzerBuilder()
18
- * .add('file:///path/to/script.R')
19
17
  * .setParser(new TreeSitterExecutor())
20
- * .buildSync();
18
+ * .buildSync()
19
+ * .addRequest('file:///path/to/script.R')
20
+ *
21
21
  * ```
22
22
  *
23
23
  * If you now want to get the dataflow information for the file, you can do this:
@@ -26,33 +26,22 @@ import type { RAnalysisRequest } from './context/flowr-analyzer-files-context';
26
26
  * const dfInfo = await analyzer.dataflow();
27
27
  * console.log(dfInfo);
28
28
  * ```
29
+ * @see https://github.com/flowr-analysis/flowr/wiki/Analyzer
29
30
  */
30
31
  export declare class FlowrAnalyzerBuilder {
31
32
  private flowrConfig;
32
33
  private parser?;
33
- private request;
34
34
  private input?;
35
35
  private plugins;
36
36
  /**
37
- * Create a new builder instance.
38
- * @param request - The code to analyze
39
- */
40
- constructor(request?: RAnalysisRequest | readonly RAnalysisRequest[]);
41
- /**
42
- * Add one or multiple requests to analyze.
43
- * This is a convenience method that uses {@link addRequest} and {@link addRequestFromInput} internally.
44
- * @param request - One or multiple requests or a file path (with the `file://` protocol). If you just enter a string, it will be interpreted as R code.
45
- */
46
- add(request: RAnalysisRequest | readonly RAnalysisRequest[] | `${typeof fileProtocol}${string}` | string): this;
47
- /**
48
- * Add one or multiple requests to analyze the builder.
49
- */
50
- addRequest(request: RAnalysisRequest | readonly RAnalysisRequest[]): this;
51
- /**
52
- * Add a request created from the given input.
53
- * This is a convenience method that uses {@link requestFromInput} internally.
37
+ * Creates a new builder for the {@link FlowrAnalyzer}.
38
+ * By default, the standard set of plugins as returned by {@link FlowrAnalyzerPluginDefaults} are registered.
39
+ * @param withDefaultPlugins - Whether to register the default plugins upon creation. Default is `true`.
40
+ * @see {@link FlowrAnalyzerPluginDefaults} - for the default plugin set.
41
+ * @see {@link FlowrAnalyzerBuilder#registerPlugins} - to add more plugins.
42
+ * @see {@link FlowrAnalyzerBuilder#unregisterPlugins} - to remove plugins.
54
43
  */
55
- addRequestFromInput(input: Parameters<typeof requestFromInput>[0]): this;
44
+ constructor(withDefaultPlugins?: boolean);
56
45
  /**
57
46
  * Apply an amendment to the configuration the builder currently holds.
58
47
  * Per default, the {@link defaultConfigOptions} are used.
@@ -79,21 +68,26 @@ export declare class FlowrAnalyzerBuilder {
79
68
  * Additional parameters for the analyses.
80
69
  * @param input - The input.
81
70
  */
82
- setInput(input: Omit<NormalizeRequiredInput, 'request'>): this;
71
+ setInput(input: Omit<NormalizeRequiredInput, 'context'>): this;
83
72
  /**
84
73
  * Register one or multiple additional plugins.
74
+ * For the default plugin set, please refer to {@link FlowrAnalyzerPluginDefaults}, they can be registered
75
+ * by passing `true` to the {@link FlowrAnalyzerBuilder} constructor.
76
+ * @param plugin - One or multiple plugins to register.
85
77
  * @see {@link FlowrAnalyzerBuilder#unregisterPlugins} to remove plugins.
86
78
  */
87
- registerPlugins(...plugin: readonly FlowrAnalyzerPlugin[]): this;
79
+ registerPlugins<T extends BuiltInFlowrPluginName | string>(...plugin: readonly PluginToRegister<T>[]): this;
88
80
  /**
89
81
  * Remove one or multiple plugins.
82
+ * @see {@link FlowrAnalyzerBuilder#registerPlugins} to add plugins.
90
83
  */
91
- unregisterPlugins(...plugin: readonly FlowrAnalyzerPlugin[]): this;
84
+ unregisterPlugins(...plugin: readonly (FlowrAnalyzerPlugin | string | BuiltInFlowrPluginName)[]): this;
92
85
  /**
93
86
  * Create the {@link FlowrAnalyzer} instance using the given information.
94
87
  * Please note that the only reason this is `async` is that if no parser is set,
95
88
  * we need to retrieve the default engine instance which is an async operation.
96
- * If you set the parser using {@link FlowrAnalyzerBuilder#setParser},
89
+ * If you have already initialized the engine (e.g., with {@link TreeSitterExecutor#initTreeSitter}),
90
+ * you can use the synchronous version {@link FlowrAnalyzerBuilder#buildSync} instead.
97
91
  */
98
92
  build(): Promise<FlowrAnalyzer>;
99
93
  /**
@@ -2,25 +2,26 @@
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.FlowrAnalyzerBuilder = void 0;
4
4
  const config_1 = require("../config");
5
- const retriever_1 = require("../r-bridge/retriever");
6
5
  const flowr_analyzer_1 = require("./flowr-analyzer");
7
6
  const engines_1 = require("../engines");
8
7
  const assert_1 = require("../util/assert");
9
- const files_1 = require("../util/files");
10
8
  const flowr_analyzer_context_1 = require("./context/flowr-analyzer-context");
11
9
  const flowr_analyzer_cache_1 = require("./cache/flowr-analyzer-cache");
10
+ const flowr_analyzer_plugin_defaults_1 = require("./plugins/flowr-analyzer-plugin-defaults");
11
+ const plugin_registry_1 = require("./plugins/plugin-registry");
12
12
  /**
13
13
  * Builder for the {@link FlowrAnalyzer}, use it to configure all analysis aspects before creating the analyzer instance
14
14
  * with {@link FlowrAnalyzerBuilder#build|`.build()`} or {@link FlowrAnalyzerBuilder#buildSync|`.buildSync()`}.
15
15
  *
16
- * You can add new files and folders to analyze using the constructor or the {@link FlowrAnalyzerBuilder#add|`.add()`} method.
16
+ * You can add new files and folders to analyze using the {@link FlowrAnalyzer#addRequest|`.addRequest()`} method on the resulting analyzer.
17
17
  * @example Let's create an analyzer for a single R script file:
18
18
  *
19
19
  * ```ts
20
20
  * const analyzer = new FlowrAnalyzerBuilder()
21
- * .add('file:///path/to/script.R')
22
21
  * .setParser(new TreeSitterExecutor())
23
- * .buildSync();
22
+ * .buildSync()
23
+ * .addRequest('file:///path/to/script.R')
24
+ *
24
25
  * ```
25
26
  *
26
27
  * If you now want to get the dataflow information for the file, you can do this:
@@ -29,63 +30,25 @@ const flowr_analyzer_cache_1 = require("./cache/flowr-analyzer-cache");
29
30
  * const dfInfo = await analyzer.dataflow();
30
31
  * console.log(dfInfo);
31
32
  * ```
33
+ * @see https://github.com/flowr-analysis/flowr/wiki/Analyzer
32
34
  */
33
35
  class FlowrAnalyzerBuilder {
34
36
  flowrConfig = (0, config_1.cloneConfig)(config_1.defaultConfigOptions);
35
37
  parser;
36
- request;
37
38
  input;
38
39
  plugins = new Map();
39
40
  /**
40
- * Create a new builder instance.
41
- * @param request - The code to analyze
42
- */
43
- constructor(request) {
44
- this.addRequest(request ?? []);
45
- }
46
- /**
47
- * Add one or multiple requests to analyze.
48
- * This is a convenience method that uses {@link addRequest} and {@link addRequestFromInput} internally.
49
- * @param request - One or multiple requests or a file path (with the `file://` protocol). If you just enter a string, it will be interpreted as R code.
41
+ * Creates a new builder for the {@link FlowrAnalyzer}.
42
+ * By default, the standard set of plugins as returned by {@link FlowrAnalyzerPluginDefaults} are registered.
43
+ * @param withDefaultPlugins - Whether to register the default plugins upon creation. Default is `true`.
44
+ * @see {@link FlowrAnalyzerPluginDefaults} - for the default plugin set.
45
+ * @see {@link FlowrAnalyzerBuilder#registerPlugins} - to add more plugins.
46
+ * @see {@link FlowrAnalyzerBuilder#unregisterPlugins} - to remove plugins.
50
47
  */
51
- add(request) {
52
- if (Array.isArray(request) || (0, retriever_1.isParseRequest)(request)) {
53
- this.addRequest(request);
48
+ constructor(withDefaultPlugins = true) {
49
+ if (withDefaultPlugins) {
50
+ this.registerPlugins(...(0, flowr_analyzer_plugin_defaults_1.FlowrAnalyzerPluginDefaults)());
54
51
  }
55
- else if (typeof request === 'string') {
56
- const trimmed = request.substring(retriever_1.fileProtocol.length);
57
- if (request.startsWith(retriever_1.fileProtocol) && !(0, files_1.isFilePath)(trimmed)) {
58
- this.addRequest({ request: 'project', content: trimmed });
59
- }
60
- else {
61
- this.addRequestFromInput(request);
62
- }
63
- }
64
- else {
65
- this.addRequest(request);
66
- }
67
- return this;
68
- }
69
- /**
70
- * Add one or multiple requests to analyze the builder.
71
- */
72
- addRequest(request) {
73
- const r = Array.isArray(request) ? request : [request];
74
- if (this.request) {
75
- this.request = this.request.concat(request);
76
- }
77
- else {
78
- this.request = r;
79
- }
80
- return this;
81
- }
82
- /**
83
- * Add a request created from the given input.
84
- * This is a convenience method that uses {@link requestFromInput} internally.
85
- */
86
- addRequestFromInput(input) {
87
- this.addRequest((0, retriever_1.requestFromInput)(input));
88
- return this;
89
52
  }
90
53
  /**
91
54
  * Apply an amendment to the configuration the builder currently holds.
@@ -132,28 +95,29 @@ class FlowrAnalyzerBuilder {
132
95
  }
133
96
  /**
134
97
  * Register one or multiple additional plugins.
98
+ * For the default plugin set, please refer to {@link FlowrAnalyzerPluginDefaults}, they can be registered
99
+ * by passing `true` to the {@link FlowrAnalyzerBuilder} constructor.
100
+ * @param plugin - One or multiple plugins to register.
135
101
  * @see {@link FlowrAnalyzerBuilder#unregisterPlugins} to remove plugins.
136
102
  */
137
103
  registerPlugins(...plugin) {
138
104
  for (const p of plugin) {
139
- const g = this.plugins.get(p.type);
140
- if (g === undefined) {
141
- this.plugins.set(p.type, [p]);
142
- }
143
- else {
144
- g.push(p);
145
- }
105
+ const s = (0, plugin_registry_1.makePlugin)(p);
106
+ const g = this.plugins.get(s.type) ?? [];
107
+ g.push(s);
108
+ this.plugins.set(s.type, g);
146
109
  }
147
110
  return this;
148
111
  }
149
112
  /**
150
113
  * Remove one or multiple plugins.
114
+ * @see {@link FlowrAnalyzerBuilder#registerPlugins} to add plugins.
151
115
  */
152
116
  unregisterPlugins(...plugin) {
153
117
  for (const p of plugin) {
154
- const g = this.plugins.get(p.type);
155
- if (g !== undefined) {
156
- this.plugins.set(p.type, g.filter(x => x !== p));
118
+ const name = typeof p === 'string' ? p : p.name;
119
+ for (const [type, plugins] of this.plugins) {
120
+ this.plugins.set(type, plugins.filter((pl) => pl.name !== name));
157
121
  }
158
122
  }
159
123
  return this;
@@ -162,7 +126,8 @@ class FlowrAnalyzerBuilder {
162
126
  * Create the {@link FlowrAnalyzer} instance using the given information.
163
127
  * Please note that the only reason this is `async` is that if no parser is set,
164
128
  * we need to retrieve the default engine instance which is an async operation.
165
- * If you set the parser using {@link FlowrAnalyzerBuilder#setParser},
129
+ * If you have already initialized the engine (e.g., with {@link TreeSitterExecutor#initTreeSitter}),
130
+ * you can use the synchronous version {@link FlowrAnalyzerBuilder#buildSync} instead.
166
131
  */
167
132
  async build() {
168
133
  if (!this.parser) {
@@ -177,16 +142,13 @@ class FlowrAnalyzerBuilder {
177
142
  */
178
143
  buildSync() {
179
144
  (0, assert_1.guard)(this.parser !== undefined, 'No parser set, please use the setParser or setEngine method to set a parser before building the analyzer');
180
- (0, assert_1.guard)(this.request !== undefined, 'Currently we require at least one request to build an analyzer, please provide one using the constructor or the addRequest method');
181
- const context = new flowr_analyzer_context_1.FlowrAnalyzerContext(this.plugins);
145
+ const context = new flowr_analyzer_context_1.FlowrAnalyzerContext(this.flowrConfig, this.plugins);
182
146
  const cache = flowr_analyzer_cache_1.FlowrAnalyzerCache.create({
183
147
  parser: this.parser,
184
- config: this.flowrConfig,
185
- request: context.files.computeLoadingOrder(),
148
+ context,
186
149
  ...(this.input ?? {})
187
150
  });
188
- const analyzer = new flowr_analyzer_1.FlowrAnalyzer(this.flowrConfig, this.parser, context, cache);
189
- analyzer.addRequests(this.request);
151
+ const analyzer = new flowr_analyzer_1.FlowrAnalyzer(this.parser, context, cache);
190
152
  // we do it here to save time later if the analyzer is to be duplicated
191
153
  context.resolvePreAnalysis();
192
154
  return analyzer;
@@ -1,5 +1,5 @@
1
1
  import type { FlowrConfigOptions } from '../config';
2
- import type { KnownParser, KnownParserInformation, ParseStepOutput } from '../r-bridge/parser';
2
+ import type { KnownParser, KnownParserInformation } from '../r-bridge/parser';
3
3
  import { type Queries, type QueryResults, type SupportedQueryTypes } from '../queries/query';
4
4
  import type { ControlFlowInformation } from '../control-flow/control-flow-graph';
5
5
  import type { NormalizedAst } from '../r-bridge/lang-4.x/ast/model/processing/decorate';
@@ -12,10 +12,13 @@ import { type GetSearchElements } from '../search/flowr-search-executor';
12
12
  import type { FlowrAnalyzerContext, ReadOnlyFlowrAnalyzerContext } from './context/flowr-analyzer-context';
13
13
  import { CfgKind } from './cfg-kind';
14
14
  import type { RAnalysisRequest } from './context/flowr-analyzer-files-context';
15
+ import type { RParseRequestFromFile } from '../r-bridge/retriever';
16
+ import { fileProtocol } from '../r-bridge/retriever';
17
+ import type { FlowrFileProvider } from './context/flowr-file';
15
18
  /**
16
19
  * Extends the {@link ReadonlyFlowrAnalysisProvider} with methods that allow modifying the analyzer state.
17
20
  */
18
- export interface FlowrAnalysisProvider extends ReadonlyFlowrAnalysisProvider {
21
+ export interface FlowrAnalysisProvider<Parser extends KnownParser = KnownParser> extends ReadonlyFlowrAnalysisProvider<Parser> {
19
22
  /**
20
23
  * Returns project context information.
21
24
  * If you are a user that wants to inspect the context, prefer {@link inspectContext} instead.
@@ -23,13 +26,18 @@ export interface FlowrAnalysisProvider extends ReadonlyFlowrAnalysisProvider {
23
26
  */
24
27
  context(): FlowrAnalyzerContext;
25
28
  /**
26
- * Add multiple analysis requests to the analyzer instance
29
+ * Add one or multiple requests to analyze.
30
+ * @param request - One or multiple requests or a file path (with the `file://` protocol). If you just enter a string without the {@link fileProtocol}, it will be interpreted as R code.
31
+ * @see {@link FlowrAnalysisProvider.addFile|addFile} - for adding files to the analyzer's context.
27
32
  */
28
- addRequests(requests: readonly RAnalysisRequest[]): void;
33
+ addRequest(...request: (RAnalysisRequest | `${typeof fileProtocol}${string}` | string)[]): void;
29
34
  /**
30
- * Add a single analysis request to the analyzer instance
35
+ * Add one or multiple files to the analyzer's context.
36
+ * @param f - One or multiple file paths, file providers, or parse requests from file.
37
+ * @see {@link FlowrFileProvider} - for creating custom file providers.
38
+ * @see {@link FlowrAnalysisProvider.addRequest|addRequest} - for adding analysis requests to the analyzer.
31
39
  */
32
- addRequest(request: RAnalysisRequest): void;
40
+ addFile(...f: (string | FlowrFileProvider<string> | RParseRequestFromFile)[]): void;
33
41
  /**
34
42
  * Reset the analyzer state, including the context and the cache.
35
43
  */
@@ -39,7 +47,7 @@ export interface FlowrAnalysisProvider extends ReadonlyFlowrAnalysisProvider {
39
47
  * Exposes the central analyses and information provided by the {@link FlowrAnalyzer} to the linter, search, and query APIs.
40
48
  * This allows us to exchange the underlying implementation of the analyzer without affecting the APIs.
41
49
  */
42
- export interface ReadonlyFlowrAnalysisProvider {
50
+ export interface ReadonlyFlowrAnalysisProvider<Parser extends KnownParser = KnownParser> {
43
51
  /**
44
52
  * Returns a set of additional data and helper functions exposed by the underlying {@link KnownParser},
45
53
  * including the parser's {@link BaseParserInformation.name} and corresponding version information.
@@ -55,25 +63,45 @@ export interface ReadonlyFlowrAnalysisProvider {
55
63
  *
56
64
  * The parse result type depends on the {@link KnownParser} used by the analyzer.
57
65
  * @param force - Do not use the cache, instead force a new parse.
66
+ * @see {@link ReadonlyFlowrAnalysisProvider#peekParse} - to get the parse output if already available without triggering a new computation.
58
67
  */
59
- parse(force?: boolean): Promise<ParseStepOutput<Awaited<ReturnType<KnownParser['parse']>>> & PipelinePerStepMetaInformation>;
68
+ parse(force?: boolean): Promise<NonNullable<AnalyzerCacheType<Parser>['parse']>>;
69
+ /**
70
+ * Peek at the parse output for the request, if it was already computed.
71
+ */
72
+ peekParse(): NonNullable<AnalyzerCacheType<Parser>['parse']> | undefined;
60
73
  /**
61
74
  * Get the normalized abstract syntax tree for the request.
62
75
  * @param force - Do not use the cache, instead force new analyses.
76
+ * @see {@link ReadonlyFlowrAnalysisProvider#peekNormalize} - to get the normalized AST if already available without triggering a new computation.
63
77
  */
64
78
  normalize(force?: boolean): Promise<NormalizedAst & PipelinePerStepMetaInformation>;
79
+ /**
80
+ * Peek at the normalized abstract syntax tree for the request, if it was already computed.
81
+ */
82
+ peekNormalize(): NormalizedAst & PipelinePerStepMetaInformation | undefined;
65
83
  /**
66
84
  * Get the dataflow graph for the request.
67
85
  * @param force - Do not use the cache, instead force new analyses.
86
+ * @see {@link ReadonlyFlowrAnalysisProvider#peekDataflow} - to get the dataflow graph if already available without triggering a new computation.
68
87
  */
69
88
  dataflow(force?: boolean): Promise<DataflowInformation & PipelinePerStepMetaInformation>;
89
+ /**
90
+ * Peek at the dataflow graph for the request, if it was already computed.
91
+ */
92
+ peekDataflow(): DataflowInformation & PipelinePerStepMetaInformation | undefined;
70
93
  /**
71
94
  * Get the control flow graph (CFG) for the request.
72
95
  * @param simplifications - Simplification passes to be applied to the CFG.
73
96
  * @param kind - The kind of CFG that is requested. By default, the CFG without dataflow information is returned.
74
97
  * @param force - Do not use the cache, instead force new analyses.
98
+ * @see {@link ReadonlyFlowrAnalysisProvider#peekControlflow} - to get the CFG if already available without triggering a new computation.
75
99
  */
76
100
  controlflow(simplifications?: readonly CfgSimplificationPassName[], kind?: CfgKind, force?: boolean): Promise<ControlFlowInformation>;
101
+ /**
102
+ * Peek at the control flow graph (CFG) for the request, if it was already computed.
103
+ */
104
+ peekControlflow(simplifications?: readonly CfgSimplificationPassName[], kind?: CfgKind): ControlFlowInformation | undefined;
77
105
  /**
78
106
  * Access the query API for the request.
79
107
  * @param query - The list of queries.
@@ -97,9 +125,9 @@ export interface ReadonlyFlowrAnalysisProvider {
97
125
  * If you want the original pattern of creating a pipeline and running all steps, you can still do this with {@link FlowrAnalyzer#runFull}.
98
126
  *
99
127
  * To inspect the context of the analyzer, use {@link FlowrAnalyzer#inspectContext} (if you are a plugin and need to modify it, use {@link FlowrAnalyzer#context} instead).
128
+ * @see https://github.com/flowr-analysis/flowr/wiki/Analyzer
100
129
  */
101
- export declare class FlowrAnalyzer<Parser extends KnownParser = KnownParser> implements ReadonlyFlowrAnalysisProvider {
102
- readonly flowrConfig: FlowrConfigOptions;
130
+ export declare class FlowrAnalyzer<Parser extends KnownParser = KnownParser> implements ReadonlyFlowrAnalysisProvider<Parser> {
103
131
  /** The parser and engine backend */
104
132
  private readonly parser;
105
133
  /** The cache used for storing analysis results */
@@ -109,23 +137,36 @@ export declare class FlowrAnalyzer<Parser extends KnownParser = KnownParser> imp
109
137
  /**
110
138
  * Create a new analyzer instance.
111
139
  * **Prefer the use of the {@link FlowrAnalyzerBuilder} instead of calling this constructor directly.**
112
- * @param config - The FlowR config to use for the analyses
113
140
  * @param parser - The parser to use for parsing the given request.
114
141
  * @param ctx - The context to use for the analyses.
115
142
  * @param cache - The caching layer to use for storing analysis results.
116
143
  */
117
- constructor(config: FlowrConfigOptions, parser: Parser, ctx: FlowrAnalyzerContext, cache: FlowrAnalyzerCache<Parser>);
144
+ constructor(parser: Parser, ctx: FlowrAnalyzerContext, cache: FlowrAnalyzerCache<Parser>);
145
+ get flowrConfig(): FlowrConfigOptions;
118
146
  context(): FlowrAnalyzerContext;
119
147
  parserInformation(): KnownParserInformation;
120
148
  inspectContext(): ReadOnlyFlowrAnalyzerContext;
121
149
  reset(): void;
122
- addRequests(requests: readonly RAnalysisRequest[]): void;
123
- addRequest(request: RAnalysisRequest): void;
150
+ addRequest(...request: (RAnalysisRequest | readonly RAnalysisRequest[] | `${typeof fileProtocol}${string}` | string)[]): this;
151
+ addFile(...f: (string | FlowrFileProvider | RParseRequestFromFile)[]): this;
152
+ /**
153
+ * Add a request created from the given input.
154
+ * This is a convenience method that uses {@link requestFromInput} internally.
155
+ */
156
+ private addRequestFromInput;
157
+ /**
158
+ * Add one or multiple requests to analyze the builder.
159
+ */
160
+ private addAnalysisRequest;
124
161
  parse(force?: boolean): Promise<NonNullable<AnalyzerCacheType<Parser>['parse']>>;
162
+ peekParse(): NonNullable<AnalyzerCacheType<Parser>['parse']> | undefined;
125
163
  normalize(force?: boolean): Promise<NonNullable<AnalyzerCacheType<Parser>['normalize']>>;
164
+ peekNormalize(): NonNullable<AnalyzerCacheType<Parser>['normalize']> | undefined;
126
165
  dataflow(force?: boolean): Promise<NonNullable<AnalyzerCacheType<Parser>['dataflow']>>;
166
+ peekDataflow(): NonNullable<AnalyzerCacheType<Parser>['dataflow']> | undefined;
127
167
  runFull(force?: boolean): Promise<void>;
128
168
  controlflow(simplifications?: readonly CfgSimplificationPassName[], kind?: CfgKind, force?: boolean): Promise<ControlFlowInformation>;
169
+ peekControlflow(simplifications?: readonly CfgSimplificationPassName[], kind?: CfgKind): ControlFlowInformation | undefined;
129
170
  query<Types extends SupportedQueryTypes = SupportedQueryTypes>(query: Queries<Types>): Promise<QueryResults<Types>>;
130
171
  runSearch<Search extends FlowrSearchLike>(search: Search): Promise<GetSearchElements<SearchOutput<Search>>>;
131
172
  /**
@@ -4,6 +4,8 @@ exports.FlowrAnalyzer = void 0;
4
4
  const query_1 = require("../queries/query");
5
5
  const flowr_search_executor_1 = require("../search/flowr-search-executor");
6
6
  const cfg_kind_1 = require("./cfg-kind");
7
+ const retriever_1 = require("../r-bridge/retriever");
8
+ const files_1 = require("../util/files");
7
9
  /**
8
10
  * Central class for conducting analyses with FlowR.
9
11
  * Use the {@link FlowrAnalyzerBuilder} to create a new instance.
@@ -11,9 +13,9 @@ const cfg_kind_1 = require("./cfg-kind");
11
13
  * If you want the original pattern of creating a pipeline and running all steps, you can still do this with {@link FlowrAnalyzer#runFull}.
12
14
  *
13
15
  * To inspect the context of the analyzer, use {@link FlowrAnalyzer#inspectContext} (if you are a plugin and need to modify it, use {@link FlowrAnalyzer#context} instead).
16
+ * @see https://github.com/flowr-analysis/flowr/wiki/Analyzer
14
17
  */
15
18
  class FlowrAnalyzer {
16
- flowrConfig;
17
19
  /** The parser and engine backend */
18
20
  parser;
19
21
  /** The cache used for storing analysis results */
@@ -23,17 +25,18 @@ class FlowrAnalyzer {
23
25
  /**
24
26
  * Create a new analyzer instance.
25
27
  * **Prefer the use of the {@link FlowrAnalyzerBuilder} instead of calling this constructor directly.**
26
- * @param config - The FlowR config to use for the analyses
27
28
  * @param parser - The parser to use for parsing the given request.
28
29
  * @param ctx - The context to use for the analyses.
29
30
  * @param cache - The caching layer to use for storing analysis results.
30
31
  */
31
- constructor(config, parser, ctx, cache) {
32
- this.flowrConfig = config;
32
+ constructor(parser, ctx, cache) {
33
33
  this.parser = parser;
34
34
  this.ctx = ctx;
35
35
  this.cache = cache;
36
36
  }
37
+ get flowrConfig() {
38
+ return this.ctx.config;
39
+ }
37
40
  context() {
38
41
  return this.ctx;
39
42
  }
@@ -48,21 +51,60 @@ class FlowrAnalyzer {
48
51
  this.ctx.reset();
49
52
  this.cache.reset();
50
53
  }
51
- addRequests(requests) {
52
- this.ctx.addRequests(requests);
54
+ addRequest(...request) {
55
+ for (const r of request) {
56
+ if (typeof r === 'string') {
57
+ const trimmed = r.substring(retriever_1.fileProtocol.length);
58
+ if (r.startsWith(retriever_1.fileProtocol) && !(0, files_1.isFilePath)(trimmed)) {
59
+ this.addAnalysisRequest({ request: 'project', content: trimmed });
60
+ }
61
+ else {
62
+ this.addRequestFromInput(r);
63
+ }
64
+ }
65
+ else {
66
+ this.addAnalysisRequest(r);
67
+ }
68
+ }
69
+ return this;
70
+ }
71
+ addFile(...f) {
72
+ this.ctx.addFiles(f);
73
+ return this;
53
74
  }
54
- addRequest(request) {
55
- this.ctx.addRequest(request);
75
+ /**
76
+ * Add a request created from the given input.
77
+ * This is a convenience method that uses {@link requestFromInput} internally.
78
+ */
79
+ addRequestFromInput(input) {
80
+ this.addAnalysisRequest((0, retriever_1.requestFromInput)(input));
81
+ return this;
82
+ }
83
+ /**
84
+ * Add one or multiple requests to analyze the builder.
85
+ */
86
+ addAnalysisRequest(request) {
87
+ this.ctx.addRequests((Array.isArray(request) ? request : [request]));
88
+ return this;
56
89
  }
57
90
  async parse(force) {
58
91
  return this.cache.parse(force);
59
92
  }
93
+ peekParse() {
94
+ return this.cache.peekParse();
95
+ }
60
96
  async normalize(force) {
61
97
  return this.cache.normalize(force);
62
98
  }
99
+ peekNormalize() {
100
+ return this.cache.peekNormalize();
101
+ }
63
102
  async dataflow(force) {
64
103
  return this.cache.dataflow(force);
65
104
  }
105
+ peekDataflow() {
106
+ return this.cache.peekDataflow();
107
+ }
66
108
  async runFull(force) {
67
109
  await this.dataflow(force);
68
110
  return;
@@ -70,6 +112,9 @@ class FlowrAnalyzer {
70
112
  async controlflow(simplifications, kind, force) {
71
113
  return this.cache.controlflow(force, kind ?? cfg_kind_1.CfgKind.NoDataflow, simplifications);
72
114
  }
115
+ peekControlflow(simplifications, kind) {
116
+ return this.cache.peekControlflow(kind ?? cfg_kind_1.CfgKind.NoDataflow, simplifications);
117
+ }
73
118
  async query(query) {
74
119
  return (0, query_1.executeQueries)({ analyzer: this }, query);
75
120
  }
@@ -12,6 +12,12 @@ export declare class FlowrAnalyzerDescriptionFilePlugin extends FlowrAnalyzerFil
12
12
  readonly name = "flowr-analyzer-description-file-plugin";
13
13
  readonly description = "This plugin provides support for DESCRIPTION files and extracts their content into key-value(s) pairs.";
14
14
  readonly version: SemVer;
15
+ private readonly pattern;
16
+ /**
17
+ * Creates a new instance of the DESCRIPTION file plugin.
18
+ * @param filePattern - The pattern to identify DESCRIPTION files, see {@link DescriptionFilePattern} for the default pattern.
19
+ */
20
+ constructor(filePattern?: RegExp);
15
21
  applies(file: PathLike): boolean;
16
- process(_ctx: FlowrAnalyzerContext, file: FlowrFileProvider<string>): FlowrDescriptionFile;
22
+ process(_ctx: FlowrAnalyzerContext, file: FlowrFileProvider): FlowrDescriptionFile;
17
23
  }
@@ -6,7 +6,9 @@ const semver_1 = require("semver");
6
6
  const log_1 = require("../../../util/log");
7
7
  const flowr_description_file_1 = require("./flowr-description-file");
8
8
  const flowr_file_1 = require("../../context/flowr-file");
9
+ const built_in_source_1 = require("../../../dataflow/internal/process/functions/call/built-in/built-in-source");
9
10
  exports.descriptionFileLog = log_1.log.getSubLogger({ name: 'flowr-analyzer-loading-order-description-file-plugin' });
11
+ const DescriptionFilePattern = /^(DESCRIPTION|DESCRIPTION\.txt)$/i;
10
12
  /**
11
13
  * This plugin provides support for R `DESCRIPTION` files.
12
14
  */
@@ -14,14 +16,20 @@ class FlowrAnalyzerDescriptionFilePlugin extends flowr_analyzer_file_plugin_1.Fl
14
16
  name = 'flowr-analyzer-description-file-plugin';
15
17
  description = 'This plugin provides support for DESCRIPTION files and extracts their content into key-value(s) pairs.';
16
18
  version = new semver_1.SemVer('0.1.0');
19
+ pattern;
20
+ /**
21
+ * Creates a new instance of the DESCRIPTION file plugin.
22
+ * @param filePattern - The pattern to identify DESCRIPTION files, see {@link DescriptionFilePattern} for the default pattern.
23
+ */
24
+ constructor(filePattern = DescriptionFilePattern) {
25
+ super();
26
+ this.pattern = filePattern;
27
+ }
17
28
  applies(file) {
18
- return /^(DESCRIPTION|DESCRIPTION\.txt)$/i.test(file.toString().split(/[/\\]/).pop() ?? '');
29
+ return this.pattern.test((0, built_in_source_1.platformBasename)(file.toString()));
19
30
  }
20
31
  process(_ctx, file) {
21
- const f = flowr_description_file_1.FlowrDescriptionFile.from(file, flowr_file_1.SpecialFileRole.Description);
22
- // already load it here
23
- f.content();
24
- return f;
32
+ return flowr_description_file_1.FlowrDescriptionFile.from(file, flowr_file_1.FileRole.Description);
25
33
  }
26
34
  }
27
35
  exports.FlowrAnalyzerDescriptionFilePlugin = FlowrAnalyzerDescriptionFilePlugin;
@@ -4,14 +4,14 @@ import type { FlowrFileProvider } from '../../context/flowr-file';
4
4
  /**
5
5
  * This is the base class for all plugins that load and possibly transform files when they are loaded.
6
6
  * Different from other plugins, these plugins trigger for each file that is loaded (if they {@link applies} to the file).
7
- * See the {@link FlowrAnalyzerFilesContext.addFile} for more information on how files are loaded and managed.
7
+ * See the {@link FlowrAnalyzer.addFile} for more information on how files are loaded and managed.
8
8
  *
9
- * It is upt to the construction to ensure that no two file plugins {@link applies} to the same file, otherwise, the loading order
9
+ * It is up to the construction to ensure that no two file plugins {@link applies} to the same file, otherwise, the loading order
10
10
  * of these plugins will determine which plugin gets to process the file.
11
11
  *
12
12
  * See {@link DefaultFlowrAnalyzerFilePlugin} for the no-op default implementation.
13
13
  */
14
- export declare abstract class FlowrAnalyzerFilePlugin extends FlowrAnalyzerPlugin<FlowrFileProvider<string>, FlowrFileProvider> {
14
+ export declare abstract class FlowrAnalyzerFilePlugin extends FlowrAnalyzerPlugin<FlowrFileProvider, FlowrFileProvider> {
15
15
  readonly type = PluginType.FileLoad;
16
16
  /**
17
17
  * Determine whether this plugin applies to the given file.