Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Feat: Follow up on source calls #609

Merged
merged 51 commits into from
Feb 7, 2024
Merged
Show file tree
Hide file tree
Changes from 3 commits
Commits
Show all changes
51 commits
Select commit Hold shift + click to select a range
b11decd
wip: added testfile & started on environment (??)
Ellpeck Jan 22, 2024
006aa10
wip: some todos
Ellpeck Jan 22, 2024
e5268f5
wip: start of source argument resolve
Ellpeck Jan 22, 2024
969815e
wip: added testfile & started on environment (??)
Ellpeck Jan 22, 2024
50a461b
wip: some todos
Ellpeck Jan 22, 2024
552bf5d
wip: start of source argument resolve
Ellpeck Jan 22, 2024
74d71da
Merge remote-tracking branch 'origin/605-feat-follow-up-on-source-cal…
Ellpeck Jan 25, 2024
df033ab
refactor: start using sync r shell implementation
Ellpeck Jan 25, 2024
97761a7
wip: rebase
Ellpeck Jan 22, 2024
e6ec40f
refactor: start using sync r shell implementation
Ellpeck Jan 25, 2024
7f5a006
Merge remote-tracking branch 'origin/605-feat-follow-up-on-source-cal…
Ellpeck Jan 25, 2024
c1d1346
wip: use executeSingleSubStep for parsing sourced code
Ellpeck Jan 25, 2024
1eae7f6
wip: added testfile & started on environment (??)
Ellpeck Jan 22, 2024
a88f8bb
wip: some todos
Ellpeck Jan 22, 2024
83cb725
wip: start of source argument resolve
Ellpeck Jan 22, 2024
10699e8
wip: rebase
Ellpeck Jan 22, 2024
5f4f31e
refactor: start using sync r shell implementation
Ellpeck Jan 25, 2024
559d80c
wip: some todos
Ellpeck Jan 22, 2024
061aaea
wip: use executeSingleSubStep for parsing sourced code
Ellpeck Jan 25, 2024
3d74428
Merge remote-tracking branch 'origin/605-feat-follow-up-on-source-cal…
Ellpeck Jan 30, 2024
4f9e9ea
wip: fix merge issues
Ellpeck Jan 30, 2024
a0f8f00
feat-fix: avoid cyclic dependency when using step executor
Ellpeck Jan 30, 2024
9fc51f0
wip: run normalize and dataflow on sourced file
Ellpeck Jan 30, 2024
32b049e
wip: some work on source dataflowing
Ellpeck Jan 31, 2024
0392ad6
refactor: remove print
Ellpeck Jan 31, 2024
ac7eb1d
Merge branch 'main' into 605-feat-follow-up-on-source-calls
EagleoutIce Feb 1, 2024
b7add0c
refactor: clean up todos and move source to its own function
Ellpeck Feb 1, 2024
92c96ac
Merge remote-tracking branch 'origin/605-feat-follow-up-on-source-cal…
Ellpeck Feb 1, 2024
787fe00
refactor: explicitly as in processSourceCall
Ellpeck Feb 1, 2024
197c418
refactor: damn u typescript
Ellpeck Feb 1, 2024
136a8eb
feat-fix: ensure we only parse built-in source calls
Ellpeck Feb 1, 2024
f335eee
refactor: remove todo
Ellpeck Feb 1, 2024
1bdbe44
feat: allow overriding the source file provider
Ellpeck Feb 1, 2024
019d49c
test: start on source tests
Ellpeck Feb 1, 2024
345bf4c
refactor: overhaul source providers
Ellpeck Feb 1, 2024
7507a18
refactor: generify source providers to RParseRequestProvider
Ellpeck Feb 1, 2024
911d349
test: added test for conditional source
Ellpeck Feb 5, 2024
ba6dce2
refactor: properly handle missing/invalid sourced files
Ellpeck Feb 5, 2024
48c7928
wip: test for recursive sources
Ellpeck Feb 5, 2024
3f21bcf
feat: skip dataflow analysis for re-sourced references
Ellpeck Feb 5, 2024
53d69de
wip: add another todo
Ellpeck Feb 5, 2024
c0eb3fc
refactor: use parse requests in dataflow processor info
Ellpeck Feb 6, 2024
5bc6d08
refactor: first pass of reference chain impl
Ellpeck Feb 6, 2024
56a4047
feat-fix: also catch normalize and dataflow errors
Ellpeck Feb 6, 2024
11b625b
test: finished recursive source test
Ellpeck Feb 6, 2024
85dd0fd
test: added test for non-constant source argument
Ellpeck Feb 6, 2024
0c239af
test: added multi-source test
Ellpeck Feb 6, 2024
f6323c6
feat-fix: sourcing multiple files works correctly now
Ellpeck Feb 6, 2024
03b4618
refactor: resolve review comments
Ellpeck Feb 7, 2024
d1ea24a
test: reset the source provider to the default value after each describe
Ellpeck Feb 7, 2024
b5ddd9a
test-fix: reset the source provider in the source describe instead
Ellpeck Feb 7, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
9 changes: 9 additions & 0 deletions src/dataflow/environments/environment.ts
Original file line number Diff line number Diff line change
Expand Up @@ -145,6 +145,15 @@ export const DefaultEnvironmentMemory = new Map<Identifier, IdentifierDefinition
definedAt: BuiltIn,
name: 'print',
nodeId: BuiltIn
}]],
// TODO is this the correct definition for source?
Ellpeck marked this conversation as resolved.
Show resolved Hide resolved
['source', [{
kind: 'built-in-function',
scope: GlobalScope,
used: 'always',
definedAt: BuiltIn,
name: 'source',
nodeId: BuiltIn
}]]
])

