mirror of
https://github.com/vlang/v.git
synced 2023-08-10 21:13:21 +03:00
os: minor optimization in os.v (#16791)
This commit is contained in:
parent
b9996619d5
commit
b171102b03
15
vlib/os/os.v
15
vlib/os/os.v
@ -55,7 +55,8 @@ fn executable_fallback() string {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
if !is_abs_path(exepath) {
|
if !is_abs_path(exepath) {
|
||||||
rexepath := exepath.replace_each(['/', path_separator, '\\', path_separator])
|
other_seperator := if path_separator == '/' { '\\' } else { '/' }
|
||||||
|
rexepath := exepath.replace(other_seperator, path_separator)
|
||||||
if rexepath.contains(path_separator) {
|
if rexepath.contains(path_separator) {
|
||||||
exepath = join_path_single(os.wd_at_startup, exepath)
|
exepath = join_path_single(os.wd_at_startup, exepath)
|
||||||
} else {
|
} else {
|
||||||
@ -230,7 +231,8 @@ pub fn dir(opath string) string {
|
|||||||
if opath == '' {
|
if opath == '' {
|
||||||
return '.'
|
return '.'
|
||||||
}
|
}
|
||||||
path := opath.replace_each(['/', path_separator, '\\', path_separator])
|
other_seperator := if path_separator == '/' { '\\' } else { '/' }
|
||||||
|
path := opath.replace(other_seperator, path_separator)
|
||||||
pos := path.last_index(path_separator) or { return '.' }
|
pos := path.last_index(path_separator) or { return '.' }
|
||||||
if pos == 0 && path_separator == '/' {
|
if pos == 0 && path_separator == '/' {
|
||||||
return '/'
|
return '/'
|
||||||
@ -246,7 +248,8 @@ pub fn base(opath string) string {
|
|||||||
if opath == '' {
|
if opath == '' {
|
||||||
return '.'
|
return '.'
|
||||||
}
|
}
|
||||||
path := opath.replace_each(['/', path_separator, '\\', path_separator])
|
other_seperator := if path_separator == '/' { '\\' } else { '/' }
|
||||||
|
path := opath.replace(other_seperator, path_separator)
|
||||||
if path == path_separator {
|
if path == path_separator {
|
||||||
return path_separator
|
return path_separator
|
||||||
}
|
}
|
||||||
@ -262,7 +265,8 @@ pub fn base(opath string) string {
|
|||||||
// file_name will return all characters found after the last occurence of `path_separator`.
|
// file_name will return all characters found after the last occurence of `path_separator`.
|
||||||
// file extension is included.
|
// file extension is included.
|
||||||
pub fn file_name(opath string) string {
|
pub fn file_name(opath string) string {
|
||||||
path := opath.replace_each(['/', path_separator, '\\', path_separator])
|
other_seperator := if path_separator == '/' { '\\' } else { '/' }
|
||||||
|
path := opath.replace(other_seperator, path_separator)
|
||||||
return path.all_after_last(path_separator)
|
return path.all_after_last(path_separator)
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -655,7 +659,8 @@ pub struct MkdirParams {
|
|||||||
|
|
||||||
// mkdir_all will create a valid full path of all directories given in `path`.
|
// mkdir_all will create a valid full path of all directories given in `path`.
|
||||||
pub fn mkdir_all(opath string, params MkdirParams) ! {
|
pub fn mkdir_all(opath string, params MkdirParams) ! {
|
||||||
path := opath.replace('/', path_separator)
|
other_seperator := if path_separator == '/' { '\\' } else { '/' }
|
||||||
|
path := opath.replace(other_seperator, path_separator)
|
||||||
mut p := if path.starts_with(path_separator) { path_separator } else { '' }
|
mut p := if path.starts_with(path_separator) { path_separator } else { '' }
|
||||||
path_parts := path.trim_left(path_separator).split(path_separator)
|
path_parts := path.trim_left(path_separator).split(path_separator)
|
||||||
for subdir in path_parts {
|
for subdir in path_parts {
|
||||||
|
Loading…
Reference in New Issue
Block a user