X-Git-Url: https://git.ktnx.net/?a=blobdiff_plain;f=app%2Fsrc%2Fmain%2Fjava%2Fnet%2Fktnx%2Fmobileledger%2Fasync%2FCommitAccountsTask.java;h=eb3dfbba51b0997424114ac55ba5a59782eebc80;hb=64bb8277f3c747f0ef2dcb48f898fb4ec07b64ee;hp=8f8c1dac98e6c4ea5fc9bc16255bca64e10e066a;hpb=83cac114e375728080194fb09758b49c50a8119b;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 8f8c1dac..eb3dfbba 100644 --- a/app/src/main/java/net/ktnx/mobileledger/async/CommitAccountsTask.java +++ b/app/src/main/java/net/ktnx/mobileledger/async/CommitAccountsTask.java @@ -1,5 +1,5 @@ /* - * Copyright © 2019 Damyan Ivanov. + * Copyright © 2020 Damyan Ivanov. * 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 @@ -19,35 +19,36 @@ package net.ktnx.mobileledger.async; import android.database.sqlite.SQLiteDatabase; import android.os.AsyncTask; -import android.util.Log; +import net.ktnx.mobileledger.App; import net.ktnx.mobileledger.model.Data; import net.ktnx.mobileledger.model.LedgerAccount; -import net.ktnx.mobileledger.utils.MLDB; +import net.ktnx.mobileledger.utils.LockHolder; 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(); + String profile = Data.profile.getValue().getUuid(); try { - SQLiteDatabase db = MLDB.getDatabase(); - db.beginTransaction(); + SQLiteDatabase db = App.getDatabase(); + db.beginTransactionNonExclusive(); try { + try (LockHolder lh = params[0].accountList.lockForWriting()) { for (int i = 0; i < params[0].accountList.size(); i++ ){ LedgerAccount acc = params[0].accountList.get(i); - Log.d("CAT", String.format("Setting %s to %s", acc.getName(), + 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(); } } @@ -56,7 +57,7 @@ public class CommitAccountsTask } } finally { - Data.backgroundTaskCount.decrementAndGet(); + Data.backgroundTaskFinished(); } return newList;