diff options
author | Chris Wren <cwren@android.com> | 2014-09-12 18:36:30 +0000 |
---|---|---|
committer | Android (Google) Code Review <android-gerrit@google.com> | 2014-09-12 18:36:31 +0000 |
commit | d33fe22b362661973455fe6b741bc82a44726512 (patch) | |
tree | 706967720b5f682c5e2c7947e436c967e4e8ffb4 | |
parent | e9cfbadc357289115d5ade81e67aa2e1af3dfa8d (diff) | |
parent | 99f4c7d0c9c9c29ced22da0a8af4d1a04b0ef186 (diff) | |
download | frameworks_base-d33fe22b362661973455fe6b741bc82a44726512.zip frameworks_base-d33fe22b362661973455fe6b741bc82a44726512.tar.gz frameworks_base-d33fe22b362661973455fe6b741bc82a44726512.tar.bz2 |
Merge "Invalidate the people cache on Contacts provider changes." into lmp-dev
-rw-r--r-- | services/core/java/com/android/server/notification/ValidateNotificationPeople.java | 21 |
1 files changed, 21 insertions, 0 deletions
diff --git a/services/core/java/com/android/server/notification/ValidateNotificationPeople.java b/services/core/java/com/android/server/notification/ValidateNotificationPeople.java index d49dc9a..1c1a034 100644 --- a/services/core/java/com/android/server/notification/ValidateNotificationPeople.java +++ b/services/core/java/com/android/server/notification/ValidateNotificationPeople.java @@ -19,9 +19,11 @@ package com.android.server.notification; import android.app.Notification; import android.content.Context; import android.content.pm.PackageManager; +import android.database.ContentObserver; import android.database.Cursor; import android.net.Uri; import android.os.Bundle; +import android.os.Handler; import android.os.UserHandle; import android.provider.ContactsContract; import android.provider.ContactsContract.Contacts; @@ -75,6 +77,9 @@ public class ValidateNotificationPeople implements NotificationSignalExtractor { // maps raw person handle to resolved person object private LruCache<String, LookupResult> mPeopleCache; private Map<Integer, Context> mUserToContextMap; + private Handler mHandler; + private ContentObserver mObserver; + private int mEvictionCount; public void initialize(Context context) { if (DEBUG) Slog.d(TAG, "Initializing " + getClass().getSimpleName() + "."); @@ -83,6 +88,22 @@ public class ValidateNotificationPeople implements NotificationSignalExtractor { mPeopleCache = new LruCache<String, LookupResult>(PEOPLE_CACHE_SIZE); mEnabled = ENABLE_PEOPLE_VALIDATOR && 1 == Settings.Global.getInt( mBaseContext.getContentResolver(), SETTING_ENABLE_PEOPLE_VALIDATOR, 1); + if (mEnabled) { + mHandler = new Handler(); + mObserver = new ContentObserver(mHandler) { + @Override + public void onChange(boolean selfChange, Uri uri, int userId) { + super.onChange(selfChange, uri, userId); + if (DEBUG || mEvictionCount % 100 == 0) { + if (INFO) Slog.i(TAG, "mEvictionCount: " + mEvictionCount); + } + mPeopleCache.evictAll(); + mEvictionCount++; + } + }; + mBaseContext.getContentResolver().registerContentObserver(Contacts.CONTENT_URI, true, + mObserver, UserHandle.USER_ALL); + } } public RankingReconsideration process(NotificationRecord record) { |