[multiple changes]

2002-02-14  Mark Wielaard  <mark@klomp.org>

    * java/math/BigInteger.java: import gnu.java.math.MPN not the whole
    package as a workaround for gcj 3.0.x

2002-02-14  Mark Wielaard <mark@klomp.org>

    * java/security/BasicPermission.java: extends with fully qualified
    classname as workaround for gcj 3.0.4.

2002-02-14  Eric Blake  <ebb9@email.byu.edu>

    * java/net/DatagramSocketImpl.java (setOption, getOption): Work
    around gcj bug of wrong emitted qualifier for inherited method.
    * java/net/SocketImpl.java (setOption, getOption): Ditto.
    * java/util/WeakHashMap.java (WeakEntrySet): Add non-private
    constructor to reduce amount of emitted bytecode. While this
    happens to work around a jikes 1.15 bug, it is still a useful
    patch even for correct compilers.
    * java/rmi/server/RMIClassLoader.java (MyClassLoader): Ditto.
    * gnu/java/rmi/server/UnicastRemoteCall.java
    (DummyObjectOutputStream, DummyObjectInputStream): Ditto.

2002-02-14  Eric Blake  <ebb9@email.byu.edu>

    * java/net/DatagramSocketImpl.java: Reformat (no code changes).
    * java/net/SocketImpl.java: Ditto.
    * java/rmi/server/RMIClassLoader.java: Ditto.
    * gnu/java/rmi/server/UnicastRemoteCall.java: Ditto.

2002-02-14  Mark Wielaard <mark@klomp.org>

    Thanks to Takashi Okamoto
    * java/util/Arrays.java (ArrayList.indexOf()): this.equals().
    * java/util/Arrays.java (ArrayList.lastIndexOf()): Likewise.
    * java/util/WeakHashMap.java (WeakEntry.getEntry()): this.get().

From-SVN: r49778
This commit is contained in:
Mark Wielaard 2002-02-14 23:16:11 +00:00
parent 9a360704f9
commit 894286989e
9 changed files with 536 additions and 344 deletions

View file

