786 if (
l->mode[0] !=
'\0' && (strcmp(
l->mode,
"r") == 0))
792 else if (strcmp(
l->mode,
"w") == 0) mode =
"w";
793 else if (strcmp(
l->mode,
"fork") == 0) mode =
"fork";
794 else if (strcmp(
l->mode,
"tcp") == 0) mode =
"tcp";
795 else if (strcmp(
l->mode,
"connect") == 0) mode =
"connect";
805 if (
l->name[0] ==
'\0')
807 if (strcmp(mode,
"fork")==0)
820 if (pid == -1 && errno == EAGAIN)
833 sigemptyset(&sigint);
834 sigaddset(&sigint, SIGINT);
835 sigprocmask(SIG_BLOCK, &sigint,
NULL);
853 #ifdef HAVE_SIMPLEIPC 855 #endif // HAVE_SIMPLEIPC 856 si_close(pc[1]); si_close(cp[0]);
895 si_close(pc[0]); si_close(cp[1]);
907 Werror(
"fork failed (%d)",errno);
914 else if (strcmp(mode,
"tcp")==0)
916 int sockfd, newsockfd, portno, clilen;
917 struct sockaddr_in serv_addr, cli_addr;
918 sockfd = socket(AF_INET, SOCK_STREAM, 0);
921 WerrorS(
"ERROR opening socket");
926 memset((
char *) &serv_addr,0,
sizeof(serv_addr));
928 serv_addr.sin_family = AF_INET;
929 serv_addr.sin_addr.s_addr = INADDR_ANY;
933 serv_addr.sin_port = htons(portno);
936 WerrorS(
"ERROR on binding (no free port available?)");
942 while(bind(sockfd, (
struct sockaddr *) &serv_addr,
sizeof(serv_addr)) < 0);
945 newsockfd = si_accept(sockfd, (
struct sockaddr *) &cli_addr, (socklen_t *)&clilen);
953 PrintS(
"client accepted\n");
957 d->
f_write = fdopen(newsockfd,
"w");
964 Werror(
"invalid mode >>%s<< for ssi",mode);
974 if(strcmp(mode,
"tcp")==0)
976 int sockfd, newsockfd, portno, clilen;
977 struct sockaddr_in serv_addr, cli_addr;
978 sockfd = socket(AF_INET, SOCK_STREAM, 0);
981 WerrorS(
"ERROR opening socket");
986 memset((
char *) &serv_addr,0,
sizeof(serv_addr));
988 serv_addr.sin_family = AF_INET;
989 serv_addr.sin_addr.s_addr = INADDR_ANY;
993 serv_addr.sin_port = htons(portno);
996 WerrorS(
"ERROR on binding (no free port available?)");
1001 while(bind(sockfd, (
struct sockaddr *) &serv_addr,
sizeof(serv_addr)) < 0);
1004 char* cli_host = (
char*)
omAlloc(256);
1005 char* path = (
char*)
omAlloc(1024);
1006 int r = si_sscanf(
l->name,
"%255[^:]:%s",cli_host,path);
1009 WerrorS(
"ERROR: no host specified");
1018 WarnS(
"program not specified, using /usr/local/bin/Singular");
1020 strcpy(path,
"/usr/local/bin/Singular");
1022 char* ssh_command = (
char*)
omAlloc(256);
1023 char* ser_host = (
char*)
omAlloc(64);
1024 gethostname(ser_host,64);
1025 sprintf(ssh_command,
"ssh %s %s -q --batch --link=ssi --MPhost=%s --MPport=%d &",cli_host,path,ser_host,portno);
1033 clilen =
sizeof(cli_addr);
1034 newsockfd = si_accept(sockfd, (
struct sockaddr *) &cli_addr, (socklen_t *)&clilen);
1046 d->
f_write = fdopen(newsockfd,
"w");
1058 else if(strcmp(mode,
"connect")==0)
1060 char* host = (
char*)
omAlloc(256);
1062 struct sockaddr_in serv_addr;
1063 struct hostent *server;
1065 si_sscanf(
l->name,
"%255[^:]:%d",host,&portno);
1069 sockfd = socket(AF_INET, SOCK_STREAM, 0);
1070 if (sockfd < 0) {
WerrorS(
"ERROR opening socket");
return TRUE; }
1071 server = gethostbyname(host);
1073 memset((
char *) &serv_addr, 0,
sizeof(serv_addr));
1074 serv_addr.sin_family = AF_INET;
1075 memcpy((
char *)&serv_addr.sin_addr.s_addr,
1076 (
char *)server->h_addr,
1078 serv_addr.sin_port = htons(portno);
1079 if (si_connect(sockfd,(sockaddr*)&serv_addr,
sizeof(serv_addr)) < 0)
1080 {
Werror(
"ERROR connecting(errno=%d)",errno);
return TRUE; }
1084 d->
f_write=fdopen(sockfd,
"w");
1101 char *filename=
l->name;
1103 if(filename[0]==
'>')
1105 if (filename[1]==
'>')
1116 outfile=
myfopen(filename,mode);
1119 if (strcmp(
l->mode,
"r")==0)
char *(* fe_fgets_stdin)(const char *pr, char *s, int size)
Class used for (list of) interpreter objects.
BOOLEAN ssiWrite(si_link l, leftv data)
#define omFreeSize(addr, size)
char * fe_fgets_dummy(const char *, char *, int)
void WerrorS(const char *s)
#define SI_LINK_SET_CLOSE_P(l)
#define SI_LINK_SET_OPEN_P(l, flag)
BOOLEAN singular_in_batchmode
FILE * myfopen(const char *path, const char *mode)
void PrintS(const char *s)
leftv ssiRead1(si_link l)
#define SI_LINK_SET_RW_OPEN_P(l)
#define SIPC_MAX_SEMAPHORES
void CleanUp(ring r=currRing)
#define omFreeBin(addr, bin)
int sem_acquired[SIPC_MAX_SEMAPHORES]
s_buff s_open_by_name(const char *n)
void Werror(const char *fmt,...)
#define SI_LINK_OPEN_P(l)