/* -*- mode: C; coding: euc-japan -*- */ /* $OpenXM: OpenXM/src/ox_math/math2ox.c,v 1.14 2000/03/10 12:38:46 ohara Exp $ */ /* Copyright (C) Katsuyoshi OHARA, 2000. 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 #include #include #include #include #include #include #include #include #include #include "serv2.h" static char *host = "localhost"; static char *ctlserv = "ox"; static char *oxprog = "ox_sm1"; static ox_file_t *ss = NULL; static int len_ss = 0; static int max_process = 0; /* The following functions are called from Mathematica. See math2.tm for detail. */ void OX_get(int id) { cmo *c = NULL; receive_ox_tag(ss[id]->stream); c = receive_cmo(ss[id]->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(int id, const char *str) { ox_execute_string(ss[id], str); return 0; } char *OX_popString(int id) { return ox_popString(ss[id]); } void OX_popCMO(int id) { cmo *c = ox_pop_cmo(ss[id]); send_mlo(c); ml_flush(); } int OX_close(int id) { ox_close(ss[id]); return 0; } int OX_reset(int id) { ox_reset(ss[id]); return 0; } /* Parsing s and sending its cmo to an OX server. */ int OX_parse(int id, char *s) { cmo *m; int len = strlen(s); init_parser(s); if(s != NULL && len > 0 && (m = parse()) != NULL) { if (m->tag == OX_DATA) { send_ox_cmo(ss[id]->stream, ((ox_data *)m)->cmo); }else if (m->tag == OX_COMMAND) { send_ox_command(ss[id]->stream, ((ox_command *)m)->command); }else { send_ox_cmo(ss[id]->stream, m); } return 0; } return -1; /* if we failed. */ } int OX_start(char* s) { if (s != NULL && s[0] != '\0') { oxprog = s; } if (++max_process < len_ss) { ss[max_process] = ox_start(host, ctlserv, oxprog); fprintf(stderr, "open (%s)\n", "localhost"); return max_process; } return -1; } int OX_start_remote_ssh(char *s, char *host) { if (s != NULL && s[0] != '\0') { oxprog = s; } if (host != NULL || host[0] == '\0') { host = "localhost"; } if (++max_process < len_ss) { ss[max_process] = ox_start_remote_with_ssh(oxprog, host); fprintf(stderr, "open (%s)\n", host); return max_process; } return -1; } int OX_start_insecure(char *host, int portCtl, int portDat) { if (host != NULL || host[0] == '\0') { host = "localhost"; } if (portCtl == 0) { portCtl = 1200; } if (portDat == 0) { portDat = 1300; } if (++max_process < len_ss) { ss[max_process] = ox_start_insecure_nonreverse(host, portCtl, portDat); fprintf(stderr, "math2ox :: connect to \"%s\" with (ctl, dat) = (%d, %d)\n", host, portCtl, portDat); return max_process; } return -1; } static char *cp_str(char *src) { char *dest = malloc(strlen(src)+1); strcpy(dest, src); return dest; } int OX_setClientParam(char *h, char* c, char* p) { host = cp_str(h); ctlserv = cp_str(c); oxprog = cp_str(p); return 0; } static ox_file_t *new_sstack(int size) { max_process = 0; len_ss = size; return (ox_file_t *)malloc(sizeof(ox_file_t)*len_ss); } static ox_file_t ss_id(int id) { return ss[id]; } static int ss_id_stream(int id) { return ss[id]->stream; } int main(int argc, char *argv[]) { /* setting the OX parser */ setflag_parse(PFLAG_ADDREV); ss = new_sstack(20); MLMain(argc, argv); }