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 | 1x 1x 1x 1x 1x 1x 1x 1x 1x 1x 82x 82x 82x 82x 82x 82x 82x 82x 82x 2x 2x 82x 82x 82x 82x 82x 1x | import {ExpressionNode} from "../../nodes";
import * as Expressions from "../../2_statements/expressions";
import {TypedIdentifier, IdentifierMeta} from "../../types/_typed_identifier";
import {UnknownType} from "../../types/basic";
import {BasicTypes} from "../basic_types";
import {SyntaxInput} from "../_syntax_input";
import {AssertError} from "../assert_error";
export class MethodDefReturning {
public static runSyntax(node: ExpressionNode, input: SyntaxInput, meta: IdentifierMeta[]): TypedIdentifier {
const name = node.findDirectExpression(Expressions.MethodParamName);
if (name === undefined) {
throw new AssertError("method_parameter.ts, todo, handle pass by value and reference");
}
const type = node.findDirectExpression(Expressions.TypeParam);
if (type === undefined) {
throw new AssertError("method_parameter.ts, unexpected structure");
}
let found = new BasicTypes(input).parseType(type);
if (found?.isGeneric() === true) {
found = new UnknownType("RETURNING parameter must be fully specified");
}
if (found) {
return new TypedIdentifier(name.getFirstToken(), input.filename, found, meta);
} else {
return new TypedIdentifier(name.getFirstToken(), input.filename, new UnknownType("method param, todo"), meta);
}
}
} |