=================================================================== RCS file: /home/cvs/OpenXM/src/kan96xx/Doc/ox.sm1,v retrieving revision 1.45 retrieving revision 1.49 diff -u -p -r1.45 -r1.49 --- OpenXM/src/kan96xx/Doc/ox.sm1 2004/09/17 12:32:11 1.45 +++ OpenXM/src/kan96xx/Doc/ox.sm1 2006/02/02 05:15:45 1.49 @@ -1,4 +1,4 @@ -%%%%%%%%%%% $OpenXM: OpenXM/src/kan96xx/Doc/ox.sm1,v 1.44 2004/09/17 11:05:56 takayama Exp $ +%%%%%%%%%%% $OpenXM: OpenXM/src/kan96xx/Doc/ox.sm1,v 1.48 2006/02/02 04:16:49 takayama Exp $ /ox.sm1.myname (ox-new.sm1) def @@ -48,6 +48,7 @@ ox.version [(Version)] system_variable gt /@@@.Xm_noX Xm_noX def }{ } ifelse /Xm_noX @@@.Xm_noX def +/Xm_engineLogToStdout 0 def /oxNoX { /Xm_noX 1 def @@ -103,6 +104,7 @@ ox.version [(Version)] system_variable gt (client oxpushcmotag) ( ) (client oxgetsp --- get stack pointer, client oxgeterrors --- get all errors) + (client oxclearstack --- clear the stack of the ox server.) (cleint oxisData, client oxreset, client oxshutdown) (oxhelp for this message) ([(oxWatch) client] extension to start a log.) @@ -684,6 +686,7 @@ ox.verbose { oxhelp } { } ifelse oxstart100 @@@.quiet { ( -quiet ) } { } ifelse Xm_noX { ( -nox ) } { } ifelse + Xm_engineLogToStdout { ( -nox -engineLogToStdout ) } { } ifelse %bug.onlyForsm1 ( -oxserver bin/ox_sm1 -e ) ( -reverse ) ( -data ) data ( -control ) control pass [1 2] get ( )] cat execve @@ -1728,6 +1731,7 @@ oxasir.verbose { oxstart100 @@@.quiet { ( -quiet ) } { } ifelse Xm_noX { ( -nox ) } { } ifelse + Xm_engineLogToStdout { ( -nox -engineLogToStdout ) } { } ifelse %bug.onlyForasir ( -oxserver bin/ox_asir -e ) ( -reverse ) ( -data ) data ( -control ) control pass [1 2] get ( )] cat execve @@ -1839,4 +1843,83 @@ oxasir.verbose { ] pop popVariables arg1 -} def \ No newline at end of file +} def + +[[(lines),[10,-1]], + [(where),[(shell), (length)]], + [(reason_of_error), (invalid argument)]] +/i1 set +%% /translateErrorForCfep.sampleInput set + +[(translateErrorForCfep) +[ + (translate the error packet defined in ox-rfc-103 into series of commands for cfep.) +] +] putUsages +/translateErrorForCfep { + /arg1 set + [/ee /ans /tt /lf] pushVariables + [ + /ee arg1 def + { + ee etag 257 eq { + ee (body) dc 1 get /ee set + ee length 3 gt { + ee 3 get /ee set + }{ /ee [ ] def } ifelse + }{ } ifelse + ee etag 6 eq not { /ans [ ] def exit } { } ifelse + /ans [ ] def + /lf 12 (string) dc def % line feed. it is not necessary. + + ee (lines) getNode /tt set + tt tag 0 eq { + ee (parse_error_at) getNode /tt set + } { } ifelse + tt isArray { + tt length 0 gt { + ans + [(gotoLine, ) tt 0 get toString nl] join /ans set + }{ } ifelse + } { } ifelse + tt isInteger { + [(gotoLine, ) tt toString nl] join /ans set + } { } ifelse + + ee (where) getNode /tt set + tt isArray { + tt length 0 gt { + ans + [(findAndSelect, ) tt 0 get (string) dc nl] join /ans set + }{ } ifelse + } { } ifelse + + ee (reason_of_error) getNode /tt set + tt tag 0 eq { + ee (reason_of_parse_error) getNode /tt set + } { } ifelse + tt tag 0 eq not { + ans [(printErrorMessage, ) tt (string) dc nl] join /ans set + %% translation and encoding is necessary. + }{ } ifelse + + exit + } loop + ans cat /arg1 set + ] pop + popVariables + arg1 +} def + +/oxclearstack { + /arg1 set + [/cl /n] pushVariables + [ + /cl arg1 def + cl oxgetsp /n set + n tag 0 eq { /n 0 def } { } ifelse + n tag 15 eq { n (integer) dc /n set } { } ifelse + cl n oxpops pop + ] pop + popVariables +} def