[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.11 and 1.24

version 1.11, 2000/01/20 15:32:21 version 1.24, 2005/07/26 12:52:04
Line 1 
Line 1 
 /* -*- mode: C; coding: euc-japan -*- */  /* -*- mode: C; coding: euc-japan -*- */
 /* $OpenXM: OpenXM/src/ox_math/math2ox.c,v 1.10 1999/12/22 11:27:59 ohara Exp $ */  /* $OpenXM: OpenXM/src/ox_math/math2ox.c,v 1.23 2005/07/20 17:48:03 ohara Exp $ */
   
 /*  /*
    Some commnets is written in Japanese by the EUC-JP coded     Copyright (C) Katsuyoshi OHARA, 2000.
    character set.     Portions copyright 1999 Wolfram Research, Inc.
   
      You must see OpenXM/Copyright/Copyright.generic.
      The MathLink Library is licensed from Wolfram Research Inc..
      See OpenXM/Copyright/Copyright.mathlink for detail.
 */  */
   
 #include <sys/types.h>  #include <sys/types.h>
Line 16 
Line 20 
 #include <unistd.h>  #include <unistd.h>
 #include <signal.h>  #include <signal.h>
 #include <mathlink.h>  #include <mathlink.h>
   #include <ox_toolkit.h>
   
 #include "ox.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;  static OXFILE **ss = NULL;
 static ox_file_t *svs = NULL;  static int len_ss = 0;
 static int len_svs = 0;  
 static int max_process = 0;  static int max_process = 0;
   
 /* Mathematica から直接呼び出される関数の定義. */  /* The following functions are called from Mathematica.
 /* 呼び出しの方法は math2ox.tm で定義される.   */     See math2.tm for detail. */
 void OX_get()  void OX_get(int id)
 {  {
     cmo *c = NULL;      cmo *c = NULL;
   
     receive_ox_tag(sv->stream);      receive_ox_tag(ss[id]);
     c = receive_cmo(sv->stream);      c = receive_cmo(ss[id]);
 #ifdef DEBUG      ox_printf("ox message is received in OxGet[].\n");
     fprintf(stderr, "ox message is received in OxGet[].\n");  
     print_cmo(c);      print_cmo(c);
     fflush(stderr);  
 #endif  
     send_mlo(c);      send_mlo(c);
         ml_flush();          ml_flush();
 }  }
   
 int OX_execute_string(const char *str)  int OX_execute_string(int id, const char *str)
 {  {
     ox_execute_string(sv, str);      ox_execute_string(ss[id], str);
     return 0;      return 0;
 }  }
   
 char *OX_popString()  char *OX_popString(int id)
 {  {
     return ox_popString(sv);      return ox_popString(ss[id]);
 }  }
   
 void OX_popCMO()  void OX_popCMO(int id)
 {  {
     cmo *c = ox_pop_cmo(sv);      cmo *c = ox_pop_cmo(ss[id]);
     send_mlo(c);      send_mlo(c);
         ml_flush();          ml_flush();
 }  }
   
 int OX_close()  int OX_close(int id)
 {  {
     ox_close(sv);      ox_close(ss[id]);
     return 0;      return 0;
 }  }
   
 int OX_reset()  int OX_reset(int id)
 {  {
     ox_reset(sv);      ox_reset(ss[id]);
     return 0;      return 0;
 }  }
   
 /* 文字列 s を parse() にかけて生成された cmo を サーバに送る. */  /* This function is compatible with previous version of math2ox. */
 int OX_parse(char *s)  /* Parsing s and sending its cmo to an OX server. */
   int OX_parse(int id, char *s)
 {  {
     cmo *m;          return OX_sendMessage(id, s);
     symbol *symp;  }
     int len = strlen(s);  
     init_parser(s);  
   
     if(s != NULL && len > 0 && (m = parse()) != NULL) {  /* After creating an OX message by parsing a string s,
         if (m->tag == OX_DATA) {     the function send the message to the OX server id. */
             send_ox_cmo(sv->stream, ((ox_data *)m)->cmo);  int OX_sendMessage(int id, char *s)
         }else if (m->tag == OX_COMMAND) {  {
             send_ox_command(sv->stream, ((ox_command *)m)->command);      cmo *m = ox_parse_lisp(s);
         }else {      if(m != NULL) {
             send_ox_cmo(sv->stream, m);          send_ox(ss[id], m);
         }  
         return 0;          return 0;
     }      }
     return -1; /* 失敗した場合 */      return -1; /* if we failed. */
 }  }
   
 int OX_start(char* s)  int OX_start(char* s)
