Difference between revisions of "Setfenv"

From GiderosMobile
m
 
(4 intermediate revisions by 2 users not shown)
Line 1: Line 1:
 
__NOTOC__
 
__NOTOC__
<languages />
+
'''Available since:''' Gideros 2011.6<br/>
'''<translate>Available since</translate>:''' Gideros 2011.6<br/>
+
'''Class:''' [[(global)]]<br/>
'''<translate>Class</translate>:''' [[Special:MyLanguage/(global)|(global)]]<br/>
 
  
=== <translate>Description</translate> ===
+
'''This function is deprecated'''
<translate>Sets the environment to be used by the given function. f can be a Lua function or a number that specifies the function at that stack level: Level 1 is the function calling setfenv. setfenv returns the given function.
+
=== Description ===
 +
Sets the environment to be used by the given function.
 +
<syntaxhighlight lang="lua">
 +
(varies) = setfenv(f,table)
 +
</syntaxhighlight>
  
  As a special case, when f is 0 setfenv changes the environment of the running thread. In this case, setfenv returns no values.</translate>
+
''f'' can be a Lua function or a number that specifies the function at that stack level: Level 1 is the function calling ''setfenv''. ''setfenv'' returns the given function.
<source lang="lua">
+
 
(varies) = setfenv(f,table)
+
  As a special case, when f is 0 ''setfenv'' changes the environment of the running thread. In this case, ''setfenv'' returns no values.
</source>
+
 
 +
=== Parameters ===
 +
'''f''': (varies) function or number(call stack level)<br/>
 +
'''table''': (table) environment table to set<br/>
 +
 
 +
=== Return values ===
 +
'''Returns''' (varies) returns provided function or nil<br/>
  
=== <translate>Parameters</translate> ===
+
=== Example ===
'''f''': (varies) <translate>function or number(call stack level)</translate> <br/>
+
<syntaxhighlight lang="lua">
'''table''': (table) <translate>environment table to set</translate> <br/>
+
a = 1  -- create a global variable
 +
-- change current environment
 +
setfenv(1, {_G = _G})
 +
_G.print(a)     --> nil
 +
_G.print(_G.a)   --> 1
 +
</syntaxhighlight>
  
=== <translate>Return values</translate> ===
+
=== See also ===
'''<translate>Returns</translate>''' (varies) <translate>returns provided function or nil</translate><br/>
+
'''https://www.lua.org/pil/14.3.html'''<br/>
 +
'''[[setsafeenv]]'''
  
 
{{(global)}}
 
{{(global)}}

Latest revision as of 07:39, 6 February 2025

Available since: Gideros 2011.6
Class: (global)

This function is deprecated

Description

Sets the environment to be used by the given function.

(varies) = setfenv(f,table)

f can be a Lua function or a number that specifies the function at that stack level: Level 1 is the function calling setfenv. setfenv returns the given function.

As a special case, when f is 0 setfenv changes the environment of the running thread. In this case, setfenv returns no values.

Parameters

f: (varies) function or number(call stack level)
table: (table) environment table to set

Return values

Returns (varies) returns provided function or nil

Example

a = 1   -- create a global variable
-- change current environment
setfenv(1, {_G = _G})
_G.print(a)      --> nil
_G.print(_G.a)   --> 1

See also

https://www.lua.org/pil/14.3.html
setsafeenv