diff options
| author | 2013-03-06 16:25:50 -0800 | |
|---|---|---|
| committer | 2013-03-06 16:28:36 -0800 | |
| commit | 94c91dca55de9ffdbe072fcc5dd6dbf1efe5e4c1 (patch) | |
| tree | 9e1a4a989c4188f15264b7c5a786f346ae876a5e | |
| parent | 18dd9b94150bf8960314aa52f2f05e31fd9a7432 (diff) | |
ArrayUtils.indexOf(), containsAll() with tests.
Change-Id: I040164d4e45126e4a6c1df54bd114f47951da560
3 files changed, 116 insertions, 5 deletions
diff --git a/core/java/android/content/pm/Signature.java b/core/java/android/content/pm/Signature.java index 9c9340d0ef00..752bf8b34b92 100644 --- a/core/java/android/content/pm/Signature.java +++ b/core/java/android/content/pm/Signature.java @@ -19,6 +19,8 @@ package android.content.pm; import android.os.Parcel; import android.os.Parcelable; +import com.android.internal.util.ArrayUtils; + import java.io.ByteArrayInputStream; import java.lang.ref.SoftReference; import java.security.PublicKey; @@ -198,4 +200,13 @@ public class Signature implements Parcelable { private Signature(Parcel source) { mSignature = source.createByteArray(); } + + /** + * Test if given {@link Signature} sets are exactly equal. + * + * @hide + */ + public static boolean areExactMatch(Signature[] a, Signature[] b) { + return ArrayUtils.containsAll(a, b) && ArrayUtils.containsAll(b, a); + } } diff --git a/core/java/com/android/internal/util/ArrayUtils.java b/core/java/com/android/internal/util/ArrayUtils.java index dbf6c8e54ca2..d44df0c6e1c8 100644 --- a/core/java/com/android/internal/util/ArrayUtils.java +++ b/core/java/com/android/internal/util/ArrayUtils.java @@ -123,14 +123,34 @@ public class ArrayUtils * @return true if the value is present in the array */ public static <T> boolean contains(T[] array, T value) { - for (T element : array) { - if (element == null) { - if (value == null) return true; + return indexOf(array, value) != -1; + } + + /** + * Return first index of {@code value} in {@code array}, or {@code -1} if + * not found. + */ + public static <T> int indexOf(T[] array, T value) { + for (int i = 0; i < array.length; i++) { + if (array[i] == null) { + if (value == null) return i; } else { - if (value != null && element.equals(value)) return true; + if (value != null && array[i].equals(value)) return i; } } - return false; + return -1; + } + + /** + * Test if all {@code check} items are contained in {@code array}. + */ + public static <T> boolean containsAll(T[] array, T[] check) { + for (T checkItem : check) { + if (!contains(array, checkItem)) { + return false; + } + } + return true; } public static boolean contains(int[] array, int value) { diff --git a/core/tests/coretests/src/com/android/internal/util/ArrayUtilsTest.java b/core/tests/coretests/src/com/android/internal/util/ArrayUtilsTest.java new file mode 100644 index 000000000000..5dc9ef8a87a1 --- /dev/null +++ b/core/tests/coretests/src/com/android/internal/util/ArrayUtilsTest.java @@ -0,0 +1,80 @@ +/* + * Copyright (C) 2013 The Android Open Source Project + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +package com.android.internal.util; + +import junit.framework.TestCase; + +/** + * Tests for {@link ArrayUtils} + */ +public class ArrayUtilsTest extends TestCase { + public void testContains() throws Exception { + final Object A = new Object(); + final Object B = new Object(); + final Object C = new Object(); + final Object D = new Object(); + + assertTrue(ArrayUtils.contains(new Object[] { A, B, C }, A)); + assertTrue(ArrayUtils.contains(new Object[] { A, B, C }, B)); + assertTrue(ArrayUtils.contains(new Object[] { A, B, C }, C)); + assertTrue(ArrayUtils.contains(new Object[] { A, null, C }, null)); + + assertFalse(ArrayUtils.contains(new Object[] { A, B, C }, null)); + assertFalse(ArrayUtils.contains(new Object[] { }, null)); + assertFalse(ArrayUtils.contains(new Object[] { null }, A)); + } + + public void testIndexOf() throws Exception { + final Object A = new Object(); + final Object B = new Object(); + final Object C = new Object(); + final Object D = new Object(); + + assertEquals(0, ArrayUtils.indexOf(new Object[] { A, B, C }, A)); + assertEquals(1, ArrayUtils.indexOf(new Object[] { A, B, C }, B)); + assertEquals(2, ArrayUtils.indexOf(new Object[] { A, B, C }, C)); + assertEquals(-1, ArrayUtils.indexOf(new Object[] { A, B, C }, D)); + + assertEquals(-1, ArrayUtils.indexOf(new Object[] { A, B, C }, null)); + assertEquals(-1, ArrayUtils.indexOf(new Object[] { }, A)); + assertEquals(-1, ArrayUtils.indexOf(new Object[] { }, null)); + + assertEquals(0, ArrayUtils.indexOf(new Object[] { null, null }, null)); + assertEquals(1, ArrayUtils.indexOf(new Object[] { A, null, B }, null)); + assertEquals(2, ArrayUtils.indexOf(new Object[] { A, null, B }, B)); + } + + public void testContainsAll() throws Exception { + final Object A = new Object(); + final Object B = new Object(); + final Object C = new Object(); + + assertTrue(ArrayUtils.containsAll(new Object[] { C, B, A }, new Object[] { A, B, C })); + assertTrue(ArrayUtils.containsAll(new Object[] { A, B }, new Object[] { A })); + assertTrue(ArrayUtils.containsAll(new Object[] { A }, new Object[] { A })); + assertTrue(ArrayUtils.containsAll(new Object[] { A }, new Object[] { })); + assertTrue(ArrayUtils.containsAll(new Object[] { }, new Object[] { })); + assertTrue(ArrayUtils.containsAll(new Object[] { null }, new Object[] { })); + assertTrue(ArrayUtils.containsAll(new Object[] { null }, new Object[] { null })); + assertTrue(ArrayUtils.containsAll(new Object[] { A, null, C }, new Object[] { C, null })); + + assertFalse(ArrayUtils.containsAll(new Object[] { }, new Object[] { A })); + assertFalse(ArrayUtils.containsAll(new Object[] { B }, new Object[] { A })); + assertFalse(ArrayUtils.containsAll(new Object[] { }, new Object[] { null })); + assertFalse(ArrayUtils.containsAll(new Object[] { A }, new Object[] { null })); + } +} |