Skip to content

Commit

Permalink
Merge pull request #70 from livefront/better-thread-safety
Browse files Browse the repository at this point in the history
Better thread safety
  • Loading branch information
brian-livefront committed Mar 31, 2021
2 parents d3d09b2 + 0a21d9d commit 6e86970
Show file tree
Hide file tree
Showing 2 changed files with 27 additions and 15 deletions.
16 changes: 14 additions & 2 deletions bridge/src/main/java/com/livefront/bridge/Bridge.java
Original file line number Diff line number Diff line change
Expand Up @@ -9,7 +9,11 @@
import androidx.annotation.NonNull;
import androidx.annotation.Nullable;

import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;

public class Bridge {
private static final ExecutorService sExecutorService = Executors.newCachedThreadPool();

private static volatile BridgeDelegate sDelegate;

Expand Down Expand Up @@ -41,7 +45,11 @@ public static void clear(@NonNull Object target) {
public static void clearAll(@NonNull Context context) {
BridgeDelegate delegate = sDelegate != null
? sDelegate
: new BridgeDelegate(context, new NoOpSavedStateHandler(), null);
: new BridgeDelegate(
context,
sExecutorService,
new NoOpSavedStateHandler(),
null);
delegate.clearAll();
}

Expand Down Expand Up @@ -83,7 +91,11 @@ private static synchronized void initializeInternal(
@NonNull Context context,
@NonNull SavedStateHandler savedStateHandler,
@Nullable ViewSavedStateHandler viewSavedStateHandler) {
sDelegate = new BridgeDelegate(context, savedStateHandler, viewSavedStateHandler);
sDelegate = new BridgeDelegate(
context,
sExecutorService,
savedStateHandler,
viewSavedStateHandler);
}

/**
Expand Down
26 changes: 13 additions & 13 deletions bridge/src/main/java/com/livefront/bridge/BridgeDelegate.java
Original file line number Diff line number Diff line change
Expand Up @@ -5,7 +5,6 @@
import android.app.ActivityManager;
import android.app.Application;
import android.content.Context;
import android.content.SharedPreferences;
import android.os.Build;
import android.os.Bundle;
import android.os.Parcelable;
Expand All @@ -27,7 +26,6 @@
import java.util.concurrent.CopyOnWriteArrayList;
import java.util.concurrent.CountDownLatch;
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;
import java.util.concurrent.TimeUnit;

class BridgeDelegate {
Expand All @@ -44,31 +42,33 @@ class BridgeDelegate {
private static final String KEY_UUID = "uuid_%s";
private static final String KEY_WRAPPED_VIEW_RESULT = "wrapped-view-result";

private final DiskHandler mDiskHandler;
private final ExecutorService mExecutorService;
private final List<Runnable> mPendingWriteTasks = new CopyOnWriteArrayList<>();
private final Map<String, Bundle> mUuidBundleMap = new ConcurrentHashMap<>();
private final Map<Object, String> mObjectUuidMap = new WeakHashMap<>();
private final SavedStateHandler mSavedStateHandler;
private final ViewSavedStateHandler mViewSavedStateHandler;

private int mActivityCount = 0;
private boolean mIsClearAllowed = false;
private boolean mIsConfigChange = false;
private boolean mIsFirstCreateCall = true;
private volatile CountDownLatch mPendingWriteTasksLatch = null;
private DiskHandler mDiskHandler;
private ExecutorService mExecutorService = Executors.newCachedThreadPool();
private List<Runnable> mPendingWriteTasks = new CopyOnWriteArrayList<>();
private Map<String, Bundle> mUuidBundleMap = new ConcurrentHashMap<>();
private Map<Object, String> mObjectUuidMap = new WeakHashMap<>();
private SavedStateHandler mSavedStateHandler;
private SharedPreferences mSharedPreferences;
private ViewSavedStateHandler mViewSavedStateHandler;

BridgeDelegate(@NonNull Context context,
@NonNull ExecutorService executorService,
@NonNull SavedStateHandler savedStateHandler,
@Nullable ViewSavedStateHandler viewSavedStateHandler) {
mSharedPreferences = context.getSharedPreferences(TAG, Context.MODE_PRIVATE);
mSavedStateHandler = savedStateHandler;
mExecutorService = executorService;
mViewSavedStateHandler = viewSavedStateHandler;
registerForLifecycleEvents(context);
mDiskHandler = new FileDiskHandler(context, mExecutorService);

registerForLifecycleEvents(context);

// Clear out any data from old storage mechanism
mSharedPreferences.edit().clear().apply();
context.getSharedPreferences(TAG, Context.MODE_PRIVATE).edit().clear().apply();
}

private void checkForViewSavedStateHandler() {
Expand Down

0 comments on commit 6e86970

Please sign in to comment.