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 | 1x 1x 1x 1x 1x 1x 1x 1x 1x 1x 1x 1x 1x 1x 1x 1x 1x 1x 1x 1x | import {seq, ver, Expression, optPrio, opt, alt, star, tok} from "../combi";
import {SQLFieldName, Dynamic, SQLField, SQLAsName, Constant, SimpleFieldChain2} from ".";
import {Version} from "../../../version";
import {IStatementRunnable} from "../statement_runnable";
import {SQLPath} from "./sql_path";
import {WAt} from "../../1_lexer/tokens";
// loop must include one field from the database table
export class SQLFieldListLoop extends Expression {
public getRunnable(): IStatementRunnable {
const comma = opt(ver(Version.v740sp05, ",", Version.OpenABAP));
const as = seq("AS", SQLAsName);
const someField = seq(SQLField, comma);
const abap = ver(Version.v740sp05, seq(tok(WAt), SimpleFieldChain2), Version.OpenABAP);
const fieldList = seq(star(someField), alt(SQLFieldName, abap, SQLPath, Constant), optPrio(as), comma, star(someField));
const fields = alt("*", Dynamic, fieldList);
return fields;
}
} |