/* * #%L * JSQLParser library * %% * Copyright (C) 2004 - 2013 JSQLParser * %% * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as * published by the Free Software Foundation, either version 2.1 of the * License, or (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Lesser Public License for more details. * * You should have received a copy of the GNU General Lesser Public * License along with this program. If not, see * <http://www.gnu.org/licenses/lgpl-2.1.html>. * #L% */ package net.sf.jsqlparser.util.deparser; import java.util.Iterator; import net.sf.jsqlparser.statement.SetStatement; import net.sf.jsqlparser.statement.StatementVisitor; import net.sf.jsqlparser.statement.Statements; import net.sf.jsqlparser.statement.alter.Alter; import net.sf.jsqlparser.statement.create.index.CreateIndex; import net.sf.jsqlparser.statement.create.table.CreateTable; import net.sf.jsqlparser.statement.create.view.AlterView; import net.sf.jsqlparser.statement.create.view.CreateView; import net.sf.jsqlparser.statement.delete.Delete; import net.sf.jsqlparser.statement.drop.Drop; import net.sf.jsqlparser.statement.execute.Execute; import net.sf.jsqlparser.statement.insert.Insert; import net.sf.jsqlparser.statement.merge.Merge; import net.sf.jsqlparser.statement.replace.Replace; import net.sf.jsqlparser.statement.select.Select; import net.sf.jsqlparser.statement.select.WithItem; import net.sf.jsqlparser.statement.truncate.Truncate; import net.sf.jsqlparser.statement.update.Update; public class StatementDeParser implements StatementVisitor { private StringBuilder buffer; public StatementDeParser(StringBuilder buffer) { this.buffer = buffer; } @Override public void visit(CreateIndex createIndex) { CreateIndexDeParser createIndexDeParser = new CreateIndexDeParser(buffer); createIndexDeParser.deParse(createIndex); } @Override public void visit(CreateTable createTable) { CreateTableDeParser createTableDeParser = new CreateTableDeParser(buffer); createTableDeParser.deParse(createTable); } @Override public void visit(CreateView createView) { CreateViewDeParser createViewDeParser = new CreateViewDeParser(buffer); createViewDeParser.deParse(createView); } @Override public void visit(AlterView alterView) { AlterViewDeParser alterViewDeParser = new AlterViewDeParser(buffer); alterViewDeParser.deParse(alterView); } @Override public void visit(Delete delete) { SelectDeParser selectDeParser = new SelectDeParser(); selectDeParser.setBuffer(buffer); ExpressionDeParser expressionDeParser = new ExpressionDeParser(selectDeParser, buffer); selectDeParser.setExpressionVisitor(expressionDeParser); DeleteDeParser deleteDeParser = new DeleteDeParser(expressionDeParser, buffer); deleteDeParser.deParse(delete); } @Override public void visit(Drop drop) { DropDeParser dropDeParser = new DropDeParser(buffer); dropDeParser.deParse(drop); } @Override public void visit(Insert insert) { SelectDeParser selectDeParser = new SelectDeParser(); selectDeParser.setBuffer(buffer); ExpressionDeParser expressionDeParser = new ExpressionDeParser(selectDeParser, buffer); selectDeParser.setExpressionVisitor(expressionDeParser); InsertDeParser insertDeParser = new InsertDeParser(expressionDeParser, selectDeParser, buffer); insertDeParser.deParse(insert); } @Override public void visit(Replace replace) { SelectDeParser selectDeParser = new SelectDeParser(); selectDeParser.setBuffer(buffer); ExpressionDeParser expressionDeParser = new ExpressionDeParser(selectDeParser, buffer); selectDeParser.setExpressionVisitor(expressionDeParser); ReplaceDeParser replaceDeParser = new ReplaceDeParser(expressionDeParser, selectDeParser, buffer); replaceDeParser.deParse(replace); } @Override public void visit(Select select) { SelectDeParser selectDeParser = new SelectDeParser(); selectDeParser.setBuffer(buffer); ExpressionDeParser expressionDeParser = new ExpressionDeParser(selectDeParser, buffer); selectDeParser.setExpressionVisitor(expressionDeParser); if (select.getWithItemsList() != null && !select.getWithItemsList().isEmpty()) { buffer.append("WITH "); for (Iterator<WithItem> iter = select.getWithItemsList().iterator(); iter.hasNext();) { WithItem withItem = iter.next(); withItem.accept(selectDeParser); if (iter.hasNext()) { buffer.append(","); } buffer.append(" "); } } select.getSelectBody().accept(selectDeParser); } @Override public void visit(Truncate truncate) { } @Override public void visit(Update update) { SelectDeParser selectDeParser = new SelectDeParser(); selectDeParser.setBuffer(buffer); ExpressionDeParser expressionDeParser = new ExpressionDeParser(selectDeParser, buffer); UpdateDeParser updateDeParser = new UpdateDeParser(expressionDeParser, selectDeParser, buffer); selectDeParser.setExpressionVisitor(expressionDeParser); updateDeParser.deParse(update); } public StringBuilder getBuffer() { return buffer; } public void setBuffer(StringBuilder buffer) { this.buffer = buffer; } @Override public void visit(Alter alter) { AlterDeParser alterDeParser = new AlterDeParser(buffer); alterDeParser.deParse(alter); } @Override public void visit(Statements stmts) { stmts.accept(this); } @Override public void visit(Execute execute) { SelectDeParser selectDeParser = new SelectDeParser(); selectDeParser.setBuffer(buffer); ExpressionDeParser expressionDeParser = new ExpressionDeParser(selectDeParser, buffer); ExecuteDeParser executeDeParser = new ExecuteDeParser(expressionDeParser, buffer); selectDeParser.setExpressionVisitor(expressionDeParser); executeDeParser.deParse(execute); } @Override public void visit(SetStatement set) { SelectDeParser selectDeParser = new SelectDeParser(); selectDeParser.setBuffer(buffer); ExpressionDeParser expressionDeParser = new ExpressionDeParser(selectDeParser, buffer); SetStatementDeParser setStatementDeparser = new SetStatementDeParser(expressionDeParser, buffer); selectDeParser.setExpressionVisitor(expressionDeParser); setStatementDeparser.deParse(set); } @Override public void visit(Merge merge) { //TODO implementation of a deparser buffer.append(merge.toString()); } }