@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
@@ -2,13 +2,14 @@
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.FlowrAnalyzerFilePlugin = void 0;
4
4
  const flowr_analyzer_plugin_1 = require("../flowr-analyzer-plugin");
5
+ const flowr_file_1 = require("../../context/flowr-file");
5
6
  const semver_1 = require("semver");
6
7
  /**
7
8
  * This is the base class for all plugins that load and possibly transform files when they are loaded.
8
9
  * Different from other plugins, these plugins trigger for each file that is loaded (if they {@link applies} to the file).
9
- * See the {@link FlowrAnalyzerFilesContext.addFile} for more information on how files are loaded and managed.
10
+ * See the {@link FlowrAnalyzer.addFile} for more information on how files are loaded and managed.
10
11
  *
11
- * It is upt to the construction to ensure that no two file plugins {@link applies} to the same file, otherwise, the loading order
12
+ * It is up to the construction to ensure that no two file plugins {@link applies} to the same file, otherwise, the loading order
12
13
  * of these plugins will determine which plugin gets to process the file.
13
14
  *
14
15
  * See {@link DefaultFlowrAnalyzerFilePlugin} for the no-op default implementation.
@@ -22,13 +23,18 @@ class FlowrAnalyzerFilePlugin extends flowr_analyzer_plugin_1.FlowrAnalyzerPlugi
22
23
  exports.FlowrAnalyzerFilePlugin = FlowrAnalyzerFilePlugin;
23
24
  class DefaultFlowrAnalyzerFilePlugin extends FlowrAnalyzerFilePlugin {
24
25
  name = 'default-file-plugin';
25
- description = 'This is the default file plugin that does nothing.';
26
+ description = 'This is the default file plugin that does nothing (but assigning default .r/.R files).';
26
27
  version = new semver_1.SemVer('0.0.0');
27
28
  applies() {
28
29
  return true;
29
30
  }
30
- process(_context, args) {
31
- return args;
31
+ process(_ctx, arg) {
32
+ const path = arg.path().toString();
33
+ if (/\.r$/i.test(path)) {
34
+ // we just assign the role :D
35
+ arg.assignRole(flowr_file_1.FileRole.Source);
36
+ }
37
+ return arg;
32
38
  }
33
39
  }
34
40
  //# sourceMappingURL=flowr-analyzer-file-plugin.js.map
@@ -1,4 +1,4 @@
1
- import { type FlowrFileProvider, type SpecialFileRole, FlowrFile } from '../../context/flowr-file';
1
+ import { type FlowrFileProvider, type FileRole, FlowrFile } from '../../context/flowr-file';
2
2
  export type DCF = Map<string, string[]>;
3
3
  /**
4
4
  * This decorates a text file and provides access to its content as a DCF (Debian Control File)-like structure.
@@ -9,7 +9,7 @@ export declare class FlowrDescriptionFile extends FlowrFile<DCF> {
9
9
  * Prefer the static {@link FlowrDescriptionFile.from} method to create instances of this class as it will not re-create if already a description file
10
10
  * and handle role assignments.
11
11
  */
12
- constructor(file: FlowrFileProvider<string>);
12
+ constructor(file: FlowrFileProvider);
13
13
  /**
14
14
  * Loads and parses the content of the wrapped file as a DCF structure.
15
15
  * @see {@link parseDCF} for details on the parsing logic.
@@ -18,5 +18,5 @@ export declare class FlowrDescriptionFile extends FlowrFile<DCF> {
18
18
  /**
19
19
  * Description file lifter, this does not re-create if already a description file
20
20
  */
21
- static from(file: FlowrFileProvider<string> | FlowrDescriptionFile, role?: SpecialFileRole): FlowrDescriptionFile;
21
+ static from(file: FlowrFileProvider | FlowrDescriptionFile, role?: FileRole): FlowrDescriptionFile;
22
22
  }
