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 | 1x 1x 1x 1x 1x 1x 1x 1x 1x 1x 1x 9x 9x 9x 1x 1x 1x 9x 8x 9x 1x 1x 1x 1x 7x 7x 7x 7x 9x 7x 7x 7x 7x 7x 7x 1x | import * as Expressions from "../../2_statements/expressions"; import {StatementNode} from "../../nodes"; import {TypedIdentifier} from "../../types/_typed_identifier"; import {UnknownType, VoidType} from "../../types/basic"; import {BasicTypes} from "../basic_types"; import {StatementSyntax} from "../_statement_syntax"; import {SyntaxInput, syntaxIssue} from "../_syntax_input"; import {Identifier} from "../../1_lexer/tokens"; export class Parameter implements StatementSyntax { public runSyntax(node: StatementNode, input: SyntaxInput): void { const nameToken = node.findFirstExpression(Expressions.FieldSub)?.getFirstToken(); if (nameToken && nameToken.getStr().length > 8) { const message = "Parameter name too long, " + nameToken.getStr(); input.issues.push(syntaxIssue(input, node.getFirstToken(), message)); return; } else if (nameToken === undefined) { return; } if (node.findDirectTokenByText("RADIOBUTTON") && node.findDirectTokenByText("LENGTH")) { const message = "RADIOBUTTON and LENGTH not possible together"; input.issues.push(syntaxIssue(input, node.getFirstToken(), message)); return; } const bfound = new BasicTypes(input).parseType(node); if (bfound) { input.scope.addIdentifier(new TypedIdentifier(nameToken, input.filename, bfound)); } else { input.scope.addIdentifier(new TypedIdentifier(nameToken, input.filename, new UnknownType("Parameter, fallback"))); } const magicName = "%_" + nameToken.getStr() + "_%_app_%"; const magicToken = new Identifier(nameToken.getStart(), magicName); input.scope.addIdentifier(new TypedIdentifier(magicToken, input.filename, new VoidType("PARAMETER magic"))); } } |