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 | 1x 1x 1x 1x 1x 1x 1x 1x 1x 1x 1x 1x 17x 17x 17x 17x 17x 17x 2x 4x 4x 2x 17x 17x 1x 1x 1x 1x 17x 17x 17x 17x 17x 17x 17x 1x 1x 16x 16x 17x 16x 16x 16x 16x 17x 2x 2x 2x 2x 14x 14x 14x 14x 14x 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"; 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)) { new Target().runSyntax(s, input); } } for (const t of node.findDirectExpressions(Expressions.PerformTables)) { for (const s of t.findDirectExpressions(Expressions.Source)) { new Source().runSyntax(s, input); } } for (const u of node.findDirectExpressions(Expressions.PerformUsing)) { for (const s of u.findDirectExpressions(Expressions.Source)) { new Source().runSyntax(s, input); } } //////////////////////////// // find FORM definition if (node.findFirstExpression(Expressions.IncludeName)) { return; // in external program, not checked, todo } if (node.findFirstExpression(Expressions.Dynamic)) { 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 } } |