2021-11-02 20:27:48 -07:00
|
|
|
/*
|
|
|
|
* lua_hooks_util.cpp
|
|
|
|
*
|
|
|
|
* Created on: Nov 2, 2021
|
|
|
|
* Author: rusefi
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include "pch.h"
|
|
|
|
#include "lua_hooks_util.h"
|
2022-10-28 16:31:17 -07:00
|
|
|
#include "script_impl.h"
|
2021-11-02 20:27:48 -07:00
|
|
|
|
|
|
|
static int lua_efi_print(lua_State* l) {
|
|
|
|
auto msg = luaL_checkstring(l, 1);
|
|
|
|
|
2022-08-25 21:04:17 -07:00
|
|
|
// we have somewhat similar debug code at serial_can.cpp
|
|
|
|
#if EFI_UNIT_TEST
|
|
|
|
printf("[LUA] %s\n", msg);
|
|
|
|
#endif
|
|
|
|
|
2021-11-02 20:27:48 -07:00
|
|
|
efiPrintf("LUA: %s", msg);
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
2021-11-02 20:35:48 -07:00
|
|
|
static int lua_interpolate(lua_State* l) {
|
|
|
|
auto x1 = luaL_checknumber(l, 1);
|
|
|
|
auto y1 = luaL_checknumber(l, 2);
|
|
|
|
auto x2 = luaL_checknumber(l, 3);
|
|
|
|
auto y2 = luaL_checknumber(l, 4);
|
|
|
|
auto x = luaL_checknumber(l, 5);
|
|
|
|
|
|
|
|
auto result = interpolateMsg("lua", x1, y1, x2, y2, x);
|
|
|
|
|
|
|
|
lua_pushnumber(l, result);
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2023-11-01 10:02:20 -07:00
|
|
|
void configureRusefiLuaUtilHooks(lua_State* lState) {
|
|
|
|
lua_register(lState, "print", lua_efi_print);
|
|
|
|
lua_register(lState, "interpolate", lua_interpolate);
|
2021-12-13 14:53:20 -08:00
|
|
|
|
2023-11-01 10:02:20 -07:00
|
|
|
lua_register(lState, "findCurveIndex", [](lua_State* l) {
|
2022-10-28 16:31:17 -07:00
|
|
|
auto name = luaL_checklstring(l, 1, nullptr);
|
|
|
|
auto result = getCurveIndexByName(name);
|
|
|
|
if (!result) {
|
|
|
|
lua_pushnil(l);
|
|
|
|
} else {
|
|
|
|
// TS counts curve from 1 so convert indexing here
|
|
|
|
lua_pushnumber(l, result.Value + HUMAN_OFFSET);
|
|
|
|
}
|
|
|
|
return 1;
|
|
|
|
});
|
|
|
|
|
2023-11-01 10:02:20 -07:00
|
|
|
lua_register(lState, "findTableIndex",
|
2022-10-28 16:31:17 -07:00
|
|
|
[](lua_State* l) {
|
|
|
|
auto name = luaL_checklstring(l, 1, nullptr);
|
|
|
|
auto index = getTableIndexByName(name);
|
|
|
|
if (!index) {
|
|
|
|
lua_pushnil(l);
|
|
|
|
} else {
|
|
|
|
// TS counts curve from 1 so convert indexing here
|
|
|
|
lua_pushnumber(l, index.Value + HUMAN_OFFSET);
|
|
|
|
}
|
|
|
|
return 1;
|
|
|
|
});
|
|
|
|
|
2023-11-01 10:02:20 -07:00
|
|
|
lua_register(lState, "findSetting",
|
2022-10-28 16:31:17 -07:00
|
|
|
[](lua_State* l) {
|
|
|
|
auto name = luaL_checklstring(l, 1, nullptr);
|
|
|
|
auto defaultValue = luaL_checknumber(l, 2);
|
|
|
|
|
|
|
|
auto index = getSettingIndexByName(name);
|
|
|
|
if (!index) {
|
|
|
|
lua_pushnumber(l, defaultValue);
|
|
|
|
} else {
|
|
|
|
// TS counts curve from 1 so convert indexing here
|
|
|
|
lua_pushnumber(l, engineConfiguration->scriptSetting[index.Value]);
|
|
|
|
}
|
|
|
|
return 1;
|
|
|
|
});
|
|
|
|
|
2021-12-13 14:53:20 -08:00
|
|
|
#if defined(STM32F4) || defined(STM32F7)
|
2023-11-01 10:02:20 -07:00
|
|
|
lua_register(lState, "mcu_standby", [](lua_State*) {
|
2023-05-12 15:13:27 -07:00
|
|
|
onBoardStandBy();
|
2022-01-15 08:37:24 -08:00
|
|
|
stm32_standby();
|
2021-12-13 14:53:20 -08:00
|
|
|
return 0;
|
|
|
|
});
|
|
|
|
#endif
|
|
|
|
|
2021-11-11 18:38:49 -08:00
|
|
|
/*
|
|
|
|
* todo: shall we? same for milliseconds?
|
|
|
|
lua_register(l, "getNowSeconds", [](lua_State* l) -> int {
|
2022-09-11 10:06:03 -07:00
|
|
|
int result = getTimeNowS();
|
2021-11-11 18:38:49 -08:00
|
|
|
lua_pushnumber(l, result);
|
|
|
|
return 1;
|
|
|
|
});
|
|
|
|
*/
|
2021-11-02 20:27:48 -07:00
|
|
|
}
|
|
|
|
|
2022-05-15 14:47:14 -07:00
|
|
|
void * hackEngineConfigurationPointer(void *ptr) {
|
|
|
|
// we know that 'engineConfiguration' was null at the time of initialization in unit tests
|
|
|
|
#if EFI_UNIT_TEST
|
|
|
|
intptr_t offset = (intptr_t)ptr;
|
2022-05-15 20:16:07 -07:00
|
|
|
void * valuePtr = (void *)((char *)engineConfiguration + offset);
|
2022-05-15 14:47:14 -07:00
|
|
|
return valuePtr;
|
|
|
|
#else
|
|
|
|
return ptr;
|
|
|
|
#endif
|
|
|
|
}
|