os: realpath potential fix

pull/2773/head
Alexander Medvednikov 2019-11-15 01:07:38 +03:00
parent bf669012e7
commit bd97dc0134
2 changed files with 11 additions and 3 deletions

View File

@ -25,6 +25,8 @@ fn backtrace_symbols_fd(voidptr, int, int)
// <libproc.h> // <libproc.h>
fn proc_pidpath(int, voidptr, int) int fn proc_pidpath(int, voidptr, int) int
fn C.realpath(byteptr, byteptr) &char
// Windows // Windows

View File

@ -833,9 +833,15 @@ pub fn realpath(fpath string) string {
res = int( C._fullpath( fullpath, fpath.str, MAX_PATH ) ) res = int( C._fullpath( fullpath, fpath.str, MAX_PATH ) )
} }
$else{ $else{
// here we want an int==0 if realpath failed, in which case if fpath.len != strlen(fpath.str) {
// realpath would return NULL, and !isnil(NULL) would be false==0 l := strlen(fpath.str)
res = int( !isnil(C.realpath( fpath.str, fullpath )) ) println('FIXME realpath diff len $fpath.len strlen=$l')
}
ret := C.realpath(fpath.str, fullpath)
if ret == 0 {
return fpath
}
return string(fullpath)
} }
if res != 0 { if res != 0 {
return string(fullpath, vstrlen(fullpath)) return string(fullpath, vstrlen(fullpath))