aboutsummaryrefslogtreecommitdiff
path: root/libjava/java/net
diff options
context:
space:
mode:
authorMichael Koch <konqueror@gmx.de>2005-04-29 22:10:09 +0000
committerMichael Koch <mkoch@gcc.gnu.org>2005-04-29 22:10:09 +0000
commitbf5d810ff1a0c1882f9690a342571dea1d6d5d8e (patch)
tree25f6089b6a536f14825da86a9d2efa0dec7c7b47 /libjava/java/net
parent2d82317df0ed13093bf5ffb60fd6ca356b3ca776 (diff)
downloadgcc-bf5d810ff1a0c1882f9690a342571dea1d6d5d8e.zip
gcc-bf5d810ff1a0c1882f9690a342571dea1d6d5d8e.tar.gz
gcc-bf5d810ff1a0c1882f9690a342571dea1d6d5d8e.tar.bz2
2005-04-29 Michael Koch <konqueror@gmx.de>
* java/net/NetworkInterface.java (static): Removed. (NetworkInterface(String,InetAddress)): Made package-private. (NetworkInterface(String,InetAddress[])): New constructor. (getRealNetworkInterfaces): Removed. (getByName): Use VMNetworkInterface.getInterfaces(). (getByInetAddress): Likewise. (getNetworkInterfaces): Likewise. * java/net/VMNetworkInterface.java, java/net/natVMNetworkInterfaceNoNet.cc, java/net/natVMNetworkInterfacePosix.c,c java/net/natVMNetworkInterfaceWin32.cc: New files. * java/net/natNetworkInterfaceNoNet.cc, java/net/natNetworkInterfacePosix.cc, java/net/natNetworkInterfaceWin32.cc: Removed. * configure.ac * Makefile.am * configure, Makefile.in: Regenerated. From-SVN: r99021
Diffstat (limited to 'libjava/java/net')
-rw-r--r--libjava/java/net/NetworkInterface.java26
-rw-r--r--libjava/java/net/VMNetworkInterface.java66
-rw-r--r--libjava/java/net/natVMNetworkInterfaceNoNet.cc (renamed from libjava/java/net/natNetworkInterfaceNoNet.cc)8
-rw-r--r--libjava/java/net/natVMNetworkInterfacePosix.cc (renamed from libjava/java/net/natNetworkInterfacePosix.cc)7
-rw-r--r--libjava/java/net/natVMNetworkInterfaceWin32.cc (renamed from libjava/java/net/natNetworkInterfaceWin32.cc)4
5 files changed, 88 insertions, 23 deletions
diff --git a/libjava/java/net/NetworkInterface.java b/libjava/java/net/NetworkInterface.java
index 2b4da73..cd59e4e 100644
--- a/libjava/java/net/NetworkInterface.java
+++ b/libjava/java/net/NetworkInterface.java
@@ -38,8 +38,6 @@ exception statement from your version. */
package java.net;
-import gnu.classpath.Configuration;
-
import java.util.Enumeration;
import java.util.Vector;
@@ -55,24 +53,24 @@ import java.util.Vector;
*/
public final class NetworkInterface
{
- static
- {
- if (Configuration.INIT_LOAD_LIBRARY)
- System.loadLibrary("javanet");
- }
-
private String name;
private Vector inetAddresses;
- private NetworkInterface(String name, InetAddress address)
+ NetworkInterface(String name, InetAddress address)
{
this.name = name;
this.inetAddresses = new Vector(1, 1);
this.inetAddresses.add(address);
}
- private static native Vector getRealNetworkInterfaces()
- throws SocketException;
+ NetworkInterface(String name, InetAddress[] addresses)
+ {
+ this.name = name;
+ this.inetAddresses = new Vector(addresses.length, 1);
+
+ for (int i = 0; i < addresses.length; i++)
+ this.inetAddresses.add(addresses[i]);
+ }
/**
* Returns the name of the network interface
@@ -145,7 +143,7 @@ public final class NetworkInterface
public static NetworkInterface getByName(String name)
throws SocketException
{
- Vector networkInterfaces = getRealNetworkInterfaces();
+ Vector networkInterfaces = VMNetworkInterface.getInterfaces();
for (Enumeration e = networkInterfaces.elements(); e.hasMoreElements();)
{
@@ -172,7 +170,7 @@ public final class NetworkInterface
public static NetworkInterface getByInetAddress(InetAddress addr)
throws SocketException
{
- Vector networkInterfaces = getRealNetworkInterfaces();
+ Vector networkInterfaces = VMNetworkInterface.getInterfaces();
for (Enumeration interfaces = networkInterfaces.elements();
interfaces.hasMoreElements();)
@@ -199,7 +197,7 @@ public final class NetworkInterface
*/
public static Enumeration getNetworkInterfaces() throws SocketException
{
- Vector networkInterfaces = getRealNetworkInterfaces();
+ Vector networkInterfaces = VMNetworkInterface.getInterfaces();
if (networkInterfaces.isEmpty())
return null;
diff --git a/libjava/java/net/VMNetworkInterface.java b/libjava/java/net/VMNetworkInterface.java
new file mode 100644
index 0000000..3aaca38
--- /dev/null
+++ b/libjava/java/net/VMNetworkInterface.java
@@ -0,0 +1,66 @@
+/* VMNetworkInterface.java --
+ Copyright (C) 2005 Free Software Foundation, Inc.
+
+This file is part of GNU Classpath.
+
+GNU Classpath is free software; you can redistribute it and/or modify
+it under the terms of the GNU General Public License as published by
+the Free Software Foundation; either version 2, or (at your option)
+any later version.
+
+GNU Classpath is distributed in the hope that it will be useful, but
+WITHOUT ANY WARRANTY; without even the implied warranty of
+MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+General Public License for more details.
+
+You should have received a copy of the GNU General Public License
+along with GNU Classpath; see the file COPYING. If not, write to the
+Free Software Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA
+02111-1307 USA.
+
+Linking this library statically or dynamically with other modules is
+making a combined work based on this library. Thus, the terms and
+conditions of the GNU General Public License cover the whole
+combination.
+
+As a special exception, the copyright holders of this library give you
+permission to link this library with independent modules to produce an
+executable, regardless of the license terms of these independent
+modules, and to copy and distribute the resulting executable under
+terms of your choice, provided that you also meet, for each linked
+independent module, the terms and conditions of the license of that
+module. An independent module is a module which is not derived from
+or based on this library. If you modify this library, you may extend
+this exception to your version of the library, but you are not
+obligated to do so. If you do not wish to do so, delete this
+exception statement from your version. */
+
+
+package java.net;
+
+import gnu.classpath.Configuration;
+
+import java.util.Enumeration;
+import java.util.Vector;
+
+/**
+ * This class models a network interface on the host computer. A network
+ * interface contains a name (typically associated with a specific
+ * hardware adapter) and a list of addresses that are bound to it.
+ * For example, an ethernet interface may be named "eth0" and have the
+ * address 192.168.1.101 assigned to it.
+ *
+ * @author Michael Koch (konqueror@gmx.de)
+ * @since 1.4
+ */
+final class VMNetworkInterface
+{
+ static
+ {
+ if (Configuration.INIT_LOAD_LIBRARY)
+ System.loadLibrary("javanet");
+ }
+
+ public static native Vector getInterfaces()
+ throws SocketException;
+}
diff --git a/libjava/java/net/natNetworkInterfaceNoNet.cc b/libjava/java/net/natVMNetworkInterfaceNoNet.cc
index 5f3c508..eda7f99 100644
--- a/libjava/java/net/natNetworkInterfaceNoNet.cc
+++ b/libjava/java/net/natVMNetworkInterfaceNoNet.cc
@@ -1,4 +1,4 @@
-/* Copyright (C) 2003 Free Software Foundation
+/* Copyright (C) 2003, 2005 Free Software Foundation
This file is part of libgcj.
@@ -9,13 +9,13 @@ details. */
#include <config.h>
#include <platform.h>
-#include <java/net/NetworkInterface.h>
#include <java/net/SocketException.h>
+#include <java/net/VMNetworkInterface.h>
#include <java/util/Vector.h>
::java::util::Vector*
-java::net::NetworkInterface::getRealNetworkInterfaces ()
+java::net::VMNetworkInterface::getInterfaces ()
{
throw new SocketException (
- JvNewStringLatin1 ("NetworkInterface.getrealNetworkInterfaces: unimplemented"));
+ JvNewStringLatin1 ("VMNetworkInterface.getInterfaces: unimplemented"));
}
diff --git a/libjava/java/net/natNetworkInterfacePosix.cc b/libjava/java/net/natVMNetworkInterfacePosix.cc
index f4c5d6b..c3a222a 100644
--- a/libjava/java/net/natNetworkInterfacePosix.cc
+++ b/libjava/java/net/natVMNetworkInterfacePosix.cc
@@ -1,4 +1,4 @@
-/* Copyright (C) 2003 Free Software Foundation
+/* Copyright (C) 2003, 2005 Free Software Foundation
This file is part of libgcj.
@@ -37,13 +37,14 @@ details. */
#include <gcj/cni.h>
#include <jvm.h>
-#include <java/net/NetworkInterface.h>
#include <java/net/Inet4Address.h>
+#include <java/net/NetworkInterface.h>
#include <java/net/SocketException.h>
+#include <java/net/VMNetworkInterface.h>
#include <java/util/Vector.h>
::java::util::Vector*
-java::net::NetworkInterface::getRealNetworkInterfaces ()
+java::net::VMNetworkInterface::getInterfaces ()
{
int fd;
int num_interfaces = 0;
diff --git a/libjava/java/net/natNetworkInterfaceWin32.cc b/libjava/java/net/natVMNetworkInterfaceWin32.cc
index 429066e..257e06d 100644
--- a/libjava/java/net/natNetworkInterfaceWin32.cc
+++ b/libjava/java/net/natVMNetworkInterfaceWin32.cc
@@ -1,4 +1,4 @@
-/* Copyright (C) 2003 Free Software Foundation
+/* Copyright (C) 2003, 2005 Free Software Foundation
This file is part of libgcj.
@@ -114,7 +114,7 @@ determineGetRealNetworkInterfacesFN ()
}
::java::util::Vector*
-java::net::NetworkInterface::getRealNetworkInterfaces ()
+java::net::VMNetworkInterface::getInterfaces ()
{
// This next declaration used to be a static local,
// but this introduced a dependency on libsupc++ due