version 1.9, 2002/10/21 01:59:16 |
version 1.15, 2003/09/16 02:57:40 |
|
|
/* $OpenXM: OpenXM/src/kan96xx/plugin/sm1Socket.c,v 1.8 2002/10/21 01:11:44 takayama Exp $ */ |
/* $OpenXM: OpenXM/src/kan96xx/plugin/sm1Socket.c,v 1.14 2002/10/30 13:23:06 takayama Exp $ */ |
/* msg0s.c */ |
/* msg0s.c */ |
#include <stdio.h> |
#include <stdio.h> |
#include <sys/types.h> |
#include <sys/types.h> |
|
|
#include "sm1Socket.h" |
#include "sm1Socket.h" |
|
|
extern int Quiet; |
extern int Quiet; |
|
static int Post_debug=0; |
static void errorMsg1s(char *s); |
static void errorMsg1s(char *s); |
static int getContentLength(char *s); |
static int getContentLength(char *s); |
static int getReceivedContentLength(char *s); |
static int getReceivedContentLength(char *s); |
Line 30 struct object KsocketOpen(struct object obj) { |
|
Line 31 struct object KsocketOpen(struct object obj) { |
|
int on; |
int on; |
int tt; |
int tt; |
extern int errno; |
extern int errno; |
|
extern int Post_debug; |
|
|
|
if ((char *)getenv("OXWEB_DEBUG") != NULL) { |
|
Post_debug = 1; |
|
} |
|
|
if (obj.tag != Sarray) { |
if (obj.tag != Sarray) { |
errorMsg1s("KsocketOpen([optional integer,optional string name])"); |
errorMsg1s("KsocketOpen([optional integer,optional string name])"); |
} |
} |
Line 173 struct object KsocketAccept(struct object obj) { |
|
Line 179 struct object KsocketAccept(struct object obj) { |
|
} |
} |
s = KopInteger(obj1); |
s = KopInteger(obj1); |
if ((news = accept(s,NULL,NULL)) < 0) { |
if ((news = accept(s,NULL,NULL)) < 0) { |
errorMsg1s("Error in accept."); |
fprintf(stderr,"Error in accept. Retrying (KsocketAccept).\n"); |
|
/* Code added for strange behavior on cygwin. */ |
|
if ((news = accept(s,NULL,NULL)) < 0) { |
|
errorMsg1s("Error in accept. Retry failed."); |
|
} |
} |
} |
if (close(s) < 0) { |
if (close(s) < 0) { |
errorMsg1s("Error in closing the old socket."); |
errorMsg1s("Error in closing the old socket."); |
Line 183 struct object KsocketAccept(struct object obj) { |
|
Line 193 struct object KsocketAccept(struct object obj) { |
|
return(robj); |
return(robj); |
} |
} |
|
|
|
/* [ integer socketid ] |
|
[ integer newsocketid ] */ |
|
/* It does not close the listening socket. You can call it as |
|
ls = open. |
|
fd=accept2(ls). close(fd). |
|
fd=accept2(ls). close(fd). |
|
.... |
|
*/ |
|
struct object KsocketAccept2(struct object obj) { |
|
struct object obj1; |
|
struct object obj2; |
|
struct object robj; |
|
int s, news; |
|
|
|
if (obj.tag != Sarray) { |
|
errorMsg1s("KsocketAccept([integer socketid])"); |
|
} |
|
if (getoaSize(obj) < 1) { |
|
errorMsg1s("KsocketAccept([integer socketid])"); |
|
} |
|
obj1 = getoa(obj,0); |
|
if (obj1.tag != Sinteger ) { |
|
errorMsg1s("KsocketAccept([integer socketid]), argument must be integer."); |
|
} |
|
s = KopInteger(obj1); |
|
if ((news = accept(s,NULL,NULL)) < 0) { |
|
fprintf(stderr,"Error in accept. Retrying (KsocketAccept2).\n"); |
|
/* Code added for strange behavior on cygwin. */ |
|
if ((news = accept(s,NULL,NULL)) < 0) { |
|
errorMsg1s("Error in accept. Retry failed."); |
|
} |
|
} |
|
if (close(s) < 0) { |
|
errorMsg1s("Error in closing the old socket."); |
|
} |
|
robj = newObjectArray(1); |
|
putoa(robj,0,KpoInteger(news)); |
|
return(robj); |
|
} |
|
|
int KsocketSelect0(int fd,int t) { |
int KsocketSelect0(int fd,int t) { |
fd_set readfds; |
fd_set readfds; |
struct timeval timeout; |
struct timeval timeout; |
Line 534 struct object KsocketWriteByte(struct object obj) { |
|
Line 584 struct object KsocketWriteByte(struct object obj) { |
|
struct object KsocketReadHTTP(struct object socketObj) { |
struct object KsocketReadHTTP(struct object socketObj) { |
/* Read until two empty line appears. */ |
/* Read until two empty line appears. */ |
struct object ob; |
struct object ob; |
|
struct object ob1; |
|
struct object nob; |
char *s; |
char *s; |
char *sss; |
char *sss; |
char *tmp; |
char *tmp; |
Line 543 struct object KsocketReadHTTP(struct object socketObj) |
|
Line 595 struct object KsocketReadHTTP(struct object socketObj) |
|
int datasize; |
int datasize; |
int last; |
int last; |
int contentLength=-1; |
int contentLength=-1; |
|
int socketid; |
|
extern int Post_debug; |
|
nob = NullObject; |
|
|
|
if (socketObj.tag != Sarray) { |
|
errorMsg1s("KsocketReadHTTP([integer socketid])"); |
|
} |
|
if (getoaSize(socketObj) < 1) { |
|
errorMsg1s("KsocketReadHTTP([integer socketid])"); |
|
} |
|
ob1 = getoa(socketObj,0); |
|
if (ob1.tag != Sinteger) { |
|
errorMsg1s("KsocketReadHTTP([integer socketid]) : the argument must be integer."); |
|
} |
|
socketid = KopInteger(ob1); |
|
|
|
if (KsocketSelect0(socketid,-1) != 1) { |
|
return(nob); |
|
} |
ob = KsocketRead(socketObj); |
ob = KsocketRead(socketObj); |
s = KopString(ob); |
s = KopString(ob); |
if (strncmp(s,"POST",4) == 0) flagmax=2; /* for IE */ |
if (strncmp(s,"POST",4) == 0) flagmax=2; /* for IE */ |
Line 574 struct object KsocketReadHTTP(struct object socketObj) |
|
Line 645 struct object KsocketReadHTTP(struct object socketObj) |
|
break; |
break; |
} |
} |
} |
} |
fprintf(stderr,"Waiting in socketReadBlock (spin lock to wait an empty line). flagmax(0d,0a)=%d, contentLength=%d\n",flagmax,contentLength); |
if (Post_debug) { |
if (strlen(s) == 0) {fprintf(stderr,"but I'm not receiving data. Expecting a bug.\n"); |
fprintf(stderr,"Waiting in socketReadBlock. flagmax(0d,0a)=%d, content-length=%d, received content-length=%d\n",flagmax,contentLength,getReceivedContentLength(sss)); |
|
} |
|
if (strlen(s) == 0) { |
|
fprintf(stderr,"No data. Perhaps connection is closed by foreign host.\n"); |
|
return nob; |
}else{ |
}else{ |
/* for debugging. */ |
/* for debugging. */ |
for (i=0; i<strlen(sss); i++) { |
if (Post_debug) { |
if ((sss[i] >= ' ') && (sss[i] < 0x7f)) { |
for (i=0; i<strlen(sss); i++) { |
fprintf(stderr,"%c",sss[i]); |
if ((sss[i] >= ' ') && (sss[i] < 0x7f)) { |
}else{ |
fprintf(stderr,"%c",sss[i]); |
fprintf(stderr,"(%3x)",sss[i]); |
}else{ |
if (sss[i] == 0xa) fprintf(stderr,"\n"); |
fprintf(stderr,"(%3x)",sss[i]); |
} |
if (sss[i] == 0xa) fprintf(stderr,"\n"); |
|
} |
|
|
|
} |
|
fprintf(stderr,"\n"); |
} |
} |
fprintf(stderr,"\n"); |
|
} |
} |
sleep(2); |
|
|
if (KsocketSelect0(socketid,-1) != 1) { |
|
return nob; |
|
} |
ob = KsocketRead(socketObj); |
ob = KsocketRead(socketObj); |
s = KopString(ob); |
s = KopString(ob); |
for (i=strlen(s)-1; i>=0; i--) { |
for (i=strlen(s)-1; i>=0; i--) { |
Line 633 struct object Kplugin_sm1Socket(char *key,struct objec |
|
Line 713 struct object Kplugin_sm1Socket(char *key,struct objec |
|
robj = KsocketConnect(obj); |
robj = KsocketConnect(obj); |
}else if (strcmp(key,"accept") == 0) { |
}else if (strcmp(key,"accept") == 0) { |
robj = KsocketAccept(obj); |
robj = KsocketAccept(obj); |
|
}else if (strcmp(key,"accept2") == 0) { |
|
robj = KsocketAccept2(obj); |
}else if (strcmp(key,"select") == 0) { |
}else if (strcmp(key,"select") == 0) { |
robj = KsocketSelect(obj); |
robj = KsocketSelect(obj); |
}else if (strcmp(key,"mselect") == 0) { |
}else if (strcmp(key,"mselect") == 0) { |
Line 641 struct object Kplugin_sm1Socket(char *key,struct objec |
|
Line 723 struct object Kplugin_sm1Socket(char *key,struct objec |
|
robj = KsocketRead(obj); |
robj = KsocketRead(obj); |
}else if (strcmp(key,"readHTTP") == 0) { |
}else if (strcmp(key,"readHTTP") == 0) { |
robj = KsocketReadHTTP(obj); |
robj = KsocketReadHTTP(obj); |
|
}else if (strcmp(key,"gethostname") == 0) { |
|
robj = KsocketGetHostName(); |
}else if (strcmp(key,"write") == 0) { |
}else if (strcmp(key,"write") == 0) { |
robj = KsocketWrite(obj); |
robj = KsocketWrite(obj); |
}else if (strcmp(key,"read") == 0) { |
}else if (strcmp(key,"read") == 0) { |
Line 660 struct object Kplugin_sm1Socket(char *key,struct objec |
|
Line 744 struct object Kplugin_sm1Socket(char *key,struct objec |
|
|
|
static int getContentLength(char *s) { |
static int getContentLength(char *s) { |
int n; |
int n; |
int i; |
int i,j; |
int len = -1; |
int len = -1; |
char *s1 = "Content-length:"; |
char *s1 = "content-length:"; |
char *s2 = "CONTENT-LENGTH:"; |
char s0[256]; |
|
int m; |
|
m = strlen(s1); |
n = strlen(s); |
n = strlen(s); |
for (i=0; i<n; i++) { |
for (i=0; i<n; i++) { |
if ((strncmp(&(s[i]),s1,strlen(s1)) == 0) || |
strncpy(s0,&(s[i]),m+1); |
(strncmp(&(s[i]),s2,strlen(s2)) == 0)) { |
for (j=0; j<m; j++) { |
sscanf(&(s[i+strlen(s1)]),"%d",&len); |
if ((s0[j] >= 'A') && (s0[j] <= 'Z')) s0[j] = s0[j]+0x20; |
break; |
} |
} |
if (strncmp(s0,s1,strlen(s1)) == 0) { |
|
sscanf(&(s[i+strlen(s1)]),"%d",&len); |
|
break; |
|
} |
} |
} |
return len; |
return len; |
} |
} |
Line 692 static int getReceivedContentLength(char *s) { |
|
Line 781 static int getReceivedContentLength(char *s) { |
|
} |
} |
|
|
|
|
|
struct object KsocketGetHostName(void) { |
|
char name[1024]; |
|
char *s; |
|
struct object rob = NullObject; |
|
if (gethostname(name,1023) != 0) { |
|
return rob; |
|
} |
|
s = (char *)GC_malloc(sizeof(char)*(strlen(name)+2)); |
|
if (s == (char *)NULL) errorMsg1s("Out of Memory."); |
|
strcpy(s,name); |
|
return(KpoString(s)); |
|
} |
|
|
|
|
|
|