mirror of
https://github.com/bjc/prosody.git
synced 2025-04-03 05:07:42 +03:00
util.mathcompat: Module to ease reuse of math.type()
Mostly to ensure it is available during tests, as util.startup is not invoked there
This commit is contained in:
parent
e64c5e30c2
commit
e2cff34641
7 changed files with 41 additions and 10 deletions
|
@ -19,6 +19,8 @@
|
||||||
-- TODO s/number/integer/ once we have appropriate math.type() compat
|
-- TODO s/number/integer/ once we have appropriate math.type() compat
|
||||||
--
|
--
|
||||||
|
|
||||||
|
if not math.type then require "util.mathcompat" end
|
||||||
|
|
||||||
local st = require "util.stanza";
|
local st = require "util.stanza";
|
||||||
local json = require"util.json"
|
local json = require"util.json"
|
||||||
local pointer = require"util.jsonpointer";
|
local pointer = require"util.jsonpointer";
|
||||||
|
|
|
@ -8,6 +8,8 @@
|
||||||
-- https://json-schema.org/draft/2020-12/json-schema-validation.html
|
-- https://json-schema.org/draft/2020-12/json-schema-validation.html
|
||||||
--
|
--
|
||||||
|
|
||||||
|
if not math.type then require "util.mathcompat" end
|
||||||
|
|
||||||
local json = require"util.json"
|
local json = require"util.json"
|
||||||
local null = json.null;
|
local null = json.null;
|
||||||
|
|
||||||
|
|
15
teal-src/util/mathcompat.tl
Normal file
15
teal-src/util/mathcompat.tl
Normal file
|
@ -0,0 +1,15 @@
|
||||||
|
if not math.type then
|
||||||
|
local enum number_subtype
|
||||||
|
"float" "integer"
|
||||||
|
end
|
||||||
|
local function math_type(t:any) : number_subtype
|
||||||
|
if t is number then
|
||||||
|
if t % 1 == 0 and t ~= t+1 and t ~= t-1 then
|
||||||
|
return "integer"
|
||||||
|
else
|
||||||
|
return "float"
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
_G.math.type = math_type
|
||||||
|
end
|
|
@ -1,5 +1,9 @@
|
||||||
-- This file is generated from teal-src/util/datamapper.lua
|
-- This file is generated from teal-src/util/datamapper.lua
|
||||||
|
|
||||||
|
if not math.type then
|
||||||
|
require("util.mathcompat")
|
||||||
|
end
|
||||||
|
|
||||||
local st = require("util.stanza");
|
local st = require("util.stanza");
|
||||||
local pointer = require("util.jsonpointer");
|
local pointer = require("util.jsonpointer");
|
||||||
|
|
||||||
|
|
13
util/mathcompat.lua
Normal file
13
util/mathcompat.lua
Normal file
|
@ -0,0 +1,13 @@
|
||||||
|
if not math.type then
|
||||||
|
|
||||||
|
local function math_type(t)
|
||||||
|
if type(t) == "number" then
|
||||||
|
if t % 1 == 0 and t ~= t + 1 and t ~= t - 1 then
|
||||||
|
return "integer"
|
||||||
|
else
|
||||||
|
return "float"
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
_G.math.type = math_type
|
||||||
|
end
|
|
@ -21,6 +21,10 @@ local to_hex = require "util.hex".to;
|
||||||
local pcall = pcall;
|
local pcall = pcall;
|
||||||
local envload = require"util.envload".envload;
|
local envload = require"util.envload".envload;
|
||||||
|
|
||||||
|
if not math.type then
|
||||||
|
require "util.mathcompat"
|
||||||
|
end
|
||||||
|
|
||||||
local pos_inf, neg_inf = math.huge, -math.huge;
|
local pos_inf, neg_inf = math.huge, -math.huge;
|
||||||
local m_type = math.type;
|
local m_type = math.type;
|
||||||
|
|
||||||
|
|
|
@ -280,16 +280,7 @@ function startup.init_global_state()
|
||||||
|
|
||||||
-- COMPAT Lua < 5.3
|
-- COMPAT Lua < 5.3
|
||||||
if not math.type then
|
if not math.type then
|
||||||
-- luacheck: ignore 122/math
|
require "util.mathcompat"
|
||||||
function math.type(n)
|
|
||||||
if type(n) == "number" then
|
|
||||||
if n % 1 == 0 and (n + 1 ~= n and n - 1 ~= n) then
|
|
||||||
return "integer"
|
|
||||||
else
|
|
||||||
return "float"
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue