Merge "Fix settings slice caching" into pi-dev am: ab3aa6989a
am: fa5e0ece68
Change-Id: Ia88dc12ead0cab4b335062cba4fbf7db8066e285
This commit is contained in:
@@ -29,6 +29,7 @@ import androidx.annotation.VisibleForTesting;
|
||||
import android.provider.SettingsSlicesContract;
|
||||
import androidx.core.graphics.drawable.IconCompat;
|
||||
import android.text.TextUtils;
|
||||
import android.util.ArrayMap;
|
||||
import android.util.Log;
|
||||
import android.util.Pair;
|
||||
|
||||
@@ -38,6 +39,7 @@ import com.android.settingslib.utils.ThreadUtils;
|
||||
import java.net.URISyntaxException;
|
||||
import java.util.ArrayList;
|
||||
import java.util.Collection;
|
||||
import java.util.HashMap;
|
||||
import java.util.List;
|
||||
import java.util.Map;
|
||||
import java.util.WeakHashMap;
|
||||
@@ -111,12 +113,14 @@ public class SettingsSliceProvider extends SliceProvider {
|
||||
SlicesDatabaseAccessor mSlicesDatabaseAccessor;
|
||||
|
||||
@VisibleForTesting
|
||||
Map<Uri, SliceData> mSliceWeakDataCache;
|
||||
Map<Uri, SliceData> mSliceDataCache;
|
||||
|
||||
@Override
|
||||
public boolean onCreateSliceProvider() {
|
||||
mSlicesDatabaseAccessor = new SlicesDatabaseAccessor(getContext());
|
||||
mSliceDataCache = new WeakHashMap<>();
|
||||
mSliceDataCache = new ArrayMap<>();
|
||||
mSliceWeakDataCache = new WeakHashMap<>();
|
||||
return true;
|
||||
}
|
||||
|
||||
@@ -131,6 +135,17 @@ public class SettingsSliceProvider extends SliceProvider {
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
public void onSlicePinned(Uri sliceUri) {
|
||||
// Start warming the slice, we expect someone will want it soon.
|
||||
loadSliceInBackground(sliceUri);
|
||||
}
|
||||
|
||||
@Override
|
||||
public void onSliceUnpinned(Uri sliceUri) {
|
||||
mSliceDataCache.remove(sliceUri);
|
||||
}
|
||||
|
||||
@Override
|
||||
public Slice onBindSlice(Uri sliceUri) {
|
||||
String path = sliceUri.getPath();
|
||||
@@ -141,14 +156,16 @@ public class SettingsSliceProvider extends SliceProvider {
|
||||
return createWifiSlice(sliceUri);
|
||||
}
|
||||
|
||||
SliceData cachedSliceData = mSliceDataCache.get(sliceUri);
|
||||
SliceData cachedSliceData = mSliceWeakDataCache.get(sliceUri);
|
||||
if (cachedSliceData == null) {
|
||||
loadSliceInBackground(sliceUri);
|
||||
return getSliceStub(sliceUri);
|
||||
}
|
||||
|
||||
// Remove the SliceData from the cache after it has been used to prevent a memory-leak.
|
||||
mSliceDataCache.remove(sliceUri);
|
||||
if (!mSliceDataCache.containsKey(sliceUri)) {
|
||||
mSliceWeakDataCache.remove(sliceUri);
|
||||
}
|
||||
return SliceBuilderUtils.buildSlice(getContext(), cachedSliceData);
|
||||
}
|
||||
|
||||
@@ -236,7 +253,12 @@ public class SettingsSliceProvider extends SliceProvider {
|
||||
long startBuildTime = System.currentTimeMillis();
|
||||
|
||||
final SliceData sliceData = mSlicesDatabaseAccessor.getSliceDataFromUri(uri);
|
||||
mSliceDataCache.put(uri, sliceData);
|
||||
List<Uri> pinnedSlices = getContext().getSystemService(
|
||||
SliceManager.class).getPinnedSlices();
|
||||
if (pinnedSlices.contains(uri)) {
|
||||
mSliceDataCache.put(uri, sliceData);
|
||||
}
|
||||
mSliceWeakDataCache.put(uri, sliceData);
|
||||
getContext().getContentResolver().notifyChange(uri, null /* content observer */);
|
||||
|
||||
Log.d(TAG, "Built slice (" + uri + ") in: " +
|
||||
|
Reference in New Issue
Block a user