version 1.22, 2006/02/08 02:11:19 |
version 1.24, 2006/11/08 07:34:33 |
|
|
* 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.21 2006/02/03 03:55:18 noro Exp $ |
* $OpenXM: OpenXM_contrib2/asir2000/builtin/file.c,v 1.23 2006/09/13 02:26:13 noro Exp $ |
*/ |
*/ |
#include "ca.h" |
#include "ca.h" |
#include "parse.h" |
#include "parse.h" |
Line 76 void Pbsave(), Pbload(), Pbload27(); |
|
Line 76 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(), Pput_byte(); |
void Popen_file(), Pclose_file(), Pget_line(), Pget_byte(), Pput_byte(); |
|
void Pput_word(), Pget_word(); |
void Ppurge_stdin(); |
void Ppurge_stdin(); |
void Pimport(); |
void Pimport(); |
|
|
Line 88 struct ftab file_tab[] = { |
|
Line 89 struct ftab file_tab[] = { |
|
{"close_file",Pclose_file,1}, |
{"close_file",Pclose_file,1}, |
{"get_byte",Pget_byte,1}, |
{"get_byte",Pget_byte,1}, |
{"put_byte",Pput_byte,2}, |
{"put_byte",Pput_byte,2}, |
|
{"get_word",Pget_word,1}, |
|
{"put_word",Pput_word,2}, |
{"get_line",Pget_line,-1}, |
{"get_line",Pget_line,-1}, |
{"remove_file",Premove_file,1}, |
{"remove_file",Premove_file,1}, |
{"access",Paccess,1}, |
{"access",Paccess,1}, |
Line 235 void Pget_byte(NODE arg,Q *rp) |
|
Line 238 void Pget_byte(NODE arg,Q *rp) |
|
error("get_byte : invalid argument"); |
error("get_byte : invalid argument"); |
} |
} |
|
|
|
void Pget_word(NODE arg,Q *rp) |
|
{ |
|
int i,c; |
|
FILE *fp; |
|
|
|
asir_assert(ARG0(arg),O_N,"get_word"); |
|
i = QTOS((Q)ARG0(arg)); |
|
if ( fp = file_ptrs[i] ) { |
|
if ( feof(fp) ) { |
|
error("get_word : end of file"); |
|
return; |
|
} |
|
read_int(fp,&c); |
|
STOQ(c,*rp); |
|
} else |
|
error("get_word : invalid argument"); |
|
} |
|
|
void Pput_byte(NODE arg,Obj *rp) |
void Pput_byte(NODE arg,Obj *rp) |
{ |
{ |
int i,j,c; |
int i,j,c; |
Line 261 void Pput_byte(NODE arg,Obj *rp) |
|
Line 282 void Pput_byte(NODE arg,Obj *rp) |
|
*rp = obj; |
*rp = obj; |
} |
} |
|
|
|
void Pput_word(NODE arg,Obj *rp) |
|
{ |
|
int i,c; |
|
FILE *fp; |
|
Obj obj; |
|
|
|
asir_assert(ARG0(arg),O_N,"put_word"); |
|
asir_assert(ARG1(arg),O_N,"put_word"); |
|
i = QTOS((Q)ARG0(arg)); |
|
if ( !(fp = file_ptrs[i]) ) |
|
error("put_word : invalid argument"); |
|
|
|
obj = (Q)ARG1(arg); |
|
c = QTOS((Q)obj); |
|
write_int(fp,&c); |
|
*rp = obj; |
|
} |
|
|
void Pload(NODE arg,Q *rp) |
void Pload(NODE arg,Q *rp) |
{ |
{ |
int ret = 0; |
int ret = 0; |
char *name,*name0; |
char *name,*name0; |
char errbuf[BUFSIZ]; |
char errbuf[BUFSIZ]; |
|
|
|
if ( !arg ) error("load : invalid argument"); |
if ( ARG0(arg) ) { |
if ( ARG0(arg) ) { |
switch (OID(ARG0(arg))) { |
switch (OID(ARG0(arg))) { |
case O_STR: |
case O_STR: |