Expand Down
25 changes: 23 additions & 2 deletions src/dataflow/internal/process/functions/function-call.ts
Original file line number Diff line number Diff line change
@@ -1,11 +1,12 @@
import { DataflowInformation } from '../../info'
import { DataflowProcessorInformation, processDataflowFor } from '../../../processor'
import { define, overwriteEnvironments, resolveByName } from '../../../environments'
import { ParentInformation, RFunctionCall, RType } from '../../../../r-bridge'
import {ParentInformation, RFunctionCall, RParseRequest, RShell, RType} from '../../../../r-bridge'
import { guard } from '../../../../util/assert'
import { DataflowGraph, dataflowLogger, EdgeType, FunctionArgument } from '../../../index'
import { linkArgumentsOnCall } from '../../linker'
import { LocalScope } from '../../../environments/scopes'
import {SteppingSlicer} from '../../../../core'

export const UnnamedFunctionCallPrefix = 'unnamed-function-call-'

Expand Down Expand Up @@ -37,7 +38,6 @@ export function processFunctionCall<OtherInfo>(functionCall: RFunctionCall<Other
finalGraph.mergeWith(functionName.graph)
}


for(const arg of functionCall.arguments) {
if(arg === undefined) {
callArgs.push('empty')
Expand Down Expand Up @@ -104,6 +104,27 @@ export function processFunctionCall<OtherInfo>(functionCall: RFunctionCall<Other
inIds.push(...functionName.in, ...functionName.unknownReferences)
}

if(named && functionCallName == 'source') {
Ellpeck marked this conversation as resolved.
Show resolved Hide resolved
const sourceFile = functionCall.arguments[0]
Ellpeck marked this conversation as resolved.
Show resolved Hide resolved
if(sourceFile?.value?.type == RType.String) {
const request: RParseRequest = {
request: 'file',
content: sourceFile.lexeme,
// TODO what does this do
ensurePackageInstalled: true
Ellpeck marked this conversation as resolved.
Show resolved Hide resolved
}
// TODO is this how to get a shell for this?
const shell = new RShell()
const slicer = new SteppingSlicer({
Ellpeck marked this conversation as resolved.
Show resolved Hide resolved
stepOfInterest: 'normalize',
criterion: [],
shell, request
})
console.log(slicer)
shell.close()
}
}

return {
unknownReferences: [],
in: inIds,
Expand Down
4 changes: 4 additions & 0 deletions test/testfiles/source.R
Original file line number Diff line number Diff line change
@@ -0,0 +1,4 @@
source("example.R")

cat("-----\n")
cat("Sourced N:", N, "\n")
Loading