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

os: add windows cp

This commit is contained in:
Trivaxy 2019-11-02 21:37:29 +02:00 committed by Alexander Medvednikov
parent 56e1dac03a
commit 8de2f00294
3 changed files with 37 additions and 6 deletions

View File

@ -71,6 +71,8 @@ fn C.ftell(fp voidptr) int
fn C.getenv(byteptr) byteptr fn C.getenv(byteptr) byteptr
fn C.sigaction(int, voidptr, int) fn C.sigaction(int, voidptr, int)
fn C.GetLastError() u32
// read_bytes reads an amount of bytes from the beginning of the file // read_bytes reads an amount of bytes from the beginning of the file
pub fn (f File) read_bytes(size int) []byte { pub fn (f File) read_bytes(size int) []byte {
return f.read_bytes_at(size, 0) return f.read_bytes_at(size, 0)
@ -126,12 +128,24 @@ pub fn mv(old, new string) {
} }
} }
// TODO implement actual cp() fn C.CopyFile(&u32, &u32, int) int
pub fn cp(old, new string) {
// TODO implement actual cp for linux
pub fn cp(old, new string) ?bool {
$if windows { $if windows {
panic('not implemented') _old := old.replace('/', '\\')
_new := new.replace('/', '\\')
C.CopyFile(_old.to_wide(), _new.to_wide(), false)
result := C.GetLastError()
if result == 0 {
return true
} else {
return error_with_code('failed to copy $old to $new', int(result))
}
} $else { } $else {
os.system('cp $old $new') os.system('cp $old $new')
return true // TODO make it return true or error when cp for linux is implemented
} }
} }

View File

@ -113,6 +113,23 @@ fn test_walk() {
os.rmdir(folder) os.rmdir(folder)
} }
fn test_cp() {
$if windows {
old_file_name := './example.txt'
new_file_name := './new_example.txt'
os.write_file(old_file_name, 'Test data 1 2 3, V is awesome #$%^[]!~')
result := os.cp(old_file_name, new_file_name) or { panic('$err: errcode: $errcode') }
old_file := os.read_file(old_file_name) or { panic(err) }
new_file := os.read_file(new_file_name) or { panic(err) }
assert old_file == new_file
os.rm(old_file_name)
os.rm(new_file_name)
}
}
//fn test_fork() { //fn test_fork() {
// pid := os.fork() // pid := os.fork()
// if pid == 0 { // if pid == 0 {

View File

@ -61,7 +61,7 @@ pub fn ls(path string) ?[]string {
// } // }
// C.FindClose(h_find_dir) // C.FindClose(h_find_dir)
if !dir_exists(path) { if !dir_exists(path) {
return error('ls() couldnt open dir "$path"') return error('ls() couldnt open dir "$path": directory does not exist')
} }
// NOTE: Should eventually have path struct & os dependant path seperator (eg os.PATH_SEPERATOR) // NOTE: Should eventually have path struct & os dependant path seperator (eg os.PATH_SEPERATOR)
// we need to add files to path eg. c:\windows\*.dll or :\windows\* // we need to add files to path eg. c:\windows\*.dll or :\windows\*