File: [local] / OpenXM_contrib2 / asir2000 / parse / load.c (download)
Revision 1.1.1.1 (vendor branch), Fri Dec 3 07:39:12 1999 UTC (24 years, 10 months ago) by noro
Branch: NORO
CVS Tags: ASIR2000 Changes since 1.1: +0 -0
lines
Imported asir2000 as OpenXM_contrib2/asir2000.
|
/* $OpenXM: OpenXM_contrib2/asir2000/parse/load.c,v 1.1.1.1 1999/12/03 07:39:12 noro Exp $ */
#include "ca.h"
#include "parse.h"
#if defined(THINK_C)
#include <string.h>
#include <StandardFile.h>
#include <Windows.h>
#include <OSUtils.h>
#include <ToolUtils.h>
#else
#if defined(VISUAL)
#include <string.h>
#include <fcntl.h>
#if defined(GO32)
#include <unistd.h>
#endif
#include <sys/stat.h>
#else
#if defined(_PA_RISC1_1) || defined(SYSV) || defined(__SVR4)
#include <unistd.h>
#include <string.h>
#else
#include <strings.h>
#endif
#include <sys/types.h>
#include <sys/file.h>
#include <sys/stat.h>
#endif
#endif
#if defined(linux)
#include <unistd.h>
#endif
#if defined(VISUAL)
#include <io.h>
#endif
#undef MALLOC
#define MALLOC(x) GC_malloc((x)+4)
char *ASIRLOADPATH[32];
void encrypt_file(char *,char *);
void decrypt_file(char *,char *);
#if defined(THINK_C)
void searchasirpath(char *,char **);
void loadasirfile(char *);
short initvol;
void initVol();
short getVol();
void setDir(short);
void resetDir();
void initVol() {
char buf[BUFSIZ];
GetVol((StringPtr)buf,&initvol);
}
short getVol() {
short vol;
char buf[BUFSIZ];
GetVol((StringPtr)buf,&vol);
return vol;
}
void setDir(short vol)
{
SetVol(0,vol);
}
void resetDir() {
SetVol(0,initvol);
}
#endif
#if defined(VISUAL)
#define ENVDELIM ';'
#define MORE "more < "
#else
#define ENVDELIM ':'
#define MORE "more"
#endif
#ifndef ASIR_LIBDIR
#define ASIR_LIBDIR "."
#endif
char *getenv();
extern char *asir_libdir;
extern char *asir_pager;
extern int read_exec_file;
extern int main_parser;
void env_init() {
char *e,*p,*q;
int i,l;
char *getenv();
char *oxhome;
char rootname[BUFSIZ];
if ( !(asir_libdir = getenv("ASIR_LIBDIR")) ) {
if ( oxhome = getenv("OpenXM_HOME") ) {
asir_libdir = (char *)malloc(strlen(oxhome)+strlen("/lib/asir")+1);
sprintf(asir_libdir,"%s/lib/asir",oxhome);
} else {
#if defined(VISUAL)
get_rootdir(rootname,sizeof(rootname));
asir_libdir = (char *)malloc(strlen(rootname)+strlen("/lib")+1);
sprintf(asir_libdir,"%s/lib",rootname);
#else
asir_libdir = (char *)malloc(strlen(ASIR_LIBDIR)+1);
strcpy(asir_libdir,ASIR_LIBDIR);
#endif
}
}
if ( !(asir_pager = getenv("PAGER")) ) {
asir_pager = (char *)malloc(strlen(MORE)+1);
strcpy(asir_pager,MORE);
}
if ( e = getenv("ASIRLOADPATH" ) )
for ( i = 0; ; i++, e = p+1 ) {
p = (char *)index(e,ENVDELIM);
l = p ? p-e : strlen(e); q = (char *)MALLOC(l+1);
if ( l ) {
strncpy(q,e,l); q[l] = 0; ASIRLOADPATH[i] = q;
}
if ( !p )
break;
}
for ( i = 0; ASIRLOADPATH[i]; i++ );
ASIRLOADPATH[i] = asir_libdir;
}
void searchasirpath(name,pathp)
char *name;
char **pathp;
{
char **p;
char *q;
int l;
#if !defined(THINK_C) && !defined(VISUAL)
struct stat sbuf;
if ( (name[0] == '/') || ( name[0] == '.') || strchr(name,':')
|| !ASIRLOADPATH[0] ) {
if ( access(name,R_OK) >= 0 ) {
stat(name,&sbuf);
if ( (sbuf.st_mode & S_IFMT) != S_IFDIR )
*pathp = name;
else
*pathp = 0;
} else
*pathp = 0;
} else {
for ( p = ASIRLOADPATH; *p; p++ ) {
l = strlen(*p)+strlen(name)+2;
q = (char *)ALLOCA(l); sprintf(q,"%s/%s",*p,name);
if ( access(q,R_OK) >= 0 ) {
stat(q,&sbuf);
if ( (sbuf.st_mode & S_IFMT) != S_IFDIR ) {
*pathp = (char *)MALLOC(l); strcpy(*pathp,q);
return;
}
}
}
*pathp = 0;
}
#elif defined(VISUAL)
if ( (name[0] == '/') || ( name[0] == '.') || strchr(name,':')
|| !ASIRLOADPATH[0] )
*pathp = name;
else {
for ( p = ASIRLOADPATH; *p; p++ ) {
l = strlen(*p)+strlen(name)+2;
q = (char *)ALLOCA(l); sprintf(q,"%s/%s",*p,name);
if ( access(q,04) >= 0 ) {
*pathp = (char *)MALLOC(l); strcpy(*pathp,q);
return;
}
}
*pathp = 0;
}
#else
if ( (name[0] == '/') || ( name[0] == '.') || !ASIRLOADPATH[0] )
*pathp = name;
else {
for ( p = ASIRLOADPATH; *p; p++ ) {
l = strlen(*p)+strlen(name)+2;
q = (char *)ALLOCA(l); sprintf(q,"%s/%s",*p,name);
*pathp = (char *)MALLOC(l); strcpy(*pathp,q);
return;
}
*pathp = 0;
}
#endif
}
#if defined(THINK_C)
#define DELIM ':'
#elif defined(VISUAL)
#define DELIM '/'
#endif
void Eungetc(int,FILE *);
void loadasirfile(name0)
char *name0;
{
FILE *in;
IN t;
extern char cppname[];
#if defined(THINK_C) || defined(VISUAL)
char tname[BUFSIZ],dname[BUFSIZ],ibuf1[BUFSIZ],ibuf2[BUFSIZ];
int ac;
#if defined(__MWERKS__)
char *av[64];
#else
char *av[BUFSIZ];
#endif
char *p,*c;
FILE *fp;
char name[BUFSIZ],tname0[BUFSIZ];
int encoded;
#if defined(VISUAL)
fp = fopen(name0,"rb");
if ( getc(fp) == 0xff ) {
/* encoded file */
fclose(fp);
sprintf(name,"%s.$$$",name0);
decrypt_file(name0,name);
encoded = 1;
} else {
fclose(fp);
strcpy(name,name0);
encoded = 0;
}
#else
strcpy(name,name0);
#endif
strcpy(dname,name);
p = strrchr(dname,DELIM);
av[0] = "cpp"; av[1] = name; av[2] = tname;
sprintf(ibuf1,"-I%s",asir_libdir); av[3] = ibuf1; av[4] = "-DWINDOWS";
if ( !p ) {
sprintf(tname,"%s.___",name); av[5] = 0; ac = 5;
} else {
*p++ = 0;
#if defined(VISUAL)
if ( c = strchr(dname,':') ) {
*c = 0;
sprintf(tname,"%s:%s%c%s.___",dname,c+1,DELIM,p);
*c = ':';
} else
#endif
sprintf(tname,"%s%c%s.___",dname,DELIM,p);
sprintf(ibuf2,"-I%s",dname); av[5] = ibuf2; av[6] = 0; ac = 6;
}
cpp_main(ac,av);
if ( encoded ) {
unlink(name);
strcpy(tname0,tname);
sprintf(tname,"%s.###",tname0);
encrypt_file(tname0,tname);
unlink(tname0);
in = fopen(tname,"rb");
} else
in = fopen(tname,"r");
if ( !in ) {
perror("fopen");
error("load : failed");
}
t = (IN)MALLOC(sizeof(struct oIN));
t->name = (char *)MALLOC(strlen(name)+1); strcpy(t->name,name);
t->tname = (char *)MALLOC(strlen(tname)+1); strcpy(t->tname,tname);
t->encoded = encoded;
#if defined(THINK_C)
t->vol = getVol();
#endif
#else
char com[BUFSIZ];
sprintf(com,"%s -I%s %s",cppname,asir_libdir,name0); in = popen(com,"r");
if ( !in ) {
perror("popen");
error("load : failed");
}
t = (IN)MALLOC(sizeof(struct oIN));
t->name = (char *)MALLOC(strlen(name0)+1); strcpy(t->name,name0);
#endif
t->fp = in; t->ln = 1; t->next = asir_infile; asir_infile = t;
main_parser = 1; /* XXX */
Eungetc(afternl(),asir_infile->fp);
if ( !EPVS->va )
reallocarray((char **)&EPVS->va,(int *)&EPVS->asize,(int *)&EPVS->n,(int)sizeof(struct oPV));
}
void execasirfile(name)
char *name;
{
loadasirfile(name);
read_exec_file = 1;
read_eval_loop();
read_exec_file = 0;
}
static NODE objfile = 0;
#if defined(apollo) || defined(VISUAL) || defined(_PA_RISC1_1) || defined(__alpha) || defined(linux) || defined(__FreeBSD__) || defined(__NetBSD__) || defined(SYSV) || defined(__SVR4)
int loadfile(s)
char *s;
{
FILE *in;
if ( in = fopen(s,"r") ) {
fclose(in);
loadasirfile(s);
return 1;
} else
return 0;
}
int loadfiles(node) NODE node; { return 0; }
#else
#if defined(THINK_C)
int loadfile(s)
char *s;
{
FILE *in;
if ( in = fopen(s,"r") ) {
loadasirfile(s); fclose(in);
return 1;
} else
return 0;
}
int loadfiles(node) NODE node; { return 0; }
int finder_loadfile() {
Point p;
SFTypeList t;
SFReply r;
int ret;
p.h = p.v = 50; t[0] = 'TEXT';
SFGetFile(p,"\p",0,1,t,0,&r);
if ( r.good ) {
setDir(r.vRefNum);
ret = loadfile(PtoCstr(r.fName));
resetDir();
return ret;
} else
return 0;
}
#else
#if defined(NeXT)
#include <rld.h>
#include <ldsyms.h>
void loadmachofile(char **);
void unloadmachofile(void);
int loadfile(s)
char *s;
{
FILE *in;
unsigned magic;
char **oname;
if ( in = fopen(s,"r") ) {
fread(&magic,sizeof(unsigned),1,in); fclose(in);
if (magic == MH_MAGIC) {
oname = (char **)ALLOCA(BUFSIZ);
oname[0] = s; oname[1] = "/usr/lib/libm.a",oname[2] = 0;
loadmachofile(oname);
} else
loadasirfile(s);
return 1;
} else
return 0;
}
int loadfiles(node)
NODE node;
{
int i;
NODE n;
char *name;
char **oname;
for ( i = 0, n = node; n; i++, n = NEXT(n) );
if ( OID(BDY(n)) != O_STR )
return 0;
oname = (char **)ALLOCA(i+1);
for ( i = 0, n = node; n; i++, n = NEXT(n) ) {
searchasirpath(BDY((STRING)BDY(node)),&name);
if ( !name )
return 0;
else
oname[i] = name;
}
oname[i] = 0;
loadmachofile(oname);
return 1;
}
static NXStream *nxs = 0;
void loadmachofile(oname)
char **oname;
{
struct mach_header *h;
unsigned int data_start,data_end;
struct section *tsec,*dsec,*bsec,*csec;
struct section *getsectbynamefromheader();
if ( !nxs )
nxs = NXOpenFile(fileno(stderr),NX_WRITEONLY);
if ( rld_load(nxs,&h,oname,"/tmp/afo") ) {
tsec = getsectbynamefromheader(h,"__TEXT","__text");
dsec = getsectbynamefromheader(h,"__DATA","__data");
bsec = getsectbynamefromheader(h,"__DATA","__bss");
csec = getsectbynamefromheader(h,"__DATA","__common");
data_start = dsec->addr; data_end = dsec->addr+dsec->size;
if ( bsec->size ) {
data_start = MIN(data_start,bsec->addr);
data_end = MAX(data_end,(bsec->addr+bsec->size));
}
if ( csec->size ) {
data_start = MIN(data_start,csec->addr);
data_end = MAX(data_end,(csec->addr+csec->size));
}
#if 0
if ( data_start != data_end )
add_data(data_start,data_end);
#endif
(*(int(*)())(tsec->addr))();
} else if ( nxs )
NXFlush(nxs);
}
void unloadmachofile()
{
if ( !rld_unload(nxs) && nxs )
NXFlush(nxs);
}
#else
#ifdef mips
#include <sys/exec.h>
#else
#include <a.out.h>
#endif
void loadaoutfile(/* char ** */);
int loadfiles(node) NODE node; { return 0; }
int loadfile(s)
char *s;
{
FILE *in;
struct exec h;
char **oname;
if ( in = fopen(s,"r") ) {
fread(&h,sizeof(h),1,in); fclose(in);
#if defined(__NetBSD__)
if ((N_GETMAGIC(h) == OMAGIC) || (N_GETMAGIC(h) == ZMAGIC)) {
#else
if ((h.a_magic == OMAGIC) || (h.a_magic == ZMAGIC)) {
#endif
oname = (char **)ALLOCA(BUFSIZ);
oname[0] = s; oname[1] = 0;
loadaoutfile(oname);
} else
loadasirfile(s);
return 1;
} else
return 0;
}
#if 0
void loadaoutfile(name)
char **name;
{
#include <sys/wait.h>
FILE *in;
char *tmpf,*buf;
char **n;
NODE tn;
struct exec h;
char com[BUFSIZ];
char *ldargv[256];
char nbuf[BUFSIZ];
int i,w;
union wait status;
static char ldcom1[] = "ld -d -N -x -A %s -T %x ";
static char ldcom2[] = " -lm -lc -o ";
extern char asirname[];
tmpf = tempnam(0,"asir");
ldargv[0] = "ld"; ldargv[1] = "-d"; ldargv[2] = "-N";
ldargv[3] = "-x"; ldargv[4] = "-A"; ldargv[5] = asirname;
ldargv[6] = "-T"; ldargv[7] = "0";
for ( i = 8, n = name; *n; n++, i++ )
ldargv[i] = *n;
ldargv[i++] = "-lm"; ldargv[i++] = "-lc"; ldargv[i++] = "-o";
ldargv[i++] = tmpf; ldargv[i] = 0;
if ( !vfork() ) {
if ( execv("/bin/ld",ldargv) < 0 )
_exit(0);
} else
wait(&status);
if ( status.w_status ) {
error("loadaoutfile : faild");
}
in = fopen(tmpf,"r"); fread(&h,sizeof(h),1,in);
fclose(in); unlink(tmpf);
buf = (char *)CALLOC(h.a_text+h.a_data+h.a_bss,1);
sprintf(nbuf,"%x",buf); ldargv[7] = nbuf;
if ( !vfork() ) {
if ( execv("/bin/ld",ldargv) < 0 );
_exit(0);
} else
wait(&status);
in = fopen(tmpf,"r"); fread(&h,sizeof(h),1,in);
#ifdef mips
fseek(in,N_TXTOFF(h.ex_f,h.ex_o),0);
#endif
fread(buf,h.a_text+h.a_data,1,in);
MKNODE(tn,buf,objfile); objfile = tn;
(*(int(*)())buf)();
fclose(in); unlink(tmpf);
}
#endif
#if 1
void loadaoutfile(name)
char **name;
{
FILE *in;
char *tmpf,*buf,*p;
char **n;
NODE tn;
struct exec h;
char com[BUFSIZ];
int status,i,len;
#ifdef mips
static char ldcom1[] = "ld -G 0 -d -N -x -A %s -T %x ";
static char ldcom2[] = " -lm_G0 -lc -o ";
#else
static char ldcom1[] = "ld -d -N -x -A %s -T %x ";
static char ldcom2[] = " -lm -lc -o ";
#endif
extern char asirname[];
tmpf = tempnam(0,"asir");
sprintf(com,ldcom1,asirname,0);
for ( n = name; *n; n++ )
strcat(com,*n);
strcat(com,ldcom2); strcat(com,tmpf);
status = system(com);
if ( status ) {
fprintf(stderr,"system() : status = %d\n",status);
error("loadaoutfile : could not exec system()");
}
in = fopen(tmpf,"r");
fread(&h,sizeof(h),1,in);
fclose(in); unlink(tmpf);
buf = (char *)CALLOC(h.a_text+h.a_data+h.a_bss,1);
sprintf(com,ldcom1,asirname,buf);
for ( n = name; *n; n++ )
strcat(com,*n);
strcat(com,ldcom2); strcat(com,tmpf);
system(com);
in = fopen(tmpf,"r"); fread(&h,sizeof(h),1,in);
#ifdef mips
fseek(in,N_TXTOFF(h.ex_f,h.ex_o),0);
#endif
len = h.a_text+h.a_data; fread(buf,1,len,in);
/* to avoid a bug on RISC-NEWS */
fprintf(stderr,"text=%d data=%d bss=%d\n",h.a_text,h.a_data,h.a_bss);
MKNODE(tn,buf,objfile); objfile = tn;
/* fprintf(stderr,"calling reg_sysf()...\n"); */
(*(int(*)())buf)();
fclose(in); unlink(tmpf);
}
#endif
#endif
#endif
#endif
static unsigned char encrypt_tab[128][2] = {
{137,40},{1,194},{133,79},{48,20},{254,76},{98,17},{110,233},{19,231},
{55,223},{75,65},{178,151},{85,222},{201,46},{51,243},{235,61},{106,113},
{116,121},{24,205},{146,244},{89,234},{163,173},{140,162},{188,45},{195,132},
{202,94},{236,87},{2,127},{253,47},{211,138},{58,252},{142,190},{77,209},
{16,53},{200,220},{99,165},{28,59},{78,0},{208,248},{50,229},{217,39},
{112,15},{18,60},{108,175},{10,67},{23,176},{49,245},{160,27},{171,219},
{105,144},{122,172},{255,114},{226,100},{70,117},{197,11},{180,36},{136,101},
{238,212},{125,120},{103,199},{38,119},{7,206},{181,228},{62,3},{30,185},
{154,63},{247,81},{187,80},{225,56},{210,221},{37,135},{155,52},{54,153},
{84,246},{166,90},{124,167},{41,184},{145,204},{147,198},{25,21},{72,97},
{66,128},{95,139},{93,42},{224,43},{35,143},{111,13},{82,249},{12,148},
{32,152},{186,168},{177,115},{216,251},{5,131},{123,170},{149,161},{213,203},
{126,150},{88,158},{74,169},{159,182},{156,26},{34,104},{8,91},{207,183},
{9,64},{83,241},{134,102},{69,33},{179,237},{129,250},{14,71},{230,4},
{218,6},{189,68},{193,22},{57,174},{215,214},{130,92},{240,31},{118,239},
{109,192},{232,196},{86,107},{96,141},{157,227},{164,242},{44,191},{29,73}
};
static unsigned char decrypt_tab[] = {
36,1,26,62,111,92,112,60,102,104,43,53,87,85,110,40,
32,5,41,7,3,78,114,44,17,78,100,46,35,127,63,118,
88,107,101,84,54,69,59,39,0,75,82,83,126,22,12,27,
3,45,38,13,70,32,71,8,67,115,29,35,41,14,62,64,
104,9,80,43,113,107,52,110,79,127,98,9,4,31,36,2,
66,65,86,105,72,11,122,25,97,19,73,102,117,82,24,81,
123,79,5,34,51,55,106,58,101,48,15,122,42,120,6,85,
40,15,50,90,16,52,119,59,57,16,49,93,74,57,96,26,
80,109,117,92,23,2,106,69,55,0,28,81,21,123,30,84,
48,76,18,77,87,94,96,10,88,71,64,70,100,124,97,99,
46,94,21,20,125,34,73,74,89,98,93,47,49,20,115,42,
44,90,10,108,54,61,99,103,75,63,89,66,22,113,30,126,
120,114,1,23,121,53,77,58,33,12,24,95,76,17,60,103,
37,31,68,28,56,95,116,116,91,39,112,47,33,68,11,8,
83,67,51,124,61,38,111,7,121,6,19,14,25,108,56,119,
118,105,125,13,18,45,72,65,37,86,109,91,29,27,4,50
};
unsigned char encrypt_char(unsigned char c)
{
return encrypt_tab[c][mt_genrand()&1];
}
unsigned char decrypt_char(unsigned char c)
{
return decrypt_tab[c];
}
void encrypt_file(in,out)
char *in,*out;
{
FILE *infp,*outfp;
int c;
infp = fopen(in,"r");
outfp = fopen(out,"wb");
while ( 1 ) {
c = getc(infp);
if ( c == EOF )
break;
putc(encrypt_char(c),outfp);
}
fclose(infp); fclose(outfp);
}
void decrypt_file(in,out)
char *in,*out;
{
FILE *infp,*outfp;
int c;
infp = fopen(in,"rb");
outfp = fopen(out,"w");
/* skip the magic number (=0xff) */
getc(infp);
while ( 1 ) {
c = getc(infp);
if ( c == EOF )
break;
putc(decrypt_char(c),outfp);
}
fclose(infp); fclose(outfp);
}