|
1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071 |
- #pragma once
- #include <jansson.h>
-
- #include <common.hpp>
-
-
- namespace rack {
- /** Handles the Rack patch file state */
- namespace patch {
-
-
- /** Handles the Rack patch file state. */
- struct Manager {
- struct Internal;
- Internal* internal;
-
- /** The currently loaded patch file path */
- std::string path;
- /** Path to autosave dir */
- std::string autosavePath;
- /** Path to user template patch */
- std::string templatePath;
- /** Path to factory template patch */
- std::string factoryTemplatePath;
-
- PRIVATE Manager();
- PRIVATE ~Manager();
- PRIVATE void launch(std::string pathArg);
- /** Clears the patch. */
- void clear();
- /** Saves the patch and nothing else. */
- void save(std::string path);
- void saveDialog();
- void saveAsDialog(bool setPath = true);
- void saveTemplateDialog();
- void saveAutosave();
- /** Delete and re-create autosave dir. */
- void clearAutosave();
- /** Clean up nonexistent module patch storage dirs in autosave dir. */
- void cleanAutosave();
- /** Loads a patch and nothing else.
- Returns whether the patch was loaded successfully.
- */
- void load(std::string path);
- /** Loads the template patch file. */
- void loadTemplate();
- void loadTemplateDialog();
- bool hasAutosave();
- /** Loads the patch from the autosave folder. */
- void loadAutosave();
- /** Loads a patch, sets the current path, and updates the recent patches. */
- void loadAction(std::string path);
- void loadDialog();
- void loadPathDialog(std::string path);
- /** Asks the user to reload the current patch. */
- void revertDialog();
- void pushRecentPath(std::string path);
- /** Disconnects all cables. */
- void disconnectDialog();
-
- json_t* toJson();
- void fromJson(json_t* rootJ);
- /** Checks if the JSON patch object contains modules not found in the loaded plugins, and launches a dialog box asking the user to cancel loading.
- Returns whether the user requests to cancel loading the patch.
- */
- bool checkUnavailableModulesJson(json_t* rootJ);
- };
-
-
- } // namespace patch
- } // namespace rack
|