diff options
author | SoniEx2 <endermoneymod@gmail.com> | 2024-06-19 23:44:42 -0300 |
---|---|---|
committer | SoniEx2 <endermoneymod@gmail.com> | 2024-06-19 23:48:25 -0300 |
commit | 13ba6740870d99749f0341b5a38e1e9213162647 (patch) | |
tree | 860aa0171f97ca97a6fa9d7bffa04db39d85ae3b | |
parent | 70a7abacbb36783fb77025814242faf32a6c8a47 (diff) |
Tokenize numbers as strings
"Fixes" Lua 5.2 support, but makes certain number formats non-portable, for example hex floats will not work before Lua 5.3.
-rw-r--r-- | src/cratera/compiler.lua | 24 | ||||
-rw-r--r-- | src/cratera/luatokens.lua | 2 | ||||
-rw-r--r-- | test/testp.lua | 24 |
3 files changed, 15 insertions, 35 deletions
diff --git a/src/cratera/compiler.lua b/src/cratera/compiler.lua index 5e9b0b5..ab4e2bf 100644 --- a/src/cratera/compiler.lua +++ b/src/cratera/compiler.lua @@ -73,30 +73,10 @@ finish[parser.EOZ] = function(state, token) local tk = table.remove(results) if tk == TK.FLT then local token = table.remove(results) - local extra, num, den = 1, token, 1 - assert(token == token and token >= 0, "NYI") -- the tokenizer should never output NaNs or negative values - if token == math.huge then -- the tokenizer *can* output math.huge tho - num, den = 1, 0 - else - while num ~= math.floor(num) do - num = num * 2 -- always safe (I think) - local oldden = den - den = den * 2 - if den == math.huge then -- subnormals or something? - extra = oldden - den = 2 - end - end - end - table.insert(state, string.format('((%d/%d)/%d)', num, den, extra)) + table.insert(state, token) elseif tk == TK.INT then local v = table.remove(results) - if v == math.mininteger then - -- corner case ( https://github.com/lua/lua/commit/707b0ba6e2dbfd58cf1167dae0e17975904b18aa ) - table.insert(state, string.format('0x%x', v)) - else - table.insert(state, string.format('(%d)', v)) -- may be negative (overflow) - end + table.insert(state, v) elseif tk == TK.STRING then -- lua tends to use a backslash and a newline but we already do newline processing, -- so we need to replace the escaped newline ("\\\n") with a newline escape ("\\n"). diff --git a/src/cratera/luatokens.lua b/src/cratera/luatokens.lua index 632cf27..6958171 100644 --- a/src/cratera/luatokens.lua +++ b/src/cratera/luatokens.lua @@ -641,7 +641,7 @@ defs.in_integer = setmetatable(selfify({ -- TODO figure out best order for these checks if rule == "digit" or token == "." or rule == "hexdigit" or rule == "into_hex" or rule == "exp" then return end state[#state+1] = state[STATE].numtype - state[#state+1] = tonumber(table.concat(state[COLLECT])) -- TODO maybe not the best option + state[#state+1] = table.concat(state[COLLECT]) -- TODO maybe not the best option state[COLLECT] = nil end, numtype = TK_INT diff --git a/test/testp.lua b/test/testp.lua index 1ab5304..7c4bf48 100644 --- a/test/testp.lua +++ b/test/testp.lua @@ -423,30 +423,30 @@ do -- numbers else -- integers assert(table.remove(state, 1) == luatokens.tokens.TK_INT) - assert(table.remove(state, 1) == 3) + assert(table.remove(state, 1) == "3") assert(table.remove(state, 1) == luatokens.tokens.TK_INT) - assert(table.remove(state, 1) == 345) + assert(table.remove(state, 1) == "345") assert(table.remove(state, 1) == luatokens.tokens.TK_INT) - assert(table.remove(state, 1) == 0xff) + assert(table.remove(state, 1) == "0xff") assert(table.remove(state, 1) == luatokens.tokens.TK_INT) - assert(table.remove(state, 1) == 0xBEBADA) + assert(table.remove(state, 1) == "0xBEBADA") -- floats assert(table.remove(state, 1) == luatokens.tokens.TK_FLT) - assert(table.remove(state, 1) == 3.0) + assert(table.remove(state, 1) == "3.0") assert(table.remove(state, 1) == luatokens.tokens.TK_FLT) - assert(table.remove(state, 1) == 3.1416) + assert(table.remove(state, 1) == "3.1416") assert(table.remove(state, 1) == luatokens.tokens.TK_FLT) - assert(table.remove(state, 1) == 314.16e-2) + assert(table.remove(state, 1) == "314.16e-2") assert(table.remove(state, 1) == luatokens.tokens.TK_FLT) - assert(table.remove(state, 1) == 0.31416E1) + assert(table.remove(state, 1) == "0.31416E1") assert(table.remove(state, 1) == luatokens.tokens.TK_FLT) - assert(table.remove(state, 1) == 34e1) + assert(table.remove(state, 1) == "34e1") assert(table.remove(state, 1) == luatokens.tokens.TK_FLT) - assert(table.remove(state, 1) == 0.1171875) + assert(table.remove(state, 1) == "0x0.1E") assert(table.remove(state, 1) == luatokens.tokens.TK_FLT) - assert(table.remove(state, 1) == 162.1875) + assert(table.remove(state, 1) == "0xA23p-4") assert(table.remove(state, 1) == luatokens.tokens.TK_FLT) - assert(table.remove(state, 1) == math.pi) + assert(table.remove(state, 1) == "0X1.921FB54442D18P+1") assert(table.remove(state, 1) == nil) assert(state.line == 3) end |