mirror of
https://github.com/vlang/v.git
synced 2023-08-10 21:13:21 +03:00
all: fix immutable fn args
This commit is contained in:
parent
76def48f01
commit
52f473d1c7
@ -666,6 +666,7 @@ fn (p mut Parser) fn_args(f mut Fn) {
|
|||||||
}
|
}
|
||||||
f.args << int_arg
|
f.args << int_arg
|
||||||
}
|
}
|
||||||
|
// `(int, string, int)`
|
||||||
// Just register fn arg types
|
// Just register fn arg types
|
||||||
types_only := p.tok == .mul || (p.peek() == .comma && p.table.known_type(p.lit)) || p.peek() == .rpar// (int, string)
|
types_only := p.tok == .mul || (p.peek() == .comma && p.table.known_type(p.lit)) || p.peek() == .rpar// (int, string)
|
||||||
if types_only {
|
if types_only {
|
||||||
@ -684,12 +685,12 @@ fn (p mut Parser) fn_args(f mut Fn) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
// (a int, b,c string) syntax
|
// `(a int, b, c string)` syntax
|
||||||
for p.tok != .rpar {
|
for p.tok != .rpar {
|
||||||
mut names := [
|
mut names := [
|
||||||
p.check_name()
|
p.check_name()
|
||||||
]
|
]
|
||||||
// a,b,c int syntax
|
// `a,b,c int` syntax
|
||||||
for p.tok == .comma {
|
for p.tok == .comma {
|
||||||
p.check(.comma)
|
p.check(.comma)
|
||||||
p.fspace()
|
p.fspace()
|
||||||
|
@ -694,13 +694,13 @@ pub fn (s string) ustring_tmp() ustring {
|
|||||||
return res
|
return res
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn (u ustring) substr(start, end int) string {
|
pub fn (u ustring) substr(_start, _end int) string {
|
||||||
start = u.runes[start]
|
start := u.runes[_start]
|
||||||
if end >= u.runes.len {
|
end := if _end >= u.runes.len {
|
||||||
end = u.s.len
|
u.s.len
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
end = u.runes[end]
|
u.runes[_end]
|
||||||
}
|
}
|
||||||
return u.s.substr(start, end)
|
return u.s.substr(start, end)
|
||||||
}
|
}
|
||||||
|
@ -102,7 +102,8 @@ pub fn exp(a f64) f64 {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// digits returns an array of the digits of n in the given base.
|
// digits returns an array of the digits of n in the given base.
|
||||||
pub fn digits(n, base int) []int {
|
pub fn digits(_n, base int) []int {
|
||||||
|
mut n := _n
|
||||||
mut sign := 1
|
mut sign := 1
|
||||||
if n < 0 {
|
if n < 0 {
|
||||||
sign = -1
|
sign = -1
|
||||||
@ -132,6 +133,7 @@ pub fn exp2(a f64) f64 {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// factorial calculates the factorial of the provided value.
|
// factorial calculates the factorial of the provided value.
|
||||||
|
// TODO bring back once multiple value functions are implemented
|
||||||
fn recursive_product( n int, current_number_ptr &int) int{
|
fn recursive_product( n int, current_number_ptr &int) int{
|
||||||
mut m := n / 2
|
mut m := n / 2
|
||||||
if (m == 0){
|
if (m == 0){
|
||||||
|
24
vlib/os/os.v
24
vlib/os/os.v
@ -337,8 +337,8 @@ fn popen(path string) *FILE {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// exec starts the specified command, waits for it to complete, and returns its output.
|
// exec starts the specified command, waits for it to complete, and returns its output.
|
||||||
pub fn exec(cmd string) string {
|
pub fn exec(_cmd string) string {
|
||||||
cmd = '$cmd 2>&1'
|
cmd := '$_cmd 2>&1'
|
||||||
f := popen(cmd)
|
f := popen(cmd)
|
||||||
if isnil(f) {
|
if isnil(f) {
|
||||||
// TODO optional or error code
|
// TODO optional or error code
|
||||||
@ -397,19 +397,19 @@ pub fn unsetenv(name string) int {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// `file_exists` returns true if `path` exists.
|
// `file_exists` returns true if `path` exists.
|
||||||
pub fn file_exists(path string) bool {
|
pub fn file_exists(_path string) bool {
|
||||||
$if windows {
|
$if windows {
|
||||||
path = path.replace('/', '\\')
|
path := _path.replace('/', '\\')
|
||||||
return C._waccess( path.to_wide(), 0 ) != -1
|
return C._waccess(path.to_wide(), 0) != -1
|
||||||
} $else {
|
} $else {
|
||||||
return C.access( path.str, 0 ) != -1
|
return C.access(_path.str, 0 ) != -1
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn dir_exists(path string) bool {
|
pub fn dir_exists(path string) bool {
|
||||||
$if windows {
|
$if windows {
|
||||||
path = path.replace('/', '\\')
|
_path := path.replace('/', '\\')
|
||||||
attr := int(C.GetFileAttributes(path.to_wide()))
|
attr := int(C.GetFileAttributes(_path.to_wide()))
|
||||||
if attr == INVALID_FILE_ATTRIBUTES {
|
if attr == INVALID_FILE_ATTRIBUTES {
|
||||||
return false
|
return false
|
||||||
}
|
}
|
||||||
@ -431,13 +431,13 @@ pub fn dir_exists(path string) bool {
|
|||||||
// mkdir creates a new directory with the specified path.
|
// mkdir creates a new directory with the specified path.
|
||||||
pub fn mkdir(path string) {
|
pub fn mkdir(path string) {
|
||||||
$if windows {
|
$if windows {
|
||||||
path = path.replace('/', '\\')
|
_path := path.replace('/', '\\')
|
||||||
// Windows doesnt recursively create the folders
|
// Windows doesnt recursively create the folders
|
||||||
// so we need to help it out here
|
// so we need to help it out here
|
||||||
if path.last_index('\\') != -1 {
|
if _path.last_index('\\') != -1 {
|
||||||
mkdir(path.all_before_last('\\'))
|
mkdir(_path.all_before_last('\\'))
|
||||||
}
|
}
|
||||||
C.CreateDirectory(path.to_wide(), 0)
|
C.CreateDirectory(_path.to_wide(), 0)
|
||||||
}
|
}
|
||||||
$else {
|
$else {
|
||||||
C.mkdir(path.str, 511)// S_IRWXU | S_IRWXG | S_IRWXO
|
C.mkdir(path.str, 511)// S_IRWXU | S_IRWXG | S_IRWXO
|
||||||
|
@ -34,7 +34,7 @@ pub fn (b Builder) str() string {
|
|||||||
return string(b.buf, b.len)
|
return string(b.buf, b.len)
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn (b Builder) cut(n int) {
|
pub fn (b mut Builder) cut(n int) {
|
||||||
b.len -= n
|
b.len -= n
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user