From 049e63d7f37229245ab241a3d3d411077fa38afd Mon Sep 17 00:00:00 2001 From: helixhorned Date: Thu, 13 Dec 2012 22:21:22 +0000 Subject: [PATCH] Mapster32: In 3D mode, [,] auto-aligns walls to the left. git-svn-id: https://svn.eduke32.com/eduke32@3281 1a8010ca-5511-0410-912e-c29ae57300e0 --- polymer/eduke32/build/src/build.c | 8 +++++--- polymer/eduke32/source/astub.c | 7 ++++--- 2 files changed, 9 insertions(+), 6 deletions(-) diff --git a/polymer/eduke32/build/src/build.c b/polymer/eduke32/build/src/build.c index 3607d7d3f..19cdaa1f6 100644 --- a/polymer/eduke32/build/src/build.c +++ b/polymer/eduke32/build/src/build.c @@ -10403,13 +10403,15 @@ void AlignWallPoint2(int32_t w0) // 2: iterate point2's // 4: carry pixel width from first wall over to the rest // 8: align TROR nextwalls +// 16: iterate lastwall()s (point2 in reverse) int32_t AutoAlignWalls(int32_t w0, uint32_t flags, int32_t nrecurs) { static int32_t numaligned, wall0, cstat0; static uint32_t lenrepquot; + const int32_t totheleft = flags&16; int32_t z0 = GetWallBaseZ(w0); - int32_t w1 = wall[w0].point2; + int32_t w1 = totheleft ? lastwall(w0) : wall[w0].point2; const int32_t tilenum = wall[w0].picnum; if (nrecurs == 0) @@ -10496,7 +10498,7 @@ int32_t AutoAlignWalls(int32_t w0, uint32_t flags, int32_t nrecurs) break; w0 = w1; z0 = GetWallBaseZ(w0); - w1 = wall[w0].point2; + w1 = totheleft ? lastwall(w0) : wall[w0].point2; continue; } @@ -10508,7 +10510,7 @@ int32_t AutoAlignWalls(int32_t w0, uint32_t flags, int32_t nrecurs) if (wall[w1].nextwall < 0 || !(flags&2)) break; - w1 = NEXTWALL(w1).point2; + w1 = totheleft ? lastwall(wall[w1].nextwall) : NEXTWALL(w1).point2; } return numaligned; diff --git a/polymer/eduke32/source/astub.c b/polymer/eduke32/source/astub.c index 103ee6ff5..cba266e74 100644 --- a/polymer/eduke32/source/astub.c +++ b/polymer/eduke32/source/astub.c @@ -5186,10 +5186,11 @@ static void Keys3d(void) } // . Search & fix panning to the right (3D) - if (AIMING_AT_WALL_OR_MASK && PRESSED_KEYSC(PERIOD)) + if (AIMING_AT_WALL_OR_MASK && ((tsign=PRESSED_KEYSC(PERIOD)) || PRESSED_KEYSC(COMMA))) { - int32_t naligned=AutoAlignWalls(searchwall, eitherCTRL|((!eitherSHIFT)<<1)| - (eitherALT<<2)|((!!keystatus[KEYSC_QUOTE])<<3), 0); + uint32_t flags = eitherCTRL | ((!eitherSHIFT)<<1) | (tsign?0:16) | + (eitherALT<<2) | ((!!keystatus[KEYSC_QUOTE])<<3); + int32_t naligned=AutoAlignWalls(searchwall, flags, 0); message("Aligned %d wall%s based on wall %d%s%s%s%s", naligned, naligned==1?"":"s", searchwall, eitherCTRL?", recursing nextwalls":"",