Ansel 0.0
A darktable fork - bloat + design vision
Loading...
Searching...
No Matches
dev_history.h
Go to the documentation of this file.
1/*
2 This file is part of the Ansel project.
3 Copyright (C) 2025 Alynx Zhou.
4 Copyright (C) 2025-2026 Aurélien PIERRE.
5
6 Ansel is free software: you can redistribute it and/or modify
7 it under the terms of the GNU General Public License as published by
8 the Free Software Foundation, either version 3 of the License, or
9 (at your option) any later version.
10
11 Ansel is distributed in the hope that it will be useful,
12 but WITHOUT ANY WARRANTY; without even the implied warranty of
13 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 GNU General Public License for more details.
15
16 You should have received a copy of the GNU General Public License
17 along with Ansel. If not, see <http://www.gnu.org/licenses/>.
18*/
19#include "common/history.h"
21
22#include <glib.h>
23
24#pragma once
25
35#ifdef __cplusplus
36extern "C" {
37#endif
38
39#ifndef DT_IOP_PARAMS_T
40#define DT_IOP_PARAMS_T
41typedef void dt_iop_params_t;
42#endif
43
44struct dt_iop_module_t;
46struct dt_develop_t;
47
49{
50 struct dt_iop_module_t *module; // pointer to image operation module
51 gboolean enabled; // switched respective module on/off
52 dt_iop_params_t *params; // parameters for this operation
53 int params_size; // serialized params size
54 int module_version; // serialized module version
56 int blendop_params_size; // serialized blend params size
57 int blendop_version; // serialized blend version
58 char op_name[32];
61 char multi_name[128];
62 GList *forms; // snapshot of dt_develop_t->forms
63 int num; // num of history on database
64
65 uint64_t hash; // module params hash.
67
68
77
83void dt_dev_free_history_item(gpointer data);
84
125 struct dt_iop_module_t *module, gboolean enabled,
126 const void *params, const int32_t params_size,
127 const struct dt_develop_blend_params_t *blend_params, GList *forms);
128
136int dt_dev_next_multi_priority_for_op(struct dt_develop_t *dev, const char *op);
137
149struct dt_iop_module_t *dt_dev_get_module_instance(struct dt_develop_t *dev, const char *op, const char *multi_name,
150 const int multi_priority);
151
162struct dt_iop_module_t *dt_dev_create_module_instance(struct dt_develop_t *dev, const char *op, const char *multi_name,
163 const int multi_priority, gboolean use_next_priority);
176int dt_dev_copy_module_contents(struct dt_develop_t *dev_dest, struct dt_develop_t *dev_src,
177 struct dt_iop_module_t *mod_dest, const struct dt_iop_module_t *mod_src);
178
193 const struct dt_dev_history_item_t *hist_src,
194 struct dt_iop_module_t *mod_dest,
195 struct dt_dev_history_item_t **out_hist);
196
209int dt_dev_merge_history_into_image(struct dt_develop_t *dev_src, int32_t dest_imgid, const GList *mod_list,
210 gboolean merge_iop_order, const dt_history_merge_strategy_t mode,
211 const gboolean paste_instances, const char *source_label,
212 dt_hm_batch_state_t *batch);
225int dt_dev_replace_history_on_image(struct dt_develop_t *dev_src, const int32_t dest_imgid,
226 const gboolean reload_defaults, const char *msg);
227
242gboolean dt_dev_add_history_item_ext(struct dt_develop_t *dev, struct dt_iop_module_t *module, gboolean enable,
243 gboolean force_new_item);
244
256void dt_dev_add_history_item_real(struct dt_develop_t *dev, struct dt_iop_module_t *module, gboolean enable, gboolean redraw);
257
258// Debug helper to follow calls to `dt_dev_add_history_item_real()`, but mostly to follow useless pipe recomputations.
259#define dt_dev_add_history_item(dev, module, enable, redraw) DT_DEBUG_TRACE_WRAPPER(DT_DEBUG_DEV, dt_dev_add_history_item_real, (dev), (module), (enable), (redraw))
260
261
270void dt_dev_write_history_ext(struct dt_develop_t *dev, const int32_t imgid);
271
279void dt_dev_write_history(struct dt_develop_t *dev, gboolean async);
280
289
296void dt_dev_history_pixelpipe_update(struct dt_develop_t *dev, gboolean rebuild);
297
306void dt_dev_history_notify_change(struct dt_develop_t *dev, const int32_t imgid);
307
346
358gboolean dt_dev_read_history_ext(struct dt_develop_t *dev, const int32_t imgid);
359
368
375
376
387gboolean dt_dev_reload_history_items(struct dt_develop_t *dev, const int32_t imgid);
388
389
398void dt_dev_invalidate_history_module(GList *list, struct dt_iop_module_t *module);
399
408
419
429void dt_dev_set_history_end_ext(struct dt_develop_t *dev, const uint32_t index);
430
439gboolean dt_history_module_skip_copy(const int flags);
440
453int dt_history_merge_module_into_history(struct dt_develop_t *dev_dest, struct dt_develop_t *dev_src,
454 struct dt_iop_module_t *mod_src);
455
470void dt_dev_history_compress_ext(struct dt_develop_t *dev, gboolean write_history);
480void dt_dev_history_cleanup(void);
481
494gboolean dt_dev_init_default_history(struct dt_develop_t *dev, const int32_t imgid, gboolean apply_auto_presets);
495
504
513dt_dev_history_item_t *dt_dev_history_get_last_item_by_module(GList *history_list, struct dt_iop_module_t *module, int history_end);
514
526int dt_dev_history_refresh_nodes_ext(struct dt_develop_t *dev, GList **iop, GList *history);
527
529void dt_dev_history_truncate(struct dt_develop_t *dev, const int32_t imgid);
530
554void dt_dev_transient_params_set(struct dt_iop_module_t *module, const void *params, size_t params_size,
555 const void *blend_params, size_t blend_size);
556
564
574gboolean dt_dev_transient_params_get(struct dt_develop_t *dev, const struct dt_iop_module_t *module,
575 void *out_params, size_t out_params_size,
576 void *out_blend, size_t out_blend_size, gboolean *out_has_blend);
577
579gboolean dt_dev_transient_params_active(struct dt_develop_t *dev, const struct dt_iop_module_t *module);
580
581#ifdef __cplusplus
582}
583#endif
void reload_defaults(dt_iop_module_t *module)
Definition ashift.c:5565
size_t params_size(dt_imageio_module_format_t *self)
Definition avif.c:565
void dt_dev_transient_params_set(struct dt_iop_module_t *module, const void *params, size_t params_size, const void *blend_params, size_t blend_size)
Out-of-history transient param channel.
void dt_dev_history_compress_ext(struct dt_develop_t *dev, gboolean write_history)
Variant of history compression that optionally skips DB writeback.
gboolean dt_dev_history_item_update_from_params(struct dt_develop_t *dev, dt_dev_history_item_t *hist, struct dt_iop_module_t *module, gboolean enabled, const void *params, const int32_t params_size, const struct dt_develop_blend_params_t *blend_params, GList *forms)
Fill/refresh a history item from explicit params and apply them to the module.
int dt_history_merge_module_into_history(struct dt_develop_t *dev_dest, struct dt_develop_t *dev_src, struct dt_iop_module_t *mod_src)
Merge a single module instance into a destination history.
dt_dev_history_item_t * dt_dev_history_get_last_item_by_module(GList *history_list, struct dt_iop_module_t *module, int history_end)
Find the last history item referencing a module up to history_end.
void dt_dev_history_free_history(struct dt_develop_t *dev)
Free the whole history list attached to dev->history.
int dt_dev_history_refresh_nodes_ext(struct dt_develop_t *dev, GList **iop, GList *history)
Refresh GUI module nodes to match history state.
void dt_dev_history_undo_end_record(struct dt_develop_t *dev)
Finish an undo record for history changes.
struct dt_iop_module_t * dt_dev_get_module_instance(struct dt_develop_t *dev, const char *op, const char *multi_name, const int multi_priority)
Find a module instance by op name and instance metadata.
int dt_dev_history_item_from_source_history_item(struct dt_develop_t *dev_dest, struct dt_develop_t *dev_src, const struct dt_dev_history_item_t *hist_src, struct dt_iop_module_t *mod_dest, struct dt_dev_history_item_t **out_hist)
Create a history item from another history item, using a destination module.
gboolean dt_dev_transient_params_get(struct dt_develop_t *dev, const struct dt_iop_module_t *module, void *out_params, size_t out_params_size, void *out_blend, size_t out_blend_size, gboolean *out_has_blend)
Copy the active transient params for module into caller buffers (pipeline thread).
int dt_dev_merge_history_into_image(struct dt_develop_t *dev_src, int32_t dest_imgid, const GList *mod_list, gboolean merge_iop_order, const dt_history_merge_strategy_t mode, const gboolean paste_instances, const char *source_label, dt_hm_batch_state_t *batch)
Merge a list of modules into a destination image history via dt_history_merge().
void dt_dev_set_history_end_ext(struct dt_develop_t *dev, const uint32_t index)
Set the history end index (GUI perspective).
Definition develop.c:1665
void dt_dev_history_undo_invalidate_module(struct dt_iop_module_t *module)
Invalidate a module pointer inside undo snapshots.
gboolean dt_dev_reload_history_items(struct dt_develop_t *dev, const int32_t imgid)
Reload history from DB and rebuild pipelines/GUI state.
void dt_dev_history_cleanup(void)
Cleanup cached statements or state used by history I/O.
void dt_dev_pop_history_items(struct dt_develop_t *dev)
Thread-safe wrapper around dt_dev_pop_history_items_ext(), then update GUI.
void dt_dev_free_history_item(gpointer data)
Free a single history item (used as GList free callback).
void dt_dev_history_pixelpipe_update(struct dt_develop_t *dev, gboolean rebuild)
Rebuild or resync pixelpipes after backend history changes.
int dt_dev_replace_history_on_image(struct dt_develop_t *dev_src, const int32_t dest_imgid, const gboolean reload_defaults, const char *msg)
Replace an image history with the content of dev_src.
void dt_dev_transient_params_clear(struct dt_iop_module_t *module)
Drop the transient slot if it belongs to module.
gboolean dt_dev_init_default_history(struct dt_develop_t *dev, const int32_t imgid, gboolean apply_auto_presets)
Initialize module defaults and insert required default modules.
uint64_t dt_dev_history_compute_hash(struct dt_develop_t *dev)
Get the integrity checksum of the whole history stack. This should be done ONLY when history is chang...
gboolean dt_dev_transient_params_active(struct dt_develop_t *dev, const struct dt_iop_module_t *module)
Whether a transient slot is currently active for module (cheap, locked read).
void dt_dev_history_undo_start_record_locked(struct dt_develop_t *dev)
Start an undo record with history_mutex already locked.
void dt_dev_pop_history_items_ext(struct dt_develop_t *dev)
Apply history items to module params up to dev->history_end.
void dt_dev_history_truncate(struct dt_develop_t *dev, const int32_t imgid)
void dt_dev_history_undo_start_record(struct dt_develop_t *dev)
Start an undo record for history changes.
void dt_dev_history_compress_or_truncate(struct dt_develop_t *dev)
Compress history if history_end is at top, otherwise truncate.
void dt_dev_write_history_ext(struct dt_develop_t *dev, const int32_t imgid)
Write dev->history to DB and XMP for a given image id.
gboolean dt_dev_read_history_ext(struct dt_develop_t *dev, const int32_t imgid)
Read history and masks from DB and populate dev->history.
void dt_dev_history_gui_update(struct dt_develop_t *dev)
Apply history-loaded params to module GUIs.
int32_t dt_dev_get_history_end_ext(struct dt_develop_t *dev)
Get the current history end index (GUI perspective).
Definition develop.c:1659
int dt_dev_copy_module_contents(struct dt_develop_t *dev_dest, struct dt_develop_t *dev_src, struct dt_iop_module_t *mod_dest, const struct dt_iop_module_t *mod_src)
Copy params/blend params from one module instance to another.
gboolean dt_history_module_skip_copy(const int flags)
Determine whether a module should be skipped during history copy.
void dt_dev_history_undo_end_record_locked(struct dt_develop_t *dev)
Finish an undo record with history_mutex already locked.
void dt_iop_params_t
Definition dev_history.h:41
void dt_dev_invalidate_history_module(GList *list, struct dt_iop_module_t *module)
Remove a module pointer from a history list.
gboolean dt_dev_add_history_item_ext(struct dt_develop_t *dev, struct dt_iop_module_t *module, gboolean enable, gboolean force_new_item)
Append or update a history item for a module.
void dt_dev_history_notify_change(struct dt_develop_t *dev, const int32_t imgid)
Notify the rest of the app that history changes were written.
void dt_dev_write_history(struct dt_develop_t *dev, gboolean async)
Thread-safe wrapper around dt_dev_write_history_ext() for dev->image_storage.id.
void dt_dev_history_compress(struct dt_develop_t *dev)
Compress an history from a loaded pipeline, aka simply take a snapshot of all modules parameters....
void dt_dev_add_history_item_real(struct dt_develop_t *dev, struct dt_iop_module_t *module, gboolean enable, gboolean redraw)
Thread-safe wrapper around dt_dev_add_history_item_ext().
struct dt_iop_module_t * dt_dev_create_module_instance(struct dt_develop_t *dev, const char *op, const char *multi_name, const int multi_priority, gboolean use_next_priority)
Create a new module instance from an existing base .so.
int dt_dev_next_multi_priority_for_op(struct dt_develop_t *dev, const char *op)
Return the next available multi_priority for an operation.
dt_dev_history_item_t * dt_dev_history_get_first_item_by_module(GList *history_list, struct dt_iop_module_t *module)
Find the first history item referencing a module.
static gboolean enable(dt_image_t *image)
dt_history_merge_strategy_t
dt_mipmap_buffer_dsc_flags flags
Definition mipmap_cache.c:4
unsigned __int64 uint64_t
Definition strptime.c:75
dt_iop_params_t * params
Definition dev_history.h:52
struct dt_develop_blend_params_t * blend_params
Definition dev_history.h:55
struct dt_iop_module_t *gboolean enabled
Definition dev_history.h:50
struct dt_develop_blend_params_t * blend_params
Definition imageop.h:316
char multi_name[128]
Definition imageop.h:363
struct dt_develop_t * dev
Definition imageop.h:296
GModule *dt_dev_operation_t op
Definition imageop.h:256
dt_iop_params_t * params
Definition imageop.h:307