Press n or j to go to the next uncovered block, b, p or k for the previous block.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 | 1x 1x 1x 1x 1x 1x 1x 1x 1x 1x 1x 1x 1x 19x 19x 19x 19x 19x 19x 2x 4x 4x 2x 19x 19x 1x 1x 1x 1x 19x 19x 19x 19x 19x 19x 19x 19x 2x 2x 2x 17x 17x 19x 17x 17x 17x 17x 19x 2x 2x 2x 2x 15x 15x 15x 15x 15x 1x | import * as Expressions from "../../2_statements/expressions"; import * as Statements from "../../2_statements/statements"; import {StatementNode} from "../../nodes"; import {ReferenceType} from "../_reference"; import {Source} from "../expressions/source"; import {StatementSyntax} from "../_statement_syntax"; import {Target} from "../expressions/target"; import {SyntaxInput, syntaxIssue} from "../_syntax_input"; import {AssertError} from "../assert_error"; import {Dynamic} from "../expressions/dynamic"; export class Perform implements StatementSyntax { public runSyntax(node: StatementNode, input: SyntaxInput): void { if (!(node.get() instanceof Statements.Perform)) { throw new AssertError("checkPerform unexpected node type"); } //////////////////////////// // check parameters are defined for (const c of node.findDirectExpressions(Expressions.PerformChanging)) { for (const s of c.findDirectExpressions(Expressions.Target)) { Target.runSyntax(s, input); } } for (const t of node.findDirectExpressions(Expressions.PerformTables)) { for (const s of t.findDirectExpressions(Expressions.Source)) { Source.runSyntax(s, input); } } for (const u of node.findDirectExpressions(Expressions.PerformUsing)) { for (const s of u.findDirectExpressions(Expressions.Source)) { Source.runSyntax(s, input); } } //////////////////////////// // find FORM definition if (node.findFirstExpression(Expressions.IncludeName)) { return; // in external program, not checked, todo } const dynamic = node.findFirstExpression(Expressions.Dynamic); if (dynamic) { Dynamic.runSyntax(dynamic, input); return; // todo, maybe some parts can be checked } const expr = node.findFirstExpression(Expressions.FormName); if (expr === undefined) { return; // it might be a dynamic call } const name = expr.concatTokens(); const found = input.scope.findFormDefinition(name); if (found === undefined) { const message = "FORM definition \"" + name + "\" not found"; input.issues.push(syntaxIssue(input, expr.getFirstToken(), message)); return; } input.scope.addReference(expr.getFirstToken(), found, ReferenceType.FormReference, input.filename); // todo, also check parameters match } } |