X-Git-Url: https://git.ktnx.net/?a=blobdiff_plain;f=app%2Fsrc%2Fmain%2Fjava%2Fnet%2Fktnx%2Fmobileledger%2Futils%2FMobileLedgerDatabase.java;h=ac78e23128d5c6994e2f152e33402def4a639543;hb=1c7d5db534b9c31c30f5a98074b0bcaeb1c0b4a9;hp=0ddaa1dc0fc2da4cb5f3c1f9a2dd9fa5684b37f1;hpb=55f4f1b5f101d0f9874fe3d3406d53c6df931a40;p=mobile-ledger.git diff --git a/app/src/main/java/net/ktnx/mobileledger/utils/MobileLedgerDatabase.java b/app/src/main/java/net/ktnx/mobileledger/utils/MobileLedgerDatabase.java index 0ddaa1dc..ac78e231 100644 --- a/app/src/main/java/net/ktnx/mobileledger/utils/MobileLedgerDatabase.java +++ b/app/src/main/java/net/ktnx/mobileledger/utils/MobileLedgerDatabase.java @@ -40,7 +40,7 @@ import static net.ktnx.mobileledger.utils.Logger.debug; public class MobileLedgerDatabase extends SQLiteOpenHelper { public static final MutableLiveData initComplete = new MutableLiveData<>(false); public static final String DB_NAME = "MoLe.db"; - private static final int LATEST_REVISION = 57; + private static final int LATEST_REVISION = 58; private static final String CREATE_DB_SQL = "create_db"; private final Application mContext; @@ -88,11 +88,10 @@ public class MobileLedgerDatabase extends SQLiteOpenHelper { InputStreamReader isr = new InputStreamReader(res); BufferedReader reader = new BufferedReader(isr); - Pattern continuation = Pattern.compile("\\\\\\s*$"); + Pattern endOfStatement = Pattern.compile(";\\s*(?:--.*)?$"); String line; String sqlStatement = null; - boolean eolPending; int lineNo = 0; while ((line = reader.readLine()) != null) { lineNo++; @@ -101,19 +100,13 @@ public class MobileLedgerDatabase extends SQLiteOpenHelper { if (line.isEmpty()) continue; - Matcher m = continuation.matcher(line); - eolPending = false; - if (m.find()) { - line = m.replaceFirst(""); - eolPending = true; - } - if (sqlStatement == null) sqlStatement = line; else sqlStatement = sqlStatement.concat(line); - if (eolPending) + Matcher m = endOfStatement.matcher(line); + if (!m.find()) continue; try { @@ -128,8 +121,9 @@ public class MobileLedgerDatabase extends SQLiteOpenHelper { } if (sqlStatement != null) - throw new RuntimeException( - String.format("Error applying %s: EOF after continuation", revFile)); + throw new RuntimeException(String.format( + "Error applying %s: EOF after continuation. Line %s, Incomplete " + + "statement: %s", revFile, lineNo, sqlStatement)); } catch (IOException e) {