mirror of
https://github.com/MarlinFirmware/Marlin.git
synced 2024-11-26 13:25:54 +00:00
Add MACHINE_COMMAND_MACROS
This commit is contained in:
parent
aa44542f76
commit
456b25996b
@ -1954,6 +1954,10 @@
|
|||||||
#define DEFAULT_SHARED_VOLUME SV_USB_FLASH_DRIVE
|
#define DEFAULT_SHARED_VOLUME SV_USB_FLASH_DRIVE
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
// Emulate RepRapFirmware with macro files stored in /sys and /macros
|
||||||
|
// Provide the M98 command to run a macro file as a sub-program
|
||||||
|
//#define MACHINE_COMMAND_MACROS
|
||||||
|
|
||||||
#endif // HAS_MEDIA
|
#endif // HAS_MEDIA
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
49
Marlin/src/gcode/sdcard/M98.cpp
Normal file
49
Marlin/src/gcode/sdcard/M98.cpp
Normal file
@ -0,0 +1,49 @@
|
|||||||
|
/**
|
||||||
|
* Marlin 3D Printer Firmware
|
||||||
|
* Copyright (c) 2022 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
|
||||||
|
* along with this program. If not, see <https://www.gnu.org/licenses/>.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include "../../inc/MarlinConfig.h"
|
||||||
|
|
||||||
|
#if ENABLED(MACHINE_COMMAND_MACROS)
|
||||||
|
|
||||||
|
#include "../gcode.h"
|
||||||
|
#include "../../sd/cardreader.h"
|
||||||
|
|
||||||
|
/**
|
||||||
|
* M98: Select file and run as sub-procedure
|
||||||
|
*
|
||||||
|
* P<path> - The plain (DOS 8.3) filepath
|
||||||
|
*
|
||||||
|
* Example:
|
||||||
|
* M98 P/macros/home.g ; Run home.g (as a procedure)
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
void GcodeSuite::M98() {
|
||||||
|
if (card.isMounted() && parser.seen('P')) {
|
||||||
|
char *path = parser.value_string();
|
||||||
|
char *lb = strchr(p, ' ');
|
||||||
|
if (!lb) lb = strchr(p, ';');
|
||||||
|
if (lb) *lb = '\0';
|
||||||
|
card.runMacro(path);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
#endif // MACHINE_COMMAND_MACROS
|
@ -806,6 +806,15 @@ bool CardReader::fileExists(const char * const path) {
|
|||||||
return success;
|
return success;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#if ENABLED(MACHINE_COMMAND_MACROS)
|
||||||
|
|
||||||
|
void CardReader::runMacro(const char * const path) {
|
||||||
|
openFileRead(path, 2);
|
||||||
|
startFileprint();
|
||||||
|
}
|
||||||
|
|
||||||
|
#endif
|
||||||
|
|
||||||
//
|
//
|
||||||
// Delete a file by name in the working directory
|
// Delete a file by name in the working directory
|
||||||
//
|
//
|
||||||
|
@ -142,6 +142,10 @@ public:
|
|||||||
static bool selectNewestFile();
|
static bool selectNewestFile();
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#if ENABLED(MACHINE_COMMAND_MACROS)
|
||||||
|
static void runMacro(const char * const path);
|
||||||
|
#endif
|
||||||
|
|
||||||
// Basic file ops
|
// Basic file ops
|
||||||
static void openFileRead(const char * const path, const uint8_t subcall=0);
|
static void openFileRead(const char * const path, const uint8_t subcall=0);
|
||||||
static void openFileWrite(const char * const path);
|
static void openFileWrite(const char * const path);
|
||||||
@ -150,6 +154,7 @@ public:
|
|||||||
static void removeFile(const char * const name);
|
static void removeFile(const char * const name);
|
||||||
|
|
||||||
static char* longest_filename() { return longFilename[0] ? longFilename : filename; }
|
static char* longest_filename() { return longFilename[0] ? longFilename : filename; }
|
||||||
|
|
||||||
#if ENABLED(LONG_FILENAME_HOST_SUPPORT)
|
#if ENABLED(LONG_FILENAME_HOST_SUPPORT)
|
||||||
static void printLongPath(char * const path); // Used by M33
|
static void printLongPath(char * const path); // Used by M33
|
||||||
static void getLongPath(char * const pathLong, char * const pathShort); // Used by anycubic_vyper
|
static void getLongPath(char * const pathLong, char * const pathShort); // Used by anycubic_vyper
|
||||||
|
Loading…
Reference in New Issue
Block a user