Skip to content

Commit

Permalink
File related control jobs safety
Browse files Browse the repository at this point in the history
As we have control jobs on "file actions" we have to make sure that we have 'dt_imageio` available for:
export, import, hdr creation and exif refresh inside the job.
While working the list of images we test for dt_control_running() and only process the job specific action if so.

Also we have some **very** time consuming jobs that can be canceled in the UI, it seems to be much better to understand
a ctrl-q or click on close-darktable button as a request-to-cancel so there will be no lengthy background actions after
the window has closed.
  • Loading branch information
jenshannoschwalm committed Dec 15, 2024
1 parent b064f9e commit 7c5b153
Showing 1 changed file with 7 additions and 7 deletions.
14 changes: 7 additions & 7 deletions src/control/jobs/control_jobs.c
Original file line number Diff line number Diff line change
Expand Up @@ -206,7 +206,7 @@ static int32_t _generic_dt_control_fileop_images_job_run(dt_job_t *job,

gboolean completeSuccess = TRUE;
double prev_time = 0;
while(t && !_job_cancelled(job))
while(dt_control_running() && t && !_job_cancelled(job))
{
completeSuccess &= (fileop_callback(GPOINTER_TO_INT(t->data), film_id) != -1);
t = g_list_next(t);
Expand Down Expand Up @@ -621,7 +621,7 @@ static int32_t _control_merge_hdr_job_run(dt_job_t *job)
(dt_control_merge_hdr_format_t){.parent = { 0 }, .d = &d };

int num = 1;
while(t)
while(t && dt_control_running())
{
if(d.abort) goto end;

Expand All @@ -640,7 +640,7 @@ static int32_t _control_merge_hdr_job_run(dt_job_t *job)
num++;
}

if(d.abort) goto end;
if(d.abort || !dt_control_running()) goto end;

// normalize by white level to make clipping at 1.0 work as expected

Expand Down Expand Up @@ -941,7 +941,7 @@ static int32_t _control_remove_images_job_run(dt_job_t *job)

double fraction = 0.0;
double prev_time = 0;
for(; t && !_job_cancelled(job); t = g_list_next(t))
for(; dt_control_running() && t && !_job_cancelled(job); t = g_list_next(t))
{
const dt_imgid_t imgid = GPOINTER_TO_INT(t->data);
const int32_t exist_count = _count_images_using_overlay(imgid);
Expand Down Expand Up @@ -1525,7 +1525,7 @@ static int32_t _control_refresh_exif_run(dt_job_t *job)

dt_control_job_set_progress_message(job, message);
double prev_time = 0;
while(t)
while(t && dt_control_running())
{
const dt_imgid_t imgid = GPOINTER_TO_INT(t->data);
if(dt_is_valid_imgid(imgid))
Expand Down Expand Up @@ -1869,7 +1869,7 @@ static int32_t _control_export_job_run(dt_job_t *job)

double prev_time = 0;

while(t && !_job_cancelled(job))
while(dt_control_running() && t && !_job_cancelled(job))
{
const dt_imgid_t imgid = GPOINTER_TO_INT(t->data);
t = g_list_next(t);
Expand Down Expand Up @@ -2885,7 +2885,7 @@ static int32_t _control_import_job_run(dt_job_t *job)
double update_interval = INIT_UPDATE_INTERVAL;
char *prev_filename = NULL;
char *prev_output = NULL;
for(GList *img = t; img && !_job_cancelled(job); img = g_list_next(img))
for(GList *img = t; dt_control_running() && img && !_job_cancelled(job); img = g_list_next(img))
{
if(data->session)
{
Expand Down

0 comments on commit 7c5b153

Please sign in to comment.