| 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; |