builtin: fix substr()

pull/9325/head
Alexander Medvednikov 2021-03-15 21:16:23 +01:00
parent 77d5fcca59
commit 667a26335f
1 changed files with 9 additions and 9 deletions

View File

@ -604,18 +604,18 @@ fn (s string) substr2(start int, _end int, end_max bool) string {
// Example: assert 'ABCD'.substr(1,3) == 'BC' // Example: assert 'ABCD'.substr(1,3) == 'BC'
pub fn (s string) substr(start int, end int) string { pub fn (s string) substr(start int, end int) string {
$if !no_bounds_checking ? { $if !no_bounds_checking ? {
if start > end || start > s.len || end > s.len || start < 0 || end < 0 {
/* /*
$if debug { $if debug {
if start > end || start > s.len || end > s.len || start < 0 || end < 0 {
println('substr($start, $end) out of bounds (len=$s.len)') println('substr($start, $end) out of bounds (len=$s.len)')
println('s="$s"') println('s="$s"')
print_backtrace() print_backtrace()
return '' return ''
} }
}
*/ */
panic('substr($start, $end) out of bounds (len=$s.len)') panic('substr($start, $end) out of bounds (len=$s.len)')
} }
}
len := end - start len := end - start
if len == s.len { if len == s.len {
return s.clone() return s.clone()