Co-authored-by: Arseny Kapoulkine <arseny.kapoulkine@gmail.com>
4.7 KiB
layout | title |
---|---|
single | Luau Recap: March 2021 |
Luau is our new language that you can read more about at https://roblox.github.io/luau. It's been a busy month in Luau!
[Cross-posted to the Roblox Developer Forum.]
Typed variadics
Luau supports variadic functions, meaning ones which can take a variable number of arguments (varargs!) but previously there was no way to specify their type. Now you can!
function f(x: string, ...: number)
print(x)
print(...)
end
f("hi")
f("lo", 5, 27)
This function takes a string, plus as many numbers as you like, but if you try calling it with anything else, you'll get a type error, for example f("oh", true)
gives an error "Type boolean
could not be converted into number
"
Variadics can be used in function declarations, and function types, for example
type T = {
sum: (...number) -> number
}
function f(x: T)
print(x.sum(1, 2, 3))
end
Generic functions
Luau has always supported type inference for generic functions, for example:
type Point<X,Y> = { x: X, y: Y }
function swap(p)
return { x = p.y, y = p.x }
end
local p : Point<number, string> = swap({ x = "hi", y = 37 })
local q : Point<boolean, string> = swap({ x = "hi", y = true })
but up until now, there's been no way to write the type of swap
, since Luau didn't have type parameters to functions (just regular old data parameters). Well, now you can:
function swap<X, Y>(p : Point<X, Y>): Point<Y, X>
return { x = p.y, y = p.x }
end
Generic functions can be used in function declarations, and function types too, for example
type Swapper = { swap : <X, Y>(Point<X, Y>) -> Point<Y, X> }
Typechecking improvements
We've made various improvements to the Luau typechecker:
- Check bodies of methods whose
self
has typeany
- More precise types for
debug.*
methods - Mutually dependent type aliases are now handled correctly
Performance improvements
We are continuing to squeeze the performance out of all sorts of possible code; this is an ongoing process and we have many improvements in the pipeline, big and small. These are the changes that are already live:
- Significantly optimized non-variadic function calls, improving performance by up to 10% on call-heavy benchmarks
- Improve performance of
math.clamp
,math.sign
andmath.round
by 2.3x, 2x and 1.6x respectively - Optimized
coroutine.resume
with ~10% gains on coroutine-heavy benchmarks - Equality comparisons are now a bit faster when comparing to constants, including
nil
; this makes some benchmarks 2-3% faster - Calls to builtin functions like
math.abs
orbit32.rrotate
are now significantly faster in some cases, e.g. this makes SHA256 benchmark 25% faster rawset
,rawget
,rawequal
and 2-argumenttable.insert
are now 40-50% faster; notably,table.insert(t, v)
is now faster thant[#t+1]=v
Note that we work off a set of benchmarks that we consider representative of the wide gamut of code that runs on Luau. If you have code that you think should be running faster, never hesitate to open a feature request / bug report on Roblox Developer Forum!
Debugger improvements
We continue to improve our Luau debugger and we have added a new feature to help with coroutine call debugging. The call stack that is being displayed while stopped inside a coroutine frame will display the chain of threads that have called it.
Before:
!["Old debugger"]({{ site.url }}{{ site.baseurl }}/assets/images/luau-recap-march-2021-debug-before.png)
After:
!["New debugger"]({{ site.url }}{{ site.baseurl }}/assets/images/luau-recap-march-2021-debug-after.png)
We have restored the ability to break on all errors inside the scripts. This is useful in cases where you need to track the location and state of an error that is triggered inside 'pcall'. For example, when the error that's triggered is not the one you expected.
!["Break on all exceptions"]({{ site.url }}{{ site.baseurl }}/assets/images/luau-recap-march-2021-debug-dialog.png)
Library changes
- Added the
debug.info
function which allows retrieving information about stack frames or functions; similarly todebug.getinfo
from Lua, this accepts an options string that must consist of charactersslnfa
; unlike Lua that returns a table, the function returns all requested values one after another to improve performance.
New logo
Luau now has a shiny new logo!
!["New logo!"]({{ site.url }}{{ site.baseurl }}/assets/images/luau.png)
Coming soon...
- Generic variadics!
- Native Vector3 math with dramatic performance improvements!
- Better tools for memory analysis!
- Better treatment of cyclic requires during type checking!
- Better type refinements including nil-ability checks,
and
/or
andIsA
!