From d965d74f358760c6097da5a5268f2d87d4918572 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?M=C3=A1ty=C3=A1s=20Mustoha?= Date: Thu, 23 Nov 2023 16:57:26 +0100 Subject: [PATCH] Prevent possible mouse-related crashes in the world editor --- src/worldeditor/worldeditor.cpp | 77 ++++++++++++++++++--------------- 1 file changed, 43 insertions(+), 34 deletions(-) diff --git a/src/worldeditor/worldeditor.cpp b/src/worldeditor/worldeditor.cpp index 2d5cc52b..b36289cd 100644 --- a/src/worldeditor/worldeditor.cpp +++ b/src/worldeditor/worldeditor.cpp @@ -38,6 +38,7 @@ #include "SDL_image.h" #include "sdl12wrapper.h" +#include #include #include #include @@ -111,6 +112,14 @@ void update_mouse_coords() { if (mouse_y > 480 - 1) mouse_y = 480 - 1; } +int bound_to_window_w(int x) { + return std::max(0, std::min(x, 640)); +} + +int bound_to_window_h(int y) { + return std::max(0, std::min(y, 480)); +} + //Vehicle structure that holds the current vehicle "stamp" WorldVehicle g_wvVehicleStamp; @@ -1323,8 +1332,8 @@ int editor_edit() } case SDL_MOUSEBUTTONDOWN: { - short iButtonX = event.button.x - draw_offset_x; - short iButtonY = event.button.y - draw_offset_y; + short iButtonX = bound_to_window_w(event.button.x) - draw_offset_x; + short iButtonY = bound_to_window_h(event.button.y) - draw_offset_y; short iCol = iButtonX / TILESIZE + draw_offset_col; short iRow = iButtonY / TILESIZE + draw_offset_row; @@ -1502,8 +1511,8 @@ int editor_edit() //Painting tiles with mouse movement case SDL_MOUSEMOTION: { update_mouse_coords(); - short iButtonX = event.button.x - draw_offset_x; - short iButtonY = event.button.y - draw_offset_y; + short iButtonX = bound_to_window_w(event.motion.x) - draw_offset_x; + short iButtonY = bound_to_window_h(event.motion.y) - draw_offset_y; short iCol = (iButtonX >> 5) + draw_offset_col; short iRow = (iButtonY >> 5) + draw_offset_row; @@ -2510,8 +2519,8 @@ int editor_warp() } case SDL_MOUSEBUTTONDOWN: { - short iButtonX = event.button.x / TILESIZE; - short iButtonY = event.button.y / TILESIZE; + short iButtonX = bound_to_window_w(event.button.x) / TILESIZE; + short iButtonY = bound_to_window_h(event.button.y) / TILESIZE; if (event.button.button == SDL_BUTTON_LEFT) { if (iButtonX >= 0 && iButtonX <= 9 && iButtonY == 0) { @@ -2607,8 +2616,8 @@ int editor_start_items() } case SDL_MOUSEBUTTONDOWN: { - short iButtonX = event.button.x; - short iButtonY = event.button.y; + short iButtonX = bound_to_window_w(event.button.x); + short iButtonY = bound_to_window_h(event.button.y); if (event.button.button == SDL_BUTTON_LEFT || event.button.button == SDL_BUTTON_RIGHT) { if (g_worldmap.iNumInitialBonuses < 32) { @@ -2706,8 +2715,8 @@ int editor_boundary() } case SDL_MOUSEBUTTONDOWN: { - short iButtonX = event.button.x / TILESIZE; - short iButtonY = event.button.y / TILESIZE; + short iButtonX = bound_to_window_w(event.button.x) / TILESIZE; + short iButtonY = bound_to_window_h(event.button.y) / TILESIZE; if (event.button.button == SDL_BUTTON_LEFT) { if (iButtonX >= 0 && iButtonX <= 9 && iButtonY >= 0 && iButtonY <= 9) { @@ -2787,8 +2796,8 @@ int editor_type() case SDL_MOUSEBUTTONDOWN: { if (event.button.button == SDL_BUTTON_LEFT) { - short iButtonX = event.button.x / TILESIZE; - short iButtonY = event.button.y / TILESIZE; + short iButtonX = bound_to_window_w(event.button.x) / TILESIZE; + short iButtonY = bound_to_window_h(event.button.y) / TILESIZE; //Start and doors if (iButtonX >= 0 && iButtonX <= 5 && iButtonY == 0) { @@ -2859,8 +2868,8 @@ int editor_water() case SDL_MOUSEBUTTONDOWN: { if (event.button.button == SDL_BUTTON_LEFT) { - short iButtonX = event.button.x / TILESIZE; - short iButtonY = event.button.y / TILESIZE; + short iButtonX = bound_to_window_w(event.button.x) / TILESIZE; + short iButtonY = bound_to_window_h(event.button.y) / TILESIZE; if (iButtonY == 0) { if (iButtonX >= 0 && iButtonX <= 2) { @@ -2935,8 +2944,8 @@ int editor_background() case SDL_MOUSEBUTTONDOWN: { if (event.button.button == SDL_BUTTON_LEFT) { - short iButtonX = event.button.x / TILESIZE; - short iButtonY = event.button.y / TILESIZE; + short iButtonX = bound_to_window_w(event.button.x) / TILESIZE; + short iButtonY = bound_to_window_h(event.button.y) / TILESIZE; short iTileStyleOffset = ((iButtonX / 4) + (iPage * 5)) * WORLD_BACKGROUND_SPRITE_SET_SIZE; @@ -3029,8 +3038,8 @@ int editor_stageforeground() case SDL_MOUSEBUTTONDOWN: { if (event.button.button == SDL_BUTTON_LEFT) { - short iButtonX = event.button.x / TILESIZE; - short iButtonY = event.button.y / TILESIZE; + short iButtonX = bound_to_window_w(event.button.x) / TILESIZE; + short iButtonY = bound_to_window_h(event.button.y) / TILESIZE; if (iButtonX >= 0 && iButtonX < 10) { if (iButtonY >= 0 && iButtonY < 10) { @@ -3100,8 +3109,8 @@ int editor_bridges() case SDL_MOUSEBUTTONDOWN: { if (event.button.button == SDL_BUTTON_LEFT) { - short iButtonX = event.button.x / TILESIZE; - short iButtonY = event.button.y / TILESIZE; + short iButtonX = bound_to_window_w(event.button.x) / TILESIZE; + short iButtonY = bound_to_window_h(event.button.y) / TILESIZE; if (iButtonX >= 0 && iButtonX < 4) { if (iButtonY >= 0 && iButtonY < 1) { @@ -3165,8 +3174,8 @@ int editor_structureforeground() case SDL_MOUSEBUTTONDOWN: { if (event.button.button == SDL_BUTTON_LEFT) { - short iButtonX = event.button.x / TILESIZE; - short iButtonY = event.button.y / TILESIZE; + short iButtonX = bound_to_window_w(event.button.x) / TILESIZE; + short iButtonY = bound_to_window_h(event.button.y) / TILESIZE; if (iButtonY >= 0 && iButtonY < 15) { if (iButtonX >= 0 && iButtonX < 12) { @@ -3235,8 +3244,8 @@ int editor_pathsprite() case SDL_MOUSEBUTTONDOWN: { if (event.button.button == SDL_BUTTON_LEFT) { - short iButtonX = event.button.x / TILESIZE; - short iButtonY = event.button.y / TILESIZE; + short iButtonX = bound_to_window_w(event.button.x) / TILESIZE; + short iButtonY = bound_to_window_h(event.button.y) / TILESIZE; if (iButtonX >= 0 && iButtonX < 8) { if (iButtonY >= 0 && iButtonY < 6) @@ -3332,8 +3341,8 @@ int editor_vehicles() } case SDL_MOUSEBUTTONDOWN: { - short iButtonX = event.button.x; - short iButtonY = event.button.y; + short iButtonX = bound_to_window_w(event.button.x); + short iButtonY = bound_to_window_h(event.button.y); if (event.button.button == SDL_BUTTON_LEFT) { code = mCurrentMenu->MouseClick(iButtonX, iButtonY); @@ -3425,8 +3434,8 @@ int editor_path() case SDL_MOUSEBUTTONDOWN: { if (event.button.button == SDL_BUTTON_LEFT) { - short iButtonX = event.button.x / TILESIZE; - short iButtonY = event.button.y / TILESIZE; + short iButtonX = bound_to_window_w(event.button.x) / TILESIZE; + short iButtonY = bound_to_window_h(event.button.y) / TILESIZE; if (iButtonX >= 0 && iButtonX <= 15 && iButtonY == 0) { set_tile = iButtonX + 1; @@ -3962,10 +3971,10 @@ int editor_stage() } case SDL_MOUSEBUTTONDOWN: { - short iTileX = event.button.x / TILESIZE; - short iTileY = event.button.y / TILESIZE; - short iButtonX = event.button.x; - short iButtonY = event.button.y; + short iTileX = bound_to_window_w(event.button.x) / TILESIZE; + short iTileY = bound_to_window_h(event.button.y) / TILESIZE; + short iButtonX = bound_to_window_w(event.button.x); + short iButtonY = bound_to_window_h(event.button.y); if (event.button.button == SDL_BUTTON_LEFT) { //Stages @@ -4036,8 +4045,8 @@ int editor_stage() if (iEditStage == -1) { // if (event.button.x >= 0 && event.button.y >= 0) { - short iMouseX = event.button.x / TILESIZE; - short iMouseY = event.button.y / TILESIZE; + short iMouseX = bound_to_window_w(event.button.x) / TILESIZE; + short iMouseY = bound_to_window_h(event.button.y) / TILESIZE; if (iMouseX >= 0 && iMouseX < g_worldmap.iNumStages - (iMouseY * 20) && iMouseY >= 0 && iMouseY <= (g_worldmap.iNumStages - 1) / 20) { iStageDisplay = iMouseX + (iMouseY * 20);