2015-12-27 23:32:07 +01:00
# node Module
2016-01-05 10:58:23 +11:00
The node module provides access to system-level features such as sleep, restart and various info and IDs.
2016-01-05 11:17:20 +11:00
## node.bootreason()
2016-01-13 16:04:59 +11:00
Returns the boot reason and extended reset info.
2016-01-05 11:17:20 +11:00
2016-01-13 16:04:59 +11:00
The first value returned is the raw code, not the new "reset info" code which was introduced in recent SDKs. Values are:
2016-01-08 20:49:56 +01:00
2016-01-08 21:17:16 +01:00
- 1, power-on
- 2, reset (software?)
- 3, hardware reset via reset pin
- 4, WDT reset (watchdog timeout)
2016-01-05 11:17:20 +11:00
2016-01-15 11:54:45 +11:00
The second value returned is the extended reset cause. Values are:
2016-01-13 16:04:59 +11:00
- 0, power-on
- 1, hardware watchdog reset
- 2, exception reset
- 3, software watchdog reset
- 4, software restart
- 5, wake from deep sleep
- 6, external reset
2016-01-15 11:54:45 +11:00
In general, the extended reset cause supercedes the raw code. The raw code is kept for backwards compatibility only. For new applications it is highly recommended to use the extended reset cause instead.
2016-01-13 16:04:59 +11:00
2016-01-15 11:54:45 +11:00
In case of extended reset cause 3 (exception reset), additional values are returned containing the crash information. These are, in order, EXCCAUSE, EPC1, EPC2, EPC3, EXCVADDR, and DEPC.
2016-01-13 16:04:59 +11:00
2016-01-08 22:39:07 +01:00
#### Syntax
`node.bootreason()`
#### Parameters
2016-01-08 20:49:56 +01:00
none
2016-01-05 11:17:20 +11:00
2016-01-08 22:39:07 +01:00
#### Returns
2016-01-15 11:54:45 +11:00
`rawcode, reason [, exccause, epc1, epc2, epc3, excvaddr, depc ]`
2016-01-13 16:04:59 +11:00
#### Example
```lua
_, reset_reason = node.bootreason()
if reset_reason == 0 then print("Power UP!") end
```
2016-01-05 11:17:20 +11:00
2016-01-08 20:49:56 +01:00
## node.chipid()
2015-12-27 23:32:07 +01:00
2016-01-08 20:49:56 +01:00
Returns the ESP chip ID.
2015-12-27 23:32:07 +01:00
2016-01-08 22:39:07 +01:00
#### Syntax
`node.chipid()`
#### Parameters
2016-01-08 20:49:56 +01:00
none
2016-01-08 22:39:07 +01:00
#### Returns
2016-01-08 20:49:56 +01:00
chip ID (number)
## node.compile()
Compiles a Lua text file into Lua bytecode, and saves it as .lc file.
2016-01-08 22:39:07 +01:00
#### Syntax
`node.compile("file.lua")`
#### Parameters
2016-01-08 20:49:56 +01:00
`filename` name of Lua text file
2015-12-27 23:32:07 +01:00
2016-01-08 22:39:07 +01:00
#### Returns
2015-12-27 23:32:07 +01:00
`nil`
2016-01-08 22:39:07 +01:00
#### Example
2015-12-27 23:32:07 +01:00
```lua
2016-01-08 20:49:56 +01:00
file.open("hello.lua","w+")
file.writeline([[print("hello nodemcu")]])
file.writeline([[print(node.heap())]])
file.close()
node.compile("hello.lua")
dofile("hello.lua")
dofile("hello.lc")
2015-12-27 23:32:07 +01:00
```
2016-01-08 20:49:56 +01:00
2015-12-27 23:32:07 +01:00
## node.dsleep()
2016-01-08 20:49:56 +01:00
Enters deep sleep mode, wakes up when timed out.
2015-12-27 23:32:07 +01:00
2016-01-05 12:26:41 +11:00
The maximum sleep time is 4294967295us, ~71 minutes. This is an SDK limitation.
Firmware from before 05 Jan 2016 have a maximum sleeptime of ~35 minutes.
2016-01-08 20:49:56 +01:00
!!! note "Note:"
2015-12-27 23:32:07 +01:00
2016-01-08 20:49:56 +01:00
This function can only be used in the condition that esp8266 PIN32(RST) and PIN8(XPD_DCDC aka GPIO16) are connected together. Using sleep(0) will set no wake up timer, connect a GPIO to pin RST, the chip will wake up by a falling-edge on pin RST.
2015-12-27 23:32:07 +01:00
2016-01-08 22:39:07 +01:00
#### Syntax
`node.dsleep(us, option)`
#### Parameters
2016-01-08 20:49:56 +01:00
- `us` number (integer) or `nil` , sleep time in micro second. If `us == 0` , it will sleep forever. If `us == nil` , will not set sleep time.
2015-12-27 23:32:07 +01:00
2016-01-08 20:49:56 +01:00
- `option` number (integer) or `nil` . If `nil` , it will use last alive setting as default option.
- 0, init data byte 108 is valuable
- \> 0, init data byte 108 is valueless
- 0, RF_CAL or not after deep-sleep wake up, depends on init data byte 108
- 1, RF_CAL after deep-sleep wake up, there will belarge current
- 2, no RF_CAL after deep-sleep wake up, there will only be small current
- 4, disable RF after deep-sleep wake up, just like modem sleep, there will be the smallest current
2015-12-27 23:32:07 +01:00
2016-01-08 22:39:07 +01:00
#### Returns
2015-12-27 23:32:07 +01:00
`nil`
2016-01-08 22:39:07 +01:00
#### Example
2015-12-27 23:32:07 +01:00
```lua
--do nothing
node.dsleep()
--sleep μs
node.dsleep(1000000)
--set sleep option, then sleep μs
node.dsleep(1000000, 4)
--set sleep option only
node.dsleep(nil,4)
```
2016-01-05 10:58:23 +11:00
2016-01-08 20:49:56 +01:00
## node.flashid()
2016-01-05 10:58:23 +11:00
2016-01-08 20:49:56 +01:00
Returns the flash chip ID.
2016-01-05 10:58:23 +11:00
2016-01-08 22:39:07 +01:00
#### Syntax
`node.flashid()`
#### Parameters
2016-01-08 20:49:56 +01:00
none
2016-01-05 10:58:23 +11:00
2016-01-08 22:39:07 +01:00
#### Returns
2016-01-08 20:49:56 +01:00
flash ID (number)
2016-01-05 10:58:23 +11:00
2016-01-08 20:49:56 +01:00
## node.heap()
2016-01-05 10:58:23 +11:00
2016-01-08 20:49:56 +01:00
Returns the current available heap size in bytes. Note that due to fragmentation, actual allocations of this size may not be possible.
2016-01-05 10:58:23 +11:00
2016-01-08 22:39:07 +01:00
#### Syntax
`node.heap()`
#### Parameters
2016-01-08 20:49:56 +01:00
none
2016-01-05 10:58:23 +11:00
2016-01-08 22:39:07 +01:00
#### Returns
2016-01-08 20:49:56 +01:00
system heap size left in bytes (number)
2016-01-05 10:58:23 +11:00
2016-01-08 20:49:56 +01:00
## node.info()
2016-01-05 10:58:23 +11:00
2016-01-08 20:49:56 +01:00
Returns NodeMCU version, chipid, flashid, flash size, flash mode, flash speed.
2016-01-05 10:58:23 +11:00
2016-01-08 22:39:07 +01:00
#### Syntax
`node.info()`
#### Parameters
2016-01-08 20:49:56 +01:00
none
2016-01-05 10:58:23 +11:00
2016-01-08 22:39:07 +01:00
#### Returns
2016-01-08 20:49:56 +01:00
- `majorVer` (number)
- `minorVer` (number)
- `devVer` (number)
- `chipid` (number)
- `flashid` (number)
- `flashsize` (number)
- `flashmode` (number)
- `flashspeed` (number)
2016-01-05 10:58:23 +11:00
2016-01-08 22:39:07 +01:00
#### Example
2016-01-05 10:58:23 +11:00
```lua
2016-01-08 20:49:56 +01:00
majorVer, minorVer, devVer, chipid, flashid, flashsize, flashmode, flashspeed = node.info()
print("NodeMCU "..majorVer.."."..minorVer.."."..devVer)
2016-01-05 10:58:23 +11:00
```
2016-01-08 20:49:56 +01:00
## node.input()
2016-01-05 10:58:23 +11:00
2016-01-08 20:49:56 +01:00
Submits a string to the Lua interpreter. Similar to `pcall(loadstring(str))` , but without the single-line limitation.
2016-01-05 10:58:23 +11:00
2016-01-08 20:49:56 +01:00
!!! note "Note:"
This function only has an effect when invoked from a callback. Using it directly on the console **does not work** .
2016-01-05 10:58:23 +11:00
2016-01-08 22:39:07 +01:00
#### Syntax
`node.input(str)`
2016-01-05 10:58:23 +11:00
2016-01-08 22:39:07 +01:00
#### Parameters
2016-01-08 20:49:56 +01:00
`str` Lua chunk
2016-01-05 10:58:23 +11:00
2016-01-08 22:39:07 +01:00
#### Returns
2016-01-05 10:58:23 +11:00
`nil`
2016-01-08 22:39:07 +01:00
#### Example
2016-01-05 10:58:23 +11:00
```lua
2016-01-08 20:49:56 +01:00
sk:on("receive", function(conn, payload) node.input(payload) end)
2016-01-05 10:58:23 +11:00
```
2016-01-08 20:49:56 +01:00
2016-01-08 22:39:07 +01:00
#### See also
2016-01-08 20:49:56 +01:00
[`node.output()` ](#nodeoutput )
## node.key() --deprecated
2016-01-05 10:58:23 +11:00
2016-01-08 20:49:56 +01:00
Defines action to take on button press (on the old devkit 0.9), button connected to GPIO 16.
2016-01-05 10:58:23 +11:00
This function is only available if the firmware was compiled with DEVKIT_VERSION_0_9 defined.
2016-01-08 22:39:07 +01:00
#### Syntax
`node.key(type, function())`
#### Parameters
2016-01-08 20:49:56 +01:00
- `type` : type is either string "long" or "short". long: press the key for 3 seconds, short: press shortly(less than 3 seconds)
- `function` : user defined function which is called when key is pressed. If nil, remove the user defined function. Default function: long: change LED blinking rate, short: reset chip
2016-01-05 10:58:23 +11:00
2016-01-08 22:39:07 +01:00
#### Returns
2016-01-05 10:58:23 +11:00
`nil`
2016-01-08 22:39:07 +01:00
#### Example
2016-01-05 10:58:23 +11:00
```lua
2016-01-08 20:49:56 +01:00
node.key("long", function() print('hello world') end)
2016-01-05 10:58:23 +11:00
```
2016-01-08 22:39:07 +01:00
#### See also
2016-01-08 21:17:16 +01:00
[`node.led()` ](#nodeled-deprecated )
2016-01-05 10:58:23 +11:00
2016-01-08 20:49:56 +01:00
## node.led() --deprecated
2016-01-05 10:58:23 +11:00
2016-01-08 21:17:16 +01:00
Sets the on/off time for the LED (on the old devkit 0.9), with the LED connected to GPIO16, multiplexed with [`node.key()` ](#nodekey-deprecated ).
2016-01-05 10:58:23 +11:00
2016-01-08 20:49:56 +01:00
This function is only available if the firmware was compiled with DEVKIT_VERSION_0_9 defined.
2016-01-05 10:58:23 +11:00
2016-01-08 22:39:07 +01:00
#### Syntax
`node.led(low, high)`
#### Parameters
- `low` LED off time, LED keeps on when low=0. Unit: milliseconds, time resolution: 80~100ms
2016-01-08 20:49:56 +01:00
- `high` LED on time. Unit: milliseconds, time resolution: 80~100ms
2016-01-05 10:58:23 +11:00
2016-01-08 22:39:07 +01:00
#### Returns
2016-01-05 10:58:23 +11:00
`nil`
2016-01-08 22:39:07 +01:00
#### Example
2016-01-05 10:58:23 +11:00
```lua
2016-01-08 20:49:56 +01:00
-- turn led on forever.
node.led(0)
2016-01-05 10:58:23 +11:00
```
2016-01-08 22:39:07 +01:00
#### See also
2016-01-08 21:17:16 +01:00
[`node.key()` ](#nodekey-deprecated )
2016-01-05 10:58:23 +11:00
## node.output()
Redirects the Lua interpreter output to a callback function. Optionally also prints it to the serial console.
!!! note "Note:"
2016-01-08 20:49:56 +01:00
Do **not** attempt to `print()` or otherwise induce the Lua interpreter to produce output from within the callback function. Doing so results in infinite recursion, and leads to a watchdog-triggered restart.
2016-01-05 10:58:23 +11:00
2016-01-08 22:39:07 +01:00
#### Syntax
`node.output(function(str), serial_debug)`
#### Parameters
2016-01-08 20:49:56 +01:00
- `output_fn(str)` a function accept every output as str, and can send the output to a socket (or maybe a file).
- `serial_debug` 1 output also show in serial. 0: no serial output.
2016-01-05 10:58:23 +11:00
2016-01-08 22:39:07 +01:00
#### Returns
2016-01-05 10:58:23 +11:00
`nil`
2016-01-08 22:39:07 +01:00
#### Example
2016-01-05 10:58:23 +11:00
```lua
2016-01-08 20:49:56 +01:00
function tonet(str)
sk:send(str)
end
node.output(tonet, 1) -- serial also get the lua output.
2016-01-05 10:58:23 +11:00
```
```lua
2016-01-08 20:49:56 +01:00
-- a simple telnet server
s=net.createServer(net.TCP)
s:listen(2323,function(c)
con_std = c
function s_output(str)
if(con_std~=nil)
then con_std:send(str)
end
end
node.output(s_output, 0) -- re-direct output to function s_ouput.
c:on("receive",function(c,l)
node.input(l) -- works like pcall(loadstring(l)) but support multiple separate line
end)
c:on("disconnection",function(c)
con_std = nil
node.output(nil) -- un-regist the redirect output function, output goes to serial
end)
end)
2016-01-05 10:58:23 +11:00
```
2016-01-08 22:39:07 +01:00
#### See also
2016-01-08 20:49:56 +01:00
[`node.input()` ](#nodeinput )
2016-01-05 10:58:23 +11:00
2016-01-08 20:49:56 +01:00
## node.readvdd33() --deprecated
Moved to [`adc.readvdd33()` ](adc/#adcreadvdd33 ).
2016-01-05 10:58:23 +11:00
2016-01-08 20:49:56 +01:00
## node.restart()
Restarts the chip.
2016-01-05 10:58:23 +11:00
2016-01-08 22:39:07 +01:00
#### Syntax
`node.restart()`
#### Parameters
2016-01-08 20:49:56 +01:00
none
2016-01-05 10:58:23 +11:00
2016-01-08 22:39:07 +01:00
#### Returns
2016-01-05 10:58:23 +11:00
`nil`
2016-01-08 20:49:56 +01:00
## node.restore()
Restores system configuration to defaults. Erases all stored WiFi settings, and resets the "esp init data" to the defaults. This function is intended as a last-resort without having to reflash the ESP altogether.
2016-01-05 10:58:23 +11:00
2016-01-08 20:49:56 +01:00
This also uses the SDK function `system_restore()` , which doesn't document precisely what it erases/restores.
2016-01-05 10:58:23 +11:00
2016-01-08 22:39:07 +01:00
#### Syntax
`node.restore()`
#### Parameters
2016-01-08 20:49:56 +01:00
none
2016-01-05 10:58:23 +11:00
2016-01-08 22:39:07 +01:00
#### Returns
2016-01-08 20:49:56 +01:00
`nil`
2016-01-05 10:58:23 +11:00
2016-01-08 22:39:07 +01:00
#### Example
2016-01-05 10:58:23 +11:00
```lua
2016-01-08 20:49:56 +01:00
node.restore()
node.restart() -- ensure the restored settings take effect
2016-01-05 10:58:23 +11:00
```
2016-01-08 20:49:56 +01:00
## node.setcpufreq()
2016-01-05 10:58:23 +11:00
2016-01-08 20:49:56 +01:00
Change the working CPU Frequency.
2016-01-05 10:58:23 +11:00
2016-01-08 22:39:07 +01:00
#### Syntax
`node.setcpufreq(speed)`
#### Parameters
2016-01-08 20:49:56 +01:00
`speed` constant 'node.CPU80MHZ' or 'node.CPU160MHZ'
2016-01-05 10:58:23 +11:00
2016-01-08 22:39:07 +01:00
#### Returns
2016-01-08 20:49:56 +01:00
target CPU frequency (number)
2016-01-05 10:58:23 +11:00
2016-01-08 22:39:07 +01:00
#### Example
2016-01-05 10:58:23 +11:00
```lua
2016-01-08 20:49:56 +01:00
node.setcpufreq(node.CPU80MHZ)
2016-01-05 10:58:23 +11:00
```
2016-01-08 20:49:56 +01:00
2016-01-05 11:17:20 +11:00
## node.stripdebug()
2016-01-08 22:39:07 +01:00
Controls the amount of debug information kept during [`node.compile()` ](#nodecompile ), and allows removal of debug information from already compiled Lua code.
2016-01-05 11:17:20 +11:00
Only recommended for advanced users, the NodeMCU defaults are fine for almost all use cases.
2016-01-08 22:39:07 +01:00
####Syntax
`node.stripdebug([level[, function]])`
#### Parameters
- `level`
- 1, don't discard debug info
- 2, discard Local and Upvalue debug info
- 3, discard Local, Upvalue and line-number debug info
- `function` a compiled function to be stripped per setfenv except 0 is not permitted.
2016-01-05 11:17:20 +11:00
If no arguments are given then the current default setting is returned. If function is omitted, this is the default setting for future compiles. The function argument uses the same rules as for `setfenv()` .
2016-01-08 22:39:07 +01:00
#### Returns
2016-01-05 11:17:20 +11:00
If invoked without arguments, returns the current level settings. Otherwise, `nil` is returned.
2016-01-08 22:39:07 +01:00
#### Example
2016-01-05 11:17:20 +11:00
```lua
node.stripdebug(3)
node.compile('bigstuff.lua')
```
2016-01-08 22:39:07 +01:00
#### See also
2016-01-08 20:49:56 +01:00
[`node.compile()` ](#nodecompile )
2016-02-20 18:54:09 +00:00
# node.egc module
## node.egc.setmode()
Sets the Emergency Garbage Collector mode. [The EGC whitepaper ](http://www.eluaproject.net/doc/v0.9/en_elua_egc.html )
provides more detailed information on the EGC.
####Syntax
`node.egc.setmode(mode, [param])`
#### Parameters
- `mode`
2016-02-24 23:29:35 +00:00
- `node.egc.NOT_ACTIVE` EGC inactive, no collection cycle will be forced in low memory situations
- `node.egc.ON_ALLOC_FAILURE` Try to allocate a new block of memory, and run the garbage collector if the allocation fails. If the allocation fails even after running the garbage collector, the allocator will return with error.
- `node.egc.ON_MEM_LIMIT` Run the garbage collector when the memory used by the Lua script goes beyond an upper `limit` . If the upper limit can't be satisfied even after running the garbage collector, the allocator will return with error.
- `node.egc.ALWAYS` Run the garbage collector before each memory allocation. If the allocation fails even after running the garbage collector, the allocator will return with error. This mode is very efficient with regards to memory savings, but it's also the slowest.
- `level` in the case of `node.egc.ON_MEM_LIMIT` , this specifies the memory limit.
2016-02-20 18:54:09 +00:00
#### Returns
`nil`
2016-02-24 23:29:35 +00:00
#### Example
`node.egc.setmode(node.egc.ALWAYS, 4096) -- This is the default setting at startup.`
`node.egc.setmode(node.egc.ON_ALLOC_FAILURE) -- This is the fastest activeEGC mode.`
2016-03-01 23:37:41 +00:00
# node.task module
## node.task.post()
Enable a Lua callback or task to post another task request. Note that as per the
example multiple tasks can be posted in any task, but the highest priority is
always delivered first.
2016-03-03 15:28:34 +00:00
If the task queue is full then a queue full error is raised.
2016-03-01 23:37:41 +00:00
####Syntax
`node.task.post([task_priority], function)`
#### Parameters
- `task_priority` (optional)
- `node.task.LOW_PRIORITY` = 0
- `node.task.MEDIUM_PRIORITY` = 1
- `node.task.HIGH_PRIORITY` = 2
- `function` a callback function to be executed when the task is run.
If the priority is omitted then this defaults to `node.task.MEDIUM_PRIORITY`
#### Returns
`nil`
#### Example
```lua
for i = node.task.LOW_PRIORITY, node.task.HIGH_PRIORITY do
node.task.post(i,function(p2)
print("priority is ..p2)
end)
end
```
prints
```
priority is 2
priority is 1
priority is 0
```