version 1.1, 1999/12/03 07:39:12 |
version 1.25, 2014/04/02 22:08:29 |
|
|
/* $OpenXM: OpenXM/src/asir99/parse/load.c,v 1.1.1.1 1999/11/10 08:12:34 noro Exp $ */ |
/* |
|
* Copyright (c) 1994-2000 FUJITSU LABORATORIES LIMITED |
|
* All rights reserved. |
|
* |
|
* FUJITSU LABORATORIES LIMITED ("FLL") hereby grants you a limited, |
|
* non-exclusive and royalty-free license to use, copy, modify and |
|
* redistribute, solely for non-commercial and non-profit purposes, the |
|
* computer program, "Risa/Asir" ("SOFTWARE"), subject to the terms and |
|
* conditions of this Agreement. For the avoidance of doubt, you acquire |
|
* only a limited right to use the SOFTWARE hereunder, and FLL or any |
|
* third party developer retains all rights, including but not limited to |
|
* copyrights, in and to the SOFTWARE. |
|
* |
|
* (1) FLL does not grant you a license in any way for commercial |
|
* purposes. You may use the SOFTWARE only for non-commercial and |
|
* non-profit purposes only, such as academic, research and internal |
|
* business use. |
|
* (2) The SOFTWARE is protected by the Copyright Law of Japan and |
|
* international copyright treaties. If you make copies of the SOFTWARE, |
|
* with or without modification, as permitted hereunder, you shall affix |
|
* to all such copies of the SOFTWARE the above copyright notice. |
|
* (3) An explicit reference to this SOFTWARE and its copyright owner |
|
* shall be made on your publication or presentation in any form of the |
|
* results obtained by use of the SOFTWARE. |
|
* (4) In the event that you modify the SOFTWARE, you shall notify FLL by |
|
* e-mail at risa-admin@sec.flab.fujitsu.co.jp of the detailed specification |
|
* for such modification or the source code of the modified part of the |
|
* SOFTWARE. |
|
* |
|
* THE SOFTWARE IS PROVIDED AS IS WITHOUT ANY WARRANTY OF ANY KIND. FLL |
|
* MAKES ABSOLUTELY NO WARRANTIES, EXPRESSED, IMPLIED OR STATUTORY, AND |
|
* EXPRESSLY DISCLAIMS ANY IMPLIED WARRANTY OF MERCHANTABILITY, FITNESS |
|
* FOR A PARTICULAR PURPOSE OR NONINFRINGEMENT OF THIRD PARTIES' |
|
* RIGHTS. NO FLL DEALER, AGENT, EMPLOYEES IS AUTHORIZED TO MAKE ANY |
|
* MODIFICATIONS, EXTENSIONS, OR ADDITIONS TO THIS WARRANTY. |
|
* UNDER NO CIRCUMSTANCES AND UNDER NO LEGAL THEORY, TORT, CONTRACT, |
|
* OR OTHERWISE, SHALL FLL BE LIABLE TO YOU OR ANY OTHER PERSON FOR ANY |
|
* DIRECT, INDIRECT, SPECIAL, INCIDENTAL, PUNITIVE OR CONSEQUENTIAL |
|
* DAMAGES OF ANY CHARACTER, INCLUDING, WITHOUT LIMITATION, DAMAGES |
|
* ARISING OUT OF OR RELATING TO THE SOFTWARE OR THIS AGREEMENT, DAMAGES |
|
* FOR LOSS OF GOODWILL, WORK STOPPAGE, OR LOSS OF DATA, OR FOR ANY |
|
* DAMAGES, EVEN IF FLL SHALL HAVE BEEN INFORMED OF THE POSSIBILITY OF |
|
* SUCH DAMAGES, OR FOR ANY CLAIM BY ANY OTHER PARTY. EVEN IF A PART |
|
* OF THE SOFTWARE HAS BEEN DEVELOPED BY A THIRD PARTY, THE THIRD PARTY |
|
* DEVELOPER SHALL HAVE NO LIABILITY IN CONNECTION WITH THE USE, |
|
* PERFORMANCE OR NON-PERFORMANCE OF THE SOFTWARE. |
|
* |
|
* $OpenXM: OpenXM_contrib2/asir2000/parse/load.c,v 1.24 2014/03/30 10:48:16 ohara Exp $ |
|
*/ |
#include "ca.h" |
#include "ca.h" |
#include "parse.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) |
#if defined(VISUAL) |
#include <string.h> |
#include <string.h> |
#include <fcntl.h> |
#include <fcntl.h> |
#if defined(GO32) |
|
#include <unistd.h> |
|
#endif |
|
#include <sys/stat.h> |
#include <sys/stat.h> |
#else |
#else /* VISUAL */ |
#if defined(_PA_RISC1_1) || defined(SYSV) || defined(__SVR4) |
#if defined(_PA_RISC1_1) || defined(SYSV) || defined(__SVR4) |
#include <unistd.h> |
#include <unistd.h> |
#include <string.h> |
#include <string.h> |
|
|
#include <sys/file.h> |
#include <sys/file.h> |
#include <sys/stat.h> |
#include <sys/stat.h> |
#endif |
#endif |
#endif |
|
|
|
#if defined(linux) |
#if defined(linux) |
#include <unistd.h> |
#include <unistd.h> |
|
|
#include <io.h> |
#include <io.h> |
#endif |
#endif |
|
|
|
#ifdef MALLOC |
#undef MALLOC |
#undef MALLOC |
#define MALLOC(x) GC_malloc((x)+4) |
#define MALLOC(x) Risa_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 |
#endif |
|
|
|
char **ASIRLOADPATH; |
|
|
#if defined(VISUAL) |
#if defined(VISUAL) |
#define ENVDELIM ';' |
#define ENVDELIM ';' |
#define MORE "more < " |
#define MORE "more < " |
Line 88 void resetDir() { |
|
Line 90 void resetDir() { |
|
#endif |
#endif |
|
|
#ifndef ASIR_LIBDIR |
#ifndef ASIR_LIBDIR |
#define ASIR_LIBDIR "." |
#define ASIR_LIBDIR "/usr/local/lib/asir" |
#endif |
#endif |
|
#ifndef ASIR_CONTRIB_DIR |
|
#define ASIR_CONTRIB_DIR "/usr/local/lib/asir-contrib" |
|
#endif |
|
|
char *getenv(); |
char *getenv(); |
|
void Pget_rootdir(); |
|
char *search_executable(char *name); |
|
|
extern char *asir_libdir; |
extern char *asir_libdir; |
|
extern char *asir_contrib_dir; |
|
extern char *asir_private_dir; |
extern char *asir_pager; |
extern char *asir_pager; |
extern int read_exec_file; |
|
extern int main_parser; |
extern int main_parser; |
|
extern JMP_BUF exec_env; |
|
|
|
char *search_executable(char *name) |
|
{ |
|
char *c,*s,*ret; |
|
int len,nlen; |
|
char dir[BUFSIZ],path[BUFSIZ]; |
|
struct stat buf; |
|
|
|
nlen = strlen(name); |
|
for ( s = (char *)getenv("PATH"); s; ) { |
|
c = (char *)index(s,':'); |
|
len = c ? c-s : strlen(s); |
|
if ( len >= BUFSIZ ) continue; |
|
strncpy(dir,s,len); dir[len] = 0; |
|
if ( c ) s = c+1; |
|
else s = 0; |
|
if ( len+nlen+1 >= BUFSIZ ) continue; |
|
sprintf(path,"%s/%s",dir,name); |
|
if ( !stat(path,&buf) && !(buf.st_mode & S_IFDIR) |
|
#if !defined(VISUAL) |
|
&& !access(path,X_OK) |
|
#endif |
|
) { |
|
len = strlen(path)+1; |
|
ret = (char *)MALLOC(len); |
|
strcpy(ret,path); |
|
return ret; |
|
} |
|
} |
|
return 0; |
|
} |
|
|
void env_init() { |
void env_init() { |
char *e,*p,*q; |
char *e,*p,*q; |
int i,l; |
int i,l,japanese; |
char *getenv(); |
char *getenv(); |
char *oxhome; |
char *oxhome; |
char rootname[BUFSIZ]; |
char rootname[BUFSIZ]; |
|
size_t len; |
|
|
|
if ( oxhome = getenv("OpenXM_HOME") ) { |
|
len = strlen(oxhome); |
|
}else { |
|
#if defined(VISUAL) |
|
get_rootdir(rootname,sizeof(rootname)); |
|
len = strlen(rootname); |
|
oxhome = rootname; |
|
#endif |
|
} |
|
|
if ( !(asir_libdir = getenv("ASIR_LIBDIR")) ) { |
if ( !(asir_libdir = getenv("ASIR_LIBDIR")) ) { |
if ( oxhome = getenv("OpenXM_HOME") ) { |
if ( oxhome ) { |
asir_libdir = (char *)malloc(strlen(oxhome)+strlen("/lib/asir")+1); |
asir_libdir = (char *)malloc(len+strlen("/lib/asir")+1); |
sprintf(asir_libdir,"%s/lib/asir",oxhome); |
sprintf(asir_libdir,"%s/lib/asir",oxhome); |
} else { |
} 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); |
asir_libdir = (char *)malloc(strlen(ASIR_LIBDIR)+1); |
strcpy(asir_libdir,ASIR_LIBDIR); |
strcpy(asir_libdir,ASIR_LIBDIR); |
#endif |
|
} |
} |
} |
} |
|
|
|
if ( !(asir_contrib_dir = getenv("ASIR_CONTRIB_DIR")) ) { |
|
if ( oxhome ) { |
|
asir_contrib_dir = (char *)malloc(len+strlen("/lib/asir-contrib")+1); |
|
sprintf(asir_contrib_dir,"%s/lib/asir-contrib",oxhome); |
|
} else { |
|
asir_contrib_dir = (char *)malloc(strlen(ASIR_CONTRIB_DIR)+1); |
|
strcpy(asir_contrib_dir,ASIR_CONTRIB_DIR); |
|
} |
|
} |
|
|
|
asir_private_dir = NULL; |
|
#if defined(VISUAL) |
|
if ( e = getenv("APPDATA") ) { |
|
asir_private_dir = (char *)malloc(strlen(e)+strlen("/asir/lib/asir-contrib")+1); |
|
sprintf(asir_private_dir,"%s/asir/lib/asir-contrib",e); |
|
} |
|
#endif |
|
|
if ( !(asir_pager = getenv("PAGER")) ) { |
if ( !(asir_pager = getenv("PAGER")) ) { |
asir_pager = (char *)malloc(strlen(MORE)+1); |
japanese = 0; |
strcpy(asir_pager,MORE); |
if ( (e = getenv("LANGUAGE")) && |
|
(!strncmp(e,"japan",5) || !strncmp(e,"ja_JP",5)) ) japanese = 1; |
|
else if ( (e = getenv("LC_ALL")) && |
|
(!strncmp(e,"japan",5) || !strncmp(e,"ja_JP",5)) ) japanese = 1; |
|
else if ( (e = getenv("LC_CTYPE")) && |
|
(!strncmp(e,"japan",5) || !strncmp(e,"ja_JP",5)) ) japanese = 1; |
|
else if ( (e = getenv("LANG")) && |
|
(!strncmp(e,"japan",5) || !strncmp(e,"ja_JP",5)) ) japanese = 1; |
|
if ( japanese ) |
|
asir_pager = search_executable("jless"); |
|
if ( !asir_pager ) { |
|
/* default: more */ |
|
asir_pager = (char *)malloc(strlen(MORE)+1); |
|
strcpy(asir_pager,MORE); |
|
} |
} |
} |
if ( e = getenv("ASIRLOADPATH" ) ) |
if ( e = getenv("ASIRLOADPATH" ) ) { |
for ( i = 0; ; i++, e = p+1 ) { |
for ( i = 0; ; i++, e = p+1 ) { |
p = (char *)index(e,ENVDELIM); |
p = (char *)index(e,ENVDELIM); |
|
if ( !p ) |
|
break; |
|
} |
|
i += 4; |
|
ASIRLOADPATH=(char **)MALLOC(sizeof(char *)*i); |
|
for ( l = 0; l<i; l++) ASIRLOADPATH[l] = NULL; |
|
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); |
l = p ? p-e : strlen(e); q = (char *)MALLOC(l+1); |
if ( l ) { |
if ( l ) { |
strncpy(q,e,l); q[l] = 0; ASIRLOADPATH[i] = q; |
strncpy(q,e,l); q[l] = 0; ASIRLOADPATH[i] = q; |
Line 133 void env_init() { |
|
Line 221 void env_init() { |
|
if ( !p ) |
if ( !p ) |
break; |
break; |
} |
} |
|
}else{ |
|
ASIRLOADPATH=(char **)MALLOC(sizeof(char *)*3); |
|
ASIRLOADPATH[0] = NULL; |
|
} |
|
|
for ( i = 0; ASIRLOADPATH[i]; i++ ); |
for ( i = 0; ASIRLOADPATH[i]; i++ ); |
ASIRLOADPATH[i] = asir_libdir; |
if (asir_private_dir) ASIRLOADPATH[i++] = asir_private_dir; |
|
if (asir_contrib_dir) ASIRLOADPATH[i++] = asir_contrib_dir; |
|
if (asir_libdir) ASIRLOADPATH[i++] = asir_libdir; |
|
ASIRLOADPATH[i] = NULL; |
} |
} |
|
|
void searchasirpath(name,pathp) |
#if defined(VISUAL) |
char *name; |
#define R_OK 4 |
char **pathp; |
#endif |
|
|
|
void searchasirpath(char *name,char **pathp) |
{ |
{ |
char **p; |
char **p; |
char *q; |
char *q; |
int l; |
size_t l; |
#if !defined(THINK_C) && !defined(VISUAL) |
int ret; |
struct stat sbuf; |
struct stat sbuf; |
|
|
if ( (name[0] == '/') || ( name[0] == '.') || strchr(name,':') |
if ( (name[0] == '/') || ( name[0] == '.') || strchr(name,':') |
|| !ASIRLOADPATH[0] ) { |
|| !ASIRLOADPATH[0] ) { |
if ( access(name,R_OK) >= 0 ) { |
if ( access(name,R_OK) >= 0 ) { |
stat(name,&sbuf); |
ret = stat(name,&sbuf); |
if ( (sbuf.st_mode & S_IFMT) != S_IFDIR ) |
if ( ret == 0 && (sbuf.st_mode & S_IFMT) != S_IFDIR ) |
*pathp = name; |
*pathp = name; |
else |
else |
*pathp = 0; |
*pathp = 0; |
|
|
l = strlen(*p)+strlen(name)+2; |
l = strlen(*p)+strlen(name)+2; |
q = (char *)ALLOCA(l); sprintf(q,"%s/%s",*p,name); |
q = (char *)ALLOCA(l); sprintf(q,"%s/%s",*p,name); |
if ( access(q,R_OK) >= 0 ) { |
if ( access(q,R_OK) >= 0 ) { |
stat(q,&sbuf); |
ret = stat(q,&sbuf); |
if ( (sbuf.st_mode & S_IFMT) != S_IFDIR ) { |
if ( ret == 0 && (sbuf.st_mode & S_IFMT) != S_IFDIR ) { |
*pathp = (char *)MALLOC(l); strcpy(*pathp,q); |
*pathp = (char *)MALLOC(l); strcpy(*pathp,q); |
return; |
return; |
} |
} |
|
|
} |
} |
*pathp = 0; |
*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 '/' |
#define DELIM '/' |
#endif |
|
|
|
void Eungetc(int,FILE *); |
void loadasirfile(char *name0) |
|
|
void loadasirfile(name0) |
|
char *name0; |
|
{ |
{ |
FILE *in; |
FILE *in; |
IN t; |
INFILE t; |
extern char cppname[]; |
extern char cppname[]; |
#if defined(THINK_C) || defined(VISUAL) |
#if defined(VISUAL) |
char tname[BUFSIZ],dname[BUFSIZ],ibuf1[BUFSIZ],ibuf2[BUFSIZ]; |
char ibuf1[BUFSIZ],ibuf2[BUFSIZ]; |
int ac; |
int ac; |
#if defined(__MWERKS__) |
|
char *av[64]; |
|
#else |
|
char *av[BUFSIZ]; |
char *av[BUFSIZ]; |
#endif |
char *p; |
char *p,*c; |
|
FILE *fp; |
FILE *fp; |
char name[BUFSIZ],tname0[BUFSIZ]; |
char dname[BUFSIZ],tname0[BUFSIZ]; |
|
char *name,*tname; |
int encoded; |
int encoded; |
|
static char prefix[BUFSIZ]; |
|
int process_id(); |
|
char CppExe[BUFSIZ]; |
|
char nbuf[BUFSIZ],tnbuf[BUFSIZ]; |
|
STRING rootdir; |
|
void call_exe(char *,char **); |
|
|
#if defined(VISUAL) |
/* create the unique prefix */ |
|
if ( !prefix[0] ) |
|
sprintf(prefix,"asir%d",process_id()); |
|
|
fp = fopen(name0,"rb"); |
fp = fopen(name0,"rb"); |
if ( getc(fp) == 0xff ) { |
if ( getc(fp) == 0xff ) { |
/* encoded file */ |
/* encoded file */ |
fclose(fp); |
fclose(fp); |
sprintf(name,"%s.$$$",name0); |
name = tempnam(NULL,prefix); |
decrypt_file(name0,name); |
decrypt_file(name0,name); |
|
/* the file 'name' created */ |
encoded = 1; |
encoded = 1; |
} else { |
} else { |
fclose(fp); |
fclose(fp); |
strcpy(name,name0); |
name = name0; |
encoded = 0; |
encoded = 0; |
} |
} |
#else |
|
strcpy(name,name0); |
|
#endif |
|
|
|
strcpy(dname,name); |
strcpy(dname,name); |
|
av[0] = "cpp"; |
|
sprintf(nbuf,"\"%s\"",name); |
|
av[1] = nbuf; |
|
tname = tempnam(NULL,prefix); |
|
sprintf(tnbuf,"\"%s\"",tname); |
|
av[2] = tnbuf; |
|
sprintf(ibuf1,"-I\"%s\"",asir_libdir); |
|
av[3] = ibuf1; |
|
av[4] = "-DWINDOWS"; |
|
|
|
/* set the include directory */ |
p = strrchr(dname,DELIM); |
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 ) { |
if ( !p ) { |
sprintf(tname,"%s.___",name); av[5] = 0; ac = 5; |
av[5] = 0; ac = 5; |
} else { |
} else { |
*p++ = 0; |
*p = 0; |
#if defined(VISUAL) |
sprintf(ibuf2,"-I\"%s\"",dname); |
if ( c = strchr(dname,':') ) { |
av[5] = ibuf2; |
*c = 0; |
av[6] = 0; ac = 6; |
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); |
// cpp_main(ac,av); |
|
Pget_rootdir(&rootdir); |
|
sprintf(CppExe,"%s\\bin\\cpp.exe",BDY(rootdir)); |
|
call_exe(CppExe,av); |
|
|
|
/* the file tname created */ |
if ( encoded ) { |
if ( encoded ) { |
unlink(name); |
unlink(name); free(name); |
strcpy(tname0,tname); |
|
sprintf(tname,"%s.###",tname0); |
strcpy(tname0,tname); free(tname); |
|
tname = tempnam(NULL,prefix); |
|
|
encrypt_file(tname0,tname); |
encrypt_file(tname0,tname); |
|
/* the file tname created */ |
unlink(tname0); |
unlink(tname0); |
|
|
in = fopen(tname,"rb"); |
in = fopen(tname,"rb"); |
} else |
} else |
in = fopen(tname,"r"); |
in = fopen(tname,"r"); |
|
|
perror("fopen"); |
perror("fopen"); |
error("load : failed"); |
error("load : failed"); |
} |
} |
t = (IN)MALLOC(sizeof(struct oIN)); |
t = (INFILE)MALLOC(sizeof(struct oINFILE)); |
t->name = (char *)MALLOC(strlen(name)+1); strcpy(t->name,name); |
t->name = (char *)MALLOC(strlen(name0)+1); strcpy(t->name,name0); |
t->tname = (char *)MALLOC(strlen(tname)+1); strcpy(t->tname,tname); |
t->tname = (char *)MALLOC(strlen(tname)+1); strcpy(t->tname,tname); free(tname); |
t->encoded = encoded; |
t->encoded = encoded; |
#if defined(THINK_C) |
|
t->vol = getVol(); |
|
#endif |
|
#else |
#else |
char com[BUFSIZ]; |
char com[BUFSIZ]; |
|
|
|
|
perror("popen"); |
perror("popen"); |
error("load : failed"); |
error("load : failed"); |
} |
} |
t = (IN)MALLOC(sizeof(struct oIN)); |
t = (INFILE)MALLOC(sizeof(struct oINFILE)); |
t->name = (char *)MALLOC(strlen(name0)+1); strcpy(t->name,name0); |
t->name = (char *)MALLOC(strlen(name0)+1); strcpy(t->name,name0); |
#endif |
#endif |
t->fp = in; t->ln = 1; t->next = asir_infile; asir_infile = t; |
t->fp = in; t->ln = 1; t->next = asir_infile; asir_infile = t; |
|
|
reallocarray((char **)&EPVS->va,(int *)&EPVS->asize,(int *)&EPVS->n,(int)sizeof(struct oPV)); |
reallocarray((char **)&EPVS->va,(int *)&EPVS->asize,(int *)&EPVS->n,(int)sizeof(struct oPV)); |
} |
} |
|
|
void execasirfile(name) |
void execasirfile(char *name) |
char *name; |
|
{ |
{ |
loadasirfile(name); |
loadasirfile(name); |
read_exec_file = 1; |
if ( !SETJMP(asir_infile->jmpbuf) ) { |
read_eval_loop(); |
asir_infile->ready_for_longjmp = 1; |
read_exec_file = 0; |
read_eval_loop(); |
|
} |
|
closecurrentinput(); |
} |
} |
|
|
static NODE objfile = 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(char *s) |
|
|
int loadfile(s) |
|
char *s; |
|
{ |
{ |
FILE *in; |
FILE *in; |
|
|
|
|
return 0; |
return 0; |
} |
} |
|
|
int loadfiles(node) NODE node; { return 0; } |
int loadfiles(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] = { |
static unsigned char encrypt_tab[128][2] = { |
{137,40},{1,194},{133,79},{48,20},{254,76},{98,17},{110,233},{19,231}, |
{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}, |
{55,223},{75,65},{178,151},{85,222},{201,46},{51,243},{235,61},{106,113}, |
Line 652 unsigned char decrypt_char(unsigned char c) |
|
Line 452 unsigned char decrypt_char(unsigned char c) |
|
return decrypt_tab[c]; |
return decrypt_tab[c]; |
} |
} |
|
|
void encrypt_file(in,out) |
void encrypt_file(char *in,char *out) |
char *in,*out; |
|
{ |
{ |
FILE *infp,*outfp; |
FILE *infp,*outfp; |
int c; |
int c; |
|
|
c = getc(infp); |
c = getc(infp); |
if ( c == EOF ) |
if ( c == EOF ) |
break; |
break; |
putc(encrypt_char(c),outfp); |
putc(encrypt_char((unsigned char)c),outfp); |
} |
} |
fclose(infp); fclose(outfp); |
fclose(infp); fclose(outfp); |
} |
} |
|
|
void decrypt_file(in,out) |
void decrypt_file(char *in,char *out) |
char *in,*out; |
|
{ |
{ |
FILE *infp,*outfp; |
FILE *infp,*outfp; |
int c; |
int c; |
|
|
c = getc(infp); |
c = getc(infp); |
if ( c == EOF ) |
if ( c == EOF ) |
break; |
break; |
putc(decrypt_char(c),outfp); |
putc(decrypt_char((unsigned char)c),outfp); |
} |
} |
fclose(infp); fclose(outfp); |
fclose(infp); fclose(outfp); |
} |
} |