open_file, close_file, get_line, get_byte, put_byte, purge_stdinopen_file() : integer (fild id); close_file() : 1; get_line() : string; get_byte(), put_byte() : integer
open_file() opens a file.
If mode is not specified, a file is opened for reading.
If mode is specified, it is used as the mode specification for
C standard I/O function fopen(). For example "w" requests
that the file is truncated to zero length or created for writing.
"a" requests that the file is opened for writing or created 
if it does not exist.
The stream pointer is set at the end of the file.
If successful, it returns a non-negative integer as the file descriptor.
Otherwise the system error function is called.
Unnecessary files should be closed by close_file().
If the special file name unix://stdin or unix://stdout or unix://stderr
is given, it returns the file descriptor for the standard input or
the standard output or the standard error stream respectively.
The mode argument is ignored in this case.
get_line() reads a line from an opened file and returns the
line as a string. If no argument is supplied, it reads a line from the
standard input.
get_byte() reads a byte from an opened file and returns the
it as an integer.
put_byte() writes a byte from an opened file and returns the
the byte as an integer.
get_line() call after reading the end of file returns
an integer 0.
sub_str(), eval_str().
purge_stdin() clears the buffer for the standard input.
When a function receives a character string from get_line(),
this functions should be called in advance in order to avoid 
an incorrect behavior which is caused by the characters already
exists in the buffer.
[185] Id = open_file("test");
0
[186] get_line(Id);
12345
[187] get_line(Id);
67890
[188] get_line(Id);
0
[189] type(@@);
0
[190] close_file(Id);
1
[191] open_file("test");
1
[192] get_line(1);   
12345
[193] get_byte(1);
54                   /* the ASCII code of '6' */
[194] get_line(1);
7890                 /* the rest of the last line */
[195] def test() { return get_line(); }
[196] def test1() { purge_stdin(); return get_line(); }
[197] test();
                     /* a remaining newline character has been read */
                     /* returns immediately */
[198] test1();
123;                 /* input from a keyboard */
123;                 /* returned value */
[199] 
eval_str, section str_len, str_chr, sub_str.
Go to the first, previous, next, last section, table of contents.