[BACK]Return to math2ox.c CVS log [TXT][DIR] Up to [local] / OpenXM / src / ox_math

Diff for /OpenXM/src/ox_math/math2ox.c between version 1.4 and 1.9

version 1.4, 1999/11/04 19:33:17 version 1.9, 1999/12/14 09:31:55
Line 1 
Line 1 
 /* -*- mode: C; coding: euc-japan -*- */  /* -*- mode: C; coding: euc-japan -*- */
 /* $OpenXM: OpenXM/src/ox_math/math2ox.c,v 1.3 1999/11/04 17:53:04 ohara Exp $ */  /* $OpenXM: OpenXM/src/ox_math/math2ox.c,v 1.8 1999/11/29 12:09:57 ohara Exp $ */
 /* $Id$ */  
   
 #include <sys/types.h>  #include <sys/types.h>
 #include <sys/stat.h>  #include <sys/stat.h>
Line 11 
Line 10 
 #include <mathlink.h>  #include <mathlink.h>
 #include <unistd.h>  #include <unistd.h>
 #include <signal.h>  #include <signal.h>
   #include <mathlink.h>
   
 #include "ox.h"  #include "ox.h"
 #include "parse.h"  #include "parse.h"
   #include "serv2.h"
   
 static char *host    = "localhost";  static char *host    = "localhost";
 static char *ctlserv = "ox";  static char *ctlserv = "ox";
 static char *oxprog  = "ox_sm1";  static char *oxprog  = "ox_sm1";
   
 ox_file_t sv;  ox_file_t sv;
   static ox_file_t *svs = NULL;
   static int len_svs = 0;
   static int max_process = 0;
   
 /* Mathematica から直接呼び出される関数の定義. */  /* Mathematica から直接呼び出される関数の定義. */
 /* 呼び出しの方法は math2ox.tm で定義される.   */  /* 呼び出しの方法は math2ox.tm で定義される.   */
 int OX_executeStringByLocalParser(const char *str)  void OX_get()
 {  {
     ox_executeStringByLocalParser(sv, str);      cmo *c = NULL;
   
       receive_ox_tag(sv->stream);
       c = receive_cmo(sv->stream);
   #ifdef DEBUG
       fprintf(stderr, "ox message is received in OxGet[].\n");
       print_cmo(c);
       fflush(stderr);
   #endif
       send_mlo(c);
           ml_flush();
   }
   
   int OX_execute_string(const char *str)
   {
       ox_execute_string(sv, str);
     return 0;      return 0;
 }  }
   
 char *OX_popString()  char *OX_popString()
 {  {
     return ox_popString(sv, sv->stream);      return ox_popString(sv);
 }  }
   
   void OX_popCMO()
   {
       cmo *c = ox_pop_cmo(sv);
       send_mlo(c);
           ml_flush();
   }
   
 int OX_close()  int OX_close()
 {  {
     ox_close(sv);      ox_close(sv);
Line 47  int OX_reset()
Line 73  int OX_reset()
 }  }
   
 /* 文字列 s を parse() にかけて生成された cmo を サーバに送る. */  /* 文字列 s を parse() にかけて生成された cmo を サーバに送る. */
 /* s は "...\n" の形でなければならない(??). */  
 int OX_parse(char *s)  int OX_parse(char *s)
 {  {
     cmo *m;      cmo *m;
         int len = strlen(s);      symbol *symp;
       int len = strlen(s);
     setmode_mygetc(s, len);      setmode_mygetc(s, len);
   
     if(s != NULL && len > 0 && (m = parse()) != NULL) {      if(s != NULL && len > 0 && (m = parse()) != NULL) {
                 /* 本来 m->tag のチェックをして CMO であることを          if (m->tag == OX_DATA) {
            確かめなければならない. */              send_ox_cmo(sv->stream, ((ox_data *)m)->cmo);
                 send_ox_cmo(sv->stream, m);          }else if (m->tag == OX_COMMAND) {
                 return 0;              send_ox_command(sv->stream, ((ox_command *)m)->command);
         }          }else {
         return -1; /* 失敗した場合 */              send_ox_cmo(sv->stream, m);
           }
           return 0;
       }
       return -1; /* 失敗した場合 */
 }  }
   
 int OX_start(char* s)  int OX_start(char* s)
Line 68  int OX_start(char* s)
Line 98  int OX_start(char* s)
     if (s != NULL && s[0] != '\0') {      if (s != NULL && s[0] != '\0') {
         oxprog = s;          oxprog = s;
     }      }
     sv = ox_start(host, ctlserv, oxprog);          if (++max_process < len_svs) {
     fprintf(stderr, "open (%s)\n", "localhost");                  sv = ox_start(host, ctlserv, oxprog);
     return 0;                  fprintf(stderr, "open (%s)\n", "localhost");
                   svs[max_process] = sv;
                   return max_process;
           }
           return -1;
 }  }
   
 int OX_start_insecure(char *host, int portCtl, int portDat)  int OX_start_insecure(char *host, int portCtl, int portDat)
Line 78  int OX_start_insecure(char *host, int portCtl, int por
Line 112  int OX_start_insecure(char *host, int portCtl, int por
     if (host != NULL || host[0] == '\0') {      if (host != NULL || host[0] == '\0') {
         host = "localhost";          host = "localhost";
     }      }
         if (portCtl == 0) {      if (portCtl == 0) {
                 portCtl = 1200;          portCtl = 1200;
         }      }
         if (portDat == 0) {      if (portDat == 0) {
                 portDat = 1300;          portDat = 1300;
         }      }
   
         sv = ox_start_insecure_nonreverse(host, portCtl, portDat);      sv = ox_start_insecure_nonreverse(host, portCtl, portDat);
     fprintf(stderr, "math2ox :: connect to \"%s\" with (ctl, dat) = (%d, %d)\n", host, portCtl, portDat);      fprintf(stderr, "math2ox :: connect to \"%s\" with (ctl, dat) = (%d, %d)\n", host, portCtl, portDat);
   
     return 0;      return 0;
 }  }
   
Line 107  int OX_setClientParam(char *h, char* c, char* p)
Line 142  int OX_setClientParam(char *h, char* c, char* p)
   
 int main(int argc, char *argv[])  int main(int argc, char *argv[])
 {  {
         /* 構文解析器の設定 */      /* 構文解析器の設定 */
         setflag_parse(PFLAG_ADDREV);      setflag_parse(PFLAG_ADDREV);
     setgetc(mygetc);      setgetc(mygetc);
   
           len_svs = 20;
           svs = (ox_file_t *)malloc(sizeof(ox_file_t)*len_svs);
   
     MLMain(argc, argv);      MLMain(argc, argv);
 }  }

Legend:
Removed from v.1.4  
changed lines
  Added in v.1.9

FreeBSD-CVSweb <freebsd-cvsweb@FreeBSD.org>