mirror of
https://github.com/amalthea-mc/ShopChest.git
synced 2024-11-13 22:21:06 +00:00
117 lines
3.5 KiB
Java
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);
|
||
|
}
|
||
|
}
|
||
|
|
||
|
}
|