From 2a81deb9769ceea4775c22641c27bc9bc5399c18 Mon Sep 17 00:00:00 2001 From: mkoch <mkoch@138bc75d-0d04-0410-961f-82ee72b054a4> Date: Fri, 23 Apr 2004 07:21:46 +0000 Subject: [PATCH] 2004-04-23 Michael Koch <konqueror@gmx.de> * java/net/URL.java (hashcode): Don't initialize with default value explicitely. (getContent): Removed redundant "final" keyword. (openStream): Likewise. (getURLStreamHandler): Fixed coding style. * java/net/URLConnection.java (defaultAllowUserInteraction): Don't initialize with default value explicitely. (connected): Likewise. (doOutput): Likewise. (ifModifiedSince): Likewise. (dateformats_initialized): Likewise. (setURLStreamHander): Use StreamTokenizer where it belongs to. git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@81080 138bc75d-0d04-0410-961f-82ee72b054a4 --- libjava/ChangeLog | 16 +++++++++++ libjava/java/net/URL.java | 43 +++++++++++++++++++---------- libjava/java/net/URLConnection.java | 8 +++--- 3 files changed, 48 insertions(+), 19 deletions(-) diff --git a/libjava/ChangeLog b/libjava/ChangeLog index 6222b5726faf..59f1fcea0acf 100644 --- a/libjava/ChangeLog +++ b/libjava/ChangeLog @@ -1,3 +1,19 @@ +2004-04-23 Michael Koch <konqueror@gmx.de> + + * java/net/URL.java + (hashcode): Don't initialize with default value explicitely. + (getContent): Removed redundant "final" keyword. + (openStream): Likewise. + (getURLStreamHandler): Fixed coding style. + * java/net/URLConnection.java + (defaultAllowUserInteraction): Don't initialize with default value + explicitely. + (connected): Likewise. + (doOutput): Likewise. + (ifModifiedSince): Likewise. + (dateformats_initialized): Likewise. + (setURLStreamHander): Use StreamTokenizer where it belongs to. + 2004-04-23 Michael Koch <konqueror@gmx.de> * gnu/java/nio/channels/FileChannelImpl.java diff --git a/libjava/java/net/URL.java b/libjava/java/net/URL.java index d9bf0ab054ce..729d96fa8781 100644 --- a/libjava/java/net/URL.java +++ b/libjava/java/net/URL.java @@ -140,6 +140,11 @@ public final class URL implements Serializable */ private String host; + /** + * The user information necessary to establish the connection. + */ + private String userInfo; + /** * The port number of this protocol or -1 if the port number used is * the default for this protocol. @@ -159,7 +164,7 @@ public final class URL implements Serializable /** * This is the hashCode for this URL */ - private int hashCode = 0; + private int hashCode; /** * The protocol handler in use for this URL @@ -276,7 +281,9 @@ public final class URL implements Serializable this.host = host; this.port = port; - this.authority = null; + this.authority = (host != null) ? host : ""; + if (port >= 0) + this.authority += ":" + port; int hashAt = file.indexOf('#'); if (hashAt < 0) @@ -480,7 +487,7 @@ public final class URL implements Serializable * * @since 1.3 */ - public final Object getContent() throws IOException + public Object getContent() throws IOException { return openConnection().getContent(); } @@ -494,7 +501,7 @@ public final class URL implements Serializable * * @exception IOException If an error occurs */ - public final Object getContent (Class[] classes) throws IOException + public Object getContent(Class[] classes) throws IOException { // FIXME: implement this return getContent(); @@ -653,7 +660,7 @@ public final class URL implements Serializable * * @exception IOException If an error occurs */ - public final InputStream openStream() throws IOException + public InputStream openStream() throws IOException { return openConnection().getInputStream(); } @@ -694,11 +701,17 @@ public final class URL implements Serializable // be aware of this. this.ph = getURLStreamHandler(protocol); this.protocol = protocol.toLowerCase(); - this.authority = null; + this.authority = ""; this.port = port; this.host = host; this.file = file; this.ref = ref; + + if (host != null) + this.authority += host; + if (port >= 0) + this.authority += ":" + port; + hashCode = hashCode(); // Used for serialization. } @@ -727,15 +740,15 @@ public final class URL implements Serializable // be aware of this. this.ph = getURLStreamHandler(protocol); this.protocol = protocol.toLowerCase(); - if (userInfo == null) - this.host = host; - else - this.host = userInfo + "@" + host; + this.host = host; + this.userInfo = userInfo; this.port = port; + this.file = path; + this.authority = authority; if (query == null) - this.file = path; + this.file = file; else - this.file = path + "?" + query; + this.file = file + "?" + query; this.ref = ref; hashCode = hashCode(); // Used for serialization. } @@ -811,13 +824,13 @@ public final class URL implements Serializable // If a non-default factory has been set, use it to find the protocol. if (factory != null) { - ph = factory.createURLStreamHandler (protocol); + ph = factory.createURLStreamHandler(protocol); } - else if (protocol.equals ("core")) + else if (protocol.equals("core")) { ph = new gnu.java.net.protocol.core.Handler(); } - else if (protocol.equals ("file")) + else if (protocol.equals("file")) { // This is an interesting case. It's tempting to think that we // could call Class.forName ("gnu.java.net.protocol.file.Handler") to diff --git a/libjava/java/net/URLConnection.java b/libjava/java/net/URLConnection.java index 39fbd32ec281..867a53450c8c 100644 --- a/libjava/java/net/URLConnection.java +++ b/libjava/java/net/URLConnection.java @@ -432,10 +432,10 @@ public abstract class URLConnection String type = getContentType(); ContentHandler ch = setContentHandler(type); - if (ch != null) - return ch.getContent(this); + if (ch == null) + return getInputStream(); - return getInputStream(); + return ch.getContent(this); } /** @@ -993,7 +993,6 @@ public abstract class URLConnection // Replace the '/' character in the content type with '.' and // all other non-alphabetic, non-numeric characters with '_'. - StringTokenizer pkgPrefix = new StringTokenizer(propVal, "|"); char[] cArray = contentType.toCharArray(); for (int i = 0; i < cArray.length; i++) { @@ -1007,6 +1006,7 @@ public abstract class URLConnection String contentClass = new String(cArray); // See if a class of this content type exists in any of the packages. + StringTokenizer pkgPrefix = new StringTokenizer(propVal, "|"); do { String facName = pkgPrefix.nextToken() + "." + contentClass; -- GitLab