From 44e2576c867e5fe51a17f64c0e97843dea990581 Mon Sep 17 00:00:00 2001 From: thefiddler Date: Wed, 15 Jan 2014 01:24:20 +0100 Subject: [PATCH] [OpenTK] Protect against invalid axis/button ids --- Source/OpenTK/Input/JoystickDevice.cs | 28 ++++++++++++++++----------- 1 file changed, 17 insertions(+), 11 deletions(-) diff --git a/Source/OpenTK/Input/JoystickDevice.cs b/Source/OpenTK/Input/JoystickDevice.cs index 8e239f56..0467ce2d 100644 --- a/Source/OpenTK/Input/JoystickDevice.cs +++ b/Source/OpenTK/Input/JoystickDevice.cs @@ -130,22 +130,28 @@ namespace OpenTK.Input internal void SetAxis(JoystickAxis axis, float @value) { - move_args.Axis = axis; - move_args.Delta = move_args.Value - @value; - axis_collection[axis] = move_args.Value = @value; - Move(this, move_args); + if ((int)axis < axis_collection.Count) + { + move_args.Axis = axis; + move_args.Delta = move_args.Value - @value; + axis_collection[axis] = move_args.Value = @value; + Move(this, move_args); + } } internal void SetButton(JoystickButton button, bool @value) { - if (button_collection[button] != @value) + if ((int)button < button_collection.Count) { - button_args.Button = button; - button_collection[button] = button_args.Pressed = @value; - if (@value) - ButtonDown(this, button_args); - else - ButtonUp(this, button_args); + if (button_collection[button] != @value) + { + button_args.Button = button; + button_collection[button] = button_args.Pressed = @value; + if (@value) + ButtonDown(this, button_args); + else + ButtonUp(this, button_args); + } } }