From 13178b7cdace6fcc8f6aec8a7bac46beebdca9c5 Mon Sep 17 00:00:00 2001 From: helixhorned Date: Mon, 20 Aug 2012 21:27:42 +0000 Subject: [PATCH] Mapster32: properly reset highlights in undo/redo. git-svn-id: https://svn.eduke32.com/eduke32@2943 1a8010ca-5511-0410-912e-c29ae57300e0 --- polymer/eduke32/build/include/editor.h | 2 ++ polymer/eduke32/build/src/build.c | 30 +++++++++++++++----------- polymer/eduke32/source/astub.c | 6 +++--- 3 files changed, 23 insertions(+), 15 deletions(-) diff --git a/polymer/eduke32/build/include/editor.h b/polymer/eduke32/build/include/editor.h index ce50c0b6b..bcb26d586 100644 --- a/polymer/eduke32/build/include/editor.h +++ b/polymer/eduke32/build/include/editor.h @@ -240,6 +240,8 @@ void getpoint(int32_t searchxe, int32_t searchye, int32_t *x, int32_t *y); int32_t getpointhighlight(int32_t xplc, int32_t yplc, int32_t point); void update_highlight(void); void update_highlightsector(void); +void reset_highlightsector(void); +void reset_highlight(void); void ovh_whiteoutgrab(int32_t restoreredwalls); int32_t inside_editor_curpos(int16_t sectnum); diff --git a/polymer/eduke32/build/src/build.c b/polymer/eduke32/build/src/build.c index ccefafb42..6e6ef7174 100644 --- a/polymer/eduke32/build/src/build.c +++ b/polymer/eduke32/build/src/build.c @@ -2460,6 +2460,7 @@ static int32_t compare_wall_coords(const void *w1, const void *w2) #undef GETWALCOORD #endif +// VARIOUS RESETTING FUNCTIONS #define RESET_EDITOR_VARS() do { \ sectorhighlightstat = -1; \ newnumwalls = -1; \ @@ -2468,6 +2469,18 @@ static int32_t compare_wall_coords(const void *w1, const void *w2) circlepoints = 7; \ } while (0) +void reset_highlightsector(void) +{ + Bmemset(hlsectorbitmap, 0, sizeof(hlsectorbitmap)); + update_highlightsector(); +} + +void reset_highlight(void) // walls and sprites +{ + Bmemset(show2dwall, 0, sizeof(show2dwall)); + Bmemset(show2dsprite, 0, sizeof(show2dsprite)); + update_highlight(); +} #ifdef YAX_ENABLE static int32_t collnumsects[2]; @@ -4061,8 +4074,7 @@ rotate_hlsect_out: yax_update(0); yax_updategrays(pos.z); - Bmemset(hlsectorbitmap, 0, sizeof(hlsectorbitmap)); - update_highlightsector(); + reset_highlightsector(); if (sandwichbunch < 0) message("Extended %ss of highlighted sectors, creating bunch %d", @@ -4254,9 +4266,7 @@ rotate_hlsect_out: // clear wall & sprite highlights // TODO: see about consistency with update_highlight() after other ops - Bmemset(show2dwall, 0, sizeof(show2dwall)); - Bmemset(show2dsprite, 0, sizeof(show2dsprite)); - update_highlight(); + reset_highlight(); // construct the loop! i = AddLoopToSector(dstsect, &ofirstwallofs); @@ -5703,8 +5713,7 @@ end_point_dragging: } } - Bmemset(hlsectorbitmap, 0, sizeof(hlsectorbitmap)); - update_highlightsector(); + reset_highlightsector(); yax_update(0); yax_updategrays(pos.z); @@ -7081,11 +7090,8 @@ end_batch_insert_points: yax_setbunch(j, YAX_FLOOR, -1); } #endif - Bmemset(hlsectorbitmap, 0, sizeof(hlsectorbitmap)); - update_highlightsector(); - - Bmemset(show2dwall, 0, sizeof(show2dwall)); - update_highlight(); + reset_highlightsector(); + reset_highlight(); newnumwalls = -1; asksave = 1; diff --git a/polymer/eduke32/source/astub.c b/polymer/eduke32/source/astub.c index 4bb1a6a33..f3c6cbf3e 100644 --- a/polymer/eduke32/source/astub.c +++ b/polymer/eduke32/source/astub.c @@ -564,9 +564,9 @@ int32_t map_undoredo(int32_t dir) map_revision = mapstate->revision; Bmemset(show2dsector, 0, sizeof(show2dsector)); - Bmemset(show2dsprite, 0, sizeof(show2dsprite)); - Bmemset(show2dwall, 0, sizeof(show2dwall)); - Bmemset(hlsectorbitmap, 0, sizeof(hlsectorbitmap)); + + reset_highlightsector(); + reset_highlight(); initspritelists();