Changeset - r25890:31b085404537
[Not reviewed]
master
0 2 0
Michael Lutz - 3 years ago 2021-08-15 10:14:53
michi@icosahedron.de
Fix 2183fd4d: [NewGRF] Use divide instead of right shift for signed numbers. (#9480)

"For negative a, the value of a >> b is implementation-defined (in most implementations, this performs arithmetic right shift, so that the result remains negative)."
2 files changed with 2 insertions and 2 deletions:
0 comments (0 inline, 0 general)
src/newgrf_engine.cpp
Show inline comments
 
@@ -1189,7 +1189,7 @@ int GetEngineProperty(EngineID engine, P
 
	if (callback != CALLBACK_FAILED) {
 
		if (is_signed) {
 
			/* Sign extend 15 bit integer */
 
			return static_cast<int16>(callback << 1) >> 1;
 
			return static_cast<int16>(callback << 1) / 2;
 
		} else {
 
			return callback;
 
		}
src/train_cmd.cpp
Show inline comments
 
@@ -363,7 +363,7 @@ int Train::GetCurveSpeedLimit() const
 

	
 
		/* Apply max_speed modifier (cached value is fixed-point binary with 8 fractional bits)
 
		 * and clamp the result to an acceptable range. */
 
		max_speed += (max_speed * this->tcache.cached_curve_speed_mod) >> 8;
 
		max_speed += (max_speed * this->tcache.cached_curve_speed_mod) / 256;
 
		max_speed = Clamp(max_speed, 2, absolute_max_speed);
 
	}
 

	
0 comments (0 inline, 0 general)