version 1.11, 2000/12/05 01:24:50 |
version 1.38, 2018/03/29 01:32:50 |
|
|
* DEVELOPER SHALL HAVE NO LIABILITY IN CONNECTION WITH THE USE, |
* DEVELOPER SHALL HAVE NO LIABILITY IN CONNECTION WITH THE USE, |
* PERFORMANCE OR NON-PERFORMANCE OF THE SOFTWARE. |
* PERFORMANCE OR NON-PERFORMANCE OF THE SOFTWARE. |
* |
* |
* $OpenXM: OpenXM_contrib2/asir2000/builtin/file.c,v 1.10 2000/11/13 01:48:12 noro Exp $ |
* $OpenXM: OpenXM_contrib2/asir2000/builtin/file.c,v 1.37 2017/09/02 04:04:41 ohara Exp $ |
*/ |
*/ |
#include "ca.h" |
#include "ca.h" |
#include "parse.h" |
#include "parse.h" |
|
#include "ox.h" |
#include "base.h" |
#include "base.h" |
|
#include <stdlib.h> |
|
#if !defined(VISUAL) && !defined(__MINGW32__) |
#include "unistd.h" |
#include "unistd.h" |
#if PARI |
#endif |
|
#if defined(PARI) |
#include "genpari.h" |
#include "genpari.h" |
#endif |
#endif |
|
|
#if defined(VISUAL) |
#if defined(VISUAL) || defined(__MINGW32__) |
#include <windows.h> |
#include <windows.h> |
#include <process.h> |
#include <process.h> |
|
#include <io.h> |
/* #define ECGEN_KEYNAME "SoftWare\\Fujitsu\\WinECgen\\1.00.000" */ |
/* #define ECGEN_KEYNAME "SoftWare\\Fujitsu\\WinECgen\\1.00.000" */ |
#define ECGEN_KEYNAME "SoftWare\\Fujitsu\\FSEcParamGen\\V1.0L10" |
#define ECGEN_KEYNAME "SoftWare\\Fujitsu\\FSEcParamGen\\V1.0L10" |
#define ASIR_KEYNAME "SoftWare\\Fujitsu\\Asir\\1999.03.31" |
#define ASIR_KEYNAME "SoftWare\\Fujitsu\\Asir\\1999.03.31" |
|
#define R_OK 0x04 |
#endif |
#endif |
|
|
|
void Psprintf(NODE,STRING *); |
|
|
void Pget_rootdir(); |
void Pget_rootdir(); |
void Paccess(),Premove_file(); |
void Paccess(),Premove_file(); |
void Pbsave_enc(), Pbload_enc(); |
void Pbsave_enc(), Pbload_enc(); |
Line 71 void Pload(), Pwhich(), Ploadfiles(), Poutput(); |
|
Line 79 void Pload(), Pwhich(), Ploadfiles(), Poutput(); |
|
void Pbsave(), Pbload(), Pbload27(); |
void Pbsave(), Pbload(), Pbload27(); |
void Pbsave_compat(), Pbload_compat(); |
void Pbsave_compat(), Pbload_compat(); |
void Pbsave_cmo(), Pbload_cmo(); |
void Pbsave_cmo(), Pbload_cmo(); |
void Popen_file(), Pclose_file(), Pget_line(), Pget_byte(); |
void Popen_file(), Pclose_file(), Pget_line(), Pget_byte(), Pput_byte(); |
|
void Pput_word(), Pget_word(); |
void Ppurge_stdin(); |
void Ppurge_stdin(); |
|
void Pfprintf(); |
|
void Pimport(); |
|
void Pgetpid(); |
|
|
extern int des_encryption; |
extern int des_encryption; |
extern char *asir_libdir; |
extern char *asir_libdir; |
|
|
struct ftab file_tab[] = { |
struct ftab file_tab[] = { |
{"purge_stdin",Ppurge_stdin,0}, |
{"fprintf",Pfprintf,-99999999}, |
{"open_file",Popen_file,1}, |
{"purge_stdin",Ppurge_stdin,0}, |
{"close_file",Pclose_file,1}, |
{"open_file",Popen_file,-2}, |
{"get_byte",Pget_byte,1}, |
{"close_file",Pclose_file,1}, |
{"get_line",Pget_line,-1}, |
{"get_byte",Pget_byte,1}, |
{"remove_file",Premove_file,1}, |
{"put_byte",Pput_byte,2}, |
{"access",Paccess,1}, |
{"get_word",Pget_word,1}, |
{"load",Pload,-1}, |
{"put_word",Pput_word,2}, |
{"which",Pwhich,1}, |
{"get_line",Pget_line,-1}, |
{"loadfiles",Ploadfiles,1}, |
{"remove_file",Premove_file,1}, |
{"output",Poutput,-1}, |
{"access",Paccess,1}, |
{"bsave",Pbsave,2}, |
{"load",Pload,-1}, |
{"bload",Pbload,1}, |
{"import",Pimport,-1}, |
{"get_rootdir",Pget_rootdir,0}, |
{"which",Pwhich,1}, |
#if defined(VISUAL) && defined(DES_ENC) |
{"loadfiles",Ploadfiles,1}, |
{"bsave_enc",Pbsave_enc,2}, |
{"output",Poutput,-1}, |
{"bload_enc",Pbload_enc,1}, |
{"bsave",Pbsave,2}, |
|
{"bload",Pbload,1}, |
|
{"get_rootdir",Pget_rootdir,0}, |
|
#if defined(DES_ENC) |
|
{"bsave_enc",Pbsave_enc,2}, |
|
{"bload_enc",Pbload_enc,1}, |
#endif |
#endif |
{"bload27",Pbload27,1}, |
{"bload27",Pbload27,1}, |
{"bsave_compat",Pbsave_compat,2}, |
{"bsave_compat",Pbsave_compat,2}, |
{"bload_compat",Pbload_compat,1}, |
{"bload_compat",Pbload_compat,1}, |
{"bsave_cmo",Pbsave_cmo,2}, |
{"bsave_cmo",Pbsave_cmo,2}, |
{"bload_cmo",Pbload_cmo,1}, |
{"bload_cmo",Pbload_cmo,1}, |
{0,0,0}, |
{"getpid",Pgetpid,0}, |
|
{0,0,0}, |
}; |
}; |
|
|
static FILE *file_ptrs[BUFSIZ]; |
static FILE *file_ptrs[BUFSIZ]; |
|
|
void Ppurge_stdin(rp) |
void Pfprintf(NODE arg,pointer *rp) |
Q *rp; |
|
{ |
{ |
purge_stdin(stdin); |
FILE *fp; |
*rp = 0; |
STRING s; |
|
asir_assert(ARG0(arg),O_N,"fprintf"); |
|
fp = file_ptrs[QTOS((Q)ARG0(arg))]; |
|
if ( !fp ) { |
|
error("fprintf : invalid argument"); |
|
} |
|
arg = NEXT(arg); |
|
if ( arg ) { |
|
Psprintf(arg,&s); |
|
fputs(BDY(s),fp); |
|
/* fflush(fp); */ |
|
} |
|
*rp = 0; |
|
return; |
} |
} |
|
|
void Popen_file(arg,rp) |
void Ppurge_stdin(Q *rp) |
NODE arg; |
|
Q *rp; |
|
{ |
{ |
char *name; |
purge_stdin(stdin); |
FILE *fp; |
*rp = 0; |
char errbuf[BUFSIZ]; |
} |
int i; |
|
|
|
asir_assert(ARG0(arg),O_STR,"open_file"); |
void Popen_file(NODE arg,Q *rp) |
for ( i = 0; i < BUFSIZ && file_ptrs[i]; i++ ); |
{ |
if ( i == BUFSIZ ) |
char *name; |
error("open_file : too many open files"); |
FILE *fp; |
name = BDY((STRING)ARG0(arg)); |
char errbuf[BUFSIZ]; |
fp = fopen(name,"r"); |
int i; |
if ( !fp ) { |
|
sprintf(errbuf,"open_file : \"%s\" not found",name); |
asir_assert(ARG0(arg),O_STR,"open_file"); |
error(errbuf); |
for ( i = 0; i < BUFSIZ && file_ptrs[i]; i++ ); |
} |
if ( i == BUFSIZ ) |
file_ptrs[i] = fp; |
error("open_file : too many open files"); |
STOQ(i,*rp); |
name = BDY((STRING)ARG0(arg)); |
|
if (strcmp(name,"unix://stdin") == 0) { |
|
fp = stdin; |
|
}else if (strcmp(name,"unix://stdout") == 0) { |
|
fp = stdout; |
|
}else if (strcmp(name,"unix://stderr") == 0) { |
|
fp = stderr; |
|
}else{ |
|
if ( argc(arg) == 2 ) { |
|
asir_assert(ARG1(arg),O_STR,"open_file"); |
|
fp = fopen(name,BDY((STRING)ARG1(arg))); |
|
} else |
|
fp = fopen(name,"rb"); |
|
} |
|
if ( !fp ) { |
|
sprintf(errbuf,"open_file : cannot open \"%s\"",name); |
|
error(errbuf); |
|
} |
|
file_ptrs[i] = fp; |
|
STOQ(i,*rp); |
} |
} |
|
|
void Pclose_file(arg,rp) |
void Pclose_file(NODE arg,Q *rp) |
NODE arg; |
|
Q *rp; |
|
{ |
{ |
int i; |
int i; |
|
|
asir_assert(ARG0(arg),O_N,"close_file"); |
asir_assert(ARG0(arg),O_N,"close_file"); |
i = QTOS((Q)ARG0(arg)); |
i = QTOS((Q)ARG0(arg)); |
if ( file_ptrs[i] ) { |
if ( file_ptrs[i] ) { |
fclose(file_ptrs[i]); |
fclose(file_ptrs[i]); |
file_ptrs[i] = 0; |
file_ptrs[i] = 0; |
} else |
} else |
error("close_file : invalid argument"); |
error("close_file : invalid argument"); |
*rp = ONE; |
*rp = ONE; |
} |
} |
|
|
void Pget_line(arg,rp) |
void Pget_line(NODE arg,STRING *rp) |
NODE arg; |
|
STRING *rp; |
|
{ |
{ |
int i,j,c; |
int i,j,c; |
FILE *fp; |
FILE *fp; |
fpos_t head; |
fpos_t head; |
char *str; |
char *str; |
char buf[BUFSIZ]; |
char buf[BUFSIZ]; |
|
|
if ( !arg ) { |
if ( !arg ) { |
#if defined(VISUAL_LIB) |
#if defined(VISUAL_LIB) |
get_string(buf,sizeof(buf)); |
get_string(buf,sizeof(buf)); |
#else |
#else |
fgets(buf,sizeof(buf),stdin); |
fgets(buf,sizeof(buf),stdin); |
#endif |
#endif |
i = strlen(buf); |
i = strlen(buf); |
str = (char *)MALLOC_ATOMIC(i+1); |
str = (char *)MALLOC_ATOMIC(i+1); |
strcpy(str,buf); |
strcpy(str,buf); |
MKSTR(*rp,str); |
MKSTR(*rp,str); |
return; |
return; |
} |
} |
|
|
asir_assert(ARG0(arg),O_N,"get_line"); |
asir_assert(ARG0(arg),O_N,"get_line"); |
i = QTOS((Q)ARG0(arg)); |
i = QTOS((Q)ARG0(arg)); |
if ( fp = file_ptrs[i] ) { |
if ( fp = file_ptrs[i] ) { |
if ( feof(fp) ) { |
if ( feof(fp) ) { |
*rp = 0; |
*rp = 0; |
return; |
return; |
} |
} |
fgetpos(fp,&head); |
fgetpos(fp,&head); |
j = 0; |
j = 0; |
while ( 1 ) { |
while ( 1 ) { |
c = getc(fp); |
c = getc(fp); |
if ( c == EOF ) { |
if ( c == EOF ) { |
if ( !j ) { |
if ( !j ) { |
*rp = 0; |
*rp = 0; |
return; |
return; |
} else |
} else |
break; |
break; |
} |
} |
j++; |
j++; |
if ( c == '\n' ) |
if ( c == '\n' ) |
break; |
break; |
} |
} |
fsetpos(fp,&head); |
fsetpos(fp,&head); |
str = (char *)MALLOC_ATOMIC(j+1); |
str = (char *)MALLOC_ATOMIC(j+1); |
fgets(str,j+1,fp); |
fgets(str,j+1,fp); |
MKSTR(*rp,str); |
for ( i = 0; i < j; i++ ) |
} else |
if ( str[i] == '\r' ) { |
error("get_line : invalid argument"); |
str[i] = '\n'; |
|
str[i+1] = 0; |
|
break; |
|
} |
|
MKSTR(*rp,str); |
|
} else |
|
error("get_line : invalid argument"); |
} |
} |
|
|
void Pget_byte(arg,rp) |
void Pget_byte(NODE arg,Q *rp) |
NODE arg; |
|
Q *rp; |
|
{ |
{ |
int i,c; |
int i,c; |
FILE *fp; |
FILE *fp; |
|
|
asir_assert(ARG0(arg),O_N,"get_byte"); |
asir_assert(ARG0(arg),O_N,"get_byte"); |
i = QTOS((Q)ARG0(arg)); |
i = QTOS((Q)ARG0(arg)); |
if ( fp = file_ptrs[i] ) { |
if ( fp = file_ptrs[i] ) { |
if ( feof(fp) ) { |
if ( feof(fp) ) { |
STOQ(-1,*rp); |
STOQ(-1,*rp); |
return; |
return; |
} |
} |
c = getc(fp); |
c = getc(fp); |
STOQ(c,*rp); |
STOQ(c,*rp); |
} else |
} else |
error("get_byte : invalid argument"); |
error("get_byte : invalid argument"); |
} |
} |
|
|
void Pload(arg,rp) |
void Pget_word(NODE arg,Q *rp) |
NODE arg; |
|
Q *rp; |
|
{ |
{ |
int ret = 0; |
int i,c; |
char *name,*name0; |
FILE *fp; |
char errbuf[BUFSIZ]; |
|
|
|
if ( ARG0(arg) ) { |
asir_assert(ARG0(arg),O_N,"get_word"); |
switch (OID(ARG0(arg))) { |
i = QTOS((Q)ARG0(arg)); |
case O_STR: |
if ( fp = file_ptrs[i] ) { |
name0 = BDY((STRING)ARG0(arg)); |
if ( feof(fp) ) { |
searchasirpath(name0,&name); |
error("get_word : end of file"); |
if ( !name ) { |
return; |
sprintf(errbuf,"load : \"%s\" not found in the search path",name0); |
} |
error(errbuf); |
read_int(fp,&c); |
} |
STOQ(c,*rp); |
ret = loadfile(name); |
} else |
if ( !ret ) { |
error("get_word : invalid argument"); |
sprintf(errbuf,"load : \"%s\" could not be loaded",name); |
|
error(errbuf); |
|
} |
|
break; |
|
default: |
|
error("load : invalid argument"); |
|
break; |
|
} |
|
} |
|
STOQ(ret,*rp); |
|
} |
} |
|
|
void Pwhich(arg,rp) |
void Pput_byte(NODE arg,Obj *rp) |
NODE arg; |
|
STRING *rp; |
|
{ |
{ |
char *name; |
int i,j,c; |
STRING str; |
FILE *fp; |
|
Obj obj; |
|
TB tb; |
|
|
switch (OID(ARG0(arg))) { |
asir_assert(ARG0(arg),O_N,"put_byte"); |
case O_STR: |
i = QTOS((Q)ARG0(arg)); |
searchasirpath(BDY((STRING)ARG0(arg)),&name); |
if ( !(fp = file_ptrs[i]) ) |
break; |
error("put_byte : invalid argument"); |
default: |
|
name = 0; |
obj = (Obj)ARG1(arg); |
break; |
if ( !obj || OID(obj) == O_N ) { |
} |
c = QTOS((Q)obj); |
if ( name ) { |
putc(c,fp); |
MKSTR(str,name); *rp = str; |
} else if ( OID(obj) == O_STR ) |
} else |
fputs(BDY((STRING)obj),fp); |
*rp = 0; |
else if ( OID(obj) == O_TB ) { |
|
tb = (TB)obj; |
|
for ( j = 0; j < tb->next; j++ ) |
|
fputs(tb->body[j],fp); |
|
} |
|
*rp = obj; |
} |
} |
|
|
void Ploadfiles(arg,rp) |
void Pput_word(NODE arg,Obj *rp) |
NODE arg; |
|
Q *rp; |
|
{ |
{ |
int ret; |
int i,c; |
|
FILE *fp; |
|
Obj obj; |
|
|
if ( ARG0(arg) ) |
asir_assert(ARG0(arg),O_N,"put_word"); |
if ( OID(ARG0(arg)) != O_LIST ) |
asir_assert(ARG1(arg),O_N,"put_word"); |
ret = 0; |
i = QTOS((Q)ARG0(arg)); |
else |
if ( !(fp = file_ptrs[i]) ) |
ret = loadfiles(BDY((LIST)ARG0(arg))); |
error("put_word : invalid argument"); |
else |
|
ret = 0; |
obj = (Q)ARG1(arg); |
STOQ(ret,*rp); |
c = QTOS((Q)obj); |
|
write_int(fp,&c); |
|
*rp = obj; |
} |
} |
|
|
void Poutput(arg,rp) |
void Pload(NODE arg,Q *rp) |
NODE arg; |
|
Q *rp; |
|
{ |
{ |
#if PARI |
int ret = 0; |
extern FILE *outfile; |
char *name,*name0; |
|
char errbuf[BUFSIZ]; |
|
|
|
if ( !arg ) error("load : invalid argument"); |
|
if ( ARG0(arg) ) { |
|
switch (OID(ARG0(arg))) { |
|
case O_STR: |
|
name0 = BDY((STRING)ARG0(arg)); |
|
searchasirpath(name0,&name); |
|
if ( !name ) { |
|
sprintf(errbuf,"load : \"%s\" not found in the search path",name0); |
|
error(errbuf); |
|
} |
|
execasirfile(name); |
|
break; |
|
default: |
|
error("load : invalid argument"); |
|
break; |
|
} |
|
} |
|
STOQ(ret,*rp); |
|
} |
|
|
|
NODE imported_files; |
|
|
|
void Pimport(NODE arg,Q *rp) |
|
{ |
|
char *name; |
|
NODE t,p,opt; |
|
|
|
name = BDY((STRING)ARG0(arg)); |
|
for ( t = imported_files; t; t = NEXT(t) ) |
|
if ( !strcmp((char *)BDY(t),name) ) break; |
|
if ( !t ) { |
|
Pload(arg,rp); |
|
MKNODE(t,name,imported_files); |
|
imported_files = t; |
|
return; |
|
} else if ( current_option ) { |
|
for ( opt = current_option; opt; opt = NEXT(opt) ) { |
|
p = BDY((LIST)BDY(opt)); |
|
if ( !strcmp(BDY((STRING)BDY(p)),"reimport") && BDY(NEXT(p)) ) { |
|
Pload(arg,rp); |
|
return; |
|
} |
|
} |
|
} |
|
*rp = 0; |
|
} |
|
|
|
void Pwhich(NODE arg,STRING *rp) |
|
{ |
|
char *name; |
|
STRING str; |
|
|
|
switch (OID(ARG0(arg))) { |
|
case O_STR: |
|
searchasirpath(BDY((STRING)ARG0(arg)),&name); |
|
break; |
|
default: |
|
name = 0; |
|
break; |
|
} |
|
if ( name ) { |
|
MKSTR(str,name); *rp = str; |
|
} else |
|
*rp = 0; |
|
} |
|
|
|
void Ploadfiles(NODE arg,Q *rp) |
|
{ |
|
int ret; |
|
|
|
if ( ARG0(arg) ) |
|
if ( OID(ARG0(arg)) != O_LIST ) |
|
ret = 0; |
|
else |
|
ret = loadfiles(BDY((LIST)ARG0(arg))); |
|
else |
|
ret = 0; |
|
STOQ(ret,*rp); |
|
} |
|
|
|
void Poutput(NODE arg,Q *rp) |
|
{ |
|
#if defined(PARI) |
|
extern FILE *outfile; |
#endif |
#endif |
FILE *fp; |
FILE *fp; |
|
|
fflush(asir_out); |
fflush(asir_out); |
if ( asir_out != stdout ) |
if ( asir_out != stdout ) |
fclose(asir_out); |
fclose(asir_out); |
switch ( argc(arg) ) { |
switch ( argc(arg) ) { |
case 0: |
case 0: |
fp = stdout; break; |
fp = stdout; break; |
case 1: |
case 1: |
asir_assert(ARG0(arg),O_STR,"output"); |
asir_assert(ARG0(arg),O_STR,"output"); |
fp = fopen(((STRING)ARG0(arg))->body,"a+"); |
fp = fopen(((STRING)ARG0(arg))->body,"a+"); |
if ( !fp ) |
if ( !fp ) |
error("output : invalid filename"); |
error("output : invalid filename"); |
break; |
break; |
} |
} |
#if PARI |
#if defined(PARI) |
pari_outfile = |
pari_outfile = |
#endif |
#endif |
asir_out = fp; |
asir_out = fp; |
*rp = ONE; |
*rp = ONE; |
} |
} |
|
|
extern int ox_file_io; |
extern int ox_file_io; |
|
|
void Pbsave(arg,rp) |
void Pbsave(NODE arg,Q *rp) |
NODE arg; |
|
Q *rp; |
|
{ |
{ |
FILE *fp; |
FILE *fp; |
VL vl,t; |
VL vl,t; |
|
|
asir_assert(ARG1(arg),O_STR,"bsave"); |
asir_assert(ARG1(arg),O_STR,"bsave"); |
get_vars_recursive(ARG0(arg),&vl); |
get_vars_recursive(ARG0(arg),&vl); |
for ( t = vl; t; t = NEXT(t) ) |
for ( t = vl; t; t = NEXT(t) ) |
if ( t->v->attr == (pointer)V_UC ) |
if ( t->v->attr == (pointer)V_UC ) |
error("bsave : not implemented"); |
error("bsave : not implemented"); |
fp = fopen(BDY((STRING)ARG1(arg)),"wb"); |
fp = fopen(BDY((STRING)ARG1(arg)),"wb"); |
if ( !fp ) |
if ( !fp ) |
error("bsave : invalid filename"); |
error("bsave : invalid filename"); |
ox_file_io = 1; /* network byte order is used */ |
ox_file_io = 1; /* network byte order is used */ |
savevl(fp,vl); |
savevl(fp,vl); |
saveobj(fp,ARG0(arg)); |
saveobj(fp,ARG0(arg)); |
fclose(fp); |
fclose(fp); |
ox_file_io = 0; |
ox_file_io = 0; |
*rp = ONE; |
*rp = ONE; |
} |
} |
|
|
void Pbload(arg,rp) |
void Pbload(NODE arg,Obj *rp) |
NODE arg; |
|
Obj *rp; |
|
{ |
{ |
FILE *fp; |
FILE *fp; |
|
|
asir_assert(ARG0(arg),O_STR,"bload"); |
asir_assert(ARG0(arg),O_STR,"bload"); |
fp = fopen(BDY((STRING)ARG0(arg)),"rb"); |
fp = fopen(BDY((STRING)ARG0(arg)),"rb"); |
if ( !fp ) |
if ( !fp ) |
error("bload : invalid filename"); |
error("bload : invalid filename"); |
ox_file_io = 1; /* network byte order is used */ |
ox_file_io = 1; /* network byte order is used */ |
loadvl(fp); |
loadvl(fp); |
loadobj(fp,rp); |
loadobj(fp,rp); |
fclose(fp); |
fclose(fp); |
ox_file_io = 0; |
ox_file_io = 0; |
} |
} |
|
|
void Pbsave_cmo(arg,rp) |
void Pbsave_cmo(NODE arg,Q *rp) |
NODE arg; |
|
Q *rp; |
|
{ |
{ |
FILE *fp; |
FILE *fp; |
VL vl,t; |
|
|
|
asir_assert(ARG1(arg),O_STR,"bsave_cmo"); |
asir_assert(ARG1(arg),O_STR,"bsave_cmo"); |
fp = fopen(BDY((STRING)ARG1(arg)),"wb"); |
fp = fopen(BDY((STRING)ARG1(arg)),"wb"); |
if ( !fp ) |
if ( !fp ) |
error("bsave_cmo : invalid filename"); |
error("bsave_cmo : invalid filename"); |
ox_file_io = 1; /* network byte order is used */ |
ox_file_io = 1; /* network byte order is used */ |
write_cmo(fp,ARG0(arg)); |
write_cmo(fp,ARG0(arg)); |
fclose(fp); |
fclose(fp); |
ox_file_io = 0; |
ox_file_io = 0; |
*rp = ONE; |
*rp = ONE; |
} |
} |
|
|
void Pbload_cmo(arg,rp) |
void Pbload_cmo(NODE arg,Obj *rp) |
NODE arg; |
|
Obj *rp; |
|
{ |
{ |
FILE *fp; |
FILE *fp; |
|
|
asir_assert(ARG0(arg),O_STR,"bload_cmo"); |
asir_assert(ARG0(arg),O_STR,"bload_cmo"); |
fp = fopen(BDY((STRING)ARG0(arg)),"rb"); |
fp = fopen(BDY((STRING)ARG0(arg)),"rb"); |
if ( !fp ) |
if ( !fp ) |
error("bload_cmo : invalid filename"); |
error("bload_cmo : invalid filename"); |
ox_file_io = 1; /* network byte order is used */ |
ox_file_io = 1; /* network byte order is used */ |
read_cmo(fp,rp); |
read_cmo(fp,rp); |
fclose(fp); |
fclose(fp); |
ox_file_io = 0; |
ox_file_io = 0; |
} |
} |
|
|
static struct oSTRING rootdir; |
static struct oSTRING rootdir; |
|
|
#if defined(VISUAL) |
#if defined(VISUAL) || defined(__MINGW32__) |
void get_rootdir(name,len) |
static void chop_delim(char *s) |
char *name; |
|
int len; |
|
{ |
{ |
LONG ret; |
int n=strlen(s); |
HKEY hOpenKey; |
if(n>1 && s[n-1]=='\\') { |
DWORD Type; |
s[n-1]=0; |
char *slash; |
} |
|
|
if ( rootdir.body ) { |
|
strcpy(name,rootdir.body); |
|
return; |
|
} |
|
name[0] = 0; |
|
ret = RegOpenKeyEx(HKEY_LOCAL_MACHINE, ECGEN_KEYNAME, 0, |
|
KEY_QUERY_VALUE, &hOpenKey); |
|
if ( ret != ERROR_SUCCESS ) |
|
ret = RegOpenKeyEx(HKEY_LOCAL_MACHINE, ASIR_KEYNAME, 0, |
|
KEY_QUERY_VALUE, &hOpenKey); |
|
if( ret == ERROR_SUCCESS ) { |
|
RegQueryValueEx(hOpenKey, "Directory", NULL, &Type, name, &len); |
|
RegCloseKey(hOpenKey); |
|
} else { |
|
GetCurrentDirectory(len,name); |
|
slash = strrchr(name,'\\'); |
|
if ( slash ) |
|
*slash = 0; |
|
} |
|
} |
} |
|
|
void set_rootdir(name) |
void get_rootdir(char *name,int len) |
char *name; |
|
{ |
{ |
static char DirName[BUFSIZ]; |
LONG ret; |
|
HKEY hOpenKey; |
|
DWORD Type; |
|
char drive[_MAX_DRIVE], dir0[_MAX_DIR], dir[_MAX_DIR]; |
|
char fullname[_MAX_PATH]; |
|
|
strcpy(DirName,name); |
if ( rootdir.body ) { |
rootdir.id = O_STR; |
strcpy_s(name,len,rootdir.body); |
rootdir.body = DirName; |
return; |
asir_libdir = DirName; |
} |
/* XXX */ |
if ( GetModuleFileName(NULL,fullname,_MAX_PATH) ) { |
env_init(); |
_splitpath(fullname,drive,dir0,NULL,NULL); |
|
chop_delim(dir0); |
|
_splitpath(dir0,NULL,dir,NULL,NULL); |
|
chop_delim(dir); |
|
strcpy_s(name,len,drive); |
|
strcat_s(name,len,dir); |
|
return; |
|
} |
|
name[0] = 0; |
|
ret = RegOpenKeyEx(HKEY_LOCAL_MACHINE, ECGEN_KEYNAME, 0, |
|
KEY_QUERY_VALUE, &hOpenKey); |
|
if ( ret != ERROR_SUCCESS ) |
|
ret = RegOpenKeyEx(HKEY_LOCAL_MACHINE, ASIR_KEYNAME, 0, |
|
KEY_QUERY_VALUE, &hOpenKey); |
|
if( ret == ERROR_SUCCESS ) { |
|
RegQueryValueEx(hOpenKey, "Directory", NULL, &Type, name, &len); |
|
RegCloseKey(hOpenKey); |
|
} else { |
|
GetCurrentDirectory(_MAX_PATH,fullname); |
|
_splitpath(fullname,drive,dir,NULL,NULL); |
|
chop_delim(dir); |
|
strcpy_s(name,len,drive); |
|
strcat_s(name,len,dir); |
|
} |
} |
} |
|
|
|
void set_rootdir(char *name) |
|
{ |
|
static char DirName[BUFSIZ]; |
|
|
|
strcpy(DirName,name); |
|
rootdir.id = O_STR; |
|
rootdir.body = DirName; |
|
asir_libdir = DirName; |
|
/* XXX */ |
|
env_init(); |
|
} |
|
|
#else |
#else |
void get_rootdir(name,len) |
void get_rootdir(char *name,int len) |
char *name; |
|
int len; |
|
{ |
{ |
strcpy(name,asir_libdir); |
strcpy(name,asir_libdir); |
} |
} |
|
|
void set_rootdir(name) |
void set_rootdir(char *name) |
char *name; |
|
{ |
{ |
static char DirName[BUFSIZ]; |
static char DirName[BUFSIZ]; |
|
|
strcpy(DirName,name); |
strcpy(DirName,name); |
asir_libdir = DirName; |
asir_libdir = DirName; |
/* XXX */ |
/* XXX */ |
env_init(); |
env_init(); |
} |
} |
|
|
#endif |
#endif |
|
|
void Pget_rootdir(rp) |
void Pget_rootdir(STRING *rp) |
STRING *rp; |
|
{ |
{ |
static char DirName[BUFSIZ]; |
static char DirName[BUFSIZ]; |
int DirNameLen; |
|
|
|
if ( !rootdir.body ) { |
if ( !rootdir.body ) { |
get_rootdir(DirName,sizeof(DirName)); |
get_rootdir(DirName,sizeof(DirName)); |
rootdir.id = O_STR; |
rootdir.id = O_STR; |
rootdir.body = DirName; |
rootdir.body = DirName; |
} |
} |
*rp = &rootdir; |
*rp = &rootdir; |
} |
} |
|
|
#if defined(VISUAL) && defined(DES_ENC) |
void Pgetpid(Q *rp) |
void Pbsave_enc(arg,rp) |
|
NODE arg; |
|
Obj *rp; |
|
{ |
{ |
init_deskey(); |
int id; |
des_encryption = 1; |
|
Pbsave(arg,rp); |
#if defined(VISUAL) || defined(__MINGW32__) |
des_encryption = 0; |
id = GetCurrentProcessId(); |
|
#else |
|
id = getpid(); |
|
#endif |
|
STOQ(id,*rp); |
} |
} |
|
|
void Pbload_enc(arg,rp) |
#if defined(DES_ENC) |
NODE arg; |
void Pbsave_enc(NODE arg,Obj *rp) |
Obj *rp; |
|
{ |
{ |
init_deskey(); |
init_deskey(); |
des_encryption = 1; |
des_encryption = 1; |
Pbload(arg,rp); |
Pbsave(arg,rp); |
des_encryption = 0; |
des_encryption = 0; |
} |
} |
|
|
|
void Pbload_enc(NODE arg,Obj *rp) |
|
{ |
|
init_deskey(); |
|
des_encryption = 1; |
|
Pbload(arg,rp); |
|
des_encryption = 0; |
|
} |
#endif |
#endif |
|
|
void Pbload27(arg,rp) |
void Pbload27(NODE arg,Obj *rp) |
NODE arg; |
|
Obj *rp; |
|
{ |
{ |
FILE *fp; |
FILE *fp; |
Obj r; |
Obj r; |
|
|
asir_assert(ARG0(arg),O_STR,"bload27"); |
asir_assert(ARG0(arg),O_STR,"bload27"); |
fp = fopen(BDY((STRING)ARG0(arg)),"rb"); |
fp = fopen(BDY((STRING)ARG0(arg)),"rb"); |
if ( !fp ) |
if ( !fp ) |
error("bload : invalid filename"); |
error("bload : invalid filename"); |
loadvl(fp); |
loadvl(fp); |
loadobj(fp,&r); |
loadobj(fp,&r); |
fclose(fp); |
fclose(fp); |
bobjtoobj(BASE27,r,rp); |
bobjtoobj(BASE27,r,rp); |
} |
} |
|
|
void Pbsave_compat(arg,rp) |
void Pbsave_compat(NODE arg,Q *rp) |
NODE arg; |
|
Q *rp; |
|
{ |
{ |
FILE *fp; |
FILE *fp; |
VL vl,t; |
VL vl,t; |
|
|
asir_assert(ARG1(arg),O_STR,"bsave_compat"); |
asir_assert(ARG1(arg),O_STR,"bsave_compat"); |
get_vars_recursive(ARG0(arg),&vl); |
get_vars_recursive(ARG0(arg),&vl); |
for ( t = vl; t; t = NEXT(t) ) |
for ( t = vl; t; t = NEXT(t) ) |
if ( t->v->attr == (pointer)V_UC ) |
if ( t->v->attr == (pointer)V_UC ) |
error("bsave : not implemented"); |
error("bsave : not implemented"); |
fp = fopen(BDY((STRING)ARG1(arg)),"wb"); |
fp = fopen(BDY((STRING)ARG1(arg)),"wb"); |
if ( !fp ) |
if ( !fp ) |
error("bsave : invalid filename"); |
error("bsave : invalid filename"); |
/* indicator of an asir32 file */ |
/* indicator of an asir32 file */ |
putw(0,fp); putw(0,fp); |
putw(0,fp); putw(0,fp); |
savevl(fp,vl); |
savevl(fp,vl); |
saveobj(fp,ARG0(arg)); |
saveobj(fp,ARG0(arg)); |
fclose(fp); |
fclose(fp); |
*rp = ONE; |
*rp = ONE; |
} |
} |
|
|
void Pbload_compat(arg,rp) |
void Pbload_compat(NODE arg,Obj *rp) |
NODE arg; |
|
Obj *rp; |
|
{ |
{ |
FILE *fp; |
FILE *fp; |
unsigned int hdr[2]; |
unsigned int hdr[2]; |
Obj r; |
Obj r; |
int c; |
int c; |
|
|
asir_assert(ARG0(arg),O_STR,"bload_compat"); |
asir_assert(ARG0(arg),O_STR,"bload_compat"); |
fp = fopen(BDY((STRING)ARG0(arg)),"rb"); |
fp = fopen(BDY((STRING)ARG0(arg)),"rb"); |
if ( !fp ) |
if ( !fp ) |
error("bload : invalid filename"); |
error("bload : invalid filename"); |
fread(hdr,sizeof(unsigned int),2,fp); |
fread(hdr,sizeof(unsigned int),2,fp); |
if ( !hdr[0] && !hdr[1] ) { |
if ( !hdr[0] && !hdr[1] ) { |
/* asir32 file or asir27 0 */ |
/* asir32 file or asir27 0 */ |
c = fgetc(fp); |
c = fgetc(fp); |
if ( c == EOF ) { |
if ( c == EOF ) { |
/* asir27 0 */ |
/* asir27 0 */ |
*rp = 0; |
*rp = 0; |
} else { |
} else { |
/* asir32 file */ |
/* asir32 file */ |
ungetc(c,fp); |
ungetc(c,fp); |
loadvl(fp); |
loadvl(fp); |
loadobj(fp,rp); |
loadobj(fp,rp); |
} |
} |
} else { |
} else { |
/* asir27 file */ |
/* asir27 file */ |
rewind(fp); |
rewind(fp); |
loadvl(fp); |
loadvl(fp); |
loadobj(fp,&r); |
loadobj(fp,&r); |
bobjtoobj(BASE27,r,rp); |
bobjtoobj(BASE27,r,rp); |
} |
} |
fclose(fp); |
fclose(fp); |
} |
} |
|
|
void Premove_file(arg,rp) |
void Premove_file(NODE arg,Q *rp) |
NODE arg; |
|
Q *rp; |
|
{ |
{ |
unlink((char *)BDY((STRING)ARG0(arg))); |
unlink((char *)BDY((STRING)ARG0(arg))); |
*rp = ONE; |
*rp = ONE; |
} |
} |
|
|
void Paccess(arg,rp) |
void Paccess(NODE arg,Q *rp) |
NODE arg; |
|
Q *rp; |
|
{ |
{ |
char *name; |
if ( access(BDY((STRING)ARG0(arg)),R_OK) >= 0 ) |
STRING str; |
*rp = ONE; |
|
else |
#if defined(VISUAL) |
*rp = 0; |
if ( access(BDY((STRING)ARG0(arg)),04) >= 0 ) |
|
#else |
|
if ( access(BDY((STRING)ARG0(arg)),R_OK) >= 0 ) |
|
#endif |
|
*rp = ONE; |
|
else |
|
*rp = 0; |
|
} |
} |
|
|
#if defined(VISUAL) |
#if defined(VISUAL) || defined(__MINGW32__) |
int process_id() |
int process_id() |
{ |
{ |
return GetCurrentProcessId(); |
return GetCurrentProcessId(); |
} |
} |
|
|
void call_exe(name,av) |
void call_exe(char *name,char **av) |
char *name; |
|
char **av; |
|
{ |
{ |
_spawnv(_P_WAIT,name,av); |
_spawnv(_P_WAIT,name,av); |
} |
} |
#endif |
#endif |