version 1.15, 1999/11/25 12:17:31 |
version 1.25, 2000/01/20 18:55:22 |
|
|
/** |
/** |
* $OpenXM: OpenXM/src/OpenMath/OMproxy.java,v 1.14 1999/11/19 08:49:06 tam Exp $ |
* $OpenXM: OpenXM/src/OpenMath/OMproxy.java,v 1.24 2000/01/20 18:14:32 tam Exp $ |
*/ |
*/ |
|
|
import JP.ac.kobe_u.math.tam.OpenXM.*; |
import JP.ac.kobe_u.math.tam.OpenXM.*; |
|
|
class OMproxy implements Runnable{ |
class OMproxy implements Runnable{ |
private OpenXM ox; |
private OpenXM ox; |
private Stack stack = new Stack(); |
private Stack stack = new Stack(); |
private boolean debug = true; |
protected boolean debug = false; |
final int version = 199911110; |
final int version = 200001190; |
|
|
public OMproxy(String host,int ControlPort,int DataPort) throws IOException{ |
public OMproxy(String host,int ControlPort,int DataPort) throws IOException{ |
ox = new OpenXM(this,host,ControlPort,DataPort); |
ox = new OpenXM(this,host,ControlPort,DataPort); |
Line 20 class OMproxy implements Runnable{ |
|
Line 20 class OMproxy implements Runnable{ |
|
OM2OXM P = new OM2OXM(); |
OM2OXM P = new OM2OXM(); |
|
|
debug("OMproxy started."); |
debug("OMproxy started."); |
try{ |
while(true){ |
while(true){ |
try{ |
int ox_tag = ox.receiveOXtag(); |
int ox_tag = ox.receiveOXtag(); |
|
|
switch(ox_tag){ |
switch(ox_tag){ |
Line 34 class OMproxy implements Runnable{ |
|
Line 34 class OMproxy implements Runnable{ |
|
debug("push: "+ stack.peek()); |
debug("push: "+ stack.peek()); |
break; |
break; |
} |
} |
|
}catch(Throwable e){ |
|
System.err.println(e.getMessage()); |
|
e.printStackTrace(); |
|
debug("error occured. stack was cleared."); |
} |
} |
}catch(java.io.IOException e){ |
|
System.err.println(e.getMessage()); |
|
e.printStackTrace(); |
|
} |
} |
|
//System.out.println("breaking..."); |
System.out.println("breaking..."); |
|
} |
} |
|
|
/* |
/* |
Line 57 class OMproxy implements Runnable{ |
|
Line 57 class OMproxy implements Runnable{ |
|
*/ |
*/ |
|
|
private void SM_popCMO() throws java.io.IOException{ |
private void SM_popCMO() throws java.io.IOException{ |
if(stack.empty()){ |
try{ |
ox.send(new CMO_NULL()); |
if(stack.empty()){ |
}else{ |
ox.send(new CMO_NULL()); |
debug("sending CMO: "+ stack.peek()); |
}else{ |
ox.send(stack.pop()); |
debug("sending CMO: "+ stack.peek()); |
|
ox.send(stack.pop()); |
|
} |
|
}catch(MathcapViolation e){ |
|
stack.push(new CMO_STRING(e.getMessage())); |
} |
} |
} |
} |
|
|
Line 113 class OMproxy implements Runnable{ |
|
Line 117 class OMproxy implements Runnable{ |
|
CMO[] list = {new CMO_INT32(SM.SM_popCMO), |
CMO[] list = {new CMO_INT32(SM.SM_popCMO), |
new CMO_INT32(SM.SM_executeFunction), |
new CMO_INT32(SM.SM_executeFunction), |
new CMO_INT32(SM.SM_mathcap), |
new CMO_INT32(SM.SM_mathcap), |
|
new CMO_INT32(SM.SM_setMathCap), |
new CMO_INT32(SM.SM_control_kill), |
new CMO_INT32(SM.SM_control_kill), |
new CMO_INT32(SM.SM_control_reset_connection)}; |
new CMO_INT32(SM.SM_control_reset_connection)}; |
mathcap[1] = new CMO_LIST(list); |
mathcap[1] = new CMO_LIST(list); |
Line 145 class OMproxy implements Runnable{ |
|
Line 150 class OMproxy implements Runnable{ |
|
debug("push: "+ stack.peek()); |
debug("push: "+ stack.peek()); |
} |
} |
|
|
|
private void SM_setMathCap() throws java.io.IOException{ |
|
Object mathcap = stack.pop(); |
|
|
|
if(mathcap instanceof CMO_MATHCAP){ |
|
stack.push(new CMO_ERROR2()); |
|
} |
|
ox.setMathCap((CMO_MATHCAP)mathcap); |
|
} |
|
|
private void StackMachine(SM mesg) throws java.io.IOException{ |
private void StackMachine(SM mesg) throws java.io.IOException{ |
debug("receive: "+mesg); |
debug("receive: "+mesg); |
|
|
Line 161 class OMproxy implements Runnable{ |
|
Line 175 class OMproxy implements Runnable{ |
|
SM_mathcap(); |
SM_mathcap(); |
break; |
break; |
|
|
|
case SM.SM_setMathCap: |
|
SM_setMathCap(); |
|
break; |
|
|
default: |
default: |
System.out.println("received "+ mesg); |
System.out.println("received "+ mesg); |
} |
} |
Line 221 class OMproxy implements Runnable{ |
|
Line 239 class OMproxy implements Runnable{ |
|
ret += "\t -data port \t (default 1300)\n"; |
ret += "\t -data port \t (default 1300)\n"; |
ret += "\t -control port \t (default 1200)\n"; |
ret += "\t -control port \t (default 1200)\n"; |
ret += "\t -insecure \t this version ignore this option\n"; |
ret += "\t -insecure \t this version ignore this option\n"; |
|
ret += "\t -debug \t display debug messages\n"; |
|
|
return ret; |
return ret; |
} |
} |
Line 228 class OMproxy implements Runnable{ |
|
Line 247 class OMproxy implements Runnable{ |
|
public static void main(String argv[]){ |
public static void main(String argv[]){ |
String host = "localhost"; |
String host = "localhost"; |
int DataPort = 1300, ControlPort = 1200; |
int DataPort = 1300, ControlPort = 1200; |
|
boolean debug = false; |
|
|
for(int i=0;i<argv.length;i++){ |
for(int i=0;i<argv.length;i++){ |
if(argv[i].equals("-h")){ |
if(argv[i].equals("-h")){ |
Line 240 class OMproxy implements Runnable{ |
|
Line 260 class OMproxy implements Runnable{ |
|
}else if(argv[i].equals("-control")){ |
}else if(argv[i].equals("-control")){ |
ControlPort = Integer.valueOf(argv[++i]).intValue(); |
ControlPort = Integer.valueOf(argv[++i]).intValue(); |
}else if(argv[i].equals("-insecure")){ |
}else if(argv[i].equals("-insecure")){ |
|
}else if(argv[i].equals("-debug")){ |
|
debug = true; |
}else{ |
}else{ |
System.err.println("unknown option : "+ argv[i]); |
System.err.println("unknown option : "+ argv[i]); |
System.err.print(usage()); |
System.err.print(usage()); |
Line 251 class OMproxy implements Runnable{ |
|
Line 273 class OMproxy implements Runnable{ |
|
+"("+ ControlPort +","+ DataPort +")"); |
+"("+ ControlPort +","+ DataPort +")"); |
|
|
try{ |
try{ |
new OMproxy(host,ControlPort,DataPort); |
new OMproxy(host,ControlPort,DataPort).debug = debug; |
System.out.println("connected."); |
System.out.println("connected."); |
}catch(IOException e){ |
}catch(IOException e){ |
System.err.println("Error occured: "+ e); |
System.err.println("Error occured: "+ e); |