+ void commitSelections() {
+ try(SQLiteDatabase db = dbh.getWritableDatabase()) {
+ db.beginTransaction();
+ try {
+ for (LedgerAccount acc : accounts) {
+ Log.d("db", String.format("Setting %s to %s", acc.getName(),
+ acc.isHidden() ? "hidden" : "starred"));
+ db.execSQL("UPDATE accounts SET hidden=? WHERE name=?",
+ new Object[]{acc.isHiddenToBe() ? 1 : 0, acc.getName()});
+ }
+ db.setTransactionSuccessful();
+ for (LedgerAccount acc : accounts ) { acc.setHidden(acc.isHiddenToBe()); }
+ }
+ finally { db.endTransaction(); }
+ }
+ }