//=-------------------------------------------------------------------------=// // Local workers definition // // // // Copyright © 2021 Libre en Communs (contact@a-lec.org) // // Copyright © 2021 Adrien Bourmault (neox@a-lec.org) // // // // This file is part of gem-graph. // // // // This program is free software: you can redistribute it and/or modify // // it under the terms of the GNU Affero General Public License as // // published by the Free Software Foundation, either version 3 of the // // License, or (at your option) any later version. // // // // This program is distributed in the hope that it will be useful, // // but WITHOUT ANY WARRANTY; without even the implied warranty of // // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the // // GNU Affero General Public License for more details. // // // // You should have received a copy of the GNU Affero General Public License // // along with this program. If not, see . // //=-------------------------------------------------------------------------=// #pragma once #ifndef BASE_H #include "../include/base.h" #endif /* -------------------------------------------------------------------------- */ // -------------------------------------------------------------------------- // // Worker init function // // -------------------------------------------------------------------------- // void WorkerInit(Worker_t *worker); // -------------------------------------------------------------------------- // // Worker destructor function // // -------------------------------------------------------------------------- // static inline void WorkerDestroy(Worker_t *worker) { worker->pleaseStop = false; worker->terminated = false; worker->returnValue = false; worker->id = 0; free(worker->localWorkAreaCenter); worker->localWorkAreaCenter = NULL; } // -------------------------------------------------------------------------- // // Worker wait function // // -------------------------------------------------------------------------- // static inline void WorkerWait(Worker_t *worker) { pthread_join(worker->id, NULL); }