package net.ktnx.mobileledger.db;
import android.content.res.Resources;
+import android.database.Cursor;
import android.database.SQLException;
import androidx.annotation.NonNull;
import net.ktnx.mobileledger.App;
import net.ktnx.mobileledger.dao.AccountDAO;
+import net.ktnx.mobileledger.dao.AccountValueDAO;
import net.ktnx.mobileledger.dao.CurrencyDAO;
+import net.ktnx.mobileledger.dao.DescriptionHistoryDAO;
import net.ktnx.mobileledger.dao.OptionDAO;
+import net.ktnx.mobileledger.dao.ProfileDAO;
import net.ktnx.mobileledger.dao.TemplateAccountDAO;
import net.ktnx.mobileledger.dao.TemplateHeaderDAO;
+import net.ktnx.mobileledger.dao.TransactionAccountDAO;
import net.ktnx.mobileledger.dao.TransactionDAO;
+import net.ktnx.mobileledger.utils.Logger;
import java.io.BufferedReader;
import java.io.IOException;
singleVersionMigration(41),
multiVersionMigration(41, 58),
singleVersionMigration(59)
- })
+ })
.addCallback(new Callback() {
@Override
public void onOpen(@NonNull SupportSQLiteDatabase db) {
String fileName = String.format(Locale.US, "db_%d", toVersion);
applyRevisionFile(db, fileName);
+
+ // when migrating to version 59, migrate profile/theme options to the
+ // SharedPreferences
+ if (toVersion == 59) {
+ try (Cursor c = db.query(
+ "SELECT p.id, p.theme_hue FROM profiles p WHERE p.id=(SELECT o.value " +
+ "FROM options WHERE o.profile_uid IS NULL AND o.name=?",
+ new Object[]{"profile_id"}))
+ {
+ if (c.moveToFirst()) {
+ long currentProfileId = c.getLong(0);
+ int currentTheme = c.getInt(1);
+
+ if (currentProfileId >= 0 && currentTheme >= 0) {
+ App.storeStartupProfileAndTheme(currentProfileId, currentTheme);
+ }
+ }
+ }
+ }
+ }
+ };
+ }
+ private static Migration dummyVersionMigration(int toVersion) {
+ return new Migration(toVersion - 1, toVersion) {
+ @Override
+ public void migrate(@NonNull SupportSQLiteDatabase db) {
+ Logger.debug("db",
+ String.format(Locale.ROOT, "Dummy DB migration to version %d", toVersion));
}
};
}
public abstract AccountDAO getAccountDAO();
+ public abstract AccountValueDAO getAccountValueDAO();
+
public abstract TransactionDAO getTransactionDAO();
+ public abstract TransactionAccountDAO getTransactionAccountDAO();
+
public abstract OptionDAO getOptionDAO();
+
+ public abstract DescriptionHistoryDAO getDescriptionHistoryDAO();
+
+ public abstract ProfileDAO getProfileDAO();
}