Line 103  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;
     }      }
         if (++max_process < len_svs) {          if (++max_process < len_ss) {
                 sv = ox_start(host, ctlserv, oxprog);                  ss[max_process] = ox_start(host, ctlserv, oxprog);
                 fprintf(stderr, "open (%s)\n", "localhost");                  ox_printf("open (%s)\n", "localhost");
                 svs[max_process] = sv;  
                 return max_process;                  return max_process;
         }          }
         return -1;          return -1;
Line 120  int OX_start_remote_ssh(char *s, char *host)
Line 114  int OX_start_remote_ssh(char *s, char *host)
     if (host != NULL || host[0] == '\0') {      if (host != NULL || host[0] == '\0') {
         host = "localhost";          host = "localhost";
     }      }
         if (++max_process < len_svs) {          if (++max_process < len_ss) {
                 sv = ox_start_remote_with_ssh(oxprog, host);                  ss[max_process] = ox_start_remote_with_ssh(oxprog, host);
                 fprintf(stderr, "open (%s)\n", host);                  ox_printf("open (%s)\n", host);
                 svs[max_process] = sv;  
                 return max_process;                  return max_process;
         }          }
     return -1;      return -1;
Line 141  int OX_start_insecure(char *host, int portCtl, int por
Line 134  int OX_start_insecure(char *host, int portCtl, int por
         portDat = 1300;          portDat = 1300;
     }      }
   
     sv = ox_start_insecure_nonreverse(host, portCtl, portDat);          if (++max_process < len_ss) {
     fprintf(stderr, "math2ox :: connect to \"%s\" with (ctl, dat) = (%d, %d)\n", host, portCtl, portDat);                  ss[max_process] = ox_start_insecure(host, portCtl, portDat);
                   ox_printf("math2ox :: connect to \"%s\" with (ctl, dat) = (%d, %d)\n", host, portCtl, portDat);
                   return max_process;
           }
   
     return 0;      return -1;
 }  }
   
 static char *cp_str(char *src)  static char *cp_str(char *src)
Line 162  int OX_setClientParam(char *h, char* c, char* p)
Line 158  int OX_setClientParam(char *h, char* c, char* p)
     return 0;      return 0;
 }  }
   
   static OXFILE **new_sstack(int size)
   {
           max_process = 0;
           len_ss = size;
           return (OXFILE **)malloc(sizeof(OXFILE *)*len_ss);
   }
   
   static OXFILE *ss_id(int id)
   {
           return ss[id];
   }
   
   static int  ss_id_stream(int id)
   {
           return ss[id];
   }
   
   #define VERSION "2000/11/29"
   
 int main(int argc, char *argv[])  int main(int argc, char *argv[])
 {  {
     /* 構文解析器の設定 */      ox_stderr_init(NULL);
     setflag_parse(PFLAG_ADDREV);  
         len_svs = 20;      ss = new_sstack(20);
         svs = (ox_file_t *)malloc(sizeof(ox_file_t)*len_svs);      mathcap_init(VERSION, "math2ox");
   
     MLMain(argc, argv);      MLMain(argc, argv);
 }  }

Legend:
Removed from v.1.11  
changed lines
  Added in v.1.24

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