2021-08-25 14:40:53 +03:00
|
|
|
module os
|
2021-07-23 18:04:36 +03:00
|
|
|
|
|
|
|
pub struct File {
|
|
|
|
pub:
|
|
|
|
fd int
|
|
|
|
pub mut:
|
|
|
|
is_opened bool
|
|
|
|
}
|
|
|
|
|
2021-12-20 16:18:21 +03:00
|
|
|
$if !js_browser {
|
|
|
|
#const $buffer = require('buffer');
|
|
|
|
}
|
2021-07-23 18:04:36 +03:00
|
|
|
// todo(playX): __as_cast is broken here
|
|
|
|
/*
|
|
|
|
pub struct ErrFileNotOpened {
|
|
|
|
msg string = 'os: file not opened'
|
|
|
|
code int
|
|
|
|
}
|
|
|
|
pub struct ErrSizeOfTypeIs0 {
|
|
|
|
msg string = 'os: size of type is 0'
|
|
|
|
code int
|
|
|
|
}
|
|
|
|
fn error_file_not_opened() IError {
|
|
|
|
return IError(&ErrFileNotOpened{})
|
|
|
|
}
|
|
|
|
fn error_size_of_type_0() IError {
|
|
|
|
return IError(&ErrSizeOfTypeIs0{})
|
|
|
|
}
|
|
|
|
*/
|
2022-10-16 09:28:57 +03:00
|
|
|
pub fn open_file(path string, mode string, options ...int) !File {
|
2021-07-23 18:04:36 +03:00
|
|
|
mut res := File{}
|
|
|
|
$if js_node {
|
|
|
|
#if (!options) { options = new array([]); }
|
|
|
|
#let permissions = 0o666
|
|
|
|
#if (options.arr.length > 0) { permissions = options.arr[0]; }
|
|
|
|
#try {
|
|
|
|
#res.fd = new int($fs.openSync(''+path,''+mode,permissions))
|
|
|
|
#} catch (e) {
|
2021-10-20 16:02:21 +03:00
|
|
|
#return error(new string('' + e));
|
2021-07-23 18:04:36 +03:00
|
|
|
#}
|
|
|
|
|
|
|
|
res.is_opened = true
|
|
|
|
} $else {
|
|
|
|
error('cannot open file on non NodeJS runtime')
|
|
|
|
}
|
|
|
|
return res
|
|
|
|
}
|
|
|
|
|
|
|
|
// open tries to open a file for reading and returns back a read-only `File` object.
|
2022-10-16 09:28:57 +03:00
|
|
|
pub fn open(path string) !File {
|
|
|
|
f := open_file(path, 'r')!
|
2021-07-23 18:04:36 +03:00
|
|
|
return f
|
|
|
|
}
|
|
|
|
|
2022-10-16 09:28:57 +03:00
|
|
|
pub fn create(path string) !File {
|
|
|
|
f := open_file(path, 'w')!
|
2021-07-23 18:04:36 +03:00
|
|
|
return f
|
|
|
|
}
|
|
|
|
|
|
|
|
pub fn stdin() File {
|
|
|
|
return File{
|
|
|
|
fd: 0
|
|
|
|
is_opened: true
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
pub fn stdout() File {
|
|
|
|
return File{
|
|
|
|
fd: 1
|
|
|
|
is_opened: true
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
pub fn stderr() File {
|
|
|
|
return File{
|
|
|
|
fd: 2
|
|
|
|
is_opened: true
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2022-10-16 09:28:57 +03:00
|
|
|
pub fn (f &File) read(mut buf []u8) !int {
|
2021-07-23 18:04:36 +03:00
|
|
|
if buf.len == 0 {
|
|
|
|
return 0
|
|
|
|
}
|
|
|
|
mut nbytes := 0
|
|
|
|
#try {
|
2021-10-20 16:02:21 +03:00
|
|
|
#let buffer = $fs.readFileSync(f.val.fd.valueOf());
|
2021-07-23 18:04:36 +03:00
|
|
|
#
|
|
|
|
#for (const val of buffer.values()) { buf.arr[nbytes++] = val; }
|
|
|
|
#}
|
2021-10-20 16:02:21 +03:00
|
|
|
#catch (e) { return error('' + e); }
|
2021-07-23 18:04:36 +03:00
|
|
|
|
|
|
|
return nbytes
|
|
|
|
}
|
|
|
|
|
2022-10-16 09:28:57 +03:00
|
|
|
pub fn (mut f File) write(buf []u8) !int {
|
2021-07-23 18:04:36 +03:00
|
|
|
if !f.is_opened {
|
|
|
|
return error('file is not opened')
|
|
|
|
}
|
|
|
|
mut nbytes := 0
|
2021-10-20 16:02:21 +03:00
|
|
|
#buf.arr.make_copy()
|
|
|
|
#const b = $buffer.Buffer.from(buf.arr.arr.map((x) => x.valueOf()))
|
|
|
|
#try { $fs.writeSync(f.val.fd.valueOf(),b,0,buf.len.valueOf(),0); } catch (e) { return error(new string('' + e)); }
|
2021-07-23 18:04:36 +03:00
|
|
|
|
|
|
|
return nbytes
|
|
|
|
}
|
|
|
|
|
|
|
|
// writeln writes the string `s` into the file, and appends a \n character.
|
|
|
|
// It returns how many bytes were written, including the \n character.
|
2022-10-16 09:28:57 +03:00
|
|
|
pub fn (mut f File) writeln(s string) !int {
|
|
|
|
mut nbytes := f.write(s.bytes())!
|
|
|
|
nbytes += f.write('\n'.bytes())!
|
2021-07-23 18:04:36 +03:00
|
|
|
return nbytes
|
|
|
|
}
|
|
|
|
|
2022-10-16 09:28:57 +03:00
|
|
|
pub fn (mut f File) write_to(pos u64, buf []u8) !int {
|
2021-07-23 18:04:36 +03:00
|
|
|
if !f.is_opened {
|
|
|
|
return error('file is not opened')
|
|
|
|
}
|
|
|
|
mut nbytes := 0
|
2021-10-20 16:02:21 +03:00
|
|
|
#buf.arr.make_copy()
|
|
|
|
#const b = $buffer.Buffer.from(buf.arr.arr.map((x) => x.valueOf()))
|
|
|
|
#try { $fs.writeSync(f.val.fd.valueOf(),b,0,buf.len.valueOf(),pos.valueOf()); } catch (e) { return error(new string('' + e)); }
|
2021-07-23 18:04:36 +03:00
|
|
|
|
|
|
|
return nbytes
|
|
|
|
}
|
|
|
|
|
|
|
|
// write_string writes the string `s` into the file
|
|
|
|
// It returns how many bytes were actually written.
|
2022-10-16 09:28:57 +03:00
|
|
|
pub fn (mut f File) write_string(s string) !int {
|
|
|
|
nbytes := f.write(s.bytes())!
|
2021-07-23 18:04:36 +03:00
|
|
|
return nbytes
|
|
|
|
}
|
2021-08-25 14:40:53 +03:00
|
|
|
|
|
|
|
pub fn (mut f File) close() {
|
2021-10-20 16:02:21 +03:00
|
|
|
#$fs.closeSync(f.valueOf().fd.valueOf())
|
2021-08-25 14:40:53 +03:00
|
|
|
}
|
|
|
|
|
2022-10-16 09:28:57 +03:00
|
|
|
pub fn (mut f File) write_full_buffer(s voidptr, buffer_len usize) ! {}
|
2021-10-20 16:02:21 +03:00
|
|
|
|
2022-10-16 09:28:57 +03:00
|
|
|
pub fn (mut f File) write_array(buffer array) !int {
|
2021-10-20 16:02:21 +03:00
|
|
|
if !f.is_opened {
|
|
|
|
return error('file is not opened')
|
|
|
|
}
|
|
|
|
mut nbytes := 0
|
|
|
|
#buffer.arr.make_copy()
|
|
|
|
#const b = $buffer.Buffer.from(buffer.arr.arr.map((x) => x.valueOf()))
|
|
|
|
#try { $fs.writeSync(f.val.fd.valueOf(),b,0,buffer.len.valueOf(),0); } catch (e) { return error(new string('' + e)); }
|
|
|
|
|
|
|
|
return nbytes
|
|
|
|
}
|