mirror of
https://github.com/neovim/neovim.git
synced 2024-12-20 03:05:11 -07:00
tests: Stabilize float format and %e in format_luav and format_string
This commit is contained in:
parent
731dc82f8c
commit
ebb33eddd9
@ -750,7 +750,7 @@ describe('api', function()
|
||||
typ = typ .. ('(val=%u)'):format(east_api_node.ivalue)
|
||||
east_api_node.ivalue = nil
|
||||
elseif typ == 'Float' then
|
||||
typ = typ .. ('(val=%e)'):format(east_api_node.fvalue)
|
||||
typ = typ .. format_string('(val=%e)', east_api_node.fvalue)
|
||||
east_api_node.fvalue = nil
|
||||
elseif typ == 'SingleQuotedString' or typ == 'DoubleQuotedString' then
|
||||
typ = format_string('%s(val=%q)', typ, east_api_node.svalue)
|
||||
|
@ -395,6 +395,13 @@ local function dedent(str, leave_indent)
|
||||
return str
|
||||
end
|
||||
|
||||
local function format_float(v)
|
||||
-- On windows exponent appears to have three digits and not two
|
||||
local ret = ('%.6e'):format(v)
|
||||
local l, f, es, e = ret:match('^(%-?%d)%.(%d+)e([+%-])0*(%d%d+)$')
|
||||
return l .. '.' .. f .. 'e' .. es .. e
|
||||
end
|
||||
|
||||
local SUBTBL = {
|
||||
'\\000', '\\001', '\\002', '\\003', '\\004',
|
||||
'\\005', '\\006', '\\007', '\\008', '\\t',
|
||||
@ -468,7 +475,7 @@ format_luav = function(v, indent, opts)
|
||||
if v % 1 == 0 then
|
||||
ret = ('%d'):format(v)
|
||||
else
|
||||
ret = ('%e'):format(v)
|
||||
ret = format_float(v)
|
||||
end
|
||||
elseif type(v) == 'nil' then
|
||||
ret = 'nil'
|
||||
@ -501,7 +508,11 @@ local function format_string(fmt, ...)
|
||||
subfmt = subfmt:sub(1, -2) .. 's'
|
||||
arg = format_luav(arg)
|
||||
end
|
||||
return subfmt:format(arg)
|
||||
if subfmt == '%e' then
|
||||
return format_float(arg)
|
||||
else
|
||||
return subfmt:format(arg)
|
||||
end
|
||||
end)
|
||||
return ret
|
||||
end
|
||||
|
@ -375,7 +375,7 @@ local function eastnode2lua(pstate, eastnode, checked_nodes)
|
||||
elseif typ == 'Integer' then
|
||||
typ = typ .. ('(val=%u)'):format(tonumber(eastnode.data.num.value))
|
||||
elseif typ == 'Float' then
|
||||
typ = typ .. ('(val=%e)'):format(tonumber(eastnode.data.flt.value))
|
||||
typ = typ .. format_string('(val=%e)', tonumber(eastnode.data.flt.value))
|
||||
elseif typ == 'SingleQuotedString' or typ == 'DoubleQuotedString' then
|
||||
if eastnode.data.str.value == nil then
|
||||
typ = typ .. '(val=NULL)'
|
||||
|
Loading…
Reference in New Issue
Block a user