diff options
author | android-build-team Robot <android-build-team-robot@google.com> | 2017-05-28 07:26:33 +0000 |
---|---|---|
committer | android-build-team Robot <android-build-team-robot@google.com> | 2017-05-28 07:26:33 +0000 |
commit | 06c040c5323b54ab598b3d502617f8178cb1a644 (patch) | |
tree | 7b61e453e289c8fae19f1f091721a1e73ef318fb | |
parent | 5e658bcb94545a1e955d00b396b0115869150e75 (diff) | |
parent | 58a1f876fb972d290bba505365605ab6f4087c7f (diff) | |
download | ContactsProvider-06c040c5323b54ab598b3d502617f8178cb1a644.tar.gz |
release-request-fca2b5ac-03eb-4055-a549-b4fc2b292b64-for-git_oc-release-4049993 snap-temp-L04900000068539456
Change-Id: I8d3edd4eea7608b6a54bce11897bd720321c257a
-rw-r--r-- | src/com/android/providers/contacts/DbModifierWithNotification.java | 11 |
1 files changed, 10 insertions, 1 deletions
diff --git a/src/com/android/providers/contacts/DbModifierWithNotification.java b/src/com/android/providers/contacts/DbModifierWithNotification.java index f67a2a8f..cb5460ce 100644 --- a/src/com/android/providers/contacts/DbModifierWithNotification.java +++ b/src/com/android/providers/contacts/DbModifierWithNotification.java @@ -37,9 +37,11 @@ import android.provider.VoicemailContract; import android.provider.VoicemailContract.Status; import android.provider.VoicemailContract.Voicemails; import android.util.Log; + import com.android.common.io.MoreCloseables; import com.android.providers.contacts.CallLogDatabaseHelper.Tables; import com.android.providers.contacts.util.DbQueryUtils; + import com.google.android.collect.Lists; import com.google.common.collect.Iterables; import java.util.ArrayList; @@ -172,7 +174,14 @@ public class DbModifierWithNotification implements DatabaseModifier { // from the server and thus is synced or "clean". Otherwise, it means that a local // change is being made to the database, so the entries should be marked as "dirty" // so that the corresponding sync adapter knows they need to be synced. - final int isDirty = isSelfModifyingOrInternal(packagesModified) ? 0 : 1; + int isDirty; + Integer callerSetDirty = values.getAsInteger(Voicemails.DIRTY); + if (callerSetDirty != null) { + // Respect the calling package if it sets the dirty flag + isDirty = callerSetDirty == 0 ? 0 : 1; + } else { + isDirty = isSelfModifyingOrInternal(packagesModified) ? 0 : 1; + } values.put(VoicemailContract.Voicemails.DIRTY, isDirty); if (isDirty == 0 && values.containsKey(Calls.IS_READ) && getAsBoolean(values, |