diff options
author | Craig Robbins <kde.psych@gmail.com> | 2015-01-25 01:19:40 +1000 |
---|---|---|
committer | Craig Robbins <kde.psych@gmail.com> | 2015-01-25 01:19:40 +1000 |
commit | 2c4a5e18619a69159bcace8c03b4ea5642f46836 (patch) | |
tree | f22463c9cb1ac5bb9589d5be94d94f89cea45e89 | |
parent | 800d19270250bb13cc6b2d330199815bf8e96446 (diff) | |
download | minetest-2c4a5e18619a69159bcace8c03b4ea5642f46836.tar.gz minetest-2c4a5e18619a69159bcace8c03b4ea5642f46836.tar.bz2 minetest-2c4a5e18619a69159bcace8c03b4ea5642f46836.zip |
Revert "Make the GameGlobalShaderConstantSetter use the settings callback (8% perf improvement in game loop)"
This reverts commit a555e2d9b0ccee452996381a44677b8bec210036.
-rw-r--r-- | src/fontengine.cpp | 2 | ||||
-rw-r--r-- | src/game.cpp | 20 | ||||
-rw-r--r-- | src/settings.cpp | 10 | ||||
-rw-r--r-- | src/settings.h | 6 |
4 files changed, 11 insertions, 27 deletions
diff --git a/src/fontengine.cpp b/src/fontengine.cpp index 2df6bf833..79d53c989 100644 --- a/src/fontengine.cpp +++ b/src/fontengine.cpp @@ -36,7 +36,7 @@ with this program; if not, write to the Free Software Foundation, Inc., FontEngine* g_fontengine = NULL; /** callback to be used on change of font size setting */ -static void font_setting_changed(const std::string, void *userdata) { +static void font_setting_changed(const std::string) { g_fontengine->readSettings(); } diff --git a/src/game.cpp b/src/game.cpp index f5a19a7e4..ec025b73f 100644 --- a/src/game.cpp +++ b/src/game.cpp @@ -809,31 +809,15 @@ class GameGlobalShaderConstantSetter : public IShaderConstantSetter bool *m_force_fog_off; f32 *m_fog_range; Client *m_client; - bool m_fogEnabled; public: - - void onSettingsChange(const std::string &name) - { - if (name == "enable_fog") - m_fogEnabled = g_settings->getBool("enable_fog"); - } - - static void SettingsCallback(const std::string name, void *userdata) - { - reinterpret_cast<GameGlobalShaderConstantSetter*>(userdata)->onSettingsChange(name); - } - GameGlobalShaderConstantSetter(Sky *sky, bool *force_fog_off, f32 *fog_range, Client *client) : m_sky(sky), m_force_fog_off(force_fog_off), m_fog_range(fog_range), m_client(client) - { - g_settings->registerChangedCallback("enable_fog", SettingsCallback, this); - } - + {} ~GameGlobalShaderConstantSetter() {} virtual void onSetConstants(video::IMaterialRendererServices *services, @@ -856,7 +840,7 @@ public: // Fog distance float fog_distance = 10000 * BS; - if (m_fogEnabled && !*m_force_fog_off) + if (g_settings->getBool("enable_fog") && !*m_force_fog_off) fog_distance = *m_fog_range; services->setPixelShaderConstant("fogDistance", &fog_distance, 1); diff --git a/src/settings.cpp b/src/settings.cpp index 3416066e2..2f515caba 100644 --- a/src/settings.cpp +++ b/src/settings.cpp @@ -965,15 +965,15 @@ void Settings::clearNoLock() void Settings::registerChangedCallback(std::string name, - setting_changed_callback cbf, void *userdata) + setting_changed_callback cbf) { - m_callbacks[name].push_back(std::make_pair(cbf,userdata)); + m_callbacks[name].push_back(cbf); } void Settings::doCallbacks(const std::string name) { - std::vector<std::pair<setting_changed_callback,void*> > tempvector; + std::vector<setting_changed_callback> tempvector; { JMutexAutoLock lock(m_mutex); if (m_callbacks.find(name) != m_callbacks.end()) @@ -982,9 +982,9 @@ void Settings::doCallbacks(const std::string name) } } - std::vector<std::pair<setting_changed_callback, void*> >::iterator iter; + std::vector<setting_changed_callback>::iterator iter; for (iter = tempvector.begin(); iter != tempvector.end(); iter++) { - (iter->first)(name,iter->second); + (*iter)(name); } } diff --git a/src/settings.h b/src/settings.h index 47feb1755..89f7589df 100644 --- a/src/settings.h +++ b/src/settings.h @@ -32,7 +32,7 @@ class Settings; struct NoiseParams; /** function type to register a changed callback */ -typedef void (*setting_changed_callback)(const std::string, void *userdata); +typedef void (*setting_changed_callback)(const std::string); enum ValueType { VALUETYPE_STRING, @@ -204,7 +204,7 @@ public: void clear(); void updateValue(const Settings &other, const std::string &name); void update(const Settings &other); - void registerChangedCallback(std::string name, setting_changed_callback cbf, void *userdata = NULL); + void registerChangedCallback(std::string name, setting_changed_callback cbf); private: @@ -215,7 +215,7 @@ private: std::map<std::string, SettingsEntry> m_settings; std::map<std::string, SettingsEntry> m_defaults; - std::map<std::string, std::vector<std::pair<setting_changed_callback,void*> > > m_callbacks; + std::map<std::string, std::vector<setting_changed_callback> > m_callbacks; // All methods that access m_settings/m_defaults directly should lock this. mutable JMutex m_mutex; }; |