2. The Input/Output library
the i/o library implements basic input/output routines.
2.1. Squirrel API
2.1.1. Global Symbols
- dofile(path[, raiseerror])
compiles a squirrel script or loads a precompiled one and executes it. returns the value returned by the script or null if no value is returned. if the optional parameter ‘raiseerror’ is true, the compiler error handler is invoked in case of a syntax error. If raiseerror is omitted or set to false, the compiler error handler is not invoked. When squirrel is compiled in Unicode mode the function can handle different character encodings, UTF8 with and without prefix and UCS-2 prefixed(both big endian an little endian). If the source stream is not prefixed UTF8 encoding is used as default.
- loadfile(path[, raiseerror])
compiles a squirrel script or loads a precompiled one an returns it as as function. if the optional parameter ‘raiseerror’ is true, the compiler error handler is invoked in case of a syntax error. If raiseerror is omitted or set to false, the compiler error handler is not invoked. When squirrel is compiled in Unicode mode the function can handle different character encodings, UTF8 with and without prefix and UCS-2 prefixed(both big endian an little endian). If the source stream is not prefixed UTF8 encoding is used as default.
- writeclosuretofile(destpath, closure)
serializes a closure to a bytecode file (destpath). The serialized file can be loaded using loadfile() and dofile().
- stderr
File object bound on the os standard error stream
- stdin
File object bound on the os standard input stream
- stdout
File object bound on the os standard output stream
2.1.2. The file class
The file object implements a stream on a operating system file.
- class file(path, patten)
It’s constructor imitates the behaviour of the C runtime function fopen for eg.
local myfile = file("test.xxx","wb+");
creates a file with read/write access in the current directory.
- file.close()
closes the file.
- file.eos()
returns a non null value if the read/write pointer is at the end of the stream.
- file.flush()
flushes the stream.return a value != null if succeeded, otherwise returns null
- file.len()
returns the length of the stream
- file.readblob(size)
- Arguments
size (
int()
) – number of bytes to read
read n bytes from the stream and returns them as blob
- file.readn(type)
- Arguments
type (
int()
) – type of the number to read
reads a number from the stream according to the type parameter.
type can have the following values:
parameter |
return description |
return type |
---|---|---|
‘l’ |
processor dependent, 32bits on 32bits processors, 64bits on 64bits processors |
integer |
‘i’ |
32bits number |
integer |
‘s’ |
16bits signed integer |
integer |
‘w’ |
16bits unsigned integer |
integer |
‘c’ |
8bits signed integer |
integer |
‘b’ |
8bits unsigned integer |
integer |
‘f’ |
32bits float |
float |
‘d’ |
64bits float |
float |
- file.resize(size)
- Arguments
size (
int()
) – the new size of the blob in bytes
resizes the blob to the specified size
- file.seek(offset[, origin])
- Arguments
offset (
int()
) – indicates the number of bytes from origin.origin (
int()
) –origin of the seek
’b’
beginning of the stream
’c’
current location
’e’
end of the stream
Moves the read/write pointer to a specified location.
Note
If origin is omitted the parameter is defaulted as ‘b’(beginning of the stream).
- file.tell()
returns the read/write pointer absolute position
- file.writeblob(src)
- Arguments
src (
blob()
) – the source blob containing the data to be written
writes a blob in the stream
- file.writen(n, type)
- Arguments
n (
number()
) – the value to be writtentype (
int()
) – type of the number to write
writes a number in the stream formatted according to the type pamraeter
type can have the following values:
parameter |
return description |
---|---|
‘i’ |
32bits number |
‘s’ |
16bits signed integer |
‘w’ |
16bits unsigned integer |
‘c’ |
8bits signed integer |
‘b’ |
8bits unsigned integer |
‘f’ |
32bits float |
‘d’ |
64bits float |
2.2. C API
-
SQRESULT sqstd_register_iolib(HSQUIRRELVM v)
- Parameters
v (HSQUIRRELVM) – the target VM
- Returns
an SQRESULT
- Remarks
The function aspects a table on top of the stack where to register the global library functions.
initialize and register the io library in the given VM.
2.2.1. File Object
-
SQRESULT sqstd_createfile(HSQUIRRELVM v, SQFILE file, SQBool owns)
- Parameters
v (HSQUIRRELVM) – the target VM
file (SQFILE) – the stream that will be rapresented by the file object
owns (SQBool) – if different true the stream will be automatically closed when the newly create file object is destroyed.
- Returns
an SQRESULT
creates a file object bound to the SQFILE passed as parameter and pushes it in the stack
-
SQRESULT sqstd_getfile(HSQUIRRELVM v, SQInteger idx, SQFILE *file)
- Parameters
v (HSQUIRRELVM) – the target VM
idx (SQInteger) – and index in the stack
file (SQFILE*) – A pointer to a SQFILE handle that will store the result
- Returns
an SQRESULT
retrieve the pointer of a stream handle from an arbitrary position in the stack.
2.2.2. Script loading and serialization
-
SQRESULT sqstd_loadfile(HSQUIRRELVM v, const SQChar *filename, SQBool printerror)
- Parameters
v (HSQUIRRELVM) – the target VM
filename (SQChar*) – path of the script that has to be loaded
printerror (SQBool) – if true the compiler error handler will be called if a error occurs
- Returns
an SQRESULT
Compiles a squirrel script or loads a precompiled one an pushes it as closure in the stack. When squirrel is compiled in Unicode mode the function can handle different character encodings, UTF8 with and without prefix and UCS-2 prefixed(both big endian an little endian). If the source stream is not prefixed UTF8 encoding is used as default.
-
SQRESULT sqstd_dofile(HSQUIRRELVM v, const SQChar *filename, SQBool retval, SQBool printerror)
- Parameters
v (HSQUIRRELVM) – the target VM
filename (SQChar*) – path of the script that has to be loaded
retval (SQBool) – if true the function will push the return value of the executed script in the stack.
printerror (SQBool) – if true the compiler error handler will be called if a error occurs
- Returns
an SQRESULT
- Remarks
the function expects a table on top of the stack that will be used as ‘this’ for the execution of the script. The ‘this’ parameter is left untouched in the stack.
Compiles a squirrel script or loads a precompiled one and executes it. Optionally pushes the return value of the executed script in the stack. When squirrel is compiled in unicode mode the function can handle different character encodings, UTF8 with and without prefix and UCS-2 prefixed(both big endian an little endian). If the source stream is not prefixed, UTF8 encoding is used as default.
sq_pushroottable(v); //push the root table(were the globals of the script will are stored) sqstd_dofile(v, _SC("test.nut"), SQFalse, SQTrue);// also prints syntax errors if any
-
SQRESULT sqstd_writeclosuretofile(HSQUIRRELVM v, const SQChar *filename)
- Parameters
v (HSQUIRRELVM) – the target VM
filename (SQChar*) – destination path of serialized closure
- Returns
an SQRESULT
serializes the closure at the top position in the stack as bytecode in the file specified by the parameter filename. If a file with the same name already exists, it will be overwritten.