Clean up host actions code (#16856)
This commit is contained in:
		| @@ -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); |       #if HAS_FILAMENT_SENSOR | ||||||
|     SERIAL_EOL(); |         || runout.filament_ran_out | ||||||
|  |       #endif | ||||||
|  |     ); | ||||||
|  |     host_prompt_do(PROMPT_FILAMENT_RUNOUT, PSTR("Paused"), PSTR("PurgeMore"), | ||||||
|  |       disable_to_continue ? PSTR("DisableRunout") : CONTINUE_STR | ||||||
|  |     ); | ||||||
|   } |   } | ||||||
|  |  | ||||||
|  |   // | ||||||
|  |   // 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) { |   void host_response_handler(const uint8_t response) { | ||||||
|     #ifdef DEBUG_HOST_ACTIONS |     #ifdef DEBUG_HOST_ACTIONS | ||||||
|       SERIAL_ECHOLNPAIR("M876 Handle Reason: ", host_prompt_reason); |       static const char m876_prefix[] PROGMEM = "M876 Handle Re"; | ||||||
|       SERIAL_ECHOLNPAIR("M876 Handle Response: ", response); |       serialprintPGM(m876_prefix); SERIAL_ECHOLNPAIR("ason: ", host_prompt_reason); | ||||||
|  |       serialprintPGM(m876_prefix); SERIAL_ECHOLNPAIR("sponse: ", response); | ||||||
|     #endif |     #endif | ||||||
|     const char *msg = PSTR("UNKNOWN STATE"); |     const char *msg = PSTR("UNKNOWN STATE"); | ||||||
|     const PromptReason hpr = host_prompt_reason; |     const PromptReason hpr = host_prompt_reason; | ||||||
|     host_prompt_reason = PROMPT_NOT_DEFINED; |     host_prompt_reason = PROMPT_NOT_DEFINED;  // Reset now ahead of logic | ||||||
|     switch (hpr) { |     switch (hpr) { | ||||||
|       case PROMPT_FILAMENT_RUNOUT: |       case PROMPT_FILAMENT_RUNOUT: | ||||||
|         msg = PSTR("FILAMENT_RUNOUT"); |         msg = PSTR("FILAMENT_RUNOUT"); | ||||||
|         if (response == 0) { |         switch (response) { | ||||||
|           #if ENABLED(ADVANCED_PAUSE_FEATURE) |  | ||||||
|             pause_menu_response = PAUSE_RESPONSE_EXTRUDE_MORE; |           case 0: // "Purge More" button | ||||||
|           #endif |             #if HAS_LCD_MENU && ENABLED(ADVANCED_PAUSE_FEATURE) | ||||||
|           host_action_prompt_end();   // Close current prompt |               pause_menu_response = PAUSE_RESPONSE_EXTRUDE_MORE;  // Simulate menu selection (menu exits, doesn't extrude more) | ||||||
|           host_action_prompt_begin(PSTR("Paused")); |  | ||||||
|           host_action_prompt_button(PSTR("Purge More")); |  | ||||||
|           if (false |  | ||||||
|             #if HAS_FILAMENT_SENSOR |  | ||||||
|               || runout.filament_ran_out |  | ||||||
|             #endif |             #endif | ||||||
|           ) |             filament_load_host_prompt();                          // Initiate another host prompt. (NOTE: The loop in load_filament may also do this!) | ||||||
|             host_action_prompt_button(PSTR("DisableRunout")); |             break; | ||||||
|           else { |  | ||||||
|             host_prompt_reason = PROMPT_FILAMENT_RUNOUT; |           case 1: // "Continue" / "Disable Runout" button | ||||||
|             host_action_prompt_button(CONTINUE_STR); |             #if HAS_LCD_MENU && ENABLED(ADVANCED_PAUSE_FEATURE) | ||||||
|           } |               pause_menu_response = PAUSE_RESPONSE_RESUME_PRINT;  // Simulate menu selection | ||||||
|           host_action_prompt_show(); |             #endif | ||||||
|         } |             #if HAS_FILAMENT_SENSOR | ||||||
|         else if (response == 1) { |               if (runout.filament_ran_out) {                      // Disable a triggered sensor | ||||||
|           #if HAS_FILAMENT_SENSOR |                 runout.enabled = false; | ||||||
|             if (runout.filament_ran_out) { |                 runout.reset(); | ||||||
|               runout.enabled = false; |               } | ||||||
|               runout.reset(); |             #endif | ||||||
|             } |             break; | ||||||
|           #endif |  | ||||||
|           #if ENABLED(ADVANCED_PAUSE_FEATURE) |  | ||||||
|             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 (pause_mode == PAUSE_MODE_PAUSE_PRINT) return; |  | ||||||
|  |     #if HAS_LCD_MENU | ||||||
|  |       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 | ||||||
|   PAUSE_RESPONSE_WAIT_FOR, |   enum PauseMenuResponse : char { | ||||||
|   PAUSE_RESPONSE_EXTRUDE_MORE, |     PAUSE_RESPONSE_WAIT_FOR, | ||||||
|   PAUSE_RESPONSE_RESUME_PRINT |     PAUSE_RESPONSE_EXTRUDE_MORE, | ||||||
| }; |     PAUSE_RESPONSE_RESUME_PRINT | ||||||
|  |   }; | ||||||
| extern PauseMode pause_mode; |   extern PauseMenuResponse pause_menu_response; | ||||||
| extern PauseMenuResponse pause_menu_response; |   extern PauseMode pause_mode; | ||||||
|  | #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 | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user