From 2e5bc4323ad553b8f85fef881b552b8e8c9e956d Mon Sep 17 00:00:00 2001
From: frankhjwx <frankhjwx@gmail.com>
Date: Mon, 21 May 2018 13:31:00 +0800
Subject: [PATCH] Fixing null reference exception bugs

---
 .../Difficulty/CatchDifficultyCalculator.cs              | 9 +++++----
 .../Difficulty/CatchDifficultyHitObject.cs               | 4 ++--
 2 files changed, 7 insertions(+), 6 deletions(-)

diff --git a/osu.Game.Rulesets.Catch/Difficulty/CatchDifficultyCalculator.cs b/osu.Game.Rulesets.Catch/Difficulty/CatchDifficultyCalculator.cs
index 31de9cfc8d..2fa946f41c 100644
--- a/osu.Game.Rulesets.Catch/Difficulty/CatchDifficultyCalculator.cs
+++ b/osu.Game.Rulesets.Catch/Difficulty/CatchDifficultyCalculator.cs
@@ -34,7 +34,7 @@ namespace osu.Game.Rulesets.Catch.Difficulty
             difficultyHitObjects.Clear();
 
             float circleSize = Beatmap.BeatmapInfo.BaseDifficulty.CircleSize;
-            float catcherWidth = (1.0f - 0.7f * (circleSize - 5) / 5) * 0.62064f * CatcherArea.CATCHER_SIZE;
+            float catcherWidth = ((1.0f - 0.7f * (circleSize - 5) / 5) * 0.62064f) * CatcherArea.CATCHER_SIZE;
             float catcherWidthHalf = catcherWidth / 2;
             catcherWidthHalf *= 0.8f;
 
@@ -72,7 +72,7 @@ namespace osu.Game.Rulesets.Catch.Difficulty
                 double ar = Beatmap.BeatmapInfo.BaseDifficulty.ApproachRate;
                 double preEmpt = BeatmapDifficulty.DifficultyRange(ar, 1800, 1200, 450) / TimeRate;
 
-                categoryDifficulty["AR"] = preEmpt > 1200.0 ? -(preEmpt - 1800.0) / 120.0 : -(preEmpt - 1200.0) / 150.0 + 5.0;
+                categoryDifficulty["AR"] = (preEmpt > 1200.0) ? -(preEmpt - 1800.0) / 120.0 : (-(preEmpt - 1200.0) / 150.0) + 5.0;
                 categoryDifficulty["Max combo"] = difficultyHitObjects.Count;
             }
 
@@ -92,7 +92,8 @@ namespace osu.Game.Rulesets.Catch.Difficulty
                 while (hitObjectsEnumerator.MoveNext())
                 {
                     CatchDifficultyHitObject nextHitObject = hitObjectsEnumerator.Current;
-                    nextHitObject.CalculateStrains(currentHitObject, TimeRate);
+                    if (nextHitObject != null)
+                        nextHitObject.CalculateStrains(currentHitObject, TimeRate);
                     currentHitObject = nextHitObject;
                 }
 
@@ -111,7 +112,7 @@ namespace osu.Game.Rulesets.Catch.Difficulty
         /// The weighting of each strain value decays to this number * it's previous value
         /// </summary>
         private const double decay_weight = 0.94;
-
+        
         protected double CalculateDifficulty()
         {
             // The strain step needs to be adjusted for the algorithm to be considered equal with speed changing mods
diff --git a/osu.Game.Rulesets.Catch/Difficulty/CatchDifficultyHitObject.cs b/osu.Game.Rulesets.Catch/Difficulty/CatchDifficultyHitObject.cs
index d9b16c2a0b..72fc6d211b 100644
--- a/osu.Game.Rulesets.Catch/Difficulty/CatchDifficultyHitObject.cs
+++ b/osu.Game.Rulesets.Catch/Difficulty/CatchDifficultyHitObject.cs
@@ -10,7 +10,7 @@ namespace osu.Game.Rulesets.Catch.Difficulty
 {
     internal class CatchDifficultyHitObject
     {
-        internal static readonly double decay_base = 0.20;
+        internal static readonly double DECAY_BASE = 0.20;
         private const float normalized_hitobject_radius = 41.0f;
         private const float absolute_player_positioning_error = 16f;
         private readonly float playerPositioningError;
@@ -49,7 +49,7 @@ namespace osu.Game.Rulesets.Catch.Difficulty
             // Rather simple, but more specialized things are inherently inaccurate due to the big difference playstyles and opinions make.
             // See Taiko feedback thread.
             double timeElapsed = (BaseHitObject.StartTime - previousHitObject.BaseHitObject.StartTime) / timeRate;
-            double decay = Math.Pow(decay_base, timeElapsed / 1000);
+            double decay = Math.Pow(DECAY_BASE, timeElapsed / 1000);
 
             // Update new position with lazy movement.
             PlayerPositionOffset =