diff options
author | Campbell Barton <ideasman42@gmail.com> | 2019-04-17 07:17:24 +0300 |
---|---|---|
committer | Campbell Barton <ideasman42@gmail.com> | 2019-04-17 07:21:24 +0300 |
commit | e12c08e8d170b7ca40f204a5b0423c23a9fbc2c1 (patch) | |
tree | 8cf3453d12edb177a218ef8009357518ec6cab6a /source/blender/windowmanager/intern/wm_jobs.c | |
parent | b3dabc200a4b0399ec6b81f2ff2730d07b44fcaa (diff) |
ClangFormat: apply to source, most of intern
Apply clang format as proposed in T53211.
For details on usage and instructions for migrating branches
without conflicts, see:
https://wiki.blender.org/wiki/Tools/ClangFormat
Diffstat (limited to 'source/blender/windowmanager/intern/wm_jobs.c')
-rw-r--r-- | source/blender/windowmanager/intern/wm_jobs.c | 921 |
1 files changed, 460 insertions, 461 deletions
diff --git a/source/blender/windowmanager/intern/wm_jobs.c b/source/blender/windowmanager/intern/wm_jobs.c index a1ebc29802f..6ce9dd70574 100644 --- a/source/blender/windowmanager/intern/wm_jobs.c +++ b/source/blender/windowmanager/intern/wm_jobs.c @@ -69,73 +69,72 @@ */ struct wmJob { - struct wmJob *next, *prev; - - /* job originating from, keep track of this when deleting windows */ - wmWindow *win; - - /* should store entire own context, for start, update, free */ - void *customdata; - /* to prevent cpu overhead, use this one which only gets called when job really starts, not in thread */ - void (*initjob)(void *); - /* this runs inside thread, and does full job */ - void (*startjob)(void *, short *stop, short *do_update, float *progress); - /* update gets called if thread defines so, and max once per timerstep */ - /* it runs outside thread, blocking blender, no drawing! */ - void (*update)(void *); - /* free entire customdata, doesn't run in thread */ - void (*free)(void *); - /* gets called when job is stopped, not in thread */ - void (*endjob)(void *); - - /* running jobs each have own timer */ - double timestep; - wmTimer *wt; - /* the notifier event timers should send */ - unsigned int note, endnote; - - - /* internal */ - void *owner; - int flag; - short suspended, running, ready, do_update, stop, job_type; - float progress; - - /* for display in header, identification */ - char name[128]; - - /* once running, we store this separately */ - void *run_customdata; - void (*run_free)(void *); - - /* we use BLI_threads api, but per job only 1 thread runs */ - ListBase threads; - - double start_time; - - /* ticket mutex for main thread locking while some job accesses - * data that the main thread might modify at the same time */ - TicketMutex *main_thread_mutex; + struct wmJob *next, *prev; + + /* job originating from, keep track of this when deleting windows */ + wmWindow *win; + + /* should store entire own context, for start, update, free */ + void *customdata; + /* to prevent cpu overhead, use this one which only gets called when job really starts, not in thread */ + void (*initjob)(void *); + /* this runs inside thread, and does full job */ + void (*startjob)(void *, short *stop, short *do_update, float *progress); + /* update gets called if thread defines so, and max once per timerstep */ + /* it runs outside thread, blocking blender, no drawing! */ + void (*update)(void *); + /* free entire customdata, doesn't run in thread */ + void (*free)(void *); + /* gets called when job is stopped, not in thread */ + void (*endjob)(void *); + + /* running jobs each have own timer */ + double timestep; + wmTimer *wt; + /* the notifier event timers should send */ + unsigned int note, endnote; + + /* internal */ + void *owner; + int flag; + short suspended, running, ready, do_update, stop, job_type; + float progress; + + /* for display in header, identification */ + char name[128]; + + /* once running, we store this separately */ + void *run_customdata; + void (*run_free)(void *); + + /* we use BLI_threads api, but per job only 1 thread runs */ + ListBase threads; + + double start_time; + + /* ticket mutex for main thread locking while some job accesses + * data that the main thread might modify at the same time */ + TicketMutex *main_thread_mutex; }; /* Main thread locking */ void WM_job_main_thread_lock_acquire(wmJob *wm_job) { - BLI_ticket_mutex_lock(wm_job->main_thread_mutex); + BLI_ticket_mutex_lock(wm_job->main_thread_mutex); } void WM_job_main_thread_lock_release(wmJob *wm_job) { - BLI_ticket_mutex_unlock(wm_job->main_thread_mutex); + BLI_ticket_mutex_unlock(wm_job->main_thread_mutex); } static void wm_job_main_thread_yield(wmJob *wm_job) { - /* unlock and lock the ticket mutex. because it's a fair mutex any job that - * is waiting to acquire the lock will get it first, before we can lock */ - BLI_ticket_mutex_unlock(wm_job->main_thread_mutex); - BLI_ticket_mutex_lock(wm_job->main_thread_mutex); + /* unlock and lock the ticket mutex. because it's a fair mutex any job that + * is waiting to acquire the lock will get it first, before we can lock */ + BLI_ticket_mutex_unlock(wm_job->main_thread_mutex); + BLI_ticket_mutex_lock(wm_job->main_thread_mutex); } /** @@ -143,31 +142,31 @@ static void wm_job_main_thread_yield(wmJob *wm_job) */ static wmJob *wm_job_find(wmWindowManager *wm, void *owner, const int job_type) { - wmJob *wm_job; - - if (owner && job_type) { - for (wm_job = wm->jobs.first; wm_job; wm_job = wm_job->next) { - if (wm_job->owner == owner && wm_job->job_type == job_type) { - return wm_job; - } - } - } - else if (owner) { - for (wm_job = wm->jobs.first; wm_job; wm_job = wm_job->next) { - if (wm_job->owner == owner) { - return wm_job; - } - } - } - else if (job_type) { - for (wm_job = wm->jobs.first; wm_job; wm_job = wm_job->next) { - if (wm_job->job_type == job_type) { - return wm_job; - } - } - } - - return NULL; + wmJob *wm_job; + + if (owner && job_type) { + for (wm_job = wm->jobs.first; wm_job; wm_job = wm_job->next) { + if (wm_job->owner == owner && wm_job->job_type == job_type) { + return wm_job; + } + } + } + else if (owner) { + for (wm_job = wm->jobs.first; wm_job; wm_job = wm_job->next) { + if (wm_job->owner == owner) { + return wm_job; + } + } + } + else if (job_type) { + for (wm_job = wm->jobs.first; wm_job; wm_job = wm_job->next) { + if (wm_job->job_type == job_type) { + return wm_job; + } + } + } + + return NULL; } /* ******************* public API ***************** */ @@ -178,182 +177,182 @@ static wmJob *wm_job_find(wmWindowManager *wm, void *owner, const int job_type) * \note every owner only gets a single job, * adding a new one will stop running job and when stopped it starts the new one. */ -wmJob *WM_jobs_get(wmWindowManager *wm, wmWindow *win, void *owner, const char *name, int flag, int job_type) +wmJob *WM_jobs_get( + wmWindowManager *wm, wmWindow *win, void *owner, const char *name, int flag, int job_type) { - wmJob *wm_job = wm_job_find(wm, owner, job_type); + wmJob *wm_job = wm_job_find(wm, owner, job_type); - if (wm_job == NULL) { - wm_job = MEM_callocN(sizeof(wmJob), "new job"); + if (wm_job == NULL) { + wm_job = MEM_callocN(sizeof(wmJob), "new job"); - BLI_addtail(&wm->jobs, wm_job); - wm_job->win = win; - wm_job->owner = owner; - wm_job->flag = flag; - wm_job->job_type = job_type; - BLI_strncpy(wm_job->name, name, sizeof(wm_job->name)); + BLI_addtail(&wm->jobs, wm_job); + wm_job->win = win; + wm_job->owner = owner; + wm_job->flag = flag; + wm_job->job_type = job_type; + BLI_strncpy(wm_job->name, name, sizeof(wm_job->name)); - wm_job->main_thread_mutex = BLI_ticket_mutex_alloc(); - WM_job_main_thread_lock_acquire(wm_job); - } - /* else: a running job, be careful */ + wm_job->main_thread_mutex = BLI_ticket_mutex_alloc(); + WM_job_main_thread_lock_acquire(wm_job); + } + /* else: a running job, be careful */ - /* prevent creating a job with an invalid type */ - BLI_assert(wm_job->job_type != WM_JOB_TYPE_ANY); + /* prevent creating a job with an invalid type */ + BLI_assert(wm_job->job_type != WM_JOB_TYPE_ANY); - return wm_job; + return wm_job; } /* returns true if job runs, for UI (progress) indicators */ bool WM_jobs_test(wmWindowManager *wm, void *owner, int job_type) { - wmJob *wm_job; - - /* job can be running or about to run (suspended) */ - for (wm_job = wm->jobs.first; wm_job; wm_job = wm_job->next) { - if (wm_job->owner == owner) { - if (job_type == WM_JOB_TYPE_ANY || (wm_job->job_type == job_type)) { - if (wm_job->running || wm_job->suspended) { - return true; - } - } - } - } - - return false; + wmJob *wm_job; + + /* job can be running or about to run (suspended) */ + for (wm_job = wm->jobs.first; wm_job; wm_job = wm_job->next) { + if (wm_job->owner == owner) { + if (job_type == WM_JOB_TYPE_ANY || (wm_job->job_type == job_type)) { + if (wm_job->running || wm_job->suspended) { + return true; + } + } + } + } + + return false; } float WM_jobs_progress(wmWindowManager *wm, void *owner) { - wmJob *wm_job = wm_job_find(wm, owner, WM_JOB_TYPE_ANY); + wmJob *wm_job = wm_job_find(wm, owner, WM_JOB_TYPE_ANY); - if (wm_job && wm_job->flag & WM_JOB_PROGRESS) { - return wm_job->progress; - } + if (wm_job && wm_job->flag & WM_JOB_PROGRESS) { + return wm_job->progress; + } - return 0.0; + return 0.0; } static void wm_jobs_update_progress_bars(wmWindowManager *wm) { - float total_progress = 0.f; - float jobs_progress = 0; - - for (wmJob *wm_job = wm->jobs.first; wm_job; wm_job = wm_job->next) { - if (wm_job->threads.first && !wm_job->ready) { - if (wm_job->flag & WM_JOB_PROGRESS) { - /* accumulate global progress for running jobs */ - jobs_progress++; - total_progress += wm_job->progress; - } - } - } - - /* if there are running jobs, set the global progress indicator */ - if (jobs_progress > 0) { - wmWindow *win; - float progress = total_progress / (float)jobs_progress; - - for (win = wm->windows.first; win; win = win->next) { - WM_progress_set(win, progress); - } - } - else { - wmWindow *win; - - for (win = wm->windows.first; win; win = win->next) { - WM_progress_clear(win); - } - } - + float total_progress = 0.f; + float jobs_progress = 0; + + for (wmJob *wm_job = wm->jobs.first; wm_job; wm_job = wm_job->next) { + if (wm_job->threads.first && !wm_job->ready) { + if (wm_job->flag & WM_JOB_PROGRESS) { + /* accumulate global progress for running jobs */ + jobs_progress++; + total_progress += wm_job->progress; + } + } + } + + /* if there are running jobs, set the global progress indicator */ + if (jobs_progress > 0) { + wmWindow *win; + float progress = total_progress / (float)jobs_progress; + + for (win = wm->windows.first; win; win = win->next) { + WM_progress_set(win, progress); + } + } + else { + wmWindow *win; + + for (win = wm->windows.first; win; win = win->next) { + WM_progress_clear(win); + } + } } /* time that job started */ double WM_jobs_starttime(wmWindowManager *wm, void *owner) { - wmJob *wm_job = wm_job_find(wm, owner, WM_JOB_TYPE_ANY); + wmJob *wm_job = wm_job_find(wm, owner, WM_JOB_TYPE_ANY); - if (wm_job && wm_job->flag & WM_JOB_PROGRESS) { - return wm_job->start_time; - } + if (wm_job && wm_job->flag & WM_JOB_PROGRESS) { + return wm_job->start_time; + } - return 0; + return 0; } char *WM_jobs_name(wmWindowManager *wm, void *owner) { - wmJob *wm_job = wm_job_find(wm, owner, WM_JOB_TYPE_ANY); + wmJob *wm_job = wm_job_find(wm, owner, WM_JOB_TYPE_ANY); - if (wm_job) { - return wm_job->name; - } + if (wm_job) { + return wm_job->name; + } - return NULL; + return NULL; } void *WM_jobs_customdata(wmWindowManager *wm, void *owner) { - wmJob *wm_job = wm_job_find(wm, owner, WM_JOB_TYPE_ANY); + wmJob *wm_job = wm_job_find(wm, owner, WM_JOB_TYPE_ANY); - if (wm_job) { - return WM_jobs_customdata_get(wm_job); - } + if (wm_job) { + return WM_jobs_customdata_get(wm_job); + } - return NULL; + return NULL; } void *WM_jobs_customdata_from_type(wmWindowManager *wm, int job_type) { - wmJob *wm_job = wm_job_find(wm, NULL, job_type); + wmJob *wm_job = wm_job_find(wm, NULL, job_type); - if (wm_job) { - return WM_jobs_customdata_get(wm_job); - } + if (wm_job) { + return WM_jobs_customdata_get(wm_job); + } - return NULL; + return NULL; } bool WM_jobs_is_running(wmJob *wm_job) { - return wm_job->running; + return wm_job->running; } bool WM_jobs_is_stopped(wmWindowManager *wm, void *owner) { - wmJob *wm_job = wm_job_find(wm, owner, WM_JOB_TYPE_ANY); - return wm_job ? wm_job->stop : true; /* XXX to be redesigned properly. */ + wmJob *wm_job = wm_job_find(wm, owner, WM_JOB_TYPE_ANY); + return wm_job ? wm_job->stop : true; /* XXX to be redesigned properly. */ } void *WM_jobs_customdata_get(wmJob *wm_job) { - if (!wm_job->customdata) { - return wm_job->run_customdata; - } - else { - return wm_job->customdata; - } + if (!wm_job->customdata) { + return wm_job->run_customdata; + } + else { + return wm_job->customdata; + } } void WM_jobs_customdata_set(wmJob *wm_job, void *customdata, void (*free)(void *)) { - /* pending job? just free */ - if (wm_job->customdata) { - wm_job->free(wm_job->customdata); - } - - wm_job->customdata = customdata; - wm_job->free = free; - - if (wm_job->running) { - /* signal job to end */ - wm_job->stop = true; - } + /* pending job? just free */ + if (wm_job->customdata) { + wm_job->free(wm_job->customdata); + } + + wm_job->customdata = customdata; + wm_job->free = free; + + if (wm_job->running) { + /* signal job to end */ + wm_job->stop = true; + } } void WM_jobs_timer(wmJob *wm_job, double timestep, unsigned int note, unsigned int endnote) { - wm_job->timestep = timestep; - wm_job->note = note; - wm_job->endnote = endnote; + wm_job->timestep = timestep; + wm_job->note = note; + wm_job->endnote = endnote; } void WM_jobs_callbacks(wmJob *wm_job, @@ -362,69 +361,69 @@ void WM_jobs_callbacks(wmJob *wm_job, void (*update)(void *), void (*endjob)(void *)) { - wm_job->startjob = startjob; - wm_job->initjob = initjob; - wm_job->update = update; - wm_job->endjob = endjob; + wm_job->startjob = startjob; + wm_job->initjob = initjob; + wm_job->update = update; + wm_job->endjob = endjob; } static void *do_job_thread(void *job_v) { - wmJob *wm_job = job_v; + wmJob *wm_job = job_v; - BLI_thread_put_thread_on_fast_node(); - wm_job->startjob(wm_job->run_customdata, &wm_job->stop, &wm_job->do_update, &wm_job->progress); - wm_job->ready = true; + BLI_thread_put_thread_on_fast_node(); + wm_job->startjob(wm_job->run_customdata, &wm_job->stop, &wm_job->do_update, &wm_job->progress); + wm_job->ready = true; - return NULL; + return NULL; } /* don't allow same startjob to be executed twice */ static void wm_jobs_test_suspend_stop(wmWindowManager *wm, wmJob *test) { - wmJob *wm_job; - bool suspend = false; - - /* job added with suspend flag, we wait 1 timer step before activating it */ - if (test->flag & WM_JOB_SUSPEND) { - suspend = true; - test->flag &= ~WM_JOB_SUSPEND; - } - else { - /* check other jobs */ - for (wm_job = wm->jobs.first; wm_job; wm_job = wm_job->next) { - /* obvious case, no test needed */ - if (wm_job == test || !wm_job->running) { - continue; - } - - /* if new job is not render, then check for same startjob */ - if (0 == (test->flag & WM_JOB_EXCL_RENDER)) { - if (wm_job->startjob != test->startjob) { - continue; - } - } - - /* if new job is render, any render job should be stopped */ - if (test->flag & WM_JOB_EXCL_RENDER) { - if (0 == (wm_job->flag & WM_JOB_EXCL_RENDER)) { - continue; - } - } - - suspend = true; - - /* if this job has higher priority, stop others */ - if (test->flag & WM_JOB_PRIORITY) { - wm_job->stop = true; - // printf("job stopped: %s\n", wm_job->name); - } - } - } - - /* Possible suspend ourselves, waiting for other jobs, or de-suspend. */ - test->suspended = suspend; - // if (suspend) printf("job suspended: %s\n", test->name); + wmJob *wm_job; + bool suspend = false; + + /* job added with suspend flag, we wait 1 timer step before activating it */ + if (test->flag & WM_JOB_SUSPEND) { + suspend = true; + test->flag &= ~WM_JOB_SUSPEND; + } + else { + /* check other jobs */ + for (wm_job = wm->jobs.first; wm_job; wm_job = wm_job->next) { + /* obvious case, no test needed */ + if (wm_job == test || !wm_job->running) { + continue; + } + + /* if new job is not render, then check for same startjob */ + if (0 == (test->flag & WM_JOB_EXCL_RENDER)) { + if (wm_job->startjob != test->startjob) { + continue; + } + } + + /* if new job is render, any render job should be stopped */ + if (test->flag & WM_JOB_EXCL_RENDER) { + if (0 == (wm_job->flag & WM_JOB_EXCL_RENDER)) { + continue; + } + } + + suspend = true; + + /* if this job has higher priority, stop others */ + if (test->flag & WM_JOB_PRIORITY) { + wm_job->stop = true; + // printf("job stopped: %s\n", wm_job->name); + } + } + } + + /* Possible suspend ourselves, waiting for other jobs, or de-suspend. */ + test->suspended = suspend; + // if (suspend) printf("job suspended: %s\n", test->name); } /** @@ -433,278 +432,278 @@ static void wm_jobs_test_suspend_stop(wmWindowManager *wm, wmJob *test) */ void WM_jobs_start(wmWindowManager *wm, wmJob *wm_job) { - if (wm_job->running) { - /* signal job to end and restart */ - wm_job->stop = true; - // printf("job started a running job, ending... %s\n", wm_job->name); - } - else { - - if (wm_job->customdata && wm_job->startjob) { - - wm_jobs_test_suspend_stop(wm, wm_job); - - if (wm_job->suspended == false) { - /* copy to ensure proper free in end */ - wm_job->run_customdata = wm_job->customdata; - wm_job->run_free = wm_job->free; - wm_job->free = NULL; - wm_job->customdata = NULL; - wm_job->running = true; - - if (wm_job->initjob) { - wm_job->initjob(wm_job->run_customdata); - } - - wm_job->stop = false; - wm_job->ready = false; - wm_job->progress = 0.0; - - // printf("job started: %s\n", wm_job->name); - - BLI_threadpool_init(&wm_job->threads, do_job_thread, 1); - BLI_threadpool_insert(&wm_job->threads, wm_job); - } - - /* restarted job has timer already */ - if (wm_job->wt == NULL) { - wm_job->wt = WM_event_add_timer(wm, wm_job->win, TIMERJOBS, wm_job->timestep); - } - - wm_job->start_time = PIL_check_seconds_timer(); - } - else { - printf("job fails, not initialized\n"); - } - } + if (wm_job->running) { + /* signal job to end and restart */ + wm_job->stop = true; + // printf("job started a running job, ending... %s\n", wm_job->name); + } + else { + + if (wm_job->customdata && wm_job->startjob) { + + wm_jobs_test_suspend_stop(wm, wm_job); + + if (wm_job->suspended == false) { + /* copy to ensure proper free in end */ + wm_job->run_customdata = wm_job->customdata; + wm_job->run_free = wm_job->free; + wm_job->free = NULL; + wm_job->customdata = NULL; + wm_job->running = true; + + if (wm_job->initjob) { + wm_job->initjob(wm_job->run_customdata); + } + + wm_job->stop = false; + wm_job->ready = false; + wm_job->progress = 0.0; + + // printf("job started: %s\n", wm_job->name); + + BLI_threadpool_init(&wm_job->threads, do_job_thread, 1); + BLI_threadpool_insert(&wm_job->threads, wm_job); + } + + /* restarted job has timer already */ + if (wm_job->wt == NULL) { + wm_job->wt = WM_event_add_timer(wm, wm_job->win, TIMERJOBS, wm_job->timestep); + } + + wm_job->start_time = PIL_check_seconds_timer(); + } + else { + printf("job fails, not initialized\n"); + } + } } static void wm_job_free(wmWindowManager *wm, wmJob *wm_job) { - BLI_remlink(&wm->jobs, wm_job); - WM_job_main_thread_lock_release(wm_job); - BLI_ticket_mutex_free(wm_job->main_thread_mutex); - MEM_freeN(wm_job); + BLI_remlink(&wm->jobs, wm_job); + WM_job_main_thread_lock_release(wm_job); + BLI_ticket_mutex_free(wm_job->main_thread_mutex); + MEM_freeN(wm_job); } /* stop job, end thread, free data completely */ static void wm_jobs_kill_job(wmWindowManager *wm, wmJob *wm_job) { - bool update_progress = (wm_job->flag & WM_JOB_PROGRESS) != 0; - - if (wm_job->running) { - /* signal job to end */ - wm_job->stop = true; - - WM_job_main_thread_lock_release(wm_job); - BLI_threadpool_end(&wm_job->threads); - WM_job_main_thread_lock_acquire(wm_job); - - if (wm_job->endjob) { - wm_job->endjob(wm_job->run_customdata); - } - } - - if (wm_job->wt) { - WM_event_remove_timer(wm, wm_job->win, wm_job->wt); - } - if (wm_job->customdata) { - wm_job->free(wm_job->customdata); - } - if (wm_job->run_customdata) { - wm_job->run_free(wm_job->run_customdata); - } - - /* remove wm_job */ - wm_job_free(wm, wm_job); - - /* Update progress bars in windows. */ - if (update_progress) { - wm_jobs_update_progress_bars(wm); - } + bool update_progress = (wm_job->flag & WM_JOB_PROGRESS) != 0; + + if (wm_job->running) { + /* signal job to end */ + wm_job->stop = true; + + WM_job_main_thread_lock_release(wm_job); + BLI_threadpool_end(&wm_job->threads); + WM_job_main_thread_lock_acquire(wm_job); + + if (wm_job->endjob) { + wm_job->endjob(wm_job->run_customdata); + } + } + + if (wm_job->wt) { + WM_event_remove_timer(wm, wm_job->win, wm_job->wt); + } + if (wm_job->customdata) { + wm_job->free(wm_job->customdata); + } + if (wm_job->run_customdata) { + wm_job->run_free(wm_job->run_customdata); + } + + /* remove wm_job */ + wm_job_free(wm, wm_job); + + /* Update progress bars in windows. */ + if (update_progress) { + wm_jobs_update_progress_bars(wm); + } } /* wait until every job ended */ void WM_jobs_kill_all(wmWindowManager *wm) { - wmJob *wm_job; - - while ((wm_job = wm->jobs.first)) { - wm_jobs_kill_job(wm, wm_job); - } + wmJob *wm_job; + while ((wm_job = wm->jobs.first)) { + wm_jobs_kill_job(wm, wm_job); + } } /* wait until every job ended, except for one owner (used in undo to keep screen job alive) */ void WM_jobs_kill_all_except(wmWindowManager *wm, void *owner) { - wmJob *wm_job, *next_job; + wmJob *wm_job, *next_job; - for (wm_job = wm->jobs.first; wm_job; wm_job = next_job) { - next_job = wm_job->next; + for (wm_job = wm->jobs.first; wm_job; wm_job = next_job) { + next_job = wm_job->next; - if (wm_job->owner != owner) { - wm_jobs_kill_job(wm, wm_job); - } - } + if (wm_job->owner != owner) { + wm_jobs_kill_job(wm, wm_job); + } + } } - void WM_jobs_kill_type(struct wmWindowManager *wm, void *owner, int job_type) { - wmJob *wm_job, *next_job; + wmJob *wm_job, *next_job; - for (wm_job = wm->jobs.first; wm_job; wm_job = next_job) { - next_job = wm_job->next; + for (wm_job = wm->jobs.first; wm_job; wm_job = next_job) { + next_job = wm_job->next; - if (!owner || wm_job->owner == owner) { - if (job_type == WM_JOB_TYPE_ANY || wm_job->job_type == job_type) { - wm_jobs_kill_job(wm, wm_job); - } - } - } + if (!owner || wm_job->owner == owner) { + if (job_type == WM_JOB_TYPE_ANY || wm_job->job_type == job_type) { + wm_jobs_kill_job(wm, wm_job); + } + } + } } /* signal job(s) from this owner or callback to stop, timer is required to get handled */ void WM_jobs_stop(wmWindowManager *wm, void *owner, void *startjob) { - wmJob *wm_job; - - for (wm_job = wm->jobs.first; wm_job; wm_job = wm_job->next) { - if (wm_job->owner == owner || wm_job->startjob == startjob) { - if (wm_job->running) { - wm_job->stop = true; - } - } - } + wmJob *wm_job; + + for (wm_job = wm->jobs.first; wm_job; wm_job = wm_job->next) { + if (wm_job->owner == owner || wm_job->startjob == startjob) { + if (wm_job->running) { + wm_job->stop = true; + } + } + } } /* actually terminate thread and job timer */ -void WM_jobs_kill(wmWindowManager *wm, void *owner, void (*startjob)(void *, short int *, short int *, float *)) +void WM_jobs_kill(wmWindowManager *wm, + void *owner, + void (*startjob)(void *, short int *, short int *, float *)) { - wmJob *wm_job; - - wm_job = wm->jobs.first; - while (wm_job) { - if (wm_job->owner == owner || wm_job->startjob == startjob) { - wmJob *wm_job_kill = wm_job; - wm_job = wm_job->next; - wm_jobs_kill_job(wm, wm_job_kill); - } - else { - wm_job = wm_job->next; - } - } + wmJob *wm_job; + + wm_job = wm->jobs.first; + while (wm_job) { + if (wm_job->owner == owner || wm_job->startjob == startjob) { + wmJob *wm_job_kill = wm_job; + wm_job = wm_job->next; + wm_jobs_kill_job(wm, wm_job_kill); + } + else { + wm_job = wm_job->next; + } + } } - /* kill job entirely, also removes timer itself */ void wm_jobs_timer_ended(wmWindowManager *wm, wmTimer *wt) { - wmJob *wm_job; - - for (wm_job = wm->jobs.first; wm_job; wm_job = wm_job->next) { - if (wm_job->wt == wt) { - wm_jobs_kill_job(wm, wm_job); - return; - } - } + wmJob *wm_job; + + for (wm_job = wm->jobs.first; wm_job; wm_job = wm_job->next) { + if (wm_job->wt == wt) { + wm_jobs_kill_job(wm, wm_job); + return; + } + } } /* hardcoded to event TIMERJOBS */ void wm_jobs_timer(const bContext *C, wmWindowManager *wm, wmTimer *wt) { - wmJob *wm_job, *wm_jobnext; - - for (wm_job = wm->jobs.first; wm_job; wm_job = wm_jobnext) { - wm_jobnext = wm_job->next; - - if (wm_job->wt == wt) { - - /* running threads */ - if (wm_job->threads.first) { - - /* let threads get temporary lock over main thread if needed */ - wm_job_main_thread_yield(wm_job); - - /* always call note and update when ready */ - if (wm_job->do_update || wm_job->ready) { - if (wm_job->update) { - wm_job->update(wm_job->run_customdata); - } - if (wm_job->note) { - WM_event_add_notifier(C, wm_job->note, NULL); - } - - if (wm_job->flag & WM_JOB_PROGRESS) { - WM_event_add_notifier(C, NC_WM | ND_JOB, NULL); - } - wm_job->do_update = false; - } - - if (wm_job->ready) { - if (wm_job->endjob) { - wm_job->endjob(wm_job->run_customdata); - } - - /* free own data */ - wm_job->run_free(wm_job->run_customdata); - wm_job->run_customdata = NULL; - wm_job->run_free = NULL; - - // if (wm_job->stop) printf("job ready but stopped %s\n", wm_job->name); - // else printf("job finished %s\n", wm_job->name); - - if (G.debug & G_DEBUG_JOBS) { - printf("Job '%s' finished in %f seconds\n", wm_job->name, - PIL_check_seconds_timer() - wm_job->start_time); - } - - wm_job->running = false; - - WM_job_main_thread_lock_release(wm_job); - BLI_threadpool_end(&wm_job->threads); - WM_job_main_thread_lock_acquire(wm_job); - - if (wm_job->endnote) { - WM_event_add_notifier(C, wm_job->endnote, NULL); - } - - WM_event_add_notifier(C, NC_WM | ND_JOB, NULL); - - /* new job added for wm_job? */ - if (wm_job->customdata) { - // printf("job restarted with new data %s\n", wm_job->name); - WM_jobs_start(wm, wm_job); - } - else { - WM_event_remove_timer(wm, wm_job->win, wm_job->wt); - wm_job->wt = NULL; - - /* remove wm_job */ - wm_job_free(wm, wm_job); - } - } - } - else if (wm_job->suspended) { - WM_jobs_start(wm, wm_job); - } - } - } - - /* Update progress bars in windows. */ - wm_jobs_update_progress_bars(wm); + wmJob *wm_job, *wm_jobnext; + + for (wm_job = wm->jobs.first; wm_job; wm_job = wm_jobnext) { + wm_jobnext = wm_job->next; + + if (wm_job->wt == wt) { + + /* running threads */ + if (wm_job->threads.first) { + + /* let threads get temporary lock over main thread if needed */ + wm_job_main_thread_yield(wm_job); + + /* always call note and update when ready */ + if (wm_job->do_update || wm_job->ready) { + if (wm_job->update) { + wm_job->update(wm_job->run_customdata); + } + if (wm_job->note) { + WM_event_add_notifier(C, wm_job->note, NULL); + } + + if (wm_job->flag & WM_JOB_PROGRESS) { + WM_event_add_notifier(C, NC_WM | ND_JOB, NULL); + } + wm_job->do_update = false; + } + + if (wm_job->ready) { + if (wm_job->endjob) { + wm_job->endjob(wm_job->run_customdata); + } + + /* free own data */ + wm_job->run_free(wm_job->run_customdata); + wm_job->run_customdata = NULL; + wm_job->run_free = NULL; + + // if (wm_job->stop) printf("job ready but stopped %s\n", wm_job->name); + // else printf("job finished %s\n", wm_job->name); + + if (G.debug & G_DEBUG_JOBS) { + printf("Job '%s' finished in %f seconds\n", + wm_job->name, + PIL_check_seconds_timer() - wm_job->start_time); + } + + wm_job->running = false; + + WM_job_main_thread_lock_release(wm_job); + BLI_threadpool_end(&wm_job->threads); + WM_job_main_thread_lock_acquire(wm_job); + + if (wm_job->endnote) { + WM_event_add_notifier(C, wm_job->endnote, NULL); + } + + WM_event_add_notifier(C, NC_WM | ND_JOB, NULL); + + /* new job added for wm_job? */ + if (wm_job->customdata) { + // printf("job restarted with new data %s\n", wm_job->name); + WM_jobs_start(wm, wm_job); + } + else { + WM_event_remove_timer(wm, wm_job->win, wm_job->wt); + wm_job->wt = NULL; + + /* remove wm_job */ + wm_job_free(wm, wm_job); + } + } + } + else if (wm_job->suspended) { + WM_jobs_start(wm, wm_job); + } + } + } + + /* Update progress bars in windows. */ + wm_jobs_update_progress_bars(wm); } bool WM_jobs_has_running(wmWindowManager *wm) { - wmJob *wm_job; + wmJob *wm_job; - for (wm_job = wm->jobs.first; wm_job; wm_job = wm_job->next) { - if (wm_job->running) { - return true; - } - } + for (wm_job = wm->jobs.first; wm_job; wm_job = wm_job->next) { + if (wm_job->running) { + return true; + } + } - return false; + return false; } |