@eagleoutice/flowr 1.5.2 → 2.0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/abstract-interpretation/handler/binop/binop.d.ts +3 -4
- package/abstract-interpretation/handler/binop/binop.js +4 -2
- package/abstract-interpretation/handler/binop/operators.d.ts +2 -2
- package/abstract-interpretation/handler/binop/operators.js +14 -28
- package/abstract-interpretation/processor.d.ts +3 -2
- package/abstract-interpretation/processor.js +2 -2
- package/benchmark/slicer.d.ts +101 -0
- package/benchmark/slicer.js +214 -0
- package/benchmark/stats/print.d.ts +7 -0
- package/benchmark/stats/print.js +151 -0
- package/benchmark/stats/stats.d.ts +42 -0
- package/benchmark/stats/stats.js +6 -0
- package/benchmark/stopwatch.d.ts +35 -0
- package/benchmark/stopwatch.js +79 -0
- package/benchmark/summarizer/data.d.ts +54 -0
- package/benchmark/summarizer/first-phase/input.d.ts +3 -0
- package/benchmark/summarizer/first-phase/input.js +76 -0
- package/benchmark/summarizer/first-phase/process.d.ts +11 -0
- package/benchmark/summarizer/first-phase/process.js +205 -0
- package/benchmark/summarizer/second-phase/graph.d.ts +2 -0
- package/benchmark/summarizer/second-phase/graph.js +54 -0
- package/benchmark/summarizer/second-phase/process.d.ts +6 -0
- package/benchmark/summarizer/second-phase/process.js +127 -0
- package/benchmark/summarizer/summarizer.d.ts +31 -0
- package/benchmark/summarizer/summarizer.js +58 -0
- package/cli/benchmark-app.d.ts +10 -0
- package/cli/benchmark-app.js +67 -0
- package/cli/benchmark-helper-app.d.ts +9 -0
- package/cli/benchmark-helper-app.js +69 -0
- package/cli/common/features.d.ts +3 -0
- package/cli/common/features.js +30 -0
- package/cli/common/options.d.ts +20 -0
- package/cli/common/options.js +85 -0
- package/cli/common/script.d.ts +21 -0
- package/cli/common/script.js +61 -0
- package/cli/common/scripts-info.d.ts +25 -0
- package/cli/common/scripts-info.js +83 -0
- package/cli/export-quads-app.d.ts +7 -0
- package/cli/export-quads-app.js +43 -0
- package/cli/flowr.d.ts +29 -0
- package/cli/flowr.js +141 -0
- package/cli/repl/commands/cfg.d.ts +3 -0
- package/cli/repl/commands/cfg.js +37 -0
- package/cli/repl/commands/commands.d.ts +13 -0
- package/cli/repl/commands/commands.js +142 -0
- package/cli/repl/commands/dataflow.d.ts +3 -0
- package/cli/repl/commands/dataflow.js +34 -0
- package/cli/repl/commands/execute.d.ts +4 -0
- package/cli/repl/commands/execute.js +27 -0
- package/cli/repl/commands/main.d.ts +39 -0
- package/cli/repl/commands/main.js +14 -0
- package/cli/repl/commands/normalize.d.ts +3 -0
- package/cli/repl/commands/normalize.js +34 -0
- package/cli/repl/commands/parse.d.ts +2 -0
- package/cli/repl/commands/parse.js +110 -0
- package/cli/repl/commands/quit.d.ts +2 -0
- package/cli/repl/commands/quit.js +15 -0
- package/cli/repl/commands/version.d.ts +16 -0
- package/cli/repl/commands/version.js +28 -0
- package/cli/repl/core.d.ts +36 -0
- package/cli/repl/core.js +174 -0
- package/cli/repl/execute.d.ts +28 -0
- package/cli/repl/execute.js +79 -0
- package/cli/repl/print-version.d.ts +2 -0
- package/cli/repl/print-version.js +10 -0
- package/cli/repl/prompt.d.ts +2 -0
- package/cli/repl/prompt.js +9 -0
- package/cli/repl/server/connection.d.ts +21 -0
- package/cli/repl/server/connection.js +218 -0
- package/cli/repl/server/messages/analysis.d.ts +72 -0
- package/cli/repl/server/messages/analysis.js +21 -0
- package/cli/repl/server/messages/error.d.ts +11 -0
- package/{core/input.js → cli/repl/server/messages/error.js} +1 -1
- package/cli/repl/server/messages/hello.d.ts +20 -0
- package/{core/output.js → cli/repl/server/messages/hello.js} +1 -1
- package/cli/repl/server/messages/messages.d.ts +35 -0
- package/cli/repl/server/messages/messages.js +40 -0
- package/cli/repl/server/messages/repl.d.ts +33 -0
- package/cli/repl/server/messages/repl.js +37 -0
- package/cli/repl/server/messages/slice.d.ts +26 -0
- package/cli/repl/server/messages/slice.js +37 -0
- package/cli/repl/server/net.d.ts +49 -0
- package/cli/repl/server/net.js +63 -0
- package/cli/repl/server/send.d.ts +4 -0
- package/cli/repl/server/send.js +18 -0
- package/cli/repl/server/server.d.ts +20 -0
- package/cli/repl/server/server.js +66 -0
- package/cli/repl/server/validate.d.ts +15 -0
- package/cli/repl/server/validate.js +34 -0
- package/cli/slicer-app.d.ts +11 -0
- package/cli/slicer-app.js +83 -0
- package/cli/statistics-app.d.ts +11 -0
- package/cli/statistics-app.js +99 -0
- package/cli/statistics-helper-app.d.ts +11 -0
- package/cli/statistics-helper-app.js +87 -0
- package/cli/summarizer-app.d.ts +18 -0
- package/cli/summarizer-app.js +66 -0
- package/core/pipeline-executor.d.ts +154 -0
- package/core/pipeline-executor.js +221 -0
- package/core/print/dataflow-printer.d.ts +3 -4
- package/core/print/dataflow-printer.js +5 -5
- package/core/print/normalize-printer.d.ts +1 -1
- package/core/print/normalize-printer.js +3 -3
- package/core/print/parse-printer.js +3 -3
- package/core/print/print.d.ts +13 -4
- package/core/print/print.js +13 -2
- package/core/print/slice-diff-ansi.d.ts +3 -2
- package/core/print/slice-diff-ansi.js +4 -4
- package/core/steps/all/core/00-parse.d.ts +28 -0
- package/core/steps/all/core/00-parse.js +24 -0
- package/core/steps/all/core/10-normalize.d.ts +29 -0
- package/core/steps/all/core/10-normalize.js +26 -0
- package/core/steps/all/core/20-dataflow.d.ts +27 -0
- package/core/steps/all/core/20-dataflow.js +29 -0
- package/core/steps/all/static-slicing/00-slice.d.ts +28 -0
- package/core/steps/all/static-slicing/00-slice.js +21 -0
- package/core/steps/all/static-slicing/10-reconstruct.d.ts +25 -0
- package/core/steps/all/static-slicing/10-reconstruct.js +21 -0
- package/core/steps/pipeline/create-pipeline.d.ts +6 -0
- package/core/steps/pipeline/create-pipeline.js +130 -0
- package/core/steps/pipeline/default-pipelines.d.ts +251 -0
- package/core/steps/pipeline/default-pipelines.js +18 -0
- package/core/steps/pipeline/invalid-pipeline-error.d.ts +6 -0
- package/core/steps/pipeline/invalid-pipeline-error.js +14 -0
- package/core/steps/pipeline/pipeline.d.ts +60 -0
- package/core/steps/pipeline/pipeline.js +28 -0
- package/core/steps/pipeline-step.d.ts +85 -0
- package/core/steps/pipeline-step.js +8 -0
- package/dataflow/environments/append.d.ts +4 -4
- package/dataflow/environments/append.js +4 -4
- package/dataflow/environments/built-in.d.ts +25 -0
- package/dataflow/environments/built-in.js +123 -0
- package/dataflow/environments/clone.d.ts +2 -0
- package/dataflow/environments/clone.js +23 -0
- package/dataflow/environments/{register.d.ts → define.d.ts} +3 -3
- package/dataflow/environments/define.js +51 -0
- package/dataflow/environments/diff.d.ts +6 -0
- package/dataflow/environments/diff.js +85 -0
- package/dataflow/environments/environment.d.ts +10 -43
- package/dataflow/environments/environment.js +32 -138
- package/dataflow/environments/identifier.d.ts +31 -0
- package/dataflow/environments/identifier.js +3 -0
- package/dataflow/environments/overwrite.d.ts +4 -4
- package/dataflow/environments/overwrite.js +9 -22
- package/dataflow/environments/resolve-by-name.d.ts +7 -6
- package/dataflow/environments/resolve-by-name.js +35 -19
- package/dataflow/environments/scoping.js +1 -4
- package/dataflow/extractor.d.ts +6 -6
- package/dataflow/extractor.js +47 -57
- package/dataflow/graph/diff.d.ts +24 -7
- package/dataflow/graph/diff.js +114 -74
- package/dataflow/graph/edge.d.ts +66 -20
- package/dataflow/graph/edge.js +73 -27
- package/dataflow/graph/graph.d.ts +53 -29
- package/dataflow/graph/graph.js +84 -89
- package/dataflow/graph/quads.js +2 -2
- package/dataflow/graph/vertex.d.ts +37 -34
- package/dataflow/info.d.ts +49 -0
- package/dataflow/info.js +29 -0
- package/dataflow/internal/linker.d.ts +11 -10
- package/dataflow/internal/linker.js +64 -90
- package/dataflow/internal/process/functions/call/argument/make-argument.d.ts +6 -0
- package/dataflow/internal/process/functions/call/argument/make-argument.js +31 -0
- package/dataflow/internal/process/functions/call/argument/unpack-argument.d.ts +3 -0
- package/dataflow/internal/process/functions/call/argument/unpack-argument.js +18 -0
- package/dataflow/internal/process/functions/call/built-in/built-in-access.d.ts +9 -0
- package/dataflow/internal/process/functions/call/built-in/built-in-access.js +82 -0
- package/dataflow/internal/process/functions/call/built-in/built-in-assignment.d.ts +29 -0
- package/dataflow/internal/process/functions/call/built-in/built-in-assignment.js +167 -0
- package/dataflow/internal/process/functions/call/built-in/built-in-expression-list.d.ts +11 -0
- package/dataflow/internal/process/functions/call/built-in/built-in-expression-list.js +165 -0
- package/dataflow/internal/process/functions/call/built-in/built-in-for-loop.d.ts +7 -0
- package/dataflow/internal/process/functions/call/built-in/built-in-for-loop.js +97 -0
- package/dataflow/internal/process/functions/call/built-in/built-in-function-definition.d.ts +7 -0
- package/dataflow/internal/process/functions/call/built-in/built-in-function-definition.js +165 -0
- package/dataflow/internal/process/functions/call/built-in/built-in-get.d.ts +7 -0
- package/dataflow/internal/process/functions/call/built-in/built-in-get.js +36 -0
- package/dataflow/internal/process/functions/call/built-in/built-in-if-then-else.d.ts +7 -0
- package/dataflow/internal/process/functions/call/built-in/built-in-if-then-else.js +100 -0
- package/dataflow/internal/process/functions/call/built-in/built-in-library.d.ts +7 -0
- package/dataflow/internal/process/functions/call/built-in/built-in-library.js +32 -0
- package/dataflow/internal/process/functions/call/built-in/built-in-logical-bin-op.d.ts +9 -0
- package/dataflow/internal/process/functions/call/built-in/built-in-logical-bin-op.js +35 -0
- package/dataflow/internal/process/functions/call/built-in/built-in-pipe.d.ts +7 -0
- package/dataflow/internal/process/functions/call/built-in/built-in-pipe.js +35 -0
- package/dataflow/internal/process/functions/call/built-in/built-in-quote.d.ts +9 -0
- package/dataflow/internal/process/functions/call/built-in/built-in-quote.js +29 -0
- package/dataflow/internal/process/functions/call/built-in/built-in-repeat-loop.d.ts +7 -0
- package/dataflow/internal/process/functions/call/built-in/built-in-repeat-loop.js +32 -0
- package/dataflow/internal/process/functions/call/built-in/built-in-replacement.d.ts +12 -0
- package/dataflow/internal/process/functions/call/built-in/built-in-replacement.js +45 -0
- package/dataflow/internal/process/functions/call/built-in/built-in-source.d.ts +11 -0
- package/dataflow/internal/process/functions/call/built-in/built-in-source.js +72 -0
- package/dataflow/internal/process/functions/call/built-in/built-in-while-loop.d.ts +7 -0
- package/dataflow/internal/process/functions/call/built-in/built-in-while-loop.js +61 -0
- package/dataflow/internal/process/functions/call/common.d.ts +35 -0
- package/dataflow/internal/process/functions/call/common.js +70 -0
- package/dataflow/internal/process/functions/call/default-call-handling.d.ts +5 -0
- package/dataflow/internal/process/functions/call/default-call-handling.js +15 -0
- package/dataflow/internal/process/functions/call/known-call-handling.d.ts +26 -0
- package/dataflow/internal/process/functions/call/known-call-handling.js +62 -0
- package/dataflow/internal/process/functions/call/named-call-handling.d.ts +7 -0
- package/dataflow/internal/process/functions/call/named-call-handling.js +53 -0
- package/dataflow/internal/process/functions/call/unnamed-call-handling.d.ts +6 -0
- package/dataflow/internal/process/functions/call/unnamed-call-handling.js +58 -0
- package/dataflow/internal/process/functions/process-argument.d.ts +9 -0
- package/dataflow/internal/process/functions/{argument.js → process-argument.js} +25 -20
- package/dataflow/internal/process/functions/{parameter.d.ts → process-parameter.d.ts} +3 -2
- package/dataflow/internal/process/functions/{parameter.js → process-parameter.js} +10 -13
- package/dataflow/internal/process/process-named-call.d.ts +6 -0
- package/dataflow/internal/process/process-named-call.js +17 -0
- package/dataflow/internal/process/process-symbol.d.ts +5 -0
- package/dataflow/internal/process/process-symbol.js +26 -0
- package/dataflow/internal/process/process-uninteresting-leaf.d.ts +4 -0
- package/dataflow/internal/process/process-uninteresting-leaf.js +9 -0
- package/dataflow/internal/process/process-value.d.ts +4 -0
- package/dataflow/internal/process/process-value.js +22 -0
- package/dataflow/logger.d.ts +1 -0
- package/dataflow/logger.js +6 -0
- package/dataflow/processor.d.ts +18 -13
- package/dataflow/processor.js +1 -1
- package/package.json +48 -85
- package/r-bridge/data/data.d.ts +603 -0
- package/r-bridge/data/data.js +753 -0
- package/r-bridge/data/get.d.ts +19 -0
- package/r-bridge/data/get.js +51 -0
- package/r-bridge/data/print.d.ts +1 -0
- package/r-bridge/data/print.js +58 -0
- package/r-bridge/data/types.d.ts +33 -0
- package/r-bridge/data/types.js +3 -0
- package/r-bridge/init.d.ts +3 -0
- package/r-bridge/init.js +22 -0
- package/r-bridge/lang-4.x/ast/model/collect.d.ts +2 -1
- package/r-bridge/lang-4.x/ast/model/collect.js +2 -2
- package/r-bridge/lang-4.x/ast/model/model.d.ts +26 -5
- package/r-bridge/lang-4.x/ast/model/nodes/r-access.d.ts +4 -3
- package/r-bridge/lang-4.x/ast/model/nodes/r-argument.d.ts +4 -0
- package/r-bridge/lang-4.x/ast/model/nodes/r-binary-op.d.ts +0 -17
- package/r-bridge/lang-4.x/ast/model/nodes/r-expression-list.d.ts +3 -1
- package/r-bridge/lang-4.x/ast/model/nodes/r-function-call.d.ts +6 -4
- package/r-bridge/lang-4.x/ast/model/nodes/r-function-call.js +2 -0
- package/r-bridge/lang-4.x/ast/model/nodes/r-function-definition.d.ts +2 -3
- package/r-bridge/lang-4.x/ast/model/nodes/r-number.d.ts +1 -1
- package/r-bridge/lang-4.x/ast/model/nodes/r-string.d.ts +1 -1
- package/r-bridge/lang-4.x/ast/model/nodes/r-symbol.js +2 -2
- package/r-bridge/lang-4.x/ast/model/nodes/r-unary-op.d.ts +0 -11
- package/r-bridge/lang-4.x/ast/model/operators.d.ts +6 -18
- package/r-bridge/lang-4.x/ast/model/operators.js +36 -48
- package/r-bridge/lang-4.x/ast/model/processing/decorate.d.ts +19 -15
- package/r-bridge/lang-4.x/ast/model/processing/decorate.js +59 -54
- package/r-bridge/lang-4.x/ast/model/processing/node-id.d.ts +8 -0
- package/r-bridge/lang-4.x/ast/model/processing/node-id.js +18 -0
- package/r-bridge/lang-4.x/ast/model/processing/role.d.ts +2 -2
- package/r-bridge/lang-4.x/ast/model/processing/stateful-fold.d.ts +28 -17
- package/r-bridge/lang-4.x/ast/model/processing/stateful-fold.js +7 -34
- package/r-bridge/lang-4.x/ast/model/processing/visitor.js +5 -2
- package/r-bridge/lang-4.x/ast/model/type.js +13 -6
- package/r-bridge/lang-4.x/ast/parser/json/format.d.ts +4 -1
- package/r-bridge/lang-4.x/ast/parser/json/format.js +9 -2
- package/r-bridge/lang-4.x/ast/parser/json/parser.d.ts +5 -5
- package/r-bridge/lang-4.x/ast/parser/json/parser.js +22 -27
- package/r-bridge/lang-4.x/ast/parser/xml/input-format.d.ts +10 -7
- package/r-bridge/lang-4.x/ast/parser/xml/input-format.js +19 -11
- package/r-bridge/lang-4.x/ast/parser/xml/internal/control/{if-then-else.d.ts → normalize-if-then-else.d.ts} +3 -3
- package/r-bridge/lang-4.x/ast/parser/xml/internal/control/{if-then-else.js → normalize-if-then-else.js} +10 -13
- package/r-bridge/lang-4.x/ast/parser/xml/internal/control/{if-then.d.ts → normalize-if-then.d.ts} +3 -3
- package/r-bridge/lang-4.x/ast/parser/xml/internal/control/{if-then.js → normalize-if-then.js} +9 -12
- package/r-bridge/lang-4.x/ast/parser/xml/internal/expression/normalize-expression.d.ts +10 -0
- package/r-bridge/lang-4.x/ast/parser/xml/internal/expression/normalize-expression.js +64 -0
- package/r-bridge/lang-4.x/ast/parser/xml/internal/functions/{argument.d.ts → normalize-argument.d.ts} +4 -4
- package/r-bridge/lang-4.x/ast/parser/xml/internal/functions/{argument.js → normalize-argument.js} +13 -17
- package/r-bridge/lang-4.x/ast/parser/xml/internal/functions/{call.d.ts → normalize-call.d.ts} +6 -4
- package/r-bridge/lang-4.x/ast/parser/xml/internal/functions/{call.js → normalize-call.js} +24 -29
- package/r-bridge/lang-4.x/ast/parser/xml/internal/functions/normalize-definition.d.ts +12 -0
- package/r-bridge/lang-4.x/ast/parser/xml/internal/functions/{definition.js → normalize-definition.js} +14 -19
- package/r-bridge/lang-4.x/ast/parser/xml/internal/functions/{parameter.d.ts → normalize-parameter.d.ts} +4 -4
- package/r-bridge/lang-4.x/ast/parser/xml/internal/functions/{parameter.js → normalize-parameter.js} +12 -16
- package/r-bridge/lang-4.x/ast/parser/xml/internal/loops/normalize-break.d.ts +4 -0
- package/r-bridge/lang-4.x/ast/parser/xml/internal/loops/{break.js → normalize-break.js} +6 -8
- package/r-bridge/lang-4.x/ast/parser/xml/internal/loops/normalize-for.d.ts +4 -0
- package/r-bridge/lang-4.x/ast/parser/xml/internal/loops/{for.js → normalize-for.js} +18 -20
- package/r-bridge/lang-4.x/ast/parser/xml/internal/loops/normalize-next.d.ts +4 -0
- package/r-bridge/lang-4.x/ast/parser/xml/internal/loops/{next.js → normalize-next.js} +6 -8
- package/r-bridge/lang-4.x/ast/parser/xml/internal/loops/normalize-repeat.d.ts +13 -0
- package/r-bridge/lang-4.x/ast/parser/xml/internal/loops/{repeat.js → normalize-repeat.js} +13 -16
- package/r-bridge/lang-4.x/ast/parser/xml/internal/loops/normalize-while.d.ts +4 -0
- package/r-bridge/lang-4.x/ast/parser/xml/internal/loops/{while.js → normalize-while.js} +10 -12
- package/r-bridge/lang-4.x/ast/parser/xml/internal/{access.d.ts → normalize-access.d.ts} +4 -4
- package/r-bridge/lang-4.x/ast/parser/xml/internal/{access.js → normalize-access.js} +44 -45
- package/r-bridge/lang-4.x/ast/parser/xml/internal/operators/{binary.d.ts → normalize-binary.d.ts} +3 -3
- package/r-bridge/lang-4.x/ast/parser/xml/internal/operators/{binary.js → normalize-binary.js} +23 -73
- package/r-bridge/lang-4.x/ast/parser/xml/internal/operators/normalize-unary.d.ts +13 -0
- package/r-bridge/lang-4.x/ast/parser/xml/internal/operators/normalize-unary.js +47 -0
- package/r-bridge/lang-4.x/ast/parser/xml/internal/other/normalize-comment.d.ts +11 -0
- package/r-bridge/lang-4.x/ast/parser/xml/internal/other/{comment.js → normalize-comment.js} +5 -10
- package/r-bridge/lang-4.x/ast/parser/xml/internal/other/normalize-line-directive.d.ts +13 -0
- package/r-bridge/lang-4.x/ast/parser/xml/internal/other/{line-directive.js → normalize-line-directive.js} +7 -12
- package/r-bridge/lang-4.x/ast/parser/xml/internal/structure/normalize-delimiter.d.ts +3 -0
- package/r-bridge/lang-4.x/ast/parser/xml/internal/structure/normalize-delimiter.js +15 -0
- package/r-bridge/lang-4.x/ast/parser/xml/internal/structure/normalize-expressions.d.ts +10 -0
- package/r-bridge/lang-4.x/ast/parser/xml/internal/structure/normalize-expressions.js +182 -0
- package/r-bridge/lang-4.x/ast/parser/xml/internal/structure/normalize-root.d.ts +4 -0
- package/r-bridge/lang-4.x/ast/parser/xml/internal/structure/normalize-root.js +34 -0
- package/r-bridge/lang-4.x/ast/parser/xml/internal/structure/normalize-single-node.d.ts +13 -0
- package/r-bridge/lang-4.x/ast/parser/xml/internal/structure/normalize-single-node.js +59 -0
- package/r-bridge/lang-4.x/ast/parser/xml/internal/values/normalize-number.d.ts +16 -0
- package/r-bridge/lang-4.x/ast/parser/xml/internal/values/{number.js → normalize-number.js} +12 -18
- package/r-bridge/lang-4.x/ast/parser/xml/internal/values/normalize-string.d.ts +11 -0
- package/r-bridge/lang-4.x/ast/parser/xml/internal/values/{string.js → normalize-string.js} +7 -12
- package/r-bridge/lang-4.x/ast/parser/xml/internal/values/{symbol.d.ts → normalize-symbol.d.ts} +4 -4
- package/r-bridge/lang-4.x/ast/parser/xml/internal/values/{symbol.js → normalize-symbol.js} +12 -15
- package/r-bridge/lang-4.x/ast/parser/xml/{internal/meta.d.ts → normalize-meta.d.ts} +5 -3
- package/r-bridge/lang-4.x/ast/parser/xml/{internal/meta.js → normalize-meta.js} +8 -8
- package/r-bridge/lang-4.x/ast/parser/xml/{data.d.ts → normalizer-data.d.ts} +1 -5
- package/r-bridge/lang-4.x/ast/parser/xml/normalizer-data.js +3 -0
- package/r-bridge/lang-4.x/{values.d.ts → convert-values.d.ts} +2 -2
- package/r-bridge/lang-4.x/{values.js → convert-values.js} +5 -5
- package/r-bridge/retriever.d.ts +5 -5
- package/r-bridge/retriever.js +11 -24
- package/r-bridge/shell-executor.d.ts +0 -1
- package/r-bridge/shell-executor.js +7 -12
- package/r-bridge/shell.d.ts +14 -12
- package/r-bridge/shell.js +52 -47
- package/reconstruct/reconstruct.d.ts +4 -2
- package/reconstruct/reconstruct.js +193 -185
- package/slicing/criterion/collect-all.d.ts +4 -3
- package/slicing/criterion/collect-all.js +5 -1
- package/slicing/criterion/filters/all-variables.js +14 -22
- package/slicing/criterion/parse.d.ts +4 -2
- package/slicing/criterion/parse.js +13 -11
- package/slicing/static/fingerprint.d.ts +5 -0
- package/slicing/static/fingerprint.js +17 -0
- package/slicing/static/slice-call.d.ts +10 -0
- package/slicing/static/slice-call.js +86 -0
- package/slicing/static/slicer-types.d.ts +33 -0
- package/slicing/static/slicer-types.js +3 -0
- package/slicing/static/static-slicer.d.ts +6 -24
- package/slicing/static/static-slicer.js +54 -155
- package/slicing/static/visiting-queue.d.ts +23 -0
- package/slicing/static/visiting-queue.js +53 -0
- package/statistics/features/common-syntax-probability.d.ts +29 -0
- package/statistics/features/common-syntax-probability.js +159 -0
- package/statistics/features/feature.d.ts +182 -0
- package/statistics/features/feature.js +39 -0
- package/statistics/features/post-processing.d.ts +12 -0
- package/statistics/features/post-processing.js +21 -0
- package/statistics/features/supported/assignments/assignments.d.ts +12 -0
- package/statistics/features/supported/assignments/assignments.js +55 -0
- package/statistics/features/supported/assignments/post-process.d.ts +3 -0
- package/statistics/features/supported/assignments/post-process.js +124 -0
- package/statistics/features/supported/comments/comments.d.ts +18 -0
- package/statistics/features/supported/comments/comments.js +133 -0
- package/statistics/features/supported/comments/post-process.d.ts +3 -0
- package/statistics/features/supported/comments/post-process.js +49 -0
- package/statistics/features/supported/control-flow/control-flow.d.ts +17 -0
- package/statistics/features/supported/control-flow/control-flow.js +68 -0
- package/statistics/features/supported/control-flow/post-process.d.ts +3 -0
- package/statistics/features/supported/control-flow/post-process.js +64 -0
- package/statistics/features/supported/data-access/data-access.d.ts +15 -0
- package/statistics/features/supported/data-access/data-access.js +120 -0
- package/statistics/features/supported/data-access/post-process.d.ts +3 -0
- package/statistics/features/supported/data-access/post-process.js +106 -0
- package/statistics/features/supported/defined-functions/defined-functions.d.ts +34 -0
- package/statistics/features/supported/defined-functions/defined-functions.js +142 -0
- package/statistics/features/supported/defined-functions/post-process.d.ts +6 -0
- package/statistics/features/supported/defined-functions/post-process.js +169 -0
- package/statistics/features/supported/expression-list/expression-list.d.ts +9 -0
- package/statistics/features/supported/expression-list/expression-list.js +36 -0
- package/statistics/features/supported/expression-list/post-process.d.ts +3 -0
- package/statistics/features/supported/expression-list/post-process.js +43 -0
- package/statistics/features/supported/loops/loops.d.ts +20 -0
- package/statistics/features/supported/loops/loops.js +79 -0
- package/statistics/features/supported/loops/post-process.d.ts +3 -0
- package/statistics/features/supported/loops/post-process.js +71 -0
- package/statistics/features/supported/used-functions/post-process.d.ts +6 -0
- package/statistics/features/supported/used-functions/post-process.js +178 -0
- package/statistics/features/supported/used-functions/used-functions.d.ts +24 -0
- package/statistics/features/supported/used-functions/used-functions.js +97 -0
- package/statistics/features/supported/used-packages/post-process.d.ts +3 -0
- package/statistics/features/supported/used-packages/post-process.js +120 -0
- package/statistics/features/supported/used-packages/used-packages.d.ts +16 -0
- package/statistics/features/supported/used-packages/used-packages.js +130 -0
- package/statistics/features/supported/values/post-process.d.ts +3 -0
- package/statistics/features/supported/values/post-process.js +71 -0
- package/statistics/features/supported/values/values.d.ts +14 -0
- package/statistics/features/supported/values/values.js +101 -0
- package/statistics/features/supported/variables/post-process.d.ts +9 -0
- package/statistics/features/supported/variables/post-process.js +121 -0
- package/statistics/features/supported/variables/variables.d.ts +15 -0
- package/statistics/features/supported/variables/variables.js +60 -0
- package/statistics/meta-statistics.d.ts +33 -0
- package/statistics/meta-statistics.js +17 -0
- package/statistics/output/file-provider.d.ts +37 -0
- package/statistics/output/file-provider.js +97 -0
- package/statistics/output/print-stats.d.ts +17 -0
- package/statistics/output/print-stats.js +69 -0
- package/statistics/output/statistics-file.d.ts +37 -0
- package/statistics/output/statistics-file.js +69 -0
- package/statistics/statistics.d.ts +28 -0
- package/statistics/statistics.js +108 -0
- package/statistics/summarizer/auto-detect.d.ts +2 -0
- package/statistics/summarizer/auto-detect.js +32 -0
- package/statistics/summarizer/first-phase/process.d.ts +6 -0
- package/statistics/summarizer/first-phase/process.js +81 -0
- package/statistics/summarizer/post-process/clusterer.d.ts +26 -0
- package/statistics/summarizer/post-process/clusterer.js +43 -0
- package/statistics/summarizer/post-process/file-based-count.d.ts +17 -0
- package/statistics/summarizer/post-process/file-based-count.js +49 -0
- package/statistics/summarizer/post-process/histogram.d.ts +59 -0
- package/statistics/summarizer/post-process/histogram.js +128 -0
- package/statistics/summarizer/post-process/post-process-output.d.ts +16 -0
- package/statistics/summarizer/post-process/post-process-output.js +105 -0
- package/statistics/summarizer/second-phase/process.d.ts +11 -0
- package/statistics/summarizer/second-phase/process.js +116 -0
- package/statistics/summarizer/summarizer.d.ts +35 -0
- package/statistics/summarizer/summarizer.js +135 -0
- package/util/ansi.d.ts +2 -2
- package/util/ansi.js +2 -2
- package/util/arrays.d.ts +11 -1
- package/util/arrays.js +34 -1
- package/util/assert.d.ts +1 -0
- package/util/assert.js +5 -1
- package/util/cfg/cfg.d.ts +3 -2
- package/util/cfg/cfg.js +17 -28
- package/util/cfg/visitor.d.ts +1 -1
- package/util/defaultmap.d.ts +1 -1
- package/util/defaultmap.js +1 -1
- package/util/diff.d.ts +4 -4
- package/util/files.d.ts +2 -2
- package/util/files.js +1 -1
- package/util/log.d.ts +1 -0
- package/util/log.js +7 -1
- package/util/logic.d.ts +1 -0
- package/util/logic.js +3 -0
- package/util/mermaid/ast.d.ts +1 -1
- package/util/mermaid/ast.js +2 -2
- package/util/mermaid/cfg.d.ts +1 -1
- package/util/mermaid/dfg.d.ts +34 -8
- package/util/mermaid/dfg.js +99 -70
- package/util/mermaid/mermaid.d.ts +1 -1
- package/util/mermaid/mermaid.js +6 -7
- package/util/objects.js +4 -0
- package/util/quads.d.ts +3 -3
- package/util/quads.js +0 -1
- package/util/range.d.ts +27 -14
- package/util/range.js +31 -27
- package/util/version.js +1 -1
- package/core/index.d.ts +0 -4
- package/core/index.js +0 -23
- package/core/input.d.ts +0 -42
- package/core/output.d.ts +0 -15
- package/core/slicer.d.ts +0 -124
- package/core/slicer.js +0 -227
- package/core/steps.d.ts +0 -508
- package/core/steps.js +0 -100
- package/dataflow/environments/index.d.ts +0 -7
- package/dataflow/environments/index.js +0 -23
- package/dataflow/environments/register.js +0 -40
- package/dataflow/environments/scopes.d.ts +0 -6
- package/dataflow/environments/scopes.js +0 -6
- package/dataflow/graph/index.d.ts +0 -4
- package/dataflow/graph/index.js +0 -21
- package/dataflow/index.d.ts +0 -5
- package/dataflow/index.js +0 -24
- package/dataflow/internal/info.d.ts +0 -21
- package/dataflow/internal/info.js +0 -16
- package/dataflow/internal/process/access.d.ts +0 -4
- package/dataflow/internal/process/access.js +0 -53
- package/dataflow/internal/process/expression-list.d.ts +0 -8
- package/dataflow/internal/process/expression-list.js +0 -144
- package/dataflow/internal/process/functions/argument.d.ts +0 -8
- package/dataflow/internal/process/functions/exit-points.d.ts +0 -2
- package/dataflow/internal/process/functions/exit-points.js +0 -121
- package/dataflow/internal/process/functions/function-call.d.ts +0 -5
- package/dataflow/internal/process/functions/function-call.js +0 -105
- package/dataflow/internal/process/functions/function-definition.d.ts +0 -4
- package/dataflow/internal/process/functions/function-definition.js +0 -176
- package/dataflow/internal/process/functions/source.d.ts +0 -8
- package/dataflow/internal/process/functions/source.js +0 -81
- package/dataflow/internal/process/if-then-else.d.ts +0 -4
- package/dataflow/internal/process/if-then-else.js +0 -56
- package/dataflow/internal/process/loops/for-loop.d.ts +0 -4
- package/dataflow/internal/process/loops/for-loop.js +0 -54
- package/dataflow/internal/process/loops/repeat-loop.d.ts +0 -4
- package/dataflow/internal/process/loops/repeat-loop.js +0 -21
- package/dataflow/internal/process/loops/while-loop.d.ts +0 -4
- package/dataflow/internal/process/loops/while-loop.js +0 -31
- package/dataflow/internal/process/operators/assignment.d.ts +0 -4
- package/dataflow/internal/process/operators/assignment.js +0 -129
- package/dataflow/internal/process/operators/non-assignment-binary-op.d.ts +0 -4
- package/dataflow/internal/process/operators/non-assignment-binary-op.js +0 -25
- package/dataflow/internal/process/operators/pipe.d.ts +0 -4
- package/dataflow/internal/process/operators/pipe.js +0 -46
- package/dataflow/internal/process/operators/unary-op.d.ts +0 -4
- package/dataflow/internal/process/operators/unary-op.js +0 -10
- package/dataflow/internal/process/symbol.d.ts +0 -4
- package/dataflow/internal/process/symbol.js +0 -21
- package/dataflow/internal/process/uninteresting-leaf.d.ts +0 -3
- package/dataflow/internal/process/uninteresting-leaf.js +0 -9
- package/index.d.ts +0 -4
- package/index.js +0 -21
- package/r-bridge/index.d.ts +0 -11
- package/r-bridge/index.js +0 -28
- package/r-bridge/lang-4.x/ast/index.d.ts +0 -3
- package/r-bridge/lang-4.x/ast/index.js +0 -22
- package/r-bridge/lang-4.x/ast/model/index.d.ts +0 -6
- package/r-bridge/lang-4.x/ast/model/index.js +0 -23
- package/r-bridge/lang-4.x/ast/model/nodes/index.d.ts +0 -21
- package/r-bridge/lang-4.x/ast/model/nodes/index.js +0 -38
- package/r-bridge/lang-4.x/ast/model/nodes/info/index.d.ts +0 -13
- package/r-bridge/lang-4.x/ast/model/nodes/info/index.js +0 -27
- package/r-bridge/lang-4.x/ast/model/processing/index.d.ts +0 -5
- package/r-bridge/lang-4.x/ast/model/processing/index.js +0 -22
- package/r-bridge/lang-4.x/ast/parser/xml/hooks.d.ts +0 -292
- package/r-bridge/lang-4.x/ast/parser/xml/hooks.js +0 -136
- package/r-bridge/lang-4.x/ast/parser/xml/index.d.ts +0 -3
- package/r-bridge/lang-4.x/ast/parser/xml/index.js +0 -20
- package/r-bridge/lang-4.x/ast/parser/xml/internal/control/index.d.ts +0 -2
- package/r-bridge/lang-4.x/ast/parser/xml/internal/control/index.js +0 -19
- package/r-bridge/lang-4.x/ast/parser/xml/internal/expression/expression.d.ts +0 -10
- package/r-bridge/lang-4.x/ast/parser/xml/internal/expression/expression.js +0 -65
- package/r-bridge/lang-4.x/ast/parser/xml/internal/expression/index.d.ts +0 -1
- package/r-bridge/lang-4.x/ast/parser/xml/internal/expression/index.js +0 -18
- package/r-bridge/lang-4.x/ast/parser/xml/internal/functions/definition.d.ts +0 -12
- package/r-bridge/lang-4.x/ast/parser/xml/internal/functions/index.d.ts +0 -2
- package/r-bridge/lang-4.x/ast/parser/xml/internal/functions/index.js +0 -20
- package/r-bridge/lang-4.x/ast/parser/xml/internal/index.d.ts +0 -9
- package/r-bridge/lang-4.x/ast/parser/xml/internal/index.js +0 -26
- package/r-bridge/lang-4.x/ast/parser/xml/internal/loops/break.d.ts +0 -4
- package/r-bridge/lang-4.x/ast/parser/xml/internal/loops/for.d.ts +0 -4
- package/r-bridge/lang-4.x/ast/parser/xml/internal/loops/index.d.ts +0 -5
- package/r-bridge/lang-4.x/ast/parser/xml/internal/loops/index.js +0 -22
- package/r-bridge/lang-4.x/ast/parser/xml/internal/loops/next.d.ts +0 -4
- package/r-bridge/lang-4.x/ast/parser/xml/internal/loops/repeat.d.ts +0 -13
- package/r-bridge/lang-4.x/ast/parser/xml/internal/loops/while.d.ts +0 -4
- package/r-bridge/lang-4.x/ast/parser/xml/internal/operators/index.d.ts +0 -3
- package/r-bridge/lang-4.x/ast/parser/xml/internal/operators/index.js +0 -20
- package/r-bridge/lang-4.x/ast/parser/xml/internal/operators/special.d.ts +0 -6
- package/r-bridge/lang-4.x/ast/parser/xml/internal/operators/special.js +0 -24
- package/r-bridge/lang-4.x/ast/parser/xml/internal/operators/unary.d.ts +0 -13
- package/r-bridge/lang-4.x/ast/parser/xml/internal/operators/unary.js +0 -59
- package/r-bridge/lang-4.x/ast/parser/xml/internal/other/comment.d.ts +0 -11
- package/r-bridge/lang-4.x/ast/parser/xml/internal/other/index.d.ts +0 -1
- package/r-bridge/lang-4.x/ast/parser/xml/internal/other/index.js +0 -18
- package/r-bridge/lang-4.x/ast/parser/xml/internal/other/line-directive.d.ts +0 -12
- package/r-bridge/lang-4.x/ast/parser/xml/internal/structure/elements.d.ts +0 -10
- package/r-bridge/lang-4.x/ast/parser/xml/internal/structure/elements.js +0 -159
- package/r-bridge/lang-4.x/ast/parser/xml/internal/structure/index.d.ts +0 -3
- package/r-bridge/lang-4.x/ast/parser/xml/internal/structure/index.js +0 -20
- package/r-bridge/lang-4.x/ast/parser/xml/internal/structure/root.d.ts +0 -4
- package/r-bridge/lang-4.x/ast/parser/xml/internal/structure/root.js +0 -33
- package/r-bridge/lang-4.x/ast/parser/xml/internal/structure/single-element.d.ts +0 -13
- package/r-bridge/lang-4.x/ast/parser/xml/internal/structure/single-element.js +0 -64
- package/r-bridge/lang-4.x/ast/parser/xml/internal/values/index.d.ts +0 -3
- package/r-bridge/lang-4.x/ast/parser/xml/internal/values/index.js +0 -20
- package/r-bridge/lang-4.x/ast/parser/xml/internal/values/number.d.ts +0 -13
- package/r-bridge/lang-4.x/ast/parser/xml/internal/values/string.d.ts +0 -11
- package/r-bridge/lang-4.x/index.d.ts +0 -2
- package/r-bridge/lang-4.x/index.js +0 -19
- package/slicing/criterion/filters/index.d.ts +0 -1
- package/slicing/criterion/filters/index.js +0 -18
- package/slicing/criterion/index.d.ts +0 -3
- package/slicing/criterion/index.js +0 -20
- package/slicing/index.d.ts +0 -3
- package/slicing/index.js +0 -20
- package/slicing/static/index.d.ts +0 -1
- package/slicing/static/index.js +0 -18
- package/util/mermaid/index.d.ts +0 -3
- package/util/mermaid/index.js +0 -20
- /package/{r-bridge/lang-4.x/ast/parser/xml → benchmark/summarizer}/data.js +0 -0
|
@@ -0,0 +1,133 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
14
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
15
|
+
}) : function(o, v) {
|
|
16
|
+
o["default"] = v;
|
|
17
|
+
});
|
|
18
|
+
var __importStar = (this && this.__importStar) || function (mod) {
|
|
19
|
+
if (mod && mod.__esModule) return mod;
|
|
20
|
+
var result = {};
|
|
21
|
+
if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
|
|
22
|
+
__setModuleDefault(result, mod);
|
|
23
|
+
return result;
|
|
24
|
+
};
|
|
25
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
26
|
+
exports.comments = exports.initialCommentInfo = void 0;
|
|
27
|
+
const xpath = __importStar(require("xpath-ts2"));
|
|
28
|
+
const post_process_1 = require("./post-process");
|
|
29
|
+
const assert_1 = require("../../../../util/assert");
|
|
30
|
+
const statistics_file_1 = require("../../../output/statistics-file");
|
|
31
|
+
exports.initialCommentInfo = {
|
|
32
|
+
totalAmount: 0,
|
|
33
|
+
roxygenComments: 0,
|
|
34
|
+
import: 0,
|
|
35
|
+
importFrom: 0,
|
|
36
|
+
importMethodsFrom: 0,
|
|
37
|
+
importClassesFrom: 0,
|
|
38
|
+
useDynLib: 0,
|
|
39
|
+
export: 0,
|
|
40
|
+
exportClass: 0,
|
|
41
|
+
exportMethod: 0,
|
|
42
|
+
exportS3Method: 0,
|
|
43
|
+
exportPattern: 0
|
|
44
|
+
};
|
|
45
|
+
const commentQuery = xpath.parse('//COMMENT');
|
|
46
|
+
const importRegex = /^'\s*@import\s+(?<package>\S+)/;
|
|
47
|
+
const importFromRegex = /^'\s*@importFrom\s+(?<package>\S+)(?<fn>( +\S+)+)$/;
|
|
48
|
+
const useDynLibRegex = /^'\s*@useDynLib\s+(?<package>\S+)(?<fn>( +\S+)+)?$/;
|
|
49
|
+
/** we still name the classes fn, so we can reuse processing code */
|
|
50
|
+
const importClassesFromRegex = /^'\s*@importClassesFrom\s+(?<package>\S+)(?<fn>( +\S+)+)$/;
|
|
51
|
+
const importMethodsFrom = /^'\s*@importMethodsFrom\s+(?<package>\S+)(?<fn>( +\S+)+)$/;
|
|
52
|
+
/** deliberately includes the others to get a "total" overview */
|
|
53
|
+
const exportRegex = /^'\s*@export/;
|
|
54
|
+
const exportS3MethodRegex = /^'\s*@exportS3Method/;
|
|
55
|
+
const exportClassRegex = /^'\s*@exportClass/;
|
|
56
|
+
const exportMethodRegex = /^'\s*@exportMethod/;
|
|
57
|
+
const exportPatternRegex = /^'\s*@exportPattern/;
|
|
58
|
+
function processRoxygenImport(existing, commentsText, filepath) {
|
|
59
|
+
const packages = commentsText.map(text => importRegex.exec(text)?.groups?.package).filter(assert_1.isNotUndefined);
|
|
60
|
+
existing.import += packages.length;
|
|
61
|
+
(0, statistics_file_1.appendStatisticsFile)(exports.comments.name, 'import', packages, filepath, true);
|
|
62
|
+
}
|
|
63
|
+
function processWithRegex(commentsText, existing, regex) {
|
|
64
|
+
return commentsText.map(text => regex.exec(text)).filter(assert_1.isNotNull)
|
|
65
|
+
.flatMap(match => {
|
|
66
|
+
const packageName = match.groups?.package ?? '<unknown>';
|
|
67
|
+
return (match.groups?.fn.trim().split(/\s+/) ?? []).map(fn => `${JSON.stringify(packageName)},${fn}`);
|
|
68
|
+
});
|
|
69
|
+
}
|
|
70
|
+
function processRoxygenImportFrom(existing, commentsText, filepath) {
|
|
71
|
+
const result = processWithRegex(commentsText, existing, importFromRegex);
|
|
72
|
+
existing.importFrom += result.length;
|
|
73
|
+
(0, statistics_file_1.appendStatisticsFile)(exports.comments.name, 'importFrom', result, filepath, true);
|
|
74
|
+
}
|
|
75
|
+
function processRoxygenImportClassesFrom(existing, commentsText, filepath) {
|
|
76
|
+
const result = processWithRegex(commentsText, existing, importClassesFromRegex);
|
|
77
|
+
existing.importClassesFrom += result.length;
|
|
78
|
+
(0, statistics_file_1.appendStatisticsFile)(exports.comments.name, 'importClassesFrom', result, filepath, true);
|
|
79
|
+
}
|
|
80
|
+
function processRoxygenImportMethodsFrom(existing, commentsText, filepath) {
|
|
81
|
+
const result = processWithRegex(commentsText, existing, importMethodsFrom);
|
|
82
|
+
existing.importMethodsFrom += result.length;
|
|
83
|
+
(0, statistics_file_1.appendStatisticsFile)(exports.comments.name, 'importMethodsFrom', result, filepath, true);
|
|
84
|
+
}
|
|
85
|
+
function processExports(existing, comments) {
|
|
86
|
+
existing.export += comments.filter(text => exportRegex.test(text)).length;
|
|
87
|
+
existing.exportClass += comments.filter(text => exportClassRegex.test(text)).length;
|
|
88
|
+
existing.exportMethod += comments.filter(text => exportMethodRegex.test(text)).length;
|
|
89
|
+
existing.exportS3Method += comments.filter(text => exportS3MethodRegex.test(text)).length;
|
|
90
|
+
existing.exportPattern += comments.filter(text => exportPatternRegex.test(text)).length;
|
|
91
|
+
}
|
|
92
|
+
function processMatchForDynLib(match) {
|
|
93
|
+
const packageName = match.groups?.package ?? '<unknown>';
|
|
94
|
+
const functions = match.groups?.fn?.trim().split(/\s+/) ?? [];
|
|
95
|
+
if (functions.length === 0) {
|
|
96
|
+
return [packageName];
|
|
97
|
+
}
|
|
98
|
+
else {
|
|
99
|
+
return functions.map(fn => `${JSON.stringify(packageName)},${fn}`);
|
|
100
|
+
}
|
|
101
|
+
}
|
|
102
|
+
function processRoxygenUseDynLib(existing, commentsText, filepath) {
|
|
103
|
+
const result = commentsText.map(text => useDynLibRegex.exec(text))
|
|
104
|
+
.filter(assert_1.isNotNull)
|
|
105
|
+
.flatMap(processMatchForDynLib);
|
|
106
|
+
existing.useDynLib += result.length;
|
|
107
|
+
(0, statistics_file_1.appendStatisticsFile)(exports.comments.name, 'useDynLib', result, filepath, true);
|
|
108
|
+
}
|
|
109
|
+
exports.comments = {
|
|
110
|
+
name: 'Comments',
|
|
111
|
+
description: 'All comments that appear within the document',
|
|
112
|
+
process(existing, input) {
|
|
113
|
+
const comments = commentQuery.select({ node: input.parsedRAst }).map(node => node.textContent ?? '#')
|
|
114
|
+
.map(text => {
|
|
115
|
+
(0, assert_1.guard)(text.startsWith('#'), `unexpected comment ${text}`);
|
|
116
|
+
return text.slice(1);
|
|
117
|
+
})
|
|
118
|
+
.map(text => text.trim());
|
|
119
|
+
existing.totalAmount += comments.length;
|
|
120
|
+
const roxygenComments = comments.filter(text => text.startsWith("'"));
|
|
121
|
+
existing.roxygenComments += roxygenComments.length;
|
|
122
|
+
processRoxygenImport(existing, roxygenComments, input.filepath);
|
|
123
|
+
processRoxygenImportFrom(existing, roxygenComments, input.filepath);
|
|
124
|
+
processRoxygenUseDynLib(existing, roxygenComments, input.filepath);
|
|
125
|
+
processRoxygenImportClassesFrom(existing, roxygenComments, input.filepath);
|
|
126
|
+
processRoxygenImportMethodsFrom(existing, roxygenComments, input.filepath);
|
|
127
|
+
processExports(existing, roxygenComments);
|
|
128
|
+
return existing;
|
|
129
|
+
},
|
|
130
|
+
initialValue: exports.initialCommentInfo,
|
|
131
|
+
postProcess: post_process_1.postProcess
|
|
132
|
+
};
|
|
133
|
+
//# sourceMappingURL=comments.js.map
|
|
@@ -0,0 +1,3 @@
|
|
|
1
|
+
import type { FeatureStatisticsWithMeta } from '../../feature';
|
|
2
|
+
import type { StatisticsSummarizerConfiguration } from '../../../summarizer/summarizer';
|
|
3
|
+
export declare function postProcess(featureRoot: string, info: Map<string, FeatureStatisticsWithMeta>, outputPath: string, config: StatisticsSummarizerConfiguration): void;
|
|
@@ -0,0 +1,49 @@
|
|
|
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.postProcess = void 0;
|
|
7
|
+
const comments_1 = require("./comments");
|
|
8
|
+
const fs_1 = __importDefault(require("fs"));
|
|
9
|
+
const path_1 = __importDefault(require("path"));
|
|
10
|
+
const summarizer_1 = require("../../../../util/summarizer");
|
|
11
|
+
const assert_1 = require("../../../../util/assert");
|
|
12
|
+
// monoids would be helpful :c
|
|
13
|
+
function appendCommentsPostProcessing(a, b, numberOfLines, filepath, skipForProjects) {
|
|
14
|
+
for (const [key, val] of Object.entries(b)) {
|
|
15
|
+
const get = a[key];
|
|
16
|
+
(0, assert_1.guard)(get !== undefined, `key ${key} is not present in the comments post processing`);
|
|
17
|
+
get.count.push(val);
|
|
18
|
+
get.fracOfLines.push(val / numberOfLines);
|
|
19
|
+
if (val > 0) {
|
|
20
|
+
get.uniqueFiles.add(filepath);
|
|
21
|
+
get.uniqueProjects.add(filepath.split(path_1.default.sep)[skipForProjects] ?? '');
|
|
22
|
+
}
|
|
23
|
+
}
|
|
24
|
+
}
|
|
25
|
+
const initialCommentsMeta = () => ({ count: [], uniqueProjects: new Set(), uniqueFiles: new Set(), fracOfLines: [] });
|
|
26
|
+
function mapComments(data, fn) {
|
|
27
|
+
const collected = {};
|
|
28
|
+
for (const [key, value] of Object.entries(data)) {
|
|
29
|
+
collected[key] = fn(value);
|
|
30
|
+
}
|
|
31
|
+
return collected;
|
|
32
|
+
}
|
|
33
|
+
function postProcess(featureRoot, info, outputPath, config) {
|
|
34
|
+
// for each we collect the count and the number of files that contain them
|
|
35
|
+
const collected = mapComments(comments_1.initialCommentInfo, initialCommentsMeta);
|
|
36
|
+
for (const [filepath, feature] of info.entries()) {
|
|
37
|
+
appendCommentsPostProcessing(collected, feature.comments, feature.stats.lines[0].length, filepath, config.projectSkip);
|
|
38
|
+
}
|
|
39
|
+
const fnOutStream = fs_1.default.createWriteStream(path_1.default.join(outputPath, 'comments.csv'));
|
|
40
|
+
fnOutStream.write(`kind,unique-projects,unique-files,${(0, summarizer_1.summarizedMeasurement2CsvHeader)('count')},${(0, summarizer_1.summarizedMeasurement2CsvHeader)('frac-of-lines')}\n`);
|
|
41
|
+
for (const [key, val] of Object.entries(collected)) {
|
|
42
|
+
const { count, uniqueProjects, uniqueFiles, fracOfLines } = val;
|
|
43
|
+
const counts = (0, summarizer_1.summarizeMeasurement)(count);
|
|
44
|
+
const lineFrac = (0, summarizer_1.summarizeMeasurement)(fracOfLines);
|
|
45
|
+
fnOutStream.write(`${JSON.stringify(key)},${uniqueProjects.size},${uniqueFiles.size},${(0, summarizer_1.summarizedMeasurement2Csv)(counts)},${(0, summarizer_1.summarizedMeasurement2Csv)(lineFrac)}\n`);
|
|
46
|
+
}
|
|
47
|
+
}
|
|
48
|
+
exports.postProcess = postProcess;
|
|
49
|
+
//# sourceMappingURL=post-process.js.map
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import type { Feature } from '../../feature';
|
|
2
|
+
import type { Writable } from 'ts-essentials';
|
|
3
|
+
declare const initialControlflowInfo: {
|
|
4
|
+
ifThen: import("../../common-syntax-probability").CommonSyntaxTypeCounts<bigint>;
|
|
5
|
+
thenBody: import("../../common-syntax-probability").CommonSyntaxTypeCounts<bigint>;
|
|
6
|
+
ifThenElse: import("../../common-syntax-probability").CommonSyntaxTypeCounts<bigint>;
|
|
7
|
+
elseBody: import("../../common-syntax-probability").CommonSyntaxTypeCounts<bigint>;
|
|
8
|
+
/** can be nested with if-s or if-then-else's */
|
|
9
|
+
nestedIfThen: number;
|
|
10
|
+
nestedIfThenElse: number;
|
|
11
|
+
deepestNesting: number;
|
|
12
|
+
/** switch(...) */
|
|
13
|
+
switchCase: import("../../common-syntax-probability").CommonSyntaxTypeCounts<bigint>;
|
|
14
|
+
};
|
|
15
|
+
export type ControlflowInfo = Writable<typeof initialControlflowInfo>;
|
|
16
|
+
export declare const controlflow: Feature<ControlflowInfo>;
|
|
17
|
+
export {};
|
|
@@ -0,0 +1,68 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.controlflow = void 0;
|
|
4
|
+
const common_syntax_probability_1 = require("../../common-syntax-probability");
|
|
5
|
+
const post_process_1 = require("./post-process");
|
|
6
|
+
const unpack_argument_1 = require("../../../../dataflow/internal/process/functions/call/argument/unpack-argument");
|
|
7
|
+
const visitor_1 = require("../../../../r-bridge/lang-4.x/ast/model/processing/visitor");
|
|
8
|
+
const initialControlflowInfo = {
|
|
9
|
+
ifThen: (0, common_syntax_probability_1.emptyCommonSyntaxTypeCounts)(),
|
|
10
|
+
thenBody: (0, common_syntax_probability_1.emptyCommonSyntaxTypeCounts)(),
|
|
11
|
+
ifThenElse: (0, common_syntax_probability_1.emptyCommonSyntaxTypeCounts)(),
|
|
12
|
+
elseBody: (0, common_syntax_probability_1.emptyCommonSyntaxTypeCounts)(),
|
|
13
|
+
/** can be nested with if-s or if-then-else's */
|
|
14
|
+
nestedIfThen: 0,
|
|
15
|
+
nestedIfThenElse: 0,
|
|
16
|
+
deepestNesting: 0,
|
|
17
|
+
/** switch(...) */
|
|
18
|
+
switchCase: (0, common_syntax_probability_1.emptyCommonSyntaxTypeCounts)()
|
|
19
|
+
};
|
|
20
|
+
function visitIfThenElse(info, input) {
|
|
21
|
+
const ifThenElseStack = [];
|
|
22
|
+
(0, visitor_1.visitAst)(input.normalizedRAst.ast, node => {
|
|
23
|
+
if (node.type !== "RIfThenElse" /* RType.IfThenElse */) {
|
|
24
|
+
if (node.type === "RFunctionCall" /* RType.FunctionCall */ && node.flavor === 'named' && node.functionName.content === 'switch') {
|
|
25
|
+
const initialArg = (0, unpack_argument_1.unpackArgument)(node.arguments[0]);
|
|
26
|
+
if (initialArg) {
|
|
27
|
+
info.switchCase = (0, common_syntax_probability_1.updateCommonSyntaxTypeCounts)(info.switchCase, initialArg);
|
|
28
|
+
}
|
|
29
|
+
}
|
|
30
|
+
return;
|
|
31
|
+
}
|
|
32
|
+
const ifThenElse = node.otherwise !== undefined;
|
|
33
|
+
if (ifThenElseStack.length > 0) {
|
|
34
|
+
if (ifThenElse) {
|
|
35
|
+
info.nestedIfThenElse++;
|
|
36
|
+
}
|
|
37
|
+
else {
|
|
38
|
+
info.nestedIfThen++;
|
|
39
|
+
}
|
|
40
|
+
info.deepestNesting = Math.max(info.deepestNesting, ifThenElseStack.length);
|
|
41
|
+
}
|
|
42
|
+
ifThenElseStack.push(node);
|
|
43
|
+
info.thenBody = (0, common_syntax_probability_1.updateCommonSyntaxTypeCounts)(info.thenBody, ...node.then.children);
|
|
44
|
+
if (ifThenElse) {
|
|
45
|
+
info.ifThenElse = (0, common_syntax_probability_1.updateCommonSyntaxTypeCounts)(info.ifThenElse, node.condition);
|
|
46
|
+
info.elseBody = (0, common_syntax_probability_1.updateCommonSyntaxTypeCounts)(info.elseBody, ...node.otherwise.children);
|
|
47
|
+
}
|
|
48
|
+
else {
|
|
49
|
+
info.ifThen = (0, common_syntax_probability_1.updateCommonSyntaxTypeCounts)(info.ifThen, node.condition);
|
|
50
|
+
}
|
|
51
|
+
}, node => {
|
|
52
|
+
// drop again :D
|
|
53
|
+
if (node.type === "RIfThenElse" /* RType.IfThenElse */) {
|
|
54
|
+
ifThenElseStack.pop();
|
|
55
|
+
}
|
|
56
|
+
});
|
|
57
|
+
}
|
|
58
|
+
exports.controlflow = {
|
|
59
|
+
name: 'Controlflow',
|
|
60
|
+
description: 'Deals with if-then-else and switch-case',
|
|
61
|
+
process(existing, input) {
|
|
62
|
+
visitIfThenElse(existing, input);
|
|
63
|
+
return existing;
|
|
64
|
+
},
|
|
65
|
+
initialValue: initialControlflowInfo,
|
|
66
|
+
postProcess: post_process_1.postProcess
|
|
67
|
+
};
|
|
68
|
+
//# sourceMappingURL=control-flow.js.map
|
|
@@ -0,0 +1,3 @@
|
|
|
1
|
+
import type { FeatureStatisticsWithMeta } from '../../feature';
|
|
2
|
+
import type { StatisticsSummarizerConfiguration } from '../../../summarizer/summarizer';
|
|
3
|
+
export declare function postProcess(featureRoot: string, info: Map<string, FeatureStatisticsWithMeta>, outputPath: string, config: StatisticsSummarizerConfiguration): void;
|
|
@@ -0,0 +1,64 @@
|
|
|
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.postProcess = void 0;
|
|
7
|
+
const common_syntax_probability_1 = require("../../common-syntax-probability");
|
|
8
|
+
const post_processing_1 = require("../../post-processing");
|
|
9
|
+
const fs_1 = __importDefault(require("fs"));
|
|
10
|
+
const path_1 = __importDefault(require("path"));
|
|
11
|
+
const summarizer_1 = require("../../../../util/summarizer");
|
|
12
|
+
function postProcess(featureRoot, info, outputPath, config) {
|
|
13
|
+
const collected = {
|
|
14
|
+
ifThen: (0, common_syntax_probability_1.emptyCommonSyntaxTypeCounts)(() => []),
|
|
15
|
+
thenBody: (0, common_syntax_probability_1.emptyCommonSyntaxTypeCounts)(() => []),
|
|
16
|
+
ifThenElse: (0, common_syntax_probability_1.emptyCommonSyntaxTypeCounts)(() => []),
|
|
17
|
+
elseBody: (0, common_syntax_probability_1.emptyCommonSyntaxTypeCounts)(() => []),
|
|
18
|
+
nestedIfThen: (0, post_processing_1.emptySummarizedWithProject)(),
|
|
19
|
+
nestedIfThenElse: (0, post_processing_1.emptySummarizedWithProject)(),
|
|
20
|
+
deepestNesting: (0, post_processing_1.emptySummarizedWithProject)(),
|
|
21
|
+
switchCase: (0, common_syntax_probability_1.emptyCommonSyntaxTypeCounts)(() => [])
|
|
22
|
+
};
|
|
23
|
+
for (const [filepath, data] of info.entries()) {
|
|
24
|
+
const value = data.controlflow;
|
|
25
|
+
for (const [key, val] of Object.entries(value)) {
|
|
26
|
+
if (typeof val === 'object') {
|
|
27
|
+
(0, common_syntax_probability_1.appendCommonSyntaxTypeCounter)(collected[key], val);
|
|
28
|
+
}
|
|
29
|
+
else {
|
|
30
|
+
const get = collected[key];
|
|
31
|
+
get.count.push(val);
|
|
32
|
+
if (val > 0) {
|
|
33
|
+
(0, post_processing_1.recordFilePath)(get, filepath, config);
|
|
34
|
+
}
|
|
35
|
+
}
|
|
36
|
+
}
|
|
37
|
+
}
|
|
38
|
+
const metaOut = fs_1.default.createWriteStream(path_1.default.join(outputPath, 'control-flow-meta.csv'));
|
|
39
|
+
metaOut.write(`kind,unique-projects,unique-files,${(0, summarizer_1.summarizedMeasurement2CsvHeader)()}\n`);
|
|
40
|
+
for (const [key, val] of Object.entries(collected)) {
|
|
41
|
+
const data = val;
|
|
42
|
+
if ('uniqueProjects' in data) {
|
|
43
|
+
metaOut.write(`${JSON.stringify(key)},${data.uniqueProjects.size},${data.uniqueFiles.size},${(0, summarizer_1.summarizedMeasurement2Csv)((0, summarizer_1.summarizeMeasurement)(data.count))}\n`);
|
|
44
|
+
}
|
|
45
|
+
else {
|
|
46
|
+
const out = fs_1.default.createWriteStream(path_1.default.join(outputPath, `control-flow-type-${key}.csv`));
|
|
47
|
+
// name is for fields like number etc. to allow to group multiple entries
|
|
48
|
+
out.write(`kind,name,${(0, summarizer_1.summarizedMeasurement2CsvHeader)()}\n`);
|
|
49
|
+
for (const [name, vals] of Object.entries(data)) {
|
|
50
|
+
if (Array.isArray(vals)) {
|
|
51
|
+
out.write(`${JSON.stringify(name)},"",${(0, summarizer_1.summarizedMeasurement2Csv)((0, summarizer_1.summarizeMeasurement)(vals.flat()))}\n`);
|
|
52
|
+
}
|
|
53
|
+
else {
|
|
54
|
+
for (const [keyName, keyValue] of Object.entries(vals)) {
|
|
55
|
+
out.write(`${JSON.stringify(name)},${JSON.stringify(keyName)},${(0, summarizer_1.summarizedMeasurement2Csv)((0, summarizer_1.summarizeMeasurement)(keyValue.flat()))}\n`);
|
|
56
|
+
}
|
|
57
|
+
}
|
|
58
|
+
}
|
|
59
|
+
out.close();
|
|
60
|
+
}
|
|
61
|
+
}
|
|
62
|
+
}
|
|
63
|
+
exports.postProcess = postProcess;
|
|
64
|
+
//# sourceMappingURL=post-process.js.map
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import type { Feature } from '../../feature';
|
|
2
|
+
import type { Writable } from 'ts-essentials';
|
|
3
|
+
import type { CommonSyntaxTypeCounts } from '../../common-syntax-probability';
|
|
4
|
+
declare const initialDataAccessInfo: {
|
|
5
|
+
singleBracket: Record<number, bigint | CommonSyntaxTypeCounts<bigint>>;
|
|
6
|
+
doubleBracket: Record<number, bigint | CommonSyntaxTypeCounts<bigint>>;
|
|
7
|
+
chainedOrNestedAccess: number;
|
|
8
|
+
longestChain: number;
|
|
9
|
+
deepestNesting: number;
|
|
10
|
+
byName: number;
|
|
11
|
+
bySlot: number;
|
|
12
|
+
};
|
|
13
|
+
export type DataAccessInfo = Writable<typeof initialDataAccessInfo>;
|
|
14
|
+
export declare const dataAccess: Feature<DataAccessInfo>;
|
|
15
|
+
export {};
|
|
@@ -0,0 +1,120 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.dataAccess = void 0;
|
|
4
|
+
const common_syntax_probability_1 = require("../../common-syntax-probability");
|
|
5
|
+
const post_process_1 = require("./post-process");
|
|
6
|
+
const assert_1 = require("../../../../util/assert");
|
|
7
|
+
const visitor_1 = require("../../../../r-bridge/lang-4.x/ast/model/processing/visitor");
|
|
8
|
+
const role_1 = require("../../../../r-bridge/lang-4.x/ast/model/processing/role");
|
|
9
|
+
const statistics_file_1 = require("../../../output/statistics-file");
|
|
10
|
+
const r_function_call_1 = require("../../../../r-bridge/lang-4.x/ast/model/nodes/r-function-call");
|
|
11
|
+
const initialDataAccessInfo = {
|
|
12
|
+
// for the nth argument, how many of them are constant, etc.
|
|
13
|
+
singleBracket: {
|
|
14
|
+
// only counts if empty
|
|
15
|
+
0: 0n,
|
|
16
|
+
1: (0, common_syntax_probability_1.emptyCommonSyntaxTypeCounts)()
|
|
17
|
+
},
|
|
18
|
+
doubleBracket: {
|
|
19
|
+
// similar to single bracket
|
|
20
|
+
0: 0n,
|
|
21
|
+
1: (0, common_syntax_probability_1.emptyCommonSyntaxTypeCounts)()
|
|
22
|
+
},
|
|
23
|
+
chainedOrNestedAccess: 0,
|
|
24
|
+
longestChain: 0,
|
|
25
|
+
deepestNesting: 0,
|
|
26
|
+
byName: 0,
|
|
27
|
+
bySlot: 0,
|
|
28
|
+
};
|
|
29
|
+
function classifyArguments(args, existing) {
|
|
30
|
+
if (args.length === 0) {
|
|
31
|
+
existing[0]++;
|
|
32
|
+
return;
|
|
33
|
+
}
|
|
34
|
+
let i = 1;
|
|
35
|
+
for (const arg of args) {
|
|
36
|
+
if (arg === null || arg === undefined || arg === r_function_call_1.EmptyArgument) {
|
|
37
|
+
existing[0]++;
|
|
38
|
+
continue;
|
|
39
|
+
}
|
|
40
|
+
existing[i] = (0, common_syntax_probability_1.updateCommonSyntaxTypeCounts)(existing[i] ?? (0, common_syntax_probability_1.emptyCommonSyntaxTypeCounts)(), arg);
|
|
41
|
+
i++;
|
|
42
|
+
}
|
|
43
|
+
}
|
|
44
|
+
function visitAccess(info, input) {
|
|
45
|
+
const accessNest = [];
|
|
46
|
+
const accessChain = [];
|
|
47
|
+
const parentRoleCache = new Map();
|
|
48
|
+
(0, visitor_1.visitAst)(input.normalizedRAst.ast, node => {
|
|
49
|
+
if (node.type !== "RAccess" /* RType.Access */) {
|
|
50
|
+
return;
|
|
51
|
+
}
|
|
52
|
+
const roles = (0, role_1.rolesOfParents)(node, input.normalizedRAst.idMap);
|
|
53
|
+
let acc = false;
|
|
54
|
+
let idxAcc = false;
|
|
55
|
+
for (const role of roles) {
|
|
56
|
+
if (role === "accessed" /* RoleInParent.Accessed */) {
|
|
57
|
+
acc = true;
|
|
58
|
+
break; // we only account for the first one
|
|
59
|
+
}
|
|
60
|
+
else if (role === "index-access" /* RoleInParent.IndexAccess */) {
|
|
61
|
+
idxAcc = true;
|
|
62
|
+
break;
|
|
63
|
+
}
|
|
64
|
+
}
|
|
65
|
+
// here we have to check after the addition as we can only check the parental context
|
|
66
|
+
if (acc) {
|
|
67
|
+
accessChain.push(node);
|
|
68
|
+
info.chainedOrNestedAccess++;
|
|
69
|
+
info.longestChain = Math.max(info.longestChain, accessChain.length);
|
|
70
|
+
}
|
|
71
|
+
else if (idxAcc) {
|
|
72
|
+
accessNest.push(node);
|
|
73
|
+
info.chainedOrNestedAccess++;
|
|
74
|
+
info.deepestNesting = Math.max(info.deepestNesting, accessNest.length);
|
|
75
|
+
}
|
|
76
|
+
parentRoleCache.set(node.info.id, { acc, idxAcc });
|
|
77
|
+
if (accessNest.length === 0 && accessChain.length === 0) { // store topmost, after add as it must not be a child to do that
|
|
78
|
+
(0, statistics_file_1.appendStatisticsFile)(exports.dataAccess.name, 'dataAccess', [node.info.fullLexeme ?? node.lexeme], input.filepath);
|
|
79
|
+
}
|
|
80
|
+
const op = node.operator;
|
|
81
|
+
switch (op) {
|
|
82
|
+
case '@':
|
|
83
|
+
info.bySlot++;
|
|
84
|
+
return;
|
|
85
|
+
case '$':
|
|
86
|
+
info.byName++;
|
|
87
|
+
return;
|
|
88
|
+
case '[':
|
|
89
|
+
classifyArguments(node.access, info.singleBracket);
|
|
90
|
+
break;
|
|
91
|
+
case '[[':
|
|
92
|
+
classifyArguments(node.access, info.doubleBracket);
|
|
93
|
+
break;
|
|
94
|
+
default: (0, assert_1.assertUnreachable)(op);
|
|
95
|
+
}
|
|
96
|
+
(0, assert_1.guard)(Array.isArray(node.access), '[ and [[ must provide access as array');
|
|
97
|
+
}, node => {
|
|
98
|
+
// drop again :D
|
|
99
|
+
if (node.type === "RAccess" /* RType.Access */) {
|
|
100
|
+
const ctx = parentRoleCache.get(node.info.id);
|
|
101
|
+
if (ctx?.acc) {
|
|
102
|
+
accessChain.pop();
|
|
103
|
+
}
|
|
104
|
+
else if (ctx?.idxAcc) {
|
|
105
|
+
accessNest.pop();
|
|
106
|
+
}
|
|
107
|
+
}
|
|
108
|
+
});
|
|
109
|
+
}
|
|
110
|
+
exports.dataAccess = {
|
|
111
|
+
name: 'Data Access',
|
|
112
|
+
description: 'Ways of accessing data structures in R',
|
|
113
|
+
process(existing, input) {
|
|
114
|
+
visitAccess(existing, input);
|
|
115
|
+
return existing;
|
|
116
|
+
},
|
|
117
|
+
initialValue: initialDataAccessInfo,
|
|
118
|
+
postProcess: post_process_1.postProcess
|
|
119
|
+
};
|
|
120
|
+
//# sourceMappingURL=data-access.js.map
|
|
@@ -0,0 +1,3 @@
|
|
|
1
|
+
import type { FeatureStatisticsWithMeta } from '../../feature';
|
|
2
|
+
import type { StatisticsSummarizerConfiguration } from '../../../summarizer/summarizer';
|
|
3
|
+
export declare function postProcess(featureRoot: string, info: Map<string, FeatureStatisticsWithMeta>, outputPath: string, config: StatisticsSummarizerConfiguration): void;
|
|
@@ -0,0 +1,106 @@
|
|
|
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.postProcess = void 0;
|
|
7
|
+
const common_syntax_probability_1 = require("../../common-syntax-probability");
|
|
8
|
+
const post_processing_1 = require("../../post-processing");
|
|
9
|
+
const fs_1 = __importDefault(require("fs"));
|
|
10
|
+
const path_1 = __importDefault(require("path"));
|
|
11
|
+
const numbers_1 = require("../../../../util/numbers");
|
|
12
|
+
const summarizer_1 = require("../../../../util/summarizer");
|
|
13
|
+
function addToList(data, dataAccess, filepath, config) {
|
|
14
|
+
data.count.push(dataAccess);
|
|
15
|
+
if (dataAccess > 0) {
|
|
16
|
+
(0, post_processing_1.recordFilePath)(data, filepath, config);
|
|
17
|
+
}
|
|
18
|
+
}
|
|
19
|
+
function summarizeForBracket(dataAccess, data, filepath, config) {
|
|
20
|
+
for (const [key, val] of Object.entries(dataAccess)) {
|
|
21
|
+
const numericKey = Number(key);
|
|
22
|
+
const get = data.get(numericKey) ?? (0, common_syntax_probability_1.emptyCommonSyntaxTypeCounts)(() => []);
|
|
23
|
+
if (typeof val === 'bigint' || typeof val === 'string') {
|
|
24
|
+
// it is for argument 0
|
|
25
|
+
const sumGet = get;
|
|
26
|
+
const numericVal = (0, numbers_1.bigint2number)(val);
|
|
27
|
+
sumGet.count.push(numericVal);
|
|
28
|
+
if (numericVal > 0) {
|
|
29
|
+
(0, post_processing_1.recordFilePath)(sumGet, filepath, config);
|
|
30
|
+
}
|
|
31
|
+
}
|
|
32
|
+
else {
|
|
33
|
+
(0, common_syntax_probability_1.appendCommonSyntaxTypeCounter)(get, val);
|
|
34
|
+
}
|
|
35
|
+
data.set(numericKey, get);
|
|
36
|
+
}
|
|
37
|
+
}
|
|
38
|
+
function writeSingleOrDoubleEmpty(outputPath, key, name, vals) {
|
|
39
|
+
const out = fs_1.default.createWriteStream(path_1.default.join(outputPath, `data-access-type-${key}-${name}.csv`));
|
|
40
|
+
// name is for fields like number etc. to allow to group multiple entries
|
|
41
|
+
out.write(`kind,unique-projects,unique-files,${(0, summarizer_1.summarizedMeasurement2CsvHeader)()}\n`);
|
|
42
|
+
out.write(`"0",${vals.uniqueProjects.size},${vals.uniqueFiles.size},${(0, summarizer_1.summarizedMeasurement2Csv)((0, summarizer_1.summarizeMeasurement)(vals.count))}\n`);
|
|
43
|
+
out.close();
|
|
44
|
+
}
|
|
45
|
+
function writeSingleOrDoubleBrackets(data, outputPath, key) {
|
|
46
|
+
for (const [name, vals] of data.entries()) {
|
|
47
|
+
// the 0 column
|
|
48
|
+
if ('uniqueProjects' in vals) {
|
|
49
|
+
writeSingleOrDoubleEmpty(outputPath, key, name, vals);
|
|
50
|
+
}
|
|
51
|
+
else {
|
|
52
|
+
// non-0-column
|
|
53
|
+
const out = fs_1.default.createWriteStream(path_1.default.join(outputPath, `data-access-type-${key}-${name}.csv`));
|
|
54
|
+
// name is for fields like number etc. to allow to group multiple entries
|
|
55
|
+
out.write(`kind,name,${(0, summarizer_1.summarizedMeasurement2CsvHeader)()}\n`);
|
|
56
|
+
for (const [entryName, values] of Object.entries(vals)) {
|
|
57
|
+
if (Array.isArray(values)) {
|
|
58
|
+
out.write(`${JSON.stringify(entryName)},"",${(0, summarizer_1.summarizedMeasurement2Csv)((0, summarizer_1.summarizeMeasurement)(values.flat()))}\n`);
|
|
59
|
+
}
|
|
60
|
+
else {
|
|
61
|
+
for (const [keyName, keyValue] of Object.entries(values)) {
|
|
62
|
+
out.write(`${JSON.stringify(entryName)},${JSON.stringify(keyName)},${(0, summarizer_1.summarizedMeasurement2Csv)((0, summarizer_1.summarizeMeasurement)(keyValue.flat()))}\n`);
|
|
63
|
+
}
|
|
64
|
+
}
|
|
65
|
+
}
|
|
66
|
+
out.close();
|
|
67
|
+
}
|
|
68
|
+
}
|
|
69
|
+
}
|
|
70
|
+
function postProcess(featureRoot, info, outputPath, config) {
|
|
71
|
+
const summarize = {
|
|
72
|
+
singleBracket: new Map(),
|
|
73
|
+
doubleBracket: new Map(),
|
|
74
|
+
chainedOrNestedAccess: (0, post_processing_1.emptySummarizedWithProject)(),
|
|
75
|
+
longestChain: (0, post_processing_1.emptySummarizedWithProject)(),
|
|
76
|
+
deepestNesting: (0, post_processing_1.emptySummarizedWithProject)(),
|
|
77
|
+
byName: (0, post_processing_1.emptySummarizedWithProject)(),
|
|
78
|
+
bySlot: (0, post_processing_1.emptySummarizedWithProject)()
|
|
79
|
+
};
|
|
80
|
+
// initialize the special 0
|
|
81
|
+
summarize.singleBracket.set(0, (0, post_processing_1.emptySummarizedWithProject)());
|
|
82
|
+
summarize.doubleBracket.set(0, (0, post_processing_1.emptySummarizedWithProject)());
|
|
83
|
+
for (const [filepath, value] of info.entries()) {
|
|
84
|
+
const dataAccess = value.dataAccess;
|
|
85
|
+
addToList(summarize.chainedOrNestedAccess, dataAccess.chainedOrNestedAccess, filepath, config);
|
|
86
|
+
addToList(summarize.longestChain, dataAccess.longestChain, filepath, config);
|
|
87
|
+
addToList(summarize.deepestNesting, dataAccess.deepestNesting, filepath, config);
|
|
88
|
+
addToList(summarize.byName, dataAccess.byName, filepath, config);
|
|
89
|
+
addToList(summarize.bySlot, dataAccess.bySlot, filepath, config);
|
|
90
|
+
summarizeForBracket(dataAccess.singleBracket, summarize.singleBracket, filepath, config);
|
|
91
|
+
summarizeForBracket(dataAccess.doubleBracket, summarize.doubleBracket, filepath, config);
|
|
92
|
+
}
|
|
93
|
+
const metaOut = fs_1.default.createWriteStream(path_1.default.join(outputPath, 'data-access-meta.csv'));
|
|
94
|
+
metaOut.write(`kind,unique-projects,unique-files,${(0, summarizer_1.summarizedMeasurement2CsvHeader)()}\n`);
|
|
95
|
+
for (const [key, value] of Object.entries(summarize)) {
|
|
96
|
+
const data = value;
|
|
97
|
+
if ('uniqueProjects' in data) {
|
|
98
|
+
metaOut.write(`${JSON.stringify(key)},${data.uniqueProjects.size},${data.uniqueFiles.size},${(0, summarizer_1.summarizedMeasurement2Csv)((0, summarizer_1.summarizeMeasurement)(data.count))}\n`);
|
|
99
|
+
continue;
|
|
100
|
+
}
|
|
101
|
+
writeSingleOrDoubleBrackets(data, outputPath, key);
|
|
102
|
+
}
|
|
103
|
+
metaOut.close();
|
|
104
|
+
}
|
|
105
|
+
exports.postProcess = postProcess;
|
|
106
|
+
//# sourceMappingURL=post-process.js.map
|
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
import type { Feature } from '../../feature';
|
|
2
|
+
import type { Writable } from 'ts-essentials';
|
|
3
|
+
import type { MergeableRecord } from '../../../../util/objects';
|
|
4
|
+
import type { SourcePosition } from '../../../../util/range';
|
|
5
|
+
declare const initialFunctionDefinitionInfo: {
|
|
6
|
+
/** all, anonymous, assigned, non-assigned, ... */
|
|
7
|
+
total: number;
|
|
8
|
+
/** how many are really using OP-Lambda? */
|
|
9
|
+
lambdasOnly: number;
|
|
10
|
+
/** using `<<-`, `<-`, `=`, `->` `->>` */
|
|
11
|
+
assignedFunctions: number;
|
|
12
|
+
nestedFunctions: number;
|
|
13
|
+
/** functions that in some easily detectable way call themselves */
|
|
14
|
+
recursive: number;
|
|
15
|
+
deepestNesting: number;
|
|
16
|
+
};
|
|
17
|
+
export type FunctionDefinitionInfo = Writable<typeof initialFunctionDefinitionInfo>;
|
|
18
|
+
export declare const AllDefinitionsFileBase = "all-definitions";
|
|
19
|
+
export interface SingleFunctionDefinitionInformation extends MergeableRecord {
|
|
20
|
+
location: SourcePosition;
|
|
21
|
+
/** locations of all direct call sites */
|
|
22
|
+
callsites: SourcePosition[];
|
|
23
|
+
numberOfParameters: number;
|
|
24
|
+
returns: {
|
|
25
|
+
location: SourcePosition;
|
|
26
|
+
}[];
|
|
27
|
+
length: {
|
|
28
|
+
lines: number;
|
|
29
|
+
characters: number;
|
|
30
|
+
nonWhitespaceCharacters: number;
|
|
31
|
+
};
|
|
32
|
+
}
|
|
33
|
+
export declare const definedFunctions: Feature<FunctionDefinitionInfo>;
|
|
34
|
+
export {};
|