From: Perttu Ahola Date: Mon, 9 Apr 2012 20:06:24 +0000 (+0300) Subject: Fix ABM handling on block activation X-Git-Url: http://81.2.79.47:8989/gitweb/?a=commitdiff_plain;h=8ed74a342988b7d67a7c9eacc2257ba42acd00de;p=zefram%2Fminetest%2Fminetest_engine.git Fix ABM handling on block activation --- diff --git a/src/environment.cpp b/src/environment.cpp index e1f5bb3f..43dbb65d 100644 --- a/src/environment.cpp +++ b/src/environment.cpp @@ -633,13 +633,15 @@ public: i->timer -= trigger_interval; actual_interval = trigger_interval; } - ActiveABM aabm; - aabm.abm = abm; float intervals = actual_interval / trigger_interval; + if(intervals == 0) + continue; float chance = abm->getTriggerChance(); if(chance == 0) chance = 1; - aabm.chance = 1.0 / pow((float)1.0/chance, (float)intervals); + ActiveABM aabm; + aabm.abm = abm; + aabm.chance = chance / intervals; if(aabm.chance == 0) aabm.chance = 1; // Trigger neighbors