Clean up host actions code (#16856)
This commit is contained in:
parent
ff0c931e47
commit
00ba053c90
|
@ -84,70 +84,78 @@ void host_action(const char * const pstr, const bool eol) {
|
||||||
if (eol) SERIAL_EOL();
|
if (eol) SERIAL_EOL();
|
||||||
}
|
}
|
||||||
|
|
||||||
void host_action_prompt_plus(const char * const ptype, const char * const pstr, const bool eol=true) {
|
void host_action_prompt_plus(const char * const ptype, const char * const pstr, const char extra_char='\0') {
|
||||||
host_action_prompt(ptype, false);
|
host_action_prompt(ptype, false);
|
||||||
SERIAL_CHAR(' ');
|
SERIAL_CHAR(' ');
|
||||||
serialprintPGM(pstr);
|
serialprintPGM(pstr);
|
||||||
if (eol) SERIAL_EOL();
|
if (extra_char != '\0') SERIAL_CHAR(extra_char);
|
||||||
|
SERIAL_EOL();
|
||||||
|
}
|
||||||
|
void host_action_prompt_begin(const PromptReason reason, const char * const pstr, const char extra_char/*='\0'*/) {
|
||||||
|
host_action_prompt_end();
|
||||||
|
host_prompt_reason = reason;
|
||||||
|
host_action_prompt_plus(PSTR("begin"), pstr, extra_char);
|
||||||
}
|
}
|
||||||
void host_action_prompt_begin(const char * const pstr, const bool eol/*=true*/) { host_action_prompt_plus(PSTR("begin"), pstr, eol); }
|
|
||||||
void host_action_prompt_button(const char * const pstr) { host_action_prompt_plus(PSTR("button"), pstr); }
|
void host_action_prompt_button(const char * const pstr) { host_action_prompt_plus(PSTR("button"), pstr); }
|
||||||
void host_action_prompt_end() { host_action_prompt(PSTR("end")); }
|
void host_action_prompt_end() { host_action_prompt(PSTR("end")); }
|
||||||
void host_action_prompt_show() { host_action_prompt(PSTR("show")); }
|
void host_action_prompt_show() { host_action_prompt(PSTR("show")); }
|
||||||
void host_prompt_do(const PromptReason reason, const char * const pstr, const char * const pbtn/*=nullptr*/) {
|
void host_prompt_do(const PromptReason reason, const char * const pstr, const char * const btn1/*=nullptr*/, const char * const btn2/*=nullptr*/) {
|
||||||
host_prompt_reason = reason;
|
host_action_prompt_begin(reason, pstr);
|
||||||
host_action_prompt_end();
|
if (btn1) host_action_prompt_button(btn1);
|
||||||
host_action_prompt_begin(pstr);
|
if (btn2) host_action_prompt_button(btn2);
|
||||||
if (pbtn) host_action_prompt_button(pbtn);
|
|
||||||
host_action_prompt_show();
|
host_action_prompt_show();
|
||||||
}
|
}
|
||||||
|
|
||||||
inline void say_m876_response(const char * const pstr) {
|
void filament_load_host_prompt() {
|
||||||
SERIAL_ECHOPGM("M876 Responding PROMPT_");
|
const bool disable_to_continue = (false
|
||||||
serialprintPGM(pstr);
|
|
||||||
SERIAL_EOL();
|
|
||||||
}
|
|
||||||
|
|
||||||
void host_response_handler(const uint8_t response) {
|
|
||||||
#ifdef DEBUG_HOST_ACTIONS
|
|
||||||
SERIAL_ECHOLNPAIR("M876 Handle Reason: ", host_prompt_reason);
|
|
||||||
SERIAL_ECHOLNPAIR("M876 Handle Response: ", response);
|
|
||||||
#endif
|
|
||||||
const char *msg = PSTR("UNKNOWN STATE");
|
|
||||||
const PromptReason hpr = host_prompt_reason;
|
|
||||||
host_prompt_reason = PROMPT_NOT_DEFINED;
|
|
||||||
switch (hpr) {
|
|
||||||
case PROMPT_FILAMENT_RUNOUT:
|
|
||||||
msg = PSTR("FILAMENT_RUNOUT");
|
|
||||||
if (response == 0) {
|
|
||||||
#if ENABLED(ADVANCED_PAUSE_FEATURE)
|
|
||||||
pause_menu_response = PAUSE_RESPONSE_EXTRUDE_MORE;
|
|
||||||
#endif
|
|
||||||
host_action_prompt_end(); // Close current prompt
|
|
||||||
host_action_prompt_begin(PSTR("Paused"));
|
|
||||||
host_action_prompt_button(PSTR("Purge More"));
|
|
||||||
if (false
|
|
||||||
#if HAS_FILAMENT_SENSOR
|
#if HAS_FILAMENT_SENSOR
|
||||||
|| runout.filament_ran_out
|
|| runout.filament_ran_out
|
||||||
#endif
|
#endif
|
||||||
)
|
);
|
||||||
host_action_prompt_button(PSTR("DisableRunout"));
|
host_prompt_do(PROMPT_FILAMENT_RUNOUT, PSTR("Paused"), PSTR("PurgeMore"),
|
||||||
else {
|
disable_to_continue ? PSTR("DisableRunout") : CONTINUE_STR
|
||||||
host_prompt_reason = PROMPT_FILAMENT_RUNOUT;
|
);
|
||||||
host_action_prompt_button(CONTINUE_STR);
|
|
||||||
}
|
}
|
||||||
host_action_prompt_show();
|
|
||||||
}
|
//
|
||||||
else if (response == 1) {
|
// Handle responses from the host, such as:
|
||||||
|
// - Filament runout responses: Purge More, Continue
|
||||||
|
// - General "Continue" response
|
||||||
|
// - Resume Print response
|
||||||
|
// - Dismissal of info
|
||||||
|
//
|
||||||
|
void host_response_handler(const uint8_t response) {
|
||||||
|
#ifdef DEBUG_HOST_ACTIONS
|
||||||
|
static const char m876_prefix[] PROGMEM = "M876 Handle Re";
|
||||||
|
serialprintPGM(m876_prefix); SERIAL_ECHOLNPAIR("ason: ", host_prompt_reason);
|
||||||
|
serialprintPGM(m876_prefix); SERIAL_ECHOLNPAIR("sponse: ", response);
|
||||||
|
#endif
|
||||||
|
const char *msg = PSTR("UNKNOWN STATE");
|
||||||
|
const PromptReason hpr = host_prompt_reason;
|
||||||
|
host_prompt_reason = PROMPT_NOT_DEFINED; // Reset now ahead of logic
|
||||||
|
switch (hpr) {
|
||||||
|
case PROMPT_FILAMENT_RUNOUT:
|
||||||
|
msg = PSTR("FILAMENT_RUNOUT");
|
||||||
|
switch (response) {
|
||||||
|
|
||||||
|
case 0: // "Purge More" button
|
||||||
|
#if HAS_LCD_MENU && ENABLED(ADVANCED_PAUSE_FEATURE)
|
||||||
|
pause_menu_response = PAUSE_RESPONSE_EXTRUDE_MORE; // Simulate menu selection (menu exits, doesn't extrude more)
|
||||||
|
#endif
|
||||||
|
filament_load_host_prompt(); // Initiate another host prompt. (NOTE: The loop in load_filament may also do this!)
|
||||||
|
break;
|
||||||
|
|
||||||
|
case 1: // "Continue" / "Disable Runout" button
|
||||||
|
#if HAS_LCD_MENU && ENABLED(ADVANCED_PAUSE_FEATURE)
|
||||||
|
pause_menu_response = PAUSE_RESPONSE_RESUME_PRINT; // Simulate menu selection
|
||||||
|
#endif
|
||||||
#if HAS_FILAMENT_SENSOR
|
#if HAS_FILAMENT_SENSOR
|
||||||
if (runout.filament_ran_out) {
|
if (runout.filament_ran_out) { // Disable a triggered sensor
|
||||||
runout.enabled = false;
|
runout.enabled = false;
|
||||||
runout.reset();
|
runout.reset();
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
#if ENABLED(ADVANCED_PAUSE_FEATURE)
|
break;
|
||||||
pause_menu_response = PAUSE_RESPONSE_RESUME_PRINT;
|
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case PROMPT_USER_CONTINUE:
|
case PROMPT_USER_CONTINUE:
|
||||||
|
@ -168,7 +176,9 @@ void host_action(const char * const pstr, const bool eol) {
|
||||||
break;
|
break;
|
||||||
default: break;
|
default: break;
|
||||||
}
|
}
|
||||||
say_m876_response(msg);
|
SERIAL_ECHOPGM("M876 Responding PROMPT_");
|
||||||
|
serialprintPGM(msg);
|
||||||
|
SERIAL_EOL();
|
||||||
}
|
}
|
||||||
|
|
||||||
#endif // HOST_PROMPT_SUPPORT
|
#endif // HOST_PROMPT_SUPPORT
|
||||||
|
|
|
@ -61,13 +61,15 @@ void host_action(const char * const pstr, const bool eol=true);
|
||||||
|
|
||||||
void host_response_handler(const uint8_t response);
|
void host_response_handler(const uint8_t response);
|
||||||
void host_action_notify(const char * const message);
|
void host_action_notify(const char * const message);
|
||||||
void host_action_prompt_begin(const char * const pstr, const bool eol=true);
|
void host_action_prompt_begin(const PromptReason reason, const char * const pstr, const char extra_char='\0');
|
||||||
void host_action_prompt_button(const char * const pstr);
|
void host_action_prompt_button(const char * const pstr);
|
||||||
void host_action_prompt_end();
|
void host_action_prompt_end();
|
||||||
void host_action_prompt_show();
|
void host_action_prompt_show();
|
||||||
void host_prompt_do(const PromptReason type, const char * const pstr, const char * const pbtn=nullptr);
|
void host_prompt_do(const PromptReason reason, const char * const pstr, const char * const btn1=nullptr, const char * const btn2=nullptr);
|
||||||
inline void host_prompt_open(const PromptReason reason, const char * const pstr, const char * const pbtn=nullptr) {
|
inline void host_prompt_open(const PromptReason reason, const char * const pstr, const char * const btn1=nullptr, const char * const btn2=nullptr) {
|
||||||
if (host_prompt_reason == PROMPT_NOT_DEFINED) host_prompt_do(reason, pstr, pbtn);
|
if (host_prompt_reason == PROMPT_NOT_DEFINED) host_prompt_do(reason, pstr, btn1, btn2);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void filament_load_host_prompt();
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
|
@ -67,9 +67,10 @@
|
||||||
|
|
||||||
static xyze_pos_t resume_position;
|
static xyze_pos_t resume_position;
|
||||||
|
|
||||||
PauseMode pause_mode = PAUSE_MODE_PAUSE_PRINT;
|
#if HAS_LCD_MENU
|
||||||
|
PauseMenuResponse pause_menu_response;
|
||||||
PauseMenuResponse pause_menu_response;
|
PauseMode pause_mode = PAUSE_MODE_PAUSE_PRINT;
|
||||||
|
#endif
|
||||||
|
|
||||||
fil_change_settings_t fc_settings[EXTRUDERS];
|
fil_change_settings_t fc_settings[EXTRUDERS];
|
||||||
|
|
||||||
|
@ -85,7 +86,11 @@ fil_change_settings_t fc_settings[EXTRUDERS];
|
||||||
|
|
||||||
#if HAS_BUZZER
|
#if HAS_BUZZER
|
||||||
static void filament_change_beep(const int8_t max_beep_count, const bool init=false) {
|
static void filament_change_beep(const int8_t max_beep_count, const bool init=false) {
|
||||||
|
|
||||||
|
#if HAS_LCD_MENU
|
||||||
if (pause_mode == PAUSE_MODE_PAUSE_PRINT) return;
|
if (pause_mode == PAUSE_MODE_PAUSE_PRINT) return;
|
||||||
|
#endif
|
||||||
|
|
||||||
static millis_t next_buzz = 0;
|
static millis_t next_buzz = 0;
|
||||||
static int8_t runout_beep = 0;
|
static int8_t runout_beep = 0;
|
||||||
|
|
||||||
|
@ -186,11 +191,7 @@ bool load_filament(const float &slow_load_length/*=0*/, const float &fast_load_l
|
||||||
+ active_extruder
|
+ active_extruder
|
||||||
#endif
|
#endif
|
||||||
;
|
;
|
||||||
host_prompt_reason = PROMPT_USER_CONTINUE;
|
host_action_prompt_begin(PROMPT_USER_CONTINUE, PSTR("Load Filament T"), tool);
|
||||||
host_action_prompt_end();
|
|
||||||
host_action_prompt_begin(PSTR("Load Filament T"), false);
|
|
||||||
SERIAL_CHAR(tool);
|
|
||||||
SERIAL_EOL();
|
|
||||||
host_action_prompt_button(CONTINUE_STR);
|
host_action_prompt_button(CONTINUE_STR);
|
||||||
host_action_prompt_show();
|
host_action_prompt_show();
|
||||||
#endif
|
#endif
|
||||||
|
@ -247,10 +248,10 @@ bool load_filament(const float &slow_load_length/*=0*/, const float &fast_load_l
|
||||||
|
|
||||||
wait_for_user = true;
|
wait_for_user = true;
|
||||||
#if ENABLED(HOST_PROMPT_SUPPORT)
|
#if ENABLED(HOST_PROMPT_SUPPORT)
|
||||||
host_prompt_do(PROMPT_USER_CONTINUE, PSTR("Filament Purge Running..."), CONTINUE_STR);
|
host_prompt_do(PROMPT_USER_CONTINUE, PSTR("Filament Purging..."), CONTINUE_STR);
|
||||||
#endif
|
#endif
|
||||||
#if ENABLED(EXTENSIBLE_UI)
|
#if ENABLED(EXTENSIBLE_UI)
|
||||||
ExtUI::onUserConfirmRequired_P(PSTR("Filament Purge Running..."));
|
ExtUI::onUserConfirmRequired_P(PSTR("Filament Purging..."));
|
||||||
#endif
|
#endif
|
||||||
for (float purge_count = purge_length; purge_count > 0 && wait_for_user; --purge_count)
|
for (float purge_count = purge_length; purge_count > 0 && wait_for_user; --purge_count)
|
||||||
do_pause_e_move(1, ADVANCED_PAUSE_PURGE_FEEDRATE);
|
do_pause_e_move(1, ADVANCED_PAUSE_PURGE_FEEDRATE);
|
||||||
|
@ -269,27 +270,13 @@ bool load_filament(const float &slow_load_length/*=0*/, const float &fast_load_l
|
||||||
do_pause_e_move(purge_length, ADVANCED_PAUSE_PURGE_FEEDRATE);
|
do_pause_e_move(purge_length, ADVANCED_PAUSE_PURGE_FEEDRATE);
|
||||||
}
|
}
|
||||||
|
|
||||||
// Show "Purge More" / "Resume" menu and wait for reply
|
|
||||||
#if ENABLED(HOST_PROMPT_SUPPORT)
|
#if ENABLED(HOST_PROMPT_SUPPORT)
|
||||||
host_prompt_reason = PROMPT_FILAMENT_RUNOUT;
|
filament_load_host_prompt(); // Initiate another host prompt. (NOTE: host_response_handler may also do this!)
|
||||||
host_action_prompt_end(); // Close current prompt
|
|
||||||
host_action_prompt_begin(PSTR("Paused"));
|
|
||||||
host_action_prompt_button(PSTR("PurgeMore"));
|
|
||||||
if (false
|
|
||||||
#if HAS_FILAMENT_SENSOR
|
|
||||||
|| runout.filament_ran_out
|
|
||||||
#endif
|
|
||||||
)
|
|
||||||
host_action_prompt_button(PSTR("DisableRunout"));
|
|
||||||
else {
|
|
||||||
host_prompt_reason = PROMPT_FILAMENT_RUNOUT;
|
|
||||||
host_action_prompt_button(CONTINUE_STR);
|
|
||||||
}
|
|
||||||
host_action_prompt_show();
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if HAS_LCD_MENU
|
#if HAS_LCD_MENU
|
||||||
if (show_lcd) {
|
if (show_lcd) {
|
||||||
|
// Show "Purge More" / "Resume" menu and wait for reply
|
||||||
KEEPALIVE_STATE(PAUSED_FOR_USER);
|
KEEPALIVE_STATE(PAUSED_FOR_USER);
|
||||||
wait_for_user = false;
|
wait_for_user = false;
|
||||||
lcd_pause_show_message(PAUSE_MESSAGE_OPTION);
|
lcd_pause_show_message(PAUSE_MESSAGE_OPTION);
|
||||||
|
|
|
@ -59,14 +59,15 @@ enum PauseMessage : char {
|
||||||
PAUSE_MESSAGE_HEATING
|
PAUSE_MESSAGE_HEATING
|
||||||
};
|
};
|
||||||
|
|
||||||
enum PauseMenuResponse : char {
|
#if HAS_LCD_MENU
|
||||||
|
enum PauseMenuResponse : char {
|
||||||
PAUSE_RESPONSE_WAIT_FOR,
|
PAUSE_RESPONSE_WAIT_FOR,
|
||||||
PAUSE_RESPONSE_EXTRUDE_MORE,
|
PAUSE_RESPONSE_EXTRUDE_MORE,
|
||||||
PAUSE_RESPONSE_RESUME_PRINT
|
PAUSE_RESPONSE_RESUME_PRINT
|
||||||
};
|
};
|
||||||
|
extern PauseMenuResponse pause_menu_response;
|
||||||
extern PauseMode pause_mode;
|
extern PauseMode pause_mode;
|
||||||
extern PauseMenuResponse pause_menu_response;
|
#endif
|
||||||
|
|
||||||
extern fil_change_settings_t fc_settings[EXTRUDERS];
|
extern fil_change_settings_t fc_settings[EXTRUDERS];
|
||||||
|
|
||||||
|
|
|
@ -92,11 +92,7 @@ void event_filament_runout() {
|
||||||
|
|
||||||
//action:out_of_filament
|
//action:out_of_filament
|
||||||
#if ENABLED(HOST_PROMPT_SUPPORT)
|
#if ENABLED(HOST_PROMPT_SUPPORT)
|
||||||
host_prompt_reason = PROMPT_FILAMENT_RUNOUT;
|
host_action_prompt_begin(PROMPT_FILAMENT_RUNOUT, PSTR("FilamentRunout T"), tool);
|
||||||
host_action_prompt_end();
|
|
||||||
host_action_prompt_begin(PSTR("FilamentRunout T"), false);
|
|
||||||
SERIAL_CHAR(tool);
|
|
||||||
SERIAL_EOL();
|
|
||||||
host_action_prompt_show();
|
host_action_prompt_show();
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
|
|
@ -31,7 +31,9 @@
|
||||||
* M876: Handle Prompt Response
|
* M876: Handle Prompt Response
|
||||||
*/
|
*/
|
||||||
void GcodeSuite::M876() {
|
void GcodeSuite::M876() {
|
||||||
|
|
||||||
if (parser.seenval('S')) host_response_handler((uint8_t)parser.value_int());
|
if (parser.seenval('S')) host_response_handler((uint8_t)parser.value_int());
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
#endif // HOST_PROMPT_SUPPORT && !EMERGENCY_PARSER
|
#endif // HOST_PROMPT_SUPPORT && !EMERGENCY_PARSER
|
||||||
|
|
Loading…
Reference in a new issue