diff --git a/spring-core/src/main/java/org/springframework/util/DigestUtils.java b/spring-core/src/main/java/org/springframework/util/DigestUtils.java index 29dcb54105..87ca6b852e 100644 --- a/spring-core/src/main/java/org/springframework/util/DigestUtils.java +++ b/spring-core/src/main/java/org/springframework/util/DigestUtils.java @@ -28,6 +28,7 @@ import java.security.NoSuchAlgorithmException; * more comprehensive suite of digest utilities. * * @author Arjen Poutsma + * @author Craig Andrews * @since 3.0 * @see org.apache.commons.codec.digest.DigestUtils */ @@ -38,6 +39,7 @@ public abstract class DigestUtils { private static final char[] HEX_CHARS = {'0', '1', '2', '3', '4', '5', '6', '7', '8', '9', 'a', 'b', 'c', 'd', 'e', 'f'}; + /** * Calculate the MD5 digest of the given bytes. * @param bytes the bytes to calculate the digest over @@ -53,7 +55,7 @@ public abstract class DigestUtils { * @return the digest * @since 4.2 */ - public static byte[] md5Digest(InputStream inputStream) throws IOException{ + public static byte[] md5Digest(InputStream inputStream) throws IOException { return digest(MD5_ALGORITHM_NAME, inputStream); } @@ -74,7 +76,7 @@ public abstract class DigestUtils { * @return a hexadecimal digest string * @since 4.2 */ - public static String md5DigestAsHex(InputStream inputStream) throws IOException{ + public static String md5DigestAsHex(InputStream inputStream) throws IOException { return digestAsHexString(MD5_ALGORITHM_NAME, inputStream); } @@ -97,13 +99,14 @@ public abstract class DigestUtils { * @return the given string builder * @since 4.2 */ - public static StringBuilder appendMd5DigestAsHex(InputStream inputStream, StringBuilder builder) throws IOException{ + public static StringBuilder appendMd5DigestAsHex(InputStream inputStream, StringBuilder builder) throws IOException { return appendDigestAsHex(MD5_ALGORITHM_NAME, inputStream, builder); } + /** - * Creates a new {@link MessageDigest} with the given algorithm. Necessary - * because {@code MessageDigest} is not thread-safe. + * Create a new {@link MessageDigest} with the given algorithm. + * Necessary because {@code MessageDigest} is not thread-safe. */ private static MessageDigest getDigest(String algorithm) { try { @@ -118,12 +121,13 @@ public abstract class DigestUtils { return getDigest(algorithm).digest(bytes); } - private static byte[] digest(String algorithm, InputStream inputStream) throws IOException{ + private static byte[] digest(String algorithm, InputStream inputStream) throws IOException { MessageDigest messageDigest = getDigest(algorithm); - if(inputStream instanceof UpdateMessageDigestInputStream){ + if (inputStream instanceof UpdateMessageDigestInputStream){ ((UpdateMessageDigestInputStream) inputStream).updateMessageDigest(messageDigest); return messageDigest.digest(); - }else{ + } + else{ return messageDigest.digest(StreamUtils.copyToByteArray(inputStream)); } } @@ -133,7 +137,7 @@ public abstract class DigestUtils { return new String(hexDigest); } - private static String digestAsHexString(String algorithm, InputStream inputStream) throws IOException{ + private static String digestAsHexString(String algorithm, InputStream inputStream) throws IOException { char[] hexDigest = digestAsHexChars(algorithm, inputStream); return new String(hexDigest); } @@ -143,7 +147,9 @@ public abstract class DigestUtils { return builder.append(hexDigest); } - private static StringBuilder appendDigestAsHex(String algorithm, InputStream inputStream, StringBuilder builder) throws IOException{ + private static StringBuilder appendDigestAsHex(String algorithm, InputStream inputStream, StringBuilder builder) + throws IOException { + char[] hexDigest = digestAsHexChars(algorithm, inputStream); return builder.append(hexDigest); } @@ -153,7 +159,7 @@ public abstract class DigestUtils { return encodeHex(digest); } - private static char[] digestAsHexChars(String algorithm, InputStream inputStream) throws IOException{ + private static char[] digestAsHexChars(String algorithm, InputStream inputStream) throws IOException { byte[] digest = digest(algorithm, inputStream); return encodeHex(digest); } diff --git a/spring-core/src/main/java/org/springframework/util/FastByteArrayOutputStream.java b/spring-core/src/main/java/org/springframework/util/FastByteArrayOutputStream.java index 6c6eb46e3a..3fa6fcf69a 100644 --- a/spring-core/src/main/java/org/springframework/util/FastByteArrayOutputStream.java +++ b/spring-core/src/main/java/org/springframework/util/FastByteArrayOutputStream.java @@ -25,14 +25,14 @@ import java.util.LinkedList; /** * A speedy alternative to {@link java.io.ByteArrayOutputStream}. - *
Unlike {@link java.io.ByteArrayOutputStream}, this implementation is backed by a - * {@link java.util.LinkedList} of byte[] instead of 1 constantly resizing byte[]. - * It does not copy buffers when it's expanded.
+ * + *Unlike {@link java.io.ByteArrayOutputStream}, this implementation is backed + * by a {@link java.util.LinkedList} of {@code byte[]} instead of 1 constantly + * resizing {@code byte[]}. It does not copy buffers when it gets expanded. * *
The initial buffer is only created when the stream is first written. - * There's also no copying of the internal buffer if its contents is extracted with the - * {@link #writeTo(OutputStream)} method. - * Instances of this class are NOT THREAD SAFE.
+ * There is also no copying of the internal buffer if its contents is extracted + * with the {@link #writeTo(OutputStream)} method. * * @author Craig Andrews * @since 4.2 @@ -41,28 +41,30 @@ public final class FastByteArrayOutputStream extends OutputStream { private static final int DEFAULT_BLOCK_SIZE = 256; - // the buffers used to store the content bytes + + // The buffers used to store the content bytes private final LinkedListFastByteArrayOutputStream
- * with the default initial capacity of {@value #DEFAULT_BLOCK_SIZE} bytes.
+ * with the default initial capacity of 256 bytes.
*/
public FastByteArrayOutputStream() {
this(DEFAULT_BLOCK_SIZE);
@@ -76,20 +78,23 @@ public final class FastByteArrayOutputStream extends OutputStream {
public FastByteArrayOutputStream(int initialBlockSize) {
Assert.isTrue(initialBlockSize > 0, "Initial block size must be greater than 0");
this.initialBlockSize = initialBlockSize;
- nextBlockSize = initialBlockSize;
+ this.nextBlockSize = initialBlockSize;
}
+
+ // Overridden methods
+
@Override
public void write(int datum) throws IOException {
- if (closed) {
+ if (this.closed) {
throw new IOException("Stream closed");
}
else {
- if (buffers.peekLast() == null || buffers.getLast().length == index) {
+ if (this.buffers.peekLast() == null || this.buffers.getLast().length == this.index) {
addBuffer(1);
}
// store the byte
- buffers.getLast()[index++] = (byte) datum;
+ this.buffers.getLast()[this.index++] = (byte) datum;
}
}
@@ -98,60 +103,81 @@ public final class FastByteArrayOutputStream extends OutputStream {
if (data == null) {
throw new NullPointerException();
}
- else if ((offset < 0) || ((offset + length) > data.length) || (length < 0)) {
+ else if (offset < 0 || offset + length > data.length || length < 0) {
throw new IndexOutOfBoundsException();
}
- else if (closed) {
+ else if (this.closed) {
throw new IOException("Stream closed");
}
else {
- if (buffers.peekLast() == null || buffers.getLast().length == index) {
+ if (this.buffers.peekLast() == null || this.buffers.getLast().length == this.index) {
addBuffer(length);
}
- if ((index + length) > buffers.getLast().length) {
+ if (this.index + length > this.buffers.getLast().length) {
+ int pos = offset;
do {
- if (index == buffers.getLast().length) {
+ if (this.index == this.buffers.getLast().length) {
addBuffer(length);
}
- int copyLength = buffers.getLast().length - index;
+ int copyLength = this.buffers.getLast().length - this.index;
if (length < copyLength) {
copyLength = length;
}
- System.arraycopy(data, offset, buffers.getLast(), index, copyLength);
- offset += copyLength;
- index += copyLength;
+ System.arraycopy(data, pos, this.buffers.getLast(), this.index, copyLength);
+ pos += copyLength;
+ this.index += copyLength;
length -= copyLength;
- } while (length > 0);
+ }
+ while (length > 0);
}
else {
- // Copy in the subarray
- System.arraycopy(data, offset, buffers.getLast(), index, length);
- index += length;
+ // copy in the sub-array
+ System.arraycopy(data, offset, this.buffers.getLast(), this.index, length);
+ this.index += length;
}
}
}
@Override
public void close() {
- closed = true;
+ this.closed = true;
}
/**
- * Returns the number of bytes stored in this FastByteArrayOutputStream
+ * Convert the buffer's contents into a string decoding bytes using the
+ * platform's default character set. The length of the new String
+ * is a function of the character set, and hence may not be equal to the
+ * size of the buffer.
+ * This method always replaces malformed-input and unmappable-character
+ * sequences with the default replacement string for the platform's
+ * default character set. The {@linkplain java.nio.charset.CharsetDecoder}
+ * class should be used when more control over the decoding process is
+ * required.
+ * @return a String decoded from the buffer's contents
+ */
+ @Override
+ public String toString() {
+ return new String(toByteArrayUnsafe());
+ }
+
+
+ // Custom methods
+
+ /**
+ * Return the number of bytes stored in this FastByteArrayOutputStream
.
*/
public int size() {
- return alreadyBufferedSize + index;
+ return (this.alreadyBufferedSize + this.index);
}
/**
* Convert the stream's data to a byte array and return the byte array.
- *
*
Also replaces the internal structures with the byte array to conserve memory: - * if the byte array is being made anyways, mind as well as use it. - * This approach also means that if this method is called twice without any writes in between, + * if the byte array is being made anyways, mind as well as use it. This approach + * also means that if this method is called twice without any writes in between, * the second call is a no-op. - * This method is "unsafe" as it returns the internal buffer - callers should not modify the returned buffer.
- * + *This method is "unsafe" as it returns the internal buffer. + * Callers should not modify the returned buffer. * @return the current contents of this output stream, as a byte array. * @see #size() * @see #toByteArray() @@ -162,16 +188,14 @@ public final class FastByteArrayOutputStream extends OutputStream { return new byte[0]; } resize(totalSize); - return buffers.getFirst(); + return this.buffers.getFirst(); } /** * Creates a newly allocated byte array. - * *
Its size is the current * size of this output stream and the valid contents of the buffer * have been copied into it.
- * * @return the current contents of this output stream, as a byte array. * @see #size() * @see #toByteArrayUnsafe() @@ -184,54 +208,49 @@ public final class FastByteArrayOutputStream extends OutputStream { } /** - * Resets the contents of thisFastByteArrayOutputStreamInputStream
+ * Reset the contents of this FastByteArrayOutputStream
.
* All currently accumulated output in the output stream is discarded. - * The output stream can be used again.
+ * The output stream can be used again. */ public void reset() { - buffers.clear(); - nextBlockSize = initialBlockSize; - closed = false; - index = 0; - alreadyBufferedSize = 0; + this.buffers.clear(); + this.nextBlockSize = this.initialBlockSize; + this.closed = false; + this.index = 0; + this.alreadyBufferedSize = 0; } /** - * Get an {@link java.io.InputStream} to retrieve the data in this OutputStream - * + * Get an {@link InputStream} to retrieve the data in this OutputStream. *Note that if any methods are called on the OutputStream * (including, but not limited to, any of the write methods, {@link #reset()}, - * {@link #toByteArray()}, and {@link #toByteArrayUnsafe()}) then the {@link java.io.InputStream}'s - * behavior is undefined.
- * - * @return {@link java.io.InputStream} of the contents of thisFastByteArrayOutputStreamInputStream
+ * {@link #toByteArray()}, and {@link #toByteArrayUnsafe()}) then the
+ * {@link java.io.InputStream}'s behavior is undefined.
+ * @return {@link InputStream} of the contents of this OutputStream
*/
public InputStream getInputStream() {
- return new FastByteArrayOutputStreamInputStream(this);
+ return new FastByteArrayInputStream(this);
}
/**
- * Write the buffers content to the given OutputStream
- *
+ * Write the buffers content to the given OutputStream.
* @param out the OutputStream to write to
*/
public void writeTo(OutputStream out) throws IOException {
- IteratorAdds a new buffer that can store at least {@code minCapacity} bytes
+ *Adds a new buffer that can store at least {@code minCapacity} bytes. */ private void addBuffer(int minCapacity) { - if (buffers.peekLast() != null) { - alreadyBufferedSize += index; - index = 0; + if (this.buffers.peekLast() != null) { + this.alreadyBufferedSize += this.index; + this.index = 0; } - if (nextBlockSize < minCapacity) { - nextBlockSize = nextPowerOf2(minCapacity); + if (this.nextBlockSize < minCapacity) { + this.nextBlockSize = nextPowerOf2(minCapacity); } - buffers.add(new byte[nextBlockSize]); - nextBlockSize *= 2; // block size doubles each time + this.buffers.add(new byte[this.nextBlockSize]); + this.nextBlockSize *= 2; // block size doubles each time } /** - * Get the next power of 2 of a number (ex, the next power of 2 of 119 is 128) + * Get the next power of 2 of a number (ex, the next power of 2 of 119 is 128). */ - private static final int nextPowerOf2(int val) { + private static int nextPowerOf2(int val) { val--; val = (val >> 1) | val; val = (val >> 2) | val; @@ -298,88 +316,67 @@ public final class FastByteArrayOutputStream extends OutputStream { return val; } - /** - * Converts the buffer's contents into a string decoding bytes using the - * platform's default character set. The length of the new String - * is a function of the character set, and hence may not be equal to the - * size of the buffer. - * - *
This method always replaces malformed-input and unmappable-character - * sequences with the default replacement string for the platform's - * default character set. The {@linkplain java.nio.charset.CharsetDecoder} - * class should be used when more control over the decoding process is - * required.
- * - * @return String decoded from the buffer's contents. - */ - @Override - public String toString() { - return new String(toByteArrayUnsafe()); - } - /** - * An implementation of {@link java.io.InputStream} that reads fromFastByteArrayOutputStream
- * Instances of this class are NOT THREAD SAFE.
+ * An implementation of {@link java.io.InputStream} that reads from a given
+ * FastByteArrayOutputStream
.
*/
- private static final class FastByteArrayOutputStreamInputStream extends UpdateMessageDigestInputStream {
- int totalBytesRead = 0;
+ private static final class FastByteArrayInputStream extends UpdateMessageDigestInputStream {
+
+ private final FastByteArrayOutputStream fastByteArrayOutputStream;
- int nextIndexInCurrentBuffer = 0;
+ private final IteratorFastByteArrayOutputStreamInputStream
backed
- * by the given FastByteArrayOutputStream
+ * by the given FastByteArrayOutputStream
.
*/
- public FastByteArrayOutputStreamInputStream(FastByteArrayOutputStream fastByteArrayOutputStream) {
+ public FastByteArrayInputStream(FastByteArrayOutputStream fastByteArrayOutputStream) {
this.fastByteArrayOutputStream = fastByteArrayOutputStream;
- buffersIterator = fastByteArrayOutputStream.buffers.iterator();
- if (buffersIterator.hasNext()) {
- currentBuffer = buffersIterator.next();
- if (currentBuffer == fastByteArrayOutputStream.buffers.getLast()) {
- currentBufferLength = fastByteArrayOutputStream.index;
+ this.buffersIterator = fastByteArrayOutputStream.buffers.iterator();
+ if (this.buffersIterator.hasNext()) {
+ this.currentBuffer = this.buffersIterator.next();
+ if (this.currentBuffer == fastByteArrayOutputStream.buffers.getLast()) {
+ this.currentBufferLength = fastByteArrayOutputStream.index;
}
else {
- currentBufferLength = currentBuffer.length;
+ this.currentBufferLength = this.currentBuffer.length;
}
}
- else {
- currentBuffer = null;
- }
}
@Override
public int read() {
- if (currentBuffer == null) {
+ if (this.currentBuffer == null) {
// this stream doesn't have any data in it
return -1;
}
else {
- if (nextIndexInCurrentBuffer < currentBufferLength) {
- totalBytesRead++;
- return currentBuffer[nextIndexInCurrentBuffer++];
+ if (this.nextIndexInCurrentBuffer < this.currentBufferLength) {
+ this.totalBytesRead++;
+ return this.currentBuffer[this.nextIndexInCurrentBuffer++];
}
else {
- if (buffersIterator.hasNext()) {
- currentBuffer = buffersIterator.next();
- if (currentBuffer == fastByteArrayOutputStream.buffers.getLast()) {
- currentBufferLength = fastByteArrayOutputStream.index;
+ if (this.buffersIterator.hasNext()) {
+ this.currentBuffer = this.buffersIterator.next();
+ if (this.currentBuffer == this.fastByteArrayOutputStream.buffers.getLast()) {
+ this.currentBufferLength = this.fastByteArrayOutputStream.index;
}
else {
- currentBufferLength = currentBuffer.length;
+ this.currentBufferLength = this.currentBuffer.length;
}
- nextIndexInCurrentBuffer = 0;
+ this.nextIndexInCurrentBuffer = 0;
}
else {
- currentBuffer = null;
+ this.currentBuffer = null;
}
return read();
}
@@ -409,31 +406,31 @@ public final class FastByteArrayOutputStream extends OutputStream {
throw new IllegalArgumentException("off must be 0 or greater: " + off);
}
else {
- if (currentBuffer == null) {
+ if (this.currentBuffer == null) {
// this stream doesn't have any data in it
return 0;
}
else {
- if (nextIndexInCurrentBuffer < currentBufferLength) {
- int bytesToCopy = Math.min(len, currentBufferLength - nextIndexInCurrentBuffer);
- System.arraycopy(currentBuffer, nextIndexInCurrentBuffer, b, off, bytesToCopy);
- totalBytesRead += bytesToCopy;
- nextIndexInCurrentBuffer += bytesToCopy;
- return bytesToCopy + read(b, off + bytesToCopy, len - bytesToCopy);
+ if (this.nextIndexInCurrentBuffer < this.currentBufferLength) {
+ int bytesToCopy = Math.min(len, this.currentBufferLength - this.nextIndexInCurrentBuffer);
+ System.arraycopy(this.currentBuffer, this.nextIndexInCurrentBuffer, b, off, bytesToCopy);
+ this.totalBytesRead += bytesToCopy;
+ this.nextIndexInCurrentBuffer += bytesToCopy;
+ return (bytesToCopy + read(b, off + bytesToCopy, len - bytesToCopy));
}
else {
- if (buffersIterator.hasNext()) {
- currentBuffer = buffersIterator.next();
- if (currentBuffer == fastByteArrayOutputStream.buffers.getLast()) {
- currentBufferLength = fastByteArrayOutputStream.index;
+ if (this.buffersIterator.hasNext()) {
+ this.currentBuffer = this.buffersIterator.next();
+ if (this.currentBuffer == this.fastByteArrayOutputStream.buffers.getLast()) {
+ this.currentBufferLength = this.fastByteArrayOutputStream.index;
}
else {
- currentBufferLength = currentBuffer.length;
+ this.currentBufferLength = this.currentBuffer.length;
}
- nextIndexInCurrentBuffer = 0;
+ this.nextIndexInCurrentBuffer = 0;
}
else {
- currentBuffer = null;
+ this.currentBuffer = null;
}
return read(b, off, len);
}
@@ -444,8 +441,7 @@ public final class FastByteArrayOutputStream extends OutputStream {
@Override
public long skip(long n) throws IOException {
if (n > Integer.MAX_VALUE) {
- throw new IllegalArgumentException("n exceeds maximum (" +
- Integer.MAX_VALUE + "): " + n);
+ throw new IllegalArgumentException("n exceeds maximum (" + Integer.MAX_VALUE + "): " + n);
}
else if (n == 0) {
return 0;
@@ -454,30 +450,30 @@ public final class FastByteArrayOutputStream extends OutputStream {
throw new IllegalArgumentException("n must be 0 or greater: " + n);
}
int len = (int) n;
- if (currentBuffer == null) {
+ if (this.currentBuffer == null) {
// this stream doesn't have any data in it
return 0;
}
else {
- if (nextIndexInCurrentBuffer < currentBufferLength) {
- int bytesToSkip = Math.min(len, currentBufferLength - nextIndexInCurrentBuffer);
- totalBytesRead += bytesToSkip;
- nextIndexInCurrentBuffer += bytesToSkip;
- return bytesToSkip + skip(len - bytesToSkip);
+ if (this.nextIndexInCurrentBuffer < this.currentBufferLength) {
+ int bytesToSkip = Math.min(len, this.currentBufferLength - this.nextIndexInCurrentBuffer);
+ this.totalBytesRead += bytesToSkip;
+ this.nextIndexInCurrentBuffer += bytesToSkip;
+ return (bytesToSkip + skip(len - bytesToSkip));
}
else {
- if (buffersIterator.hasNext()) {
- currentBuffer = buffersIterator.next();
- if (currentBuffer == fastByteArrayOutputStream.buffers.getLast()) {
- currentBufferLength = fastByteArrayOutputStream.index;
+ if (this.buffersIterator.hasNext()) {
+ this.currentBuffer = this.buffersIterator.next();
+ if (this.currentBuffer == this.fastByteArrayOutputStream.buffers.getLast()) {
+ this.currentBufferLength = this.fastByteArrayOutputStream.index;
}
else {
- currentBufferLength = currentBuffer.length;
+ this.currentBufferLength = this.currentBuffer.length;
}
- nextIndexInCurrentBuffer = 0;
+ this.nextIndexInCurrentBuffer = 0;
}
else {
- currentBuffer = null;
+ this.currentBuffer = null;
}
return skip(len);
}
@@ -486,12 +482,11 @@ public final class FastByteArrayOutputStream extends OutputStream {
@Override
public int available() {
- return fastByteArrayOutputStream.size() - totalBytesRead;
+ return (this.fastByteArrayOutputStream.size() - this.totalBytesRead);
}
/**
* Update the message digest with the remaining bytes in this stream.
- *
* @param messageDigest The message digest to update
*/
public void updateMessageDigest(MessageDigest messageDigest) {
@@ -505,7 +500,7 @@ public final class FastByteArrayOutputStream extends OutputStream {
* @param len how many bytes to read from this stream and use to update the message digest
*/
public void updateMessageDigest(MessageDigest messageDigest, int len) {
- if (currentBuffer == null) {
+ if (this.currentBuffer == null) {
// this stream doesn't have any data in it
return;
}
@@ -516,29 +511,30 @@ public final class FastByteArrayOutputStream extends OutputStream {
throw new IllegalArgumentException("len must be 0 or greater: " + len);
}
else {
- if (nextIndexInCurrentBuffer < currentBufferLength) {
- int bytesToCopy = Math.min(len, currentBufferLength - nextIndexInCurrentBuffer);
- messageDigest.update(currentBuffer, nextIndexInCurrentBuffer, bytesToCopy);
- nextIndexInCurrentBuffer += bytesToCopy;
+ if (this.nextIndexInCurrentBuffer < this.currentBufferLength) {
+ int bytesToCopy = Math.min(len, this.currentBufferLength - this.nextIndexInCurrentBuffer);
+ messageDigest.update(this.currentBuffer, this.nextIndexInCurrentBuffer, bytesToCopy);
+ this.nextIndexInCurrentBuffer += bytesToCopy;
updateMessageDigest(messageDigest, len - bytesToCopy);
}
else {
- if (buffersIterator.hasNext()) {
- currentBuffer = buffersIterator.next();
- if (currentBuffer == fastByteArrayOutputStream.buffers.getLast()) {
- currentBufferLength = fastByteArrayOutputStream.index;
+ if (this.buffersIterator.hasNext()) {
+ this.currentBuffer = this.buffersIterator.next();
+ if (this.currentBuffer == this.fastByteArrayOutputStream.buffers.getLast()) {
+ this.currentBufferLength = this.fastByteArrayOutputStream.index;
}
else {
- currentBufferLength = currentBuffer.length;
+ this.currentBufferLength = this.currentBuffer.length;
}
- nextIndexInCurrentBuffer = 0;
+ this.nextIndexInCurrentBuffer = 0;
}
else {
- currentBuffer = null;
+ this.currentBuffer = null;
}
updateMessageDigest(messageDigest, len);
}
}
}
}
+
}
diff --git a/spring-core/src/main/java/org/springframework/util/ResizableByteArrayOutputStream.java b/spring-core/src/main/java/org/springframework/util/ResizableByteArrayOutputStream.java
index 78f29574fd..b42aa17c55 100644
--- a/spring-core/src/main/java/org/springframework/util/ResizableByteArrayOutputStream.java
+++ b/spring-core/src/main/java/org/springframework/util/ResizableByteArrayOutputStream.java
@@ -1,5 +1,5 @@
/*
- * Copyright 2002-2014 the original author or authors.
+ * Copyright 2002-2015 the original author or authors.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
@@ -27,6 +27,11 @@ import java.io.ByteArrayOutputStream;
* As of 4.2, this class has been superseded by {@link FastByteArrayOutputStream}
+ * for Spring's internal use where no assignability to {@link ByteArrayOutputStream}
+ * is needed (since {@link FastByteArrayOutputStream} is more efficient with buffer
+ * resize management but doesn't extend the standard {@link ByteArrayOutputStream}).
+ *
* @author Brian Clozel
* @author Juergen Hoeller
* @since 4.0.3
@@ -38,7 +43,7 @@ public class ResizableByteArrayOutputStream extends ByteArrayOutputStream {
/**
* Create a new ResizableByteArrayOutputStream
- * with the default initial capacity of 128 bytes.
+ * with the default initial capacity of 256 bytes.
*/
public ResizableByteArrayOutputStream() {
super(DEFAULT_INITIAL_CAPACITY);
diff --git a/spring-core/src/main/java/org/springframework/util/UpdateMessageDigestInputStream.java b/spring-core/src/main/java/org/springframework/util/UpdateMessageDigestInputStream.java
index 8ae173627e..3dc081e74e 100644
--- a/spring-core/src/main/java/org/springframework/util/UpdateMessageDigestInputStream.java
+++ b/spring-core/src/main/java/org/springframework/util/UpdateMessageDigestInputStream.java
@@ -27,38 +27,37 @@ import java.security.MessageDigest;
* @author Craig Andrews
* @since 4.2
*/
-public abstract class UpdateMessageDigestInputStream extends InputStream {
+abstract class UpdateMessageDigestInputStream extends InputStream {
/**
- * Update the message digest with the rest of the bytes in this stream
- *
- *
Using this method is more optimized since it avoids creating new byte arrays for each call.
- * + * Update the message digest with the rest of the bytes in this stream. + *Using this method is more optimized since it avoids creating new + * byte arrays for each call. * @param messageDigest The message digest to update - * @throws IOException + * @throws IOException when propagated from {@link #read()} */ - public void updateMessageDigest(MessageDigest messageDigest) throws IOException{ + public void updateMessageDigest(MessageDigest messageDigest) throws IOException { int data; - while((data = read()) != -1){ - messageDigest.update((byte)data); + while ((data = read()) != -1){ + messageDigest.update((byte) data); } } /** - * Update the message digest with the next len bytes in this stream - * - *
Using this method is more optimized since it avoids creating new byte arrays for each call.
- * + * Update the message digest with the next len bytes in this stream. + *Using this method is more optimized since it avoids creating new + * byte arrays for each call. * @param messageDigest The message digest to update * @param len how many bytes to read from this stream and use to update the message digest - * @throws IOException + * @throws IOException when propagated from {@link #read()} */ - public void updateMessageDigest(MessageDigest messageDigest, int len) throws IOException{ + public void updateMessageDigest(MessageDigest messageDigest, int len) throws IOException { int data; int bytesRead = 0; - while(bytesRead < len && (data = read()) != -1){ - messageDigest.update((byte)data); + while (bytesRead < len && (data = read()) != -1){ + messageDigest.update((byte) data); bytesRead++; } } + } diff --git a/spring-jdbc/src/main/java/org/springframework/jdbc/datasource/init/ScriptStatementFailedException.java b/spring-jdbc/src/main/java/org/springframework/jdbc/datasource/init/ScriptStatementFailedException.java index 224973bf80..44c975c10c 100644 --- a/spring-jdbc/src/main/java/org/springframework/jdbc/datasource/init/ScriptStatementFailedException.java +++ b/spring-jdbc/src/main/java/org/springframework/jdbc/datasource/init/ScriptStatementFailedException.java @@ -31,30 +31,30 @@ public class ScriptStatementFailedException extends ScriptException { /** * Construct a new {@code ScriptStatementFailedException}. - * @param statement the actual SQL statement that failed - * @param statementNumber the statement number in the SQL script (i.e., + * @param stmt the actual SQL statement that failed + * @param stmtNumber the statement number in the SQL script (i.e., * the nth statement present in the resource) * @param resource the resource from which the SQL statement was read * @param cause the underlying cause of the failure */ - public ScriptStatementFailedException(String statement, int statementNumber, EncodedResource resource, Throwable cause) { - super(buildErrorMessage(statement, statementNumber, resource), cause); + public ScriptStatementFailedException(String stmt, int stmtNumber, EncodedResource resource, Throwable cause) { + super(buildErrorMessage(stmt, stmtNumber, resource), cause); } /** - * Build an error message for an SQL script execution failure, based on - * the supplied arguments. - * @param statement the actual SQL statement that failed - * @param statementNumber the statement number in the SQL script (i.e., + * Build an error message for an SQL script execution failure, + * based on the supplied arguments. + * @param stmt the actual SQL statement that failed + * @param stmtNumber the statement number in the SQL script (i.e., * the nth statement present in the resource) * @param encodedResource the resource from which the SQL statement was read * @return an error message suitable for an exception's detail message * or logging * @since 4.2 */ - public static String buildErrorMessage(String statement, int statementNumber, EncodedResource encodedResource) { + public static String buildErrorMessage(String stmt, int stmtNumber, EncodedResource encodedResource) { return String.format("Failed to execute SQL script statement #%s of %s: %s", - statementNumber, encodedResource, statement); + stmtNumber, encodedResource, stmt); } } diff --git a/spring-webmvc/src/main/java/org/springframework/web/servlet/tags/HtmlEscapingAwareTag.java b/spring-webmvc/src/main/java/org/springframework/web/servlet/tags/HtmlEscapingAwareTag.java index 1a55230bb6..18d1014a87 100644 --- a/spring-webmvc/src/main/java/org/springframework/web/servlet/tags/HtmlEscapingAwareTag.java +++ b/spring-webmvc/src/main/java/org/springframework/web/servlet/tags/HtmlEscapingAwareTag.java @@ -1,5 +1,5 @@ /* - * Copyright 2002-2014 the original author or authors. + * Copyright 2002-2015 the original author or authors. * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. @@ -29,6 +29,7 @@ import org.springframework.web.util.HtmlUtils; * context-param in {@code web.xml}) is used. * * @author Juergen Hoeller + * @author Brian Clozel * @since 1.1 * @see #setHtmlEscape * @see HtmlEscapeTag @@ -76,24 +77,26 @@ public abstract class HtmlEscapingAwareTag extends RequestContextAwareTag { } /** - * Return the applicable default for the use of response encoding with HTML escape for this tag. + * Return the applicable default for the use of response encoding with + * HTML escaping for this tag. *
The default implementation checks the RequestContext's setting, * falling back to {@code false} in case of no explicit default given. - * @see #getRequestContext() * @since 4.1.2 + * @see #getRequestContext() */ protected boolean isResponseEncodedHtmlEscape() { return getRequestContext().isResponseEncodedHtmlEscape(); } /** - * HTML encodes the given string, only if the htmlEscape setting is enabled. - * The response encoding will be taken into account if the responseEncodedHtmlEscape setting is enabled. - * @param content - * @return + * HTML-encodes the given String, only if the "htmlEscape" setting is enabled. + *
The response encoding will be taken into account if the + * "responseEncodedHtmlEscape" setting is enabled as well. + * @param content the String to escape + * @return the escaped String + * @since 4.1.2 * @see #isHtmlEscape() * @see #isResponseEncodedHtmlEscape() - * @since 4.1.2 */ protected String htmlEscape(String content) { String out = content;