mirror of
https://github.com/nodemcu/nodemcu-firmware.git
synced 2025-01-16 20:52:57 +08:00
Merge pull request #883 from nodemcu/dev
Resync master to dev prior to upgrading Dev to SDK 1.5
This commit is contained in:
commit
c803756857
12
app/Makefile
12
app/Makefile
@ -86,8 +86,13 @@ COMPONENTS_eagle.app.v6 = \
|
|||||||
crypto/libcrypto.a \
|
crypto/libcrypto.a \
|
||||||
dhtlib/libdhtlib.a \
|
dhtlib/libdhtlib.a \
|
||||||
tsl2561/tsl2561lib.a \
|
tsl2561/tsl2561lib.a \
|
||||||
modules/libmodules.a
|
modules/libmodules.a \
|
||||||
|
|
||||||
|
# Inspect the modules library and work out which modules need to be linked.
|
||||||
|
# For each enabled module, a symbol name of the form XYZ_module_selected is
|
||||||
|
# returned. At link time those names are declared undefined, so those (and
|
||||||
|
# only those) modules are pulled in.
|
||||||
|
SELECTED_MODULE_SYMS=$(filter %_module_selected %module_selected1,$(shell $(NM) modules/.output/$(TARGET)/$(FLAVOR)/lib/libmodules.a))
|
||||||
|
|
||||||
LINKFLAGS_eagle.app.v6 = \
|
LINKFLAGS_eagle.app.v6 = \
|
||||||
-Wl,--gc-sections \
|
-Wl,--gc-sections \
|
||||||
@ -98,6 +103,7 @@ LINKFLAGS_eagle.app.v6 = \
|
|||||||
-Wl,--no-check-sections \
|
-Wl,--no-check-sections \
|
||||||
-Wl,--wrap=_xtos_set_exception_handler \
|
-Wl,--wrap=_xtos_set_exception_handler \
|
||||||
-Wl,-static \
|
-Wl,-static \
|
||||||
|
$(addprefix -u , $(SELECTED_MODULE_SYMS)) \
|
||||||
-Wl,--start-group \
|
-Wl,--start-group \
|
||||||
-lc \
|
-lc \
|
||||||
-lgcc \
|
-lgcc \
|
||||||
@ -134,9 +140,11 @@ DEPENDS_eagle.app.v6 = \
|
|||||||
# -DWLAN_CONFIG_CCX
|
# -DWLAN_CONFIG_CCX
|
||||||
CONFIGURATION_DEFINES = -D__ets__ \
|
CONFIGURATION_DEFINES = -D__ets__ \
|
||||||
-DICACHE_FLASH \
|
-DICACHE_FLASH \
|
||||||
|
-DLUA_OPTIMIZE_MEMORY=2 \
|
||||||
|
-DMIN_OPT_LEVEL=2 \
|
||||||
-DLWIP_OPEN_SRC \
|
-DLWIP_OPEN_SRC \
|
||||||
-DPBUF_RSV_FOR_WLAN \
|
-DPBUF_RSV_FOR_WLAN \
|
||||||
-DEBUF_LWIP
|
-DEBUF_LWIP \
|
||||||
|
|
||||||
DEFINES += \
|
DEFINES += \
|
||||||
$(UNIVERSAL_TARGET_DEFINES) \
|
$(UNIVERSAL_TARGET_DEFINES) \
|
||||||
|
@ -60,10 +60,10 @@ uart_config(uint8 uart_no)
|
|||||||
|
|
||||||
uart_div_modify(uart_no, UART_CLK_FREQ / (UartDev.baut_rate));
|
uart_div_modify(uart_no, UART_CLK_FREQ / (UartDev.baut_rate));
|
||||||
|
|
||||||
WRITE_PERI_REG(UART_CONF0(uart_no), UartDev.exist_parity
|
WRITE_PERI_REG(UART_CONF0(uart_no), ((UartDev.exist_parity & UART_PARITY_EN_M) << UART_PARITY_EN_S) //SET BIT AND PARITY MODE
|
||||||
| UartDev.parity
|
| ((UartDev.parity & UART_PARITY_M) <<UART_PARITY_S )
|
||||||
| (UartDev.stop_bits << UART_STOP_BIT_NUM_S)
|
| ((UartDev.stop_bits & UART_STOP_BIT_NUM) << UART_STOP_BIT_NUM_S)
|
||||||
| (UartDev.data_bits << UART_BIT_NUM_S));
|
| ((UartDev.data_bits & UART_BIT_NUM) << UART_BIT_NUM_S));
|
||||||
|
|
||||||
|
|
||||||
//clear rx and tx fifo,not ready
|
//clear rx and tx fifo,not ready
|
||||||
|
@ -17,20 +17,20 @@ typedef enum {
|
|||||||
} UartBitsNum4Char;
|
} UartBitsNum4Char;
|
||||||
|
|
||||||
typedef enum {
|
typedef enum {
|
||||||
ONE_STOP_BIT = 0,
|
ONE_STOP_BIT = 0x1,
|
||||||
ONE_HALF_STOP_BIT = BIT2,
|
ONE_HALF_STOP_BIT = 0x2,
|
||||||
TWO_STOP_BIT = BIT2
|
TWO_STOP_BIT = 0x3
|
||||||
} UartStopBitsNum;
|
} UartStopBitsNum;
|
||||||
|
|
||||||
typedef enum {
|
typedef enum {
|
||||||
NONE_BITS = 0,
|
NONE_BITS = 0x2,
|
||||||
ODD_BITS = 0,
|
ODD_BITS = 1,
|
||||||
EVEN_BITS = BIT4
|
EVEN_BITS = 0
|
||||||
} UartParityMode;
|
} UartParityMode;
|
||||||
|
|
||||||
typedef enum {
|
typedef enum {
|
||||||
STICK_PARITY_DIS = 0,
|
STICK_PARITY_DIS = 0,
|
||||||
STICK_PARITY_EN = BIT3 | BIT5
|
STICK_PARITY_EN = 1
|
||||||
} UartExistParity;
|
} UartExistParity;
|
||||||
|
|
||||||
typedef enum {
|
typedef enum {
|
||||||
|
@ -78,26 +78,36 @@
|
|||||||
#define UART_RXFIFO_CNT 0x000000FF
|
#define UART_RXFIFO_CNT 0x000000FF
|
||||||
#define UART_RXFIFO_CNT_S 0
|
#define UART_RXFIFO_CNT_S 0
|
||||||
|
|
||||||
#define UART_CONF0( i ) (REG_UART_BASE( i ) + 0x20)
|
#define UART_CONF0( i ) (REG_UART_BASE( i ) + 0x20)
|
||||||
#define UART_TXFIFO_RST (BIT(18))
|
#define UART_DTR_INV (BIT(24))
|
||||||
#define UART_RXFIFO_RST (BIT(17))
|
#define UART_RTS_INV (BIT(23))
|
||||||
#define UART_IRDA_EN (BIT(16))
|
#define UART_TXD_INV (BIT(22))
|
||||||
#define UART_TX_FLOW_EN (BIT(15))
|
#define UART_DSR_INV (BIT(21))
|
||||||
#define UART_LOOPBACK (BIT(14))
|
#define UART_CTS_INV (BIT(20))
|
||||||
#define UART_IRDA_RX_INV (BIT(13))
|
#define UART_RXD_INV (BIT(19))
|
||||||
#define UART_IRDA_TX_INV (BIT(12))
|
#define UART_TXFIFO_RST (BIT(18))
|
||||||
#define UART_IRDA_WCTL (BIT(11))
|
#define UART_RXFIFO_RST (BIT(17))
|
||||||
#define UART_IRDA_TX_EN (BIT(10))
|
#define UART_IRDA_EN (BIT(16))
|
||||||
#define UART_IRDA_DPLX (BIT(9))
|
#define UART_TX_FLOW_EN (BIT(15))
|
||||||
#define UART_TXD_BRK (BIT(8))
|
#define UART_LOOPBACK (BIT(14))
|
||||||
#define UART_SW_DTR (BIT(7))
|
#define UART_IRDA_RX_INV (BIT(13))
|
||||||
#define UART_SW_RTS (BIT(6))
|
#define UART_IRDA_TX_INV (BIT(12))
|
||||||
#define UART_STOP_BIT_NUM 0x00000003
|
#define UART_IRDA_WCTL (BIT(11))
|
||||||
#define UART_STOP_BIT_NUM_S 4
|
#define UART_IRDA_TX_EN (BIT(10))
|
||||||
#define UART_BIT_NUM 0x00000003
|
#define UART_IRDA_DPLX (BIT(9))
|
||||||
#define UART_BIT_NUM_S 2
|
#define UART_TXD_BRK (BIT(8))
|
||||||
#define UART_PARITY_EN (BIT(1))
|
#define UART_SW_DTR (BIT(7))
|
||||||
#define UART_PARITY (BIT(0))
|
#define UART_SW_RTS (BIT(6))
|
||||||
|
#define UART_STOP_BIT_NUM 0x00000003
|
||||||
|
#define UART_STOP_BIT_NUM_S 4
|
||||||
|
#define UART_BIT_NUM 0x00000003
|
||||||
|
#define UART_BIT_NUM_S 2
|
||||||
|
#define UART_PARITY_EN (BIT(1))
|
||||||
|
#define UART_PARITY_EN_M 0x00000001
|
||||||
|
#define UART_PARITY_EN_S 1
|
||||||
|
#define UART_PARITY (BIT(0))
|
||||||
|
#define UART_PARITY_M 0x00000001
|
||||||
|
#define UART_PARITY_S 0
|
||||||
|
|
||||||
#define UART_CONF1( i ) (REG_UART_BASE( i ) + 0x24)
|
#define UART_CONF1( i ) (REG_UART_BASE( i ) + 0x24)
|
||||||
#define UART_RX_TOUT_EN (BIT(31))
|
#define UART_RX_TOUT_EN (BIT(31))
|
||||||
|
74
app/include/module.h
Normal file
74
app/include/module.h
Normal file
@ -0,0 +1,74 @@
|
|||||||
|
#ifndef __MODULE_H__
|
||||||
|
#define __MODULE_H__
|
||||||
|
|
||||||
|
#include "user_modules.h"
|
||||||
|
#include "lrodefs.h"
|
||||||
|
|
||||||
|
/* Registering a module within NodeMCU is really easy these days!
|
||||||
|
*
|
||||||
|
* Most of the work is done by a combination of pre-processor, compiler
|
||||||
|
* and linker "magic". Gone are the days of needing to update 4+ separate
|
||||||
|
* files just to register a module!
|
||||||
|
*
|
||||||
|
* You will need:
|
||||||
|
* - to include this header
|
||||||
|
* - a name for the module
|
||||||
|
* - a LUA_REG_TYPE module map
|
||||||
|
* - optionally, an init function
|
||||||
|
*
|
||||||
|
* Then simply put a line like this at the bottom of your module file:
|
||||||
|
*
|
||||||
|
* NODEMCU_MODULE(MYNAME, "myname", myname_map, luaopen_myname);
|
||||||
|
*
|
||||||
|
* or perhaps
|
||||||
|
*
|
||||||
|
* NODEMCU_MODULE(MYNAME, "myname", myname_map, NULL);
|
||||||
|
*
|
||||||
|
* if you don't need an init function.
|
||||||
|
*
|
||||||
|
* When you've done this, the module can be enabled in user_modules.h with:
|
||||||
|
*
|
||||||
|
* #define LUA_USE_MODULES_MYNAME
|
||||||
|
*
|
||||||
|
* and within NodeMCU you access it with myname.foo(), assuming you have
|
||||||
|
* a foo function in your module.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#define MODULE_EXPAND_(x) x
|
||||||
|
#define MODULE_PASTE_(x,y) x##y
|
||||||
|
#define MODULE_EXPAND_PASTE_(x,y) MODULE_PASTE_(x,y)
|
||||||
|
|
||||||
|
#define LOCK_IN_SECTION(s) __attribute__((used,unused,section(s)))
|
||||||
|
|
||||||
|
/* For the ROM table, we name the variable according to ( | denotes concat):
|
||||||
|
* cfgname | _module_selected | LUA_USE_MODULES_##cfgname
|
||||||
|
* where the LUA_USE_MODULES_XYZ macro is first expanded to yield either
|
||||||
|
* an empty string (or 1) if the module has been enabled, or the literal
|
||||||
|
* LUA_USE_MOUDLE_XYZ in the case it hasn't. Thus, the name of the variable
|
||||||
|
* ends up looking either like XYZ_module_enabled, or if not enabled,
|
||||||
|
* XYZ_module_enabledLUA_USE_MODULES_XYZ. This forms the basis for
|
||||||
|
* letting the build system detect automatically (via nm) which modules need
|
||||||
|
* to be linked in.
|
||||||
|
*/
|
||||||
|
#define NODEMCU_MODULE(cfgname, luaname, map, initfunc) \
|
||||||
|
const LOCK_IN_SECTION(".lua_libs") \
|
||||||
|
luaL_Reg MODULE_PASTE_(lua_lib_,cfgname) = { luaname, initfunc }; \
|
||||||
|
const LOCK_IN_SECTION(".lua_rotable") \
|
||||||
|
luaR_table MODULE_EXPAND_PASTE_(cfgname,MODULE_EXPAND_PASTE_(_module_selected,MODULE_PASTE_(LUA_USE_MODULES_,cfgname))) \
|
||||||
|
= { luaname, map }
|
||||||
|
|
||||||
|
|
||||||
|
/* System module registration support, not using LUA_USE_MODULES_XYZ. */
|
||||||
|
#define BUILTIN_LIB_INIT(name, luaname, initfunc) \
|
||||||
|
const LOCK_IN_SECTION(".lua_libs") \
|
||||||
|
luaL_Reg MODULE_PASTE_(lua_lib_,name) = { luaname, initfunc }
|
||||||
|
|
||||||
|
#define BUILTIN_LIB(name, luaname, map) \
|
||||||
|
const LOCK_IN_SECTION(".lua_rotable") \
|
||||||
|
luaR_table MODULE_PASTE_(lua_rotable_,name) = { luaname, map }
|
||||||
|
|
||||||
|
#if !(MIN_OPT_LEVEL==2 && LUA_OPTIMIZE_MEMORY==2)
|
||||||
|
# error "NodeMCU modules must be built with LTR enabled (MIN_OPT_LEVEL=2 and LUA_OPTIMIZE_MEMORY=2)"
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#endif
|
@ -12,9 +12,7 @@
|
|||||||
#define LUA_USE_BUILTIN_DEBUG_MINIMAL // for debug.getregistry() and debug.traceback()
|
#define LUA_USE_BUILTIN_DEBUG_MINIMAL // for debug.getregistry() and debug.traceback()
|
||||||
|
|
||||||
#ifndef LUA_CROSS_COMPILER
|
#ifndef LUA_CROSS_COMPILER
|
||||||
#define LUA_USE_MODULES
|
|
||||||
|
|
||||||
#ifdef LUA_USE_MODULES
|
|
||||||
#define LUA_USE_MODULES_ADC
|
#define LUA_USE_MODULES_ADC
|
||||||
#define LUA_USE_MODULES_BIT
|
#define LUA_USE_MODULES_BIT
|
||||||
//#define LUA_USE_MODULES_BMP085
|
//#define LUA_USE_MODULES_BMP085
|
||||||
@ -47,7 +45,6 @@
|
|||||||
//#define LUA_USE_MODULES_WS2801
|
//#define LUA_USE_MODULES_WS2801
|
||||||
#define LUA_USE_MODULES_WS2812
|
#define LUA_USE_MODULES_WS2812
|
||||||
|
|
||||||
#endif /* LUA_USE_MODULES */
|
|
||||||
#endif
|
|
||||||
|
|
||||||
|
#endif /* LUA_CROSS_COMPILER */
|
||||||
#endif /* __USER_MODULES_H__ */
|
#endif /* __USER_MODULES_H__ */
|
||||||
|
@ -816,6 +816,7 @@ static int panic (lua_State *L) {
|
|||||||
luai_writestringerror("PANIC: unprotected error in call to Lua API (%s)\n",
|
luai_writestringerror("PANIC: unprotected error in call to Lua API (%s)\n",
|
||||||
lua_tostring(L, -1));
|
lua_tostring(L, -1));
|
||||||
#endif
|
#endif
|
||||||
|
while (1) {}
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -489,6 +489,7 @@ static int luaB_newproxy (lua_State *L) {
|
|||||||
{LSTRKEY("xpcall"), LFUNCVAL(luaB_xpcall)}
|
{LSTRKEY("xpcall"), LFUNCVAL(luaB_xpcall)}
|
||||||
|
|
||||||
#if LUA_OPTIMIZE_MEMORY == 2
|
#if LUA_OPTIMIZE_MEMORY == 2
|
||||||
|
#undef MIN_OPT_LEVEL
|
||||||
#define MIN_OPT_LEVEL 2
|
#define MIN_OPT_LEVEL 2
|
||||||
#include "lrodefs.h"
|
#include "lrodefs.h"
|
||||||
const LUA_REG_TYPE base_funcs_list[] = {
|
const LUA_REG_TYPE base_funcs_list[] = {
|
||||||
|
@ -383,6 +383,7 @@ static int db_errorfb (lua_State *L) {
|
|||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#undef MIN_OPT_LEVEL
|
||||||
#define MIN_OPT_LEVEL 1
|
#define MIN_OPT_LEVEL 1
|
||||||
#include "lrodefs.h"
|
#include "lrodefs.h"
|
||||||
const LUA_REG_TYPE dblib[] = {
|
const LUA_REG_TYPE dblib[] = {
|
||||||
|
@ -538,6 +538,7 @@ static int f_flush (lua_State *L) {
|
|||||||
return pushresult(L, fs_flush(tofile(L)) == 0, NULL);
|
return pushresult(L, fs_flush(tofile(L)) == 0, NULL);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#undef MIN_OPT_LEVEL
|
||||||
#define MIN_OPT_LEVEL 2
|
#define MIN_OPT_LEVEL 2
|
||||||
#include "lrodefs.h"
|
#include "lrodefs.h"
|
||||||
#if LUA_OPTIMIZE_MEMORY == 2
|
#if LUA_OPTIMIZE_MEMORY == 2
|
||||||
|
@ -311,6 +311,7 @@ static int math_randomseed (lua_State *L) {
|
|||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
#undef MIN_OPT_LEVEL
|
||||||
#define MIN_OPT_LEVEL 1
|
#define MIN_OPT_LEVEL 1
|
||||||
#include "lrodefs.h"
|
#include "lrodefs.h"
|
||||||
const LUA_REG_TYPE math_map[] = {
|
const LUA_REG_TYPE math_map[] = {
|
||||||
|
@ -646,6 +646,7 @@ static const lua_CFunction loaders[] =
|
|||||||
{loader_preload, loader_Lua, loader_C, loader_Croot, NULL};
|
{loader_preload, loader_Lua, loader_C, loader_Croot, NULL};
|
||||||
|
|
||||||
#if LUA_OPTIMIZE_MEMORY > 0
|
#if LUA_OPTIMIZE_MEMORY > 0
|
||||||
|
#undef MIN_OPT_LEVEL
|
||||||
#define MIN_OPT_LEVEL 1
|
#define MIN_OPT_LEVEL 1
|
||||||
#include "lrodefs.h"
|
#include "lrodefs.h"
|
||||||
const LUA_REG_TYPE lmt[] = {
|
const LUA_REG_TYPE lmt[] = {
|
||||||
|
@ -83,9 +83,11 @@ int luaO_rawequalObj (const TValue *t1, const TValue *t2) {
|
|||||||
case LUA_TBOOLEAN:
|
case LUA_TBOOLEAN:
|
||||||
return bvalue(t1) == bvalue(t2); /* boolean true must be 1 !! */
|
return bvalue(t1) == bvalue(t2); /* boolean true must be 1 !! */
|
||||||
case LUA_TLIGHTUSERDATA:
|
case LUA_TLIGHTUSERDATA:
|
||||||
case LUA_TROTABLE:
|
|
||||||
case LUA_TLIGHTFUNCTION:
|
|
||||||
return pvalue(t1) == pvalue(t2);
|
return pvalue(t1) == pvalue(t2);
|
||||||
|
case LUA_TROTABLE:
|
||||||
|
return rvalue(t1) == rvalue(t2);
|
||||||
|
case LUA_TLIGHTFUNCTION:
|
||||||
|
return fvalue(t1) == fvalue(t2);
|
||||||
default:
|
default:
|
||||||
lua_assert(iscollectable(t1));
|
lua_assert(iscollectable(t1));
|
||||||
return gcvalue(t1) == gcvalue(t2);
|
return gcvalue(t1) == gcvalue(t2);
|
||||||
|
@ -16,7 +16,7 @@
|
|||||||
#undef LREGISTER
|
#undef LREGISTER
|
||||||
|
|
||||||
#if (MIN_OPT_LEVEL > 0) && (LUA_OPTIMIZE_MEMORY >= MIN_OPT_LEVEL)
|
#if (MIN_OPT_LEVEL > 0) && (LUA_OPTIMIZE_MEMORY >= MIN_OPT_LEVEL)
|
||||||
#define LUA_REG_TYPE luaR_entry ICACHE_RODATA_ATTR
|
#define LUA_REG_TYPE luaR_entry
|
||||||
#define LSTRKEY LRO_STRKEY
|
#define LSTRKEY LRO_STRKEY
|
||||||
#define LNUMKEY LRO_NUMKEY
|
#define LNUMKEY LRO_NUMKEY
|
||||||
#define LNILKEY LRO_NILKEY
|
#define LNILKEY LRO_NILKEY
|
||||||
|
@ -825,6 +825,7 @@ static int str_format (lua_State *L) {
|
|||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#undef MIN_OPT_LEVEL
|
||||||
#define MIN_OPT_LEVEL 1
|
#define MIN_OPT_LEVEL 1
|
||||||
#include "lrodefs.h"
|
#include "lrodefs.h"
|
||||||
const LUA_REG_TYPE strlib[] = {
|
const LUA_REG_TYPE strlib[] = {
|
||||||
|
@ -266,6 +266,7 @@ static int sort (lua_State *L) {
|
|||||||
/* }====================================================== */
|
/* }====================================================== */
|
||||||
|
|
||||||
|
|
||||||
|
#undef MIN_OPT_LEVEL
|
||||||
#define MIN_OPT_LEVEL 1
|
#define MIN_OPT_LEVEL 1
|
||||||
#include "lrodefs.h"
|
#include "lrodefs.h"
|
||||||
const LUA_REG_TYPE tab_funcs[] = {
|
const LUA_REG_TYPE tab_funcs[] = {
|
||||||
|
@ -221,6 +221,7 @@ static int os_exit (lua_State *L) {
|
|||||||
c_exit(luaL_optint(L, 1, EXIT_SUCCESS));
|
c_exit(luaL_optint(L, 1, EXIT_SUCCESS));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#undef MIN_OPT_LEVEL
|
||||||
#define MIN_OPT_LEVEL 1
|
#define MIN_OPT_LEVEL 1
|
||||||
#include "lrodefs.h"
|
#include "lrodefs.h"
|
||||||
const LUA_REG_TYPE syslib[] = {
|
const LUA_REG_TYPE syslib[] = {
|
||||||
|
@ -319,22 +319,25 @@ void luaV_concat (lua_State *L, int total, int last) {
|
|||||||
lu_mem max_sizet = MAX_SIZET;
|
lu_mem max_sizet = MAX_SIZET;
|
||||||
if (G(L)->memlimit < max_sizet) max_sizet = G(L)->memlimit;
|
if (G(L)->memlimit < max_sizet) max_sizet = G(L)->memlimit;
|
||||||
do {
|
do {
|
||||||
|
/* Any call which does a memory allocation may trim the stack,
|
||||||
|
invalidating top unless the stack is fixed duri ng the allocation */
|
||||||
StkId top = L->base + last + 1;
|
StkId top = L->base + last + 1;
|
||||||
|
fixedstack(L);
|
||||||
int n = 2; /* number of elements handled in this pass (at least 2) */
|
int n = 2; /* number of elements handled in this pass (at least 2) */
|
||||||
if (!(ttisstring(top-2) || ttisnumber(top-2)) || !tostring(L, top-1)) {
|
if (!(ttisstring(top-2) || ttisnumber(top-2)) || !tostring(L, top-1)) {
|
||||||
|
unfixedstack(L);
|
||||||
if (!call_binTM(L, top-2, top-1, top-2, TM_CONCAT)) {
|
if (!call_binTM(L, top-2, top-1, top-2, TM_CONCAT)) {
|
||||||
/* restore 'top' pointer, since stack might have been reallocted */
|
/* restore 'top' pointer, since stack might have been reallocted */
|
||||||
top = L->base + last + 1;
|
top = L->base + last + 1;
|
||||||
luaG_concaterror(L, top-2, top-1);
|
luaG_concaterror(L, top-2, top-1);
|
||||||
}
|
}
|
||||||
} else if (tsvalue(top-1)->len == 0) /* second op is empty? */
|
} else if (tsvalue(top-1)->len == 0) { /* second op is empty? */
|
||||||
(void)tostring(L, top - 2); /* result is first op (as string) */
|
(void)tostring(L, top - 2); /* result is first op (as string) */
|
||||||
else {
|
} else {
|
||||||
/* at least two string values; get as many as possible */
|
/* at least two string values; get as many as possible */
|
||||||
size_t tl = tsvalue(top-1)->len;
|
size_t tl = tsvalue(top-1)->len;
|
||||||
char *buffer;
|
char *buffer;
|
||||||
int i;
|
int i;
|
||||||
fixedstack(L);
|
|
||||||
/* collect total length */
|
/* collect total length */
|
||||||
for (n = 1; n < total && tostring(L, top-n-1); n++) {
|
for (n = 1; n < total && tostring(L, top-n-1); n++) {
|
||||||
size_t l = tsvalue(top-n-1)->len;
|
size_t l = tsvalue(top-n-1)->len;
|
||||||
@ -351,10 +354,10 @@ void luaV_concat (lua_State *L, int total, int last) {
|
|||||||
}
|
}
|
||||||
setsvalue2s(L, top-n, luaS_newlstr(L, buffer, tl));
|
setsvalue2s(L, top-n, luaS_newlstr(L, buffer, tl));
|
||||||
luaZ_resetbuffer(&G(L)->buff);
|
luaZ_resetbuffer(&G(L)->buff);
|
||||||
unfixedstack(L);
|
|
||||||
}
|
}
|
||||||
total -= n-1; /* got `n' strings to create 1 new */
|
total -= n-1; /* got `n' strings to create 1 new */
|
||||||
last -= n-1;
|
last -= n-1;
|
||||||
|
unfixedstack(L);
|
||||||
} while (total > 1); /* repeat until only 1 result left */
|
} while (total > 1); /* repeat until only 1 result left */
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1,11 +1,8 @@
|
|||||||
// Module for interfacing with adc
|
// Module for interfacing with adc
|
||||||
|
|
||||||
//#include "lua.h"
|
#include "module.h"
|
||||||
#include "lualib.h"
|
|
||||||
#include "lauxlib.h"
|
#include "lauxlib.h"
|
||||||
#include "platform.h"
|
#include "platform.h"
|
||||||
#include "auxmods.h"
|
|
||||||
#include "lrotable.h"
|
|
||||||
|
|
||||||
#include "c_types.h"
|
#include "c_types.h"
|
||||||
#include "user_interface.h"
|
#include "user_interface.h"
|
||||||
@ -28,26 +25,10 @@ static int adc_readvdd33( lua_State* L )
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Module function map
|
// Module function map
|
||||||
#define MIN_OPT_LEVEL 2
|
static const LUA_REG_TYPE adc_map[] = {
|
||||||
#include "lrodefs.h"
|
{ LSTRKEY( "read" ), LFUNCVAL( adc_sample ) },
|
||||||
const LUA_REG_TYPE adc_map[] =
|
|
||||||
{
|
|
||||||
{ LSTRKEY( "read" ), LFUNCVAL( adc_sample ) },
|
|
||||||
{ LSTRKEY( "readvdd33" ), LFUNCVAL( adc_readvdd33) },
|
{ LSTRKEY( "readvdd33" ), LFUNCVAL( adc_readvdd33) },
|
||||||
#if LUA_OPTIMIZE_MEMORY > 0
|
|
||||||
|
|
||||||
#endif
|
|
||||||
{ LNILKEY, LNILVAL }
|
{ LNILKEY, LNILVAL }
|
||||||
};
|
};
|
||||||
|
|
||||||
LUALIB_API int luaopen_adc( lua_State *L )
|
NODEMCU_MODULE(ADC, "adc", adc_map, NULL);
|
||||||
{
|
|
||||||
#if LUA_OPTIMIZE_MEMORY > 0
|
|
||||||
return 0;
|
|
||||||
#else // #if LUA_OPTIMIZE_MEMORY > 0
|
|
||||||
luaL_register( L, AUXLIB_ADC, adc_map );
|
|
||||||
// Add constants
|
|
||||||
|
|
||||||
return 1;
|
|
||||||
#endif // #if LUA_OPTIMIZE_MEMORY > 0
|
|
||||||
}
|
|
||||||
|
@ -1,121 +0,0 @@
|
|||||||
// Auxiliary Lua modules. All of them are declared here, then each platform
|
|
||||||
// decides what module(s) to register in the src/platform/xxxxx/platform_conf.h file
|
|
||||||
// FIXME: no longer platform_conf.h - either CPU header file, or board file
|
|
||||||
|
|
||||||
#ifndef __AUXMODS_H__
|
|
||||||
#define __AUXMODS_H__
|
|
||||||
|
|
||||||
#include "lua.h"
|
|
||||||
|
|
||||||
#define AUXLIB_GPIO "gpio"
|
|
||||||
LUALIB_API int ( luaopen_gpio )( lua_State *L );
|
|
||||||
|
|
||||||
#define AUXLIB_SPI "spi"
|
|
||||||
LUALIB_API int ( luaopen_spi )( lua_State *L );
|
|
||||||
|
|
||||||
#define AUXLIB_CAN "can"
|
|
||||||
LUALIB_API int ( luaopen_can )( lua_State *L );
|
|
||||||
|
|
||||||
#define AUXLIB_TMR "tmr"
|
|
||||||
LUALIB_API int ( luaopen_tmr )( lua_State *L );
|
|
||||||
|
|
||||||
#define AUXLIB_PD "pd"
|
|
||||||
LUALIB_API int ( luaopen_pd )( lua_State *L );
|
|
||||||
|
|
||||||
#define AUXLIB_UART "uart"
|
|
||||||
LUALIB_API int ( luaopen_uart )( lua_State *L );
|
|
||||||
|
|
||||||
#define AUXLIB_TERM "term"
|
|
||||||
LUALIB_API int ( luaopen_term )( lua_State *L );
|
|
||||||
|
|
||||||
#define AUXLIB_PWM "pwm"
|
|
||||||
LUALIB_API int ( luaopen_pwm )( lua_State *L );
|
|
||||||
|
|
||||||
#define AUXLIB_PACK "pack"
|
|
||||||
LUALIB_API int ( luaopen_pack )( lua_State *L );
|
|
||||||
|
|
||||||
#define AUXLIB_BIT "bit"
|
|
||||||
LUALIB_API int ( luaopen_bit )( lua_State *L );
|
|
||||||
|
|
||||||
#define AUXLIB_NET "net"
|
|
||||||
LUALIB_API int ( luaopen_net )( lua_State *L );
|
|
||||||
|
|
||||||
#define AUXLIB_CPU "cpu"
|
|
||||||
LUALIB_API int ( luaopen_cpu )( lua_State* L );
|
|
||||||
|
|
||||||
#define AUXLIB_ADC "adc"
|
|
||||||
LUALIB_API int ( luaopen_adc )( lua_State *L );
|
|
||||||
|
|
||||||
#define AUXLIB_RPC "rpc"
|
|
||||||
LUALIB_API int ( luaopen_rpc )( lua_State *L );
|
|
||||||
|
|
||||||
#define AUXLIB_BITARRAY "bitarray"
|
|
||||||
LUALIB_API int ( luaopen_bitarray )( lua_State *L );
|
|
||||||
|
|
||||||
#define AUXLIB_ELUA "elua"
|
|
||||||
LUALIB_API int ( luaopen_elua )( lua_State *L );
|
|
||||||
|
|
||||||
#define AUXLIB_I2C "i2c"
|
|
||||||
LUALIB_API int ( luaopen_i2c )( lua_State *L );
|
|
||||||
|
|
||||||
#define AUXLIB_WIFI "wifi"
|
|
||||||
LUALIB_API int ( luaopen_wifi )( lua_State *L );
|
|
||||||
|
|
||||||
#define AUXLIB_COAP "coap"
|
|
||||||
LUALIB_API int ( luaopen_coap )( lua_State *L );
|
|
||||||
|
|
||||||
#define AUXLIB_MQTT "mqtt"
|
|
||||||
LUALIB_API int ( luaopen_mqtt )( lua_State *L );
|
|
||||||
|
|
||||||
#define AUXLIB_U8G "u8g"
|
|
||||||
LUALIB_API int ( luaopen_u8g )( lua_State *L );
|
|
||||||
|
|
||||||
#define AUXLIB_UCG "ucg"
|
|
||||||
LUALIB_API int ( luaopen_ucg )( lua_State *L );
|
|
||||||
|
|
||||||
#define AUXLIB_NODE "node"
|
|
||||||
LUALIB_API int ( luaopen_node )( lua_State *L );
|
|
||||||
|
|
||||||
#define AUXLIB_FILE "file"
|
|
||||||
LUALIB_API int ( luaopen_file )( lua_State *L );
|
|
||||||
|
|
||||||
#define AUXLIB_OW "ow"
|
|
||||||
LUALIB_API int ( luaopen_ow )( lua_State *L );
|
|
||||||
|
|
||||||
#define AUXLIB_CJSON "cjson"
|
|
||||||
LUALIB_API int ( luaopen_cjson )( lua_State *L );
|
|
||||||
|
|
||||||
#define AUXLIB_CRYPTO "crypto"
|
|
||||||
LUALIB_API int ( luaopen_crypto )( lua_State *L );
|
|
||||||
|
|
||||||
#define AUXLIB_RC "rc"
|
|
||||||
LUALIB_API int ( luaopen_rc )( lua_State *L );
|
|
||||||
|
|
||||||
#define AUXLIB_DHT "dht"
|
|
||||||
LUALIB_API int ( luaopen_dht )( lua_State *L );
|
|
||||||
|
|
||||||
// Helper macros
|
|
||||||
#define MOD_CHECK_ID( mod, id )\
|
|
||||||
if( !platform_ ## mod ## _exists( id ) )\
|
|
||||||
return luaL_error( L, #mod" %d does not exist", ( unsigned )id )
|
|
||||||
|
|
||||||
#define MOD_CHECK_TIMER( id )\
|
|
||||||
if( id == PLATFORM_TIMER_SYS_ID && !platform_timer_sys_available() )\
|
|
||||||
return luaL_error( L, "the system timer is not available on this platform" );\
|
|
||||||
if( !platform_timer_exists( id ) )\
|
|
||||||
return luaL_error( L, "timer %d does not exist", ( unsigned )id )\
|
|
||||||
|
|
||||||
#define MOD_CHECK_RES_ID( mod, id, resmod, resid )\
|
|
||||||
if( !platform_ ## mod ## _check_ ## resmod ## _id( id, resid ) )\
|
|
||||||
return luaL_error( L, #resmod" %d not valid with " #mod " %d", ( unsigned )resid, ( unsigned )id )
|
|
||||||
|
|
||||||
#define MOD_REG_NUMBER( L, name, val )\
|
|
||||||
lua_pushnumber( L, val );\
|
|
||||||
lua_setfield( L, -2, name )
|
|
||||||
|
|
||||||
#define MOD_REG_LUDATA( L, name, val )\
|
|
||||||
lua_pushlightuserdata( L, val );\
|
|
||||||
lua_setfield( L, -2, name )
|
|
||||||
|
|
||||||
#endif
|
|
||||||
|
|
@ -5,13 +5,10 @@
|
|||||||
// Modified by BogdanM for eLua
|
// Modified by BogdanM for eLua
|
||||||
|
|
||||||
|
|
||||||
|
#include "module.h"
|
||||||
#include "c_limits.h"
|
#include "c_limits.h"
|
||||||
|
|
||||||
//#include "lua.h"
|
|
||||||
#include "lauxlib.h"
|
#include "lauxlib.h"
|
||||||
#include "auxmods.h"
|
|
||||||
// #include "type.h"
|
|
||||||
#include "lrotable.h"
|
|
||||||
|
|
||||||
/* FIXME: Assume size_t is an unsigned lua_Integer */
|
/* FIXME: Assume size_t is an unsigned lua_Integer */
|
||||||
typedef size_t lua_UInteger;
|
typedef size_t lua_UInteger;
|
||||||
@ -122,9 +119,7 @@ static int bit_clear( lua_State* L )
|
|||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
#define MIN_OPT_LEVEL 2
|
static const LUA_REG_TYPE bit_map[] = {
|
||||||
#include "lrodefs.h"
|
|
||||||
const LUA_REG_TYPE bit_map[] = {
|
|
||||||
{ LSTRKEY( "bnot" ), LFUNCVAL( bit_bnot ) },
|
{ LSTRKEY( "bnot" ), LFUNCVAL( bit_bnot ) },
|
||||||
{ LSTRKEY( "band" ), LFUNCVAL( bit_band ) },
|
{ LSTRKEY( "band" ), LFUNCVAL( bit_band ) },
|
||||||
{ LSTRKEY( "bor" ), LFUNCVAL( bit_bor ) },
|
{ LSTRKEY( "bor" ), LFUNCVAL( bit_bor ) },
|
||||||
@ -140,6 +135,4 @@ const LUA_REG_TYPE bit_map[] = {
|
|||||||
{ LNILKEY, LNILVAL}
|
{ LNILKEY, LNILVAL}
|
||||||
};
|
};
|
||||||
|
|
||||||
LUALIB_API int luaopen_bit (lua_State *L) {
|
NODEMCU_MODULE(BIT, "bit", bit_map, NULL);
|
||||||
LREGISTER( L, "bit", bit_map );
|
|
||||||
}
|
|
||||||
|
@ -1,8 +1,6 @@
|
|||||||
#include "lualib.h"
|
#include "module.h"
|
||||||
#include "lauxlib.h"
|
#include "lauxlib.h"
|
||||||
#include "platform.h"
|
#include "platform.h"
|
||||||
#include "auxmods.h"
|
|
||||||
#include "lrotable.h"
|
|
||||||
#include "c_stdlib.h"
|
#include "c_stdlib.h"
|
||||||
#include "c_string.h"
|
#include "c_string.h"
|
||||||
|
|
||||||
@ -185,19 +183,12 @@ static int ICACHE_FLASH_ATTR bmp085_lua_pressure(lua_State* L) {
|
|||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
#define MIN_OPT_LEVEL 2
|
static const LUA_REG_TYPE bmp085_map[] = {
|
||||||
#include "lrodefs.h"
|
{ LSTRKEY( "temperature" ), LFUNCVAL( bmp085_lua_temperature )},
|
||||||
const LUA_REG_TYPE bmp085_map[] =
|
{ LSTRKEY( "pressure" ), LFUNCVAL( bmp085_lua_pressure )},
|
||||||
{
|
|
||||||
{ LSTRKEY( "temperature" ), LFUNCVAL( bmp085_lua_temperature )},
|
|
||||||
{ LSTRKEY( "pressure" ), LFUNCVAL( bmp085_lua_pressure )},
|
|
||||||
{ LSTRKEY( "pressure_raw" ), LFUNCVAL( bmp085_lua_pressure_raw )},
|
{ LSTRKEY( "pressure_raw" ), LFUNCVAL( bmp085_lua_pressure_raw )},
|
||||||
{ LSTRKEY( "init" ), LFUNCVAL( bmp085_init )},
|
{ LSTRKEY( "init" ), LFUNCVAL( bmp085_init )},
|
||||||
{ LNILKEY, LNILVAL}
|
{ LNILKEY, LNILVAL}
|
||||||
};
|
};
|
||||||
|
|
||||||
LUALIB_API int luaopen_bmp085(lua_State *L) {
|
NODEMCU_MODULE(BMP085, "bmp085", bmp085_map, NULL);
|
||||||
LREGISTER(L, "bmp085", bmp085_map);
|
|
||||||
return 1;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
@ -37,10 +37,10 @@
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
// #include <assert.h>
|
// #include <assert.h>
|
||||||
|
#include "module.h"
|
||||||
#include "c_string.h"
|
#include "c_string.h"
|
||||||
#include "c_math.h"
|
#include "c_math.h"
|
||||||
#include "c_limits.h"
|
#include "c_limits.h"
|
||||||
#include "lua.h"
|
|
||||||
#include "lauxlib.h"
|
#include "lauxlib.h"
|
||||||
#include "flash_api.h"
|
#include "flash_api.h"
|
||||||
|
|
||||||
@ -1528,53 +1528,7 @@ static int json_protect_conversion(lua_State *l)
|
|||||||
* errors are memory related */
|
* errors are memory related */
|
||||||
return luaL_error(l, "Memory allocation error in CJSON protected call");
|
return luaL_error(l, "Memory allocation error in CJSON protected call");
|
||||||
}
|
}
|
||||||
#endif
|
|
||||||
|
|
||||||
// Module function map
|
|
||||||
#define MIN_OPT_LEVEL 2
|
|
||||||
#include "lrodefs.h"
|
|
||||||
const LUA_REG_TYPE cjson_map[] =
|
|
||||||
{
|
|
||||||
{ LSTRKEY( "encode" ), LFUNCVAL( json_encode ) },
|
|
||||||
{ LSTRKEY( "decode" ), LFUNCVAL( json_decode ) },
|
|
||||||
// { LSTRKEY( "encode_sparse_array" ), LFUNCVAL( json_cfg_encode_sparse_array ) },
|
|
||||||
// { LSTRKEY( "encode_max_depth" ), LFUNCVAL( json_cfg_encode_max_depth ) },
|
|
||||||
// { LSTRKEY( "decode_max_depth" ), LFUNCVAL( json_cfg_decode_max_depth ) },
|
|
||||||
// { LSTRKEY( "encode_number_precision" ), LFUNCVAL( json_cfg_encode_number_precision ) },
|
|
||||||
// { LSTRKEY( "encode_keep_buffer" ), LFUNCVAL( json_cfg_encode_keep_buffer ) },
|
|
||||||
// { LSTRKEY( "encode_invalid_numbers" ), LFUNCVAL( json_cfg_encode_invalid_numbers ) },
|
|
||||||
// { LSTRKEY( "decode_invalid_numbers" ), LFUNCVAL( json_cfg_decode_invalid_numbers ) },
|
|
||||||
// { LSTRKEY( "new" ), LFUNCVAL( lua_cjson_new ) },
|
|
||||||
#if LUA_OPTIMIZE_MEMORY > 0
|
|
||||||
|
|
||||||
#endif
|
|
||||||
{ LNILKEY, LNILVAL }
|
|
||||||
};
|
|
||||||
|
|
||||||
LUALIB_API int luaopen_cjson( lua_State *L )
|
|
||||||
{
|
|
||||||
cjson_mem_setlua (L);
|
|
||||||
|
|
||||||
/* Initialise number conversions */
|
|
||||||
// fpconv_init(); // not needed for a specific cpu.
|
|
||||||
if(-1==cfg_init(&_cfg)){
|
|
||||||
return luaL_error(L, "BUG: Unable to init config for cjson");;
|
|
||||||
}
|
|
||||||
#if LUA_OPTIMIZE_MEMORY > 0
|
|
||||||
return 0;
|
|
||||||
#else // #if LUA_OPTIMIZE_MEMORY > 0
|
|
||||||
luaL_register( L, AUXLIB_CJSON, cjson_map );
|
|
||||||
// Add constants
|
|
||||||
/* Set cjson.null */
|
|
||||||
lua_pushlightuserdata(l, NULL);
|
|
||||||
lua_setfield(l, -2, "null");
|
|
||||||
|
|
||||||
/* Return cjson table */
|
|
||||||
return 1;
|
|
||||||
#endif // #if LUA_OPTIMIZE_MEMORY > 0
|
|
||||||
}
|
|
||||||
|
|
||||||
#if 0
|
|
||||||
/* Return cjson module table */
|
/* Return cjson module table */
|
||||||
static int lua_cjson_new(lua_State *l)
|
static int lua_cjson_new(lua_State *l)
|
||||||
{
|
{
|
||||||
@ -1644,5 +1598,34 @@ int luaopen_cjson_safe(lua_State *l)
|
|||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
// Module function map
|
||||||
|
static const LUA_REG_TYPE cjson_map[] = {
|
||||||
|
{ LSTRKEY( "encode" ), LFUNCVAL( json_encode ) },
|
||||||
|
{ LSTRKEY( "decode" ), LFUNCVAL( json_decode ) },
|
||||||
|
//{ LSTRKEY( "encode_sparse_array" ), LFUNCVAL( json_cfg_encode_sparse_array ) },
|
||||||
|
//{ LSTRKEY( "encode_max_depth" ), LFUNCVAL( json_cfg_encode_max_depth ) },
|
||||||
|
//{ LSTRKEY( "decode_max_depth" ), LFUNCVAL( json_cfg_decode_max_depth ) },
|
||||||
|
//{ LSTRKEY( "encode_number_precision" ), LFUNCVAL( json_cfg_encode_number_precision ) },
|
||||||
|
//{ LSTRKEY( "encode_keep_buffer" ), LFUNCVAL( json_cfg_encode_keep_buffer ) },
|
||||||
|
//{ LSTRKEY( "encode_invalid_numbers" ), LFUNCVAL( json_cfg_encode_invalid_numbers ) },
|
||||||
|
//{ LSTRKEY( "decode_invalid_numbers" ), LFUNCVAL( json_cfg_decode_invalid_numbers ) },
|
||||||
|
//{ LSTRKEY( "new" ), LFUNCVAL( lua_cjson_new ) },
|
||||||
|
{ LNILKEY, LNILVAL }
|
||||||
|
};
|
||||||
|
|
||||||
|
int luaopen_cjson( lua_State *L )
|
||||||
|
{
|
||||||
|
cjson_mem_setlua (L);
|
||||||
|
|
||||||
|
/* Initialise number conversions */
|
||||||
|
// fpconv_init(); // not needed for a specific cpu.
|
||||||
|
if(-1==cfg_init(&_cfg)){
|
||||||
|
return luaL_error(L, "BUG: Unable to init config for cjson");;
|
||||||
|
}
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
NODEMCU_MODULE(CJSON, "cjson", cjson_map, luaopen_cjson);
|
||||||
/* vi:ai et sw=4 ts=4:
|
/* vi:ai et sw=4 ts=4:
|
||||||
*/
|
*/
|
||||||
|
@ -1,11 +1,8 @@
|
|||||||
// Module for coapwork
|
// Module for coapwork
|
||||||
|
|
||||||
//#include "lua.h"
|
#include "module.h"
|
||||||
#include "lualib.h"
|
|
||||||
#include "lauxlib.h"
|
#include "lauxlib.h"
|
||||||
#include "platform.h"
|
#include "platform.h"
|
||||||
#include "auxmods.h"
|
|
||||||
#include "lrotable.h"
|
|
||||||
|
|
||||||
#include "c_string.h"
|
#include "c_string.h"
|
||||||
#include "c_stdlib.h"
|
#include "c_stdlib.h"
|
||||||
@ -561,99 +558,48 @@ static int coap_client_delete( lua_State* L )
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Module function map
|
// Module function map
|
||||||
#define MIN_OPT_LEVEL 2
|
static const LUA_REG_TYPE coap_server_map[] = {
|
||||||
#include "lrodefs.h"
|
{ LSTRKEY( "listen" ), LFUNCVAL( coap_server_listen ) },
|
||||||
static const LUA_REG_TYPE coap_server_map[] =
|
{ LSTRKEY( "close" ), LFUNCVAL( coap_server_close ) },
|
||||||
{
|
{ LSTRKEY( "var" ), LFUNCVAL( coap_server_var ) },
|
||||||
{ LSTRKEY( "listen" ), LFUNCVAL ( coap_server_listen ) },
|
{ LSTRKEY( "func" ), LFUNCVAL( coap_server_func ) },
|
||||||
{ LSTRKEY( "close" ), LFUNCVAL ( coap_server_close ) },
|
{ LSTRKEY( "__gc" ), LFUNCVAL( coap_server_delete ) },
|
||||||
{ LSTRKEY( "var" ), LFUNCVAL ( coap_server_var ) },
|
{ LSTRKEY( "__index" ), LROVAL( coap_server_map ) },
|
||||||
{ LSTRKEY( "func" ), LFUNCVAL ( coap_server_func ) },
|
|
||||||
{ LSTRKEY( "__gc" ), LFUNCVAL ( coap_server_delete ) },
|
|
||||||
#if LUA_OPTIMIZE_MEMORY > 0
|
|
||||||
{ LSTRKEY( "__index" ), LROVAL ( coap_server_map ) },
|
|
||||||
#endif
|
|
||||||
{ LNILKEY, LNILVAL }
|
{ LNILKEY, LNILVAL }
|
||||||
};
|
};
|
||||||
|
|
||||||
static const LUA_REG_TYPE coap_client_map[] =
|
static const LUA_REG_TYPE coap_client_map[] = {
|
||||||
{
|
{ LSTRKEY( "get" ), LFUNCVAL( coap_client_get ) },
|
||||||
{ LSTRKEY( "get" ), LFUNCVAL ( coap_client_get ) },
|
{ LSTRKEY( "post" ), LFUNCVAL( coap_client_post ) },
|
||||||
{ LSTRKEY( "post" ), LFUNCVAL ( coap_client_post ) },
|
{ LSTRKEY( "put" ), LFUNCVAL( coap_client_put ) },
|
||||||
{ LSTRKEY( "put" ), LFUNCVAL ( coap_client_put ) },
|
{ LSTRKEY( "delete" ), LFUNCVAL( coap_client_delete ) },
|
||||||
{ LSTRKEY( "delete" ), LFUNCVAL ( coap_client_delete ) },
|
{ LSTRKEY( "__gc" ), LFUNCVAL( coap_client_gcdelete ) },
|
||||||
{ LSTRKEY( "__gc" ), LFUNCVAL ( coap_client_gcdelete ) },
|
{ LSTRKEY( "__index" ), LROVAL( coap_client_map ) },
|
||||||
#if LUA_OPTIMIZE_MEMORY > 0
|
|
||||||
{ LSTRKEY( "__index" ), LROVAL ( coap_client_map ) },
|
|
||||||
#endif
|
|
||||||
{ LNILKEY, LNILVAL }
|
{ LNILKEY, LNILVAL }
|
||||||
};
|
};
|
||||||
|
|
||||||
const LUA_REG_TYPE coap_map[] =
|
static const LUA_REG_TYPE coap_map[] =
|
||||||
{
|
{
|
||||||
{ LSTRKEY( "Server" ), LFUNCVAL ( coap_createServer ) },
|
{ LSTRKEY( "Server" ), LFUNCVAL( coap_createServer ) },
|
||||||
{ LSTRKEY( "Client" ), LFUNCVAL ( coap_createClient ) },
|
{ LSTRKEY( "Client" ), LFUNCVAL( coap_createClient ) },
|
||||||
#if LUA_OPTIMIZE_MEMORY > 0
|
{ LSTRKEY( "CON" ), LNUMVAL( COAP_TYPE_CON ) },
|
||||||
{ LSTRKEY( "CON" ), LNUMVAL( COAP_TYPE_CON ) },
|
{ LSTRKEY( "NON" ), LNUMVAL( COAP_TYPE_NONCON ) },
|
||||||
{ LSTRKEY( "NON" ), LNUMVAL( COAP_TYPE_NONCON ) },
|
{ LSTRKEY( "TEXT_PLAIN"), LNUMVAL( COAP_CONTENTTYPE_TEXT_PLAIN ) },
|
||||||
{ LSTRKEY( "TEXT_PLAIN"), LNUMVAL( COAP_CONTENTTYPE_TEXT_PLAIN ) },
|
{ LSTRKEY( "LINKFORMAT"), LNUMVAL( COAP_CONTENTTYPE_APPLICATION_LINKFORMAT ) },
|
||||||
{ LSTRKEY( "LINKFORMAT"), LNUMVAL( COAP_CONTENTTYPE_APPLICATION_LINKFORMAT ) },
|
{ LSTRKEY( "XML"), LNUMVAL( COAP_CONTENTTYPE_APPLICATION_XML ) },
|
||||||
{ LSTRKEY( "XML"), LNUMVAL( COAP_CONTENTTYPE_APPLICATION_XML ) },
|
|
||||||
{ LSTRKEY( "OCTET_STREAM"), LNUMVAL( COAP_CONTENTTYPE_APPLICATION_OCTET_STREAM ) },
|
{ LSTRKEY( "OCTET_STREAM"), LNUMVAL( COAP_CONTENTTYPE_APPLICATION_OCTET_STREAM ) },
|
||||||
{ LSTRKEY( "EXI"), LNUMVAL( COAP_CONTENTTYPE_APPLICATION_EXI ) },
|
{ LSTRKEY( "EXI"), LNUMVAL( COAP_CONTENTTYPE_APPLICATION_EXI ) },
|
||||||
{ LSTRKEY( "JSON"), LNUMVAL( COAP_CONTENTTYPE_APPLICATION_JSON) },
|
{ LSTRKEY( "JSON"), LNUMVAL( COAP_CONTENTTYPE_APPLICATION_JSON) },
|
||||||
|
|
||||||
{ LSTRKEY( "__metatable" ), LROVAL( coap_map ) },
|
{ LSTRKEY( "__metatable" ), LROVAL( coap_map ) },
|
||||||
#endif
|
|
||||||
{ LNILKEY, LNILVAL }
|
{ LNILKEY, LNILVAL }
|
||||||
};
|
};
|
||||||
|
|
||||||
LUALIB_API int luaopen_coap( lua_State *L )
|
int luaopen_coap( lua_State *L )
|
||||||
{
|
{
|
||||||
endpoint_setup();
|
endpoint_setup();
|
||||||
#if LUA_OPTIMIZE_MEMORY > 0
|
|
||||||
luaL_rometatable(L, "coap_server", (void *)coap_server_map); // create metatable for coap_server
|
luaL_rometatable(L, "coap_server", (void *)coap_server_map); // create metatable for coap_server
|
||||||
luaL_rometatable(L, "coap_client", (void *)coap_client_map); // create metatable for coap_client
|
luaL_rometatable(L, "coap_client", (void *)coap_client_map); // create metatable for coap_client
|
||||||
return 0;
|
return 0;
|
||||||
#else // #if LUA_OPTIMIZE_MEMORY > 0
|
|
||||||
int n;
|
|
||||||
luaL_register( L, AUXLIB_COAP, coap_map );
|
|
||||||
|
|
||||||
// Set it as its own metatable
|
|
||||||
lua_pushvalue( L, -1 );
|
|
||||||
lua_setmetatable( L, -2 );
|
|
||||||
|
|
||||||
// Module constants
|
|
||||||
MOD_REG_NUMBER( L, "CON", COAP_TYPE_CON );
|
|
||||||
MOD_REG_NUMBER( L, "NON", COAP_TYPE_NONCON );
|
|
||||||
MOD_REG_NUMBER( L, "TEXT_PLAIN", COAP_CONTENTTYPE_TEXT_PLAIN );
|
|
||||||
MOD_REG_NUMBER( L, "LINKFORMAT", COAP_CONTENTTYPE_APPLICATION_LINKFORMAT );
|
|
||||||
MOD_REG_NUMBER( L, "XML", COAP_CONTENTTYPE_APPLICATION_XML);
|
|
||||||
MOD_REG_NUMBER( L, "OCTET_STREAM", COAP_CONTENTTYPE_APPLICATION_OCTET_STREAM);
|
|
||||||
MOD_REG_NUMBER( L, "EXI", COAP_CONTENTTYPE_APPLICATION_EXI);
|
|
||||||
MOD_REG_NUMBER( L, "JSON", COAP_CONTENTTYPE_APPLICATION_JSON);
|
|
||||||
|
|
||||||
n = lua_gettop(L);
|
|
||||||
|
|
||||||
// create metatable
|
|
||||||
luaL_newmetatable(L, "coap_server");
|
|
||||||
// metatable.__index = metatable
|
|
||||||
lua_pushliteral(L, "__index");
|
|
||||||
lua_pushvalue(L,-2);
|
|
||||||
lua_rawset(L,-3);
|
|
||||||
// Setup the methods inside metatable
|
|
||||||
luaL_register( L, NULL, coap_server_map );
|
|
||||||
|
|
||||||
lua_settop(L, n);
|
|
||||||
// create metatable
|
|
||||||
luaL_newmetatable(L, "coap_client");
|
|
||||||
// metatable.__index = metatable
|
|
||||||
lua_pushliteral(L, "__index");
|
|
||||||
lua_pushvalue(L,-2);
|
|
||||||
lua_rawset(L,-3);
|
|
||||||
// Setup the methods inside metatable
|
|
||||||
luaL_register( L, NULL, coap_client_map );
|
|
||||||
|
|
||||||
return 1;
|
|
||||||
#endif // #if LUA_OPTIMIZE_MEMORY > 0
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
NODEMCU_MODULE(COAP, "coap", coap_map, luaopen_coap);
|
||||||
|
@ -1,11 +1,8 @@
|
|||||||
// Module for cryptography
|
// Module for cryptography
|
||||||
|
|
||||||
//#include "lua.h"
|
#include "module.h"
|
||||||
#include "lualib.h"
|
|
||||||
#include "lauxlib.h"
|
#include "lauxlib.h"
|
||||||
#include "platform.h"
|
#include "platform.h"
|
||||||
#include "auxmods.h"
|
|
||||||
#include "lrotable.h"
|
|
||||||
#include "c_types.h"
|
#include "c_types.h"
|
||||||
#include "c_stdlib.h"
|
#include "c_stdlib.h"
|
||||||
#include "../crypto/digests.h"
|
#include "../crypto/digests.h"
|
||||||
@ -153,31 +150,14 @@ static int crypto_lhmac (lua_State *L)
|
|||||||
|
|
||||||
|
|
||||||
// Module function map
|
// Module function map
|
||||||
#define MIN_OPT_LEVEL 2
|
static const LUA_REG_TYPE crypto_map[] = {
|
||||||
#include "lrodefs.h"
|
{ LSTRKEY( "sha1" ), LFUNCVAL( crypto_sha1 ) },
|
||||||
const LUA_REG_TYPE crypto_map[] =
|
|
||||||
{
|
|
||||||
{ LSTRKEY( "sha1" ), LFUNCVAL( crypto_sha1 ) },
|
|
||||||
{ LSTRKEY( "toBase64" ), LFUNCVAL( crypto_base64_encode ) },
|
{ LSTRKEY( "toBase64" ), LFUNCVAL( crypto_base64_encode ) },
|
||||||
{ LSTRKEY( "toHex" ), LFUNCVAL( crypto_hex_encode ) },
|
{ LSTRKEY( "toHex" ), LFUNCVAL( crypto_hex_encode ) },
|
||||||
{ LSTRKEY( "mask" ), LFUNCVAL( crypto_mask ) },
|
{ LSTRKEY( "mask" ), LFUNCVAL( crypto_mask ) },
|
||||||
{ LSTRKEY( "hash" ), LFUNCVAL( crypto_lhash ) },
|
{ LSTRKEY( "hash" ), LFUNCVAL( crypto_lhash ) },
|
||||||
{ LSTRKEY( "hmac" ), LFUNCVAL( crypto_lhmac ) },
|
{ LSTRKEY( "hmac" ), LFUNCVAL( crypto_lhmac ) },
|
||||||
|
|
||||||
#if LUA_OPTIMIZE_MEMORY > 0
|
|
||||||
|
|
||||||
#endif
|
|
||||||
{ LNILKEY, LNILVAL }
|
{ LNILKEY, LNILVAL }
|
||||||
};
|
};
|
||||||
|
|
||||||
LUALIB_API int luaopen_crypto( lua_State *L )
|
NODEMCU_MODULE(CRYPTO, "crypto", crypto_map, NULL);
|
||||||
{
|
|
||||||
#if LUA_OPTIMIZE_MEMORY > 0
|
|
||||||
return 0;
|
|
||||||
#else // #if LUA_OPTIMIZE_MEMORY > 0
|
|
||||||
luaL_register( L, AUXLIB_CRYPTO, crypto_map );
|
|
||||||
// Add constants
|
|
||||||
|
|
||||||
return 1;
|
|
||||||
#endif // #if LUA_OPTIMIZE_MEMORY > 0
|
|
||||||
}
|
|
||||||
|
@ -1,9 +1,8 @@
|
|||||||
// Module for interfacing with the DHTxx sensors (xx = 11-21-22-33-44).
|
// Module for interfacing with the DHTxx sensors (xx = 11-21-22-33-44).
|
||||||
|
|
||||||
#include "lualib.h"
|
#include "module.h"
|
||||||
#include "lauxlib.h"
|
#include "lauxlib.h"
|
||||||
#include "auxmods.h"
|
#include "platform.h"
|
||||||
#include "lrotable.h"
|
|
||||||
#include "cpu_esp8266.h"
|
#include "cpu_esp8266.h"
|
||||||
#include "dht.h"
|
#include "dht.h"
|
||||||
|
|
||||||
@ -100,30 +99,14 @@ static int dht_lapi_readxx( lua_State *L )
|
|||||||
// }
|
// }
|
||||||
|
|
||||||
// Module function map
|
// Module function map
|
||||||
#define MIN_OPT_LEVEL 2
|
static const LUA_REG_TYPE dht_map[] = {
|
||||||
#include "lrodefs.h"
|
{ LSTRKEY( "read" ), LFUNCVAL( dht_lapi_read ) },
|
||||||
const LUA_REG_TYPE dht_map[] =
|
{ LSTRKEY( "read11" ), LFUNCVAL( dht_lapi_read11 ) },
|
||||||
{
|
{ LSTRKEY( "readxx" ), LFUNCVAL( dht_lapi_readxx ) },
|
||||||
{ LSTRKEY( "read" ), LFUNCVAL( dht_lapi_read ) },
|
{ LSTRKEY( "OK" ), LNUMVAL( DHTLIB_OK ) },
|
||||||
{ LSTRKEY( "read11" ), LFUNCVAL( dht_lapi_read11 ) },
|
|
||||||
{ LSTRKEY( "readxx" ), LFUNCVAL( dht_lapi_readxx ) },
|
|
||||||
#if LUA_OPTIMIZE_MEMORY > 0
|
|
||||||
{ LSTRKEY( "OK" ), LNUMVAL( DHTLIB_OK ) },
|
|
||||||
{ LSTRKEY( "ERROR_CHECKSUM" ), LNUMVAL( DHTLIB_ERROR_CHECKSUM ) },
|
{ LSTRKEY( "ERROR_CHECKSUM" ), LNUMVAL( DHTLIB_ERROR_CHECKSUM ) },
|
||||||
{ LSTRKEY( "ERROR_TIMEOUT" ), LNUMVAL( DHTLIB_ERROR_TIMEOUT ) },
|
{ LSTRKEY( "ERROR_TIMEOUT" ), LNUMVAL( DHTLIB_ERROR_TIMEOUT ) },
|
||||||
#endif
|
|
||||||
{ LNILKEY, LNILVAL }
|
{ LNILKEY, LNILVAL }
|
||||||
};
|
};
|
||||||
|
|
||||||
LUALIB_API int luaopen_dht( lua_State *L )
|
NODEMCU_MODULE(DHT, "dht", dht_map, NULL);
|
||||||
{
|
|
||||||
#if LUA_OPTIMIZE_MEMORY > 0
|
|
||||||
return 0;
|
|
||||||
#else // #if LUA_OPTIMIZE_MEMORY > 0
|
|
||||||
luaL_register( L, AUXLIB_DHT, dht_map );
|
|
||||||
|
|
||||||
// Add the constants
|
|
||||||
|
|
||||||
return 1;
|
|
||||||
#endif // #if LUA_OPTIMIZE_MEMORY > 0
|
|
||||||
}
|
|
||||||
|
@ -31,12 +31,9 @@
|
|||||||
* @author Robert Foss <dev@robertfoss.se>
|
* @author Robert Foss <dev@robertfoss.se>
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
#include "module.h"
|
||||||
#include "lualib.h"
|
|
||||||
#include "lauxlib.h"
|
#include "lauxlib.h"
|
||||||
#include "platform.h"
|
#include "platform.h"
|
||||||
#include "auxmods.h"
|
|
||||||
#include "lrotable.h"
|
|
||||||
#include "c_stdlib.h"
|
#include "c_stdlib.h"
|
||||||
#include "c_string.h"
|
#include "c_string.h"
|
||||||
#include "user_interface.h"
|
#include "user_interface.h"
|
||||||
@ -643,6 +640,10 @@ static void enduser_setup_ap_start(void)
|
|||||||
struct softap_config cnf;
|
struct softap_config cnf;
|
||||||
c_memset(&(cnf), 0, sizeof(struct softap_config));
|
c_memset(&(cnf), 0, sizeof(struct softap_config));
|
||||||
|
|
||||||
|
#ifndef ENDUSER_SETUP_AP_SSID
|
||||||
|
#define ENDUSER_SETUP_AP_SSID "SetupGadget"
|
||||||
|
#endif
|
||||||
|
|
||||||
char ssid[] = ENDUSER_SETUP_AP_SSID;
|
char ssid[] = ENDUSER_SETUP_AP_SSID;
|
||||||
int ssid_name_len = c_strlen(ENDUSER_SETUP_AP_SSID);
|
int ssid_name_len = c_strlen(ENDUSER_SETUP_AP_SSID);
|
||||||
c_memcpy(&(cnf.ssid), ssid, ssid_name_len);
|
c_memcpy(&(cnf.ssid), ssid, ssid_name_len);
|
||||||
@ -929,17 +930,10 @@ static int enduser_setup_stop(lua_State* L)
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
#define MIN_OPT_LEVEL 2
|
static const LUA_REG_TYPE enduser_setup_map[] = {
|
||||||
#include "lrodefs.h"
|
|
||||||
const LUA_REG_TYPE enduser_setup_map[] =
|
|
||||||
{
|
|
||||||
{ LSTRKEY( "start" ), LFUNCVAL( enduser_setup_start )},
|
{ LSTRKEY( "start" ), LFUNCVAL( enduser_setup_start )},
|
||||||
{ LSTRKEY( "stop" ), LFUNCVAL( enduser_setup_stop )},
|
{ LSTRKEY( "stop" ), LFUNCVAL( enduser_setup_stop )},
|
||||||
{ LNILKEY, LNILVAL}
|
{ LNILKEY, LNILVAL}
|
||||||
};
|
};
|
||||||
|
|
||||||
LUALIB_API int luaopen_enduser_setup(lua_State *L) {
|
NODEMCU_MODULE(ENDUSER_SETUP, "enduser_setup", enduser_setup_map, NULL);
|
||||||
LREGISTER(L, "enduser_setup", enduser_setup_map);
|
|
||||||
return 1;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
@ -1,11 +1,8 @@
|
|||||||
// Module for interfacing with file system
|
// Module for interfacing with file system
|
||||||
|
|
||||||
#include "lua.h"
|
#include "module.h"
|
||||||
#include "lualib.h"
|
|
||||||
#include "lauxlib.h"
|
#include "lauxlib.h"
|
||||||
#include "platform.h"
|
#include "platform.h"
|
||||||
#include "auxmods.h"
|
|
||||||
#include "lrotable.h"
|
|
||||||
|
|
||||||
#include "c_types.h"
|
#include "c_types.h"
|
||||||
#include "flash_fs.h"
|
#include "flash_fs.h"
|
||||||
@ -299,42 +296,24 @@ static int file_writeline( lua_State* L )
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Module function map
|
// Module function map
|
||||||
#define MIN_OPT_LEVEL 2
|
static const LUA_REG_TYPE file_map[] = {
|
||||||
#include "lrodefs.h"
|
{ LSTRKEY( "list" ), LFUNCVAL( file_list ) },
|
||||||
const LUA_REG_TYPE file_map[] =
|
{ LSTRKEY( "open" ), LFUNCVAL( file_open ) },
|
||||||
{
|
{ LSTRKEY( "close" ), LFUNCVAL( file_close ) },
|
||||||
{ LSTRKEY( "list" ), LFUNCVAL( file_list ) },
|
{ LSTRKEY( "write" ), LFUNCVAL( file_write ) },
|
||||||
{ LSTRKEY( "open" ), LFUNCVAL( file_open ) },
|
|
||||||
{ LSTRKEY( "close" ), LFUNCVAL( file_close ) },
|
|
||||||
{ LSTRKEY( "write" ), LFUNCVAL( file_write ) },
|
|
||||||
{ LSTRKEY( "writeline" ), LFUNCVAL( file_writeline ) },
|
{ LSTRKEY( "writeline" ), LFUNCVAL( file_writeline ) },
|
||||||
{ LSTRKEY( "read" ), LFUNCVAL( file_read ) },
|
{ LSTRKEY( "read" ), LFUNCVAL( file_read ) },
|
||||||
{ LSTRKEY( "readline" ), LFUNCVAL( file_readline ) },
|
{ LSTRKEY( "readline" ), LFUNCVAL( file_readline ) },
|
||||||
{ LSTRKEY( "format" ), LFUNCVAL( file_format ) },
|
{ LSTRKEY( "format" ), LFUNCVAL( file_format ) },
|
||||||
#if defined(BUILD_WOFS)
|
#if defined(BUILD_SPIFFS) && !defined(BUILD_WOFS)
|
||||||
#elif defined(BUILD_SPIFFS)
|
{ LSTRKEY( "remove" ), LFUNCVAL( file_remove ) },
|
||||||
{ LSTRKEY( "remove" ), LFUNCVAL( file_remove ) },
|
{ LSTRKEY( "seek" ), LFUNCVAL( file_seek ) },
|
||||||
{ LSTRKEY( "seek" ), LFUNCVAL( file_seek ) },
|
{ LSTRKEY( "flush" ), LFUNCVAL( file_flush ) },
|
||||||
{ LSTRKEY( "flush" ), LFUNCVAL( file_flush ) },
|
//{ LSTRKEY( "check" ), LFUNCVAL( file_check ) },
|
||||||
// { LSTRKEY( "check" ), LFUNCVAL( file_check ) },
|
{ LSTRKEY( "rename" ), LFUNCVAL( file_rename ) },
|
||||||
{ LSTRKEY( "rename" ), LFUNCVAL( file_rename ) },
|
{ LSTRKEY( "fsinfo" ), LFUNCVAL( file_fsinfo ) },
|
||||||
{ LSTRKEY( "fsinfo" ), LFUNCVAL( file_fsinfo ) },
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if LUA_OPTIMIZE_MEMORY > 0
|
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
{ LNILKEY, LNILVAL }
|
{ LNILKEY, LNILVAL }
|
||||||
};
|
};
|
||||||
|
|
||||||
LUALIB_API int luaopen_file( lua_State *L )
|
NODEMCU_MODULE(FILE, "file", file_map, NULL);
|
||||||
{
|
|
||||||
#if LUA_OPTIMIZE_MEMORY > 0
|
|
||||||
return 0;
|
|
||||||
#else // #if LUA_OPTIMIZE_MEMORY > 0
|
|
||||||
luaL_register( L, AUXLIB_FILE, file_map );
|
|
||||||
// Add constants
|
|
||||||
|
|
||||||
return 1;
|
|
||||||
#endif // #if LUA_OPTIMIZE_MEMORY > 0
|
|
||||||
}
|
|
||||||
|
@ -1,11 +1,8 @@
|
|||||||
// Module for interfacing with GPIO
|
// Module for interfacing with GPIO
|
||||||
|
|
||||||
//#include "lua.h"
|
#include "module.h"
|
||||||
#include "lualib.h"
|
|
||||||
#include "lauxlib.h"
|
#include "lauxlib.h"
|
||||||
#include "platform.h"
|
#include "platform.h"
|
||||||
#include "auxmods.h"
|
|
||||||
#include "lrotable.h"
|
|
||||||
|
|
||||||
#include "c_types.h"
|
#include "c_types.h"
|
||||||
#include "c_string.h"
|
#include "c_string.h"
|
||||||
@ -223,33 +220,25 @@ static int lgpio_serout( lua_State* L )
|
|||||||
#undef DELAY_TABLE_MAX_LEN
|
#undef DELAY_TABLE_MAX_LEN
|
||||||
|
|
||||||
// Module function map
|
// Module function map
|
||||||
#define MIN_OPT_LEVEL 2
|
static const LUA_REG_TYPE gpio_map[] = {
|
||||||
#include "lrodefs.h"
|
{ LSTRKEY( "mode" ), LFUNCVAL( lgpio_mode ) },
|
||||||
const LUA_REG_TYPE gpio_map[] =
|
{ LSTRKEY( "read" ), LFUNCVAL( lgpio_read ) },
|
||||||
{
|
{ LSTRKEY( "write" ), LFUNCVAL( lgpio_write ) },
|
||||||
{ LSTRKEY( "mode" ), LFUNCVAL( lgpio_mode ) },
|
|
||||||
{ LSTRKEY( "read" ), LFUNCVAL( lgpio_read ) },
|
|
||||||
{ LSTRKEY( "write" ), LFUNCVAL( lgpio_write ) },
|
|
||||||
{ LSTRKEY( "serout" ), LFUNCVAL( lgpio_serout ) },
|
{ LSTRKEY( "serout" ), LFUNCVAL( lgpio_serout ) },
|
||||||
#ifdef GPIO_INTERRUPT_ENABLE
|
#ifdef GPIO_INTERRUPT_ENABLE
|
||||||
{ LSTRKEY( "trig" ), LFUNCVAL( lgpio_trig ) },
|
{ LSTRKEY( "trig" ), LFUNCVAL( lgpio_trig ) },
|
||||||
#endif
|
{ LSTRKEY( "INT" ), LNUMVAL( INTERRUPT ) },
|
||||||
#if LUA_OPTIMIZE_MEMORY > 0
|
|
||||||
#ifdef GPIO_INTERRUPT_ENABLE
|
|
||||||
{ LSTRKEY( "INT" ), LNUMVAL( INTERRUPT ) },
|
|
||||||
#endif
|
#endif
|
||||||
{ LSTRKEY( "OUTPUT" ), LNUMVAL( OUTPUT ) },
|
{ LSTRKEY( "OUTPUT" ), LNUMVAL( OUTPUT ) },
|
||||||
{ LSTRKEY( "INPUT" ), LNUMVAL( INPUT ) },
|
{ LSTRKEY( "INPUT" ), LNUMVAL( INPUT ) },
|
||||||
{ LSTRKEY( "HIGH" ), LNUMVAL( HIGH ) },
|
{ LSTRKEY( "HIGH" ), LNUMVAL( HIGH ) },
|
||||||
{ LSTRKEY( "LOW" ), LNUMVAL( LOW ) },
|
{ LSTRKEY( "LOW" ), LNUMVAL( LOW ) },
|
||||||
{ LSTRKEY( "FLOAT" ), LNUMVAL( FLOAT ) },
|
{ LSTRKEY( "FLOAT" ), LNUMVAL( FLOAT ) },
|
||||||
{ LSTRKEY( "PULLUP" ), LNUMVAL( PULLUP ) },
|
{ LSTRKEY( "PULLUP" ), LNUMVAL( PULLUP ) },
|
||||||
#endif
|
|
||||||
{ LNILKEY, LNILVAL }
|
{ LNILKEY, LNILVAL }
|
||||||
};
|
};
|
||||||
|
|
||||||
LUALIB_API int luaopen_gpio( lua_State *L )
|
int luaopen_gpio( lua_State *L ) {
|
||||||
{
|
|
||||||
#ifdef GPIO_INTERRUPT_ENABLE
|
#ifdef GPIO_INTERRUPT_ENABLE
|
||||||
int i;
|
int i;
|
||||||
for(i=0;i<GPIO_PIN_NUM;i++){
|
for(i=0;i<GPIO_PIN_NUM;i++){
|
||||||
@ -257,21 +246,7 @@ LUALIB_API int luaopen_gpio( lua_State *L )
|
|||||||
}
|
}
|
||||||
platform_gpio_init(gpio_intr_callback);
|
platform_gpio_init(gpio_intr_callback);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if LUA_OPTIMIZE_MEMORY > 0
|
|
||||||
return 0;
|
return 0;
|
||||||
#else // #if LUA_OPTIMIZE_MEMORY > 0
|
|
||||||
luaL_register( L, AUXLIB_GPIO, gpio_map );
|
|
||||||
// Add constants
|
|
||||||
#ifdef GPIO_INTERRUPT_ENABLE
|
|
||||||
MOD_REG_NUMBER( L, "INT", INTERRUPT );
|
|
||||||
#endif
|
|
||||||
MOD_REG_NUMBER( L, "OUTPUT", OUTPUT );
|
|
||||||
MOD_REG_NUMBER( L, "INPUT", INPUT );
|
|
||||||
MOD_REG_NUMBER( L, "HIGH", HIGH );
|
|
||||||
MOD_REG_NUMBER( L, "LOW", LOW );
|
|
||||||
MOD_REG_NUMBER( L, "FLOAT", FLOAT );
|
|
||||||
MOD_REG_NUMBER( L, "PULLUP", PULLUP );
|
|
||||||
return 1;
|
|
||||||
#endif // #if LUA_OPTIMIZE_MEMORY > 0
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
NODEMCU_MODULE(GPIO, "gpio", gpio_map, luaopen_gpio);
|
||||||
|
@ -1,11 +1,9 @@
|
|||||||
// Module for HX711 load cell amplifier
|
// Module for HX711 load cell amplifier
|
||||||
// https://learn.sparkfun.com/tutorials/load-cell-amplifier-hx711-breakout-hookup-guide
|
// https://learn.sparkfun.com/tutorials/load-cell-amplifier-hx711-breakout-hookup-guide
|
||||||
|
|
||||||
#include "lualib.h"
|
#include "module.h"
|
||||||
#include "lauxlib.h"
|
#include "lauxlib.h"
|
||||||
#include "platform.h"
|
#include "platform.h"
|
||||||
#include "auxmods.h"
|
|
||||||
#include "lrotable.h"
|
|
||||||
#include "c_stdlib.h"
|
#include "c_stdlib.h"
|
||||||
#include "c_string.h"
|
#include "c_string.h"
|
||||||
#include "user_interface.h"
|
#include "user_interface.h"
|
||||||
@ -67,18 +65,16 @@ static int ICACHE_FLASH_ATTR hx711_read(lua_State* L) {
|
|||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
#define MIN_OPT_LEVEL 2
|
// Module function map
|
||||||
#include "lrodefs.h"
|
static const LUA_REG_TYPE hx711_map[] = {
|
||||||
const LUA_REG_TYPE hx711_map[] =
|
|
||||||
{
|
|
||||||
{ LSTRKEY( "init" ), LFUNCVAL( hx711_init )},
|
{ LSTRKEY( "init" ), LFUNCVAL( hx711_init )},
|
||||||
{ LSTRKEY( "read" ), LFUNCVAL( hx711_read )},
|
{ LSTRKEY( "read" ), LFUNCVAL( hx711_read )},
|
||||||
{ LNILKEY, LNILVAL}
|
{ LNILKEY, LNILVAL}
|
||||||
};
|
};
|
||||||
|
|
||||||
LUALIB_API int luaopen_hx711(lua_State *L) {
|
int luaopen_hx711(lua_State *L) {
|
||||||
// TODO: the below todo was inherited from the ws2812 code but is still valid.
|
|
||||||
// TODO: Make sure that the GPIO system is initialized
|
// TODO: Make sure that the GPIO system is initialized
|
||||||
LREGISTER(L, "hx711", hx711_map);
|
return 0;
|
||||||
return 1;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
NODEMCU_MODULE(HX711, "hx711", hx711_map, luaopen_hx711);
|
||||||
|
@ -1,11 +1,8 @@
|
|||||||
// Module for interfacing with the I2C interface
|
// Module for interfacing with the I2C interface
|
||||||
|
|
||||||
//#include "lua.h"
|
#include "module.h"
|
||||||
#include "lualib.h"
|
|
||||||
#include "lauxlib.h"
|
#include "lauxlib.h"
|
||||||
#include "platform.h"
|
#include "platform.h"
|
||||||
#include "auxmods.h"
|
|
||||||
#include "lrotable.h"
|
|
||||||
|
|
||||||
// Lua: speed = i2c.setup( id, sda, scl, speed )
|
// Lua: speed = i2c.setup( id, sda, scl, speed )
|
||||||
static int i2c_setup( lua_State *L )
|
static int i2c_setup( lua_State *L )
|
||||||
@ -143,39 +140,18 @@ static int i2c_read( lua_State *L )
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Module function map
|
// Module function map
|
||||||
#define MIN_OPT_LEVEL 2
|
static const LUA_REG_TYPE i2c_map[] = {
|
||||||
#include "lrodefs.h"
|
{ LSTRKEY( "setup" ), LFUNCVAL( i2c_setup ) },
|
||||||
const LUA_REG_TYPE i2c_map[] =
|
{ LSTRKEY( "start" ), LFUNCVAL( i2c_start ) },
|
||||||
{
|
{ LSTRKEY( "stop" ), LFUNCVAL( i2c_stop ) },
|
||||||
{ LSTRKEY( "setup" ), LFUNCVAL( i2c_setup ) },
|
{ LSTRKEY( "address" ), LFUNCVAL( i2c_address ) },
|
||||||
{ LSTRKEY( "start" ), LFUNCVAL( i2c_start ) },
|
{ LSTRKEY( "write" ), LFUNCVAL( i2c_write ) },
|
||||||
{ LSTRKEY( "stop" ), LFUNCVAL( i2c_stop ) },
|
{ LSTRKEY( "read" ), LFUNCVAL( i2c_read ) },
|
||||||
{ LSTRKEY( "address" ), LFUNCVAL( i2c_address ) },
|
//{ LSTRKEY( "FAST" ), LNUMVAL( PLATFORM_I2C_SPEED_FAST ) },
|
||||||
{ LSTRKEY( "write" ), LFUNCVAL( i2c_write ) },
|
{ LSTRKEY( "SLOW" ), LNUMVAL( PLATFORM_I2C_SPEED_SLOW ) },
|
||||||
{ LSTRKEY( "read" ), LFUNCVAL( i2c_read ) },
|
|
||||||
#if LUA_OPTIMIZE_MEMORY > 0
|
|
||||||
// { LSTRKEY( "FAST" ), LNUMVAL( PLATFORM_I2C_SPEED_FAST ) },
|
|
||||||
{ LSTRKEY( "SLOW" ), LNUMVAL( PLATFORM_I2C_SPEED_SLOW ) },
|
|
||||||
{ LSTRKEY( "TRANSMITTER" ), LNUMVAL( PLATFORM_I2C_DIRECTION_TRANSMITTER ) },
|
{ LSTRKEY( "TRANSMITTER" ), LNUMVAL( PLATFORM_I2C_DIRECTION_TRANSMITTER ) },
|
||||||
{ LSTRKEY( "RECEIVER" ), LNUMVAL( PLATFORM_I2C_DIRECTION_RECEIVER ) },
|
{ LSTRKEY( "RECEIVER" ), LNUMVAL( PLATFORM_I2C_DIRECTION_RECEIVER ) },
|
||||||
#endif
|
|
||||||
{ LNILKEY, LNILVAL }
|
{ LNILKEY, LNILVAL }
|
||||||
};
|
};
|
||||||
|
|
||||||
LUALIB_API int luaopen_i2c( lua_State *L )
|
NODEMCU_MODULE(I2C, "i2c", i2c_map, NULL);
|
||||||
{
|
|
||||||
#if LUA_OPTIMIZE_MEMORY > 0
|
|
||||||
return 0;
|
|
||||||
#else // #if LUA_OPTIMIZE_MEMORY > 0
|
|
||||||
luaL_register( L, AUXLIB_I2C, i2c_map );
|
|
||||||
|
|
||||||
// Add the stop bits and parity constants (for i2c.setup)
|
|
||||||
// MOD_REG_NUMBER( L, "FAST", PLATFORM_I2C_SPEED_FAST );
|
|
||||||
MOD_REG_NUMBER( L, "SLOW", PLATFORM_I2C_SPEED_SLOW );
|
|
||||||
MOD_REG_NUMBER( L, "TRANSMITTER", PLATFORM_I2C_DIRECTION_TRANSMITTER );
|
|
||||||
MOD_REG_NUMBER( L, "RECEIVER", PLATFORM_I2C_DIRECTION_RECEIVER );
|
|
||||||
|
|
||||||
return 1;
|
|
||||||
#endif // #if LUA_OPTIMIZE_MEMORY > 0
|
|
||||||
}
|
|
||||||
|
|
||||||
|
@ -13,124 +13,61 @@
|
|||||||
|
|
||||||
#include "lualib.h"
|
#include "lualib.h"
|
||||||
#include "lauxlib.h"
|
#include "lauxlib.h"
|
||||||
#include "lrotable.h"
|
|
||||||
#include "luaconf.h"
|
#include "luaconf.h"
|
||||||
|
#include "module.h"
|
||||||
|
|
||||||
#include "user_modules.h"
|
|
||||||
|
|
||||||
#if defined(LUA_USE_MODULES)
|
BUILTIN_LIB_INIT( BASE, "", luaopen_base);
|
||||||
#include "modules.h"
|
BUILTIN_LIB_INIT( LOADLIB, LUA_LOADLIBNAME, luaopen_package);
|
||||||
#endif
|
|
||||||
|
|
||||||
#if defined(LUA_MODULES_ROM)
|
|
||||||
#undef _ROM
|
|
||||||
#define _ROM( name, openf, table ) extern int openf(lua_State *);
|
|
||||||
LUA_MODULES_ROM
|
|
||||||
#endif
|
|
||||||
|
|
||||||
static const luaL_Reg lualibs[] = {
|
|
||||||
{"", luaopen_base},
|
|
||||||
{LUA_LOADLIBNAME, luaopen_package},
|
|
||||||
#if defined(LUA_USE_BUILTIN_IO)
|
#if defined(LUA_USE_BUILTIN_IO)
|
||||||
{LUA_IOLIBNAME, luaopen_io},
|
BUILTIN_LIB_INIT( IO, LUA_IOLIBNAME, luaopen_io);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if defined(LUA_USE_BUILTIN_STRING)
|
#if defined (LUA_USE_BUILTIN_STRING)
|
||||||
{LUA_STRLIBNAME, luaopen_string},
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if LUA_OPTIMIZE_MEMORY == 0
|
|
||||||
#if defined(LUA_USE_BUILTIN_MATH)
|
|
||||||
{LUA_MATHLIBNAME, luaopen_math},
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if defined(LUA_USE_BUILTIN_TABLE)
|
|
||||||
{LUA_TABLIBNAME, luaopen_table},
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if defined(LUA_USE_BUILTIN_DEBUG) || defined(LUA_USE_BUILTIN_DEBUG_MINIMAL)
|
|
||||||
{LUA_DBLIBNAME, luaopen_debug},
|
|
||||||
#endif
|
|
||||||
#endif
|
|
||||||
#if defined(LUA_MODULES_ROM)
|
|
||||||
#undef _ROM
|
|
||||||
#define _ROM( name, openf, table ) { name, openf },
|
|
||||||
LUA_MODULES_ROM
|
|
||||||
#endif
|
|
||||||
{NULL, NULL}
|
|
||||||
};
|
|
||||||
|
|
||||||
#if defined(LUA_USE_BUILTIN_STRING)
|
|
||||||
extern const luaR_entry strlib[];
|
extern const luaR_entry strlib[];
|
||||||
#endif
|
BUILTIN_LIB_INIT( STRING, LUA_STRLIBNAME, luaopen_string);
|
||||||
|
BUILTIN_LIB( STRING, LUA_STRLIBNAME, strlib);
|
||||||
#if defined(LUA_USE_BUILTIN_OS)
|
|
||||||
extern const luaR_entry syslib[];
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if defined(LUA_USE_BUILTIN_TABLE)
|
#if defined(LUA_USE_BUILTIN_TABLE)
|
||||||
extern const luaR_entry tab_funcs[];
|
extern const luaR_entry tab_funcs[];
|
||||||
|
BUILTIN_LIB_INIT( TABLE, LUA_TABLIBNAME, luaopen_table);
|
||||||
|
BUILTIN_LIB( TABLE, LUA_TABLIBNAME, tab_funcs);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if defined(LUA_USE_BUILTIN_DEBUG) || defined(LUA_USE_BUILTIN_DEBUG_MINIMAL)
|
#if defined(LUA_USE_BUILTIN_DEBUG) || defined(LUA_USE_BUILTIN_DEBUG_MINIMAL)
|
||||||
extern const luaR_entry dblib[];
|
extern const luaR_entry dblib[];
|
||||||
|
BUILTIN_LIB_INIT( DBG, LUA_DBLIBNAME, luaopen_debug);
|
||||||
|
BUILTIN_LIB( DBG, LUA_DBLIBNAME, dblib);
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if defined(LUA_USE_BUILTIN_OS)
|
||||||
|
extern const luaR_entry syslib[];
|
||||||
|
BUILTIN_LIB( OS, LUA_OSLIBNAME, syslib);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if defined(LUA_USE_BUILTIN_COROUTINE)
|
#if defined(LUA_USE_BUILTIN_COROUTINE)
|
||||||
extern const luaR_entry co_funcs[];
|
extern const luaR_entry co_funcs[];
|
||||||
|
BUILTIN_LIB( CO, LUA_COLIBNAME, co_funcs);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if defined(LUA_USE_BUILTIN_MATH)
|
#if defined(LUA_USE_BUILTIN_MATH)
|
||||||
extern const luaR_entry math_map[];
|
extern const luaR_entry math_map[];
|
||||||
|
BUILTIN_LIB( MATH, LUA_MATHLIBNAME, math_map);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if defined(LUA_MODULES_ROM) && LUA_OPTIMIZE_MEMORY == 2
|
extern const luaL_Reg lua_libs[];
|
||||||
#undef _ROM
|
|
||||||
#define _ROM( name, openf, table ) extern const luaR_entry table[];
|
|
||||||
LUA_MODULES_ROM
|
|
||||||
#endif
|
|
||||||
const luaR_table lua_rotable[] =
|
|
||||||
{
|
|
||||||
#if LUA_OPTIMIZE_MEMORY > 0
|
|
||||||
#if defined(LUA_USE_BUILTIN_STRING)
|
|
||||||
{LUA_STRLIBNAME, strlib},
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if defined(LUA_USE_BUILTIN_TABLE)
|
void luaL_openlibs (lua_State *L) {
|
||||||
{LUA_TABLIBNAME, tab_funcs},
|
const luaL_Reg *lib = lua_libs;
|
||||||
#endif
|
for (; lib->name; lib++) {
|
||||||
|
if (lib->func)
|
||||||
#if defined(LUA_USE_BUILTIN_DEBUG) || defined(LUA_USE_BUILTIN_DEBUG_MINIMAL)
|
{
|
||||||
{LUA_DBLIBNAME, dblib},
|
lua_pushcfunction(L, lib->func);
|
||||||
#endif
|
lua_pushstring(L, lib->name);
|
||||||
|
lua_call(L, 1, 0);
|
||||||
#if defined(LUA_USE_BUILTIN_COROUTINE)
|
}
|
||||||
{LUA_COLIBNAME, co_funcs},
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if defined(LUA_USE_BUILTIN_MATH)
|
|
||||||
{LUA_MATHLIBNAME, math_map},
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if defined(LUA_USE_BUILTIN_OS)
|
|
||||||
{LUA_OSLIBNAME, syslib},
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if defined(LUA_MODULES_ROM) && LUA_OPTIMIZE_MEMORY == 2
|
|
||||||
#undef _ROM
|
|
||||||
#define _ROM( name, openf, table ) { name, table },
|
|
||||||
LUA_MODULES_ROM
|
|
||||||
#endif
|
|
||||||
#endif
|
|
||||||
{NULL, NULL}
|
|
||||||
};
|
|
||||||
|
|
||||||
LUALIB_API void luaL_openlibs (lua_State *L) {
|
|
||||||
const luaL_Reg *lib = lualibs;
|
|
||||||
for (; lib->func; lib++) {
|
|
||||||
lua_pushcfunction(L, lib->func);
|
|
||||||
lua_pushstring(L, lib->name);
|
|
||||||
lua_call(L, 1, 0);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1,289 +0,0 @@
|
|||||||
/**
|
|
||||||
* External modules library
|
|
||||||
*/
|
|
||||||
|
|
||||||
#ifndef __MODULES_H__
|
|
||||||
#define __MODULES_H__
|
|
||||||
|
|
||||||
#if defined(LUA_USE_MODULES_GPIO)
|
|
||||||
#define MODULES_GPIO "gpio"
|
|
||||||
#define ROM_MODULES_GPIO \
|
|
||||||
_ROM(MODULES_GPIO, luaopen_gpio, gpio_map)
|
|
||||||
#else
|
|
||||||
#define ROM_MODULES_GPIO
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if defined(LUA_USE_MODULES_PWM)
|
|
||||||
#define MODULES_PWM "pwm"
|
|
||||||
#define ROM_MODULES_PWM \
|
|
||||||
_ROM(MODULES_PWM, luaopen_pwm, pwm_map)
|
|
||||||
#else
|
|
||||||
#define ROM_MODULES_PWM
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if defined(LUA_USE_MODULES_WIFI)
|
|
||||||
#define MODULES_WIFI "wifi"
|
|
||||||
#define ROM_MODULES_WIFI \
|
|
||||||
_ROM(MODULES_WIFI, luaopen_wifi, wifi_map)
|
|
||||||
#else
|
|
||||||
#define ROM_MODULES_WIFI
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if defined(LUA_USE_MODULES_NET)
|
|
||||||
#define MODULES_NET "net"
|
|
||||||
#define ROM_MODULES_NET \
|
|
||||||
_ROM(MODULES_NET, luaopen_net, net_map)
|
|
||||||
#else
|
|
||||||
#define ROM_MODULES_NET
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if defined(LUA_USE_MODULES_COAP)
|
|
||||||
#define MODULES_COAP "coap"
|
|
||||||
#define ROM_MODULES_COAP \
|
|
||||||
_ROM(MODULES_COAP, luaopen_coap, coap_map)
|
|
||||||
#else
|
|
||||||
#define ROM_MODULES_COAP
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if defined(LUA_USE_MODULES_MQTT)
|
|
||||||
#define MODULES_MQTT "mqtt"
|
|
||||||
#define ROM_MODULES_MQTT \
|
|
||||||
_ROM(MODULES_MQTT, luaopen_mqtt, mqtt_map)
|
|
||||||
#else
|
|
||||||
#define ROM_MODULES_MQTT
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if defined(LUA_USE_MODULES_U8G)
|
|
||||||
#define MODULES_U8G "u8g"
|
|
||||||
#define ROM_MODULES_U8G \
|
|
||||||
_ROM(MODULES_U8G, luaopen_u8g, lu8g_map)
|
|
||||||
#else
|
|
||||||
#define ROM_MODULES_U8G
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if defined(LUA_USE_MODULES_UCG)
|
|
||||||
#define MODULES_UCG "ucg"
|
|
||||||
#define ROM_MODULES_UCG \
|
|
||||||
_ROM(MODULES_UCG, luaopen_ucg, lucg_map)
|
|
||||||
#else
|
|
||||||
#define ROM_MODULES_UCG
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if defined(LUA_USE_MODULES_I2C)
|
|
||||||
#define MODULES_I2C "i2c"
|
|
||||||
#define ROM_MODULES_I2C \
|
|
||||||
_ROM(MODULES_I2C, luaopen_i2c, i2c_map)
|
|
||||||
#else
|
|
||||||
#define ROM_MODULES_I2C
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if defined(LUA_USE_MODULES_SPI)
|
|
||||||
#define MODULES_SPI "spi"
|
|
||||||
#define ROM_MODULES_SPI \
|
|
||||||
_ROM(MODULES_SPI, luaopen_spi, spi_map)
|
|
||||||
#else
|
|
||||||
#define ROM_MODULES_SPI
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if defined(LUA_USE_MODULES_TMR)
|
|
||||||
#define MODULES_TMR "tmr"
|
|
||||||
#define ROM_MODULES_TMR \
|
|
||||||
_ROM(MODULES_TMR, luaopen_tmr, tmr_map)
|
|
||||||
#else
|
|
||||||
#define ROM_MODULES_TMR
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if defined(LUA_USE_MODULES_NODE)
|
|
||||||
#define MODULES_NODE "node"
|
|
||||||
#define ROM_MODULES_NODE \
|
|
||||||
_ROM(MODULES_NODE, luaopen_node, node_map)
|
|
||||||
#else
|
|
||||||
#define ROM_MODULES_NODE
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if defined(LUA_USE_MODULES_FILE)
|
|
||||||
#define MODULES_FILE "file"
|
|
||||||
#define ROM_MODULES_FILE \
|
|
||||||
_ROM(MODULES_FILE, luaopen_file, file_map)
|
|
||||||
#else
|
|
||||||
#define ROM_MODULES_FILE
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if defined(LUA_USE_MODULES_ADC)
|
|
||||||
#define MODULES_ADC "adc"
|
|
||||||
#define ROM_MODULES_ADC \
|
|
||||||
_ROM(MODULES_ADC, luaopen_adc, adc_map)
|
|
||||||
#else
|
|
||||||
#define ROM_MODULES_ADC
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if defined(LUA_USE_MODULES_UART)
|
|
||||||
#define MODULES_UART "uart"
|
|
||||||
#define ROM_MODULES_UART \
|
|
||||||
_ROM(MODULES_UART, luaopen_uart, uart_map)
|
|
||||||
#else
|
|
||||||
#define ROM_MODULES_UART
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if defined(LUA_USE_MODULES_OW)
|
|
||||||
#define MODULES_OW "ow"
|
|
||||||
#define ROM_MODULES_OW \
|
|
||||||
_ROM(MODULES_OW, luaopen_ow, ow_map)
|
|
||||||
#else
|
|
||||||
#define ROM_MODULES_OW
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if defined(LUA_USE_MODULES_BIT)
|
|
||||||
#define MODULES_BIT "bit"
|
|
||||||
#define ROM_MODULES_BIT \
|
|
||||||
_ROM(MODULES_BIT, luaopen_bit, bit_map)
|
|
||||||
#else
|
|
||||||
#define ROM_MODULES_BIT
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if defined(LUA_USE_MODULES_WS2801)
|
|
||||||
#define MODULES_WS2801 "ws2801"
|
|
||||||
#define ROM_MODULES_WS2801 \
|
|
||||||
_ROM(MODULES_WS2801, luaopen_ws2801, ws2801_map)
|
|
||||||
#else
|
|
||||||
#define ROM_MODULES_WS2801
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if defined(LUA_USE_MODULES_WS2812)
|
|
||||||
#define MODULES_WS2812 "ws2812"
|
|
||||||
#define ROM_MODULES_WS2812 \
|
|
||||||
_ROM(MODULES_WS2812, luaopen_ws2812, ws2812_map)
|
|
||||||
#else
|
|
||||||
#define ROM_MODULES_WS2812
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if defined(LUA_USE_MODULES_ENDUSER_SETUP)
|
|
||||||
#define MODULES_ENDUSER_SETUP "enduser_setup"
|
|
||||||
#define ROM_MODULES_ENDUSER_SETUP \
|
|
||||||
_ROM(MODULES_ENDUSER_SETUP, luaopen_enduser_setup, enduser_setup_map)
|
|
||||||
#else
|
|
||||||
#define ROM_MODULES_ENDUSER_SETUP
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if defined(LUA_USE_MODULES_CJSON)
|
|
||||||
#define MODULES_CJSON "cjson"
|
|
||||||
#define ROM_MODULES_CJSON \
|
|
||||||
_ROM(MODULES_CJSON, luaopen_cjson, cjson_map)
|
|
||||||
#else
|
|
||||||
#define ROM_MODULES_CJSON
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if defined(LUA_USE_MODULES_CRYPTO)
|
|
||||||
#define MODULES_CRYPTO "crypto"
|
|
||||||
#define ROM_MODULES_CRYPTO \
|
|
||||||
_ROM(MODULES_CRYPTO, luaopen_crypto, crypto_map)
|
|
||||||
#else
|
|
||||||
#define ROM_MODULES_CRYPTO
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if defined(LUA_USE_MODULES_RC)
|
|
||||||
#define MODULES_RC "rc"
|
|
||||||
#define ROM_MODULES_RC \
|
|
||||||
_ROM(MODULES_RC, luaopen_rc, rc_map)
|
|
||||||
#else
|
|
||||||
#define ROM_MODULES_RC
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if defined(LUA_USE_MODULES_DHT)
|
|
||||||
#define MODULES_DHT "dht"
|
|
||||||
#define ROM_MODULES_DHT \
|
|
||||||
_ROM(MODULES_DHT, luaopen_dht, dht_map)
|
|
||||||
#else
|
|
||||||
#define ROM_MODULES_DHT
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if defined(LUA_USE_MODULES_RTCMEM)
|
|
||||||
#define MODULES_RTCMEM "rtcmem"
|
|
||||||
#define ROM_MODULES_RTCMEM \
|
|
||||||
_ROM(MODULES_RTCMEM, luaopen_rtcmem, rtcmem_map)
|
|
||||||
#else
|
|
||||||
#define ROM_MODULES_RTCMEM
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if defined(LUA_USE_MODULES_RTCTIME)
|
|
||||||
#define MODULES_RTCTIME "rtctime"
|
|
||||||
#define ROM_MODULES_RTCTIME \
|
|
||||||
_ROM(MODULES_RTCTIME, luaopen_rtctime, rtctime_map)
|
|
||||||
#else
|
|
||||||
#define ROM_MODULES_RTCTIME
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if defined(LUA_USE_MODULES_RTCFIFO)
|
|
||||||
#define MODULES_RTCFIFO "rtcfifo"
|
|
||||||
#define ROM_MODULES_RTCFIFO \
|
|
||||||
_ROM(MODULES_RTCFIFO, luaopen_rtcfifo, rtcfifo_map)
|
|
||||||
#else
|
|
||||||
#define ROM_MODULES_RTCFIFO
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if defined(LUA_USE_MODULES_SNTP)
|
|
||||||
#define MODULES_SNTP "sntp"
|
|
||||||
#define ROM_MODULES_SNTP \
|
|
||||||
_ROM(MODULES_SNTP, luaopen_sntp, sntp_map)
|
|
||||||
#else
|
|
||||||
#define ROM_MODULES_SNTP
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if defined(LUA_USE_MODULES_BMP085)
|
|
||||||
#define MODULES_BMP085 "bmp085"
|
|
||||||
#define ROM_MODULES_BMP085 \
|
|
||||||
_ROM(MODULES_BMP085, luaopen_bmp085, bmp085_map)
|
|
||||||
#else
|
|
||||||
#define ROM_MODULES_BMP085
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if defined(LUA_USE_MODULES_TSL2561)
|
|
||||||
#define MODULES_TSL2561 "tsl2561"
|
|
||||||
#define ROM_MODULES_TSL2561 \
|
|
||||||
_ROM(MODULES_TSL2561, luaopen_tsl2561, tsl2561_map)
|
|
||||||
#else
|
|
||||||
#define ROM_MODULES_TSL2561
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if defined(LUA_USE_MODULES_HX711)
|
|
||||||
#define MODULES_HX711 "hx711"
|
|
||||||
#define ROM_MODULES_HX711 \
|
|
||||||
_ROM(MODULES_HX711, luaopen_hx711, hx711_map)
|
|
||||||
#else
|
|
||||||
#define ROM_MODULES_HX711
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#define LUA_MODULES_ROM \
|
|
||||||
ROM_MODULES_GPIO \
|
|
||||||
ROM_MODULES_PWM \
|
|
||||||
ROM_MODULES_WIFI \
|
|
||||||
ROM_MODULES_COAP \
|
|
||||||
ROM_MODULES_MQTT \
|
|
||||||
ROM_MODULES_U8G \
|
|
||||||
ROM_MODULES_UCG \
|
|
||||||
ROM_MODULES_I2C \
|
|
||||||
ROM_MODULES_SPI \
|
|
||||||
ROM_MODULES_TMR \
|
|
||||||
ROM_MODULES_NODE \
|
|
||||||
ROM_MODULES_FILE \
|
|
||||||
ROM_MODULES_NET \
|
|
||||||
ROM_MODULES_ADC \
|
|
||||||
ROM_MODULES_UART \
|
|
||||||
ROM_MODULES_OW \
|
|
||||||
ROM_MODULES_BIT \
|
|
||||||
ROM_MODULES_ENDUSER_SETUP \
|
|
||||||
ROM_MODULES_WS2801 \
|
|
||||||
ROM_MODULES_WS2812 \
|
|
||||||
ROM_MODULES_CJSON \
|
|
||||||
ROM_MODULES_CRYPTO \
|
|
||||||
ROM_MODULES_RC \
|
|
||||||
ROM_MODULES_DHT \
|
|
||||||
ROM_MODULES_RTCMEM \
|
|
||||||
ROM_MODULES_RTCTIME \
|
|
||||||
ROM_MODULES_RTCFIFO \
|
|
||||||
ROM_MODULES_SNTP \
|
|
||||||
ROM_MODULES_BMP085 \
|
|
||||||
ROM_MODULES_TSL2561 \
|
|
||||||
ROM_MODULES_HX711
|
|
||||||
|
|
||||||
#endif
|
|
@ -1,11 +1,8 @@
|
|||||||
// Module for mqtt
|
// Module for mqtt
|
||||||
|
|
||||||
//#include "lua.h"
|
#include "module.h"
|
||||||
#include "lualib.h"
|
|
||||||
#include "lauxlib.h"
|
#include "lauxlib.h"
|
||||||
#include "platform.h"
|
#include "platform.h"
|
||||||
#include "auxmods.h"
|
|
||||||
#include "lrotable.h"
|
|
||||||
|
|
||||||
#include "c_string.h"
|
#include "c_string.h"
|
||||||
#include "c_stdlib.h"
|
#include "c_stdlib.h"
|
||||||
@ -1392,59 +1389,28 @@ static int mqtt_socket_lwt( lua_State* L )
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Module function map
|
// Module function map
|
||||||
#define MIN_OPT_LEVEL 2
|
static const LUA_REG_TYPE mqtt_socket_map[] = {
|
||||||
#include "lrodefs.h"
|
{ LSTRKEY( "connect" ), LFUNCVAL( mqtt_socket_connect ) },
|
||||||
|
{ LSTRKEY( "close" ), LFUNCVAL( mqtt_socket_close ) },
|
||||||
static const LUA_REG_TYPE mqtt_socket_map[] =
|
{ LSTRKEY( "publish" ), LFUNCVAL( mqtt_socket_publish ) },
|
||||||
{
|
{ LSTRKEY( "subscribe" ), LFUNCVAL( mqtt_socket_subscribe ) },
|
||||||
{ LSTRKEY( "connect" ), LFUNCVAL ( mqtt_socket_connect ) },
|
{ LSTRKEY( "lwt" ), LFUNCVAL( mqtt_socket_lwt ) },
|
||||||
{ LSTRKEY( "close" ), LFUNCVAL ( mqtt_socket_close ) },
|
{ LSTRKEY( "on" ), LFUNCVAL( mqtt_socket_on ) },
|
||||||
{ LSTRKEY( "publish" ), LFUNCVAL ( mqtt_socket_publish ) },
|
{ LSTRKEY( "__gc" ), LFUNCVAL( mqtt_delete ) },
|
||||||
{ LSTRKEY( "subscribe" ), LFUNCVAL ( mqtt_socket_subscribe ) },
|
{ LSTRKEY( "__index" ), LROVAL( mqtt_socket_map ) },
|
||||||
{ LSTRKEY( "lwt" ), LFUNCVAL ( mqtt_socket_lwt ) },
|
|
||||||
{ LSTRKEY( "on" ), LFUNCVAL ( mqtt_socket_on ) },
|
|
||||||
{ LSTRKEY( "__gc" ), LFUNCVAL ( mqtt_delete ) },
|
|
||||||
#if LUA_OPTIMIZE_MEMORY > 0
|
|
||||||
{ LSTRKEY( "__index" ), LROVAL ( mqtt_socket_map ) },
|
|
||||||
#endif
|
|
||||||
{ LNILKEY, LNILVAL }
|
{ LNILKEY, LNILVAL }
|
||||||
};
|
};
|
||||||
|
|
||||||
const LUA_REG_TYPE mqtt_map[] =
|
static const LUA_REG_TYPE mqtt_map[] = {
|
||||||
{
|
{ LSTRKEY( "Client" ), LFUNCVAL( mqtt_socket_client ) },
|
||||||
{ LSTRKEY( "Client" ), LFUNCVAL ( mqtt_socket_client ) },
|
|
||||||
#if LUA_OPTIMIZE_MEMORY > 0
|
|
||||||
|
|
||||||
{ LSTRKEY( "__metatable" ), LROVAL( mqtt_map ) },
|
{ LSTRKEY( "__metatable" ), LROVAL( mqtt_map ) },
|
||||||
#endif
|
|
||||||
{ LNILKEY, LNILVAL }
|
{ LNILKEY, LNILVAL }
|
||||||
};
|
};
|
||||||
|
|
||||||
LUALIB_API int luaopen_mqtt( lua_State *L )
|
int luaopen_mqtt( lua_State *L )
|
||||||
{
|
{
|
||||||
#if LUA_OPTIMIZE_MEMORY > 0
|
|
||||||
luaL_rometatable(L, "mqtt.socket", (void *)mqtt_socket_map); // create metatable for mqtt.socket
|
luaL_rometatable(L, "mqtt.socket", (void *)mqtt_socket_map); // create metatable for mqtt.socket
|
||||||
return 0;
|
return 0;
|
||||||
#else // #if LUA_OPTIMIZE_MEMORY > 0
|
|
||||||
int n;
|
|
||||||
luaL_register( L, AUXLIB_MQTT, mqtt_map );
|
|
||||||
|
|
||||||
// Set it as its own metatable
|
|
||||||
lua_pushvalue( L, -1 );
|
|
||||||
lua_setmetatable( L, -2 );
|
|
||||||
|
|
||||||
// Module constants
|
|
||||||
// MOD_REG_NUMBER( L, "TCP", TCP );
|
|
||||||
|
|
||||||
// create metatable
|
|
||||||
luaL_newmetatable(L, "mqtt.socket");
|
|
||||||
// metatable.__index = metatable
|
|
||||||
lua_pushliteral(L, "__index");
|
|
||||||
lua_pushvalue(L,-2);
|
|
||||||
lua_rawset(L,-3);
|
|
||||||
// Setup the methods inside metatable
|
|
||||||
luaL_register( L, NULL, mqtt_socket_map );
|
|
||||||
|
|
||||||
return 1;
|
|
||||||
#endif // #if LUA_OPTIMIZE_MEMORY > 0
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
NODEMCU_MODULE(MQTT, "mqtt", mqtt_map, luaopen_mqtt);
|
||||||
|
@ -1,11 +1,8 @@
|
|||||||
// Module for network
|
// Module for network
|
||||||
|
|
||||||
//#include "lua.h"
|
#include "module.h"
|
||||||
#include "lualib.h"
|
|
||||||
#include "lauxlib.h"
|
#include "lauxlib.h"
|
||||||
#include "platform.h"
|
#include "platform.h"
|
||||||
#include "auxmods.h"
|
|
||||||
#include "lrotable.h"
|
|
||||||
|
|
||||||
#include "c_string.h"
|
#include "c_string.h"
|
||||||
#include "c_stdlib.h"
|
#include "c_stdlib.h"
|
||||||
@ -1508,132 +1505,72 @@ static int expose_array(lua_State* L, char *array, unsigned short len) {
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
// Module function map
|
// Module function map
|
||||||
#define MIN_OPT_LEVEL 2
|
static const LUA_REG_TYPE net_server_map[] = {
|
||||||
#include "lrodefs.h"
|
{ LSTRKEY( "listen" ), LFUNCVAL( net_server_listen ) },
|
||||||
static const LUA_REG_TYPE net_server_map[] =
|
{ LSTRKEY( "close" ), LFUNCVAL( net_server_close ) },
|
||||||
{
|
{ LSTRKEY( "on" ), LFUNCVAL( net_udpserver_on ) },
|
||||||
{ LSTRKEY( "listen" ), LFUNCVAL ( net_server_listen ) },
|
{ LSTRKEY( "send" ), LFUNCVAL( net_udpserver_send ) },
|
||||||
{ LSTRKEY( "close" ), LFUNCVAL ( net_server_close ) },
|
//{ LSTRKEY( "delete" ), LFUNCVAL( net_server_delete ) },
|
||||||
{ LSTRKEY( "on" ), LFUNCVAL ( net_udpserver_on ) },
|
{ LSTRKEY( "__gc" ), LFUNCVAL( net_server_delete ) },
|
||||||
{ LSTRKEY( "send" ), LFUNCVAL ( net_udpserver_send ) },
|
{ LSTRKEY( "__index" ), LROVAL( net_server_map ) },
|
||||||
// { LSTRKEY( "delete" ), LFUNCVAL ( net_server_delete ) },
|
|
||||||
{ LSTRKEY( "__gc" ), LFUNCVAL ( net_server_delete ) },
|
|
||||||
#if LUA_OPTIMIZE_MEMORY > 0
|
|
||||||
{ LSTRKEY( "__index" ), LROVAL ( net_server_map ) },
|
|
||||||
#endif
|
|
||||||
{ LNILKEY, LNILVAL }
|
{ LNILKEY, LNILVAL }
|
||||||
};
|
};
|
||||||
|
|
||||||
static const LUA_REG_TYPE net_socket_map[] =
|
static const LUA_REG_TYPE net_socket_map[] = {
|
||||||
{
|
|
||||||
{ LSTRKEY( "connect" ), LFUNCVAL( net_socket_connect ) },
|
{ LSTRKEY( "connect" ), LFUNCVAL( net_socket_connect ) },
|
||||||
{ LSTRKEY( "close" ), LFUNCVAL ( net_socket_close ) },
|
{ LSTRKEY( "close" ), LFUNCVAL( net_socket_close ) },
|
||||||
{ LSTRKEY( "on" ), LFUNCVAL ( net_socket_on ) },
|
{ LSTRKEY( "on" ), LFUNCVAL( net_socket_on ) },
|
||||||
{ LSTRKEY( "send" ), LFUNCVAL ( net_socket_send ) },
|
{ LSTRKEY( "send" ), LFUNCVAL( net_socket_send ) },
|
||||||
{ LSTRKEY( "hold" ), LFUNCVAL ( net_socket_hold ) },
|
{ LSTRKEY( "hold" ), LFUNCVAL( net_socket_hold ) },
|
||||||
{ LSTRKEY( "unhold" ), LFUNCVAL ( net_socket_unhold ) },
|
{ LSTRKEY( "unhold" ), LFUNCVAL( net_socket_unhold ) },
|
||||||
{ LSTRKEY( "dns" ), LFUNCVAL ( net_socket_dns ) },
|
{ LSTRKEY( "dns" ), LFUNCVAL( net_socket_dns ) },
|
||||||
{ LSTRKEY( "getpeer" ), LFUNCVAL ( net_socket_getpeer ) },
|
{ LSTRKEY( "getpeer" ), LFUNCVAL( net_socket_getpeer ) },
|
||||||
// { LSTRKEY( "delete" ), LFUNCVAL ( net_socket_delete ) },
|
//{ LSTRKEY( "delete" ), LFUNCVAL( net_socket_delete ) },
|
||||||
{ LSTRKEY( "__gc" ), LFUNCVAL ( net_socket_delete ) },
|
{ LSTRKEY( "__gc" ), LFUNCVAL( net_socket_delete ) },
|
||||||
#if LUA_OPTIMIZE_MEMORY > 0
|
{ LSTRKEY( "__index" ), LROVAL( net_socket_map ) },
|
||||||
{ LSTRKEY( "__index" ), LROVAL ( net_socket_map ) },
|
|
||||||
#endif
|
|
||||||
{ LNILKEY, LNILVAL }
|
{ LNILKEY, LNILVAL }
|
||||||
};
|
};
|
||||||
#if 0
|
#if 0
|
||||||
static const LUA_REG_TYPE net_array_map[] =
|
static const LUA_REG_TYPE net_array_map[] = {
|
||||||
{
|
{ LSTRKEY( "__index" ), LFUNCVAL( net_array_index ) },
|
||||||
{ LSTRKEY( "__index" ), LFUNCVAL( net_array_index ) },
|
|
||||||
{ LSTRKEY( "__newindex" ), LFUNCVAL( net_array_newindex ) },
|
{ LSTRKEY( "__newindex" ), LFUNCVAL( net_array_newindex ) },
|
||||||
{ LNILKEY, LNILVAL }
|
{ LNILKEY, LNILVAL }
|
||||||
};
|
};
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
static const LUA_REG_TYPE net_dns_map[] =
|
static const LUA_REG_TYPE net_dns_map[] = {
|
||||||
{
|
{ LSTRKEY( "setdnsserver" ), LFUNCVAL( net_setdnsserver ) },
|
||||||
{ LSTRKEY( "setdnsserver" ), LFUNCVAL ( net_setdnsserver ) },
|
{ LSTRKEY( "getdnsserver" ), LFUNCVAL( net_getdnsserver ) },
|
||||||
{ LSTRKEY( "getdnsserver" ), LFUNCVAL ( net_getdnsserver ) },
|
{ LSTRKEY( "resolve" ), LFUNCVAL( net_dns_static ) },
|
||||||
{ LSTRKEY( "resolve" ), LFUNCVAL ( net_dns_static ) },
|
|
||||||
{ LNILKEY, LNILVAL }
|
{ LNILKEY, LNILVAL }
|
||||||
};
|
};
|
||||||
|
|
||||||
const LUA_REG_TYPE net_map[] =
|
static const LUA_REG_TYPE net_map[] = {
|
||||||
{
|
{ LSTRKEY( "createServer" ), LFUNCVAL( net_createServer ) },
|
||||||
{ LSTRKEY( "createServer" ), LFUNCVAL ( net_createServer ) },
|
{ LSTRKEY( "createConnection" ), LFUNCVAL( net_createConnection ) },
|
||||||
{ LSTRKEY( "createConnection" ), LFUNCVAL ( net_createConnection ) },
|
{ LSTRKEY( "multicastJoin"), LFUNCVAL( net_multicastJoin ) },
|
||||||
{ LSTRKEY( "multicastJoin"), LFUNCVAL( net_multicastJoin ) },
|
{ LSTRKEY( "multicastLeave"), LFUNCVAL( net_multicastLeave ) },
|
||||||
{ LSTRKEY( "multicastLeave"), LFUNCVAL( net_multicastLeave ) },
|
{ LSTRKEY( "dns" ), LROVAL( net_dns_map ) },
|
||||||
#if LUA_OPTIMIZE_MEMORY > 0
|
{ LSTRKEY( "TCP" ), LNUMVAL( TCP ) },
|
||||||
{ LSTRKEY( "dns" ), LROVAL( net_dns_map ) },
|
{ LSTRKEY( "UDP" ), LNUMVAL( UDP ) },
|
||||||
{ LSTRKEY( "TCP" ), LNUMVAL( TCP ) },
|
{ LSTRKEY( "__metatable" ), LROVAL( net_map ) },
|
||||||
{ LSTRKEY( "UDP" ), LNUMVAL( UDP ) },
|
|
||||||
|
|
||||||
{ LSTRKEY( "__metatable" ), LROVAL( net_map ) },
|
|
||||||
#endif
|
|
||||||
{ LNILKEY, LNILVAL }
|
{ LNILKEY, LNILVAL }
|
||||||
};
|
};
|
||||||
|
|
||||||
LUALIB_API int luaopen_net( lua_State *L )
|
int luaopen_net( lua_State *L ) {
|
||||||
{
|
|
||||||
int i;
|
int i;
|
||||||
for(i=0;i<MAX_SOCKET;i++)
|
for(i=0;i<MAX_SOCKET;i++)
|
||||||
{
|
{
|
||||||
socket[i] = LUA_NOREF;
|
socket[i] = LUA_NOREF;
|
||||||
}
|
}
|
||||||
|
|
||||||
#if LUA_OPTIMIZE_MEMORY > 0
|
|
||||||
luaL_rometatable(L, "net.server", (void *)net_server_map); // create metatable for net.server
|
luaL_rometatable(L, "net.server", (void *)net_server_map); // create metatable for net.server
|
||||||
luaL_rometatable(L, "net.socket", (void *)net_socket_map); // create metatable for net.socket
|
luaL_rometatable(L, "net.socket", (void *)net_socket_map); // create metatable for net.socket
|
||||||
#if 0
|
#if 0
|
||||||
luaL_rometatable(L, "net.array", (void *)net_array_map); // create metatable for net.array
|
luaL_rometatable(L, "net.array", (void *)net_array_map); // create metatable for net.array
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
#else // #if LUA_OPTIMIZE_MEMORY > 0
|
|
||||||
int n;
|
|
||||||
luaL_register( L, AUXLIB_NET, net_map );
|
|
||||||
|
|
||||||
// Set it as its own metatable
|
|
||||||
lua_pushvalue( L, -1 );
|
|
||||||
lua_setmetatable( L, -2 );
|
|
||||||
|
|
||||||
// Module constants
|
|
||||||
MOD_REG_NUMBER( L, "TCP", TCP );
|
|
||||||
MOD_REG_NUMBER( L, "UDP", UDP );
|
|
||||||
|
|
||||||
n = lua_gettop(L);
|
|
||||||
|
|
||||||
// create metatable
|
|
||||||
luaL_newmetatable(L, "net.server");
|
|
||||||
// metatable.__index = metatable
|
|
||||||
lua_pushliteral(L, "__index");
|
|
||||||
lua_pushvalue(L,-2);
|
|
||||||
lua_rawset(L,-3);
|
|
||||||
// Setup the methods inside metatable
|
|
||||||
luaL_register( L, NULL, net_server_map );
|
|
||||||
|
|
||||||
lua_settop(L, n);
|
|
||||||
// create metatable
|
|
||||||
luaL_newmetatable(L, "net.socket");
|
|
||||||
// metatable.__index = metatable
|
|
||||||
lua_pushliteral(L, "__index");
|
|
||||||
lua_pushvalue(L,-2);
|
|
||||||
lua_rawset(L,-3);
|
|
||||||
// Setup the methods inside metatable
|
|
||||||
luaL_register( L, NULL, net_socket_map );
|
|
||||||
#if 0
|
|
||||||
lua_settop(L, n);
|
|
||||||
// create metatable
|
|
||||||
luaL_newmetatable(L, "net.array");
|
|
||||||
// Setup the methods inside metatable
|
|
||||||
luaL_register( L, NULL, net_array_map );
|
|
||||||
#endif
|
|
||||||
|
|
||||||
lua_settop(L, n);
|
|
||||||
lua_newtable( L );
|
|
||||||
luaL_register( L, NULL, net_dns_map );
|
|
||||||
lua_setfield( L, -2, "dns" );
|
|
||||||
|
|
||||||
return 1;
|
|
||||||
#endif // #if LUA_OPTIMIZE_MEMORY > 0
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
NODEMCU_MODULE(NET, "net", net_map, luaopen_net);
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
// Module for interfacing with system
|
// Module for interfacing with system
|
||||||
|
|
||||||
#include "lua.h"
|
#include "module.h"
|
||||||
#include "lauxlib.h"
|
#include "lauxlib.h"
|
||||||
|
|
||||||
#include "ldebug.h"
|
#include "ldebug.h"
|
||||||
@ -15,14 +15,12 @@
|
|||||||
#include "lundump.h"
|
#include "lundump.h"
|
||||||
|
|
||||||
#include "platform.h"
|
#include "platform.h"
|
||||||
#include "auxmods.h"
|
#include "lrodefs.h"
|
||||||
#include "lrotable.h"
|
|
||||||
|
|
||||||
#include "c_types.h"
|
#include "c_types.h"
|
||||||
#include "romfs.h"
|
#include "romfs.h"
|
||||||
#include "c_string.h"
|
#include "c_string.h"
|
||||||
#include "driver/uart.h"
|
#include "driver/uart.h"
|
||||||
//#include "spi_flash.h"
|
|
||||||
#include "user_interface.h"
|
#include "user_interface.h"
|
||||||
#include "flash_api.h"
|
#include "flash_api.h"
|
||||||
#include "flash_fs.h"
|
#include "flash_fs.h"
|
||||||
@ -550,9 +548,7 @@ static int node_stripdebug (lua_State *L) {
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
// Module function map
|
// Module function map
|
||||||
#define MIN_OPT_LEVEL 2
|
static const LUA_REG_TYPE node_map[] =
|
||||||
#include "lrodefs.h"
|
|
||||||
const LUA_REG_TYPE node_map[] =
|
|
||||||
{
|
{
|
||||||
{ LSTRKEY( "restart" ), LFUNCVAL( node_restart ) },
|
{ LSTRKEY( "restart" ), LFUNCVAL( node_restart ) },
|
||||||
{ LSTRKEY( "dsleep" ), LFUNCVAL( node_deepsleep ) },
|
{ LSTRKEY( "dsleep" ), LFUNCVAL( node_deepsleep ) },
|
||||||
@ -581,20 +577,7 @@ const LUA_REG_TYPE node_map[] =
|
|||||||
|
|
||||||
// Combined to dsleep(us, option)
|
// Combined to dsleep(us, option)
|
||||||
// { LSTRKEY( "dsleepsetoption" ), LFUNCVAL( node_deepsleep_setoption) },
|
// { LSTRKEY( "dsleepsetoption" ), LFUNCVAL( node_deepsleep_setoption) },
|
||||||
#if LUA_OPTIMIZE_MEMORY > 0
|
|
||||||
|
|
||||||
#endif
|
|
||||||
{ LNILKEY, LNILVAL }
|
{ LNILKEY, LNILVAL }
|
||||||
};
|
};
|
||||||
|
|
||||||
LUALIB_API int luaopen_node( lua_State *L )
|
NODEMCU_MODULE(NODE, "node", node_map, NULL);
|
||||||
{
|
|
||||||
#if LUA_OPTIMIZE_MEMORY > 0
|
|
||||||
return 0;
|
|
||||||
#else // #if LUA_OPTIMIZE_MEMORY > 0
|
|
||||||
luaL_register( L, AUXLIB_NODE, node_map );
|
|
||||||
// Add constants
|
|
||||||
|
|
||||||
return 1;
|
|
||||||
#endif // #if LUA_OPTIMIZE_MEMORY > 0
|
|
||||||
}
|
|
||||||
|
@ -1,10 +1,8 @@
|
|||||||
// Module for interfacing with the OneWire interface
|
// Module for interfacing with the OneWire interface
|
||||||
|
|
||||||
//#include "lua.h"
|
#include "module.h"
|
||||||
#include "lualib.h"
|
|
||||||
#include "lauxlib.h"
|
#include "lauxlib.h"
|
||||||
#include "auxmods.h"
|
#include "platform.h"
|
||||||
#include "lrotable.h"
|
|
||||||
#include "driver/onewire.h"
|
#include "driver/onewire.h"
|
||||||
|
|
||||||
// Lua: ow.setup( id )
|
// Lua: ow.setup( id )
|
||||||
@ -282,46 +280,29 @@ static int ow_crc16( lua_State *L )
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
// Module function map
|
// Module function map
|
||||||
#define MIN_OPT_LEVEL 2
|
static const LUA_REG_TYPE ow_map[] = {
|
||||||
#include "lrodefs.h"
|
{ LSTRKEY( "setup" ), LFUNCVAL( ow_setup ) },
|
||||||
const LUA_REG_TYPE ow_map[] =
|
{ LSTRKEY( "reset" ), LFUNCVAL( ow_reset ) },
|
||||||
{
|
{ LSTRKEY( "skip" ), LFUNCVAL( ow_skip ) },
|
||||||
{ LSTRKEY( "setup" ), LFUNCVAL( ow_setup ) },
|
{ LSTRKEY( "select" ), LFUNCVAL( ow_select ) },
|
||||||
{ LSTRKEY( "reset" ), LFUNCVAL( ow_reset ) },
|
{ LSTRKEY( "write" ), LFUNCVAL( ow_write ) },
|
||||||
{ LSTRKEY( "skip" ), LFUNCVAL( ow_skip ) },
|
{ LSTRKEY( "write_bytes" ), LFUNCVAL( ow_write_bytes ) },
|
||||||
{ LSTRKEY( "select" ), LFUNCVAL( ow_select ) },
|
{ LSTRKEY( "read" ), LFUNCVAL( ow_read ) },
|
||||||
{ LSTRKEY( "write" ), LFUNCVAL( ow_write ) },
|
{ LSTRKEY( "read_bytes" ), LFUNCVAL( ow_read_bytes ) },
|
||||||
{ LSTRKEY( "write_bytes" ), LFUNCVAL( ow_write_bytes ) },
|
{ LSTRKEY( "depower" ), LFUNCVAL( ow_depower ) },
|
||||||
{ LSTRKEY( "read" ), LFUNCVAL( ow_read ) },
|
|
||||||
{ LSTRKEY( "read_bytes" ), LFUNCVAL( ow_read_bytes ) },
|
|
||||||
{ LSTRKEY( "depower" ), LFUNCVAL( ow_depower ) },
|
|
||||||
#if ONEWIRE_SEARCH
|
#if ONEWIRE_SEARCH
|
||||||
{ LSTRKEY( "reset_search" ), LFUNCVAL( ow_reset_search ) },
|
{ LSTRKEY( "reset_search" ), LFUNCVAL( ow_reset_search ) },
|
||||||
{ LSTRKEY( "target_search" ), LFUNCVAL( ow_target_search ) },
|
{ LSTRKEY( "target_search" ), LFUNCVAL( ow_target_search ) },
|
||||||
{ LSTRKEY( "search" ), LFUNCVAL( ow_search ) },
|
{ LSTRKEY( "search" ), LFUNCVAL( ow_search ) },
|
||||||
#endif
|
#endif
|
||||||
#if ONEWIRE_CRC
|
#if ONEWIRE_CRC
|
||||||
{ LSTRKEY( "crc8" ), LFUNCVAL( ow_crc8 ) },
|
{ LSTRKEY( "crc8" ), LFUNCVAL( ow_crc8 ) },
|
||||||
#if ONEWIRE_CRC16
|
#if ONEWIRE_CRC16
|
||||||
{ LSTRKEY( "check_crc16" ), LFUNCVAL( ow_check_crc16 ) },
|
{ LSTRKEY( "check_crc16" ), LFUNCVAL( ow_check_crc16 ) },
|
||||||
{ LSTRKEY( "crc16" ), LFUNCVAL( ow_crc16 ) },
|
{ LSTRKEY( "crc16" ), LFUNCVAL( ow_crc16 ) },
|
||||||
#endif
|
#endif
|
||||||
#endif
|
|
||||||
#if LUA_OPTIMIZE_MEMORY > 0
|
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
{ LNILKEY, LNILVAL }
|
{ LNILKEY, LNILVAL }
|
||||||
};
|
};
|
||||||
|
|
||||||
LUALIB_API int luaopen_ow( lua_State *L )
|
NODEMCU_MODULE(OW, "ow", ow_map, NULL);
|
||||||
{
|
|
||||||
#if LUA_OPTIMIZE_MEMORY > 0
|
|
||||||
return 0;
|
|
||||||
#else // #if LUA_OPTIMIZE_MEMORY > 0
|
|
||||||
luaL_register( L, AUXLIB_OW, ow_map );
|
|
||||||
|
|
||||||
// Add the constants
|
|
||||||
|
|
||||||
return 1;
|
|
||||||
#endif // #if LUA_OPTIMIZE_MEMORY > 0
|
|
||||||
}
|
|
||||||
|
@ -1,12 +1,8 @@
|
|||||||
// Module for interfacing with PWM
|
// Module for interfacing with PWM
|
||||||
|
|
||||||
//#include "lua.h"
|
#include "module.h"
|
||||||
#include "lualib.h"
|
|
||||||
#include "lauxlib.h"
|
#include "lauxlib.h"
|
||||||
#include "platform.h"
|
#include "platform.h"
|
||||||
#include "auxmods.h"
|
|
||||||
#include "lrotable.h"
|
|
||||||
|
|
||||||
#include "c_types.h"
|
#include "c_types.h"
|
||||||
|
|
||||||
// Lua: realfrequency = setup( id, frequency, duty )
|
// Lua: realfrequency = setup( id, frequency, duty )
|
||||||
@ -125,30 +121,16 @@ static int lpwm_getduty( lua_State* L )
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Module function map
|
// Module function map
|
||||||
#define MIN_OPT_LEVEL 2
|
static const LUA_REG_TYPE pwm_map[] = {
|
||||||
#include "lrodefs.h"
|
{ LSTRKEY( "setup" ), LFUNCVAL( lpwm_setup ) },
|
||||||
const LUA_REG_TYPE pwm_map[] =
|
{ LSTRKEY( "close" ), LFUNCVAL( lpwm_close ) },
|
||||||
{
|
{ LSTRKEY( "start" ), LFUNCVAL( lpwm_start ) },
|
||||||
{ LSTRKEY( "setup" ), LFUNCVAL( lpwm_setup ) },
|
{ LSTRKEY( "stop" ), LFUNCVAL( lpwm_stop ) },
|
||||||
{ LSTRKEY( "close" ), LFUNCVAL( lpwm_close ) },
|
|
||||||
{ LSTRKEY( "start" ), LFUNCVAL( lpwm_start ) },
|
|
||||||
{ LSTRKEY( "stop" ), LFUNCVAL( lpwm_stop ) },
|
|
||||||
{ LSTRKEY( "setclock" ), LFUNCVAL( lpwm_setclock ) },
|
{ LSTRKEY( "setclock" ), LFUNCVAL( lpwm_setclock ) },
|
||||||
{ LSTRKEY( "getclock" ), LFUNCVAL( lpwm_getclock ) },
|
{ LSTRKEY( "getclock" ), LFUNCVAL( lpwm_getclock ) },
|
||||||
{ LSTRKEY( "setduty" ), LFUNCVAL( lpwm_setduty ) },
|
{ LSTRKEY( "setduty" ), LFUNCVAL( lpwm_setduty ) },
|
||||||
{ LSTRKEY( "getduty" ), LFUNCVAL( lpwm_getduty ) },
|
{ LSTRKEY( "getduty" ), LFUNCVAL( lpwm_getduty ) },
|
||||||
#if LUA_OPTIMIZE_MEMORY > 0
|
|
||||||
|
|
||||||
#endif
|
|
||||||
{ LNILKEY, LNILVAL }
|
{ LNILKEY, LNILVAL }
|
||||||
};
|
};
|
||||||
|
|
||||||
LUALIB_API int luaopen_pwm( lua_State *L )
|
NODEMCU_MODULE(PWM, "pwm", pwm_map, NULL);
|
||||||
{
|
|
||||||
#if LUA_OPTIMIZE_MEMORY > 0
|
|
||||||
return 0;
|
|
||||||
#else // #if LUA_OPTIMIZE_MEMORY > 0
|
|
||||||
luaL_register( L, AUXLIB_PWM, pwm_map );
|
|
||||||
return 1;
|
|
||||||
#endif // #if LUA_OPTIMIZE_MEMORY > 0
|
|
||||||
}
|
|
||||||
|
@ -1,8 +1,6 @@
|
|||||||
#include "lualib.h"
|
#include "module.h"
|
||||||
#include "lauxlib.h"
|
#include "lauxlib.h"
|
||||||
#include "platform.h"
|
#include "platform.h"
|
||||||
#include "auxmods.h"
|
|
||||||
#include "lrotable.h"
|
|
||||||
//#include "driver/easygpio.h"
|
//#include "driver/easygpio.h"
|
||||||
//static Ping_Data pingA;
|
//static Ping_Data pingA;
|
||||||
#define defPulseLen 185
|
#define defPulseLen 185
|
||||||
@ -80,17 +78,16 @@ static int ICACHE_FLASH_ATTR rc_send(lua_State* L) {
|
|||||||
|
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
#define MIN_OPT_LEVEL 2
|
|
||||||
#include "lrodefs.h"
|
// Module function map
|
||||||
const LUA_REG_TYPE rc_map[] =
|
static const LUA_REG_TYPE rc_map[] = {
|
||||||
{
|
|
||||||
{ LSTRKEY( "send" ), LFUNCVAL( rc_send )},
|
{ LSTRKEY( "send" ), LFUNCVAL( rc_send )},
|
||||||
{ LNILKEY, LNILVAL}
|
{ LNILKEY, LNILVAL}
|
||||||
};
|
};
|
||||||
|
|
||||||
//LUALIB_API int luaopen_ultra(lua_State *L) {
|
int luaopen_rc(lua_State *L) {
|
||||||
LUALIB_API int luaopen_rc(lua_State *L) {
|
|
||||||
// TODO: Make sure that the GPIO system is initialized
|
// TODO: Make sure that the GPIO system is initialized
|
||||||
LREGISTER(L, "rc", rc_map);
|
return 0;
|
||||||
return 1;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
NODEMCU_MODULE(RC, "rc", rc_map, luaopen_rc);
|
||||||
|
@ -1,5 +1,6 @@
|
|||||||
// Module for RTC sample FIFO storage
|
// Module for RTC sample FIFO storage
|
||||||
|
|
||||||
|
#include "module.h"
|
||||||
#include "lauxlib.h"
|
#include "lauxlib.h"
|
||||||
#include "user_modules.h"
|
#include "user_modules.h"
|
||||||
#include "rtc/rtctime.h"
|
#include "rtc/rtctime.h"
|
||||||
@ -164,10 +165,7 @@ static int rtcfifo_dsleep_until_sample (lua_State *L)
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
// Module function map
|
// Module function map
|
||||||
#define MIN_OPT_LEVEL 2
|
static const LUA_REG_TYPE rtcfifo_map[] = {
|
||||||
#include "lrodefs.h"
|
|
||||||
const LUA_REG_TYPE rtcfifo_map[] =
|
|
||||||
{
|
|
||||||
{ LSTRKEY("prepare"), LFUNCVAL(rtcfifo_prepare) },
|
{ LSTRKEY("prepare"), LFUNCVAL(rtcfifo_prepare) },
|
||||||
{ LSTRKEY("ready"), LFUNCVAL(rtcfifo_ready) },
|
{ LSTRKEY("ready"), LFUNCVAL(rtcfifo_ready) },
|
||||||
{ LSTRKEY("put"), LFUNCVAL(rtcfifo_put) },
|
{ LSTRKEY("put"), LFUNCVAL(rtcfifo_put) },
|
||||||
@ -181,12 +179,4 @@ const LUA_REG_TYPE rtcfifo_map[] =
|
|||||||
{ LNILKEY, LNILVAL }
|
{ LNILKEY, LNILVAL }
|
||||||
};
|
};
|
||||||
|
|
||||||
LUALIB_API int luaopen_rtcfifo (lua_State *L)
|
NODEMCU_MODULE(RTCFIFO, "rtcfifo", rtcfifo_map, NULL);
|
||||||
{
|
|
||||||
#if LUA_OPTIMIZE_MEMORY > 0
|
|
||||||
return 0;
|
|
||||||
#else
|
|
||||||
luaL_register (L, AUXLIB_RTCFIFO, rtcfifo_map);
|
|
||||||
return 1;
|
|
||||||
#endif
|
|
||||||
}
|
|
||||||
|
@ -1,5 +1,6 @@
|
|||||||
// Module for RTC user memory access
|
// Module for RTC user memory access
|
||||||
|
|
||||||
|
#include "module.h"
|
||||||
#include "lauxlib.h"
|
#include "lauxlib.h"
|
||||||
#include "rtc/rtcaccess.h"
|
#include "rtc/rtcaccess.h"
|
||||||
|
|
||||||
@ -40,21 +41,10 @@ static int rtcmem_write32 (lua_State *L)
|
|||||||
|
|
||||||
|
|
||||||
// Module function map
|
// Module function map
|
||||||
#define MIN_OPT_LEVEL 2
|
static const LUA_REG_TYPE rtcmem_map[] = {
|
||||||
#include "lrodefs.h"
|
|
||||||
const LUA_REG_TYPE rtcmem_map[] =
|
|
||||||
{
|
|
||||||
{ LSTRKEY("read32"), LFUNCVAL(rtcmem_read32) },
|
{ LSTRKEY("read32"), LFUNCVAL(rtcmem_read32) },
|
||||||
{ LSTRKEY("write32"), LFUNCVAL(rtcmem_write32) },
|
{ LSTRKEY("write32"), LFUNCVAL(rtcmem_write32) },
|
||||||
{ LNILKEY, LNILVAL }
|
{ LNILKEY, LNILVAL }
|
||||||
};
|
};
|
||||||
|
|
||||||
LUALIB_API int luaopen_rtcmem (lua_State *L)
|
NODEMCU_MODULE(RTCMEM, "rtcmem", rtcmem_map, NULL);
|
||||||
{
|
|
||||||
#if LUA_OPTIMIZE_MEMORY > 0
|
|
||||||
return 0;
|
|
||||||
#else
|
|
||||||
luaL_register (L, AUXLIB_RTCMEM, rtcmem_map);
|
|
||||||
return 1;
|
|
||||||
#endif
|
|
||||||
}
|
|
||||||
|
@ -1,5 +1,6 @@
|
|||||||
// Module for RTC time keeping
|
// Module for RTC time keeping
|
||||||
|
|
||||||
|
#include "module.h"
|
||||||
#include "lauxlib.h"
|
#include "lauxlib.h"
|
||||||
|
|
||||||
#include "rtc/rtctime_internal.h"
|
#include "rtc/rtctime_internal.h"
|
||||||
@ -115,23 +116,12 @@ static int rtctime_dsleep_aligned (lua_State *L)
|
|||||||
|
|
||||||
|
|
||||||
// Module function map
|
// Module function map
|
||||||
#define MIN_OPT_LEVEL 2
|
static const LUA_REG_TYPE rtctime_map[] = {
|
||||||
#include "lrodefs.h"
|
{ LSTRKEY("set"), LFUNCVAL(rtctime_set) },
|
||||||
const LUA_REG_TYPE rtctime_map[] =
|
{ LSTRKEY("get"), LFUNCVAL(rtctime_get) },
|
||||||
{
|
{ LSTRKEY("dsleep"), LFUNCVAL(rtctime_dsleep) },
|
||||||
{ LSTRKEY("set"), LFUNCVAL(rtctime_set) },
|
|
||||||
{ LSTRKEY("get"), LFUNCVAL(rtctime_get) },
|
|
||||||
{ LSTRKEY("dsleep"), LFUNCVAL(rtctime_dsleep) },
|
|
||||||
{ LSTRKEY("dsleep_aligned"), LFUNCVAL(rtctime_dsleep_aligned) },
|
{ LSTRKEY("dsleep_aligned"), LFUNCVAL(rtctime_dsleep_aligned) },
|
||||||
{ LNILKEY, LNILVAL }
|
{ LNILKEY, LNILVAL }
|
||||||
};
|
};
|
||||||
|
|
||||||
LUALIB_API int luaopen_rtctime (lua_State *L)
|
NODEMCU_MODULE(RTCTIME, "rtctime", rtctime_map, NULL);
|
||||||
{
|
|
||||||
#if LUA_OPTIMIZE_MEMORY > 0
|
|
||||||
return 0;
|
|
||||||
#else
|
|
||||||
luaL_register (L, AUXLIB_RTCTIME, rtctime_map);
|
|
||||||
return 1;
|
|
||||||
#endif
|
|
||||||
}
|
|
||||||
|
@ -33,6 +33,7 @@
|
|||||||
|
|
||||||
// Module for Simple Network Time Protocol (SNTP)
|
// Module for Simple Network Time Protocol (SNTP)
|
||||||
|
|
||||||
|
#include "module.h"
|
||||||
#include "lauxlib.h"
|
#include "lauxlib.h"
|
||||||
#include "os_type.h"
|
#include "os_type.h"
|
||||||
#include "osapi.h"
|
#include "osapi.h"
|
||||||
@ -375,20 +376,9 @@ error:
|
|||||||
|
|
||||||
|
|
||||||
// Module function map
|
// Module function map
|
||||||
#define MIN_OPT_LEVEL 2
|
static const LUA_REG_TYPE sntp_map[] = {
|
||||||
#include "lrodefs.h"
|
|
||||||
const LUA_REG_TYPE sntp_map[] =
|
|
||||||
{
|
|
||||||
{ LSTRKEY("sync"), LFUNCVAL(sntp_sync) },
|
{ LSTRKEY("sync"), LFUNCVAL(sntp_sync) },
|
||||||
{ LNILKEY, LNILVAL }
|
{ LNILKEY, LNILVAL }
|
||||||
};
|
};
|
||||||
|
|
||||||
LUALIB_API int luaopen_sntp (lua_State *L)
|
NODEMCU_MODULE(SNTP, "sntp", sntp_map, NULL);
|
||||||
{
|
|
||||||
#if LUA_OPTIMIZE_MEMORY > 0
|
|
||||||
return 0;
|
|
||||||
#else
|
|
||||||
luaL_register (L, AUXLIB_SNTP, sntp_map);
|
|
||||||
return 1;
|
|
||||||
#endif
|
|
||||||
}
|
|
||||||
|
@ -1,11 +1,8 @@
|
|||||||
// Module for interfacing with the SPI interface
|
// Module for interfacing with the SPI interface
|
||||||
|
|
||||||
//#include "lua.h"
|
#include "module.h"
|
||||||
#include "lualib.h"
|
|
||||||
#include "lauxlib.h"
|
#include "lauxlib.h"
|
||||||
#include "platform.h"
|
#include "platform.h"
|
||||||
#include "auxmods.h"
|
|
||||||
#include "lrotable.h"
|
|
||||||
|
|
||||||
#define SPI_HALFDUPLEX 0
|
#define SPI_HALFDUPLEX 0
|
||||||
#define SPI_FULLDUPLEX 1
|
#define SPI_FULLDUPLEX 1
|
||||||
@ -33,6 +30,10 @@ static int spi_setup( lua_State *L )
|
|||||||
if (cpol != PLATFORM_SPI_CPOL_LOW && cpol != PLATFORM_SPI_CPOL_HIGH) {
|
if (cpol != PLATFORM_SPI_CPOL_LOW && cpol != PLATFORM_SPI_CPOL_HIGH) {
|
||||||
return luaL_error( L, "wrong arg type" );
|
return luaL_error( L, "wrong arg type" );
|
||||||
}
|
}
|
||||||
|
// CPOL_HIGH is not implemented, see app/driver/spi.c spi_master_init()
|
||||||
|
if (cpol == PLATFORM_SPI_CPOL_HIGH) {
|
||||||
|
return luaL_error( L, "cpol=high is not implemented" );
|
||||||
|
}
|
||||||
|
|
||||||
if (cpha != PLATFORM_SPI_CPHA_LOW && cpha != PLATFORM_SPI_CPHA_HIGH) {
|
if (cpha != PLATFORM_SPI_CPHA_LOW && cpha != PLATFORM_SPI_CPHA_HIGH) {
|
||||||
return luaL_error( L, "wrong arg type" );
|
return luaL_error( L, "wrong arg type" );
|
||||||
@ -309,48 +310,23 @@ static int spi_transaction( lua_State *L )
|
|||||||
|
|
||||||
|
|
||||||
// Module function map
|
// Module function map
|
||||||
#define MIN_OPT_LEVEL 2
|
static const LUA_REG_TYPE spi_map[] = {
|
||||||
#include "lrodefs.h"
|
|
||||||
const LUA_REG_TYPE spi_map[] =
|
|
||||||
{
|
|
||||||
{ LSTRKEY( "setup" ), LFUNCVAL( spi_setup ) },
|
{ LSTRKEY( "setup" ), LFUNCVAL( spi_setup ) },
|
||||||
{ LSTRKEY( "send" ), LFUNCVAL( spi_send_recv ) },
|
{ LSTRKEY( "send" ), LFUNCVAL( spi_send_recv ) },
|
||||||
{ LSTRKEY( "recv" ), LFUNCVAL( spi_recv ) },
|
{ LSTRKEY( "recv" ), LFUNCVAL( spi_recv ) },
|
||||||
{ LSTRKEY( "set_mosi" ), LFUNCVAL( spi_set_mosi ) },
|
{ LSTRKEY( "set_mosi" ), LFUNCVAL( spi_set_mosi ) },
|
||||||
{ LSTRKEY( "get_miso" ), LFUNCVAL( spi_get_miso ) },
|
{ LSTRKEY( "get_miso" ), LFUNCVAL( spi_get_miso ) },
|
||||||
{ LSTRKEY( "transaction" ), LFUNCVAL( spi_transaction ) },
|
{ LSTRKEY( "transaction" ), LFUNCVAL( spi_transaction ) },
|
||||||
#if LUA_OPTIMIZE_MEMORY > 0
|
{ LSTRKEY( "MASTER" ), LNUMVAL( PLATFORM_SPI_MASTER ) },
|
||||||
{ LSTRKEY( "MASTER" ), LNUMVAL( PLATFORM_SPI_MASTER ) },
|
{ LSTRKEY( "SLAVE" ), LNUMVAL( PLATFORM_SPI_SLAVE) },
|
||||||
{ LSTRKEY( "SLAVE" ), LNUMVAL( PLATFORM_SPI_SLAVE) },
|
{ LSTRKEY( "CPHA_LOW" ), LNUMVAL( PLATFORM_SPI_CPHA_LOW) },
|
||||||
{ LSTRKEY( "CPHA_LOW" ), LNUMVAL( PLATFORM_SPI_CPHA_LOW) },
|
{ LSTRKEY( "CPHA_HIGH" ), LNUMVAL( PLATFORM_SPI_CPHA_HIGH) },
|
||||||
{ LSTRKEY( "CPHA_HIGH" ), LNUMVAL( PLATFORM_SPI_CPHA_HIGH) },
|
{ LSTRKEY( "CPOL_LOW" ), LNUMVAL( PLATFORM_SPI_CPOL_LOW) },
|
||||||
{ LSTRKEY( "CPOL_LOW" ), LNUMVAL( PLATFORM_SPI_CPOL_LOW) },
|
{ LSTRKEY( "CPOL_HIGH" ), LNUMVAL( PLATFORM_SPI_CPOL_HIGH) },
|
||||||
{ LSTRKEY( "CPOL_HIGH" ), LNUMVAL( PLATFORM_SPI_CPOL_HIGH) },
|
{ LSTRKEY( "DATABITS_8" ), LNUMVAL( 8 ) },
|
||||||
{ LSTRKEY( "DATABITS_8" ), LNUMVAL( 8 ) },
|
{ LSTRKEY( "HALFDUPLEX" ), LNUMVAL( SPI_HALFDUPLEX ) },
|
||||||
{ LSTRKEY( "HALFDUPLEX" ), LNUMVAL( SPI_HALFDUPLEX ) },
|
{ LSTRKEY( "FULLDUPLEX" ), LNUMVAL( SPI_FULLDUPLEX ) },
|
||||||
{ LSTRKEY( "FULLDUPLEX" ), LNUMVAL( SPI_FULLDUPLEX ) },
|
|
||||||
#endif // #if LUA_OPTIMIZE_MEMORY > 0
|
|
||||||
{ LNILKEY, LNILVAL }
|
{ LNILKEY, LNILVAL }
|
||||||
};
|
};
|
||||||
|
|
||||||
LUALIB_API int luaopen_spi( lua_State *L )
|
NODEMCU_MODULE(SPI, "spi", spi_map, NULL);
|
||||||
{
|
|
||||||
#if LUA_OPTIMIZE_MEMORY > 0
|
|
||||||
return 0;
|
|
||||||
#else // #if LUA_OPTIMIZE_MEMORY > 0
|
|
||||||
luaL_register( L, AUXLIB_SPI, spi_map );
|
|
||||||
|
|
||||||
// Add constants
|
|
||||||
MOD_REG_NUMBER( L, "MASTER", PLATFORM_SPI_MASTER);
|
|
||||||
MOD_REG_NUMBER( L, "SLAVE", PLATFORM_SPI_SLAVE);
|
|
||||||
MOD_REG_NUMBER( L, "CPHA_LOW" , PLATFORM_SPI_CPHA_LOW);
|
|
||||||
MOD_REG_NUMBER( L, "CPHA_HIGH", PLATFORM_SPI_CPHA_HIGH);
|
|
||||||
MOD_REG_NUMBER( L, "CPOL_LOW" , PLATFORM_SPI_CPOL_LOW);
|
|
||||||
MOD_REG_NUMBER( L, "CPOL_HIGH", PLATFORM_SPI_CPOL_HIGH);
|
|
||||||
MOD_REG_NUMBER( L, "DATABITS_8", 8 );
|
|
||||||
MOD_REG_NUMBER( L, "HALFDUPLEX", SPI_HALFDUPLEX );
|
|
||||||
MOD_REG_NUMBER( L, "FULLDUPLEX", SPI_FULLDUPLEX );
|
|
||||||
|
|
||||||
return 1;
|
|
||||||
#endif // #if LUA_OPTIMIZE_MEMORY > 0
|
|
||||||
}
|
|
||||||
|
@ -48,14 +48,9 @@ tmr.softwd(int)
|
|||||||
the timer units are seconds
|
the timer units are seconds
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#define MIN_OPT_LEVEL 2
|
#include "module.h"
|
||||||
|
|
||||||
#include "lualib.h"
|
|
||||||
#include "lauxlib.h"
|
#include "lauxlib.h"
|
||||||
#include "platform.h"
|
#include "platform.h"
|
||||||
#include "auxmods.h"
|
|
||||||
#include "lrotable.h"
|
|
||||||
#include "lrodefs.h"
|
|
||||||
#include "c_types.h"
|
#include "c_types.h"
|
||||||
|
|
||||||
#define TIMER_MODE_OFF 3
|
#define TIMER_MODE_OFF 3
|
||||||
@ -311,28 +306,26 @@ static int tmr_softwd( lua_State* L ){
|
|||||||
|
|
||||||
// Module function map
|
// Module function map
|
||||||
|
|
||||||
const LUA_REG_TYPE tmr_map[] = {
|
static const LUA_REG_TYPE tmr_map[] = {
|
||||||
{ LSTRKEY( "delay" ), LFUNCVAL( tmr_delay ) },
|
{ LSTRKEY( "delay" ), LFUNCVAL( tmr_delay ) },
|
||||||
{ LSTRKEY( "now" ), LFUNCVAL( tmr_now ) },
|
{ LSTRKEY( "now" ), LFUNCVAL( tmr_now ) },
|
||||||
{ LSTRKEY( "wdclr" ), LFUNCVAL( tmr_wdclr ) },
|
{ LSTRKEY( "wdclr" ), LFUNCVAL( tmr_wdclr ) },
|
||||||
{ LSTRKEY( "softwd" ), LFUNCVAL( tmr_softwd ) },
|
{ LSTRKEY( "softwd" ), LFUNCVAL( tmr_softwd ) },
|
||||||
{ LSTRKEY( "time" ), LFUNCVAL( tmr_time ) },
|
{ LSTRKEY( "time" ), LFUNCVAL( tmr_time ) },
|
||||||
{ LSTRKEY( "register" ), LFUNCVAL ( tmr_register ) },
|
{ LSTRKEY( "register" ), LFUNCVAL( tmr_register ) },
|
||||||
{ LSTRKEY( "alarm" ), LFUNCVAL( tmr_alarm ) },
|
{ LSTRKEY( "alarm" ), LFUNCVAL( tmr_alarm ) },
|
||||||
{ LSTRKEY( "start" ), LFUNCVAL ( tmr_start ) },
|
{ LSTRKEY( "start" ), LFUNCVAL( tmr_start ) },
|
||||||
{ LSTRKEY( "stop" ), LFUNCVAL ( tmr_stop ) },
|
{ LSTRKEY( "stop" ), LFUNCVAL( tmr_stop ) },
|
||||||
{ LSTRKEY( "unregister" ), LFUNCVAL ( tmr_unregister ) },
|
{ LSTRKEY( "unregister" ), LFUNCVAL( tmr_unregister ) },
|
||||||
{ LSTRKEY( "state" ), LFUNCVAL ( tmr_state ) },
|
{ LSTRKEY( "state" ), LFUNCVAL( tmr_state ) },
|
||||||
{ LSTRKEY( "interval" ), LFUNCVAL ( tmr_interval) },
|
{ LSTRKEY( "interval" ), LFUNCVAL( tmr_interval) },
|
||||||
#if LUA_OPTIMIZE_MEMORY > 0
|
|
||||||
{ LSTRKEY( "ALARM_SINGLE" ), LNUMVAL( TIMER_MODE_SINGLE ) },
|
{ LSTRKEY( "ALARM_SINGLE" ), LNUMVAL( TIMER_MODE_SINGLE ) },
|
||||||
{ LSTRKEY( "ALARM_SEMI" ), LNUMVAL( TIMER_MODE_SEMI ) },
|
{ LSTRKEY( "ALARM_SEMI" ), LNUMVAL( TIMER_MODE_SEMI ) },
|
||||||
{ LSTRKEY( "ALARM_AUTO" ), LNUMVAL( TIMER_MODE_AUTO ) },
|
{ LSTRKEY( "ALARM_AUTO" ), LNUMVAL( TIMER_MODE_AUTO ) },
|
||||||
#endif
|
|
||||||
{ LNILKEY, LNILVAL }
|
{ LNILKEY, LNILVAL }
|
||||||
};
|
};
|
||||||
|
|
||||||
LUALIB_API int luaopen_tmr( lua_State *L ){
|
int luaopen_tmr( lua_State *L ){
|
||||||
int i;
|
int i;
|
||||||
for(i=0; i<NUM_TMR; i++){
|
for(i=0; i<NUM_TMR; i++){
|
||||||
alarm_timers[i].lua_ref = LUA_NOREF;
|
alarm_timers[i].lua_ref = LUA_NOREF;
|
||||||
@ -343,17 +336,7 @@ LUALIB_API int luaopen_tmr( lua_State *L ){
|
|||||||
ets_timer_disarm(&rtc_timer);
|
ets_timer_disarm(&rtc_timer);
|
||||||
ets_timer_setfn(&rtc_timer, rtc_callback, NULL);
|
ets_timer_setfn(&rtc_timer, rtc_callback, NULL);
|
||||||
ets_timer_arm_new(&rtc_timer, 1000, 1, 1);
|
ets_timer_arm_new(&rtc_timer, 1000, 1, 1);
|
||||||
|
return 0;
|
||||||
#if LUA_OPTIMIZE_MEMORY > 0
|
|
||||||
return 0;
|
|
||||||
#else
|
|
||||||
luaL_register( L, AUXLIB_TMR, tmr_map );
|
|
||||||
lua_pushvalue( L, -1 );
|
|
||||||
lua_setmetatable( L, -2 );
|
|
||||||
MOD_REG_NUMBER( L, "ALARM_SINGLE", TIMER_MODE_SINGLE );
|
|
||||||
MOD_REG_NUMBER( L, "ALARM_SEMI", TIMER_MODE_SEMI );
|
|
||||||
MOD_REG_NUMBER( L, "ALARM_AUTO", TIMER_MODE_AUTO );
|
|
||||||
return 1;
|
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
NODEMCU_MODULE(TMR, "tmr", tmr_map, luaopen_tmr);
|
||||||
|
@ -4,11 +4,9 @@
|
|||||||
* Created on: Aug 21, 2015
|
* Created on: Aug 21, 2015
|
||||||
* Author: Michael Lucas (Aeprox @github)
|
* Author: Michael Lucas (Aeprox @github)
|
||||||
*/
|
*/
|
||||||
#include "lualib.h"
|
#include "module.h"
|
||||||
#include "lauxlib.h"
|
#include "lauxlib.h"
|
||||||
#include "platform.h"
|
#include "platform.h"
|
||||||
#include "auxmods.h"
|
|
||||||
#include "lrotable.h"
|
|
||||||
#include "../tsl2561/tsl2561.h"
|
#include "../tsl2561/tsl2561.h"
|
||||||
|
|
||||||
static uint16_t ch0;
|
static uint16_t ch0;
|
||||||
@ -102,38 +100,28 @@ static int ICACHE_FLASH_ATTR tsl2561_lua_getchannels(lua_State* L) {
|
|||||||
return 3;
|
return 3;
|
||||||
}
|
}
|
||||||
|
|
||||||
#define MIN_OPT_LEVEL 2
|
// Module function map
|
||||||
#include "lrodefs.h"
|
static const LUA_REG_TYPE tsl2561_map[] = {
|
||||||
const LUA_REG_TYPE tsl2561_map[] =
|
{ LSTRKEY( "settiming" ), LFUNCVAL( tsl2561_lua_settiming)},
|
||||||
{
|
{ LSTRKEY( "getlux" ), LFUNCVAL( tsl2561_lua_calclux )},
|
||||||
{ LSTRKEY( "settiming" ), LFUNCVAL( tsl2561_lua_settiming)},
|
{ LSTRKEY( "getrawchannels" ), LFUNCVAL( tsl2561_lua_getchannels )},
|
||||||
{ LSTRKEY( "getlux" ), LFUNCVAL( tsl2561_lua_calclux )},
|
{ LSTRKEY( "init" ), LFUNCVAL( tsl2561_init )},
|
||||||
{ LSTRKEY( "getrawchannels" ), LFUNCVAL( tsl2561_lua_getchannels )},
|
{ LSTRKEY( "TSL2561_OK" ), LNUMVAL( TSL2561_ERROR_OK )},
|
||||||
{ LSTRKEY( "init" ), LFUNCVAL( tsl2561_init )},
|
|
||||||
|
|
||||||
{ LSTRKEY( "TSL2561_OK" ), LNUMVAL( TSL2561_ERROR_OK )},
|
|
||||||
{ LSTRKEY( "TSL2561_ERROR_I2CINIT" ), LNUMVAL( TSL2561_ERROR_I2CINIT )},
|
{ LSTRKEY( "TSL2561_ERROR_I2CINIT" ), LNUMVAL( TSL2561_ERROR_I2CINIT )},
|
||||||
{ LSTRKEY( "TSL2561_ERROR_I2CBUSY" ), LNUMVAL( TSL2561_ERROR_I2CBUSY )},
|
{ LSTRKEY( "TSL2561_ERROR_I2CBUSY" ), LNUMVAL( TSL2561_ERROR_I2CBUSY )},
|
||||||
{ LSTRKEY( "TSL2561_ERROR_NOINIT" ), LNUMVAL( TSL2561_ERROR_NOINIT )},
|
{ LSTRKEY( "TSL2561_ERROR_NOINIT" ), LNUMVAL( TSL2561_ERROR_NOINIT )},
|
||||||
{ LSTRKEY( "TSL2561_ERROR_LAST" ), LNUMVAL( TSL2561_ERROR_LAST )},
|
{ LSTRKEY( "TSL2561_ERROR_LAST" ), LNUMVAL( TSL2561_ERROR_LAST )},
|
||||||
|
{ LSTRKEY( "INTEGRATIONTIME_13MS" ), LNUMVAL( TSL2561_INTEGRATIONTIME_13MS )},
|
||||||
{ LSTRKEY( "INTEGRATIONTIME_13MS" ), LNUMVAL( TSL2561_INTEGRATIONTIME_13MS )},
|
|
||||||
{ LSTRKEY( "INTEGRATIONTIME_101MS" ), LNUMVAL( TSL2561_INTEGRATIONTIME_101MS )},
|
{ LSTRKEY( "INTEGRATIONTIME_101MS" ), LNUMVAL( TSL2561_INTEGRATIONTIME_101MS )},
|
||||||
{ LSTRKEY( "INTEGRATIONTIME_402MS" ), LNUMVAL( TSL2561_INTEGRATIONTIME_402MS )},
|
{ LSTRKEY( "INTEGRATIONTIME_402MS" ), LNUMVAL( TSL2561_INTEGRATIONTIME_402MS )},
|
||||||
{ LSTRKEY( "GAIN_1X" ), LNUMVAL( TSL2561_GAIN_1X )},
|
{ LSTRKEY( "GAIN_1X" ), LNUMVAL( TSL2561_GAIN_1X )},
|
||||||
{ LSTRKEY( "GAIN_16X" ), LNUMVAL( TSL2561_GAIN_16X )},
|
{ LSTRKEY( "GAIN_16X" ), LNUMVAL( TSL2561_GAIN_16X )},
|
||||||
|
{ LSTRKEY( "PACKAGE_CS" ), LNUMVAL( TSL2561_PACKAGE_CS )},
|
||||||
{ LSTRKEY( "PACKAGE_CS" ), LNUMVAL( TSL2561_PACKAGE_CS )},
|
{ LSTRKEY( "PACKAGE_T_FN_CL" ), LNUMVAL( TSL2561_PACKAGE_T_FN_CL )},
|
||||||
{ LSTRKEY( "PACKAGE_T_FN_CL" ), LNUMVAL( TSL2561_PACKAGE_T_FN_CL )},
|
{ LSTRKEY( "ADDRESS_GND" ), LNUMVAL( TSL2561_ADDRESS_GND )},
|
||||||
|
{ LSTRKEY( "ADDRESS_FLOAT" ), LNUMVAL( TSL2561_ADDRESS_FLOAT )},
|
||||||
{ LSTRKEY( "ADDRESS_GND" ), LNUMVAL( TSL2561_ADDRESS_GND )},
|
{ LSTRKEY( "ADDRESS_VDD" ), LNUMVAL( TSL2561_ADDRESS_VDD )},
|
||||||
{ LSTRKEY( "ADDRESS_FLOAT" ), LNUMVAL( TSL2561_ADDRESS_FLOAT )},
|
|
||||||
{ LSTRKEY( "ADDRESS_VDD" ), LNUMVAL( TSL2561_ADDRESS_VDD )},
|
|
||||||
|
|
||||||
{ LNILKEY, LNILVAL}
|
{ LNILKEY, LNILVAL}
|
||||||
};
|
};
|
||||||
|
|
||||||
LUALIB_API int luaopen_tsl2561(lua_State *L) {
|
NODEMCU_MODULE(TSL2561, "tsl2561", tsl2561_map, NULL);
|
||||||
LREGISTER(L, "tsl2561", tsl2561_map);
|
|
||||||
return 1;
|
|
||||||
}
|
|
||||||
|
@ -1,10 +1,8 @@
|
|||||||
// Module for U8glib
|
// Module for U8glib
|
||||||
|
|
||||||
#include "lualib.h"
|
#include "module.h"
|
||||||
#include "lauxlib.h"
|
#include "lauxlib.h"
|
||||||
#include "platform.h"
|
#include "platform.h"
|
||||||
#include "auxmods.h"
|
|
||||||
#include "lrotable.h"
|
|
||||||
|
|
||||||
#include "c_stdlib.h"
|
#include "c_stdlib.h"
|
||||||
|
|
||||||
@ -1027,138 +1025,90 @@ U8G_DISPLAY_TABLE_SPI
|
|||||||
|
|
||||||
|
|
||||||
// Module function map
|
// Module function map
|
||||||
#define MIN_OPT_LEVEL 2
|
static const LUA_REG_TYPE lu8g_display_map[] = {
|
||||||
#include "lrodefs.h"
|
{ LSTRKEY( "begin" ), LFUNCVAL( lu8g_begin ) },
|
||||||
|
{ LSTRKEY( "drawBitmap" ), LFUNCVAL( lu8g_drawBitmap ) },
|
||||||
static const LUA_REG_TYPE lu8g_display_map[] =
|
{ LSTRKEY( "drawBox" ), LFUNCVAL( lu8g_drawBox ) },
|
||||||
{
|
{ LSTRKEY( "drawCircle" ), LFUNCVAL( lu8g_drawCircle ) },
|
||||||
{ LSTRKEY( "begin" ), LFUNCVAL( lu8g_begin ) },
|
{ LSTRKEY( "drawDisc" ), LFUNCVAL( lu8g_drawDisc ) },
|
||||||
{ LSTRKEY( "drawBitmap" ), LFUNCVAL( lu8g_drawBitmap ) },
|
{ LSTRKEY( "drawEllipse" ), LFUNCVAL( lu8g_drawEllipse ) },
|
||||||
{ LSTRKEY( "drawBox" ), LFUNCVAL( lu8g_drawBox ) },
|
{ LSTRKEY( "drawFilledEllipse" ), LFUNCVAL( lu8g_drawFilledEllipse ) },
|
||||||
{ LSTRKEY( "drawCircle" ), LFUNCVAL( lu8g_drawCircle ) },
|
{ LSTRKEY( "drawFrame" ), LFUNCVAL( lu8g_drawFrame ) },
|
||||||
{ LSTRKEY( "drawDisc" ), LFUNCVAL( lu8g_drawDisc ) },
|
{ LSTRKEY( "drawHLine" ), LFUNCVAL( lu8g_drawHLine ) },
|
||||||
{ LSTRKEY( "drawEllipse" ), LFUNCVAL( lu8g_drawEllipse ) },
|
{ LSTRKEY( "drawLine" ), LFUNCVAL( lu8g_drawLine ) },
|
||||||
{ LSTRKEY( "drawFilledEllipse" ), LFUNCVAL( lu8g_drawFilledEllipse ) },
|
{ LSTRKEY( "drawPixel" ), LFUNCVAL( lu8g_drawPixel ) },
|
||||||
{ LSTRKEY( "drawFrame" ), LFUNCVAL( lu8g_drawFrame ) },
|
{ LSTRKEY( "drawRBox" ), LFUNCVAL( lu8g_drawRBox ) },
|
||||||
{ LSTRKEY( "drawHLine" ), LFUNCVAL( lu8g_drawHLine ) },
|
{ LSTRKEY( "drawRFrame" ), LFUNCVAL( lu8g_drawRFrame ) },
|
||||||
{ LSTRKEY( "drawLine" ), LFUNCVAL( lu8g_drawLine ) },
|
{ LSTRKEY( "drawStr" ), LFUNCVAL( lu8g_drawStr ) },
|
||||||
{ LSTRKEY( "drawPixel" ), LFUNCVAL( lu8g_drawPixel ) },
|
{ LSTRKEY( "drawStr90" ), LFUNCVAL( lu8g_drawStr90 ) },
|
||||||
{ LSTRKEY( "drawRBox" ), LFUNCVAL( lu8g_drawRBox ) },
|
{ LSTRKEY( "drawStr180" ), LFUNCVAL( lu8g_drawStr180 ) },
|
||||||
{ LSTRKEY( "drawRFrame" ), LFUNCVAL( lu8g_drawRFrame ) },
|
{ LSTRKEY( "drawStr270" ), LFUNCVAL( lu8g_drawStr270 ) },
|
||||||
{ LSTRKEY( "drawStr" ), LFUNCVAL( lu8g_drawStr ) },
|
{ LSTRKEY( "drawTriangle" ), LFUNCVAL( lu8g_drawTriangle ) },
|
||||||
{ LSTRKEY( "drawStr90" ), LFUNCVAL( lu8g_drawStr90 ) },
|
{ LSTRKEY( "drawVLine" ), LFUNCVAL( lu8g_drawVLine ) },
|
||||||
{ LSTRKEY( "drawStr180" ), LFUNCVAL( lu8g_drawStr180 ) },
|
{ LSTRKEY( "drawXBM" ), LFUNCVAL( lu8g_drawXBM ) },
|
||||||
{ LSTRKEY( "drawStr270" ), LFUNCVAL( lu8g_drawStr270 ) },
|
{ LSTRKEY( "firstPage" ), LFUNCVAL( lu8g_firstPage ) },
|
||||||
{ LSTRKEY( "drawTriangle" ), LFUNCVAL( lu8g_drawTriangle ) },
|
{ LSTRKEY( "getColorIndex" ), LFUNCVAL( lu8g_getColorIndex ) },
|
||||||
{ LSTRKEY( "drawVLine" ), LFUNCVAL( lu8g_drawVLine ) },
|
{ LSTRKEY( "getFontAscent" ), LFUNCVAL( lu8g_getFontAscent ) },
|
||||||
{ LSTRKEY( "drawXBM" ), LFUNCVAL( lu8g_drawXBM ) },
|
{ LSTRKEY( "getFontDescent" ), LFUNCVAL( lu8g_getFontDescent ) },
|
||||||
{ LSTRKEY( "firstPage" ), LFUNCVAL( lu8g_firstPage ) },
|
{ LSTRKEY( "getFontLineSpacing" ), LFUNCVAL( lu8g_getFontLineSpacing ) },
|
||||||
{ LSTRKEY( "getColorIndex" ), LFUNCVAL( lu8g_getColorIndex ) },
|
{ LSTRKEY( "getHeight" ), LFUNCVAL( lu8g_getHeight ) },
|
||||||
{ LSTRKEY( "getFontAscent" ), LFUNCVAL( lu8g_getFontAscent ) },
|
{ LSTRKEY( "getMode" ), LFUNCVAL( lu8g_getMode ) },
|
||||||
{ LSTRKEY( "getFontDescent" ), LFUNCVAL( lu8g_getFontDescent ) },
|
{ LSTRKEY( "getStrWidth" ), LFUNCVAL( lu8g_getStrWidth ) },
|
||||||
{ LSTRKEY( "getFontLineSpacing" ), LFUNCVAL( lu8g_getFontLineSpacing ) },
|
{ LSTRKEY( "getWidth" ), LFUNCVAL( lu8g_getWidth ) },
|
||||||
{ LSTRKEY( "getHeight" ), LFUNCVAL( lu8g_getHeight ) },
|
{ LSTRKEY( "nextPage" ), LFUNCVAL( lu8g_nextPage ) },
|
||||||
{ LSTRKEY( "getMode" ), LFUNCVAL( lu8g_getMode ) },
|
{ LSTRKEY( "setColorIndex" ), LFUNCVAL( lu8g_setColorIndex ) },
|
||||||
{ LSTRKEY( "getStrWidth" ), LFUNCVAL( lu8g_getStrWidth ) },
|
{ LSTRKEY( "setDefaultBackgroundColor" ), LFUNCVAL( lu8g_setDefaultBackgroundColor ) },
|
||||||
{ LSTRKEY( "getWidth" ), LFUNCVAL( lu8g_getWidth ) },
|
{ LSTRKEY( "setDefaultForegroundColor" ), LFUNCVAL( lu8g_setDefaultForegroundColor ) },
|
||||||
{ LSTRKEY( "nextPage" ), LFUNCVAL( lu8g_nextPage ) },
|
{ LSTRKEY( "setFont" ), LFUNCVAL( lu8g_setFont ) },
|
||||||
{ LSTRKEY( "setColorIndex" ), LFUNCVAL( lu8g_setColorIndex ) },
|
{ LSTRKEY( "setFontLineSpacingFactor" ), LFUNCVAL( lu8g_setFontLineSpacingFactor ) },
|
||||||
{ LSTRKEY( "setDefaultBackgroundColor" ), LFUNCVAL( lu8g_setDefaultBackgroundColor ) },
|
{ LSTRKEY( "setFontPosBaseline" ), LFUNCVAL( lu8g_setFontPosBaseline ) },
|
||||||
{ LSTRKEY( "setDefaultForegroundColor" ), LFUNCVAL( lu8g_setDefaultForegroundColor ) },
|
{ LSTRKEY( "setFontPosBottom" ), LFUNCVAL( lu8g_setFontPosBottom ) },
|
||||||
{ LSTRKEY( "setFont" ), LFUNCVAL( lu8g_setFont ) },
|
{ LSTRKEY( "setFontPosCenter" ), LFUNCVAL( lu8g_setFontPosCenter ) },
|
||||||
{ LSTRKEY( "setFontLineSpacingFactor" ), LFUNCVAL( lu8g_setFontLineSpacingFactor ) },
|
{ LSTRKEY( "setFontPosTop" ), LFUNCVAL( lu8g_setFontPosTop ) },
|
||||||
{ LSTRKEY( "setFontPosBaseline" ), LFUNCVAL( lu8g_setFontPosBaseline ) },
|
{ LSTRKEY( "setFontRefHeightAll" ), LFUNCVAL( lu8g_setFontRefHeightAll ) },
|
||||||
{ LSTRKEY( "setFontPosBottom" ), LFUNCVAL( lu8g_setFontPosBottom ) },
|
{ LSTRKEY( "setFontRefHeightExtendedText" ), LFUNCVAL( lu8g_setFontRefHeightExtendedText ) },
|
||||||
{ LSTRKEY( "setFontPosCenter" ), LFUNCVAL( lu8g_setFontPosCenter ) },
|
{ LSTRKEY( "setFontRefHeightText" ), LFUNCVAL( lu8g_setFontRefHeightText ) },
|
||||||
{ LSTRKEY( "setFontPosTop" ), LFUNCVAL( lu8g_setFontPosTop ) },
|
{ LSTRKEY( "setRot90" ), LFUNCVAL( lu8g_setRot90 ) },
|
||||||
{ LSTRKEY( "setFontRefHeightAll" ), LFUNCVAL( lu8g_setFontRefHeightAll ) },
|
{ LSTRKEY( "setRot180" ), LFUNCVAL( lu8g_setRot180 ) },
|
||||||
{ LSTRKEY( "setFontRefHeightExtendedText" ), LFUNCVAL( lu8g_setFontRefHeightExtendedText ) },
|
{ LSTRKEY( "setRot270" ), LFUNCVAL( lu8g_setRot270 ) },
|
||||||
{ LSTRKEY( "setFontRefHeightText" ), LFUNCVAL( lu8g_setFontRefHeightText ) },
|
{ LSTRKEY( "setScale2x2" ), LFUNCVAL( lu8g_setScale2x2 ) },
|
||||||
{ LSTRKEY( "setRot90" ), LFUNCVAL( lu8g_setRot90 ) },
|
{ LSTRKEY( "sleepOff" ), LFUNCVAL( lu8g_sleepOff ) },
|
||||||
{ LSTRKEY( "setRot180" ), LFUNCVAL( lu8g_setRot180 ) },
|
{ LSTRKEY( "sleepOn" ), LFUNCVAL( lu8g_sleepOn ) },
|
||||||
{ LSTRKEY( "setRot270" ), LFUNCVAL( lu8g_setRot270 ) },
|
{ LSTRKEY( "undoRotation" ), LFUNCVAL( lu8g_undoRotation ) },
|
||||||
{ LSTRKEY( "setScale2x2" ), LFUNCVAL( lu8g_setScale2x2 ) },
|
{ LSTRKEY( "undoScale" ), LFUNCVAL( lu8g_undoScale ) },
|
||||||
{ LSTRKEY( "sleepOff" ), LFUNCVAL( lu8g_sleepOff ) },
|
{ LSTRKEY( "__gc" ), LFUNCVAL( lu8g_close_display ) },
|
||||||
{ LSTRKEY( "sleepOn" ), LFUNCVAL( lu8g_sleepOn ) },
|
{ LSTRKEY( "__index" ), LROVAL( lu8g_display_map ) },
|
||||||
{ LSTRKEY( "undoRotation" ), LFUNCVAL( lu8g_undoRotation ) },
|
{ LNILKEY, LNILVAL }
|
||||||
{ LSTRKEY( "undoScale" ), LFUNCVAL( lu8g_undoScale ) },
|
|
||||||
{ LSTRKEY( "__gc" ), LFUNCVAL( lu8g_close_display ) },
|
|
||||||
#if LUA_OPTIMIZE_MEMORY > 0
|
|
||||||
{ LSTRKEY( "__index" ), LROVAL ( lu8g_display_map ) },
|
|
||||||
#endif
|
|
||||||
{ LNILKEY, LNILVAL }
|
|
||||||
};
|
};
|
||||||
|
|
||||||
const LUA_REG_TYPE lu8g_map[] =
|
|
||||||
{
|
|
||||||
#undef U8G_DISPLAY_TABLE_ENTRY
|
#undef U8G_DISPLAY_TABLE_ENTRY
|
||||||
#define U8G_DISPLAY_TABLE_ENTRY(device) { LSTRKEY( #device ), LFUNCVAL ( lu8g_ ##device ) },
|
|
||||||
U8G_DISPLAY_TABLE_I2C
|
|
||||||
U8G_DISPLAY_TABLE_SPI
|
|
||||||
|
|
||||||
#if LUA_OPTIMIZE_MEMORY > 0
|
|
||||||
|
|
||||||
// Register fonts
|
|
||||||
#undef U8G_FONT_TABLE_ENTRY
|
#undef U8G_FONT_TABLE_ENTRY
|
||||||
#define U8G_FONT_TABLE_ENTRY(font) { LSTRKEY( #font ), LUDATA( (void *)(u8g_ ## font) ) },
|
|
||||||
U8G_FONT_TABLE
|
|
||||||
|
|
||||||
// Options for circle/ ellipse drawing
|
static const LUA_REG_TYPE lu8g_map[] = {
|
||||||
{ LSTRKEY( "DRAW_UPPER_RIGHT" ), LNUMVAL( U8G_DRAW_UPPER_RIGHT ) },
|
#define U8G_DISPLAY_TABLE_ENTRY(device) \
|
||||||
{ LSTRKEY( "DRAW_UPPER_LEFT" ), LNUMVAL( U8G_DRAW_UPPER_LEFT ) },
|
{ LSTRKEY( #device ), LFUNCVAL ( lu8g_ ##device ) },
|
||||||
{ LSTRKEY( "DRAW_LOWER_RIGHT" ), LNUMVAL( U8G_DRAW_LOWER_RIGHT ) },
|
U8G_DISPLAY_TABLE_I2C
|
||||||
{ LSTRKEY( "DRAW_LOWER_LEFT" ), LNUMVAL( U8G_DRAW_LOWER_LEFT ) },
|
U8G_DISPLAY_TABLE_SPI
|
||||||
{ LSTRKEY( "DRAW_ALL" ), LNUMVAL( U8G_DRAW_ALL ) },
|
// Register fonts
|
||||||
|
#define U8G_FONT_TABLE_ENTRY(font) \
|
||||||
// Display modes
|
{ LSTRKEY( #font ), LUDATA( (void *)(u8g_ ## font) ) },
|
||||||
{ LSTRKEY( "MODE_BW" ), LNUMVAL( U8G_MODE_BW ) },
|
U8G_FONT_TABLE
|
||||||
{ LSTRKEY( "MODE_GRAY2BIT" ), LNUMVAL( U8G_MODE_GRAY2BIT ) },
|
// Options for circle/ ellipse drawing
|
||||||
|
{ LSTRKEY( "DRAW_UPPER_RIGHT" ), LNUMVAL( U8G_DRAW_UPPER_RIGHT ) },
|
||||||
{ LSTRKEY( "__metatable" ), LROVAL( lu8g_map ) },
|
{ LSTRKEY( "DRAW_UPPER_LEFT" ), LNUMVAL( U8G_DRAW_UPPER_LEFT ) },
|
||||||
#endif
|
{ LSTRKEY( "DRAW_LOWER_RIGHT" ), LNUMVAL( U8G_DRAW_LOWER_RIGHT ) },
|
||||||
{ LNILKEY, LNILVAL }
|
{ LSTRKEY( "DRAW_LOWER_LEFT" ), LNUMVAL( U8G_DRAW_LOWER_LEFT ) },
|
||||||
|
{ LSTRKEY( "DRAW_ALL" ), LNUMVAL( U8G_DRAW_ALL ) },
|
||||||
|
// Display modes
|
||||||
|
{ LSTRKEY( "MODE_BW" ), LNUMVAL( U8G_MODE_BW ) },
|
||||||
|
{ LSTRKEY( "MODE_GRAY2BIT" ), LNUMVAL( U8G_MODE_GRAY2BIT ) },
|
||||||
|
{ LSTRKEY( "__metatable" ), LROVAL( lu8g_map ) },
|
||||||
|
{ LNILKEY, LNILVAL }
|
||||||
};
|
};
|
||||||
|
|
||||||
LUALIB_API int luaopen_u8g( lua_State *L )
|
int luaopen_u8g( lua_State *L ) {
|
||||||
{
|
luaL_rometatable(L, "u8g.display", (void *)lu8g_display_map); // create metatable
|
||||||
#if LUA_OPTIMIZE_MEMORY > 0
|
return 0;
|
||||||
luaL_rometatable(L, "u8g.display", (void *)lu8g_display_map); // create metatable
|
|
||||||
return 0;
|
|
||||||
#else // #if LUA_OPTIMIZE_MEMORY > 0
|
|
||||||
int n;
|
|
||||||
luaL_register( L, AUXLIB_U8G, lu8g_map );
|
|
||||||
|
|
||||||
// Set it as its own metatable
|
|
||||||
lua_pushvalue( L, -1 );
|
|
||||||
lua_setmetatable( L, -2 );
|
|
||||||
|
|
||||||
// Module constants
|
|
||||||
|
|
||||||
// Register fonts
|
|
||||||
#undef U8G_FONT_TABLE_ENTRY
|
|
||||||
#define U8G_FONT_TABLE_ENTRY(font) MOD_REG_LUDATA( L, #font, (void *)(u8g_ ## font) );
|
|
||||||
U8G_FONT_TABLE
|
|
||||||
|
|
||||||
// Options for circle/ ellipse drawing
|
|
||||||
MOD_REG_NUMBER( L, "DRAW_UPPER_RIGHT", U8G_DRAW_UPPER_RIGHT );
|
|
||||||
MOD_REG_NUMBER( L, "DRAW_UPPER_LEFT", U8G_DRAW_UPPER_LEFT );
|
|
||||||
MOD_REG_NUMBER( L, "DRAW_LOWER_RIGHT", U8G_DRAW_LOWER_RIGHT );
|
|
||||||
MOD_REG_NUMBER( L, "DRAW_LOWER_LEFT", U8G_DRAW_LOWER_LEFT );
|
|
||||||
MOD_REG_NUMBER( L, "DRAW_ALL", U8G_DRAW_ALL );
|
|
||||||
|
|
||||||
// Display modes
|
|
||||||
MOD_REG_NUMBER( L, "MODE_BW", U8G_MODE_BW );
|
|
||||||
MOD_REG_NUMBER( L, "MODE_GRAY2BIT", U8G_MODE_GRAY2BIT );
|
|
||||||
|
|
||||||
// create metatable
|
|
||||||
luaL_newmetatable(L, "u8g.display");
|
|
||||||
// metatable.__index = metatable
|
|
||||||
lua_pushliteral(L, "__index");
|
|
||||||
lua_pushvalue(L,-2);
|
|
||||||
lua_rawset(L,-3);
|
|
||||||
// Setup the methods inside metatable
|
|
||||||
luaL_register( L, NULL, u8g_display_map );
|
|
||||||
|
|
||||||
return 1;
|
|
||||||
#endif // #if LUA_OPTIMIZE_MEMORY > 0
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
NODEMCU_MODULE(U8G, "u8g", lu8g_map, luaopen_u8g);
|
||||||
|
@ -1,11 +1,8 @@
|
|||||||
// Module for interfacing with serial
|
// Module for interfacing with serial
|
||||||
|
|
||||||
//#include "lua.h"
|
#include "module.h"
|
||||||
#include "lualib.h"
|
|
||||||
#include "lauxlib.h"
|
#include "lauxlib.h"
|
||||||
#include "platform.h"
|
#include "platform.h"
|
||||||
#include "auxmods.h"
|
|
||||||
#include "lrotable.h"
|
|
||||||
|
|
||||||
#include "c_types.h"
|
#include "c_types.h"
|
||||||
#include "c_string.h"
|
#include "c_string.h"
|
||||||
@ -158,29 +155,18 @@ static int uart_write( lua_State* L )
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Module function map
|
// Module function map
|
||||||
#define MIN_OPT_LEVEL 2
|
static const LUA_REG_TYPE uart_map[] = {
|
||||||
#include "lrodefs.h"
|
{ LSTRKEY( "setup" ), LFUNCVAL( uart_setup ) },
|
||||||
const LUA_REG_TYPE uart_map[] =
|
|
||||||
{
|
|
||||||
{ LSTRKEY( "setup" ), LFUNCVAL( uart_setup ) },
|
|
||||||
{ LSTRKEY( "write" ), LFUNCVAL( uart_write ) },
|
{ LSTRKEY( "write" ), LFUNCVAL( uart_write ) },
|
||||||
{ LSTRKEY( "on" ), LFUNCVAL( uart_on ) },
|
{ LSTRKEY( "on" ), LFUNCVAL( uart_on ) },
|
||||||
{ LSTRKEY( "alt" ), LFUNCVAL( uart_alt ) },
|
{ LSTRKEY( "alt" ), LFUNCVAL( uart_alt ) },
|
||||||
|
{ LSTRKEY( "STOPBITS_1" ), LNUMVAL( PLATFORM_UART_STOPBITS_1 ) },
|
||||||
#if LUA_OPTIMIZE_MEMORY > 0
|
{ LSTRKEY( "STOPBITS_1_5" ), LNUMVAL( PLATFORM_UART_STOPBITS_1_5 ) },
|
||||||
|
{ LSTRKEY( "STOPBITS_2" ), LNUMVAL( PLATFORM_UART_STOPBITS_2 ) },
|
||||||
#endif
|
{ LSTRKEY( "PARITY_NONE" ), LNUMVAL( PLATFORM_UART_PARITY_NONE ) },
|
||||||
|
{ LSTRKEY( "PARITY_EVEN" ), LNUMVAL( PLATFORM_UART_PARITY_EVEN ) },
|
||||||
|
{ LSTRKEY( "PARITY_ODD" ), LNUMVAL( PLATFORM_UART_PARITY_ODD ) },
|
||||||
{ LNILKEY, LNILVAL }
|
{ LNILKEY, LNILVAL }
|
||||||
};
|
};
|
||||||
|
|
||||||
LUALIB_API int luaopen_uart( lua_State *L )
|
NODEMCU_MODULE(UART, "uart", uart_map, NULL);
|
||||||
{
|
|
||||||
#if LUA_OPTIMIZE_MEMORY > 0
|
|
||||||
return 0;
|
|
||||||
#else // #if LUA_OPTIMIZE_MEMORY > 0
|
|
||||||
luaL_register( L, AUXLIB_UART, uart_map );
|
|
||||||
// Add constants
|
|
||||||
|
|
||||||
return 1;
|
|
||||||
#endif // #if LUA_OPTIMIZE_MEMORY > 0
|
|
||||||
}
|
|
||||||
|
@ -1,10 +1,8 @@
|
|||||||
// Module for Ucglib
|
// Module for Ucglib
|
||||||
|
|
||||||
#include "lualib.h"
|
#include "module.h"
|
||||||
#include "lauxlib.h"
|
#include "lauxlib.h"
|
||||||
#include "platform.h"
|
#include "platform.h"
|
||||||
#include "auxmods.h"
|
|
||||||
#include "lrotable.h"
|
|
||||||
|
|
||||||
#include "c_stdlib.h"
|
#include "c_stdlib.h"
|
||||||
|
|
||||||
@ -404,7 +402,7 @@ static int lucg_getHeight( lua_State *L )
|
|||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Lua: width = ucg.getStrWidth( self )
|
// Lua: width = ucg.getStrWidth( self, string )
|
||||||
static int lucg_getStrWidth( lua_State *L )
|
static int lucg_getStrWidth( lua_State *L )
|
||||||
{
|
{
|
||||||
lucg_userdata_t *lud;
|
lucg_userdata_t *lud;
|
||||||
@ -412,7 +410,7 @@ static int lucg_getStrWidth( lua_State *L )
|
|||||||
if ((lud = get_lud( L )) == NULL)
|
if ((lud = get_lud( L )) == NULL)
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
const char *s = luaL_checkstring( L, (1+3) + 1 );
|
const char *s = luaL_checkstring( L, 2 );
|
||||||
if (s == NULL)
|
if (s == NULL)
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
@ -876,9 +874,6 @@ UCG_DISPLAY_TABLE
|
|||||||
|
|
||||||
|
|
||||||
// Module function map
|
// Module function map
|
||||||
#define MIN_OPT_LEVEL 2
|
|
||||||
#include "lrodefs.h"
|
|
||||||
|
|
||||||
static const LUA_REG_TYPE lucg_display_map[] =
|
static const LUA_REG_TYPE lucg_display_map[] =
|
||||||
{
|
{
|
||||||
{ LSTRKEY( "begin" ), LFUNCVAL( lucg_begin ) },
|
{ LSTRKEY( "begin" ), LFUNCVAL( lucg_begin ) },
|
||||||
@ -926,20 +921,16 @@ static const LUA_REG_TYPE lucg_display_map[] =
|
|||||||
{ LSTRKEY( "undoScale" ), LFUNCVAL( lucg_undoScale ) },
|
{ LSTRKEY( "undoScale" ), LFUNCVAL( lucg_undoScale ) },
|
||||||
|
|
||||||
{ LSTRKEY( "__gc" ), LFUNCVAL( lucg_close_display ) },
|
{ LSTRKEY( "__gc" ), LFUNCVAL( lucg_close_display ) },
|
||||||
#if LUA_OPTIMIZE_MEMORY > 0
|
|
||||||
{ LSTRKEY( "__index" ), LROVAL ( lucg_display_map ) },
|
{ LSTRKEY( "__index" ), LROVAL ( lucg_display_map ) },
|
||||||
#endif
|
|
||||||
{ LNILKEY, LNILVAL }
|
{ LNILKEY, LNILVAL }
|
||||||
};
|
};
|
||||||
|
|
||||||
const LUA_REG_TYPE lucg_map[] =
|
static const LUA_REG_TYPE lucg_map[] =
|
||||||
{
|
{
|
||||||
#undef UCG_DISPLAY_TABLE_ENTRY
|
#undef UCG_DISPLAY_TABLE_ENTRY
|
||||||
#define UCG_DISPLAY_TABLE_ENTRY(binding, device, extension) { LSTRKEY( #binding ), LFUNCVAL ( lucg_ ##binding ) },
|
#define UCG_DISPLAY_TABLE_ENTRY(binding, device, extension) { LSTRKEY( #binding ), LFUNCVAL ( lucg_ ##binding ) },
|
||||||
UCG_DISPLAY_TABLE
|
UCG_DISPLAY_TABLE
|
||||||
|
|
||||||
#if LUA_OPTIMIZE_MEMORY > 0
|
|
||||||
|
|
||||||
// Register fonts
|
// Register fonts
|
||||||
#undef UCG_FONT_TABLE_ENTRY
|
#undef UCG_FONT_TABLE_ENTRY
|
||||||
#define UCG_FONT_TABLE_ENTRY(font) { LSTRKEY( #font ), LUDATA( (void *)(ucg_ ## font) ) },
|
#define UCG_FONT_TABLE_ENTRY(font) { LSTRKEY( #font ), LUDATA( (void *)(ucg_ ## font) ) },
|
||||||
@ -957,50 +948,13 @@ const LUA_REG_TYPE lucg_map[] =
|
|||||||
{ LSTRKEY( "DRAW_ALL" ), LNUMVAL( UCG_DRAW_ALL ) },
|
{ LSTRKEY( "DRAW_ALL" ), LNUMVAL( UCG_DRAW_ALL ) },
|
||||||
|
|
||||||
{ LSTRKEY( "__metatable" ), LROVAL( lucg_map ) },
|
{ LSTRKEY( "__metatable" ), LROVAL( lucg_map ) },
|
||||||
#endif
|
|
||||||
{ LNILKEY, LNILVAL }
|
{ LNILKEY, LNILVAL }
|
||||||
};
|
};
|
||||||
|
|
||||||
LUALIB_API int luaopen_ucg( lua_State *L )
|
int luaopen_ucg( lua_State *L )
|
||||||
{
|
{
|
||||||
#if LUA_OPTIMIZE_MEMORY > 0
|
|
||||||
luaL_rometatable(L, "ucg.display", (void *)lucg_display_map); // create metatable
|
luaL_rometatable(L, "ucg.display", (void *)lucg_display_map); // create metatable
|
||||||
return 0;
|
return 0;
|
||||||
#else // #if LUA_OPTIMIZE_MEMORY > 0
|
|
||||||
int n;
|
|
||||||
luaL_register( L, AUXLIB_UCG, lucg_map );
|
|
||||||
|
|
||||||
// Set it as its own metatable
|
|
||||||
lua_pushvalue( L, -1 );
|
|
||||||
lua_setmetatable( L, -2 );
|
|
||||||
|
|
||||||
// Module constants
|
|
||||||
|
|
||||||
// Register fonts
|
|
||||||
#undef UCG_FONT_TABLE_ENTRY
|
|
||||||
#define UCG_FONT_TABLE_ENTRY(font) MOD_REG_LUDATA( L, #font, (void *)(ucg_ ## font) );
|
|
||||||
UCG_FONT_TABLE
|
|
||||||
|
|
||||||
// Font modes
|
|
||||||
MOD_REG_NUMBER( L, "FONT_MODE_TRANSPARENT", UCG_FONT_MODE_TRANSPARENT );
|
|
||||||
MOD_REG_NUMBER( L, "FONT_MODE_SOLID", UCG_FONT_MODE_SOLID );
|
|
||||||
|
|
||||||
// Options for circle/ disc drawing
|
|
||||||
MOD_REG_NUMBER( L, "DRAW_UPPER_RIGHT", UCG_DRAW_UPPER_RIGHT );
|
|
||||||
MOD_REG_NUMBER( L, "DRAW_UPPER_LEFT", UCG_DRAW_UPPER_LEFT );
|
|
||||||
MOD_REG_NUMBER( L, "DRAW_LOWER_RIGHT", UCG_DRAW_LOWER_RIGHT );
|
|
||||||
MOD_REG_NUMBER( L, "DRAW_LOWER_LEFT", UCG_DRAW_LOWER_LEFT );
|
|
||||||
MOD_REG_NUMBER( L, "DRAW_ALL", UCG_DRAW_ALL );
|
|
||||||
|
|
||||||
// create metatable
|
|
||||||
luaL_newmetatable(L, "ucg.display");
|
|
||||||
// metatable.__index = metatable
|
|
||||||
lua_pushliteral(L, "__index");
|
|
||||||
lua_pushvalue(L,-2);
|
|
||||||
lua_rawset(L,-3);
|
|
||||||
// Setup the methods inside metatable
|
|
||||||
luaL_register( L, NULL, lucg_display_map );
|
|
||||||
|
|
||||||
return 1;
|
|
||||||
#endif // #if LUA_OPTIMIZE_MEMORY > 0
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
NODEMCU_MODULE(UCG, "ucg", lucg_map, luaopen_ucg);
|
||||||
|
@ -1,11 +1,8 @@
|
|||||||
// Module for interfacing with WIFI
|
// Module for interfacing with WIFI
|
||||||
|
|
||||||
//#include "lua.h"
|
#include "module.h"
|
||||||
#include "lualib.h"
|
|
||||||
#include "lauxlib.h"
|
#include "lauxlib.h"
|
||||||
#include "platform.h"
|
#include "platform.h"
|
||||||
#include "auxmods.h"
|
|
||||||
#include "lrotable.h"
|
|
||||||
|
|
||||||
#include "c_string.h"
|
#include "c_string.h"
|
||||||
#include "c_stdlib.h"
|
#include "c_stdlib.h"
|
||||||
@ -1340,148 +1337,88 @@ static int wifi_ap_dhcp_stop( lua_State* L )
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Module function map
|
// Module function map
|
||||||
#define MIN_OPT_LEVEL 2
|
static const LUA_REG_TYPE wifi_station_map[] = {
|
||||||
#include "lrodefs.h"
|
{ LSTRKEY( "getconfig" ), LFUNCVAL( wifi_station_getconfig ) },
|
||||||
static const LUA_REG_TYPE wifi_station_map[] =
|
{ LSTRKEY( "config" ), LFUNCVAL( wifi_station_config ) },
|
||||||
{
|
{ LSTRKEY( "connect" ), LFUNCVAL( wifi_station_connect4lua ) },
|
||||||
{ LSTRKEY( "getconfig" ), LFUNCVAL ( wifi_station_getconfig ) },
|
{ LSTRKEY( "disconnect" ), LFUNCVAL( wifi_station_disconnect4lua ) },
|
||||||
{ LSTRKEY( "config" ), LFUNCVAL ( wifi_station_config ) },
|
{ LSTRKEY( "autoconnect" ), LFUNCVAL( wifi_station_setauto ) },
|
||||||
{ LSTRKEY( "connect" ), LFUNCVAL ( wifi_station_connect4lua ) },
|
{ LSTRKEY( "getip" ), LFUNCVAL( wifi_station_getip ) },
|
||||||
{ LSTRKEY( "disconnect" ), LFUNCVAL ( wifi_station_disconnect4lua ) },
|
{ LSTRKEY( "setip" ), LFUNCVAL( wifi_station_setip ) },
|
||||||
{ LSTRKEY( "autoconnect" ), LFUNCVAL ( wifi_station_setauto ) },
|
{ LSTRKEY( "getbroadcast" ), LFUNCVAL( wifi_station_getbroadcast) },
|
||||||
{ LSTRKEY( "getip" ), LFUNCVAL ( wifi_station_getip ) },
|
{ LSTRKEY( "getmac" ), LFUNCVAL( wifi_station_getmac ) },
|
||||||
{ LSTRKEY( "setip" ), LFUNCVAL ( wifi_station_setip ) },
|
{ LSTRKEY( "setmac" ), LFUNCVAL( wifi_station_setmac ) },
|
||||||
{ LSTRKEY( "getbroadcast" ), LFUNCVAL ( wifi_station_getbroadcast) },
|
{ LSTRKEY( "getap" ), LFUNCVAL( wifi_station_listap ) },
|
||||||
{ LSTRKEY( "getmac" ), LFUNCVAL ( wifi_station_getmac ) },
|
{ LSTRKEY( "status" ), LFUNCVAL( wifi_station_status ) },
|
||||||
{ LSTRKEY( "setmac" ), LFUNCVAL ( wifi_station_setmac ) },
|
{ LSTRKEY( "eventMonReg" ), LFUNCVAL( wifi_station_event_mon_reg ) },
|
||||||
{ LSTRKEY( "getap" ), LFUNCVAL ( wifi_station_listap ) },
|
{ LSTRKEY( "eventMonStart" ), LFUNCVAL( wifi_station_event_mon_start ) },
|
||||||
{ LSTRKEY( "status" ), LFUNCVAL ( wifi_station_status ) },
|
{ LSTRKEY( "eventMonStop" ), LFUNCVAL( wifi_station_event_mon_stop ) },
|
||||||
{ LSTRKEY( "eventMonReg" ), LFUNCVAL ( wifi_station_event_mon_reg ) },
|
|
||||||
{ LSTRKEY( "eventMonStart" ), LFUNCVAL ( wifi_station_event_mon_start ) },
|
|
||||||
{ LSTRKEY( "eventMonStop" ), LFUNCVAL ( wifi_station_event_mon_stop ) },
|
|
||||||
{ LNILKEY, LNILVAL }
|
{ LNILKEY, LNILVAL }
|
||||||
};
|
};
|
||||||
|
|
||||||
static const LUA_REG_TYPE wifi_ap_dhcp_map[] =
|
static const LUA_REG_TYPE wifi_ap_dhcp_map[] = {
|
||||||
{
|
{ LSTRKEY( "config" ), LFUNCVAL( wifi_ap_dhcp_config ) },
|
||||||
{ LSTRKEY( "config" ), LFUNCVAL( wifi_ap_dhcp_config ) },
|
{ LSTRKEY( "start" ), LFUNCVAL( wifi_ap_dhcp_start ) },
|
||||||
{ LSTRKEY( "start" ), LFUNCVAL( wifi_ap_dhcp_start ) },
|
{ LSTRKEY( "stop" ), LFUNCVAL( wifi_ap_dhcp_stop ) },
|
||||||
{ LSTRKEY( "stop" ), LFUNCVAL( wifi_ap_dhcp_stop ) },
|
|
||||||
{ LNILKEY, LNILVAL }
|
{ LNILKEY, LNILVAL }
|
||||||
};
|
};
|
||||||
|
|
||||||
static const LUA_REG_TYPE wifi_ap_map[] =
|
static const LUA_REG_TYPE wifi_ap_map[] = {
|
||||||
{
|
{ LSTRKEY( "config" ), LFUNCVAL( wifi_ap_config ) },
|
||||||
{ LSTRKEY( "config" ), LFUNCVAL( wifi_ap_config ) },
|
{ LSTRKEY( "getip" ), LFUNCVAL( wifi_ap_getip ) },
|
||||||
{ LSTRKEY( "getip" ), LFUNCVAL ( wifi_ap_getip ) },
|
{ LSTRKEY( "setip" ), LFUNCVAL( wifi_ap_setip ) },
|
||||||
{ LSTRKEY( "setip" ), LFUNCVAL ( wifi_ap_setip ) },
|
{ LSTRKEY( "getbroadcast" ), LFUNCVAL( wifi_ap_getbroadcast) },
|
||||||
{ LSTRKEY( "getbroadcast" ), LFUNCVAL ( wifi_ap_getbroadcast) },
|
{ LSTRKEY( "getmac" ), LFUNCVAL( wifi_ap_getmac ) },
|
||||||
{ LSTRKEY( "getmac" ), LFUNCVAL ( wifi_ap_getmac ) },
|
{ LSTRKEY( "setmac" ), LFUNCVAL( wifi_ap_setmac ) },
|
||||||
{ LSTRKEY( "setmac" ), LFUNCVAL ( wifi_ap_setmac ) },
|
{ LSTRKEY( "getclient" ), LFUNCVAL( wifi_ap_listclient ) },
|
||||||
{ LSTRKEY( "getclient" ), LFUNCVAL ( wifi_ap_listclient ) },
|
{ LSTRKEY( "getconfig" ), LFUNCVAL( wifi_ap_getconfig ) },
|
||||||
{ LSTRKEY( "getconfig" ), LFUNCVAL( wifi_ap_getconfig ) },
|
{ LSTRKEY( "dhcp" ), LROVAL( wifi_ap_dhcp_map ) },
|
||||||
#if LUA_OPTIMIZE_MEMORY > 0
|
//{ LSTRKEY( "__metatable" ), LROVAL( wifi_ap_map ) },
|
||||||
{ LSTRKEY( "dhcp" ), LROVAL( wifi_ap_dhcp_map ) },
|
|
||||||
|
|
||||||
// { LSTRKEY( "__metatable" ), LROVAL( wifi_ap_map ) },
|
|
||||||
#endif
|
|
||||||
{ LNILKEY, LNILVAL }
|
{ LNILKEY, LNILVAL }
|
||||||
};
|
};
|
||||||
|
|
||||||
const LUA_REG_TYPE wifi_map[] =
|
static const LUA_REG_TYPE wifi_map[] = {
|
||||||
{
|
{ LSTRKEY( "setmode" ), LFUNCVAL( wifi_setmode ) },
|
||||||
{ LSTRKEY( "setmode" ), LFUNCVAL( wifi_setmode ) },
|
{ LSTRKEY( "getmode" ), LFUNCVAL( wifi_getmode ) },
|
||||||
{ LSTRKEY( "getmode" ), LFUNCVAL( wifi_getmode ) },
|
{ LSTRKEY( "getchannel" ), LFUNCVAL( wifi_getchannel ) },
|
||||||
{ LSTRKEY( "getchannel" ), LFUNCVAL( wifi_getchannel ) },
|
{ LSTRKEY( "setphymode" ), LFUNCVAL( wifi_setphymode ) },
|
||||||
{ LSTRKEY( "setphymode" ), LFUNCVAL( wifi_setphymode ) },
|
{ LSTRKEY( "getphymode" ), LFUNCVAL( wifi_getphymode ) },
|
||||||
{ LSTRKEY( "getphymode" ), LFUNCVAL( wifi_getphymode ) },
|
{ LSTRKEY( "sleep" ), LFUNCVAL( wifi_sleep ) },
|
||||||
{ LSTRKEY( "sleep" ), LFUNCVAL( wifi_sleep ) },
|
{ LSTRKEY( "startsmart" ), LFUNCVAL( wifi_start_smart ) },
|
||||||
{ LSTRKEY( "startsmart" ), LFUNCVAL( wifi_start_smart ) },
|
{ LSTRKEY( "stopsmart" ), LFUNCVAL( wifi_exit_smart ) },
|
||||||
{ LSTRKEY( "stopsmart" ), LFUNCVAL( wifi_exit_smart ) },
|
{ LSTRKEY( "sleeptype" ), LFUNCVAL( wifi_sleeptype ) },
|
||||||
{ LSTRKEY( "sleeptype" ), LFUNCVAL( wifi_sleeptype ) },
|
|
||||||
#if LUA_OPTIMIZE_MEMORY > 0
|
|
||||||
{ LSTRKEY( "sta" ), LROVAL( wifi_station_map ) },
|
|
||||||
{ LSTRKEY( "ap" ), LROVAL( wifi_ap_map ) },
|
|
||||||
|
|
||||||
{ LSTRKEY( "NULLMODE" ), LNUMVAL( NULL_MODE ) },
|
{ LSTRKEY( "sta" ), LROVAL( wifi_station_map ) },
|
||||||
{ LSTRKEY( "STATION" ), LNUMVAL( STATION_MODE ) },
|
{ LSTRKEY( "ap" ), LROVAL( wifi_ap_map ) },
|
||||||
{ LSTRKEY( "SOFTAP" ), LNUMVAL( SOFTAP_MODE ) },
|
|
||||||
{ LSTRKEY( "STATIONAP" ), LNUMVAL( STATIONAP_MODE ) },
|
|
||||||
|
|
||||||
{ LSTRKEY( "PHYMODE_B" ), LNUMVAL( PHY_MODE_11B ) },
|
{ LSTRKEY( "NULLMODE" ), LNUMVAL( NULL_MODE ) },
|
||||||
{ LSTRKEY( "PHYMODE_G" ), LNUMVAL( PHY_MODE_11G ) },
|
{ LSTRKEY( "STATION" ), LNUMVAL( STATION_MODE ) },
|
||||||
{ LSTRKEY( "PHYMODE_N" ), LNUMVAL( PHY_MODE_11N ) },
|
{ LSTRKEY( "SOFTAP" ), LNUMVAL( SOFTAP_MODE ) },
|
||||||
|
{ LSTRKEY( "STATIONAP" ), LNUMVAL( STATIONAP_MODE ) },
|
||||||
|
|
||||||
{ LSTRKEY( "NONE_SLEEP" ), LNUMVAL( NONE_SLEEP_T ) },
|
{ LSTRKEY( "PHYMODE_B" ), LNUMVAL( PHY_MODE_11B ) },
|
||||||
{ LSTRKEY( "LIGHT_SLEEP" ), LNUMVAL( LIGHT_SLEEP_T ) },
|
{ LSTRKEY( "PHYMODE_G" ), LNUMVAL( PHY_MODE_11G ) },
|
||||||
{ LSTRKEY( "MODEM_SLEEP" ), LNUMVAL( MODEM_SLEEP_T ) },
|
{ LSTRKEY( "PHYMODE_N" ), LNUMVAL( PHY_MODE_11N ) },
|
||||||
|
|
||||||
{ LSTRKEY( "OPEN" ), LNUMVAL( AUTH_OPEN ) },
|
{ LSTRKEY( "NONE_SLEEP" ), LNUMVAL( NONE_SLEEP_T ) },
|
||||||
// { LSTRKEY( "WEP" ), LNUMVAL( AUTH_WEP ) },
|
{ LSTRKEY( "LIGHT_SLEEP" ), LNUMVAL( LIGHT_SLEEP_T ) },
|
||||||
{ LSTRKEY( "WPA_PSK" ), LNUMVAL( AUTH_WPA_PSK ) },
|
{ LSTRKEY( "MODEM_SLEEP" ), LNUMVAL( MODEM_SLEEP_T ) },
|
||||||
{ LSTRKEY( "WPA2_PSK" ), LNUMVAL( AUTH_WPA2_PSK ) },
|
|
||||||
{ LSTRKEY( "WPA_WPA2_PSK" ), LNUMVAL( AUTH_WPA_WPA2_PSK ) },
|
|
||||||
|
|
||||||
{ LSTRKEY( "STA_IDLE" ), LNUMVAL( STATION_IDLE ) },
|
{ LSTRKEY( "OPEN" ), LNUMVAL( AUTH_OPEN ) },
|
||||||
{ LSTRKEY( "STA_CONNECTING" ), LNUMVAL( STATION_CONNECTING ) },
|
//{ LSTRKEY( "WEP" ), LNUMVAL( AUTH_WEP ) },
|
||||||
{ LSTRKEY( "STA_WRONGPWD" ), LNUMVAL( STATION_WRONG_PASSWORD ) },
|
{ LSTRKEY( "WPA_PSK" ), LNUMVAL( AUTH_WPA_PSK ) },
|
||||||
{ LSTRKEY( "STA_APNOTFOUND" ), LNUMVAL( STATION_NO_AP_FOUND ) },
|
{ LSTRKEY( "WPA2_PSK" ), LNUMVAL( AUTH_WPA2_PSK ) },
|
||||||
{ LSTRKEY( "STA_FAIL" ), LNUMVAL( STATION_CONNECT_FAIL ) },
|
{ LSTRKEY( "WPA_WPA2_PSK" ), LNUMVAL( AUTH_WPA_WPA2_PSK ) },
|
||||||
{ LSTRKEY( "STA_GOTIP" ), LNUMVAL( STATION_GOT_IP ) },
|
|
||||||
|
|
||||||
{ LSTRKEY( "__metatable" ), LROVAL( wifi_map ) },
|
{ LSTRKEY( "STA_IDLE" ), LNUMVAL( STATION_IDLE ) },
|
||||||
#endif
|
{ LSTRKEY( "STA_CONNECTING" ), LNUMVAL( STATION_CONNECTING ) },
|
||||||
|
{ LSTRKEY( "STA_WRONGPWD" ), LNUMVAL( STATION_WRONG_PASSWORD ) },
|
||||||
|
{ LSTRKEY( "STA_APNOTFOUND" ), LNUMVAL( STATION_NO_AP_FOUND ) },
|
||||||
|
{ LSTRKEY( "STA_FAIL" ), LNUMVAL( STATION_CONNECT_FAIL ) },
|
||||||
|
{ LSTRKEY( "STA_GOTIP" ), LNUMVAL( STATION_GOT_IP ) },
|
||||||
|
|
||||||
|
{ LSTRKEY( "__metatable" ), LROVAL( wifi_map ) },
|
||||||
{ LNILKEY, LNILVAL }
|
{ LNILKEY, LNILVAL }
|
||||||
};
|
};
|
||||||
|
|
||||||
LUALIB_API int luaopen_wifi( lua_State *L )
|
NODEMCU_MODULE(WIFI, "wifi", wifi_map, NULL);
|
||||||
{
|
|
||||||
#if LUA_OPTIMIZE_MEMORY > 0
|
|
||||||
return 0;
|
|
||||||
#else // #if LUA_OPTIMIZE_MEMORY > 0
|
|
||||||
luaL_register( L, AUXLIB_WIFI, wifi_map );
|
|
||||||
|
|
||||||
// Set it as its own metatable
|
|
||||||
lua_pushvalue( L, -1 );
|
|
||||||
lua_setmetatable( L, -2 );
|
|
||||||
|
|
||||||
// Module constants
|
|
||||||
// MOD_REG_NUMBER( L, "NULLMODE", NULL_MODE );
|
|
||||||
MOD_REG_NUMBER( L, "STATION", STATION_MODE );
|
|
||||||
MOD_REG_NUMBER( L, "SOFTAP", SOFTAP_MODE );
|
|
||||||
MOD_REG_NUMBER( L, "STATIONAP", STATIONAP_MODE );
|
|
||||||
|
|
||||||
MOD_REG_NUMBER( L, "NONE_SLEEP", NONE_SLEEP_T );
|
|
||||||
MOD_REG_NUMBER( L, "LIGHT_SLEEP", LIGHT_SLEEP_T );
|
|
||||||
MOD_REG_NUMBER( L, "MODEM_SLEEP", MODEM_SLEEP_T );
|
|
||||||
|
|
||||||
MOD_REG_NUMBER( L, "OPEN", AUTH_OPEN );
|
|
||||||
// MOD_REG_NUMBER( L, "WEP", AUTH_WEP );
|
|
||||||
MOD_REG_NUMBER( L, "WPA_PSK", AUTH_WPA_PSK );
|
|
||||||
MOD_REG_NUMBER( L, "WPA2_PSK", AUTH_WPA2_PSK );
|
|
||||||
MOD_REG_NUMBER( L, "WPA_WPA2_PSK", AUTH_WPA_WPA2_PSK );
|
|
||||||
|
|
||||||
// MOD_REG_NUMBER( L, "STA_IDLE", STATION_IDLE );
|
|
||||||
// MOD_REG_NUMBER( L, "STA_CONNECTING", STATION_CONNECTING );
|
|
||||||
// MOD_REG_NUMBER( L, "STA_WRONGPWD", STATION_WRONG_PASSWORD );
|
|
||||||
// MOD_REG_NUMBER( L, "STA_APNOTFOUND", STATION_NO_AP_FOUND );
|
|
||||||
// MOD_REG_NUMBER( L, "STA_FAIL", STATION_CONNECT_FAIL );
|
|
||||||
// MOD_REG_NUMBER( L, "STA_GOTIP", STATION_GOT_IP );
|
|
||||||
|
|
||||||
// Setup the new tables (station and ap) inside wifi
|
|
||||||
lua_newtable( L );
|
|
||||||
luaL_register( L, NULL, wifi_station_map );
|
|
||||||
lua_setfield( L, -2, "sta" );
|
|
||||||
|
|
||||||
lua_newtable( L );
|
|
||||||
luaL_register( L, NULL, wifi_ap_map );
|
|
||||||
lua_setfield( L, -2, "ap" );
|
|
||||||
|
|
||||||
// Setup the new table (dhcp) inside ap
|
|
||||||
lua_newtable( L );
|
|
||||||
luaL_register( L, NULL, wifi_ap_dhcp_map );
|
|
||||||
lua_setfield( L, -1, "dhcp" );
|
|
||||||
|
|
||||||
return 1;
|
|
||||||
#endif // #if LUA_OPTIMIZE_MEMORY > 0
|
|
||||||
}
|
|
||||||
|
@ -1,8 +1,6 @@
|
|||||||
#include "lualib.h"
|
#include "module.h"
|
||||||
#include "lauxlib.h"
|
#include "lauxlib.h"
|
||||||
#include "platform.h"
|
#include "platform.h"
|
||||||
#include "auxmods.h"
|
|
||||||
#include "lrotable.h"
|
|
||||||
#include "c_stdlib.h"
|
#include "c_stdlib.h"
|
||||||
#include "c_string.h"
|
#include "c_string.h"
|
||||||
|
|
||||||
@ -124,17 +122,11 @@ static int ICACHE_FLASH_ATTR ws2801_writergb(lua_State* L) {
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
#define MIN_OPT_LEVEL 2
|
static const LUA_REG_TYPE ws2801_map[] =
|
||||||
#include "lrodefs.h"
|
|
||||||
const LUA_REG_TYPE ws2801_map[] =
|
|
||||||
{
|
{
|
||||||
{ LSTRKEY( "write" ), LFUNCVAL( ws2801_writergb )},
|
{ LSTRKEY( "write" ), LFUNCVAL( ws2801_writergb )},
|
||||||
{ LSTRKEY( "init" ), LFUNCVAL( ws2801_init_lua )},
|
{ LSTRKEY( "init" ), LFUNCVAL( ws2801_init_lua )},
|
||||||
{ LNILKEY, LNILVAL}
|
{ LNILKEY, LNILVAL}
|
||||||
};
|
};
|
||||||
|
|
||||||
LUALIB_API int luaopen_ws2801(lua_State *L) {
|
NODEMCU_MODULE(WS2801, "ws2801", ws2801_map, NULL);
|
||||||
LREGISTER(L, "ws2801", ws2801_map);
|
|
||||||
return 1;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
@ -1,8 +1,6 @@
|
|||||||
#include "lualib.h"
|
#include "module.h"
|
||||||
#include "lauxlib.h"
|
#include "lauxlib.h"
|
||||||
#include "platform.h"
|
#include "platform.h"
|
||||||
#include "auxmods.h"
|
|
||||||
#include "lrotable.h"
|
|
||||||
#include "c_stdlib.h"
|
#include "c_stdlib.h"
|
||||||
#include "c_string.h"
|
#include "c_string.h"
|
||||||
#include "user_interface.h"
|
#include "user_interface.h"
|
||||||
@ -127,17 +125,16 @@ static int ICACHE_FLASH_ATTR ws2812_writegrb(lua_State* L) {
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
#define MIN_OPT_LEVEL 2
|
static const LUA_REG_TYPE ws2812_map[] =
|
||||||
#include "lrodefs.h"
|
|
||||||
const LUA_REG_TYPE ws2812_map[] =
|
|
||||||
{
|
{
|
||||||
{ LSTRKEY( "writergb" ), LFUNCVAL( ws2812_writergb )},
|
{ LSTRKEY( "writergb" ), LFUNCVAL( ws2812_writergb )},
|
||||||
{ LSTRKEY( "write" ), LFUNCVAL( ws2812_writegrb )},
|
{ LSTRKEY( "write" ), LFUNCVAL( ws2812_writegrb )},
|
||||||
{ LNILKEY, LNILVAL}
|
{ LNILKEY, LNILVAL}
|
||||||
};
|
};
|
||||||
|
|
||||||
LUALIB_API int luaopen_ws2812(lua_State *L) {
|
int luaopen_ws2812(lua_State *L) {
|
||||||
// TODO: Make sure that the GPIO system is initialized
|
// TODO: Make sure that the GPIO system is initialized
|
||||||
LREGISTER(L, "ws2812", ws2812_map);
|
return 0;
|
||||||
return 1;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
NODEMCU_MODULE(WS2812, "ws2812", ws2812_map, luaopen_ws2812);
|
||||||
|
@ -102,15 +102,14 @@ extern char _flash_used_end[];
|
|||||||
// Return the sector number, as well as the start and end address of the sector
|
// Return the sector number, as well as the start and end address of the sector
|
||||||
static uint32_t flashh_find_sector( uint32_t address, uint32_t *pstart, uint32_t *pend )
|
static uint32_t flashh_find_sector( uint32_t address, uint32_t *pstart, uint32_t *pend )
|
||||||
{
|
{
|
||||||
address -= INTERNAL_FLASH_START_ADDRESS;
|
|
||||||
#ifdef INTERNAL_FLASH_SECTOR_SIZE
|
#ifdef INTERNAL_FLASH_SECTOR_SIZE
|
||||||
// All the sectors in the flash have the same size, so just align the address
|
// All the sectors in the flash have the same size, so just align the address
|
||||||
uint32_t sect_id = address / INTERNAL_FLASH_SECTOR_SIZE;
|
uint32_t sect_id = address / INTERNAL_FLASH_SECTOR_SIZE;
|
||||||
|
|
||||||
if( pstart )
|
if( pstart )
|
||||||
*pstart = sect_id * INTERNAL_FLASH_SECTOR_SIZE + INTERNAL_FLASH_START_ADDRESS;
|
*pstart = sect_id * INTERNAL_FLASH_SECTOR_SIZE ;
|
||||||
if( pend )
|
if( pend )
|
||||||
*pend = ( sect_id + 1 ) * INTERNAL_FLASH_SECTOR_SIZE + INTERNAL_FLASH_START_ADDRESS - 1;
|
*pend = ( sect_id + 1 ) * INTERNAL_FLASH_SECTOR_SIZE - 1;
|
||||||
return sect_id;
|
return sect_id;
|
||||||
#else // #ifdef INTERNAL_FLASH_SECTOR_SIZE
|
#else // #ifdef INTERNAL_FLASH_SECTOR_SIZE
|
||||||
// The flash has blocks of different size
|
// The flash has blocks of different size
|
||||||
@ -121,9 +120,9 @@ static uint32_t flashh_find_sector( uint32_t address, uint32_t *pstart, uint32_t
|
|||||||
while( ( total <= address ) && ( i < sizeof( flash_sect_size ) / sizeof( uint32_t ) ) )
|
while( ( total <= address ) && ( i < sizeof( flash_sect_size ) / sizeof( uint32_t ) ) )
|
||||||
total += flash_sect_size[ i ++ ];
|
total += flash_sect_size[ i ++ ];
|
||||||
if( pstart )
|
if( pstart )
|
||||||
*pstart = ( total - flash_sect_size[ i - 1 ] ) + INTERNAL_FLASH_START_ADDRESS;
|
*pstart = ( total - flash_sect_size[ i - 1 ] );
|
||||||
if( pend )
|
if( pend )
|
||||||
*pend = total + INTERNAL_FLASH_START_ADDRESS - 1;
|
*pend = total - 1;
|
||||||
return i - 1;
|
return i - 1;
|
||||||
#endif // #ifdef INTERNAL_FLASH_SECTOR_SIZE
|
#endif // #ifdef INTERNAL_FLASH_SECTOR_SIZE
|
||||||
}
|
}
|
||||||
@ -150,13 +149,12 @@ uint32_t platform_flash_get_first_free_block_address( uint32_t *psect )
|
|||||||
uint32_t start, end, sect;
|
uint32_t start, end, sect;
|
||||||
NODE_DBG("_flash_used_end:%08x\n", (uint32_t)_flash_used_end);
|
NODE_DBG("_flash_used_end:%08x\n", (uint32_t)_flash_used_end);
|
||||||
if(_flash_used_end>0){ // find the used sector
|
if(_flash_used_end>0){ // find the used sector
|
||||||
// sect = flashh_find_sector( ( uint32_t )flash_used_size + INTERNAL_FLASH_START_ADDRESS - 1, NULL, &end );
|
sect = flashh_find_sector( platform_flash_mapped2phys ( (uint32_t)_flash_used_end - 1), NULL, &end );
|
||||||
sect = flashh_find_sector( ( uint32_t )_flash_used_end - 1, NULL, &end );
|
|
||||||
if( psect )
|
if( psect )
|
||||||
*psect = sect + 1;
|
*psect = sect + 1;
|
||||||
return end + 1;
|
return end + 1;
|
||||||
}else{
|
}else{
|
||||||
sect = flashh_find_sector( INTERNAL_FLASH_START_ADDRESS, &start, NULL ); // find the first free sector
|
sect = flashh_find_sector( 0, &start, NULL ); // find the first free sector
|
||||||
if( psect )
|
if( psect )
|
||||||
*psect = sect;
|
*psect = sect;
|
||||||
return start;
|
return start;
|
||||||
|
@ -53,7 +53,7 @@
|
|||||||
#define INTERNAL_FLASH_READ_UNIT_SIZE 4
|
#define INTERNAL_FLASH_READ_UNIT_SIZE 4
|
||||||
|
|
||||||
#define INTERNAL_FLASH_SIZE ( (SYS_PARAM_SEC_START) * INTERNAL_FLASH_SECTOR_SIZE )
|
#define INTERNAL_FLASH_SIZE ( (SYS_PARAM_SEC_START) * INTERNAL_FLASH_SECTOR_SIZE )
|
||||||
#define INTERNAL_FLASH_START_ADDRESS 0x40200000
|
#define INTERNAL_FLASH_MAPPED_ADDRESS 0x40200000
|
||||||
|
|
||||||
// SpiFlashOpResult spi_flash_erase_sector(uint16 sec);
|
// SpiFlashOpResult spi_flash_erase_sector(uint16 sec);
|
||||||
// SpiFlashOpResult spi_flash_write(uint32 des_addr, uint32 *src_addr, uint32 size);
|
// SpiFlashOpResult spi_flash_write(uint32 des_addr, uint32 *src_addr, uint32 size);
|
||||||
@ -68,4 +68,9 @@
|
|||||||
#define flash_read spi_flash_read
|
#define flash_read spi_flash_read
|
||||||
#endif // defined(FLASH_SAFE_API)
|
#endif // defined(FLASH_SAFE_API)
|
||||||
|
|
||||||
|
#define CACHE_FLASH_CTRL_REG 0x3ff0000c
|
||||||
|
#define CACHE_FLASH_ACTIVE 0x00000100
|
||||||
|
#define CACHE_FLASH_MAPPED0 0x02000000
|
||||||
|
#define CACHE_FLASH_MAPPED1 0x00010000
|
||||||
|
|
||||||
#endif // #ifndef __CPU_ESP8266_H__
|
#endif // #ifndef __CPU_ESP8266_H__
|
||||||
|
@ -96,11 +96,6 @@ SpiFlashOpResult flash_safe_erase_sector(uint16 sec)
|
|||||||
SPIFlashInfo flash_rom_getinfo(void)
|
SPIFlashInfo flash_rom_getinfo(void)
|
||||||
{
|
{
|
||||||
volatile SPIFlashInfo spi_flash_info ICACHE_STORE_ATTR;
|
volatile SPIFlashInfo spi_flash_info ICACHE_STORE_ATTR;
|
||||||
// Don't use it before cache read disabled
|
|
||||||
// FLASH_DISABLE_CACHE();
|
|
||||||
// spi_flash_info = *((SPIFlashInfo *)(FLASH_ADDRESS_START_MAP));
|
|
||||||
// FLASH_ENABLE_CACHE();
|
|
||||||
// Needn't safe mode.
|
|
||||||
spi_flash_read(0, (uint32 *)(& spi_flash_info), sizeof(spi_flash_info));
|
spi_flash_read(0, (uint32 *)(& spi_flash_info), sizeof(spi_flash_info));
|
||||||
return spi_flash_info;
|
return spi_flash_info;
|
||||||
}
|
}
|
||||||
|
@ -4,8 +4,6 @@
|
|||||||
#include "user_config.h"
|
#include "user_config.h"
|
||||||
#include "cpu_esp8266.h"
|
#include "cpu_esp8266.h"
|
||||||
|
|
||||||
#define FLASH_ADDRESS_START_MAP (INTERNAL_FLASH_START_ADDRESS)
|
|
||||||
|
|
||||||
#define FLASH_SIZE_2MBIT (2 * 1024 * 1024)
|
#define FLASH_SIZE_2MBIT (2 * 1024 * 1024)
|
||||||
#define FLASH_SIZE_4MBIT (4 * 1024 * 1024)
|
#define FLASH_SIZE_4MBIT (4 * 1024 * 1024)
|
||||||
#define FLASH_SIZE_8MBIT (8 * 1024 * 1024)
|
#define FLASH_SIZE_8MBIT (8 * 1024 * 1024)
|
||||||
|
@ -222,8 +222,8 @@ uint32_t platform_uart_setup( unsigned id, uint32_t baud, int databits, int pari
|
|||||||
|
|
||||||
switch (stopbits)
|
switch (stopbits)
|
||||||
{
|
{
|
||||||
case PLATFORM_UART_STOPBITS_1:
|
case PLATFORM_UART_STOPBITS_1_5:
|
||||||
UartDev.stop_bits = ONE_STOP_BIT;
|
UartDev.stop_bits = ONE_HALF_STOP_BIT;
|
||||||
break;
|
break;
|
||||||
case PLATFORM_UART_STOPBITS_2:
|
case PLATFORM_UART_STOPBITS_2:
|
||||||
UartDev.stop_bits = TWO_STOP_BIT;
|
UartDev.stop_bits = TWO_STOP_BIT;
|
||||||
@ -237,12 +237,15 @@ uint32_t platform_uart_setup( unsigned id, uint32_t baud, int databits, int pari
|
|||||||
{
|
{
|
||||||
case PLATFORM_UART_PARITY_EVEN:
|
case PLATFORM_UART_PARITY_EVEN:
|
||||||
UartDev.parity = EVEN_BITS;
|
UartDev.parity = EVEN_BITS;
|
||||||
|
UartDev.exist_parity = STICK_PARITY_EN;
|
||||||
break;
|
break;
|
||||||
case PLATFORM_UART_PARITY_ODD:
|
case PLATFORM_UART_PARITY_ODD:
|
||||||
UartDev.parity = ODD_BITS;
|
UartDev.parity = ODD_BITS;
|
||||||
|
UartDev.exist_parity = STICK_PARITY_EN;
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
UartDev.parity = NONE_BITS;
|
UartDev.parity = NONE_BITS;
|
||||||
|
UartDev.exist_parity = STICK_PARITY_DIS;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -514,12 +517,11 @@ int platform_spi_transaction( uint8_t id, uint8_t cmd_bitlen, spi_data_type cmd_
|
|||||||
*/
|
*/
|
||||||
uint32_t platform_s_flash_write( const void *from, uint32_t toaddr, uint32_t size )
|
uint32_t platform_s_flash_write( const void *from, uint32_t toaddr, uint32_t size )
|
||||||
{
|
{
|
||||||
toaddr -= INTERNAL_FLASH_START_ADDRESS;
|
|
||||||
SpiFlashOpResult r;
|
SpiFlashOpResult r;
|
||||||
const uint32_t blkmask = INTERNAL_FLASH_WRITE_UNIT_SIZE - 1;
|
const uint32_t blkmask = INTERNAL_FLASH_WRITE_UNIT_SIZE - 1;
|
||||||
uint32_t *apbuf = NULL;
|
uint32_t *apbuf = NULL;
|
||||||
uint32_t fromaddr = (uint32_t)from;
|
uint32_t fromaddr = (uint32_t)from;
|
||||||
if( (fromaddr & blkmask ) || (fromaddr >= INTERNAL_FLASH_START_ADDRESS)) {
|
if( (fromaddr & blkmask ) || (fromaddr >= INTERNAL_FLASH_MAPPED_ADDRESS)) {
|
||||||
apbuf = (uint32_t *)c_malloc(size);
|
apbuf = (uint32_t *)c_malloc(size);
|
||||||
if(!apbuf)
|
if(!apbuf)
|
||||||
return 0;
|
return 0;
|
||||||
@ -532,7 +534,7 @@ uint32_t platform_s_flash_write( const void *from, uint32_t toaddr, uint32_t siz
|
|||||||
if(SPI_FLASH_RESULT_OK == r)
|
if(SPI_FLASH_RESULT_OK == r)
|
||||||
return size;
|
return size;
|
||||||
else{
|
else{
|
||||||
NODE_ERR( "ERROR in flash_write: r=%d at %08X\n", ( int )r, ( unsigned )toaddr+INTERNAL_FLASH_START_ADDRESS );
|
NODE_ERR( "ERROR in flash_write: r=%d at %08X\n", ( int )r, ( unsigned )toaddr);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -547,7 +549,6 @@ uint32_t platform_s_flash_read( void *to, uint32_t fromaddr, uint32_t size )
|
|||||||
if (size==0)
|
if (size==0)
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
fromaddr -= INTERNAL_FLASH_START_ADDRESS;
|
|
||||||
SpiFlashOpResult r;
|
SpiFlashOpResult r;
|
||||||
system_soft_wdt_feed ();
|
system_soft_wdt_feed ();
|
||||||
|
|
||||||
@ -571,7 +572,7 @@ uint32_t platform_s_flash_read( void *to, uint32_t fromaddr, uint32_t size )
|
|||||||
if(SPI_FLASH_RESULT_OK == r)
|
if(SPI_FLASH_RESULT_OK == r)
|
||||||
return size;
|
return size;
|
||||||
else{
|
else{
|
||||||
NODE_ERR( "ERROR in flash_read: r=%d at %08X\n", ( int )r, ( unsigned )fromaddr+INTERNAL_FLASH_START_ADDRESS );
|
NODE_ERR( "ERROR in flash_read: r=%d at %08X\n", ( int )r, ( unsigned )fromaddr);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -581,3 +582,14 @@ int platform_flash_erase_sector( uint32_t sector_id )
|
|||||||
system_soft_wdt_feed ();
|
system_soft_wdt_feed ();
|
||||||
return flash_erase( sector_id ) == SPI_FLASH_RESULT_OK ? PLATFORM_OK : PLATFORM_ERR;
|
return flash_erase( sector_id ) == SPI_FLASH_RESULT_OK ? PLATFORM_OK : PLATFORM_ERR;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
uint32_t platform_flash_mapped2phys (uint32_t mapped_addr)
|
||||||
|
{
|
||||||
|
uint32_t cache_ctrl = READ_PERI_REG(CACHE_FLASH_CTRL_REG);
|
||||||
|
if (!(cache_ctrl & CACHE_FLASH_ACTIVE))
|
||||||
|
return -1;
|
||||||
|
bool b0 = (cache_ctrl & CACHE_FLASH_MAPPED0) ? 1 : 0;
|
||||||
|
bool b1 = (cache_ctrl & CACHE_FLASH_MAPPED1) ? 1 : 0;
|
||||||
|
uint32_t meg = (b1 << 1) | b0;
|
||||||
|
return mapped_addr - INTERNAL_FLASH_MAPPED_ADDRESS + meg * 0x100000;
|
||||||
|
}
|
||||||
|
@ -119,19 +119,19 @@ int platform_spi_transaction( uint8_t id, uint8_t cmd_bitlen, spi_data_type cmd_
|
|||||||
// Parity
|
// Parity
|
||||||
enum
|
enum
|
||||||
{
|
{
|
||||||
PLATFORM_UART_PARITY_EVEN,
|
PLATFORM_UART_PARITY_NONE = 0,
|
||||||
PLATFORM_UART_PARITY_ODD,
|
PLATFORM_UART_PARITY_EVEN = 1,
|
||||||
PLATFORM_UART_PARITY_NONE,
|
PLATFORM_UART_PARITY_ODD = 2,
|
||||||
PLATFORM_UART_PARITY_MARK,
|
PLATFORM_UART_PARITY_MARK = 3,
|
||||||
PLATFORM_UART_PARITY_SPACE
|
PLATFORM_UART_PARITY_SPACE = 4
|
||||||
};
|
};
|
||||||
|
|
||||||
// Stop bits
|
// Stop bits
|
||||||
enum
|
enum
|
||||||
{
|
{
|
||||||
PLATFORM_UART_STOPBITS_1,
|
PLATFORM_UART_STOPBITS_1 = 1,
|
||||||
PLATFORM_UART_STOPBITS_1_5,
|
PLATFORM_UART_STOPBITS_2 = 2,
|
||||||
PLATFORM_UART_STOPBITS_2
|
PLATFORM_UART_STOPBITS_1_5 = 3
|
||||||
};
|
};
|
||||||
|
|
||||||
// Flow control types (this is a bit mask, one can specify PLATFORM_UART_FLOW_RTS | PLATFORM_UART_FLOW_CTS )
|
// Flow control types (this is a bit mask, one can specify PLATFORM_UART_FLOW_RTS | PLATFORM_UART_FLOW_CTS )
|
||||||
@ -237,10 +237,36 @@ uint32_t platform_s_flash_read( void *to, uint32_t fromaddr, uint32_t size );
|
|||||||
uint32_t platform_flash_get_num_sectors(void);
|
uint32_t platform_flash_get_num_sectors(void);
|
||||||
int platform_flash_erase_sector( uint32_t sector_id );
|
int platform_flash_erase_sector( uint32_t sector_id );
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Translated a mapped address to a physical flash address, based on the
|
||||||
|
* current flash cache mapping.
|
||||||
|
* @param mapped_addr Address to translate (>= INTERNAL_FLASH_MAPPED_ADDRESS)
|
||||||
|
* @return the corresponding physical flash address, or -1 if flash cache is
|
||||||
|
* not currently active.
|
||||||
|
* @see Cache_Read_Enable.
|
||||||
|
*/
|
||||||
|
uint32_t platform_flash_mapped2phys (uint32_t mapped_addr);
|
||||||
|
|
||||||
// *****************************************************************************
|
// *****************************************************************************
|
||||||
// Allocator support
|
// Allocator support
|
||||||
|
|
||||||
void* platform_get_first_free_ram( unsigned id );
|
void* platform_get_first_free_ram( unsigned id );
|
||||||
void* platform_get_last_free_ram( unsigned id );
|
void* platform_get_last_free_ram( unsigned id );
|
||||||
|
|
||||||
|
// *****************************************************************************
|
||||||
|
// Helper macros
|
||||||
|
#define MOD_CHECK_ID( mod, id )\
|
||||||
|
if( !platform_ ## mod ## _exists( id ) )\
|
||||||
|
return luaL_error( L, #mod" %d does not exist", ( unsigned )id )
|
||||||
|
|
||||||
|
#define MOD_CHECK_TIMER( id )\
|
||||||
|
if( id == PLATFORM_TIMER_SYS_ID && !platform_timer_sys_available() )\
|
||||||
|
return luaL_error( L, "the system timer is not available on this platform" );\
|
||||||
|
if( !platform_timer_exists( id ) )\
|
||||||
|
return luaL_error( L, "timer %d does not exist", ( unsigned )id )\
|
||||||
|
|
||||||
|
#define MOD_CHECK_RES_ID( mod, id, resmod, resid )\
|
||||||
|
if( !platform_ ## mod ## _check_ ## resmod ## _id( id, resid ) )\
|
||||||
|
return luaL_error( L, #resmod" %d not valid with " #mod " %d", ( unsigned )resid, ( unsigned )id )
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
@ -51,9 +51,9 @@ void myspiffs_mount() {
|
|||||||
#else
|
#else
|
||||||
cfg.phys_addr = ( u32_t )platform_flash_get_first_free_block_address( NULL );
|
cfg.phys_addr = ( u32_t )platform_flash_get_first_free_block_address( NULL );
|
||||||
#endif
|
#endif
|
||||||
cfg.phys_addr += 0x3000;
|
cfg.phys_addr += 0x3FFF;
|
||||||
cfg.phys_addr &= 0xFFFFC000; // align to 4 sector.
|
cfg.phys_addr &= 0xFFFFC000; // align to 4 sector.
|
||||||
cfg.phys_size = INTERNAL_FLASH_SIZE - ( ( u32_t )cfg.phys_addr - INTERNAL_FLASH_START_ADDRESS );
|
cfg.phys_size = INTERNAL_FLASH_SIZE - ( ( u32_t )cfg.phys_addr );
|
||||||
cfg.phys_erase_block = INTERNAL_FLASH_SECTOR_SIZE; // according to datasheet
|
cfg.phys_erase_block = INTERNAL_FLASH_SECTOR_SIZE; // according to datasheet
|
||||||
cfg.log_block_size = INTERNAL_FLASH_SECTOR_SIZE; // let us not complicate things
|
cfg.log_block_size = INTERNAL_FLASH_SECTOR_SIZE; // let us not complicate things
|
||||||
cfg.log_page_size = LOG_PAGE_SIZE; // as we said
|
cfg.log_page_size = LOG_PAGE_SIZE; // as we said
|
||||||
@ -94,10 +94,10 @@ int myspiffs_format( void )
|
|||||||
#else
|
#else
|
||||||
sect_first = ( u32_t )platform_flash_get_first_free_block_address( NULL );
|
sect_first = ( u32_t )platform_flash_get_first_free_block_address( NULL );
|
||||||
#endif
|
#endif
|
||||||
sect_first += 0x3000;
|
sect_first += 0x3FFF;
|
||||||
sect_first &= 0xFFFFC000; // align to 4 sector.
|
sect_first &= 0xFFFFC000; // align to 4 sector.
|
||||||
sect_first = platform_flash_get_sector_of_address(sect_first);
|
sect_first = platform_flash_get_sector_of_address(sect_first);
|
||||||
sect_last = INTERNAL_FLASH_SIZE + INTERNAL_FLASH_START_ADDRESS - 4;
|
sect_last = INTERNAL_FLASH_SIZE - SYS_PARAM_SEC_NUM;
|
||||||
sect_last = platform_flash_get_sector_of_address(sect_last);
|
sect_last = platform_flash_get_sector_of_address(sect_last);
|
||||||
NODE_DBG("sect_first: %x, sect_last: %x\n", sect_first, sect_last);
|
NODE_DBG("sect_first: %x, sect_last: %x\n", sect_first, sect_last);
|
||||||
while( sect_first <= sect_last )
|
while( sect_first <= sect_last )
|
||||||
|
34
app/u8glib/README.md
Normal file
34
app/u8glib/README.md
Normal file
@ -0,0 +1,34 @@
|
|||||||
|
##U8glib package
|
||||||
|
|
||||||
|
Ported from https://github.com/olikraus/u8glib
|
||||||
|
|
||||||
|
|
||||||
|
Here is black magic with ImageMagic package for image conversion:
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
```bash
|
||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
mkdir out
|
||||||
|
|
||||||
|
for icon in *png; do
|
||||||
|
convert $icon -depth 1 ./out/$(basename $icon .png)_1bpp.png
|
||||||
|
if [[ "$icon" == *"black"* ]]; then
|
||||||
|
convert ./out/$(basename $icon .png)_1bpp.png -background white -alpha Background ./out/$(basename $icon .png)_1bpp.xbm
|
||||||
|
else
|
||||||
|
convert ./out/$(basename $icon .png)_1bpp.png -background black -alpha Background ./out/$(basename $icon .png)_1bpp.xbm
|
||||||
|
fi
|
||||||
|
cat ./out/$(basename $icon .png)_1bpp.xbm | tr '\n' ' ' | tr -d " " |sed -e s'#^.*{##g' | sed s'#,}##' |sed s'/;//' | xxd -r -p > ./out/$(basename $icon .png).xbm.mono
|
||||||
|
done
|
||||||
|
|
||||||
|
rm out/*png out/*xbm
|
||||||
|
```
|
||||||
|
Convert all the png in the current folder and put resulting .mono to ./out
|
||||||
|
|
||||||
|
The convert binary is a part of ImageMagic package. You need to install it.
|
||||||
|
|
||||||
|
```
|
||||||
|
sudo apt-get install imagemagick
|
||||||
|
```
|
||||||
|
for Debian/Ubuntu.
|
@ -521,7 +521,7 @@ int romfs_init( void )
|
|||||||
#if defined( BUILD_WOFS )
|
#if defined( BUILD_WOFS )
|
||||||
// Get the start address and size of WOFS and register it
|
// Get the start address and size of WOFS and register it
|
||||||
wofs_fsdata.pbase = ( uint8_t* )platform_flash_get_first_free_block_address( NULL );
|
wofs_fsdata.pbase = ( uint8_t* )platform_flash_get_first_free_block_address( NULL );
|
||||||
wofs_fsdata.max_size = INTERNAL_FLASH_SIZE - ( ( uint32_t )wofs_fsdata.pbase - INTERNAL_FLASH_START_ADDRESS );
|
wofs_fsdata.max_size = INTERNAL_FLASH_SIZE - ( ( uint32_t )wofs_fsdata.pbase );
|
||||||
NODE_DBG("wofs.pbase:%x,max:%x\n",wofs_fsdata.pbase,wofs_fsdata.max_size);
|
NODE_DBG("wofs.pbase:%x,max:%x\n",wofs_fsdata.pbase,wofs_fsdata.max_size);
|
||||||
#endif // ifdef BUILD_WOFS
|
#endif // ifdef BUILD_WOFS
|
||||||
return 0;
|
return 0;
|
||||||
|
@ -79,6 +79,16 @@ SECTIONS
|
|||||||
*(.rodata*)
|
*(.rodata*)
|
||||||
*(.sdk.version)
|
*(.sdk.version)
|
||||||
|
|
||||||
|
/* Link-time arrays containing the defs for the included modules */
|
||||||
|
. = ALIGN(4);
|
||||||
|
lua_libs = ABSOLUTE(.);
|
||||||
|
/* Allow either empty define or defined-to-1 to include the module */
|
||||||
|
KEEP(*(.lua_libs))
|
||||||
|
LONG(0) LONG(0) /* Null-terminate the array */
|
||||||
|
lua_rotable = ABSOLUTE(.);
|
||||||
|
KEEP(*(.lua_rotable))
|
||||||
|
LONG(0) LONG(0) /* Null-terminate the array */
|
||||||
|
|
||||||
/* These are *only* pulled in by Lua, and therefore safe to put in flash */
|
/* These are *only* pulled in by Lua, and therefore safe to put in flash */
|
||||||
*/libc.a:lib_a-isalnum.o(.text* .literal*)
|
*/libc.a:lib_a-isalnum.o(.text* .literal*)
|
||||||
*/libc.a:lib_a-isalpha.o(.text* .literal*)
|
*/libc.a:lib_a-isalpha.o(.text* .literal*)
|
||||||
|
Loading…
x
Reference in New Issue
Block a user