diff options
| author | Ken Shirriff <kens@google.com> | 2009-05-22 12:33:15 -0700 | 
|---|---|---|
| committer | Ken Shirriff <kens@google.com> | 2009-06-04 15:59:48 -0700 | 
| commit | 7a9e348c0776d0d9ad773fbf304bff3fd0de2e7b (patch) | |
| tree | 82d474f32aa96073383894e70641c77cae5d7b61 /core/java/android/content | |
| parent | 2c159ec05b8fc52166e22d7c4f49cf43d10b487b (diff) | |
| download | frameworks_base-7a9e348c0776d0d9ad773fbf304bff3fd0de2e7b.zip frameworks_base-7a9e348c0776d0d9ad773fbf304bff3fd0de2e7b.tar.gz frameworks_base-7a9e348c0776d0d9ad773fbf304bff3fd0de2e7b.tar.bz2 | |
Don't crash on null edit url.
bug=1568060
Diffstat (limited to 'core/java/android/content')
| -rw-r--r-- | core/java/android/content/AbstractTableMerger.java | 48 | 
1 files changed, 28 insertions, 20 deletions
| diff --git a/core/java/android/content/AbstractTableMerger.java b/core/java/android/content/AbstractTableMerger.java index 700f1d8..94afcee 100644 --- a/core/java/android/content/AbstractTableMerger.java +++ b/core/java/android/content/AbstractTableMerger.java @@ -61,8 +61,10 @@ public abstract class AbstractTableMerger              _SYNC_ID +"=? and " + _SYNC_ACCOUNT + "=?";      private static final String SELECT_BY_ID = BaseColumns._ID +"=?"; +    // The last clause rejects events with a null _SYNC_VERSION if they've already been synced      private static final String SELECT_UNSYNCED = "" -            + _SYNC_DIRTY + " > 0 and (" + _SYNC_ACCOUNT + "=? or " + _SYNC_ACCOUNT + " is null)"; +            + _SYNC_DIRTY + " > 0 and (" + _SYNC_ACCOUNT + "=? or " + _SYNC_ACCOUNT + " is null) " +            + "and (" + _SYNC_VERSION + " is not null or " + _SYNC_ACCOUNT + " is null)";      public AbstractTableMerger(SQLiteDatabase database,              String table, Uri tableURL, String deletedTable, @@ -365,26 +367,32 @@ public abstract class AbstractTableMerger              if (!TextUtils.isEmpty(localSyncID)) {                  // An existing server item has changed -                boolean recordChanged = (localSyncVersion == null) || -                        !serverSyncVersion.equals(localSyncVersion); -                if (recordChanged) { -                    if (localSyncDirty) { -                        if (Log.isLoggable(TAG, Log.VERBOSE)) { -                            Log.v(TAG, "remote record " + serverSyncId -                                    + " conflicts with local _sync_id " + localSyncID -                                    + ", local _id " + localRowId); +                // If serverSyncVersion is null, there is no edit URL; +                // server won't let this change be written. +                // Just hold onto it, I guess, in case the server permissions +                // change later. +                if (serverSyncVersion != null) { +                    boolean recordChanged = (localSyncVersion == null) || +                            !serverSyncVersion.equals(localSyncVersion); +                    if (recordChanged) { +                        if (localSyncDirty) { +                            if (Log.isLoggable(TAG, Log.VERBOSE)) { +                                Log.v(TAG, "remote record " + serverSyncId +                                        + " conflicts with local _sync_id " + localSyncID +                                        + ", local _id " + localRowId); +                            } +                            conflict = true; +                        } else { +                            if (Log.isLoggable(TAG, Log.VERBOSE)) { +                                Log.v(TAG, +                                        "remote record " + +                                                serverSyncId + +                                                " updates local _sync_id " + +                                                localSyncID + ", local _id " + +                                                localRowId); +                            } +                            update = true;                          } -                        conflict = true; -                    } else { -                        if (Log.isLoggable(TAG, Log.VERBOSE)) { -                             Log.v(TAG, -                                     "remote record " + -                                             serverSyncId + -                                     " updates local _sync_id " + -                                     localSyncID + ", local _id " + -                                     localRowId); -                         } -                         update = true;                      }                  }              } else { | 
