diff options
author | Mark Wielaard <mark@gcc.gnu.org> | 2006-05-18 17:29:21 +0000 |
---|---|---|
committer | Mark Wielaard <mark@gcc.gnu.org> | 2006-05-18 17:29:21 +0000 |
commit | 4f9533c7722fa07511a94d005227961f4a4dec23 (patch) | |
tree | 9f9c470de62ee62fba1331a396450d728d2b1fad /libjava/classpath/gnu/java/net/protocol | |
parent | eaec4980e139903ae9b274d1abcf3a13946603a8 (diff) | |
download | gcc-4f9533c7722fa07511a94d005227961f4a4dec23.zip gcc-4f9533c7722fa07511a94d005227961f4a4dec23.tar.gz gcc-4f9533c7722fa07511a94d005227961f4a4dec23.tar.bz2 |
Imported GNU Classpath 0.90
Imported GNU Classpath 0.90
* scripts/makemake.tcl: LocaleData.java moved to gnu/java/locale.
* sources.am: Regenerated.
* gcj/javaprims.h: Regenerated.
* Makefile.in: Regenerated.
* gcj/Makefile.in: Regenerated.
* include/Makefile.in: Regenerated.
* testsuite/Makefile.in: Regenerated.
* gnu/java/lang/VMInstrumentationImpl.java: New override.
* gnu/java/net/local/LocalSocketImpl.java: Likewise.
* gnu/classpath/jdwp/VMMethod.java: Likewise.
* gnu/classpath/jdwp/VMVirtualMachine.java: Update to latest
interface.
* java/lang/Thread.java: Add UncaughtExceptionHandler.
* java/lang/reflect/Method.java: Implements GenericDeclaration and
isSynthetic(),
* java/lang/reflect/Field.java: Likewise.
* java/lang/reflect/Constructor.java
* java/lang/Class.java: Implements Type, GenericDeclaration,
getSimpleName() and getEnclosing*() methods.
* java/lang/Class.h: Add new public methods.
* java/lang/Math.java: Add signum(), ulp() and log10().
* java/lang/natMath.cc (log10): New function.
* java/security/VMSecureRandom.java: New override.
* java/util/logging/Logger.java: Updated to latest classpath
version.
* java/util/logging/LogManager.java: New override.
From-SVN: r113887
Diffstat (limited to 'libjava/classpath/gnu/java/net/protocol')
4 files changed, 80 insertions, 42 deletions
diff --git a/libjava/classpath/gnu/java/net/protocol/file/Connection.java b/libjava/classpath/gnu/java/net/protocol/file/Connection.java index f7253b0..04278d4 100644 --- a/libjava/classpath/gnu/java/net/protocol/file/Connection.java +++ b/libjava/classpath/gnu/java/net/protocol/file/Connection.java @@ -160,7 +160,9 @@ public class Connection extends URLConnection else if (c > 127) { try { byte [] c_as_bytes = Character.toString(c).getBytes("utf-8"); - System.arraycopy(c_as_bytes, 0, buf, pos, c_as_bytes.length); + final int c_length = c_as_bytes.length; + System.arraycopy(c_as_bytes, 0, buf, pos, c_length); + pos += c_length; } catch (java.io.UnsupportedEncodingException x2) { throw (Error) new InternalError().initCause(x2); diff --git a/libjava/classpath/gnu/java/net/protocol/ftp/FTPConnection.java b/libjava/classpath/gnu/java/net/protocol/ftp/FTPConnection.java index d0f4872..f5317d4 100644 --- a/libjava/classpath/gnu/java/net/protocol/ftp/FTPConnection.java +++ b/libjava/classpath/gnu/java/net/protocol/ftp/FTPConnection.java @@ -429,6 +429,9 @@ public class FTPConnection public boolean changeWorkingDirectory(String path) throws IOException { + // Do nothing if the path is empty. + if (path.length() == 0) + return true; String cmd = CWD + ' ' + path; send(cmd); FTPResponse response = getResponse(); diff --git a/libjava/classpath/gnu/java/net/protocol/http/HTTPURLConnection.java b/libjava/classpath/gnu/java/net/protocol/http/HTTPURLConnection.java index 5c2af9e..0dce7c7 100644 --- a/libjava/classpath/gnu/java/net/protocol/http/HTTPURLConnection.java +++ b/libjava/classpath/gnu/java/net/protocol/http/HTTPURLConnection.java @@ -48,12 +48,8 @@ import java.io.OutputStream; import java.net.ProtocolException; import java.net.URL; import java.security.cert.Certificate; -import java.util.ArrayList; import java.util.Collections; import java.util.Date; -import java.util.HashMap; -import java.util.Iterator; -import java.util.LinkedHashMap; import java.util.Map; import javax.net.ssl.HandshakeCompletedEvent; @@ -271,6 +267,8 @@ public class HTTPURLConnection secure = false; start = 7; int end = location.indexOf('/', start); + if (end == -1) + end = location.length(); host = location.substring(start, end); int ci = host.lastIndexOf(':'); if (ci != -1) @@ -292,6 +290,8 @@ public class HTTPURLConnection secure = true; start = 8; int end = location.indexOf('/', start); + if (end == -1) + end = location.length(); host = location.substring(start, end); int ci = host.lastIndexOf(':'); if (ci != -1) @@ -410,10 +410,7 @@ public class HTTPURLConnection } public String getRequestProperty(String key) - { - if (key == null) - return null; - + { return requestHeaders.getValue(key); } diff --git a/libjava/classpath/gnu/java/net/protocol/http/Headers.java b/libjava/classpath/gnu/java/net/protocol/http/Headers.java index b42faaa..a793bbd 100644 --- a/libjava/classpath/gnu/java/net/protocol/http/Headers.java +++ b/libjava/classpath/gnu/java/net/protocol/http/Headers.java @@ -50,7 +50,6 @@ import java.util.Date; import java.util.Iterator; import java.util.LinkedHashMap; import java.util.Map; -import java.util.Set; /** * A collection of HTTP header names and associated values. The @@ -65,12 +64,18 @@ class Headers { /** * A list of HeaderElements - * */ private final ArrayList headers = new ArrayList(); - static final DateFormat dateFormat = new HTTPDateFormat(); + /** + * The HTTP dateformat used to parse date header fields. + */ + private static final DateFormat dateFormat = new HTTPDateFormat(); + /** + * Class for a Header element consisting of + * a name and value String. + */ static class HeaderElement { String name; @@ -83,8 +88,12 @@ class Headers } } + /** + * Default constructor. + */ public Headers() { + // nothing to do } /** @@ -99,8 +108,11 @@ class Headers } /** - * Returns the value of the specified header as a string. If + * Returns the value of the specified header as a string. If * multiple values are present, the last one is returned. + * + * @param header the header name (case insensitive search) + * @return The header value or <code>null</code> if not found. */ public String getValue(String header) { @@ -116,8 +128,12 @@ class Headers } /** - * Returns the value of the specified header as an integer, - * or -1 if the header is not present or not an integer. + * Returns the value of the specified header as an integer. If + * multiple values are present, the last one is returned. + * + * @param header the header name (case insensitive search) + * @return The header value or <code>-1</code> if not present or + * not an integer value. */ public int getIntValue(String header) { @@ -132,13 +148,18 @@ class Headers } catch (NumberFormatException e) { + // fall through } return -1; } /** - * Returns the value of the specified header as a long, or -1 if the - * header is not present or cannot be parsed as a long. + * Returns the value of the specified header as a long. If + * multiple values are present, the last one is returned. + * + * @param header the header name (case insensitive search) + * @return The header value or <code>-1</code> if not present or + * not a long value. */ public long getLongValue(String header) { @@ -153,13 +174,18 @@ class Headers } catch (NumberFormatException e) { + // fall through } return -1; } /** - * Returns the value of the specified header as a date, - * or <code>null</code> if the header is not present or not a date. + * Returns the value of the specified header as a date. If + * multiple values are present, the last one is returned. + * + * @param header the header name (case insensitive search) + * @return The header value or <code>null</code> if not present or + * not a date value. */ public Date getDateValue(String header) { @@ -180,23 +206,35 @@ class Headers /** * Add a header to this set of headers. If there is an existing - * header with the same name, it is discarded. + * header with the same name it's value is replaced with the new value. + * If multiple headers of the same name exist only the last one's value + * is replaced. * * @param name the header name * @param value the header value * - * @see #addValue + * @see #addValue(String, String) */ public void put(String name, String value) - { - remove(name); - headers.add(headers.size(), new HeaderElement(name, value)); + { + for (int i = headers.size() - 1; i >= 0; i--) + { + HeaderElement e = (HeaderElement)headers.get(i); + if (e.name.equalsIgnoreCase(name)) + { + e.value = value; + return; + } + } + + // nothing was replaced so add it as new HeaderElement + addValue(name, value); } - + /** - * Add all headers from a set of headers to this set. If any of the - * headers to be added have the same name as existing headers, the - * existing headers will be discarded. + * Add all headers from a set of headers to this set. Any existing header + * with the same (case insensitive) name as one of the new headers will + * be overridden. * * @param o the headers to be added */ @@ -206,10 +244,6 @@ class Headers { HeaderElement e = (HeaderElement)it.next(); remove(e.name); - } - for (Iterator it = o.iterator(); it.hasNext(); ) - { - HeaderElement e = (HeaderElement)it.next(); addValue(e.name, e.value); } } @@ -234,6 +268,7 @@ class Headers * Parse the specified InputStream, adding headers to this collection. * * @param in the InputStream. + * @throws IOException if I/O error occured. */ public void parse(InputStream in) throws IOException @@ -303,7 +338,7 @@ class Headers * @param name the header name * @param value the header value * - * @see #put + * @see #put(String, String) */ public void addValue(String name, String value) { @@ -312,13 +347,14 @@ class Headers /** * Get a new Map containing all the headers. The keys of the Map - * are Strings (the header names). The values of the Map are + * are Strings (the header names). The headers will be included + * case-sensitive in the map so that querying must be done with the + * correct case of the needed header name. The values of the Map are * unmodifiable Lists containing Strings (the header values). * - * <p> - * - * The returned map is modifiable. Changing it will not effect this - * collection of Headers in any way. + * <p> + * The returned map is modifiable. Changing it will not effect this + * collection of Headers in any way.</p> * * @return a Map containing all the headers. */ @@ -352,9 +388,9 @@ class Headers * * @param i the header index. * - * @return the header name. + * @return The header name, or <code>null</code> if index outside of range. * - * @see #getHeaderValue + * @see #getHeaderValue(int) */ public String getHeaderName(int i) { @@ -369,9 +405,9 @@ class Headers * * @param i the header index. * - * @return the header value. + * @return the header value, or <code>null</code> if index outside of range. * - * @see #getHeaderName + * @see #getHeaderName(int) */ public String getHeaderValue(int i) { |