Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(536)

Unified Diff: components/invalidation/android/java/src/org/chromium/components/invalidation/PendingInvalidation.java

Issue 1191393008: Introduce a layering in the invalidation component as public and impl (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Explicitly forbid content to prevent future additions Created 5 years, 6 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: components/invalidation/android/java/src/org/chromium/components/invalidation/PendingInvalidation.java
diff --git a/components/invalidation/android/java/src/org/chromium/components/invalidation/PendingInvalidation.java b/components/invalidation/android/java/src/org/chromium/components/invalidation/PendingInvalidation.java
deleted file mode 100644
index 89950f22071031028ec22586205896cf4b3c51ef..0000000000000000000000000000000000000000
--- a/components/invalidation/android/java/src/org/chromium/components/invalidation/PendingInvalidation.java
+++ /dev/null
@@ -1,136 +0,0 @@
-// Copyright 2015 The Chromium Authors. All rights reserved.
-// Use of this source code is governed by a BSD-style license that can be
-// found in the LICENSE file.
-
-package org.chromium.components.invalidation;
-
-import android.os.Bundle;
-import android.util.Base64;
-
-import com.google.protobuf.nano.MessageNano;
-
-import org.chromium.base.Log;
-import org.chromium.base.VisibleForTesting;
-import org.chromium.components.invalidation.SerializedInvalidation.Invalidation;
-
-import java.io.IOException;
-import java.util.Locale;
-
-import javax.annotation.Nullable;
-
-/**
- * A container class that stores the received invalidations.
- * It plays the role of abstracting conversions to and from other storage types like String
- * (storing in prefStore) and Bundle (ContentProvider).
- */
-public class PendingInvalidation {
- private static final String TAG = "cr.invalidation";
-
- private static final String INVALIDATION_OBJECT_SOURCE_KEY = "objectSource";
- private static final String INVALIDATION_OBJECT_ID_KEY = "objectId";
- private static final String INVALIDATION_VERSION_KEY = "version";
- private static final String INVALIDATION_PAYLOAD_KEY = "payload";
-
- public final String mObjectId;
- public final int mObjectSource;
- public final long mVersion;
- public final String mPayload;
-
- /**
- * A constructor used in tests only.
- */
- @VisibleForTesting
- public PendingInvalidation(String id, int source, long version, String payload) {
- mObjectId = id;
- mObjectSource = source;
- mVersion = version;
- mPayload = payload;
- }
-
- /**
- * Parse a PendingInvalidation from a bundle.
- */
- public PendingInvalidation(Bundle bundle) {
- // bundle.get* methods helpfully give compatible fallback values so we don't handle that.
- mObjectId = bundle.getString(INVALIDATION_OBJECT_ID_KEY);
- mObjectSource = bundle.getInt(INVALIDATION_OBJECT_SOURCE_KEY);
- mVersion = bundle.getLong(INVALIDATION_VERSION_KEY);
- mPayload = bundle.getString(INVALIDATION_PAYLOAD_KEY);
- }
-
- /**
- * Encode an invalidation into a bundle.
- */
- public static Bundle createBundle(String id, int source, long version, String payload) {
- Bundle bundle = new Bundle();
- bundle.putString(INVALIDATION_OBJECT_ID_KEY, id);
- bundle.putInt(INVALIDATION_OBJECT_SOURCE_KEY, source);
- bundle.putLong(INVALIDATION_VERSION_KEY, version);
- bundle.putString(INVALIDATION_PAYLOAD_KEY, payload);
- return bundle;
- }
-
- /**
- * Encode an invalidation into a String.
- * The invalidation is first encoded as {@link SerializedInvalidation.Invalidation}, which is
- * further encoded into a String of Base64 encoding.
- * Do not call for mObjectSource == 0, which is an invalidation for all types and is handled
- * specially.
- */
- public String encodeToString() {
- assert mObjectSource != 0;
- Invalidation invalidation = new Invalidation();
- invalidation.objectSource = mObjectSource;
- invalidation.objectId = mObjectId;
- invalidation.version = mVersion;
- invalidation.payload = mPayload;
- return Base64.encodeToString(MessageNano.toByteArray(invalidation), Base64.DEFAULT);
- }
-
- /**
- * Decode the invalidation encoded as a String into a Bundle.
- * Return value is {@code null} if the string could not be parsed or is an invalidation for all.
- */
- @Nullable
- public static Bundle decodeToBundle(String encoded) {
- assert encoded != null;
- byte[] decoded = Base64.decode(encoded, Base64.DEFAULT);
- Invalidation invalidation;
- try {
- invalidation = MessageNano.mergeFrom(new Invalidation(), decoded);
- } catch (IOException e) {
- Log.e(TAG, "Could not parse the serialized invalidations.", e);
- return null;
- }
- assert invalidation != null;
- if (invalidation.objectSource == null || invalidation.objectSource == 0) return null;
- return createBundle(invalidation.objectId, invalidation.objectSource,
- invalidation.version != null ? invalidation.version : 0L, invalidation.payload);
- }
-
- @VisibleForTesting
- @Override
- public boolean equals(Object other) {
- if (other == null) return false;
- if (other == this) return true;
- if (!(other instanceof PendingInvalidation)) return false;
- PendingInvalidation otherInvalidation = (PendingInvalidation) other;
- if (mObjectSource != otherInvalidation.mObjectSource) return false;
- if (mObjectSource == 0) return true;
- if (!mObjectId.equals(otherInvalidation.mObjectId)) return false;
- if (!mPayload.equals(otherInvalidation.mPayload)) return false;
- return mVersion == otherInvalidation.mVersion;
- }
-
- @Override
- public int hashCode() {
- return mObjectId == null ? mObjectSource : mObjectSource ^ mObjectId.hashCode()
- ^ Long.valueOf(mVersion).hashCode();
- }
-
- @Override
- public String toString() {
- return String.format(Locale.US, "objectSrc:%d,objectId:%s,version:%d,payload:%s",
- mObjectSource, mObjectId, mVersion, mPayload);
- }
-}

Powered by Google App Engine
This is Rietveld 408576698