AP_Scripting: stop and restart scripting via command int

This commit is contained in:
Iampete1 2021-08-04 17:49:17 +01:00 committed by Willian Galvani
parent 0db7afb074
commit d1c3ef7e5b
3 changed files with 48 additions and 11 deletions

View File

@ -150,6 +150,14 @@ MAV_RESULT AP_Scripting::handle_command_int_packet(const mavlink_command_int_t &
case SCRIPTING_CMD_REPL_STOP: case SCRIPTING_CMD_REPL_STOP:
repl_stop(); repl_stop();
return MAV_RESULT_ACCEPTED; return MAV_RESULT_ACCEPTED;
case SCRIPTING_CMD_STOP:
_restart = false;
_stop = true;
return MAV_RESULT_ACCEPTED;
case SCRIPTING_CMD_STOP_AND_RESTART:
_restart = true;
_stop = true;
return MAV_RESULT_ACCEPTED;
case SCRIPTING_CMD_ENUM_END: // cope with MAVLink generator appending to our enum case SCRIPTING_CMD_ENUM_END: // cope with MAVLink generator appending to our enum
break; break;
} }
@ -193,17 +201,43 @@ void AP_Scripting::repl_stop(void) {
} }
void AP_Scripting::thread(void) { void AP_Scripting::thread(void) {
lua_scripts *lua = new lua_scripts(_script_vm_exec_count, _script_heap_size, _debug_level, terminal); while (true) {
if (lua == nullptr || !lua->heap_allocated()) { // reset flags
gcs().send_text(MAV_SEVERITY_CRITICAL, "Unable to allocate scripting memory"); _stop = false;
delete lua; _restart = false;
_init_failed = true;
return;
}
lua->run();
// only reachable if the lua backend has died for any reason lua_scripts *lua = new lua_scripts(_script_vm_exec_count, _script_heap_size, _debug_level, terminal);
gcs().send_text(MAV_SEVERITY_CRITICAL, "Scripting has stopped"); if (lua == nullptr || !lua->heap_allocated()) {
gcs().send_text(MAV_SEVERITY_CRITICAL, "Unable to allocate scripting memory");
_init_failed = true;
} else {
// run won't return while scripting is still active
lua->run();
// only reachable if the lua backend has died for any reason
gcs().send_text(MAV_SEVERITY_CRITICAL, "Scripting has stopped");
}
delete lua;
bool cleared = false;
while(true) {
// 1hz check if we should restart
hal.scheduler->delay(1000);
if (!enabled()) {
// enable must be put to 0 and back to 1 to restart from params
cleared = true;
continue;
}
// must be enabled to get this far
if (cleared || _restart) {
gcs().send_text(MAV_SEVERITY_CRITICAL, "Scripting restated");
break;
}
if (_debug_level > 0) {
gcs().send_text(MAV_SEVERITY_DEBUG, "Lua: scripting stopped");
}
}
}
} }
void AP_Scripting::handle_mission_command(const AP_Mission::Mission_Command& cmd_in) void AP_Scripting::handle_mission_command(const AP_Mission::Mission_Command& cmd_in)

View File

@ -39,6 +39,7 @@ public:
bool init_failed(void) const { return _init_failed; } bool init_failed(void) const { return _init_failed; }
bool enabled(void) const { return _enable != 0; }; bool enabled(void) const { return _enable != 0; };
bool should_run(void) const { return enabled() && !_stop; }
static AP_Scripting * get_singleton(void) { return _singleton; } static AP_Scripting * get_singleton(void) { return _singleton; }
@ -94,6 +95,8 @@ private:
AP_Int16 _dir_disable; AP_Int16 _dir_disable;
bool _init_failed; // true if memory allocation failed bool _init_failed; // true if memory allocation failed
bool _restart; // true if scripts should be restarted
bool _stop; // true if scripts should be stopped
static AP_Scripting *_singleton; static AP_Scripting *_singleton;

View File

@ -383,7 +383,7 @@ void lua_scripts::run(void) {
succeeded_initial_load = true; succeeded_initial_load = true;
#endif // __clang_analyzer__ #endif // __clang_analyzer__
while (AP_Scripting::get_singleton()->enabled()) { while (AP_Scripting::get_singleton()->should_run()) {
// handle terminal data if we have any // handle terminal data if we have any
if (terminal.session) { if (terminal.session) {
doREPL(L); doREPL(L);