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
|
#include "formatwith.h"
#include "parser/ast/sqliteselect.h"
FormatWith::FormatWith(SqliteWith *with) :
with(with)
{
}
void FormatWith::setLineUpKeyword(const QString& kw)
{
lineUpKeyword = kw;
}
void FormatWith::formatInternal()
{
markKeywordLineUp(lineUpKeyword);
withLinedUpKeyword("WITH");
if (with->recursive)
withKeyword("RECURSIVE");
withStatementList(with->cteList);
}
FormatWithCommonTableExpression::FormatWithCommonTableExpression(SqliteWith::CommonTableExpression *cte) :
cte(cte)
{
}
void FormatWithCommonTableExpression::formatInternal()
{
withId(cte->table);
if (cte->indexedColumns.size() > 0)
withParDefLeft().withStatementList(cte->indexedColumns, "idxCols").withParDefRight();
withKeyword("AS");
switch (cte->asMode) {
case SqliteWith::CommonTableExpression::ANY:
break;
case SqliteWith::CommonTableExpression::MATERIALIZED:
withKeyword("MATERIALIZED");
break;
case SqliteWith::CommonTableExpression::NOT_MATERIALIZED:
withKeyword("NOT").withKeyword("MATERIALIZED");
break;
}
withParDefLeft().withStatement(cte->select).withParDefRight();
}
|