2020-01-23 05:26:30 +03:00
|
|
|
module picohttpparser
|
|
|
|
|
2023-07-12 09:40:16 +03:00
|
|
|
const (
|
|
|
|
// vfmt off
|
|
|
|
g_digits_lut = [
|
|
|
|
`0`,`0`,`0`,`1`,`0`,`2`,`0`,`3`,`0`,`4`,`0`,`5`,`0`,`6`,`0`,`7`,`0`,`8`,`0`,`9`,
|
|
|
|
`1`,`0`,`1`,`1`,`1`,`2`,`1`,`3`,`1`,`4`,`1`,`5`,`1`,`6`,`1`,`7`,`1`,`8`,`1`,`9`,
|
|
|
|
`2`,`0`,`2`,`1`,`2`,`2`,`2`,`3`,`2`,`4`,`2`,`5`,`2`,`6`,`2`,`7`,`2`,`8`,`2`,`9`,
|
|
|
|
`3`,`0`,`3`,`1`,`3`,`2`,`3`,`3`,`3`,`4`,`3`,`5`,`3`,`6`,`3`,`7`,`3`,`8`,`3`,`9`,
|
|
|
|
`4`,`0`,`4`,`1`,`4`,`2`,`4`,`3`,`4`,`4`,`4`,`5`,`4`,`6`,`4`,`7`,`4`,`8`,`4`,`9`,
|
|
|
|
`5`,`0`,`5`,`1`,`5`,`2`,`5`,`3`,`5`,`4`,`5`,`5`,`5`,`6`,`5`,`7`,`5`,`8`,`5`,`9`,
|
|
|
|
`6`,`0`,`6`,`1`,`6`,`2`,`6`,`3`,`6`,`4`,`6`,`5`,`6`,`6`,`6`,`7`,`6`,`8`,`6`,`9`,
|
|
|
|
`7`,`0`,`7`,`1`,`7`,`2`,`7`,`3`,`7`,`4`,`7`,`5`,`7`,`6`,`7`,`7`,`7`,`8`,`7`,`9`,
|
|
|
|
`8`,`0`,`8`,`1`,`8`,`2`,`8`,`3`,`8`,`4`,`8`,`5`,`8`,`6`,`8`,`7`,`8`,`8`,`8`,`9`,
|
|
|
|
`9`,`0`,`9`,`1`,`9`,`2`,`9`,`3`,`9`,`4`,`9`,`5`,`9`,`6`,`9`,`7`,`9`,`8`,`9`,`9`
|
|
|
|
]
|
|
|
|
// vfmt on
|
|
|
|
)
|
2020-01-23 05:26:30 +03:00
|
|
|
|
2023-07-12 09:40:16 +03:00
|
|
|
// u64toa converts `value` to an ascii string and stores it at `buf_start`
|
|
|
|
// then it returns the length of the ascii string (branch lookup table implementation)
|
2023-07-14 17:21:40 +03:00
|
|
|
[direct_array_access; unsafe]
|
|
|
|
pub fn u64toa(buf_start &u8, value u64) !int {
|
2023-07-12 09:40:16 +03:00
|
|
|
mut buf := unsafe { buf_start }
|
|
|
|
// set maximum length to 100MB
|
|
|
|
if value >= 100_000_000 {
|
|
|
|
return error('Maximum size of 100MB exceeded!')
|
|
|
|
}
|
|
|
|
|
|
|
|
v := u32(value)
|
|
|
|
if v < 10_000 {
|
|
|
|
d1 := u32((v / 100) << 1)
|
|
|
|
d2 := u32((v % 100) << 1)
|
|
|
|
unsafe {
|
|
|
|
if v >= 1000 {
|
|
|
|
*buf++ = picohttpparser.g_digits_lut[d1]
|
|
|
|
}
|
|
|
|
if v >= 100 {
|
|
|
|
*buf++ = picohttpparser.g_digits_lut[d1 + 1]
|
|
|
|
}
|
|
|
|
if v >= 10 {
|
|
|
|
*buf++ = picohttpparser.g_digits_lut[d2]
|
|
|
|
}
|
|
|
|
*buf++ = picohttpparser.g_digits_lut[d2 + 1]
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
b := v / 10_000
|
|
|
|
c := v % 10_000
|
|
|
|
|
|
|
|
d1 := u32((b / 100) << 1)
|
|
|
|
d2 := u32((b % 100) << 1)
|
|
|
|
|
|
|
|
d3 := u32((c / 100) << 1)
|
|
|
|
d4 := u32((c % 100) << 1)
|
|
|
|
|
|
|
|
unsafe {
|
|
|
|
if value >= 10_000_000 {
|
|
|
|
*buf++ = picohttpparser.g_digits_lut[d1]
|
|
|
|
}
|
|
|
|
if value >= 1_000_000 {
|
|
|
|
*buf++ = picohttpparser.g_digits_lut[d1 + 1]
|
|
|
|
}
|
|
|
|
if value >= 100_000 {
|
|
|
|
*buf++ = picohttpparser.g_digits_lut[d2]
|
|
|
|
}
|
|
|
|
*buf++ = picohttpparser.g_digits_lut[d2 + 1]
|
|
|
|
|
|
|
|
*buf++ = picohttpparser.g_digits_lut[d3]
|
|
|
|
*buf++ = picohttpparser.g_digits_lut[d3 + 1]
|
|
|
|
*buf++ = picohttpparser.g_digits_lut[d4]
|
|
|
|
*buf++ = picohttpparser.g_digits_lut[d4 + 1]
|
|
|
|
}
|
2020-10-21 12:23:03 +03:00
|
|
|
}
|
2020-01-23 05:26:30 +03:00
|
|
|
|
2023-07-12 09:40:16 +03:00
|
|
|
return unsafe { buf - buf_start }
|
2020-01-23 05:26:30 +03:00
|
|
|
}
|