1
0
mirror of https://github.com/vlang/v.git synced 2023-08-10 21:13:21 +03:00
v/vlib/os/os_nix.c.v

186 lines
3.4 KiB
V
Raw Normal View History

module os
2019-07-01 18:04:09 +03:00
2020-02-03 06:01:39 +03:00
import strings
2019-07-01 18:04:09 +03:00
#include <dirent.h>
#include <unistd.h>
2020-01-21 18:58:47 +03:00
#include <fcntl.h>
2020-06-14 16:46:30 +03:00
#include <sys/utsname.h>
2020-01-21 18:58:47 +03:00
2019-10-24 12:36:57 +03:00
pub const (
2019-10-12 22:18:19 +03:00
path_separator = '/'
2020-05-26 04:17:52 +03:00
path_delimiter = ':'
)
2019-12-31 10:53:53 +03:00
const (
stdin_value = 0
stdout_value = 1
2020-01-05 22:13:35 +03:00
stderr_value = 2
2019-12-31 10:53:53 +03:00
)
2020-06-14 16:46:30 +03:00
struct C.utsname {
mut:
sysname charptr
nodename charptr
release charptr
version charptr
machine charptr
}
fn C.uname(name voidptr) int
2019-12-27 21:10:06 +03:00
fn C.symlink(charptr, charptr) int
2020-06-14 16:46:30 +03:00
pub fn uname() Uname {
mut u := Uname{}
d := &C.utsname( malloc(int(sizeof(C.utsname))) )
if C.uname(d) == 0 {
u.sysname = cstring_to_vstring(d.sysname)
u.nodename = cstring_to_vstring(d.nodename)
u.release = cstring_to_vstring(d.release)
u.version = cstring_to_vstring(d.version)
u.machine = cstring_to_vstring(d.machine)
}
free(d)
return u
}
2020-05-05 16:26:42 +03:00
fn init_os_args(argc int, argv &&byte) []string {
mut args := []string{}
2020-03-21 21:52:19 +03:00
//mut args := []string(make(0, argc, sizeof(string)))
//mut args := []string{len:argc}
2019-10-13 01:50:15 +03:00
for i in 0 .. argc {
2020-03-21 21:52:19 +03:00
//args [i] = string(argv[i])
2019-09-14 23:48:30 +03:00
args << string(argv[i])
2019-11-29 19:14:26 +03:00
}
2019-09-14 23:48:30 +03:00
return args
}
2019-10-17 14:30:05 +03:00
pub fn ls(path string) ?[]string {
mut res := []string{}
dir := C.opendir(path.str)
2019-08-16 15:05:11 +03:00
if isnil(dir) {
2019-10-17 14:30:05 +03:00
return error('ls() couldnt open dir "$path"')
2019-08-16 15:05:11 +03:00
}
2019-12-04 12:19:32 +03:00
mut ent := &C.dirent(0)
2019-12-20 00:29:37 +03:00
// mut ent := &C.dirent{!}
2019-08-16 15:05:11 +03:00
for {
ent = C.readdir(dir)
if isnil(ent) {
break
}
2019-09-15 19:07:40 +03:00
name := tos_clone(byteptr(ent.d_name))
2019-08-16 15:05:11 +03:00
if name != '.' && name != '..' && name != '' {
res << name
}
}
C.closedir(dir)
return res
}
2019-08-17 16:17:43 +03:00
/*
pub fn is_dir(path string) bool {
//$if linux {
//C.syscall(4, path.str) // sys_newstat
//}
2019-08-17 16:17:43 +03:00
dir := C.opendir(path.str)
res := !isnil(dir)
if res {
C.closedir(dir)
}
return res
}
*/
2019-08-17 16:17:43 +03:00
/*
2020-05-17 14:51:18 +03:00
pub fn (mut f File) fseek(pos, mode int) {
}
*/
2020-01-05 22:13:35 +03:00
2019-08-17 16:17:43 +03:00
// mkdir creates a new directory with the specified path.
2019-11-23 19:55:18 +03:00
pub fn mkdir(path string) ?bool {
2019-12-20 00:29:37 +03:00
if path == '.' {
return true
}
2020-03-20 18:41:18 +03:00
apath := os.real_path(path)
/*
$if linux {
2020-01-05 22:13:35 +03:00
$if !android {
ret := C.syscall(sys_mkdir, apath.str, 511)
if ret == -1 {
2020-01-21 18:58:47 +03:00
return error(posix_get_error_msg(C.errno))
2020-01-05 22:13:35 +03:00
}
return true
2019-12-31 10:53:53 +03:00
}
}
*/
2019-12-07 15:51:00 +03:00
r := C.mkdir(apath.str, 511)
2019-11-23 19:55:18 +03:00
if r == -1 {
2020-01-21 18:58:47 +03:00
return error(posix_get_error_msg(C.errno))
2019-11-23 19:55:18 +03:00
}
return true
2019-08-17 16:17:43 +03:00
}
2019-11-07 16:01:17 +03:00
// exec starts the specified command, waits for it to complete, and returns its output.
pub fn exec(cmd string) ?Result {
2019-12-20 00:29:37 +03:00
// if cmd.contains(';') || cmd.contains('&&') || cmd.contains('||') || cmd.contains('\n') {
// return error(';, &&, || and \\n are not allowed in shell commands')
// }
2019-11-07 16:01:17 +03:00
pcmd := '$cmd 2>&1'
f := vpopen(pcmd)
if isnil(f) {
return error('exec("$cmd") failed')
}
2020-02-03 06:01:39 +03:00
buf := [4096]byte
mut res := strings.new_builder(1024)
for C.fgets(charptr(buf), 4096, f) != 0 {
2020-05-18 22:38:06 +03:00
bufbp := byteptr(buf)
res.write_bytes( bufbp, vstrlen(bufbp) )
2019-11-07 16:01:17 +03:00
}
soutput := res.str()
//res.free()
2019-11-07 16:01:17 +03:00
exit_code := vpclose(f)
2019-12-20 00:29:37 +03:00
// if exit_code != 0 {
// return error(res)
// }
return Result{
exit_code: exit_code
2020-05-18 22:38:06 +03:00
output: soutput
2019-11-07 16:01:17 +03:00
}
}
2019-12-20 00:29:37 +03:00
2019-12-27 21:10:06 +03:00
pub fn symlink(origin, target string) ?bool {
res := C.symlink(origin.str, target.str)
2020-01-05 22:13:35 +03:00
if res == 0 {
return true
}
2020-01-21 18:58:47 +03:00
return error(posix_get_error_msg(C.errno))
}
// get_error_msg return error code representation in string.
pub fn get_error_msg(code int) string {
return posix_get_error_msg(code)
2019-12-27 21:10:06 +03:00
}
2020-05-17 14:51:18 +03:00
pub fn (mut f File) close() {
if !f.opened {
return
}
f.opened = false
/*
$if linux {
2020-01-05 22:13:35 +03:00
$if !android {
C.syscall(sys_close, f.fd)
return
}
}
*/
C.fflush(f.cfile)
C.fclose(f.cfile)
}
2020-05-31 13:57:26 +03:00
pub fn debugger_present() bool {
return false
}