diff --git a/libjava/ChangeLog b/libjava/ChangeLog index cc46804b0c0..baa5810f3e7 100644 --- a/libjava/ChangeLog +++ b/libjava/ChangeLog @@ -1,3 +1,8 @@ +2003-07-14 Michael Koch + + * gnu/java/rmi/server/UnicastServerRef.java: + New version from classpath. + 2003-07-14 Michael Koch * java/awt/image/MemoryImageSource.java, diff --git a/libjava/gnu/java/rmi/server/UnicastServerRef.java b/libjava/gnu/java/rmi/server/UnicastServerRef.java index a3a999f2e9f..e2f38ff5f8c 100644 --- a/libjava/gnu/java/rmi/server/UnicastServerRef.java +++ b/libjava/gnu/java/rmi/server/UnicastServerRef.java @@ -138,8 +138,9 @@ public boolean unexportObject(Remote obj, boolean force) { private Object getHelperClass(Class cls, String type) { try { String classname = cls.getName(); - ClassLoader cl = cls.getClassLoader(); //DONT use "Class scls = Class.forName(classname + type);" - Class scls = cl.loadClass(classname + type); + ClassLoader cl = cls.getClassLoader(); + Class scls = cl == null ? Class.forName(classname + type) + : cl.loadClass(classname + type); if (type.equals("_Stub")) { try { // JDK 1.2 stubs @@ -225,7 +226,9 @@ public Object incomingMessageCall(UnicastConnection conn, int method, long hash) * lets us know that. */ try { - args[i] = in.readObject(); + // need to handle primitive types + args[i] = ((RMIObjectInputStream)in).readValue(meth.getParameterTypes()[i]); + } catch (Exception t) { t.printStackTrace(); @@ -257,3 +260,5 @@ public Object incomingMessageCall(UnicastConnection conn, int method, long hash) } } + +