2018-04-06 14:49:33 +00:00
|
|
|
#ifndef slic3r_GUI_Snapshot_
|
|
|
|
#define slic3r_GUI_Snapshot_
|
|
|
|
|
2018-04-11 10:21:15 +00:00
|
|
|
#include <map>
|
|
|
|
#include <set>
|
2018-04-06 14:49:33 +00:00
|
|
|
#include <string>
|
|
|
|
#include <vector>
|
|
|
|
|
|
|
|
#include <boost/filesystem.hpp>
|
|
|
|
|
2018-04-09 15:03:37 +00:00
|
|
|
#include "Version.hpp"
|
2018-04-06 14:49:33 +00:00
|
|
|
#include "../Utils/Semver.hpp"
|
|
|
|
|
|
|
|
namespace Slic3r {
|
|
|
|
|
|
|
|
class AppConfig;
|
|
|
|
|
|
|
|
namespace GUI {
|
|
|
|
namespace Config {
|
|
|
|
|
2018-04-09 15:03:37 +00:00
|
|
|
class Version;
|
2018-04-11 10:21:15 +00:00
|
|
|
class Index;
|
2018-04-09 15:03:37 +00:00
|
|
|
|
2018-04-06 14:49:33 +00:00
|
|
|
// A snapshot contains:
|
|
|
|
// Slic3r.ini
|
|
|
|
// vendor/
|
|
|
|
// print/
|
|
|
|
// filament/
|
|
|
|
// printer/
|
|
|
|
class Snapshot
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
enum Reason {
|
|
|
|
SNAPSHOT_UNKNOWN,
|
|
|
|
SNAPSHOT_UPGRADE,
|
|
|
|
SNAPSHOT_DOWNGRADE,
|
2018-04-20 08:26:23 +00:00
|
|
|
SNAPSHOT_BEFORE_ROLLBACK,
|
2018-04-06 14:49:33 +00:00
|
|
|
SNAPSHOT_USER,
|
|
|
|
};
|
|
|
|
|
|
|
|
Snapshot() { clear(); }
|
|
|
|
|
|
|
|
void clear();
|
|
|
|
void load_ini(const std::string &path);
|
|
|
|
void save_ini(const std::string &path);
|
|
|
|
|
|
|
|
// Export the print / filament / printer selections to be activated into the AppConfig.
|
|
|
|
void export_selections(AppConfig &config) const;
|
2018-04-11 10:21:15 +00:00
|
|
|
void export_vendor_configs(AppConfig &config) const;
|
2018-04-06 14:49:33 +00:00
|
|
|
|
2018-04-20 08:26:23 +00:00
|
|
|
// Perform a deep compare of the active print / filament / printer / vendor directories.
|
|
|
|
// Return true if the content of the current print / filament / printer / vendor directories
|
|
|
|
// matches the state stored in this snapshot.
|
|
|
|
bool equal_to_active(const AppConfig &app_config) const;
|
|
|
|
|
2018-04-06 14:49:33 +00:00
|
|
|
// ID of a snapshot should equal to the name of the snapshot directory.
|
|
|
|
// The ID contains the date/time, reason and comment to be human readable.
|
|
|
|
std::string id;
|
|
|
|
std::time_t time_captured;
|
|
|
|
// Which Slic3r version captured this snapshot?
|
|
|
|
Semver slic3r_version_captured = Semver::invalid();
|
|
|
|
// Comment entered by the user at the start of the snapshot capture.
|
|
|
|
std::string comment;
|
|
|
|
Reason reason;
|
|
|
|
|
2018-04-12 09:24:03 +00:00
|
|
|
std::string format_reason() const;
|
|
|
|
|
2018-04-06 14:49:33 +00:00
|
|
|
// Active presets at the time of the snapshot.
|
|
|
|
std::string print;
|
|
|
|
std::vector<std::string> filaments;
|
|
|
|
std::string printer;
|
|
|
|
|
|
|
|
// Annotation of the vendor configuration stored in the snapshot.
|
|
|
|
// This information is displayed to the user and used to decide compatibility
|
|
|
|
// of the configuration stored in the snapshot with the running Slic3r version.
|
|
|
|
struct VendorConfig {
|
|
|
|
// Name of the vendor contained in this snapshot.
|
|
|
|
std::string name;
|
|
|
|
// Version of the vendor config contained in this snapshot.
|
|
|
|
Semver version = Semver::invalid();
|
|
|
|
// Minimum Slic3r version compatible with this vendor configuration.
|
|
|
|
Semver min_slic3r_version = Semver::zero();
|
|
|
|
// Maximum Slic3r version compatible with this vendor configuration, or empty.
|
|
|
|
Semver max_slic3r_version = Semver::inf();
|
2018-04-11 10:21:15 +00:00
|
|
|
// Which printer models of this vendor were installed, and which variants of the models?
|
|
|
|
std::map<std::string, std::set<std::string>> models_variants_installed;
|
2018-04-06 14:49:33 +00:00
|
|
|
};
|
2018-04-20 08:26:23 +00:00
|
|
|
// List of vendor configs contained in this snapshot, sorted lexicographically.
|
2018-04-06 14:49:33 +00:00
|
|
|
std::vector<VendorConfig> vendor_configs;
|
|
|
|
};
|
|
|
|
|
|
|
|
class SnapshotDB
|
|
|
|
{
|
|
|
|
public:
|
2018-04-09 15:03:37 +00:00
|
|
|
// Initialize the SnapshotDB singleton instance. Load the database if it has not been loaded yet.
|
|
|
|
static SnapshotDB& singleton();
|
|
|
|
|
2018-04-06 14:49:33 +00:00
|
|
|
typedef std::vector<Snapshot>::const_iterator const_iterator;
|
|
|
|
|
|
|
|
// Load the snapshot database from the snapshots directory.
|
|
|
|
// If the snapshot directory or its parent does not exist yet, it will be created.
|
|
|
|
// Returns a number of snapshots loaded.
|
|
|
|
size_t load_db();
|
2018-04-09 15:03:37 +00:00
|
|
|
void update_slic3r_versions(std::vector<Index> &index_db);
|
2018-04-06 14:49:33 +00:00
|
|
|
|
|
|
|
// Create a snapshot directory, copy the vendor config bundles, user print/filament/printer profiles,
|
|
|
|
// create an index.
|
2018-04-16 14:52:11 +00:00
|
|
|
const Snapshot& take_snapshot(const AppConfig &app_config, Snapshot::Reason reason, const std::string &comment = "");
|
2018-04-20 08:26:23 +00:00
|
|
|
const Snapshot& restore_snapshot(const std::string &id, AppConfig &app_config);
|
2018-04-06 14:49:33 +00:00
|
|
|
void restore_snapshot(const Snapshot &snapshot, AppConfig &app_config);
|
2018-04-20 08:26:23 +00:00
|
|
|
// Test whether the AppConfig's on_snapshot variable points to an existing snapshot, and the existing snapshot
|
|
|
|
// matches the current state. If it does not match the current state, the AppConfig's "on_snapshot" ID is reset.
|
|
|
|
bool is_on_snapshot(AppConfig &app_config) const;
|
|
|
|
// Finds the newest snapshot, which contains a config bundle for vendor_name with config_version.
|
|
|
|
const_iterator snapshot_with_vendor_preset(const std::string &vendor_name, const Semver &config_version);
|
2018-04-06 14:49:33 +00:00
|
|
|
|
|
|
|
const_iterator begin() const { return m_snapshots.begin(); }
|
|
|
|
const_iterator end() const { return m_snapshots.end(); }
|
2018-04-20 08:26:23 +00:00
|
|
|
const_iterator snapshot(const std::string &id) const;
|
2018-04-06 14:49:33 +00:00
|
|
|
const std::vector<Snapshot>& snapshots() const { return m_snapshots; }
|
|
|
|
|
|
|
|
private:
|
|
|
|
// Create the snapshots directory if it does not exist yet.
|
|
|
|
static boost::filesystem::path create_db_dir();
|
|
|
|
|
2018-04-20 08:26:23 +00:00
|
|
|
// Snapshots are sorted by their date/time, oldest first.
|
2018-04-06 14:49:33 +00:00
|
|
|
std::vector<Snapshot> m_snapshots;
|
|
|
|
};
|
|
|
|
|
|
|
|
} // namespace Config
|
|
|
|
} // namespace GUI
|
|
|
|
} // namespace Slic3r
|
|
|
|
|
|
|
|
#endif /* slic3r_GUI_Snapshot_ */
|