/* * This file is part of RawTherapee. * * Copyright (c) 2004-2010 Gabor Horvath * * RawTherapee is free software: you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * RawTherapee 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 General Public License for more details. * * You should have received a copy of the GNU General Public License * along with RawTherapee. If not, see . */ #include #include "../rtgui/profilestorecombobox.h" #include "rtengine.h" #include "iccstore.h" #include "dcp.h" #include "camconst.h" #include "curves.h" #include "rawimagesource.h" #include "improcfun.h" #include "improccoordinator.h" #include "dfmanager.h" #include "ffmanager.h" #include "rtthumbnail.h" #include "profilestore.h" #include "../rtgui/threadutils.h" #include "rtlensfun.h" #include "procparams.h" namespace rtengine { const Settings* settings; MyMutex* lcmsMutex = nullptr; MyMutex *fftwMutex = nullptr; int init (const Settings* s, Glib::ustring baseDir, Glib::ustring userSettingsDir, bool loadAll) { settings = s; ProcParams::init(); PerceptualToneCurve::init(); RawImageSource::init(); #ifdef _OPENMP #pragma omp parallel sections if (!settings->verbose) #endif { #ifdef _OPENMP #pragma omp section #endif { if (s->lensfunDbDirectory.empty() || Glib::path_is_absolute(s->lensfunDbDirectory)) { LFDatabase::init(s->lensfunDbDirectory); } else { LFDatabase::init(Glib::build_filename(baseDir, s->lensfunDbDirectory)); } } #ifdef _OPENMP #pragma omp section #endif { ProfileStore::getInstance()->init(loadAll); } #ifdef _OPENMP #pragma omp section #endif { ICCStore::getInstance()->init(s->iccDirectory, Glib::build_filename (baseDir, "iccprofiles"), loadAll); } #ifdef _OPENMP #pragma omp section #endif { DCPStore::getInstance()->init(Glib::build_filename (baseDir, "dcpprofiles"), loadAll); } #ifdef _OPENMP #pragma omp section #endif { CameraConstantsStore::getInstance()->init(baseDir, userSettingsDir); } #ifdef _OPENMP #pragma omp section #endif { dfm.init(s->darkFramesPath); } #ifdef _OPENMP #pragma omp section #endif { ffm.init(s->flatFieldsPath); } } Color::init (); delete lcmsMutex; lcmsMutex = new MyMutex; fftwMutex = new MyMutex; return 0; } void cleanup () { ProcParams::cleanup (); Color::cleanup (); RawImageSource::cleanup (); #ifdef RT_FFTW3F_OMP fftwf_cleanup_threads(); #else fftwf_cleanup(); #endif } StagedImageProcessor* StagedImageProcessor::create (InitialImage* initialImage) { ImProcCoordinator* ipc = new ImProcCoordinator (); ipc->assign (initialImage->getImageSource ()); return ipc; } void StagedImageProcessor::destroy (StagedImageProcessor* sip) { delete sip; } Settings* Settings::create () { return new Settings; } void Settings::destroy (Settings* s) { delete s; } }