package net.ktnx.mobileledger.model;
+import net.ktnx.mobileledger.utils.LockHolder;
import net.ktnx.mobileledger.utils.MLDB;
import net.ktnx.mobileledger.utils.ObservableAtomicInteger;
import net.ktnx.mobileledger.utils.ObservableList;
public final class Data {
public static TransactionList transactions = new TransactionList();
- public static ObservableValue<ArrayList<LedgerAccount>> accounts =
- new ObservableValue<>(new ArrayList<>());
+ public static ObservableList<LedgerAccount> accounts =
+ new ObservableList<>(new ArrayList<>());
public static ObservableAtomicInteger backgroundTaskCount = new ObservableAtomicInteger(0);
public static ObservableValue<Date> lastUpdateDate = new ObservableValue<>();
public static ObservableValue<MobileLedgerProfile> profile = new ObservableValue<>();
profile.set(newProfile);
}
public static int getProfileIndex(MobileLedgerProfile profile) {
- List<MobileLedgerProfile> list = profiles.getList();
+ try(LockHolder lh = profiles.lockForReading()) {
+ for (int i = 0; i < profiles.size(); i++) {
+ MobileLedgerProfile p = profiles.get(i);
+ if (p.equals(profile)) return i;
+ }
- for (int i = 0; i < list.size(); i++) {
- MobileLedgerProfile p = list.get(i);
- if (p.equals(profile)) return i;
+ return -1;
}
-
- return -1;
}
}