From 0b92b896f774d3c7ef3e063ace730d21de629f59 Mon Sep 17 00:00:00 2001 From: Alexandre Bique Date: Mon, 16 Sep 2024 11:34:39 +0200 Subject: [PATCH] Update undo draft (#420) * undo: better method name * undo: introduce change flags * undo: make the delta always be able to perform the redo Rationnale: redo is the forward operation and is the easiest * undo: style * undo: doc * undo: simplify the interface * undo: simplify the interface and update documentation --- include/clap/ext/draft/undo.h | 51 +++++++++++++++-------------------- 1 file changed, 22 insertions(+), 29 deletions(-) diff --git a/include/clap/ext/draft/undo.h b/include/clap/ext/draft/undo.h index 4b47bca2..61bf560f 100644 --- a/include/clap/ext/draft/undo.h +++ b/include/clap/ext/draft/undo.h @@ -41,26 +41,16 @@ extern "C" { /// and maybe an easier experience for the user because there's a single undo context versus one /// for the host and one for each plugin instance. -enum clap_undo_context_flags { - // While the host is within a change, it is impossible to perform undo or redo. - CLAP_UNDO_IS_WITHIN_CHANGE = 1 << 0, -}; - -enum clap_undo_delta_properties_flags { - // If not set, then all clap_undo_delta_properties's attributes become irrelevant. +typedef struct clap_undo_delta_properties { + // If false, then all clap_undo_delta_properties's attributes become irrelevant. // If set, then the plugin will provide deltas in host->change_made(). - CLAP_UNDO_DELTA_PROPERTIES_HAS_DELTA = 1 << 0, + bool has_delta; // If set, then the delta will be reusable in the future as long as the plugin is // compatible with the given format_version. - CLAP_UNDO_DELTA_PROPERTIES_IS_PERSISTENT = 1 << 1, -}; + bool are_delta_persistant; -typedef struct clap_undo_delta_properties { - // Bitmask of clap_undo_delta_properties_flags - uint64_t flags; - - // This represents the delta format version that the plugin is using. + // This represents the delta format version that the plugin is currently using. uint32_t format_version; } clap_undo_delta_properties_t; @@ -94,14 +84,18 @@ typedef struct clap_plugin_undo { const void *delta, size_t delta_size); - // Sets the undo context. - // flags: bitmask of clap_undo_context_flags values - // names: null terminated string if an redo/undo step exists, null otherwise. + // Indicate if it is currently possible to perform a redo or undo operation. + // if can_* is false then it invalidates the corresponding name. + // [main-thread] + void (CLAP_ABI *set_can_undo)(const clap_plugin_t *plugin, bool can_undo); + void (CLAP_ABI *set_can_redo)(const clap_plugin_t *plugin, bool can_redo); + + // Sets the name of the next undo or redo step. + // name: null terminated string if an redo/undo step exists, null otherwise. // [main-thread] - void(CLAP_ABI *set_context_info)(const clap_plugin_t *plugin, - uint64_t flags, - const char *undo_name, - const char *redo_name); + void (CLAP_ABI *set_undo_name)(const clap_plugin_t *plugin, const char *name); + void (CLAP_ABI *set_redo_name)(const clap_plugin_t *plugin, const char *name); + } clap_plugin_undo_t; typedef struct clap_host_undo { @@ -123,6 +117,8 @@ typedef struct clap_host_undo { // // delta: optional, it is a binary blobs used to perform the undo and redo. When not available // the host will save the plugin state and use state->load() to perform undo and redo. + // The plugin must be able to perform a redo operation using the delta, though the undo operation + // is only possible if delta_can_undo is true. // // Note: the provided delta may be used for incremental state saving and crash recovery. The // plugin can indicate a format version id and the validity lifetime for the binary blobs. @@ -138,16 +134,13 @@ typedef struct clap_host_undo { void(CLAP_ABI *change_made)(const clap_host_t *host, const char *name, const void *delta, - size_t delta_size); + size_t delta_size, + bool delta_can_undo); - // Asks the host to perform the next undo step. + // Asks the host to perform the next undo or redo step. // This operation may be asynchronous and isn't available while the host is within a change. // [main-thread] void(CLAP_ABI *undo)(const clap_host_t *host); - - // Asks the host to perform the next redo step. - // This operation may be asynchronous and isn't available while the host is within a change. - // [main-thread] void(CLAP_ABI *redo)(const clap_host_t *host); // Subscribes to or unsubscribes from undo context info. @@ -162,7 +155,7 @@ typedef struct clap_host_undo { // is_subscribed: set to true to receive context info // // [main-thread] - void(CLAP_ABI *set_context_info_subscription)(const clap_host_t *host, bool is_subscribed); + void(CLAP_ABI *set_wants_context_updates)(const clap_host_t *host, bool is_subscribed); } clap_host_undo_t; #ifdef __cplusplus