strconv: fix string builder leaks in format_dec_old, format_es_old, format_fl_old, v_sprintf
parent
1313dcf601
commit
6e4bda3741
|
@ -98,6 +98,9 @@ pub fn format_str(s string, p BF_param) string {
|
||||||
return s.clone()
|
return s.clone()
|
||||||
}
|
}
|
||||||
mut res := strings.new_builder(s.len + dif)
|
mut res := strings.new_builder(s.len + dif)
|
||||||
|
defer {
|
||||||
|
unsafe { res.free() }
|
||||||
|
}
|
||||||
if p.allign == .right {
|
if p.allign == .right {
|
||||||
for i1 := 0; i1 < dif; i1++ {
|
for i1 := 0; i1 < dif; i1++ {
|
||||||
res.write_b(p.pad_ch)
|
res.write_b(p.pad_ch)
|
||||||
|
|
|
@ -28,6 +28,9 @@ pub fn v_printf(str string, pt ...voidptr) {
|
||||||
|
|
||||||
pub fn v_sprintf(str string, pt ...voidptr) string {
|
pub fn v_sprintf(str string, pt ...voidptr) string {
|
||||||
mut res := strings.new_builder(pt.len * 16)
|
mut res := strings.new_builder(pt.len * 16)
|
||||||
|
defer {
|
||||||
|
unsafe { res.free() }
|
||||||
|
}
|
||||||
|
|
||||||
mut i := 0 // main string index
|
mut i := 0 // main string index
|
||||||
mut p_index := 0 // parameter index
|
mut p_index := 0 // parameter index
|
||||||
|
@ -531,6 +534,9 @@ pub fn format_fl_old(f f64, p BF_param) string {
|
||||||
tmp.free()
|
tmp.free()
|
||||||
}
|
}
|
||||||
mut res := strings.new_builder(if p.len0 > fs.len { p.len0 } else { fs.len })
|
mut res := strings.new_builder(if p.len0 > fs.len { p.len0 } else { fs.len })
|
||||||
|
defer {
|
||||||
|
res.free()
|
||||||
|
}
|
||||||
|
|
||||||
mut sign_len_diff := 0
|
mut sign_len_diff := 0
|
||||||
if p.pad_ch == `0` {
|
if p.pad_ch == `0` {
|
||||||
|
@ -580,9 +586,7 @@ pub fn format_fl_old(f f64, p BF_param) string {
|
||||||
|
|
||||||
s.free()
|
s.free()
|
||||||
fs.free()
|
fs.free()
|
||||||
tmp_res := res.str()
|
return res.str()
|
||||||
res.free()
|
|
||||||
return tmp_res
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -595,6 +599,9 @@ pub fn format_es_old(f f64, p BF_param) string {
|
||||||
fs = remove_tail_zeros_old(fs)
|
fs = remove_tail_zeros_old(fs)
|
||||||
}
|
}
|
||||||
mut res := strings.new_builder(if p.len0 > fs.len { p.len0 } else { fs.len })
|
mut res := strings.new_builder(if p.len0 > fs.len { p.len0 } else { fs.len })
|
||||||
|
defer {
|
||||||
|
res.free()
|
||||||
|
}
|
||||||
|
|
||||||
mut sign_len_diff := 0
|
mut sign_len_diff := 0
|
||||||
if p.pad_ch == `0` {
|
if p.pad_ch == `0` {
|
||||||
|
@ -642,9 +649,7 @@ pub fn format_es_old(f f64, p BF_param) string {
|
||||||
}
|
}
|
||||||
s.free()
|
s.free()
|
||||||
fs.free()
|
fs.free()
|
||||||
tmp_res := res.str()
|
return res.str()
|
||||||
res.free()
|
|
||||||
return tmp_res
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -692,6 +697,9 @@ pub fn remove_tail_zeros_old(s string) string {
|
||||||
pub fn format_dec_old(d u64, p BF_param) string {
|
pub fn format_dec_old(d u64, p BF_param) string {
|
||||||
mut s := ''
|
mut s := ''
|
||||||
mut res := strings.new_builder(20)
|
mut res := strings.new_builder(20)
|
||||||
|
defer {
|
||||||
|
unsafe { res.free() }
|
||||||
|
}
|
||||||
mut sign_len_diff := 0
|
mut sign_len_diff := 0
|
||||||
if p.pad_ch == `0` {
|
if p.pad_ch == `0` {
|
||||||
if p.positive {
|
if p.positive {
|
||||||
|
|
Loading…
Reference in New Issue