Commit d2d50f9a authored by xiaofeng@google.com's avatar xiaofeng@google.com

Fix Java compile issues under JDK 1.5

parent a4491ea1
...@@ -37,7 +37,6 @@ import java.io.OutputStream; ...@@ -37,7 +37,6 @@ import java.io.OutputStream;
import java.io.UnsupportedEncodingException; import java.io.UnsupportedEncodingException;
import java.nio.ByteBuffer; import java.nio.ByteBuffer;
import java.util.ArrayList; import java.util.ArrayList;
import java.util.Arrays;
import java.util.Collection; import java.util.Collection;
import java.util.Iterator; import java.util.Iterator;
import java.util.List; import java.util.List;
...@@ -776,6 +775,15 @@ public abstract class ByteString implements Iterable<Byte> { ...@@ -776,6 +775,15 @@ public abstract class ByteString implements Iterable<Byte> {
flushLastBuffer(); flushLastBuffer();
return ByteString.copyFrom(flushedBuffers); return ByteString.copyFrom(flushedBuffers);
} }
/**
* Implement java.util.Arrays.copyOf() for jdk 1.5.
*/
private byte[] copyArray(byte[] buffer, int length) {
byte[] result = new byte[length];
System.arraycopy(buffer, 0, result, 0, Math.min(buffer.length, length));
return result;
}
/** /**
* Writes the complete contents of this byte array output stream to * Writes the complete contents of this byte array output stream to
...@@ -800,7 +808,7 @@ public abstract class ByteString implements Iterable<Byte> { ...@@ -800,7 +808,7 @@ public abstract class ByteString implements Iterable<Byte> {
byteString.writeTo(out); byteString.writeTo(out);
} }
out.write(Arrays.copyOf(cachedBuffer, cachedBufferPos)); out.write(copyArray(cachedBuffer, cachedBufferPos));
} }
/** /**
...@@ -853,7 +861,7 @@ public abstract class ByteString implements Iterable<Byte> { ...@@ -853,7 +861,7 @@ public abstract class ByteString implements Iterable<Byte> {
private void flushLastBuffer() { private void flushLastBuffer() {
if (bufferPos < buffer.length) { if (bufferPos < buffer.length) {
if (bufferPos > 0) { if (bufferPos > 0) {
byte[] bufferCopy = Arrays.copyOf(buffer, bufferPos); byte[] bufferCopy = copyArray(buffer, bufferPos);
flushedBuffers.add(new LiteralByteString(bufferCopy)); flushedBuffers.add(new LiteralByteString(bufferCopy));
} }
// We reuse this buffer for further writes. // We reuse this buffer for further writes.
......
...@@ -157,12 +157,10 @@ class LazyField { ...@@ -157,12 +157,10 @@ class LazyField {
this.entry = entry; this.entry = entry;
} }
@Override
public K getKey() { public K getKey() {
return entry.getKey(); return entry.getKey();
} }
@Override
public Object getValue() { public Object getValue() {
LazyField field = entry.getValue(); LazyField field = entry.getValue();
if (field == null) { if (field == null) {
...@@ -175,7 +173,6 @@ class LazyField { ...@@ -175,7 +173,6 @@ class LazyField {
return entry.getValue(); return entry.getValue();
} }
@Override
public Object setValue(Object value) { public Object setValue(Object value) {
if (!(value instanceof MessageLite)) { if (!(value instanceof MessageLite)) {
throw new IllegalArgumentException( throw new IllegalArgumentException(
...@@ -193,13 +190,11 @@ class LazyField { ...@@ -193,13 +190,11 @@ class LazyField {
this.iterator = iterator; this.iterator = iterator;
} }
@Override
public boolean hasNext() { public boolean hasNext() {
return iterator.hasNext(); return iterator.hasNext();
} }
@SuppressWarnings("unchecked") @SuppressWarnings("unchecked")
@Override
public Entry<K, Object> next() { public Entry<K, Object> next() {
Entry<K, ?> entry = iterator.next(); Entry<K, ?> entry = iterator.next();
if (entry.getValue() instanceof LazyField) { if (entry.getValue() instanceof LazyField) {
...@@ -208,7 +203,6 @@ class LazyField { ...@@ -208,7 +203,6 @@ class LazyField {
return (Entry<K, Object>) entry; return (Entry<K, Object>) entry;
} }
@Override
public void remove() { public void remove() {
iterator.remove(); iterator.remove();
} }
......
...@@ -172,7 +172,6 @@ public class LazyStringArrayList extends AbstractList<String> ...@@ -172,7 +172,6 @@ public class LazyStringArrayList extends AbstractList<String>
} }
} }
@Override
public List<?> getUnderlyingElements() { public List<?> getUnderlyingElements() {
return Collections.unmodifiableList(list); return Collections.unmodifiableList(list);
} }
......
...@@ -36,13 +36,12 @@ import java.io.OutputStream; ...@@ -36,13 +36,12 @@ import java.io.OutputStream;
import java.io.UnsupportedEncodingException; import java.io.UnsupportedEncodingException;
import java.io.ByteArrayInputStream; import java.io.ByteArrayInputStream;
import java.nio.ByteBuffer; import java.nio.ByteBuffer;
import java.util.ArrayDeque;
import java.util.ArrayList; import java.util.ArrayList;
import java.util.Arrays; import java.util.Arrays;
import java.util.Deque;
import java.util.Iterator; import java.util.Iterator;
import java.util.List; import java.util.List;
import java.util.NoSuchElementException; import java.util.NoSuchElementException;
import java.util.Stack;
/** /**
* Class to represent {@code ByteStrings} formed by concatenation of other * Class to represent {@code ByteStrings} formed by concatenation of other
...@@ -590,8 +589,7 @@ class RopeByteString extends ByteString { ...@@ -590,8 +589,7 @@ class RopeByteString extends ByteString {
// Stack containing the part of the string, starting from the left, that // Stack containing the part of the string, starting from the left, that
// we've already traversed. The final string should be the equivalent of // we've already traversed. The final string should be the equivalent of
// concatenating the strings on the stack from bottom to top. // concatenating the strings on the stack from bottom to top.
private final Deque<ByteString> prefixesStack = private final Stack<ByteString> prefixesStack = new Stack<ByteString>();
new ArrayDeque<ByteString>(minLengthByDepth.length);
private ByteString balance(ByteString left, ByteString right) { private ByteString balance(ByteString left, ByteString right) {
doBalance(left); doBalance(left);
...@@ -703,8 +701,8 @@ class RopeByteString extends ByteString { ...@@ -703,8 +701,8 @@ class RopeByteString extends ByteString {
*/ */
private static class PieceIterator implements Iterator<LiteralByteString> { private static class PieceIterator implements Iterator<LiteralByteString> {
private final Deque<RopeByteString> breadCrumbs = private final Stack<RopeByteString> breadCrumbs =
new ArrayDeque<RopeByteString>(minLengthByDepth.length); new Stack<RopeByteString>();
private LiteralByteString next; private LiteralByteString next;
private PieceIterator(ByteString root) { private PieceIterator(ByteString root) {
......
...@@ -145,7 +145,6 @@ public class UnmodifiableLazyStringList extends AbstractList<String> ...@@ -145,7 +145,6 @@ public class UnmodifiableLazyStringList extends AbstractList<String>
}; };
} }
@Override
public List<?> getUnderlyingElements() { public List<?> getUnderlyingElements() {
// The returned value is already unmodifiable. // The returned value is already unmodifiable.
return list.getUnderlyingElements(); return list.getUnderlyingElements();
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment