From 53c39bf25f008bec91fc6cded13f54718b2b31fd Mon Sep 17 00:00:00 2001 From: UbitUmarov Date: Thu, 17 Oct 2019 21:35:34 +0100 Subject: Xengine: Error on division by Zero. Yengine will take a lot more work. If your script gets killed by this, don't bother us, your script is just BAD --- OpenSim/Region/ScriptEngine/Shared/LSL_Types.cs | 55 +++++++++++++++++++++---- 1 file changed, 46 insertions(+), 9 deletions(-) (limited to 'OpenSim/Region/ScriptEngine') diff --git a/OpenSim/Region/ScriptEngine/Shared/LSL_Types.cs b/OpenSim/Region/ScriptEngine/Shared/LSL_Types.cs index f981e89..6af4a54 100644 --- a/OpenSim/Region/ScriptEngine/Shared/LSL_Types.cs +++ b/OpenSim/Region/ScriptEngine/Shared/LSL_Types.cs @@ -245,9 +245,21 @@ namespace OpenSim.Region.ScriptEngine.Shared public static Vector3 operator /(Vector3 v, float f) { - v.x = v.x / f; - v.y = v.y / f; - v.z = v.z / f; + double r = v.x / f; + if (double.IsNaN(r) || double.IsNegativeInfinity(r) || double.IsPositiveInfinity(r)) + throw new ScriptException("Vector division by zero"); + v.x = r; + + r = v.y / f; + if (double.IsNaN(r) || double.IsNegativeInfinity(r) || double.IsPositiveInfinity(r)) + throw new ScriptException("Vector division by zero"); + v.y = r; + + r = v.z / f; + if (double.IsNaN(r) || double.IsNegativeInfinity(r) || double.IsPositiveInfinity(r)) + throw new ScriptException("Vector division by zero"); + v.z = r; + return v; } @@ -267,9 +279,21 @@ namespace OpenSim.Region.ScriptEngine.Shared public static Vector3 operator /(Vector3 v, double f) { - v.x = v.x / f; - v.y = v.y / f; - v.z = v.z / f; + double r = v.x / f; + if (double.IsNaN(r) || double.IsNegativeInfinity(r) || double.IsPositiveInfinity(r)) + throw new ScriptException("Vector division by zero"); + v.x = r; + + r = v.y / f; + if (double.IsNaN(r) || double.IsNegativeInfinity(r) || double.IsPositiveInfinity(r)) + throw new ScriptException("Vector division by zero"); + v.y = r; + + r = v.z / f; + if (double.IsNaN(r) || double.IsNegativeInfinity(r) || double.IsPositiveInfinity(r)) + throw new ScriptException("Vector division by zero"); + v.z = r; + return v; } @@ -1987,7 +2011,14 @@ namespace OpenSim.Region.ScriptEngine.Shared static public LSLInteger operator /(LSLInteger i1, int i2) { - return new LSLInteger(i1.value / i2); + try + { + return new LSLInteger(i1.value / i2); + } + catch(DivideByZeroException) + { + throw new ScriptException("Integer division by Zero"); + } } // static public LSLFloat operator +(LSLInteger i1, double f) @@ -2260,7 +2291,10 @@ namespace OpenSim.Region.ScriptEngine.Shared static public LSLFloat operator /(LSLFloat f, int i) { - return new LSLFloat(f.value / (double)i); + double r = f.value / (double)i; + if (double.IsNaN(r) || double.IsNegativeInfinity(r) || double.IsPositiveInfinity(r)) + throw new ScriptException("Float division by zero"); + return new LSLFloat(r); } static public LSLFloat operator +(LSLFloat lhs, LSLFloat rhs) @@ -2280,7 +2314,10 @@ namespace OpenSim.Region.ScriptEngine.Shared static public LSLFloat operator /(LSLFloat lhs, LSLFloat rhs) { - return new LSLFloat(lhs.value / rhs.value); + double r = lhs.value / rhs.value; + if (double.IsNaN(r) || double.IsNegativeInfinity(r) || double.IsPositiveInfinity(r)) + throw new ScriptException("Float division by zero"); + return new LSLFloat(r); } static public LSLFloat operator -(LSLFloat f) -- cgit v1.1