X-Git-Url: https://git.ktnx.net/?a=blobdiff_plain;f=app%2Fsrc%2Fmain%2Fjava%2Fnet%2Fktnx%2Fmobileledger%2Fasync%2FCommitAccountsTask.java;h=2c3d90f83947f9c7576624d718a84f9c218b4847;hb=431f39f54e46ffbad03159c1881bac8edcf30d75;hp=35a78dbeec119369683d4fa4561e0f34478c505d;hpb=b19d307424598019385bb9b65405e45ffe65cde1;p=mobile-ledger.git
diff --git a/app/src/main/java/net/ktnx/mobileledger/async/CommitAccountsTask.java b/app/src/main/java/net/ktnx/mobileledger/async/CommitAccountsTask.java
index 35a78dbe..2c3d90f8 100644
--- a/app/src/main/java/net/ktnx/mobileledger/async/CommitAccountsTask.java
+++ b/app/src/main/java/net/ktnx/mobileledger/async/CommitAccountsTask.java
@@ -1,60 +1,66 @@
/*
* Copyright © 2019 Damyan Ivanov.
- * This file is part of Mobile-Ledger.
- * Mobile-Ledger is free software: you can distribute it and/or modify it
+ * This file is part of MoLe.
+ * MoLe is free software: you can distribute it and/or modify it
* under the term of the GNU General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your opinion), any later version.
*
- * Mobile-Ledger is distributed in the hope that it will be useful,
+ * MoLe is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License terms for details.
*
* You should have received a copy of the GNU General Public License
- * along with Mobile-Ledger. If not, see .
+ * along with MoLe. If not, see .
*/
package net.ktnx.mobileledger.async;
import android.database.sqlite.SQLiteDatabase;
import android.os.AsyncTask;
-import android.util.Log;
import net.ktnx.mobileledger.model.Data;
import net.ktnx.mobileledger.model.LedgerAccount;
+import net.ktnx.mobileledger.utils.LockHolder;
import net.ktnx.mobileledger.utils.MLDB;
import java.util.ArrayList;
+import static net.ktnx.mobileledger.utils.Logger.debug;
+
public class CommitAccountsTask
extends AsyncTask> {
protected ArrayList doInBackground(CommitAccountsTaskParams... params) {
- Data.backgroundTaskCount.incrementAndGet();
+ Data.backgroundTaskStarted();
ArrayList newList = new ArrayList<>();
String profile = Data.profile.get().getUuid();
try {
- SQLiteDatabase db = MLDB.getWritableDatabase();
+ SQLiteDatabase db = MLDB.getDatabase();
db.beginTransaction();
try {
- for (LedgerAccount acc : params[0].accountList) {
- Log.d("CAT", String.format("Setting %s to %s", acc.getName(),
- acc.isHiddenToBe() ? "hidden" : "starred"));
- db.execSQL("UPDATE accounts SET hidden=? WHERE profile=? AND name=?",
- new Object[]{acc.isHiddenToBe() ? 1 : 0, profile, acc.getName()});
-
- acc.setHidden(acc.isHiddenToBe());
- if (!params[0].showOnlyStarred || !acc.isHidden()) newList.add(acc);
+ try (LockHolder lh = params[0].accountList.lockForWriting()) {
+ for (int i = 0; i < params[0].accountList.size(); i++ ){
+ LedgerAccount acc = params[0].accountList.get(i);
+ debug("CAT", String.format("Setting %s to %s", acc.getName(),
+ acc.isHiddenByStarToBe() ? "hidden" : "starred"));
+ db.execSQL("UPDATE accounts SET hidden=? WHERE profile=? AND name=?",
+ new Object[]{acc.isHiddenByStarToBe() ? 1 : 0, profile, acc.getName()
+ });
+
+ acc.setHiddenByStar(acc.isHiddenByStarToBe());
+ if (!params[0].showOnlyStarred || !acc.isHiddenByStar()) newList.add(acc);
+ }
+ db.setTransactionSuccessful();
}
- db.setTransactionSuccessful();
}
finally {
db.endTransaction();
}
}
finally {
- Data.backgroundTaskCount.decrementAndGet();
+ Data.backgroundTaskFinished();
}
return newList;