2020-03-28 08:18:53 +00:00
|
|
|
/**
|
|
|
|
* Marlin 3D Printer Firmware
|
|
|
|
* Copyright (c) 2020 MarlinFirmware [https://github.com/MarlinFirmware/Marlin]
|
|
|
|
*
|
|
|
|
* Based on Sprinter and grbl.
|
|
|
|
* Copyright (c) 2011 Camiel Gubbels / Erik van der Zalm
|
|
|
|
*
|
|
|
|
* This program is free software: you can redistribute it and/or modify
|
|
|
|
* it under the terms of the GNU General Public License as published by
|
|
|
|
* the Free Software Foundation, either version 3 of the License, or
|
|
|
|
* (at your option) any later version.
|
|
|
|
*
|
|
|
|
* This program is distributed in the hope that it will be useful,
|
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
* GNU General Public License for more details.
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU General Public License
|
2020-07-23 03:20:14 +00:00
|
|
|
* along with this program. If not, see <https://www.gnu.org/licenses/>.
|
2020-03-28 08:18:53 +00:00
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include "../../inc/MarlinConfig.h"
|
|
|
|
|
|
|
|
#if ENABLED(SDSUPPORT)
|
|
|
|
|
|
|
|
#include "../gcode.h"
|
2021-05-08 09:35:35 +00:00
|
|
|
#include "../../module/planner.h"
|
2020-03-28 08:18:53 +00:00
|
|
|
#include "../../module/printcounter.h"
|
2021-10-05 04:23:02 +00:00
|
|
|
#include "../../module/temperature.h"
|
2021-05-13 20:10:48 +00:00
|
|
|
#include "../../sd/cardreader.h"
|
2020-12-07 11:53:15 +00:00
|
|
|
|
2020-04-12 02:27:49 +00:00
|
|
|
#ifdef SD_FINISHED_RELEASECOMMAND
|
|
|
|
#include "../queue.h"
|
|
|
|
#endif
|
|
|
|
|
2020-03-28 08:18:53 +00:00
|
|
|
#if EITHER(LCD_SET_PROGRESS_MANUALLY, SD_REPRINT_LAST_SELECTED_FILE)
|
2020-10-17 00:36:25 +00:00
|
|
|
#include "../../lcd/marlinui.h"
|
2020-03-28 08:18:53 +00:00
|
|
|
#endif
|
|
|
|
|
|
|
|
#if ENABLED(POWER_LOSS_RECOVERY)
|
|
|
|
#include "../../feature/powerloss.h"
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#if HAS_LEDS_OFF_FLAG
|
2021-01-21 09:40:07 +00:00
|
|
|
#include "../../MarlinCore.h" // for wait_for_user_response()
|
2020-03-28 08:18:53 +00:00
|
|
|
#include "../../feature/leds/printer_event_leds.h"
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#if ENABLED(EXTENSIBLE_UI)
|
|
|
|
#include "../../lcd/extui/ui_api.h"
|
2021-09-07 07:15:24 +00:00
|
|
|
#elif ENABLED(DWIN_CREALITY_LCD_ENHANCED)
|
2022-02-05 16:30:17 +00:00
|
|
|
#include "../../lcd/e3v2/proui/dwin.h"
|
2020-03-28 08:18:53 +00:00
|
|
|
#endif
|
|
|
|
|
|
|
|
#if ENABLED(HOST_ACTION_COMMANDS)
|
|
|
|
#include "../../feature/host_actions.h"
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#ifndef PE_LEDS_COMPLETED_TIME
|
|
|
|
#define PE_LEDS_COMPLETED_TIME (30*60)
|
|
|
|
#endif
|
|
|
|
|
|
|
|
/**
|
|
|
|
* M1001: Execute actions for SD print completion
|
|
|
|
*/
|
|
|
|
void GcodeSuite::M1001() {
|
2021-05-08 09:35:35 +00:00
|
|
|
planner.synchronize();
|
|
|
|
|
|
|
|
// SD Printing is finished when the queue reaches M1001
|
|
|
|
card.flag.sdprinting = card.flag.sdprintdone = false;
|
|
|
|
|
2020-12-07 11:53:15 +00:00
|
|
|
// If there's another auto#.g file to run...
|
2020-12-15 03:06:56 +00:00
|
|
|
if (TERN(NO_SD_AUTOSTART, false, card.autofile_check())) return;
|
2020-12-07 11:53:15 +00:00
|
|
|
|
|
|
|
// Purge the recovery file...
|
|
|
|
TERN_(POWER_LOSS_RECOVERY, recovery.purge());
|
2020-03-28 08:18:53 +00:00
|
|
|
|
|
|
|
// Report total print time
|
|
|
|
const bool long_print = print_job_timer.duration() > 60;
|
2021-09-25 23:43:52 +00:00
|
|
|
if (long_print) process_subcommands_now(F("M31"));
|
2020-03-28 08:18:53 +00:00
|
|
|
|
|
|
|
// Stop the print job timer
|
2021-09-25 23:43:52 +00:00
|
|
|
process_subcommands_now(F("M77"));
|
2020-03-28 08:18:53 +00:00
|
|
|
|
|
|
|
// Set the progress bar "done" state
|
2020-04-22 21:35:03 +00:00
|
|
|
TERN_(LCD_SET_PROGRESS_MANUALLY, ui.set_progress_done());
|
2020-03-28 08:18:53 +00:00
|
|
|
|
|
|
|
// Announce SD file completion
|
2020-08-21 22:06:51 +00:00
|
|
|
{
|
2021-03-09 09:20:37 +00:00
|
|
|
PORT_REDIRECT(SerialMask::All);
|
2020-08-21 22:06:51 +00:00
|
|
|
SERIAL_ECHOLNPGM(STR_FILE_PRINTED);
|
|
|
|
}
|
2020-03-28 08:18:53 +00:00
|
|
|
|
|
|
|
// Update the status LED color
|
|
|
|
#if HAS_LEDS_OFF_FLAG
|
|
|
|
if (long_print) {
|
|
|
|
printerEventLEDs.onPrintCompleted();
|
2021-09-26 03:11:48 +00:00
|
|
|
TERN_(EXTENSIBLE_UI, ExtUI::onUserConfirmRequired(GET_TEXT_F(MSG_PRINT_DONE)));
|
2021-10-15 05:24:08 +00:00
|
|
|
TERN_(HOST_PROMPT_SUPPORT, hostui.prompt_do(PROMPT_USER_CONTINUE, GET_TEXT_F(MSG_PRINT_DONE), FPSTR(CONTINUE_STR)));
|
2022-01-25 21:33:03 +00:00
|
|
|
TERN_(HAS_RESUME_CONTINUE, wait_for_user_response(SEC_TO_MS(TERN(HAS_MARLINUI_MENU, PE_LEDS_COMPLETED_TIME, 30))));
|
2020-03-28 08:18:53 +00:00
|
|
|
printerEventLEDs.onResumeAfterWait();
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
2020-04-12 02:27:49 +00:00
|
|
|
// Inject SD_FINISHED_RELEASECOMMAND, if any
|
|
|
|
#ifdef SD_FINISHED_RELEASECOMMAND
|
2021-09-25 23:43:52 +00:00
|
|
|
process_subcommands_now(F(SD_FINISHED_RELEASECOMMAND));
|
2020-03-28 08:18:53 +00:00
|
|
|
#endif
|
|
|
|
|
2020-11-05 22:45:22 +00:00
|
|
|
TERN_(EXTENSIBLE_UI, ExtUI::onPrintFinished());
|
2021-09-07 07:15:24 +00:00
|
|
|
TERN_(DWIN_CREALITY_LCD_ENHANCED, DWIN_Print_Finished());
|
2020-11-05 22:45:22 +00:00
|
|
|
|
2020-03-28 08:18:53 +00:00
|
|
|
// Re-select the last printed file in the UI
|
2020-04-22 21:35:03 +00:00
|
|
|
TERN_(SD_REPRINT_LAST_SELECTED_FILE, ui.reselect_last_file());
|
2020-03-28 08:18:53 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
#endif // SDSUPPORT
|