]> git.lizzy.rs Git - minetest.git/blobdiff - src/environment.cpp
FormSpec: Add StaticTextSpec and superimpose over item image buttons
[minetest.git] / src / environment.cpp
index 2a42f18adef202e7a5e289678aea253f573663c3..38316cb3141d84c8a2a23aafcf2a298dc42094ad 100644 (file)
@@ -49,11 +49,12 @@ with this program; if not, write to the Free Software Foundation, Inc.,
 #define PP(x) "("<<(x).X<<","<<(x).Y<<","<<(x).Z<<")"
 
 Environment::Environment():
+       m_time_of_day_speed(0),
        m_time_of_day(9000),
        m_time_of_day_f(9000./24000),
-       m_time_of_day_speed(0),
-       m_time_conversion_skew(0),
-       m_day_night_ratio_override_storage(0)
+       m_time_conversion_skew(0.0f),
+       m_enable_day_night_ratio_override(false),
+       m_day_night_ratio_override(0.0f)
 {
        m_cache_enable_shaders = g_settings->getBool("enable_shaders");
 }
@@ -179,10 +180,9 @@ std::vector<Player*> Environment::getPlayers(bool ignore_disconnected)
 
 u32 Environment::getDayNightRatio()
 {
-       u64 day_night_st = m_day_night_ratio_override_storage;
-       if (day_night_st & ((u64)1 << 63))
-               return day_night_st & U32_MAX;
-       MutexAutoLock lock(this->m_time_floats_lock);
+       MutexAutoLock lock(this->m_time_lock);
+       if (m_enable_day_night_ratio_override)
+               return m_day_night_ratio_override;
        return time_to_daynight_ratio(m_time_of_day_f * 24000, m_cache_enable_shaders);
 }
 
@@ -196,29 +196,43 @@ float Environment::getTimeOfDaySpeed()
        return m_time_of_day_speed;
 }
 
+void Environment::setDayNightRatioOverride(bool enable, u32 value)
+{
+       MutexAutoLock lock(this->m_time_lock);
+       m_enable_day_night_ratio_override = enable;
+       m_day_night_ratio_override = value;
+}
+
 void Environment::setTimeOfDay(u32 time)
 {
-       MutexAutoLock lock(this->m_time_floats_lock);
+       MutexAutoLock lock(this->m_time_lock);
        m_time_of_day = time;
        m_time_of_day_f = (float)time / 24000.0;
 }
 
 u32 Environment::getTimeOfDay()
 {
+       MutexAutoLock lock(this->m_time_lock);
        return m_time_of_day;
 }
 
 float Environment::getTimeOfDayF()
 {
-       MutexAutoLock lock(this->m_time_floats_lock);
+       MutexAutoLock lock(this->m_time_lock);
        return m_time_of_day_f;
 }
 
 void Environment::stepTimeOfDay(float dtime)
 {
-       MutexAutoLock lock(this->m_time_floats_lock);
-       f32 speed = m_time_of_day_speed * 24000. / (24. * 3600);
-       u32 units = (u32)((dtime + m_time_conversion_skew) * speed);
+       MutexAutoLock lock(this->m_time_lock);
+
+       // Cached in order to prevent the two reads we do to give
+       // different results (can be written by code not under the lock)
+       f32 cached_time_of_day_speed = m_time_of_day_speed;
+
+       f32 speed = cached_time_of_day_speed * 24000. / (24. * 3600);
+       m_time_conversion_skew += dtime;
+       u32 units = (u32)(m_time_conversion_skew * speed);
        bool sync_f = false;
        if (units > 0) {
                // Sync at overflow
@@ -232,7 +246,7 @@ void Environment::stepTimeOfDay(float dtime)
                m_time_conversion_skew -= (f32)units / speed;
        }
        if (!sync_f) {
-               m_time_of_day_f += m_time_of_day_speed / (24. * 3600.) * dtime;
+               m_time_of_day_f += cached_time_of_day_speed / 24 / 3600 * dtime;
                if (m_time_of_day_f > 1.0)
                        m_time_of_day_f -= 1.0;
                if (m_time_of_day_f < 0.0)
@@ -527,10 +541,10 @@ void ServerEnvironment::loadMeta()
        }
 
        try {
-               m_time_of_day = args.getU64("time_of_day");
+               setTimeOfDay(args.getU64("time_of_day"));
        } catch (SettingNotFoundException &e) {
                // This is not as important
-               m_time_of_day = 9000;
+               setTimeOfDay(9000);
        }
 }