=================================================================== RCS file: /home/cvs/OpenXM/src/OpenMath/OMproxy.java,v retrieving revision 1.35 retrieving revision 1.38 diff -u -p -r1.35 -r1.38 --- OpenXM/src/OpenMath/OMproxy.java 2000/03/15 15:02:06 1.35 +++ OpenXM/src/OpenMath/OMproxy.java 2000/06/14 08:01:08 1.38 @@ -1,37 +1,36 @@ /** - * $OpenXM: OpenXM/src/OpenMath/OMproxy.java,v 1.34 2000/03/14 05:38:49 tam Exp $ + * $OpenXM: OpenXM/src/OpenMath/OMproxy.java,v 1.37 2000/06/13 14:04:19 tam Exp $ */ import JP.ac.kobe_u.math.tam.OpenXM.*; import java.util.Stack; import java.io.*; -class OMproxy implements Runnable{ - private OpenXM ox; +public class OMproxy extends OpenXMserver{ private Stack stack = new Stack(); protected boolean debug = false; - final int version = 200001190; + final int version = 200006130; - public OMproxy(String host,int ControlPort,int DataPort) throws IOException{ - ox = new OpenXM(this,host,ControlPort,DataPort); + public OMproxy(String hostname,int ControlPort,int DataPort){ + super(hostname,ControlPort,DataPort); } - public void run(){ + public void computeProcess(OpenXMconnection stream){ OM2OXM P = new OM2OXM(); debug("OMproxy started."); try{ while(true){ try{ - OXmessage message = ox.receive(); + OXmessage message = stream.receive(); int ox_tag = message.getTag(); switch(ox_tag){ - case OpenXM.OX_COMMAND: - StackMachine((SM)message.getBody()); + case OXmessage.OX_COMMAND: + StackMachine((SM)message.getBody(),stream); break; - case OpenXM.OX_DATA: + case OXmessage.OX_DATA: stack.push(message.getBody()); debug("push: "+ stack.peek()); break; @@ -40,6 +39,7 @@ class OMproxy implements Runnable{ System.err.println(e.getMessage()); e.printStackTrace(); debug("error occured. stack was cleared."); + stack = new Stack(); } } }catch(IOException e){ @@ -64,17 +64,18 @@ class OMproxy implements Runnable{ } */ - private void SM_popCMO() throws java.io.IOException{ + private void SM_popCMO(OpenXMconnection stream) throws java.io.IOException{ try{ if(stack.empty()){ - ox.send(new CMO_NULL()); + stream.send(new CMO_NULL()); }else{ debug("sending CMO: "+ stack.peek()); - ox.send((CMO)stack.pop()); + stream.send((CMO)stack.pop()); + debug("test"); } }catch(MathcapViolation e){ try{ - ox.send(new CMO_ERROR2(new CMO_STRING("MathcapViolation: "+ + stream.send(new CMO_ERROR2(new CMO_STRING("MathcapViolation: "+ e.getMessage()))); }catch(MathcapViolation tmp){} } @@ -113,7 +114,7 @@ class OMproxy implements Runnable{ return; } - private void SM_mathcap() throws java.io.IOException{ + private void SM_mathcap(OpenXMconnection stream) throws java.io.IOException{ CMO[] mathcap = new CMO[3]; { @@ -150,32 +151,35 @@ class OMproxy implements Runnable{ new CMO_INT32(CMO.BIGFLOAT), new CMO_INT32(CMO.INDETERMINATE), new CMO_INT32(CMO.TREE)}; - CMO[] DataFormat1 = {new CMO_INT32(OpenXM.OX_DATA), + CMO[] DataFormat1 = {new CMO_INT32(OXmessage.OX_DATA), new CMO_LIST(CMOFormat)}; CMO[] list = {new CMO_LIST(DataFormat1)}; mathcap[2] = new CMO_LIST(list); } + stack = new Stack(); stack.push(new CMO_MATHCAP(new CMO_LIST(mathcap))); debug("push: "+ stack.peek()); } - private void SM_setMathCap() throws java.io.IOException{ + private void SM_setMathCap(OpenXMconnection stream) + throws java.io.IOException{ Object mathcap = stack.pop(); if(mathcap instanceof CMO_MATHCAP){ stack.push(new CMO_ERROR2(new CMO_NULL())); } - ox.setMathCap((CMO_MATHCAP)mathcap); + stream.setMathCap((CMO_MATHCAP)mathcap); } - private void StackMachine(SM mesg) throws java.io.IOException{ + private void StackMachine(SM mesg,OpenXMconnection stream) + throws java.io.IOException{ debug("receive: "+mesg); switch(mesg.getCode()){ case SM.SM_popCMO: - SM_popCMO(); + SM_popCMO(stream); break; case SM.SM_executeFunction: @@ -183,11 +187,11 @@ class OMproxy implements Runnable{ break; case SM.SM_mathcap: - SM_mathcap(); + SM_mathcap(stream); break; case SM.SM_setMathCap: - SM_setMathCap(); + SM_setMathCap(stream); break; default: @@ -236,7 +240,7 @@ class OMproxy implements Runnable{ private void debug(String str){ if(debug){ - System.out.println(str); + System.err.println(str); } } @@ -255,41 +259,45 @@ class OMproxy implements Runnable{ return ret; } - public static void main(String argv[]){ - String host = "localhost"; - int DataPort = 1300, ControlPort = 1200; - boolean debug = false; + public static void main(String[] argv){ + String hostname = "localhost"; + int ControlPort = 1200, DataPort = 1300; + OpenXMserver ox; for(int i=0;i