From 71faf5a8f217cf30cffe87b4393bb1e1e8222979 Mon Sep 17 00:00:00 2001 From: Tomas Doran Date: Sun, 10 Jan 2021 17:37:54 +0000 Subject: [PATCH] Fix bugs so you can move from one mount to another --- TODO | 1 - screen/move.go | 20 +++++++++++++------- 2 files changed, 13 insertions(+), 8 deletions(-) diff --git a/TODO b/TODO index f5982ba..1ae74da 100644 --- a/TODO +++ b/TODO @@ -17,6 +17,5 @@ Bug / missing feature list: Gooey blob / Fire character and player interactions Bugs: - - Cannot move from magic wood tree to dark citadel - Players can attack walls? - Line of sight calculation seems a bit harsh currently diff --git a/screen/move.go b/screen/move.go index 6b6c831..a3d5a2a 100644 --- a/screen/move.go +++ b/screen/move.go @@ -303,8 +303,7 @@ func MoveDoAttackMaybe(from, to logical.Vec, playerIdx int, ctx screeniface.Game } if as.IsMount { - - doMount(from, to, grid) + doMount(from, to, grid, isDismount) return MoveStatus{ DidMove: true, MountMove: true, @@ -390,7 +389,7 @@ func DoAttackMaybe(from, to logical.Vec, playerIdx int, ctx screeniface.GameCtx, } // Does belong to this player, see if it's mountable, if so we can move to it _, isPlayer := grid.GetGameObject(from).(*player.Player) - if isPlayer { // We're moving the player, lets see if target is something we can mount + if isPlayer || isDismount { // We're moving the player, lets see if target is something we can mount fmt.Printf("Moving player, check for mount\n") if ob.IsMount() { fmt.Printf(" Is mount\n") @@ -437,11 +436,18 @@ func doCharacterMove(from, to logical.Vec, grid *grid.GameGrid, isDismount bool) grid.PlaceGameObject(to, character) } -func doMount(from, to logical.Vec, grid *grid.GameGrid) { +func doMount(from, to logical.Vec, grid *grid.GameGrid, isDismount bool) { fmt.Printf("doMount\n") - // Take the player off the board (as we just track them as mounted on the character) - // but set their position (in case they dismount without moving first) - grid.GetGameObjectStack(from).RemoveTopObject().SetBoardPosition(to) + stack := grid.GetGameObjectStack(from) + if !isDismount { + // Take the player off the board (as we just track them as mounted on the character) + // but set their position (in case they dismount without moving first) + stack.RemoveTopObject().SetBoardPosition(to) + } else { + // Was already mounted, need to dismount old place + mount := stack.TopObject().(*character.Character) + mount.CarryingPlayer = false + } grid.GetGameObject(to).(*character.Character).Mount() }