WoW:API collectgarbage: Difference between revisions

From AddOn Studio
Jump to navigation Jump to search
No edit summary
No edit summary
Line 1: Line 1:
{{wowapi}}
{{wowapi}}
<center>'''collectgarbage''' ''-Documentation by [[user:Aradan|Aradan]], Update by [[user:CuteMiyu|CuteMiyu]]-''</center>
Control the garbage collector and query it for information. As of WoW 2.0, this is the same as the standard collectgarbage() in Lua, but prior to that it was quite different.
 
Sets garbage collection limit and calls the garbage collector if the Lua byte counter exceeds this limit.
 
Since WoW 2.0, it change to Lua 5.1. Lua 5.1 changed collectgarbage design, and you need update your script or AddOn if you used this function.


  collectgarbage(opt [, arg])
  collectgarbage(opt [, arg])
Line 26: Line 22:
  collectgarbage("count") -- return kilobytes of memory in use, i.e. 2048 for 2 megabytes
  collectgarbage("count") -- return kilobytes of memory in use, i.e. 2048 for 2 megabytes


== Note ==
There is a [[Lua]] function with the exact same name but its parameters and behavior is quite different from the WoW API version.
----
__NOTOC__
__NOTOC__

Revision as of 15:21, 16 July 2007

WoW API < collectgarbage

Control the garbage collector and query it for information. As of WoW 2.0, this is the same as the standard collectgarbage() in Lua, but prior to that it was quite different.

collectgarbage(opt [, arg])

Parameters

Arguments

(opt [, arg])
opt
String - This function is a generic interface to the garbage collector. It performs different functions according to its first argument:
* "stop": stops the garbage collector.
* "restart": restarts the garbage collector.
* "collect": performs a full garbage-collection cycle.
* "count": returns the total memory in use by Lua (in Kbytes).
* "step": performs a garbage-collection step. The step "size" is controlled by arg (larger values mean more steps) in a non-specified way. If you want to control the step size you must experimentally tune the value of arg. Returns true if the step finished a collection cycle.
* "setpause": sets arg/100 as the new value for the pause of the collector (see §2.10).
* "setstepmul": sets arg/100 as the new value for the step multiplier of the collector (see §2.10).

Example

collectgarbage("collect") -- Force garbage collection
collectgarbage("count") -- return kilobytes of memory in use, i.e. 2048 for 2 megabytes