=================================================================== RCS file: /home/cvs/OpenXM/src/kan96xx/plugin/oxmisc2.c,v retrieving revision 1.6 retrieving revision 1.11 diff -u -p -r1.6 -r1.11 --- OpenXM/src/kan96xx/plugin/oxmisc2.c 2000/03/20 01:53:47 1.6 +++ OpenXM/src/kan96xx/plugin/oxmisc2.c 2000/12/06 00:29:52 1.11 @@ -1,8 +1,9 @@ -/* $OpenXM: OpenXM/src/kan96xx/plugin/oxmisc2.c,v 1.5 2000/02/02 03:30:48 takayama Exp $ */ +/* $OpenXM: OpenXM/src/kan96xx/plugin/oxmisc2.c,v 1.10 2000/12/05 12:03:43 takayama Exp $ */ #include #include "ox_kan.h" #include "oxmisc2.h" /* This file requires sm1 object description. */ #include "cmo.h" + extern FILE *MyErrorOut; #define SET_MYERROROUT { if (MyErrorOut == NULL) MyErrorOut=stdout; } /* It is also defined in oxmisc.c */ @@ -71,6 +72,7 @@ int oxGet(oxclientp client, struct object *op,int *isO int oxGetFromControl(oxclientp client) { int ans = -1; + AbortIfRFC_101(client); if (client->cstate != -1) { ans = oxGetResultOfControlInt32(client->controlfd); if (ans != -1) { client->cstate = 0; } @@ -86,10 +88,11 @@ int oxReq(oxclientp client,int func,struct object ob) /* request to the control channel */ if (func == SM_control_reset_connection || func == SM_control_kill) { + AbortIfRFC_101(client); switch(func) { case SM_control_reset_connection: oxReqControlResetConnection(client->controlfd); - client->cstate = 1; + client->cstate = 0; client->dstate = DSTATE_FIRST_SYNC; break; case SM_control_kill: @@ -914,6 +917,26 @@ struct object KoxGetPort(struct object host) putoa(rob,3,KpoInteger(portControl)); 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 ipmask, @@ -972,4 +995,299 @@ errorOxmisc2(char *s) { SET_MYERROROUT; fprintf(MyErrorOut,"error in oxmisc2.c: %s\n",s); errorKan1("%s\n"," "); +} + +struct object KoxPushCMD(struct object client,struct object cmd) { + int ans; + static oxclientp cc1 = NULL; + struct object rob; + rob.tag = Snull; + if (cc1 == NULL) { + cc1 = (oxclientp) mymalloc(sizeof(oxclient)); + if (cc1 == NULL) { + errorOxmisc2("KoxReq(): no more memory."); + return(rob); + } + oxInitClient(cc1); /* BUG: is it fine? */ + } + + if (oxObjectToClient(client,cc1) == -1) return(rob); + if (cc1 == NULL) { + errorOxmisc2("KoxReq(): the first argument must be a client object."); + return(rob); + } + if (cmd.tag != Sinteger) { + errorOxmisc2("KoxReq(): the second argument must be an integer."); + return(rob); + } + /* BUG: check the mathcap */ + oxSendOXheader(cc1->datafp2,OX_COMMAND,SerialOX++); + oxSendInt32(cc1->datafp2,KopInteger(cmd)); + /* synchronize cc1 and client. */ + oxClientToObject(cc1,client); + return(cmd); +} + +struct object KoxPushCMO(struct object client,struct object ob) { + int ans; + static oxclientp cc1 = NULL; + struct object rob; + rob.tag = Snull; + if (cc1 == NULL) { + cc1 = (oxclientp) mymalloc(sizeof(oxclient)); + if (cc1 == NULL) { + errorOxmisc2("KoxReq(): no more memory."); + return(rob); + } + oxInitClient(cc1); /* BUG: is it fine? */ + } + + if (oxObjectToClient(client,cc1) == -1) return(rob); + if (cc1 == NULL) { + errorOxmisc2("KoxReq(): the first argument must be a client object."); + return(rob); + } + + /* request to the data channel */ + if (cc1->dstate != DSTATE_ANY) { + errorOxmisc2("oxPushCMO: cc1->dstate != DSTATE_ANY, data channel is not ready to send data.\n"); + return(rob); + } + + if (!cmoCheckMathCap(ob,(struct object *)cc1->mathcapObjp)) { + errorOxmisc2("oxPushCMO: your peer does not understand this cmo.\n"); + return(rob); + } + oxSendOXheader(cc1->datafp2,OX_DATA,SerialOX++); + cmoObjectToStream2(ob,cc1->datafp2); + /* synchronize cc1 and client. */ + oxClientToObject(cc1,client); + return(ob); +} + +oxclientp oxCreateControl_RFC_101(int fdstream,int portStream, + int ipmask,char *pass); +struct object KoxCreateControl_RFC_101(struct object peer,struct object ipmask,struct object pass) +{ + struct object rob; + oxclientp client; + int fdStream, portStream; + int i; + struct object ob1; + rob.tag = Snull; + if (peer.tag != Sarray) { + errorOxmisc2("KoxCreateControl_RFC_101(): The first argument must be an array [fdStream, portStream]"); + return(rob); + } + if (getoaSize(peer) != 2 ) { + errorOxmisc2("KoxCreateControl_RFC_101(): The first argument must be an array [fdStream, portStream] of size 2."); + return(rob); + } + for (i=0; idatafp2 = fp2open(fdStream); + if (client->datafp2 == NULL) { + fprintf(stderr,"oxCreateControl_RFC_101(): fp2open(fd) failed.\n"); + return(NULL); + } + client->dataport = portStream; + client->controlport = -1; + client->controlfd = -1; + 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; idatafp2 = 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->engineByteOrder = engineByteOrder; + client->controlByteOrder = -1; + return(client); }