@@ -0,0 +1,22 @@
1
+ import type { PathLike } from 'fs';
2
+ import { SemVer } from 'semver';
3
+ import type { FlowrAnalyzerContext } from '../../../context/flowr-analyzer-context';
4
+ import type { FlowrFileProvider } from '../../../context/flowr-file';
5
+ import { FlowrAnalyzerFilePlugin } from '../flowr-analyzer-file-plugin';
6
+ import { FlowrJupyterFile } from './flowr-jupyter-file';
7
+ /**
8
+ * The plugin provides support for Jupyter (`.ipynb`) files
9
+ */
10
+ export declare class FlowrAnalyzerJupyterFilePlugin extends FlowrAnalyzerFilePlugin {
11
+ readonly name = "ipynb-file-plugin";
12
+ readonly description = "Parses Jupyter files";
13
+ readonly version: SemVer;
14
+ private readonly pattern;
15
+ /**
16
+ * Creates a new instance of the Jupyter file plugin.
17
+ * @param filePattern - The pattern to identify Jupyter files, see {@link IpynbPattern} for the default pattern.
18
+ */
19
+ constructor(filePattern?: RegExp);
20
+ applies(file: PathLike): boolean;
21
+ protected process(_ctx: FlowrAnalyzerContext, arg: FlowrFileProvider<string>): FlowrJupyterFile;
22
+ }
@@ -0,0 +1,33 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.FlowrAnalyzerJupyterFilePlugin = void 0;
4
+ const semver_1 = require("semver");
5
+ const flowr_analyzer_file_plugin_1 = require("../flowr-analyzer-file-plugin");
6
+ const built_in_source_1 = require("../../../../dataflow/internal/process/functions/call/built-in/built-in-source");
7
+ const flowr_jupyter_file_1 = require("./flowr-jupyter-file");
8
+ const IpynbPattern = /\.ipynb$/i;
9
+ /**
10
+ * The plugin provides support for Jupyter (`.ipynb`) files
11
+ */
12
+ class FlowrAnalyzerJupyterFilePlugin extends flowr_analyzer_file_plugin_1.FlowrAnalyzerFilePlugin {
13
+ name = 'ipynb-file-plugin';
14
+ description = 'Parses Jupyter files';
15
+ version = new semver_1.SemVer('0.1.0');
16
+ pattern;
17
+ /**
18
+ * Creates a new instance of the Jupyter file plugin.
19
+ * @param filePattern - The pattern to identify Jupyter files, see {@link IpynbPattern} for the default pattern.
20
+ */
21
+ constructor(filePattern = IpynbPattern) {
22
+ super();
23
+ this.pattern = filePattern;
24
+ }
25
+ applies(file) {
26
+ return this.pattern.test((0, built_in_source_1.platformBasename)(file.toString()));
27
+ }
28
+ process(_ctx, arg) {
29
+ return flowr_jupyter_file_1.FlowrJupyterFile.from(arg);
30
+ }
31
+ }
32
+ exports.FlowrAnalyzerJupyterFilePlugin = FlowrAnalyzerJupyterFilePlugin;
33
+ //# sourceMappingURL=flowr-analyzer-jupyter-file-plugin.js.map
@@ -0,0 +1,22 @@
1
+ import type { PathLike } from 'fs';
2
+ import { SemVer } from 'semver';
3
+ import type { FlowrAnalyzerContext } from '../../../context/flowr-analyzer-context';
4
+ import type { FlowrFileProvider } from '../../../context/flowr-file';
5
+ import { FlowrAnalyzerFilePlugin } from '../flowr-analyzer-file-plugin';
6
+ import { FlowrRMarkdownFile } from './flowr-rmarkdown-file';
7
+ /**
8
+ * The plugin provides support for Quarto R Markdown (`.qmd`) files
9
+ */
10
+ export declare class FlowrAnalyzerQmdFilePlugin extends FlowrAnalyzerFilePlugin {
11
+ readonly name = "qmd-file-plugin";
12
+ readonly description = "Parses Quarto R Markdown files";
13
+ readonly version: SemVer;
14
+ private readonly pattern;
15
+ /**
16
+ * Creates a new instance of the Quarto R Markdown file plugin.
17
+ * @param filePattern - The pattern to identify Quarto R Markdown files, see {@link QmdPattern} for the default pattern.
18
+ */
19
+ constructor(filePattern?: RegExp);
20
+ applies(file: PathLike): boolean;
21
+ protected process(_ctx: FlowrAnalyzerContext, arg: FlowrFileProvider<string>): FlowrRMarkdownFile;
22
+ }
@@ -0,0 +1,33 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.FlowrAnalyzerQmdFilePlugin = void 0;
4
+ const semver_1 = require("semver");
5
+ const flowr_analyzer_file_plugin_1 = require("../flowr-analyzer-file-plugin");
6
+ const flowr_rmarkdown_file_1 = require("./flowr-rmarkdown-file");
7
+ const built_in_source_1 = require("../../../../dataflow/internal/process/functions/call/built-in/built-in-source");
8
+ const QmdPattern = /\.qmd$/i;
9
+ /**
10
+ * The plugin provides support for Quarto R Markdown (`.qmd`) files
11
+ */
12
+ class FlowrAnalyzerQmdFilePlugin extends flowr_analyzer_file_plugin_1.FlowrAnalyzerFilePlugin {
13
+ name = 'qmd-file-plugin';
14
+ description = 'Parses Quarto R Markdown files';
15
+ version = new semver_1.SemVer('0.1.0');
16
+ pattern;
17
+ /**
18
+ * Creates a new instance of the Quarto R Markdown file plugin.
19
+ * @param filePattern - The pattern to identify Quarto R Markdown files, see {@link QmdPattern} for the default pattern.
20
+ */
21
+ constructor(filePattern = QmdPattern) {
22
+ super();
23
+ this.pattern = filePattern;
24
+ }
25
+ applies(file) {
26
+ return this.pattern.test((0, built_in_source_1.platformBasename)(file.toString()));
27
+ }
28
+ process(_ctx, arg) {
29
+ return flowr_rmarkdown_file_1.FlowrRMarkdownFile.from(arg);
30
+ }
31
+ }
32
+ exports.FlowrAnalyzerQmdFilePlugin = FlowrAnalyzerQmdFilePlugin;
33
+ //# sourceMappingURL=flowr-analyzer-qmd-file-plugin.js.map
@@ -0,0 +1,22 @@
1
+ import type { PathLike } from 'fs';
2
+ import { SemVer } from 'semver';
3
+ import type { FlowrAnalyzerContext } from '../../../context/flowr-analyzer-context';
4
+ import { type FlowrFileProvider } from '../../../context/flowr-file';
5
+ import { FlowrAnalyzerFilePlugin } from '../flowr-analyzer-file-plugin';
6
+ import { FlowrRMarkdownFile } from './flowr-rmarkdown-file';
7
+ /**
8
+ * The plugin provides support for R Markdown (`.rmd`) files
9
+ */
10
+ export declare class FlowrAnalyzerRmdFilePlugin extends FlowrAnalyzerFilePlugin {
11
+ readonly name = "rmd-file-plugin";
12
+ readonly description = "Parses R Markdown files";
13
+ readonly version: SemVer;
14
+ private readonly pattern;
15
+ /**
16
+ * Creates a new instance of the R Markdown file plugin.
17
+ * @param filePattern - The pattern to identify R Markdown files, see {@link RmdPattern} for the default pattern.
18
+ */
19
+ constructor(filePattern?: RegExp);
20
+ applies(file: PathLike): boolean;
21
+ protected process(_ctx: FlowrAnalyzerContext, arg: FlowrFileProvider<string>): FlowrRMarkdownFile;
22
+ }
@@ -0,0 +1,33 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.FlowrAnalyzerRmdFilePlugin = void 0;
4
+ const semver_1 = require("semver");
5
+ const flowr_analyzer_file_plugin_1 = require("../flowr-analyzer-file-plugin");
6
+ const flowr_rmarkdown_file_1 = require("./flowr-rmarkdown-file");
7
+ const built_in_source_1 = require("../../../../dataflow/internal/process/functions/call/built-in/built-in-source");
8
+ const RmdPattern = /\.rmd$/i;
9
+ /**
10
+ * The plugin provides support for R Markdown (`.rmd`) files
11
+ */
12
+ class FlowrAnalyzerRmdFilePlugin extends flowr_analyzer_file_plugin_1.FlowrAnalyzerFilePlugin {
13
+ name = 'rmd-file-plugin';
14
+ description = 'Parses R Markdown files';
15
+ version = new semver_1.SemVer('0.1.0');
16
+ pattern;
17
+ /**
18
+ * Creates a new instance of the R Markdown file plugin.
19
+ * @param filePattern - The pattern to identify R Markdown files, see {@link RmdPattern} for the default pattern.
20
+ */
21
+ constructor(filePattern = RmdPattern) {
22
+ super();
23
+ this.pattern = filePattern;
24
+ }
25
+ applies(file) {
26
+ return this.pattern.test((0, built_in_source_1.platformBasename)(file.toString()));
27
+ }
28
+ process(_ctx, arg) {
29
+ return flowr_rmarkdown_file_1.FlowrRMarkdownFile.from(arg);
30
+ }
31
+ }
32
+ exports.FlowrAnalyzerRmdFilePlugin = FlowrAnalyzerRmdFilePlugin;
33
+ //# sourceMappingURL=flowr-analyzer-rmd-file-plugin.js.map
@@ -0,0 +1,20 @@
1
+ import type { FlowrFileProvider } from '../../../context/flowr-file';
2
+ import { FlowrFile } from '../../../context/flowr-file';
3
+ /**
4
+ * This decorates a text file and parses its contents as a Jupyter file.
5
+ * Finnaly, it provides access to the single cells, and all cells fused together as one R file.
6
+ */
7
+ export declare class FlowrJupyterFile extends FlowrFile<string> {
8
+ private readonly wrapped;
9
+ /**
10
+ * Prefer the static {@link FlowrRMarkdownFile.from} method
11
+ * @param file - the file to load as R Markdown
12
+ */
13
+ constructor(file: FlowrFileProvider<string>);
14
+ /**
15
+ * Loads and parses the content of the wrapped file.
16
+ * @returns RmdInfo
17
+ */
18
+ protected loadContent(): string;
19
+ static from(file: FlowrFileProvider<string> | FlowrJupyterFile): FlowrJupyterFile;
20
+ }
@@ -0,0 +1,42 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.FlowrJupyterFile = void 0;
4
+ const flowr_file_1 = require("../../../context/flowr-file");
5
+ /**
6
+ * This decorates a text file and parses its contents as a Jupyter file.
7
+ * Finnaly, it provides access to the single cells, and all cells fused together as one R file.
8
+ */
9
+ class FlowrJupyterFile extends flowr_file_1.FlowrFile {
10
+ wrapped;
11
+ /**
12
+ * Prefer the static {@link FlowrRMarkdownFile.from} method
13
+ * @param file - the file to load as R Markdown
14
+ */
15
+ constructor(file) {
16
+ super(file.path(), flowr_file_1.FileRole.Source);
17
+ this.wrapped = file;
18
+ }
19
+ /**
20
+ * Loads and parses the content of the wrapped file.
21
+ * @returns RmdInfo
22
+ */
23
+ loadContent() {
24
+ return loadJupyter(this.wrapped.content());
25
+ }
26
+ static from(file) {
27
+ return file instanceof FlowrJupyterFile ? file : new FlowrJupyterFile(file);
28
+ }
29
+ }
30
+ exports.FlowrJupyterFile = FlowrJupyterFile;
31
+ function loadJupyter(content) {
32
+ const nb = JSON.parse(content);
33
+ return nb.cells.map(cell => {
34
+ if (cell.cell_type === 'code') {
35
+ return typeof cell.source === 'object' ? cell.source.join('') : cell.source;
36
+ }
37
+ else {
38
+ return typeof cell.source === 'object' ? cell.source.map(s => `# ${s}`).join('') : `# ${cell.source}`;
39
+ }
40
+ }).join('\n');
41
+ }
42
+ //# sourceMappingURL=flowr-jupyter-file.js.map
@@ -0,0 +1,59 @@
1
+ import type { FlowrFileProvider } from '../../../context/flowr-file';
2
+ import { FlowrFile } from '../../../context/flowr-file';
3
+ import { type Node } from 'commonmark';
4
+ /**
5
+ * This decorates a text file and parses its contents as a R Markdown file.
6
+ * Finnaly, it provides access to the single cells, and all cells fused together as one R file.
7
+ */
8
+ export declare class FlowrRMarkdownFile extends FlowrFile<string> {
9
+ private data?;
10
+ private readonly wrapped;
11
+ /**
12
+ * Prefer the static {@link FlowrRMarkdownFile.from} method
13
+ * @param file - the file to load as R Markdown
14
+ */
15
+ constructor(file: FlowrFileProvider<string>);
16
+ get rmd(): RmdInfo;
17
+ /**
18
+ * Loads and parses the content of the wrapped file.
19
+ * @returns RmdInfo
20
+ */
21
+ protected loadContent(): string;
22
+ static from(file: FlowrFileProvider<string> | FlowrRMarkdownFile): FlowrRMarkdownFile;
23
+ }
24
+ export interface CodeBlock {
25
+ options: string;
26
+ code: string;
27
+ }
28
+ export type CodeBlockEx = CodeBlock & {
29
+ startpos: {
30
+ line: number;
31
+ col: number;
32
+ };
33
+ };
34
+ export interface RmdInfo {
35
+ content: string;
36
+ blocks: CodeBlock[];
37
+ options: object;
38
+ }
39
+ /**
40
+ * Parse the contents of a RMarkdown file into complete code and blocks
41
+ * @param raw - the raw file content
42
+ * @returns Rmd Info
43
+ */
44
+ export declare function parseRMarkdownFile(raw: string): RmdInfo;
45
+ /**
46
+ * Checks whether a CommonMark node is an R code block
47
+ */
48
+ export declare function isRCodeBlock(node: Node): node is Node & {
49
+ literal: string;
50
+ info: string;
51
+ };
52
+ /**
53
+ * Restores an Rmd file from code blocks, filling non-code lines with empty lines
54
+ */
55
+ export declare function restoreBlocksWithoutMd(blocks: CodeBlockEx[], totalLines: number): string;
56
+ /**
57
+ * Parses the options of an R code block from its header and content
58
+ */
59
+ export declare function parseCodeBlockOptions(header: string, content: string): string;
@@ -0,0 +1,132 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ exports.FlowrRMarkdownFile = void 0;
7
+ exports.parseRMarkdownFile = parseRMarkdownFile;
8
+ exports.isRCodeBlock = isRCodeBlock;
9
+ exports.restoreBlocksWithoutMd = restoreBlocksWithoutMd;
10
+ exports.parseCodeBlockOptions = parseCodeBlockOptions;
11
+ const flowr_file_1 = require("../../../context/flowr-file");
12
+ const assert_1 = require("../../../../util/assert");
13
+ const commonmark_1 = require("commonmark");
14
+ const gray_matter_1 = __importDefault(require("gray-matter"));
15
+ /**
16
+ * This decorates a text file and parses its contents as a R Markdown file.
17
+ * Finnaly, it provides access to the single cells, and all cells fused together as one R file.
18
+ */
19
+ class FlowrRMarkdownFile extends flowr_file_1.FlowrFile {
20
+ data;
21
+ wrapped;
22
+ /**
23
+ * Prefer the static {@link FlowrRMarkdownFile.from} method
24
+ * @param file - the file to load as R Markdown
25
+ */
26
+ constructor(file) {
27
+ super(file.path(), flowr_file_1.FileRole.Source);
28
+ this.wrapped = file;
29
+ }
30
+ get rmd() {
31
+ if (!this.data) {
32
+ this.loadContent();
33
+ }
34
+ (0, assert_1.guard)(this.data);
35
+ return this.data;
36
+ }
37
+ /**
38
+ * Loads and parses the content of the wrapped file.
39
+ * @returns RmdInfo
40
+ */
41
+ loadContent() {
42
+ this.data = parseRMarkdownFile(this.wrapped.content());
43
+ return this.data.content;
44
+ }
45
+ static from(file) {
46
+ return file instanceof FlowrRMarkdownFile ? file : new FlowrRMarkdownFile(file);
47
+ }
48
+ }
49
+ exports.FlowrRMarkdownFile = FlowrRMarkdownFile;
50
+ /**
51
+ * Parse the contents of a RMarkdown file into complete code and blocks
52
+ * @param raw - the raw file content
53
+ * @returns Rmd Info
54
+ */
55
+ function parseRMarkdownFile(raw) {
56
+ // Read and Parse Markdown
57
+ const parser = new commonmark_1.Parser();
58
+ const ast = parser.parse(raw);
59
+ // Parse Frontmatter
60
+ const frontmatter = (0, gray_matter_1.default)(raw);
61
+ // Parse Codeblocks
62
+ const walker = ast.walker();
63
+ const blocks = [];
64
+ let e;
65
+ while ((e = walker.next())) {
66
+ const node = e.node;
67
+ if (!isRCodeBlock(node)) {
68
+ continue;
69
+ }
70
+ blocks.push({
71
+ code: node.literal,
72
+ options: parseCodeBlockOptions(node.info, node.literal),
73
+ startpos: { line: node.sourcepos[0][0] + 1, col: 0 }
74
+ });
75
+ }
76
+ return {
77
+ content: restoreBlocksWithoutMd(blocks, countNewlines(raw)),
78
+ // eslint-disable-next-line unused-imports/no-unused-vars
79
+ blocks: blocks.map(({ startpos, ...block }) => block),
80
+ options: frontmatter.data
81
+ };
82
+ }
83
+ const RTagRegex = /{[rR](?:[\s,][^}]*)?}/;
84
+ /**
85
+ * Checks whether a CommonMark node is an R code block
86
+ */
87
+ function isRCodeBlock(node) {
88
+ return node.type === 'code_block' && node.literal !== null && node.info !== null && RTagRegex.test(node.info);
89
+ }
90
+ const LineRegex = /\r\n|\r|\n/;
91
+ function countNewlines(str) {
92
+ return str.split(LineRegex).length - 1;
93
+ }
94
+ /**
95
+ * Restores an Rmd file from code blocks, filling non-code lines with empty lines
96
+ */
97
+ function restoreBlocksWithoutMd(blocks, totalLines) {
98
+ let line = 1;
99
+ let output = '';
100
+ const goToLine = (n) => {
101
+ const diff = n - line;
102
+ (0, assert_1.guard)(diff >= 0);
103
+ line += diff;
104
+ output += '\n'.repeat(diff);
105
+ };
106
+ for (const block of blocks) {
107
+ goToLine(block.startpos.line);
108
+ output += block.code;
109
+ line += countNewlines(block.code);
110
+ }
111
+ // Add remainder of file
112
+ goToLine(totalLines + 1);
113
+ return output;
114
+ }
115
+ /**
116
+ * Parses the options of an R code block from its header and content
117
+ */
118
+ function parseCodeBlockOptions(header, content) {
119
+ let opts = header.length === 3 // '{r}' => header.length=3 (no options in header)
120
+ ? ''
121
+ : header.substring(3, header.length - 1).trim();
122
+ const lines = content.split('\n');
123
+ for (const line of lines) {
124
+ if (!line.trim().startsWith('#|')) {
125
+ break;
126
+ }
127
+ const opt = line.substring(3);
128
+ opts += opts.length === 0 ? opt : `, ${opt}`;
129
+ }
130
+ return opts;
131
+ }
132
+ //# sourceMappingURL=flowr-rmarkdown-file.js.map
@@ -0,0 +1,2 @@
1
+ "use strict";
2
+ //# sourceMappingURL=notebook.js.map
@@ -0,0 +1,5 @@
1
+ import type { FlowrAnalyzerPlugin } from './flowr-analyzer-plugin';
2
+ /**
3
+ * Provides the default set of Flowr Analyzer plugins.
4
+ */
5
+ export declare function FlowrAnalyzerPluginDefaults(): FlowrAnalyzerPlugin[];
@@ -0,0 +1,23 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.FlowrAnalyzerPluginDefaults = FlowrAnalyzerPluginDefaults;
4
+ const flowr_analyzer_description_file_plugin_1 = require("./file-plugins/flowr-analyzer-description-file-plugin");
5
+ const flowr_analyzer_package_versions_description_file_plugin_1 = require("./package-version-plugins/flowr-analyzer-package-versions-description-file-plugin");
6
+ const flowr_analyzer_loading_order_description_file_plugin_1 = require("./loading-order-plugins/flowr-analyzer-loading-order-description-file-plugin");
7
+ const flowr_analyzer_rmd_file_plugin_1 = require("./file-plugins/notebooks/flowr-analyzer-rmd-file-plugin");
8
+ const flowr_analyzer_qmd_file_plugin_1 = require("./file-plugins/notebooks/flowr-analyzer-qmd-file-plugin");
9
+ const flowr_analyzer_jupyter_file_plugin_1 = require("./file-plugins/notebooks/flowr-analyzer-jupyter-file-plugin");
10
+ /**
11
+ * Provides the default set of Flowr Analyzer plugins.
12
+ */
13
+ function FlowrAnalyzerPluginDefaults() {
14
+ return [
15
+ new flowr_analyzer_description_file_plugin_1.FlowrAnalyzerDescriptionFilePlugin(),
16
+ new flowr_analyzer_package_versions_description_file_plugin_1.FlowrAnalyzerPackageVersionsDescriptionFilePlugin(),
17
+ new flowr_analyzer_loading_order_description_file_plugin_1.FlowrAnalyzerLoadingOrderDescriptionFilePlugin(),
18
+ new flowr_analyzer_rmd_file_plugin_1.FlowrAnalyzerRmdFilePlugin(),
19
+ new flowr_analyzer_qmd_file_plugin_1.FlowrAnalyzerQmdFilePlugin(),
20
+ new flowr_analyzer_jupyter_file_plugin_1.FlowrAnalyzerJupyterFilePlugin(),
21
+ ];
22
+ }
23
+ //# sourceMappingURL=flowr-analyzer-plugin-defaults.js.map
@@ -72,6 +72,8 @@ export interface FlowrAnalyzerPluginInterface<In = unknown, Out = In> {
72
72
  * **Please do not create plugins directly based on this class, but use the classes referenced alongside the {@link PluginType} values!**
73
73
  * For example, if you want to create a plugin that determines the loading order of files, extend {@link FlowrAnalyzerLoadingOrderPlugin} instead.
74
74
  * These classes also provide sensible overrides of {@link FlowrAnalyzerPlugin.defaultPlugin} to be used when no plugin of this type is registered or triggered.
75
+ *
76
+ * For a collection of default plugins, see {@link FlowrAnalyzerPluginDefaults}.
75
77
  */
76
78
  export declare abstract class FlowrAnalyzerPlugin<In = unknown, Out extends AsyncOrSync<unknown> = In> implements FlowrAnalyzerPluginInterface<In, Out> {
77
79
  abstract readonly name: string;
@@ -52,6 +52,8 @@ const generalPluginLog = log_1.log.getSubLogger({ name: 'plugins' });
52
52
  * **Please do not create plugins directly based on this class, but use the classes referenced alongside the {@link PluginType} values!**
53
53
  * For example, if you want to create a plugin that determines the loading order of files, extend {@link FlowrAnalyzerLoadingOrderPlugin} instead.
54
54
  * These classes also provide sensible overrides of {@link FlowrAnalyzerPlugin.defaultPlugin} to be used when no plugin of this type is registered or triggered.
55
+ *
56
+ * For a collection of default plugins, see {@link FlowrAnalyzerPluginDefaults}.
55
57
  */
56
58
  class FlowrAnalyzerPlugin {
57
59
  /**
@@ -15,7 +15,7 @@ class FlowrAnalyzerLoadingOrderDescriptionFilePlugin extends flowr_analyzer_load
15
15
  description = 'This plugin determines loading order based on the Collate field in DESCRIPTION files.';
16
16
  version = new semver_1.SemVer('0.1.0');
17
17
  process(ctx) {
18
- const descFiles = ctx.files.getFilesByRole(flowr_file_1.SpecialFileRole.Description);
18
+ const descFiles = ctx.files.getFilesByRole(flowr_file_1.FileRole.Description);
19
19
  if (descFiles.length !== 1) {
20
20
  flowr_analyzer_description_file_plugin_1.descriptionFileLog.warn(`Supporting only exactly one DESCRIPTION file, found ${descFiles.length}`);
21
21
  return;
@@ -16,7 +16,7 @@ class FlowrAnalyzerPackageVersionsDescriptionFilePlugin extends flowr_analyzer_p
16
16
  description = 'This plugin does...';
17
17
  version = new semver_1.SemVer('0.1.0');
18
18
  process(ctx) {
19
- const descFiles = ctx.files.getFilesByRole(flowr_file_1.SpecialFileRole.Description);
19
+ const descFiles = ctx.files.getFilesByRole(flowr_file_1.FileRole.Description);
20
20
  if (descFiles.length !== 1) {
21
21
  flowr_analyzer_description_file_plugin_1.descriptionFileLog.warn(`Supporting only exactly one DESCRIPTION file, found ${descFiles.length}`);
22
22
  return;
@@ -0,0 +1,34 @@
1
+ import type { FlowrAnalyzerPlugin } from './flowr-analyzer-plugin';
2
+ import { FlowrAnalyzerDescriptionFilePlugin } from './file-plugins/flowr-analyzer-description-file-plugin';
3
+ import { FlowrAnalyzerPackageVersionsDescriptionFilePlugin } from './package-version-plugins/flowr-analyzer-package-versions-description-file-plugin';
4
+ import { FlowrAnalyzerLoadingOrderDescriptionFilePlugin } from './loading-order-plugins/flowr-analyzer-loading-order-description-file-plugin';
5
+ import { FlowrAnalyzerRmdFilePlugin } from './file-plugins/notebooks/flowr-analyzer-rmd-file-plugin';
6
+ import { FlowrAnalyzerQmdFilePlugin } from './file-plugins/notebooks/flowr-analyzer-qmd-file-plugin';
7
+ import { FlowrAnalyzerJupyterFilePlugin } from './file-plugins/notebooks/flowr-analyzer-jupyter-file-plugin';
8
+ /**
9
+ * The built-in Flowr Analyzer plugins that are always available.
10
+ */
11
+ export declare const BuiltInPlugins: [["file:description", typeof FlowrAnalyzerDescriptionFilePlugin], ["versions:description", typeof FlowrAnalyzerPackageVersionsDescriptionFilePlugin], ["loading-order:description", typeof FlowrAnalyzerLoadingOrderDescriptionFilePlugin], ["file:rmd", typeof FlowrAnalyzerRmdFilePlugin], ["file:qmd", typeof FlowrAnalyzerQmdFilePlugin], ["file:ipynb", typeof FlowrAnalyzerJupyterFilePlugin]];
12
+ export type BuiltInFlowrPluginName = typeof BuiltInPlugins[number][0];
13
+ export type BuiltInFlowrPluginArgs<N extends BuiltInFlowrPluginName> = N extends typeof BuiltInPlugins[number][0] ? ConstructorParameters<Extract<typeof BuiltInPlugins[number], [N, PluginProducer]>[1]> : never;
14
+ type PluginProducer = new (...args: never[]) => FlowrAnalyzerPlugin;
15
+ /**
16
+ * Register a new Flowr Analyzer plugin for the registry,
17
+ * to be used by the {@link FlowrAnalyzerBuilder} and {@link FlowrAnalyzer}.
18
+ */
19
+ export declare function registerPluginMaker(plugin: PluginProducer, name?: Exclude<string, BuiltInFlowrPluginName>): void;
20
+ export declare function getPlugin(name: BuiltInFlowrPluginName, args: BuiltInFlowrPluginArgs<typeof name>): FlowrAnalyzerPlugin;
21
+ export declare function getPlugin(name: string, args?: unknown[]): FlowrAnalyzerPlugin | undefined;
22
+ /**
23
+ * The type used to register a plugin with the {@link FlowrAnalyzerBuilder}.
24
+ * @see {@link makePlugin}
25
+ */
26
+ export type PluginToRegister<T extends BuiltInFlowrPluginName | string> = FlowrAnalyzerPlugin | T | string | (T extends BuiltInFlowrPluginName ? [
27
+ T,
28
+ BuiltInFlowrPluginArgs<T>
29
+ ] : [string, unknown[]]);
30
+ /**
31
+ * Create a Flowr Analyzer plugin from a {@link PluginToRegister} specification.
32
+ */
33
+ export declare function makePlugin<T extends BuiltInFlowrPluginName | string>(toRegister: PluginToRegister<T>): FlowrAnalyzerPlugin;
34
+ export {};