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 | 1x 1x 1x 1x 1x 1x 1x 1x 1x 1x 1x 1x 1x 70x 70x 70x 70x 70x 70x 233x 233x 89x 89x 89x 89x 2x 2x 89x 233x 1x 1x 1x 1x 144x 70x 12x 12x 143x 5x 5x 5x 5x 5x 5x 2x 2x 2x 2x 2x 5x 3x 3x 5x 2x 1x 1x 1x 1x 2x 5x 5x 3x 3x 3x 3x 233x 68x 70x 11x 11x 70x 57x 57x 57x 70x 1x | import * as Expressions from "../../2_statements/expressions"; import * as Statements from "../../2_statements/statements"; import * as Structures from "../../3_structures/structures"; import {StatementNode, StructureNode} from "../../nodes"; import {CurrentScope} from "../_current_scope"; import {TypedIdentifier} from "../../types/_typed_identifier"; import * as Basic from "../../types/basic"; import {IStructureComponent} from "../../types/basic"; import {Data as DataSyntax} from "../statements/data"; import {ReferenceType} from "../_reference"; export class Data { public runSyntax(node: StructureNode, scope: CurrentScope, filename: string): TypedIdentifier | 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, scope, filename); 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 = new Data().runSyntax(c, scope, filename); 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(); const foundId = scope.findType(typeName); let found = foundId?.getType(); if (found === undefined) { const f = scope.getDDIC().lookupTableOrView(typeName).type; if (f instanceof TypedIdentifier) { found = f.getType(); } else { found = f; } } else { scope.addReference(typeToken, foundId, ReferenceType.TypeReference, filename); } if (found instanceof Basic.VoidType) { if (table === true) { return new TypedIdentifier(name, filename, new Basic.TableType(found, {withHeader: true, keyType: Basic.TableKeyType.default})); } else { return new TypedIdentifier(name, filename, found); } } if (found instanceof Basic.UnknownType) { return new TypedIdentifier(name, filename, new Basic.UnknownType("unknown type, " + typeName)); } if (!(found instanceof Basic.StructureType)) { throw new Error("not structured, " + typeName); } for (const c of found.getComponents()) { components.push(c); } } } if (table === true) { return new TypedIdentifier(name, 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, filename, new Basic.StructureType(components), undefined, val); } } } |