Userdata: Difference between revisions
From Legacy Roblox Wiki
Jump to navigationJump to search
>Camoy fixed headings |
>JulienDethurens No edit summary |
||
(3 intermediate revisions by 3 users not shown) | |||
Line 1: | Line 1: | ||
==Userdata== | ==Userdata== | ||
===What is a | ===What is a userdata?=== | ||
A userdata is the type Lua uses for data structures in the underlying C program. There | A {{type|userdata}} is the type Lua uses for data structures in the underlying C program. There aren't native Lua functions for handling those types, they must be handled via [[metatables]]. All Roblox objects and events are {{type|userdata}} Lua type. | ||
===Using | ===Using userdatas=== | ||
You can create a new userdata by passing true to the undocumented newproxy function. This userdata cannot be used for anything other than invoking functions via its metatable. | You can create a new {{type|userdata}} with an empty metatable by passing true to the undocumented [[newproxy]] function. This {{type|userdata}} cannot be used for anything other than invoking functions via its metatable. | ||
{{Example|<pre> | {{Example|<pre> | ||
Line 15: | Line 15: | ||
</pre>}} | </pre>}} | ||
[[Category:Data | [[Category:Data types]] |
Latest revision as of 17:59, 7 April 2012
Userdata
What is a userdata?
A userdata is the type Lua uses for data structures in the underlying C program. There aren't native Lua functions for handling those types, they must be handled via metatables. All Roblox objects and events are userdata Lua type.
Using userdatas
You can create a new userdata with an empty metatable by passing true to the undocumented newproxy function. This userdata cannot be used for anything other than invoking functions via its metatable.
Example
local ud = newproxy(true) -- new userdata with an empty metatable getmetatable(ud).__index = {Foo = "Bar"} -- index metamethod print(type(ud), ud.Foo) Output: userdata: 0x631fc8 Bar