Reduced operation processing

pull/187/head
M66B 4 years ago
parent 75480a6f42
commit 074a2d953e

@ -1295,27 +1295,31 @@ public class ServiceSynchronize extends ServiceBase implements SharedPreferences
@Override @Override
public void onChanged(final List<TupleOperationEx> _operations) { public void onChanged(final List<TupleOperationEx> _operations) {
// Get new operations // Get new operations
List<Long> ops = new ArrayList<>(); List<Long> all = new ArrayList<>();
Map<EntityFolder, List<TupleOperationEx>> added = new HashMap<>(); Map<Long, List<TupleOperationEx>> added = new HashMap<>();
for (TupleOperationEx op : _operations) { for (TupleOperationEx op : _operations) {
all.add(op.id);
if (!handling.contains(op.id)) { if (!handling.contains(op.id)) {
boolean found = false; if (!added.containsKey(op.folder))
for (EntityFolder folder : mapFolders.keySet()) added.put(op.folder, new ArrayList<>());
if (Objects.equals(folder.id, op.folder)) { added.get(op.folder).add(op);
found = true;
if (!added.containsKey(folder))
added.put(folder, new ArrayList<>());
added.get(folder).add(op);
break;
} }
if (!found)
Log.w(account.name + " folder not found operation=" + op.name);
} }
ops.add(op.id); handling = all;
for (Long fid : added.keySet()) {
EntityFolder found = null;
for (EntityFolder f : mapFolders.keySet())
if (Objects.equals(fid, f.id)) {
found = f;
break;
}
if (found == null) {
Log.w(account.name + " folder not found operation=" + fid);
continue;
} }
handling = ops;
for (EntityFolder folder : added.keySet()) { final EntityFolder folder = found;
Log.i(folder.name + " queuing operations=" + added.size() + Log.i(folder.name + " queuing operations=" + added.size() +
" init=" + folder.initialize + " poll=" + folder.poll); " init=" + folder.initialize + " poll=" + folder.poll);
@ -1323,7 +1327,7 @@ public class ServiceSynchronize extends ServiceBase implements SharedPreferences
boolean offline = (mapFolders.get(folder) == null); boolean offline = (mapFolders.get(folder) == null);
List<TupleOperationEx.PartitionKey> keys = new ArrayList<>(); List<TupleOperationEx.PartitionKey> keys = new ArrayList<>();
synchronized (partitions) { synchronized (partitions) {
for (TupleOperationEx op : added.get(folder)) { for (TupleOperationEx op : added.get(folder.id)) {
TupleOperationEx.PartitionKey key = op.getPartitionKey(offline); TupleOperationEx.PartitionKey key = op.getPartitionKey(offline);
if (!partitions.containsKey(key)) { if (!partitions.containsKey(key)) {

Loading…
Cancel
Save