diff options
author | rtk0c <[email protected]> | 2021-06-05 19:44:54 -0700 |
---|---|---|
committer | rtk0c <[email protected]> | 2021-06-05 19:44:54 -0700 |
commit | a180e1b56025c6b7d81d2e587ad90531d29de44c (patch) | |
tree | 1c88361320371b508c81b52a28ae0579fcdd1fd7 /core/src/Model/Workflow/Workflow.hpp | |
parent | d3fa128d5408673b0ea8d3ba3435c38b258a5e7a (diff) |
Initial work on asset system (does not compile)
Diffstat (limited to 'core/src/Model/Workflow/Workflow.hpp')
-rw-r--r-- | core/src/Model/Workflow/Workflow.hpp | 25 |
1 files changed, 16 insertions, 9 deletions
diff --git a/core/src/Model/Workflow/Workflow.hpp b/core/src/Model/Workflow/Workflow.hpp index c57ac31..51596e5 100644 --- a/core/src/Model/Workflow/Workflow.hpp +++ b/core/src/Model/Workflow/Workflow.hpp @@ -1,5 +1,6 @@ #pragma once +#include "Model/Assets.hpp" #include "Model/Workflow/Value.hpp" #include "Utils/Vector.hpp" #include "cplt_fwd.hpp" @@ -174,17 +175,12 @@ protected: void OnDetach(); }; -struct WorkflowInfo +class Workflow : public Asset { - std::filesystem::path Path; - std::string Name; - std::string PathStringCache = Path.string(); - - std::unique_ptr<Workflow> LoadFromDisk() const; -}; +public: + using CategoryType = WorkflowAssetCategory; + static constinit const WorkflowAssetCategory Category; -class Workflow -{ private: friend class WorkflowNode; friend class WorkflowEvaluationContext; @@ -279,3 +275,14 @@ private: std::pair<WorkflowConnection&, size_t> AllocWorkflowConnection(); std::pair<std::unique_ptr<WorkflowNode>&, size_t> AllocWorkflowStep(); }; + +class WorkflowAssetCategory : public AssetCategory +{ +public: + virtual void DiscoverFiles(const std::function<void(SavedAsset)>& callback) const override; + virtual Workflow* CreateEmpty(const SavedAsset& diskForm) const override; + virtual Workflow* Load(const SavedAsset& diskForm) const override; + virtual void SetupDetailsTable(const char* tableId) const override; + virtual void DrawBigIcon(const SavedAsset& asset) const override; + virtual void DrawDetailsTableRow(const SavedAsset& asset) const override; +}; |