@ -1,5 +1,5 @@
/*
Copyright (c) 1996, 1997, 1998, 1999 Free Software Foundation, Inc.
/* UnicastRemoteCall.java
Copyright (c) 1996, 1997, 1998, 1999, 2002 Free Software Foundation, Inc.
This file is part of GNU Classpath.
@ -7,7 +7,7 @@ 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
@ -45,267 +45,331 @@ import java.io.StreamCorruptedException;
import java.rmi.server.RemoteCall;
import java.util.Vector;
public class UnicastRemoteCall
implements RemoteCall {
public class UnicastRemoteCall implements RemoteCall
{
private UnicastConnection conn;
private Object result;
private Object object;
private int opnum;
private long hash;
private Vector vec;
private int ptr;
private UnicastConnection conn;
private Object result;
private Object object;
private int opnum;
private long hash;
private Vector vec;
private int ptr;
/**
* Incoming call.
*/
UnicastRemoteCall(UnicastConnection conn) {
this.conn = conn;
}
/**
* Incoming call.
*/
UnicastRemoteCall(UnicastConnection conn)
{
this.conn = conn;
}
/**
* Outgoing call.
*/
UnicastRemoteCall(Object obj, int opnum, long hash) {
this.object = obj;
this.opnum = opnum;
this.hash = hash;
}
/**
* Outgoing call.
*/
UnicastRemoteCall(Object obj, int opnum, long hash)
{
this.object = obj;
this.opnum = opnum;
this.hash = hash;
}
public ObjectOutput getOutputStream() throws IOException {
vec = new Vector();
return (new DummyObjectOutputStream());
}
public ObjectOutput getOutputStream() throws IOException
{
vec = new Vector();
return new DummyObjectOutputStream();
}
public void releaseOutputStream() throws IOException {
// Does nothing.
}
public void releaseOutputStream() throws IOException
{
// Does nothing.
}
public ObjectInput getInputStream() throws IOException {
if (conn != null) {
return (conn.getObjectInputStream());
}
else {
ptr = 0;
return (new DummyObjectInputStream());
}
}
public ObjectInput getInputStream() throws IOException
{
if (conn != null)
return conn.getObjectInputStream();
ptr = 0;
return new DummyObjectInputStream();
}
public void releaseInputStream() throws IOException {
// Does nothing.
}
public void releaseInputStream() throws IOException
{
// Does nothing.
}
public ObjectOutput getResultStream(boolean success) throws IOException, StreamCorruptedException {
vec = new Vector();
return (new DummyObjectOutputStream());
}
public ObjectOutput getResultStream(boolean success)
throws IOException, StreamCorruptedException
{
vec = new Vector();
return new DummyObjectOutputStream();
}
public void executeCall() throws Exception {
throw new Error("Not implemented");
}
public void executeCall() throws Exception
{
throw new Error("Not implemented");
}
public void done() throws IOException {
/* Does nothing */
}
public void done() throws IOException
{
/* Does nothing */
}
Object returnValue() {
return (vec.elementAt(0));
}
Object returnValue()
{
return vec.elementAt(0);
}
Object[] getArguments() {
return (vec.toArray());
}
Object[] getArguments()
{
return vec.toArray();
}
Object getObject() {
return (object);
}
Object getObject()
{
return object;
}
int getOpnum() {
return (opnum);
}
int getOpnum()
{
return opnum;
}
long getHash() {
return (hash);
}
long getHash()
{
return hash;
}
void setReturnValue(Object obj) {
vec.removeAllElements();
vec.addElement(obj);
}
void setReturnValue(Object obj)
{
vec.removeAllElements();
vec.addElement(obj);
}
/**
* Dummy object output class.
*/
private class DummyObjectOutputStream implements ObjectOutput {
/**
* Dummy object output class.
*/
private class DummyObjectOutputStream implements ObjectOutput
{
/**
* Non-private constructor to reduce bytecode emitted.
*/
DummyObjectOutputStream()
{
}
public void writeBoolean(boolean v) throws IOException {
vec.addElement(new Boolean(v));
}
public void writeBoolean(boolean v) throws IOException
{
vec.addElement(new Boolean(v));
}
public void writeByte(int v) throws IOException {
vec.addElement(new Byte((byte)v));
}
public void writeByte(int v) throws IOException
{
vec.addElement(new Byte((byte) v));
}
public void writeChar(int v) throws IOException {
vec.addElement(new Character((char)v));
}
public void writeChar(int v) throws IOException
{
vec.addElement(new Character((char) v));
}
public void writeDouble(double v) throws IOException {
vec.addElement(new Double(v));
}
public void writeDouble(double v) throws IOException
{
vec.addElement(new Double(v));
}
public void writeFloat(float v) throws IOException {
vec.addElement(new Float(v));
}
public void writeFloat(float v) throws IOException
{
vec.addElement(new Float(v));
}
public void writeInt(int v) throws IOException {
vec.addElement(new Integer(v));
}
public void writeInt(int v) throws IOException
{
vec.addElement(new Integer(v));
}
public void writeLong(long v) throws IOException {
vec.addElement(new Long(v));
}
public void writeLong(long v) throws IOException
{
vec.addElement(new Long(v));
}
public void writeShort(int v) throws IOException {
vec.addElement(new Short((short)v));
}
public void writeShort(int v) throws IOException
{
vec.addElement(new Short((short) v));
}
public void writeObject(Object obj) throws IOException {
vec.addElement(obj);
}
public void writeObject(Object obj) throws IOException
{
vec.addElement(obj);
}
public void write(byte b[]) throws IOException {
throw new IOException("not required");
}
public void write(byte b[]) throws IOException
{
throw new IOException("not required");
}
public void write(byte b[], int off, int len) throws IOException {
throw new IOException("not required");
}
public void write(byte b[], int off, int len) throws IOException
{
throw new IOException("not required");
}
public void write(int b) throws IOException {
throw new IOException("not required");
}
public void write(int b) throws IOException
{
throw new IOException("not required");
}
public void writeBytes(String s) throws IOException {
throw new IOException("not required");
}
public void writeBytes(String s) throws IOException
{
throw new IOException("not required");
}
public void writeChars(String s) throws IOException {
throw new IOException("not required");
}
public void writeChars(String s) throws IOException
{
throw new IOException("not required");
}
public void writeUTF(String str) throws IOException {
throw new IOException("not required");
}
public void writeUTF(String str) throws IOException
{
throw new IOException("not required");
}
public void flush() throws IOException {
}
public void flush() throws IOException
{
}
public void close() throws IOException {
}
}
/**
* Dummy object input class.
*/
private class DummyObjectInputStream implements ObjectInput {
public boolean readBoolean() throws IOException {
Object obj = vec.elementAt(ptr++);
return (((Boolean)obj).booleanValue());
}
public byte readByte() throws IOException {
Object obj = vec.elementAt(ptr++);
return (((Byte)obj).byteValue());
}
public char readChar() throws IOException {
Object obj = vec.elementAt(ptr++);
return (((Character)obj).charValue());
}
public double readDouble() throws IOException {
Object obj = vec.elementAt(ptr++);
return (((Double)obj).doubleValue());
}
public float readFloat() throws IOException {
Object obj = vec.elementAt(ptr++);
return (((Float)obj).floatValue());
}
public int readInt() throws IOException {
Object obj = vec.elementAt(ptr++);
return (((Integer)obj).intValue());
}
public long readLong() throws IOException {
Object obj = vec.elementAt(ptr++);
return (((Long)obj).longValue());
}
public short readShort() throws IOException {
Object obj = vec.elementAt(ptr++);
return (((Short)obj).shortValue());
}
public Object readObject() throws IOException {
return (vec.elementAt(ptr++));
}
public int read(byte b[]) throws IOException {
throw new IOException("not required");
}
public int read(byte b[], int off, int len) throws IOException {
throw new IOException("not required");
}
public int read() throws IOException {
throw new IOException("not required");
}
public long skip(long n) throws IOException {
throw new IOException("not required");
}
public int available() throws IOException {
throw new IOException("not required");
}
public void readFully(byte b[]) throws IOException {
throw new IOException("not required");
}
public void readFully(byte b[], int off, int len) throws IOException {
throw new IOException("not required");
}
public String readLine() throws IOException {
throw new IOException("not required");
}
public String readUTF() throws IOException {
throw new IOException("not required");
}
public int readUnsignedByte() throws IOException {
throw new IOException("not required");
}
public int readUnsignedShort() throws IOException {
throw new IOException("not required");
}
public int skipBytes(int n) throws IOException {
throw new IOException("not required");
}
public void close() throws IOException {
}
}
public void close() throws IOException
{
}
} // class DummyObjectOutputStream
/**
* Dummy object input class.
*/
private class DummyObjectInputStream implements ObjectInput
{
/**
* Non-private constructor to reduce bytecode emitted.
*/
DummyObjectInputStream()
{
}
public boolean readBoolean() throws IOException
{
Object obj = vec.elementAt(ptr++);
return ((Boolean) obj).booleanValue();
}
public byte readByte() throws IOException
{
Object obj = vec.elementAt(ptr++);
return ((Byte) obj).byteValue();
}
public char readChar() throws IOException
{
Object obj = vec.elementAt(ptr++);
return ((Character) obj).charValue();
}
public double readDouble() throws IOException
{
Object obj = vec.elementAt(ptr++);
return ((Double) obj).doubleValue();
}
public float readFloat() throws IOException
{
Object obj = vec.elementAt(ptr++);
return ((Float) obj).floatValue();
}
public int readInt() throws IOException
{
Object obj = vec.elementAt(ptr++);
return ((Integer) obj).intValue();
}
public long readLong() throws IOException
{
Object obj = vec.elementAt(ptr++);
return ((Long) obj).longValue();
}
public short readShort() throws IOException
{
Object obj = vec.elementAt(ptr++);
return ((Short) obj).shortValue();
}
public Object readObject() throws IOException
{
return vec.elementAt(ptr++);
}
public int read(byte b[]) throws IOException
{
throw new IOException("not required");
}
public int read(byte b[], int off, int len) throws IOException
{
throw new IOException("not required");
}
public int read() throws IOException
{
throw new IOException("not required");
}
public long skip(long n) throws IOException
{
throw new IOException("not required");
}
public int available() throws IOException
{
throw new IOException("not required");
}
public void readFully(byte b[]) throws IOException
{
throw new IOException("not required");
}
public void readFully(byte b[], int off, int len) throws IOException
{
throw new IOException("not required");
}
public String readLine() throws IOException
{
throw new IOException("not required");
}
public String readUTF() throws IOException
{
throw new IOException("not required");
}
public int readUnsignedByte() throws IOException
{
throw new IOException("not required");
}
public int readUnsignedShort() throws IOException
{
throw new IOException("not required");
}
public int skipBytes(int n) throws IOException
{
throw new IOException("not required");
}
public void close() throws IOException
{
}
} // class DummyObjectInputStream
}