custom-board-bundle-sample-.../firmware/controllers/lua/rusefi_lua.h

70 lines
1.5 KiB
C
Raw Normal View History

// This file is not named lua.h as it would collide with firmware/ext/lua/src/lua.h
#pragma once
#include "lua.hpp"
class LuaHandle final {
public:
LuaHandle() : LuaHandle(nullptr) { }
LuaHandle(lua_State* ptr) : m_ptr(ptr) { }
// Don't allow copying!
LuaHandle(const LuaHandle&) = delete;
LuaHandle& operator=(const LuaHandle&) = delete;
// Allow moving!
LuaHandle(LuaHandle&& rhs) {
m_ptr = rhs.m_ptr;
rhs.m_ptr = nullptr;
}
// Move assignment operator
LuaHandle& operator=(LuaHandle&& rhs) {
m_ptr = rhs.m_ptr;
rhs.m_ptr = nullptr;
return *this;
}
// Destruction cleans up lua state
~LuaHandle() {
if (m_ptr) {
efiPrintf("LUA: Tearing down instance...");
lua_close(m_ptr);
}
}
operator lua_State*() const { return m_ptr; }
private:
lua_State* m_ptr;
};
void startLua();
#if EFI_UNIT_TEST
#include "expected.h"
expected<float> testLuaReturnsNumberOrNil(const char* script);
float testLuaReturnsNumber(const char* script);
int testLuaReturnsInteger(const char* script);
void testLuaExecString(const char* script);
#endif
#if EFI_CAN_SUPPORT
#include "can.h"
// Lua CAN rx feature
void initLuaCanRx();
// Called when the user script is unloaded, resets any CAN rx filters
void resetLuaCanRx();
// Adds a frame ID to listen to
void addLuaCanRxFilter(int32_t eid);
// Called from the Lua loop to process any pending CAN frames
void doLuaCanRx(LuaHandle& ls);
// Called from the CAN RX thread to queue a frame for Lua consumption
2021-12-20 22:17:02 -08:00
void processLuaCan(const size_t busIndex, const CANRxFrame& frame);
#endif // not EFI_CAN_SUPPORT