WoW:API unpack: Difference between revisions

From AddOn Studio
Jump to navigation Jump to search
(→‎Notes: I think only the first 4 values will be assigned to x1, x2, x3 and x4.)
m (→‎Notes: I R has gud grammar...)
Line 25: Line 25:


== Notes ==
== Notes ==
Unpack() appears to be buggy when dealing with multiple nil values and the last value is nil.
unpack() doesn't return all the values in the following example because it is not a contiguous table.
   t = {1,nil,"something",nil)
  -- Notes Example 1
   x1,x2,x3,x4 = unpack(t)  -- returns 1,nil
   t = {1,nil,"something",nil}
   print(unpack(t))  -- prints 1


A simple fix that works could be adding an empty value.
A simple fix would be to add a value at the end of the list. This works because when you assign a table in this manner, Lua treats it as a contiguous table as long as there is a value at the last index. Nuking this value before adding new values at the end will break this behavior.
   t = {1,nil,"something",nil,1)
  -- Notes Example 2
   x1,x2,x3,x4 = unpack(t)  -- returns 1,nil,"something",nil
   t = {1,nil,"something",nil,1}
  print(unpack(t))  -- prints 1 nil "something" nil 1
   t[5] = nil
  print(unpack(t))  -- prints 1
 
If you assign each value individually, unpack() will behave the same way it does in Notes Example 1.
  -- Notes Example 3
  t = {}
  t[1] = 1
  t[2] = nil
  t[3] = "something"
  t[4] = nil
  t[5] = 1
  print(unpack(t))  -- prints 1 even though it's the same contents as in Notes Example 2.


--Peeka, sentinels
{{LUA}}
{{LUA}}

Revision as of 08:11, 27 November 2009

Returns the values in a consecutive-integer indexed table

ret1, ret2, ... retN = unpack(table[, start][, end])

Will not return values with hash style indexes. For example:

local t = {1, "two", "3", x = "ecks", y = "why?"}
unpack(t) -- returns: 1, "two", "3"

Arguments

Parameters

table
(table) - A table
start
Integer - Starting index, defaults to 1 if nil
end
Integer - Ending index, appends nil values if the table does not contain enough

Returns

ret1, ret2, ... retN
A list of the values contained in the given table.

Examples

local arg1, arg2, arg3 = unpack({1, 5, "Hearthstone"})

-- This does the same thing:
local arg1, arg2, arg3 = 1, 5, "Hearthstone"
unpack({1,2,3,4,5},2,7)  -- returns 2, 3, 4, 5, nil, nil

Notes

unpack() doesn't return all the values in the following example because it is not a contiguous table.

 -- Notes Example 1
 t = {1,nil,"something",nil}
 print(unpack(t))  -- prints 1

A simple fix would be to add a value at the end of the list. This works because when you assign a table in this manner, Lua treats it as a contiguous table as long as there is a value at the last index. Nuking this value before adding new values at the end will break this behavior.

 -- Notes Example 2
 t = {1,nil,"something",nil,1}
 print(unpack(t))  -- prints 1 nil "something" nil 1
 t[5] = nil
 print(unpack(t))  -- prints 1

If you assign each value individually, unpack() will behave the same way it does in Notes Example 1.

 -- Notes Example 3
 t = {}
 t[1] = 1
 t[2] = nil
 t[3] = "something"
 t[4] = nil
 t[5] = 1
 print(unpack(t))  -- prints 1 even though it's the same contents as in Notes Example 2.

Template:LUA