All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.skife.jdbi.v2.SqlScriptParser Maven / Gradle / Ivy

Go to download

jDBI is designed to provide convenient tabular data access in Java(tm). It uses the Java collections framework for query results, provides a convenient means of externalizing sql statements, and provides named parameter support for any database being used.

There is a newer version: 2.78
Show newest version
/*
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 * http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */
package org.skife.jdbi.v2;

import org.antlr.runtime.CharStream;
import org.antlr.runtime.Token;

/**
 * An SQL script parser.
 *
 * 

It performs lexical analysis of a script and generates events for semicolons. * As a result it returns a script without comments and newlines.

*/ class SqlScriptParser { private final TokenHandler semicolonHandler; public SqlScriptParser(TokenHandler semicolonHandler) { this.semicolonHandler = semicolonHandler; } public String parse(CharStream charStream) { StringBuilder sb = new StringBuilder(); SqlScriptLexer lexer = new SqlScriptLexer(charStream); boolean endOfFile = false; while (!endOfFile) { Token t = lexer.nextToken(); switch (t.getType()) { case Token.EOF: endOfFile = true; break; case SqlScriptLexer.SEMICOLON: semicolonHandler.handle(t, sb); break; case SqlScriptLexer.COMMENT: case SqlScriptLexer.MULTI_LINE_COMMENT: break; case SqlScriptLexer.NEWLINES: if (sb.length() > 0) { sb.append(" "); } break; case SqlScriptLexer.QUOTED_TEXT: case SqlScriptLexer.LITERAL: case SqlScriptLexer.OTHER: sb.append(t.getText()); break; default: throw new IllegalArgumentException("Unrecognizable token " + t); } } return sb.toString(); } interface TokenHandler { void handle(Token t, StringBuilder sb); } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy