ShopChest/libs/org/sqlite/ExtendedCommand.java
2015-09-06 11:58:25 +02:00

117 lines
3.5 KiB
Java

//--------------------------------------
// sqlite-jdbc Project
//
// ExtendedCommand.java
// Since: Mar 12, 2010
//
// $URL$
// $Author$
//--------------------------------------
package org.sqlite;
import java.sql.SQLException;
import java.util.regex.Matcher;
import java.util.regex.Pattern;
/**
* parsing SQLite specific extension of SQL command
*
* @author leo
*
*/
public class ExtendedCommand
{
public static interface SQLExtension
{
public void execute(DB db) throws SQLException;
}
public static SQLExtension parse(String sql) throws SQLException {
if (sql == null)
return null;
if (sql.startsWith("backup"))
return BackupCommand.parse(sql);
else if (sql.startsWith("restore"))
return RestoreCommand.parse(sql);
return null;
}
public static String removeQuotation(String s) {
if (s == null)
return s;
if ((s.startsWith("\"") && s.endsWith("\"")) || (s.startsWith("'") && s.endsWith("'")))
return s.substring(1, s.length() - 1);
else
return s;
}
public static class BackupCommand implements SQLExtension
{
public final String srcDB;
public final String destFile;
public BackupCommand(String srcDB, String destFile) {
this.srcDB = srcDB;
this.destFile = destFile;
}
private static Pattern backupCmd = Pattern
.compile("backup(\\s+(\"[^\"]*\"|'[^\']*\'|\\S+))?\\s+to\\s+(\"[^\"]*\"|'[^\']*\'|\\S+)");
public static BackupCommand parse(String sql) throws SQLException {
if (sql != null) {
Matcher m = backupCmd.matcher(sql);
if (m.matches()) {
String dbName = removeQuotation(m.group(2));
String dest = removeQuotation(m.group(3));
if (dbName == null || dbName.length() == 0)
dbName = "main";
return new BackupCommand(dbName, dest);
}
}
throw new SQLException("syntax error: " + sql);
}
public void execute(DB db) throws SQLException {
db.backup(srcDB, destFile, null);
}
}
public static class RestoreCommand implements SQLExtension
{
public final String targetDB;
public final String srcFile;
private static Pattern restoreCmd = Pattern
.compile("restore(\\s+(\"[^\"]*\"|'[^\']*\'|\\S+))?\\s+from\\s+(\"[^\"]*\"|'[^\']*\'|\\S+)");
public RestoreCommand(String targetDB, String srcFile) {
this.targetDB = targetDB;
this.srcFile = srcFile;
}
public static RestoreCommand parse(String sql) throws SQLException {
if (sql != null) {
Matcher m = restoreCmd.matcher(sql);
if (m.matches()) {
String dbName = removeQuotation(m.group(2));
String dest = removeQuotation(m.group(3));
if (dbName == null || dbName.length() == 0)
dbName = "main";
return new RestoreCommand(dbName, dest);
}
}
throw new SQLException("syntax error: " + sql);
}
public void execute(DB db) throws SQLException {
db.restore(targetDB, srcFile, null);
}
}
}