/* -*- Mode: C++; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*- */ /*************************************************************************** * settings.h * * Tue Mar 22 10:59:46 CET 2016 * Copyright 2016 Christian Glöckner * cgloeckner@freenet.de ****************************************************************************/ /* * This file is part of DrumGizmo. * * DrumGizmo is free software; you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation; either version 3 of the License, or * (at your option) any later version. * * DrumGizmo 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 Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public License * along with DrumGizmo; if not, write to the Free Software * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA. */ #pragma once #include #include #include #include #include "atomic.h" #include "notifier.h" enum class LoadStatus : unsigned int { Idle, Loading, Done, Error }; //! Engine settings struct Settings { Atomic drumkit_file{""}; Atomic drumkit_load_status{LoadStatus::Idle}; //! The maximum amount of memory in bytes that the AudioCache //! is allowed to use for preloading. Default is 1GB. Atomic disk_cache_upper_limit{1024 * 1024 * 1024}; //! The optimal read chunk size from the disk. Atomic disk_cache_chunk_size{1024 * 1024}; Atomic disk_cache_enable{true}; Atomic number_of_underruns{0}; //! Increment this in order to invoke a reload of the current drumkit. Atomic reload_counter{0}; Atomic midimap_file{""}; Atomic midimap_load_status{LoadStatus::Idle}; Atomic enable_velocity_modifier{true}; Atomic velocity_modifier_falloff{0.5f}; Atomic velocity_modifier_weight{0.25f}; Atomic enable_velocity_randomiser{false}; Atomic velocity_randomiser_weight{0.1f}; Atomic samplerate{44100.0}; Atomic enable_resampling{true}; Atomic number_of_files{0}; Atomic number_of_files_loaded{0}; Atomic current_file{""}; }; //! Settings getter class. struct SettingsGetter { SettingRef drumkit_file; SettingRef drumkit_load_status; SettingRef disk_cache_upper_limit; SettingRef disk_cache_chunk_size; SettingRef disk_cache_enable; SettingRef number_of_underruns; SettingRef reload_counter; SettingRef midimap_file; SettingRef midimap_load_status; SettingRef enable_velocity_modifier; SettingRef velocity_modifier_falloff; SettingRef velocity_modifier_weight; SettingRef enable_velocity_randomiser; SettingRef velocity_randomiser_weight; SettingRef samplerate; SettingRef enable_resampling; SettingRef number_of_files; SettingRef number_of_files_loaded; SettingRef current_file; SettingsGetter(Settings& settings) : drumkit_file(settings.drumkit_file) , drumkit_load_status(settings.drumkit_load_status) , disk_cache_upper_limit(settings.disk_cache_upper_limit) , disk_cache_chunk_size(settings.disk_cache_chunk_size) , disk_cache_enable(settings.disk_cache_enable) , number_of_underruns(settings.number_of_underruns) , reload_counter(settings.reload_counter) , midimap_file(settings.midimap_file) , midimap_load_status(settings.midimap_load_status) , enable_velocity_modifier{settings.enable_velocity_modifier} , velocity_modifier_falloff{settings.velocity_modifier_falloff} , velocity_modifier_weight{settings.velocity_modifier_weight} , enable_velocity_randomiser{settings.enable_velocity_randomiser} , velocity_randomiser_weight{settings.velocity_randomiser_weight} , samplerate{settings.samplerate} , enable_resampling{settings.enable_resampling} , number_of_files{settings.number_of_files} , number_of_files_loaded{settings.number_of_files_loaded} , current_file{settings.current_file} { } }; //! Settings change notifier class. class SettingsNotifier { public: Notifier drumkit_file; Notifier drumkit_load_status; Notifier disk_cache_upper_limit; Notifier disk_cache_chunk_size; Notifier disk_cache_enable; Notifier number_of_underruns; Notifier reload_counter; Notifier midimap_file; Notifier midimap_load_status; Notifier enable_velocity_modifier; Notifier velocity_modifier_falloff; Notifier velocity_modifier_weight; Notifier enable_velocity_randomiser; Notifier velocity_randomiser_weight; Notifier samplerate; Notifier enable_resampling; Notifier number_of_files; Notifier number_of_files_loaded; Notifier current_file; void evaluate() { #define EVAL(x) if(settings.x.hasChanged()) { x(settings.x.getValue()); } EVAL(drumkit_file); EVAL(drumkit_load_status); EVAL(disk_cache_upper_limit); EVAL(disk_cache_chunk_size); EVAL(disk_cache_enable); EVAL(number_of_underruns); EVAL(reload_counter); EVAL(midimap_file); EVAL(midimap_load_status); EVAL(enable_velocity_modifier); EVAL(velocity_modifier_falloff); EVAL(velocity_modifier_weight); EVAL(enable_velocity_randomiser); EVAL(velocity_randomiser_weight); EVAL(samplerate); EVAL(enable_resampling); EVAL(number_of_files); EVAL(number_of_files_loaded); EVAL(current_file); } SettingsNotifier(Settings& settings) : settings(settings) { } private: SettingsGetter settings; }; // lovely reminder: NO, GLOCKE. NOOOO!! /* enum class IntParams { Foo = 0 }; struct Settings { std::array, 5> ints; Settings() : ints{} { //get(IntParams::Foo).store(3); } std::atomic& get(IntParams param) { return ints[(size_t)param]; } }; struct SettingsGetter { std::vector> ints; SettingsGetter(Settings& parent) { for(auto& atomic: parent.ints) { ints.emplace_back(atomic); } } }; */