=================================================================== RCS file: /home/cvs/OpenXM/src/OpenMath/OMproxy.java,v retrieving revision 1.25 retrieving revision 1.42 diff -u -p -r1.25 -r1.42 --- OpenXM/src/OpenMath/OMproxy.java 2000/01/20 18:55:22 1.25 +++ OpenXM/src/OpenMath/OMproxy.java 2001/01/30 05:55:13 1.42 @@ -1,92 +1,108 @@ /** - * $OpenXM: OpenXM/src/OpenMath/OMproxy.java,v 1.24 2000/01/20 18:14:32 tam Exp $ + * $OpenXM: OpenXM/src/OpenMath/OMproxy.java,v 1.41 2000/10/11 08:32:13 ohara Exp $ */ -import JP.ac.kobe_u.math.tam.OpenXM.*; +import ORG.openxm.tam.*; import java.util.Stack; import java.io.*; -class OMproxy implements Runnable{ - private OpenXM ox; +public class OMproxy extends OpenXMControlServer{ 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(OpenXMstream stream){ OM2OXM P = new OM2OXM(); debug("OMproxy started."); - while(true){ - try{ - int ox_tag = ox.receiveOXtag(); + try{ + while(true){ + try{ + OXmessage message = stream.receive(); + int ox_tag = message.getTag(); - switch(ox_tag){ - case OpenXM.OX_COMMAND: - StackMachine(ox.receiveSM()); - break; + switch(ox_tag){ + case OXmessage.OX_COMMAND: + StackMachine((SM)message.getBody(),stream); + break; - case OpenXM.OX_DATA: - stack.push(ox.receiveCMO()); - debug("push: "+ stack.peek()); - break; + case OXmessage.OX_DATA: + stack.push(message.getBody()); + debug("push: "+ stack.peek()); + break; + } + }catch(RuntimeException e){ + System.err.println(e.getMessage()); + e.printStackTrace(); + debug("error occured. stack was cleared."); + stack = new Stack(); } - }catch(Throwable e){ - System.err.println(e.getMessage()); - e.printStackTrace(); - debug("error occured. stack was cleared."); } + }catch(IOException e){ + System.err.println(e.getMessage()); + e.printStackTrace(); + System.err.println("error occured, and recovering processes seems to be impossible."); + }catch(Exception e){ + System.err.println(e.getMessage()); + e.printStackTrace(); + System.err.println("error occured, and recovering processes seems to be impossible."); + }finally{ + System.err.println("breaking..."); } - //System.out.println("breaking..."); } /* public void stop(){ - System.out.println("OMproxy Stoping..."); + System.err.println("OMproxy Stoping..."); synchronized(ox){ //this.stop(); while(!stack.empty()){ stack.pop(); } - System.out.println("OMproxy Stopped"); + System.err.println("OMproxy Stopped"); } } */ - private void SM_popCMO() throws java.io.IOException{ + private void SM_popCMO(OpenXMstream 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(stack.pop()); + stream.send((CMO)stack.pop()); + debug("test"); } }catch(MathcapViolation e){ - stack.push(new CMO_STRING(e.getMessage())); + try{ + stream.send(new CMO_ERROR2(new CMO_STRING("MathcapViolation: "+ + e.getMessage()))); + }catch(MathcapViolation tmp){} } } private void SM_executeFunction() throws java.io.IOException{ String function_name; CMO[] argv; - int argc = 1; + int argc; if(!(stack.peek() instanceof CMO_STRING)){ - stack.push(new CMO_ERROR2()); + stack.push(new CMO_ERROR2(new CMO_NULL())); return; } function_name = ((CMO_STRING)stack.pop()).getString(); - //argc = ((CMO_INT32)stack.pop()).intValue(); + argc = ((CMO_INT32)stack.pop()).intValue(); argv = new CMO[argc]; for(int i=0;i