| version 1.9, 2000/12/05 11:20:26 | version 1.13, 2002/02/24 10:27:20 | 
|  |  | 
| /* $OpenXM: OpenXM/src/kan96xx/plugin/oxmisc2.c,v 1.8 2000/12/03 08:19:55 takayama Exp $ */ | /* $OpenXM: OpenXM/src/kan96xx/plugin/oxmisc2.c,v 1.12 2001/05/04 01:06:30 takayama Exp $ */ | 
| #include <stdio.h> | #include <stdio.h> | 
| #include "ox_kan.h" | #include "ox_kan.h" | 
| #include "oxmisc2.h"   /* This file requires sm1 object description. */ | #include "oxmisc2.h"   /* This file requires sm1 object description. */ | 
| 
| Line 17  int DebugMathCap = 1; |  | 
| Line 17  int DebugMathCap = 1; |  | 
|  |  | 
|  |  | 
| int oxGet(oxclientp client, struct object *op,int *isObj) | int oxGet(oxclientp client, struct object *op,int *isObj) | 
| /* This method should be synchronized. */ | /* This method should be synchronized. */ | 
| /* oxGet is a function for client. */ | /* oxGet is a function for client. */ | 
| { | { | 
| int ans; | int ans; | 
| ox_stream os; | ox_stream os; | 
| 
| Line 88  int oxReq(oxclientp client,int func,struct object ob) |  | 
| Line 88  int oxReq(oxclientp client,int func,struct object ob) |  | 
| /* request to the control channel */ | /* request to the control channel */ | 
| if (func == SM_control_reset_connection || | if (func == SM_control_reset_connection || | 
| func == SM_control_kill) { | func == SM_control_kill) { | 
| AbortIfRFC_101(client); | AbortIfRFC_101(client); | 
| switch(func) { | switch(func) { | 
| case SM_control_reset_connection: | case SM_control_reset_connection: | 
| oxReqControlResetConnection(client->controlfd); | oxReqControlResetConnection(client->controlfd); | 
| 
| Line 135  int oxReq(oxclientp client,int func,struct object ob) |  | 
| Line 135  int oxReq(oxclientp client,int func,struct object ob) |  | 
| break; | break; | 
| case SM_setMathCap: | case SM_setMathCap: | 
| /* ob = [(mathcap-obj) [[version num, system name] [sm tags] | /* ob = [(mathcap-obj) [[version num, system name] [sm tags] | 
| ob1                        smtags | ob1                        smtags | 
| oxtags      [[ox numbers, [cmo numbers]]] | oxtags      [[ox numbers, [cmo numbers]]] | 
| ob3         ob2 */ | ob3         ob2 */ | 
| /*     oxtags      [[OX_DATA, [cmo numbers]],[OX_DATA_LOCAL,[opt]],...]*/ | /*     oxtags      [[OX_DATA, [cmo numbers]],[OX_DATA_LOCAL,[opt]],...]*/ | 
| { | { | 
| struct object ob1; | struct object ob1; | 
| struct object ob2; | struct object ob2; | 
| 
| Line 147  int oxReq(oxclientp client,int func,struct object ob) |  | 
| Line 147  int oxReq(oxclientp client,int func,struct object ob) |  | 
| struct object smtags; | struct object smtags; | 
| struct object oxtags; | struct object oxtags; | 
| struct object ox; | struct object ox; | 
| int n,i; | int n,i; | 
| struct mathCap mathcap; | struct mathCap mathcap; | 
|  |  | 
| if (strcmp(KopString(getoa(ob,0)),"mathcap-object") != 0) { | if (strcmp(KopString(getoa(ob,0)),"mathcap-object") != 0) { | 
| errorOxmisc2("data format error in oxReqSetMathCap"); | errorOxmisc2("data format error in oxReqSetMathCap"); | 
| client->dstate = DSTATE_ANY; | client->dstate = DSTATE_ANY; | 
| break; | break; | 
| } | } | 
| obm = getoa(ob,1); | obm = getoa(ob,1); | 
| ob1 = getoa(obm,0); | ob1 = getoa(obm,0); | 
| smtags = getoa(obm,1); | smtags = getoa(obm,1); | 
| oxtags = getoa(obm,2); | oxtags = getoa(obm,2); | 
| if (smtags.tag != Sarray || oxtags.tag != Sarray) { | if (smtags.tag != Sarray || oxtags.tag != Sarray) { | 
| errorOxmisc2("data format error in oxReqSetMathCap"); | errorOxmisc2("data format error in oxReqSetMathCap"); | 
| } | } | 
| ob1p = (struct object *) sGC_malloc(sizeof(struct object)); | ob1p = (struct object *) sGC_malloc(sizeof(struct object)); | 
| *ob1p = ob1; | *ob1p = ob1; | 
| 
| Line 170  int oxReq(oxclientp client,int func,struct object ob) |  | 
| Line 170  int oxReq(oxclientp client,int func,struct object ob) |  | 
| if (n >= MATHCAP_SIZE) errorOxmisc2("Too big mathcap of your peer."); | if (n >= MATHCAP_SIZE) errorOxmisc2("Too big mathcap of your peer."); | 
| mathcap.oxSize = n; | mathcap.oxSize = n; | 
| for (i=0; i<n; i++) { | for (i=0; i<n; i++) { | 
| ox = getoa(oxtags,i); | ox = getoa(oxtags,i); | 
| if (ox.tag != Sarray) { | if (ox.tag != Sarray) { | 
| errorOxmisc2("Data format error of the third argument of mathcap."); | errorOxmisc2("Data format error of the third argument of mathcap."); | 
| } | } | 
| mathcap.ox[i] = KopInteger(getoa(ox,0)); | mathcap.ox[i] = KopInteger(getoa(ox,0)); | 
| if (mathcap.ox[i] == OX_DATA) { | if (mathcap.ox[i] == OX_DATA) { | 
| if (getoaSize(ox) < 2) { | if (getoaSize(ox) < 2) { | 
| errorOxmisc2("Data format error in an entry of the third argument of mathcap."); | errorOxmisc2("Data format error in an entry of the third argument of mathcap."); | 
| } | } | 
| ob2 = getoa(ox,1); | ob2 = getoa(ox,1); | 
| if (ob2.tag != Sarray) { | if (ob2.tag != Sarray) { | 
| errorOxmisc2("Data format error in an entry of the third argument of mathcap."); | errorOxmisc2("Data format error in an entry of the third argument of mathcap."); | 
| } | } | 
| mathcap.n = getoaSize(ob2); | mathcap.n = getoaSize(ob2); | 
| if (n >= MATHCAP_SIZE) errorOxmisc2("Too big mathcap of your peer."); | if (n >= MATHCAP_SIZE) errorOxmisc2("Too big mathcap of your peer."); | 
| for (i=0; i<mathcap.n; i++) { | for (i=0; i<mathcap.n; i++) { | 
| mathcap.cmo[i] = KopInteger(getoa(ob2,i)); | mathcap.cmo[i] = KopInteger(getoa(ob2,i)); | 
| } | } | 
| } | } | 
| } | } | 
|  |  | 
| n = getoaSize(smtags); | n = getoaSize(smtags); | 
| if (n >= MATHCAP_SIZE) errorOxmisc2("Too big mathcap of your peer."); | if (n >= MATHCAP_SIZE) errorOxmisc2("Too big mathcap of your peer."); | 
| mathcap.smSize = n; | mathcap.smSize = n; | 
| for (i=0; i<n; i++) { | for (i=0; i<n; i++) { | 
| mathcap.sm[i] = KopInteger(getoa(smtags,i)); | mathcap.sm[i] = KopInteger(getoa(smtags,i)); | 
| } | } | 
|  |  | 
| oxReqSetMathCap(client->datafp2,&mathcap); | oxReqSetMathCap(client->datafp2,&mathcap); | 
| 
| Line 264  int oxReq(oxclientp client,int func,struct object ob) |  | 
| Line 264  int oxReq(oxclientp client,int func,struct object ob) |  | 
| } | } | 
|  |  | 
| struct object KoxCreateClient(struct object ip, | struct object KoxCreateClient(struct object ip, | 
| struct object portStream, | struct object portStream, | 
| struct object portControl) | struct object portControl) | 
| { | { | 
| struct object rob; | struct object rob; | 
| oxclientp client; | oxclientp client; | 
| 
| Line 276  struct object KoxCreateClient(struct object ip, |  | 
| Line 276  struct object KoxCreateClient(struct object ip, |  | 
| } | } | 
| if (portStream.tag == Sdollar) { | if (portStream.tag == Sdollar) { | 
| client = oxCreateClientFile(KopString(ip),KopString(portStream), | client = oxCreateClientFile(KopString(ip),KopString(portStream), | 
| "/dev/null","w"); | "/dev/null","w"); | 
| if (client == NULL) { | if (client == NULL) { | 
| errorOxmisc2("KoxCreateClient(): Open error."); | errorOxmisc2("KoxCreateClient(): Open error."); | 
| return(rob); | return(rob); | 
| 
| Line 443  int oxObjectToClient(struct object ob,oxclientp cp) |  | 
| Line 443  int oxObjectToClient(struct object ob,oxclientp cp) |  | 
| } | } | 
|  |  | 
| struct object KoxReq(struct object client, | struct object KoxReq(struct object client, | 
| struct object func, | struct object func, | 
| struct object ob1) | struct object ob1) | 
| { | { | 
| int ans; | int ans; | 
| static oxclientp cc1 = NULL; | static oxclientp cc1 = NULL; | 
| 
| Line 560  struct object KoxMultiSelect(struct object oclients,st |  | 
| Line 560  struct object KoxMultiSelect(struct object oclients,st |  | 
| if (first) { | if (first) { | 
| first = 0; csize = size; | first = 0; csize = size; | 
| clients = (oxclientp *)mymalloc(sizeof(oxclientp)*(size+1)); | clients = (oxclientp *)mymalloc(sizeof(oxclientp)*(size+1)); | 
| if (clients == NULL) { | if (clients == NULL) { | 
| errorOxmisc2("KoxMultiSelect(): no more memory."); | errorOxmisc2("KoxMultiSelect(): no more memory."); | 
| return(rob); | return(rob); | 
| } | } | 
| for (i=0; i<size; i++) { | for (i=0; i<size; i++) { | 
| clients[i] =  (oxclientp) mymalloc(sizeof(oxclient)); | clients[i] =  (oxclientp) mymalloc(sizeof(oxclient)); | 
| if (clients[i] == NULL) { | if (clients[i] == NULL) { | 
| errorOxmisc2("KoxMultiSelect(): no more memory."); | errorOxmisc2("KoxMultiSelect(): no more memory."); | 
| return(rob); | return(rob); | 
| } | } | 
| oxInitClient(clients[i]); | oxInitClient(clients[i]); | 
| } | } | 
| 
| Line 606  struct object KoxMultiSelect(struct object oclients,st |  | 
| Line 606  struct object KoxMultiSelect(struct object oclients,st |  | 
| } | } | 
|  |  | 
| struct object KoxWatch(struct object client,struct object f) | struct object KoxWatch(struct object client,struct object f) | 
| /* f is not used for now. It should be log file. */ | /* f is not used for now. It should be log file. */ | 
| { | { | 
| int ans,k; | int ans,k; | 
| static oxclientp cc1 = NULL; | static oxclientp cc1 = NULL; | 
| 
| Line 614  struct object KoxWatch(struct object client,struct obj |  | 
| Line 614  struct object KoxWatch(struct object client,struct obj |  | 
| extern int WatchStream; | extern int WatchStream; | 
| rob.tag = Snull; | rob.tag = Snull; | 
| if (client.tag == Sinteger) { | if (client.tag == Sinteger) { | 
| if (KopInteger(client)) { | if (KopInteger(client)) { | 
| WatchStream = 1; | WatchStream = 1; | 
| }else{ | }else{ | 
| WatchStream = 0; | WatchStream = 0; | 
| } | } | 
| return; | return; | 
| } | } | 
| if (cc1 == NULL) { | if (cc1 == NULL) { | 
| cc1 = (oxclientp) mymalloc(sizeof(oxclient)); | cc1 = (oxclientp) mymalloc(sizeof(oxclient)); | 
| 
| Line 685  static int cmoCheck00(struct object obj,int cmo[], int |  | 
| Line 685  static int cmoCheck00(struct object obj,int cmo[], int |  | 
| static int typeTrans[CHECK00_N]; | static int typeTrans[CHECK00_N]; | 
| static int init = 0; | static int init = 0; | 
| /* if n == 0, report the cmo tag of the object obj. | /* if n == 0, report the cmo tag of the object obj. | 
| If it cannot be translated to cmo, then return -1. */ | If it cannot be translated to cmo, then return -1. */ | 
|  |  | 
| if (!init) { | if (!init) { | 
| for (i=0; i<CHECK00_N; i++) { | for (i=0; i<CHECK00_N; i++) { | 
| 
| Line 717  static int cmoCheck00(struct object obj,int cmo[], int |  | 
| Line 717  static int cmoCheck00(struct object obj,int cmo[], int |  | 
| } | } | 
| /* Only report the cmo tag. */ | /* Only report the cmo tag. */ | 
| if (n == 0) { | if (n == 0) { | 
| if (ttt == 0) return(-1); | if (ttt == 0) return(-1); | 
| else return(ttt); | else return(ttt); | 
| } | } | 
|  |  | 
| for (i=0; i<n; i++) { | for (i=0; i<n; i++) { | 
| if (ttt == cmo[i]) { | if (ttt == cmo[i]) { | 
| if (ttt != CMO_LIST) return(1); | if (ttt != CMO_LIST) return(1); | 
| else { | else { | 
| m = getoaSize(obj); | m = getoaSize(obj); | 
| for (j=0; j<m; j++) { | for (j=0; j<m; j++) { | 
| if (!cmoCheck00(getoa(obj,j),cmo,n)) return(0); | if (!cmoCheck00(getoa(obj,j),cmo,n)) return(0); | 
| } | } | 
| return(1); | return(1); | 
| } | } | 
| } | } | 
| } | } | 
| 
| Line 737  static int cmoCheck00(struct object obj,int cmo[], int |  | 
| Line 737  static int cmoCheck00(struct object obj,int cmo[], int |  | 
| if (DebugMathCap && 1) { | if (DebugMathCap && 1) { | 
| fprintf(stderr,"Type translation table (internal object tag --> CMO tag)\n"); | fprintf(stderr,"Type translation table (internal object tag --> CMO tag)\n"); | 
| for (i=0; i<20; i++) { | for (i=0; i<20; i++) { | 
| printf("%d ", typeTrans[i]); | printf("%d ", typeTrans[i]); | 
| } | } | 
| printf("\n"); | printf("\n"); | 
| } | } | 
| 
| Line 776  int cmoCheckMathCap(struct object obj, struct object * |  | 
| Line 776  int cmoCheckMathCap(struct object obj, struct object * |  | 
| } | } | 
| mathcap = *obp; | mathcap = *obp; | 
| /* Example of mathcap | /* Example of mathcap | 
| [    $mathcap-object$ , | [    $mathcap-object$ , | 
| [    [    199909080 , $Ox_system=ox_sm1.plain$ , $Version=2.991106$ , | [    [    199909080 , $Ox_system=ox_sm1.plain$ , $Version=2.991106$ , | 
| $HOSTTYPE=i386$ ]  , | $HOSTTYPE=i386$ ]  , | 
| [    262 , 263 , 264 , 265 , 266 , 268 , 269 , 272 , 273 , 275 , | [    262 , 263 , 264 , 265 , 266 , 268 , 269 , 272 , 273 , 275 , | 
| 276 ]  , | 276 ]  , | 
| [    [    514  , [    2130706434 , 1 , 2 , 4 , 5 , 17 , 19 , 20 , 22 , 23 , 24 , 25 , 26 , 30 , 31 , 60 , 61 , 27 , 33 , 40 , 16 , 34 ] ] ]  ]  ] | [    [    514  , [    2130706434 , 1 , 2 , 4 , 5 , 17 , 19 , 20 , 22 , 23 , 24 , 25 , 26 , 30 , 31 , 60 , 61 , 27 , 33 , 40 , 16 , 34 ] ] ]  ]  ] | 
| */ | */ | 
|  |  | 
| n = getoaSize(mathcap); | n = getoaSize(mathcap); | 
| 
| Line 806  int cmoCheckMathCap(struct object obj, struct object * |  | 
| Line 806  int cmoCheckMathCap(struct object obj, struct object * |  | 
| } | } | 
|  |  | 
| /* I should check | /* I should check | 
| getoa(getoa(mathcap,1),2) | getoa(getoa(mathcap,1),2) | 
| contains OX_DATA. | contains OX_DATA. | 
| It has not yet implemented. | It has not yet implemented. | 
| */ | */ | 
| 
| Line 836  int cmoCheckMathCap(struct object obj, struct object * |  | 
| Line 836  int cmoCheckMathCap(struct object obj, struct object * |  | 
| if (getoaSize(ox) != 0) { | if (getoaSize(ox) != 0) { | 
| oxtag = getoa(ox,0); | oxtag = getoa(ox,0); | 
| if (oxtag.tag != Sinteger) { | if (oxtag.tag != Sinteger) { | 
| fprintf(stderr,"cmoCheckMathCap: the mathcap obj is \n"); | fprintf(stderr,"cmoCheckMathCap: the mathcap obj is \n"); | 
| printObject(*obp,0,stderr); | printObject(*obp,0,stderr); | 
| fprintf(stderr,"\n"); | fprintf(stderr,"\n"); | 
| errorOxmisc2("cmoCheckMathCap: the third element of mathcap must be [OX_DATA_xxx, [  ]]."); | errorOxmisc2("cmoCheckMathCap: the third element of mathcap must be [OX_DATA_xxx, [  ]]."); | 
| } | } | 
| if (KopInteger(oxtag) == OX_DATA) { | if (KopInteger(oxtag) == OX_DATA) { | 
| if (getoaSize(ox) > 1) { | if (getoaSize(ox) > 1) { | 
| cmolist = getoa(ox,1); | cmolist = getoa(ox,1); | 
| if (cmolist.tag != Sarray) { | if (cmolist.tag != Sarray) { | 
| fprintf(stderr,"cmoCheckMathCap: the mathcap obj is \n"); | fprintf(stderr,"cmoCheckMathCap: the mathcap obj is \n"); | 
| printObject(*obp,0,stderr); | printObject(*obp,0,stderr); | 
| fprintf(stderr,"\n"); | fprintf(stderr,"\n"); | 
| errorOxmisc2("cmoCheckMathCap: mathcap[1] must be an array of integers.\n"); | errorOxmisc2("cmoCheckMathCap: mathcap[1] must be an array of integers.\n"); | 
| } | } | 
| n = getoaSize(cmolist); | n = getoaSize(cmolist); | 
| if (n > CMO_CHECK_MATH_CAP_LIST_SIZE) { | if (n > CMO_CHECK_MATH_CAP_LIST_SIZE) { | 
| errorOxmisc2("cmoCheckMathCap: Too big cmo list.\n"); | errorOxmisc2("cmoCheckMathCap: Too big cmo list.\n"); | 
| } | } | 
| for (i=0; i<n; i++) { | for (i=0; i<n; i++) { | 
| cmo[i] = KopInteger(getoa(cmolist,i)); | cmo[i] = KopInteger(getoa(cmolist,i)); | 
| } | } | 
| }else{ | }else{ | 
| fprintf(stderr,"cmoCheckMathCap: the mathcap obj is \n"); | fprintf(stderr,"cmoCheckMathCap: the mathcap obj is \n"); | 
| printObject(*obp,0,stderr); | printObject(*obp,0,stderr); | 
| fprintf(stderr,"\nox="); | fprintf(stderr,"\nox="); | 
| printObject(ox,0,stderr); | printObject(ox,0,stderr); | 
| errorOxmisc2("cmoCheckMathCap: [OX_DATA, cmolist]"); | errorOxmisc2("cmoCheckMathCap: [OX_DATA, cmolist]"); | 
| } | } | 
| } | } | 
| } | } | 
| } | } | 
| return(cmoCheck00(obj,cmo,n)); | return(cmoCheck00(obj,cmo,n)); | 
| } | } | 
|  |  | 
|  |  | 
| struct object KoxGenPortFile(void) { | struct object KoxGenPortFile(void) { | 
| struct object ob; | struct object ob; | 
| ob = KpoString(oxGenPortFile()); | ob = KpoString(oxGenPortFile()); | 
| 
| Line 917  struct object KoxGetPort(struct object host) |  | 
| Line 917  struct object KoxGetPort(struct object host) |  | 
| putoa(rob,3,KpoInteger(portControl)); | putoa(rob,3,KpoInteger(portControl)); | 
| return(rob); | return(rob); | 
| } | } | 
|  | struct object KoxGetPort1(struct object host) | 
|  | { | 
|  | struct object rob; | 
|  | int fdStream; | 
|  | int portStream; | 
|  | extern int OpenedSocket; | 
|  | char *sname; | 
|  | rob = NullObject; | 
|  | if (host.tag != Sdollar) { | 
|  | errorOxmisc2("KoxGetPort1: argument is not a string."); | 
|  | return(rob); | 
|  | } | 
|  | sname = KopString(host); | 
|  | fdStream = socketOpen(sname,0); | 
|  | portStream = OpenedSocket; | 
|  | rob = newObjectArray(2); | 
|  | putoa(rob,0,KpoInteger(fdStream)); | 
|  | putoa(rob,1,KpoInteger(portStream)); | 
|  | return(rob); | 
|  | } | 
|  |  | 
| struct object KoxCreateClient2(struct object peer, | struct object KoxCreateClient2(struct object peer, | 
| struct object ipmask, | struct object ipmask, | 
| struct object pass) | struct object pass) | 
| { | { | 
| struct object rob; | struct object rob; | 
| oxclientp client; | oxclientp client; | 
| 
| Line 955  struct object KoxCreateClient2(struct object peer, |  | 
| Line 975  struct object KoxCreateClient2(struct object peer, |  | 
| } | } | 
|  |  | 
| client = oxCreateClient2(fdStream, portStream, fdControl, portControl, | client = oxCreateClient2(fdStream, portStream, fdControl, portControl, | 
| KopInteger(ipmask), KopString(pass)); | KopInteger(ipmask), KopString(pass)); | 
| if (client == NULL) { | if (client == NULL) { | 
| errorOxmisc2("KoxCreateClient2(): Open error."); | errorOxmisc2("KoxCreateClient2(): Open error."); | 
| return(rob); | return(rob); | 
| 
| Line 1035  struct object KoxPushCMO(struct object client,struct o |  | 
| Line 1055  struct object KoxPushCMO(struct object client,struct o |  | 
| } | } | 
|  |  | 
| if (!cmoCheckMathCap(ob,(struct object *)cc1->mathcapObjp)) { | if (!cmoCheckMathCap(ob,(struct object *)cc1->mathcapObjp)) { | 
| errorOxmisc2("oxPushCMO: your peer does not understand this cmo.\n"); | errorOxmisc2("oxPushCMO: your peer does not understand this cmo.\n"); | 
| return(rob); | return(rob); | 
| } | } | 
| oxSendOXheader(cc1->datafp2,OX_DATA,SerialOX++); | oxSendOXheader(cc1->datafp2,OX_DATA,SerialOX++); | 
| cmoObjectToStream2(ob,cc1->datafp2); | cmoObjectToStream2(ob,cc1->datafp2); | 
| 
| Line 1045  struct object KoxPushCMO(struct object client,struct o |  | 
| Line 1065  struct object KoxPushCMO(struct object client,struct o |  | 
| return(ob); | return(ob); | 
| } | } | 
|  |  | 
| /* ------------- TODO ----------------- */ |  | 
| oxclientp oxCreateControl_RFC_101(int fdstream,int portStream, | oxclientp oxCreateControl_RFC_101(int fdstream,int portStream, | 
| int ipmask,char *pass); | int ipmask,char *pass); | 
| struct object KoxCreateControl_RFC_101(struct object peer,struct object ipmask,struct object pass) | struct object KoxCreateControl_RFC_101(struct object peer,struct object ipmask,struct object pass) | 
| { | { | 
| struct object rob; | struct object rob; | 
| 
| Line 1081  struct object KoxCreateControl_RFC_101(struct object p |  | 
| Line 1100  struct object KoxCreateControl_RFC_101(struct object p |  | 
| } | } | 
|  |  | 
| client = oxCreateControl_RFC_101(fdStream, portStream, | client = oxCreateControl_RFC_101(fdStream, portStream, | 
| KopInteger(ipmask), KopString(pass)); | KopInteger(ipmask), KopString(pass)); | 
| if (client == NULL) { | if (client == NULL) { | 
| errorOxmisc2("KoxCreateControl_RFC_101(): Open error."); | errorOxmisc2("KoxCreateControl_RFC_101(): Open error."); | 
| return(rob); | return(rob); | 
| 
| Line 1092  struct object KoxCreateControl_RFC_101(struct object p |  | 
| Line 1111  struct object KoxCreateControl_RFC_101(struct object p |  | 
| } | } | 
|  |  | 
| oxclientp oxCreateControl_RFC_101(int fdstream,int portStream, | oxclientp oxCreateControl_RFC_101(int fdstream,int portStream, | 
| int ipmask,char *pass) | int ipmask,char *pass) | 
| { | { | 
| static int clnum = 0; | static int clnum = 0; | 
| int v = 0; | int v = 0; | 
| 
| Line 1102  oxclientp oxCreateControl_RFC_101(int fdstream,int por |  | 
| Line 1121  oxclientp oxCreateControl_RFC_101(int fdstream,int por |  | 
|  |  | 
| char *s; | char *s; | 
| oxclientp client; | oxclientp client; | 
| extern jmp_buf MyEnv_oxmisc ; | #if defined(__CYGWIN__) | 
|  | extern sigjmp_buf MyEnv_oxmisc; | 
|  | #else | 
|  | extern jmp_buf MyEnv_oxmisc; | 
|  | #endif | 
| int engineByteOrder; | int engineByteOrder; | 
| extern int Quiet; | extern int Quiet; | 
|  |  | 
| 
| Line 1136  oxclientp oxCreateControl_RFC_101(int fdstream,int por |  | 
| Line 1159  oxclientp oxCreateControl_RFC_101(int fdstream,int por |  | 
|  |  | 
| engineByteOrder = oxSetByteOrder(fdStream); | engineByteOrder = oxSetByteOrder(fdStream); | 
| if (v) fprintf(stderr,"Byte order for control stackmacine is %s.\n", | if (v) fprintf(stderr,"Byte order for control stackmacine is %s.\n", | 
| (engineByteOrder == 0? "network byte order": | (engineByteOrder == 0? "network byte order": | 
| (engineByteOrder == 1? "little indican": | (engineByteOrder == 1? "little indican": | 
| "big indian"))); | "big indian"))); | 
|  |  | 
|  |  | 
| client = (oxclientp) mymalloc(sizeof(oxclient)); | client = (oxclientp) mymalloc(sizeof(oxclient)); | 
| 
| Line 1152  oxclientp oxCreateControl_RFC_101(int fdstream,int por |  | 
| Line 1175  oxclientp oxCreateControl_RFC_101(int fdstream,int por |  | 
| client->controlport = -1; | client->controlport = -1; | 
| client->controlfd = -1; | client->controlfd = -1; | 
| client->id = clnum; clnum++; | client->id = clnum; clnum++; | 
|  | client->type = CLIENT_SOCKET; /* socket */ | 
|  | client->engineByteOrder = engineByteOrder; | 
|  | client->controlByteOrder = -1; | 
|  | return(client); | 
|  | } | 
|  |  | 
|  | oxclientp oxCreateEngine_RFC_101(int fdstream,int portStream, | 
|  | int ipmask,char *pass, int engineID); | 
|  | struct object KoxCreateEngine_RFC_101(struct object peer,struct object ipmask,struct object pass, struct object engineID) | 
|  | { | 
|  | struct object rob; | 
|  | oxclientp client; | 
|  | int fdStream, portStream; | 
|  | int i; | 
|  | struct object ob1; | 
|  | rob.tag = Snull; | 
|  | if (peer.tag != Sarray) { | 
|  | errorOxmisc2("KoxCreateEngine_RFC_101(): The first argument must be an array [fdStream, portStream]"); | 
|  | return(rob); | 
|  | } | 
|  | if (getoaSize(peer) != 2 ) { | 
|  | errorOxmisc2("KoxCreateEngine_RFC_101(): The first argument must be an array [fdStream, portStream] of size 2."); | 
|  | return(rob); | 
|  | } | 
|  | for (i=0; i<getoaSize(peer); i++) { | 
|  | ob1 = getoa(peer,i); | 
|  | if (ob1.tag != Sinteger) { | 
|  | errorOxmisc2("KoxCreateEngine_RFC_101(): The element of the first argument must be an integer."); | 
|  | } | 
|  | } | 
|  | fdStream = KopInteger(getoa(peer,0)); | 
|  | portStream = KopInteger(getoa(peer,1)); | 
|  |  | 
|  | if (ipmask.tag != Sinteger) { | 
|  | errorOxmisc2("KoxCreateEngine_RFC_101(): ipmask must be an integer."); | 
|  | } | 
|  | if (pass.tag != Sdollar) { | 
|  | errorOxmisc2("KoxCreateEngine_RFC_101(): pass must be a string."); | 
|  | } | 
|  | if (engineID.tag != Sinteger) { | 
|  | errorOxmisc2("KoxCreateEngine_RFC_101(): engineID must be an integer."); | 
|  | } | 
|  |  | 
|  | client = oxCreateEngine_RFC_101(fdStream, portStream, | 
|  | KopInteger(ipmask), KopString(pass),KopInteger(engineID)); | 
|  | if (client == NULL) { | 
|  | errorOxmisc2("KoxCreateEngine_RFC_101(): Open error."); | 
|  | return(rob); | 
|  | } | 
|  | rob = newObjectArray(N_OF_CLIENT_FIELDS); | 
|  | oxClientToObject(client,rob); | 
|  | return(rob); | 
|  | } | 
|  |  | 
|  | oxclientp oxCreateEngine_RFC_101(int fdstream,int portStream, | 
|  | int ipmask,char *pass,int engineID) | 
|  | { | 
|  | int v = 0; | 
|  | int fdControl = -1; | 
|  | int fdStream = -1; | 
|  | int m; | 
|  |  | 
|  | char *s; | 
|  | oxclientp client; | 
|  | #if defined(__CYGWIN__) | 
|  | extern sigjmp_buf MyEnv_oxmisc; | 
|  | #else | 
|  | extern jmp_buf MyEnv_oxmisc; | 
|  | #endif | 
|  | int engineByteOrder; | 
|  | extern int Quiet; | 
|  |  | 
|  | v = !Quiet; | 
|  |  | 
|  | switch(ipmask) { | 
|  | case 0:/* only local */ | 
|  | fdStream  = socketAcceptLocal(fdstream); | 
|  | break; | 
|  | default:/* any */ | 
|  | fdStream  = socketAccept(fdstream); | 
|  | break; | 
|  | } | 
|  | if (v) fprintf(stderr,"\nEngine port %d : Connected.\n",portStream); | 
|  |  | 
|  | if (fdStream == -1 ) { | 
|  | fprintf(stderr,"\nOpen error in oxCreateEngine_RFC_101.\n"); | 
|  | return(NULL); | 
|  | } | 
|  |  | 
|  | /* Authentication by password. */ | 
|  | /*  skip password check for now. BUG. | 
|  | m = strlen(pass); | 
|  | s = (char *)mymalloc(sizeof(char)*(m+1)); | 
|  | read(fdStream,s,m+1); s[m] = '\0'; | 
|  | if (strcmp(s,pass) != 0) { | 
|  | fprintf(stderr,"oxCreateEngine_RFC_101(): password authentication failed for control channel.\n"); | 
|  | close(fdStream); | 
|  | return(NULL); | 
|  | } | 
|  | */ | 
|  |  | 
|  | engineByteOrder = oxSetByteOrder(fdStream); | 
|  | if (v) fprintf(stderr,"Byte order for engine stackmacine is %s.\n", | 
|  | (engineByteOrder == 0? "network byte order": | 
|  | (engineByteOrder == 1? "little indican": | 
|  | "big indian"))); | 
|  |  | 
|  |  | 
|  | client = (oxclientp) mymalloc(sizeof(oxclient)); | 
|  | oxInitClient(client); | 
|  | client->datafp2 = fp2open(fdStream); | 
|  | if (client->datafp2 == NULL) { | 
|  | fprintf(stderr,"oxCreateEngine_RFC_101(): fp2open(fd) failed.\n"); | 
|  | return(NULL); | 
|  | } | 
|  | client->dataport = portStream; | 
|  | client->controlport = -1; | 
|  | client->controlfd = -1; | 
|  | client->id = engineID; | 
| client->type = CLIENT_SOCKET; /* socket */ | client->type = CLIENT_SOCKET; /* socket */ | 
| client->engineByteOrder = engineByteOrder; | client->engineByteOrder = engineByteOrder; | 
| client->controlByteOrder = -1; | client->controlByteOrder = -1; |