All files / src/abap/2_statements/expressions sql_replace_regexpr.ts

100% Statements 27/27
100% Branches 1/1
100% Functions 1/1
100% Lines 27/27

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 281x 1x 1x 1x 1x 1x 1x 1x 1x 1x 1x 1x 1x 1x 1x 1x 1x 1x 1x 1x 1x 1x 1x 1x 1x 1x 1x  
import {seq, optPrio, altPrio, Expression, ver, tok} from "../combi";
import {IStatementRunnable} from "../statement_runnable";
import {Release} from "../../../version";
import {ParenLeftW, WAt, WParenRightW} from "../../1_lexer/tokens";
import {SimpleSource3} from "./simple_source3";
import {Source} from "./source";
import {SQLFunctionInput} from "./sql_function_input";
import {SQLRegexprPattern} from "./sql_regexpr_pattern";
import {SQLRegexprFrom} from "./sql_regexpr_from";
import {SQLRegexprOccurrence} from "./sql_regexpr_occurrence";
 
export class SQLReplaceRegexpr extends Expression {
  public getRunnable(): IStatementRunnable {
    const hostParen = seq(tok(ParenLeftW), Source, tok(WParenRightW));
    const hostVar = seq(tok(WAt), altPrio(SimpleSource3, hostParen));
    const withClause = seq("WITH", altPrio(hostVar, SQLFunctionInput));
    return ver(Release.v757, seq(
      "REPLACE_REGEXPR",
      tok(ParenLeftW),
      SQLRegexprPattern,
      optPrio(withClause),
      optPrio(SQLRegexprFrom),
      optPrio(SQLRegexprOccurrence),
      tok(WParenRightW),
    ));
  }
}