=================================================================== RCS file: /home/cvs/OpenXM/rc/repl.c,v retrieving revision 1.8 retrieving revision 1.15 diff -u -p -r1.8 -r1.15 --- OpenXM/rc/repl.c 2003/01/16 07:50:57 1.8 +++ OpenXM/rc/repl.c 2004/02/13 03:10:19 1.15 @@ -1,12 +1,20 @@ -/* $OpenXM: OpenXM/rc/repl.c,v 1.7 2002/04/05 01:55:59 takayama Exp $ */ +/* $OpenXM: OpenXM/rc/repl.c,v 1.14 2003/02/02 01:52:50 takayama Exp $ */ #include #include -#include + +#include +#include #include +#include #define BUFSIZE 10000 +#define SSIZE 1024 +/* If you make the following two strings longer, increase the number SSIZE */ +#define REPL_IMGFILE "repl_test.img" +#define REPL_PSFILE "repl_test.ps" + int main(int argc,char *argv[]) { char s[BUFSIZE]; @@ -14,6 +22,9 @@ main(int argc,char *argv[]) { char *slash; char type = 'b'; FILE *fp; + int fd; + char sss_png[SSIZE]; + char sss_gif[SSIZE]; if (argc >= 2) { if (strcmp(argv[1],"csh")==0) { @@ -21,8 +32,14 @@ main(int argc,char *argv[]) { } } - getcwd(cwd,BUFSIZE); - slash = strrchr(cwd,'/'); + if (getcwd(cwd, sizeof(cwd)) == NULL) { + fprintf(stderr, "getcwd: %s\n", strerror(errno)); + exit(EXIT_FAILURE); + } + if ((slash = strrchr(cwd, '/')) == cwd) { + fprintf(stderr, "The current working directory is /.\n"); + exit(EXIT_FAILURE); + } *slash = 0; while (fgets(s,BUFSIZE,stdin) != NULL) { if (strcmp(s,"OpenXM_HOME=$HOME/OpenXM\n") == 0) { @@ -36,22 +53,29 @@ main(int argc,char *argv[]) { /* Configuring environmental variables. */ /* Check if pstoimg (src/asir-contrib) supports png format. */ - fp = fopen("/tmp/repl_test.ps","w"); - if (fp == NULL) { - fprintf(stderr,"Open error of /tmp/repl_test.ps. Use the existing file.\n"); - }else{ - fprintf(fp,"/Times-Roman findfont 10 scalefont setfont\n"); - fprintf(fp," 390 290 moveto (F) show \n"); - fprintf(fp,"showpage \n"); - fclose(fp); + if ((fp = fopen(REPL_PSFILE,"w")) == NULL) { + fprintf(stderr, "fopen: %s", strerror(errno)); + exit(EXIT_FAILURE); } - if (!system("pstoimg -type png /tmp/repl_test.ps -out /tmp/repl_test.png >/dev/null")) { + fprintf(fp,"/Times-Roman findfont 10 scalefont setfont\n"); + fprintf(fp," 390 290 moveto (F) show \n"); + fprintf(fp,"showpage \n"); + while (fclose(fp) != 0) { + if (errno == EINTR) + continue; + break; + } + + sprintf(sss_png,"pstoimg -type png %s -out %s >/dev/null",REPL_PSFILE,REPL_IMGFILE); + sprintf(sss_gif,"pstoimg -type gif %s -out %s >/dev/null",REPL_PSFILE,REPL_IMGFILE); + + if (!system(sss_png)) { if (type == 'b') { printf("export OpenXM_PSTOIMG_TYPE=png\n"); }else{ printf("setenv OpenXM_PSTOIMG_TYPE png\n"); } - }else if (!system("pstoimg -type gif /tmp/repl_test.ps -out /tmp/repl_test.gif >/dev/null")) { + }else if (!system(sss_gif)) { if (type == 'b') { printf("OpenXM_PSTOIMG_TYPE=gif\n"); printf("export OpenXM_PSTOIMG_TYPE\n"); @@ -62,8 +86,17 @@ main(int argc,char *argv[]) { printf("OpenXM_PSTOIMG_TYPE=no\n"); printf("export OpenXM_PSTOIMG_TYPE\n"); } - system("rm -f /tmp/repl_test.*"); + while (unlink(REPL_IMGFILE) != 0) { + if (errno == EINTR) + continue; + break; + } + while (unlink(REPL_PSFILE) != 0) { + if (errno == EINTR) + continue; + break; + } - exit(0); + exit(EXIT_SUCCESS); }