- /*    Copyright (C) 2002-2003 XIAO, Gang of Universite de Nice - Sophia Antipolis 
-  * 
-  *  This program is free software; you can redistribute it and/or modify 
-  *  it under the terms of the GNU General Public License as published by 
-  *  the Free Software Foundation; either version 2 of the License, or 
-  *  (at your option) any later version. 
-  * 
-  *  This program is distributed in the hope that it will be useful, 
-  *  but WITHOUT ANY WARRANTY; without even the implied warranty of 
-  *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the 
-  *  GNU General Public License for more details. 
-  * 
-  *  You should have received a copy of the GNU General Public License 
-  *  along with this program; if not, write to the Free Software 
-  *  Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. 
-  */ 
-   
- /* dvi 2 gif driver, tex standard */ 
-   
- #include "texgif.h" 
-   
- void texgif_error(char *s) 
- { 
-     fprintf(- stderr ,"%s: %s\n",- progname ,-  s );
 
- } 
-   
- unsigned long int texint(void *bp, int l) 
- { 
-     unsigned long int o, t; 
-     unsigned char c, *p; 
-     int i; 
-     o=t=0; p=bp; 
-     for(i=0;i<l;i++) { 
-         c=p[i]; t=c; o<<=8; o+=t; 
-     } 
-     return o; 
- } 
-   
- long int texintsigned(void *bp, int l) 
- { 
-     long int o, t; 
-     signed char c, *p; 
-     int i; 
-     if(l<=0) return 0; 
-     p=bp; o=*p; 
-     for(i=1;i<l;i++) { 
-         c=p[i]; t=c; o<<=8; o|=t&255; 
-     } 
-     return o; 
- } 
-   
- /* get the content of a file, and store in buf. */ 
- int getfile(char *fname, unsigned char **buf) 
- { 
-     FILE *f; 
-     long l, l2; 
-   
-     f =fopen(- fname ,"r"); if(- f ==- NULL ) return -1;
-     if(l>FILE_LENGTH_LIMIT || l<=0) { 
-     } 
-     *buf=xmalloc(l+16); 
-     if(l!=l2) { 
-     } 
-     return l; 
- } 
-   
- int execredirected(char *cmdf, char *inf, char *outf, char *errf, char *arg[]) 
- { 
-     pid_t pid; 
-     int status; 
-   
-     fflush(- NULL );       /* flush all output streams before forking
 
-                          * otherwise they will be doubled */ 
-     pid=fork(); if(pid==-1) return -1; 
-     if(!pid) {  /* child */ 
-         if(- inf !=- NULL  && freopen(- inf ,"r",- stdin ) ==-  NULL )
 
-           texgif_error("freopen failure"); 
-         if(- outf !=- NULL  && freopen(- outf ,"w",- stdout ))
 
-           texgif_error("freopen failure"); 
-         if(- errf !=- NULL  && freopen(- errf ,"w",- stderr ))
 
-           texgif_error("freopen failure"); 
-         if(wrapexec) { 
-             setreuid(getuid(),getuid());setregid(getgid(),getgid()); 
-         } 
-         if(strchr(- cmdf ,'/'))-  execv (- cmdf ,- arg );
 
-         else execvp(cmdf,arg); 
-     } 
-     else {      /* parent */ 
-         status=0; waitpid(pid,&status,0); 
-         return WEXITSTATUS(status); 
-     } 
- } 
-   
- /* system(), but with variable parms 
-  * Uses sh to execute command. 
-  */ 
- int call_sh(char *s,...) 
- { 
-     va_list vp; 
-     char buf[MAX_LINELEN+1]; 
-     char *parmbuf[4]; 
-     int t; 
-   
-     vsnprintf(buf,sizeof(buf),s,vp); 
-     parmbuf[0]="sh"; parmbuf[1]="-c"; parmbuf[2]=buf; parmbuf[3]=NULL; 
-     wrapexec=0; 
-     t=execredirected("sh",NULL,NULL,NULL,parmbuf); 
-     sync(); return t; 
- } 
-   
-