mirror of
https://github.com/luau-lang/luau.git
synced 2024-12-12 21:10:37 +00:00
551a43c424
- Updated Roblox copyright to 2023 - Floor division operator `//` (implements #832) - Autocomplete now shows `end` within `do` blocks - Restore BraceType when using `Lexer::lookahead` (fixes #1019) # New typechecker - Subtyping tests between metatables and tables - Subtyping tests between string singletons and tables - Subtyping tests for class types # Native codegen - Fixed macOS test failure (wrong spill restore offset) - Fixed clobbering of non-volatile xmm registers on Windows - Fixed wrong storage location of SSA reg spills - Implemented A64 support for add/sub extended - Eliminated zextReg from A64 lowering - Remove identical table slot lookups - Propagate values from predecessor into the linear block - Disabled reuse slot optimization - Keep `LuaNode::val` check for nil when optimizing `CHECK_SLOT_MATCH` - Implemented IR translation of `table.insert` builtin - Fixed mmap error handling on macOS/Linux # Tooling - Used `|` as a column separator instead of `+` in `bench.py` - Added a `table.sort` micro-benchmark - Switched `libprotobuf-mutator` to a less problematic version
51 lines
1.4 KiB
Lua
51 lines
1.4 KiB
Lua
-- This file is part of the Luau programming language and is licensed under MIT License; see LICENSE.txt for details
|
|
print('testing userdata')
|
|
|
|
-- int64 is a userdata type defined in C++
|
|
|
|
-- equality
|
|
assert(int64(1) == int64(1))
|
|
assert(int64(1) ~= int64(2))
|
|
|
|
-- relational
|
|
assert(not (int64(1) < int64(1)))
|
|
assert(int64(1) < int64(2))
|
|
assert(int64(1) <= int64(1))
|
|
assert(int64(1) <= int64(2))
|
|
|
|
-- arithmetics
|
|
assert(-int64(2) == int64(-2))
|
|
|
|
assert(int64(1) + int64(2) == int64(3))
|
|
assert(int64(1) - int64(2) == int64(-1))
|
|
assert(int64(2) * int64(3) == int64(6))
|
|
assert(int64(4) / int64(2) == int64(2))
|
|
assert(int64(4) % int64(3) == int64(1))
|
|
assert(int64(2) ^ int64(3) == int64(8))
|
|
|
|
assert(int64(1) + 2 == int64(3))
|
|
assert(int64(1) - 2 == int64(-1))
|
|
assert(int64(2) * 3 == int64(6))
|
|
assert(int64(4) / 2 == int64(2))
|
|
assert(int64(4) % 3 == int64(1))
|
|
assert(int64(2) ^ 3 == int64(8))
|
|
|
|
-- / and // round in different directions in our test implementation
|
|
assert(int64(5) / int64(2) == int64(2))
|
|
assert(int64(5) // int64(2) == int64(2))
|
|
assert(int64(-5) / int64(2) == int64(-2))
|
|
assert(int64(-5) // int64(2) == int64(-3))
|
|
|
|
-- tostring
|
|
assert(tostring(int64(2)) == "2")
|
|
|
|
-- index/newindex; note, mutable userdatas aren't very idiomatic but we need to test this
|
|
do
|
|
local v = int64(42)
|
|
assert(v.value == 42)
|
|
v.value = 4
|
|
assert(v.value == 4)
|
|
assert(v == int64(4))
|
|
end
|
|
|
|
return 'OK'
|