| Index: third_party/protobuf/java/core/src/main/java/com/google/protobuf/LongArrayList.java
|
| diff --git a/third_party/protobuf/java/src/main/java/com/google/protobuf/LongArrayList.java b/third_party/protobuf/java/core/src/main/java/com/google/protobuf/LongArrayList.java
|
| similarity index 86%
|
| rename from third_party/protobuf/java/src/main/java/com/google/protobuf/LongArrayList.java
|
| rename to third_party/protobuf/java/core/src/main/java/com/google/protobuf/LongArrayList.java
|
| index ebe620290028e837e0b5f2686422fadbddf5dc5f..bc4475d11aa916cf79529e18fa636f28eb7bf3e6 100644
|
| --- a/third_party/protobuf/java/src/main/java/com/google/protobuf/LongArrayList.java
|
| +++ b/third_party/protobuf/java/core/src/main/java/com/google/protobuf/LongArrayList.java
|
| @@ -34,7 +34,6 @@ import com.google.protobuf.Internal.LongList;
|
|
|
| import java.util.Arrays;
|
| import java.util.Collection;
|
| -import java.util.List;
|
| import java.util.RandomAccess;
|
|
|
| /**
|
| @@ -44,8 +43,6 @@ import java.util.RandomAccess;
|
| */
|
| final class LongArrayList extends AbstractProtobufList<Long> implements LongList, RandomAccess {
|
|
|
| - private static final int DEFAULT_CAPACITY = 10;
|
| -
|
| private static final LongArrayList EMPTY_LIST = new LongArrayList();
|
| static {
|
| EMPTY_LIST.makeImmutable();
|
| @@ -70,32 +67,55 @@ final class LongArrayList extends AbstractProtobufList<Long> implements LongList
|
| * Constructs a new mutable {@code LongArrayList} with default capacity.
|
| */
|
| LongArrayList() {
|
| - this(DEFAULT_CAPACITY);
|
| - }
|
| -
|
| - /**
|
| - * Constructs a new mutable {@code LongArrayList} with the provided capacity.
|
| - */
|
| - LongArrayList(int capacity) {
|
| - array = new long[capacity];
|
| - size = 0;
|
| + this(new long[DEFAULT_CAPACITY], 0);
|
| }
|
|
|
| /**
|
| * Constructs a new mutable {@code LongArrayList} containing the same elements as {@code other}.
|
| */
|
| - LongArrayList(List<Long> other) {
|
| - if (other instanceof LongArrayList) {
|
| - LongArrayList list = (LongArrayList) other;
|
| - array = list.array.clone();
|
| - size = list.size;
|
| - } else {
|
| - size = other.size();
|
| - array = new long[size];
|
| - for (int i = 0; i < size; i++) {
|
| - array[i] = other.get(i);
|
| + private LongArrayList(long[] array, int size) {
|
| + this.array = array;
|
| + this.size = size;
|
| + }
|
| +
|
| + @Override
|
| + public boolean equals(Object o) {
|
| + if (this == o) {
|
| + return true;
|
| + }
|
| + if (!(o instanceof IntArrayList)) {
|
| + return super.equals(o);
|
| + }
|
| + LongArrayList other = (LongArrayList) o;
|
| + if (size != other.size) {
|
| + return false;
|
| + }
|
| +
|
| + final long[] arr = other.array;
|
| + for (int i = 0; i < size; i++) {
|
| + if (array[i] != arr[i]) {
|
| + return false;
|
| }
|
| }
|
| +
|
| + return true;
|
| + }
|
| +
|
| + @Override
|
| + public int hashCode() {
|
| + int result = 1;
|
| + for (int i = 0; i < size; i++) {
|
| + result = (31 * result) + Internal.hashLong(array[i]);
|
| + }
|
| + return result;
|
| + }
|
| +
|
| + @Override
|
| + public LongList mutableCopyWithCapacity(int capacity) {
|
| + if (capacity < size) {
|
| + throw new IllegalArgumentException();
|
| + }
|
| + return new LongArrayList(Arrays.copyOf(array, capacity), size);
|
| }
|
|
|
| @Override
|
|
|