X-Git-Url: http://git.linex4red.de/pub/Android/ownCloud.git/blobdiff_plain/baa585550d9031f4b7f2b7a7fd6b5b19dc1a58d3..12bbc51dcbb7eccf4189dcc8f7d9c20aa634aad9:/src/com/owncloud/android/services/OperationsService.java diff --git a/src/com/owncloud/android/services/OperationsService.java b/src/com/owncloud/android/services/OperationsService.java index a4de86a9..bbecf21a 100644 --- a/src/com/owncloud/android/services/OperationsService.java +++ b/src/com/owncloud/android/services/OperationsService.java @@ -52,7 +52,6 @@ import android.os.IBinder; import android.os.Looper; import android.os.Message; import android.os.Process; -import android.util.Log; import android.util.Pair; public class OperationsService extends Service { @@ -89,8 +88,14 @@ public class OperationsService extends Service { private ConcurrentLinkedQueue> mPendingOperations = new ConcurrentLinkedQueue>(); + /* private ConcurrentMap mOperationResults = new ConcurrentHashMap(); + */ + + private ConcurrentMap> + mUndispatchedFinishedOperations = + new ConcurrentHashMap>(); private static class Target { public Uri mServerUrl = null; @@ -149,21 +154,21 @@ public class OperationsService extends Service { */ @Override public int onStartCommand(Intent intent, int flags, int startId) { - Log.wtf(TAG, "onStartCommand init" ); + Log_OC.wtf(TAG, "onStartCommand init" ); Message msg = mServiceHandler.obtainMessage(); msg.arg1 = startId; mServiceHandler.sendMessage(msg); - Log.wtf(TAG, "onStartCommand end" ); + Log_OC.wtf(TAG, "onStartCommand end" ); return START_NOT_STICKY; } @Override public void onDestroy() { - Log.wtf(TAG, "onDestroy init" ); + Log_OC.wtf(TAG, "onDestroy init" ); super.onDestroy(); - Log.wtf(TAG, "Clear mOperationResults" ); - mOperationResults.clear(); - Log.wtf(TAG, "onDestroy end" ); + Log_OC.wtf(TAG, "Clear mUndispatchedFinisiedOperations" ); + mUndispatchedFinishedOperations.clear(); + Log_OC.wtf(TAG, "onDestroy end" ); } @@ -173,7 +178,7 @@ public class OperationsService extends Service { */ @Override public IBinder onBind(Intent intent) { - Log.wtf(TAG, "onBind" ); + Log_OC.wtf(TAG, "onBind" ); return mBinder; } @@ -256,9 +261,9 @@ public class OperationsService extends Service { * Creates and adds to the queue a new operation, as described by operationIntent * * @param operationIntent Intent describing a new operation to queue and execute. - * @return Identifier of the operation created, or -1 if failed. + * @return Identifier of the operation created, or null if failed. */ - public int newOperation(Intent operationIntent) { + public long newOperation(Intent operationIntent) { RemoteOperation operation = null; Target target = null; try { @@ -341,16 +346,25 @@ public class OperationsService extends Service { if (operation != null) { mPendingOperations.add(new Pair(target, operation)); startService(new Intent(OperationsService.this, OperationsService.class)); + Log_OC.wtf(TAG, "New operation added, opId: " + operation.hashCode()); + // better id than hash? ; should be good enough by the time being return operation.hashCode(); } else { - return -1; + Log_OC.wtf(TAG, "New operation failed, returned Long.MAX_VALUE"); + return Long.MAX_VALUE; } } - public RemoteOperationResult getOperationResultIfFinished(int operationId) { - Log_OC.wtf(TAG, "Searching result for operation with id " + operationId); - return mOperationResults.remove(operationId); + public void dispatchResultIfFinished(int operationId, OnRemoteOperationListener listener) { + Pair undispatched = + mUndispatchedFinishedOperations.remove(operationId); + if (undispatched != null) { + listener.onRemoteOperationFinish(undispatched.first, undispatched.second); + Log_OC.wtf(TAG, "Sending callback later"); + } else { + Log_OC.wtf(TAG, "Not finished yet"); + } } } @@ -385,7 +399,7 @@ public class OperationsService extends Service { */ private void nextOperation() { - Log.wtf(TAG, "nextOperation init" ); + Log_OC.wtf(TAG, "nextOperation init" ); Pair next = null; synchronized(mPendingOperations) { @@ -457,7 +471,7 @@ public class OperationsService extends Service { } //sendBroadcastOperationFinished(mLastTarget, mCurrentOperation, result); - dispatchOperationListeners(mLastTarget, mCurrentOperation, result); + dispatchResultToOperationListeners(mLastTarget, mCurrentOperation, result); } } @@ -515,7 +529,7 @@ public class OperationsService extends Service { * @param operation Finished operation. * @param result Result of the operation. */ - private void dispatchOperationListeners( + private void dispatchResultToOperationListeners( Target target, final RemoteOperation operation, final RemoteOperationResult result) { int count = 0; Iterator listeners = mBinder.mBoundListeners.keySet().iterator(); @@ -533,7 +547,10 @@ public class OperationsService extends Service { } } if (count == 0) { - mOperationResults.put(operation.hashCode(), result); + //mOperationResults.put(operation.hashCode(), result); + Pair undispatched = + new Pair(operation, result); + mUndispatchedFinishedOperations.put(operation.hashCode(), undispatched); } Log_OC.d(TAG, "Called " + count + " listeners"); }