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 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 | 1x 1x 1x 1x 1x 1x 1x 1x 1x 1x 1x 1x 1x 1x 1x 91x 91x 91x 3x 3x 3x 88x 88x 88x 88x 88x 88x 91x 295x 295x 110x 110x 110x 110x 2x 2x 110x 295x 1x 1x 1x 1x 185x 88x 17x 17x 184x 13x 13x 13x 13x 13x 13x 13x 13x 13x 13x 13x 13x 13x 13x 13x 13x 13x 13x 13x 13x 13x 13x 13x 13x 13x 13x 13x 13x 13x 13x 13x 13x 13x 13x 13x 13x 13x 13x 13x 13x 13x 13x 13x 5x 2x 2x 5x 3x 3x 5x 8x 13x 11x 11x 8x 295x 83x 91x 15x 15x 91x 68x 68x 68x 91x 1x 1x 3x 9x 9x 1x 1x 1x 1x 9x 8x 1x 1x 1x 1x 8x 1x 1x 1x 1x 1x 9x 3x 1x | import {SyntaxInput} from "../_syntax_input"; import {Data as DataSyntax} from "../statements/data"; import {IStructureComponent} from "../../types/basic"; import {StatementNode, StructureNode, TokenNode} from "../../nodes"; import {Type} from "../statements/type"; import {TypedIdentifier} from "../../types/_typed_identifier"; import {Types} from "./types"; import * as Basic from "../../types/basic"; import * as Expressions from "../../2_statements/expressions"; import * as Statements from "../../2_statements/statements"; import * as Structures from "../../3_structures/structures"; import {IncludeType} from "../statements/include_type"; export class Data { public static runSyntax(node: StructureNode, input: SyntaxInput): TypedIdentifier | undefined { const fouth = node.getFirstChild()?.getChildren()[3]; const isCommonPart = fouth instanceof TokenNode && fouth.concatTokens() === "COMMON"; if (isCommonPart) { this.runCommonPartSyntax(node, input); return undefined; } const name = node.findFirstExpression(Expressions.DefinitionName)!.getFirstToken(); let table: boolean = false; const values: {[index: string]: string} = {}; const components: IStructureComponent[] = []; for (const c of node.getChildren()) { const ctyp = c.get(); if (c instanceof StatementNode && ctyp instanceof Statements.Data) { const found = new DataSyntax().runSyntax(c, input); if (found) { components.push({name: found.getName(), type: found.getType()}); if (found.getValue() !== undefined) { values[found.getName()] = found.getValue() as string; } } } else if (c instanceof StructureNode && ctyp instanceof Structures.Data) { const found = Data.runSyntax(c, input); if (found) { components.push({name: found.getName(), type: found.getType()}); } } else if (c instanceof StatementNode && ctyp instanceof Statements.DataBegin) { if (c.findDirectTokenByText("OCCURS")) { table = true; } } else if (c instanceof StatementNode && ctyp instanceof Statements.IncludeType) { // INCLUDES /* const typeToken = c.findFirstExpression(Expressions.TypeName)?.getFirstToken(); const typeName = typeToken?.getStr(); let foundId = input.scope.findType(typeName); if (foundId === undefined) { foundId = input.scope.findVariable(typeName); } let found = foundId?.getType(); if (found === undefined) { const f = input.scope.getDDIC().lookupTableOrView(typeName).type; if (f instanceof TypedIdentifier) { found = f.getType(); } else { found = f; } } else { input.scope.addReference(typeToken, foundId, ReferenceType.TypeReference, input.filename); } if (found instanceof Basic.VoidType) { if (table === true) { const ttyp = new Basic.TableType(found, {withHeader: true, keyType: Basic.TableKeyType.default}); return new TypedIdentifier(name, input.filename, ttyp); } else { return new TypedIdentifier(name, input.filename, found); } } if (found instanceof Basic.UnknownType) { return new TypedIdentifier(name, input.filename, new Basic.UnknownType("unknown type, " + typeName)); } if (found instanceof Basic.TableType && found.isWithHeader()) { found = found.getRowType(); } if (!(found instanceof Basic.StructureType)) { const message = "not structured, " + typeName; input.issues.push(syntaxIssue(input, typeToken!, message)); return new TypedIdentifier(name, input.filename, Basic.VoidType.get(CheckSyntaxKey)); } */ const found = new IncludeType().runSyntax(c, input); if (found instanceof Basic.VoidType) { if (table === true) { const ttyp = new Basic.TableType(found, {withHeader: true, keyType: Basic.TableKeyType.default}); return new TypedIdentifier(name, input.filename, ttyp); } else { return new TypedIdentifier(name, input.filename, found); } } for (const c of found) { components.push(c); } } } if (table === true) { return new TypedIdentifier(name, input.filename, new Basic.TableType( new Basic.StructureType(components), {withHeader: true, keyType: Basic.TableKeyType.default})); } else { const val = Object.keys(values).length > 0 ? values : undefined; return new TypedIdentifier(name, input.filename, new Basic.StructureType(components), undefined, val); } } private static runCommonPartSyntax(node: StructureNode, input: SyntaxInput): void { for (const c of node.getChildren()) { const ctyp = c.get(); if (c instanceof StatementNode && ctyp instanceof Statements.Data) { const found = new DataSyntax().runSyntax(c, input); if (found) { input.scope.addIdentifier(found); } } else if (c instanceof StructureNode && ctyp instanceof Structures.Data) { const found = Data.runSyntax(c, input); if (found) { input.scope.addIdentifier(found); } } else if (c instanceof StatementNode && ctyp instanceof Statements.Type) { const found = new Type().runSyntax(c, input); if (found) { input.scope.addType(found); } } else if (c instanceof StructureNode && ctyp instanceof Structures.Types) { const found = new Types().runSyntax(c, input); if (found) { input.scope.addType(found); } } } } } |