aboutsummaryrefslogtreecommitdiff
path: root/libjava/java/net
diff options
context:
space:
mode:
Diffstat (limited to 'libjava/java/net')
-rw-r--r--libjava/java/net/Inet4Address.java2
-rw-r--r--libjava/java/net/Inet6Address.java12
-rw-r--r--libjava/java/net/InetAddress.java2
3 files changed, 9 insertions, 7 deletions
diff --git a/libjava/java/net/Inet4Address.java b/libjava/java/net/Inet4Address.java
index 917e9e3..b654ce6 100644
--- a/libjava/java/net/Inet4Address.java
+++ b/libjava/java/net/Inet4Address.java
@@ -207,7 +207,7 @@ public final class Inet4Address extends InetAddress
*/
public byte[] getAddress()
{
- return addr;
+ return (byte[]) addr.clone();
}
/**
diff --git a/libjava/java/net/Inet6Address.java b/libjava/java/net/Inet6Address.java
index 0c1d60e..69d266a 100644
--- a/libjava/java/net/Inet6Address.java
+++ b/libjava/java/net/Inet6Address.java
@@ -65,7 +65,8 @@ public final class Inet6Address extends InetAddress
Inet6Address(byte[] addr, String host)
{
super(addr, host);
- this.ipaddress = addr;
+ // Super constructor clones the addr. Get a reference to the clone.
+ this.ipaddress = this.addr;
}
/**
@@ -194,7 +195,7 @@ public final class Inet6Address extends InetAddress
*/
public byte[] getAddress()
{
- return ipaddress;
+ return (byte[]) ipaddress.clone();
}
/**
@@ -233,9 +234,10 @@ public final class Inet6Address extends InetAddress
if (! (obj instanceof Inet6Address))
return false;
- Inet6Address tmp = (Inet6Address) obj;
-
- return super.equals(tmp) && this.ipaddress == tmp.ipaddress;
+ // this.ipaddress is never set in this class except to
+ // the value of the super class' addr. The super classes
+ // equals(Object) will do the compare.
+ return super.equals(obj);
}
/**
diff --git a/libjava/java/net/InetAddress.java b/libjava/java/net/InetAddress.java
index cfcf22b..5a3ec47 100644
--- a/libjava/java/net/InetAddress.java
+++ b/libjava/java/net/InetAddress.java
@@ -123,7 +123,7 @@ public class InetAddress implements Serializable
*/
InetAddress(byte[] ipaddr, String hostname)
{
- addr = ipaddr;
+ addr = (null == ipaddr) ? null : (byte[]) ipaddr.clone();
hostName = hostname;
if (ipaddr != null)