From 1edf55d244bd14467a9ebf8ae9c8318904bcacbe Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Ond=C5=99ej=20=C5=A0ebek?= <44544735+xsebek@users.noreply.github.com> Date: Sun, 15 Sep 2024 23:59:34 +0200 Subject: [PATCH] Make Rolex show time (#2147) * show time when robot has `time` capability Prompted by #2146, which used the fancy `rolex` entity for commands but surprisingly did not show time in UI. You can test it with: ```sh git cherry-pick ba8dae31 # see before and after adding rolex cabal run swarm -O0 -- -i data/scenarios/Testing/562-lodestone.yaml --speed 2 --autoplay ``` --- src/swarm-tui/Swarm/TUI/View.hs | 12 +++++------- 1 file changed, 5 insertions(+), 7 deletions(-) diff --git a/src/swarm-tui/Swarm/TUI/View.hs b/src/swarm-tui/Swarm/TUI/View.hs index 3201fc56c..b5df6bb24 100644 --- a/src/swarm-tui/Swarm/TUI/View.hs +++ b/src/swarm-tui/Swarm/TUI/View.hs @@ -61,13 +61,13 @@ import Data.Map qualified as M import Data.Maybe (catMaybes, fromMaybe, isJust, mapMaybe, maybeToList) import Data.Semigroup (sconcat) import Data.Sequence qualified as Seq -import Data.Set qualified as Set (toList) +import Data.Set qualified as Set import Data.Text (Text) import Data.Text qualified as T import Data.Time (NominalDiffTime, defaultTimeLocale, formatTime) import Network.Wai.Handler.Warp (Port) import Swarm.Constant -import Swarm.Game.Device (commandCost, commandsForDeviceCaps, enabledCommands, getMap, ingredients) +import Swarm.Game.Device (commandCost, commandsForDeviceCaps, enabledCommands, getCapabilitySet, getMap, ingredients) import Swarm.Game.Display import Swarm.Game.Entity as E import Swarm.Game.Ingredients @@ -538,14 +538,12 @@ drawClockDisplay lgTPS gs = hBox . intersperse (txt " ") $ catMaybes [clockWidge clockWidget = maybeDrawTime (gs ^. temporal . ticks) (gs ^. temporal . paused || lgTPS < 3) gs pauseWidget = guard (gs ^. temporal . paused) $> txt "(PAUSED)" --- | Check whether the currently focused robot (if any) has a clock --- device equipped. +-- | Check whether the currently focused robot (if any) has some kind +-- of a clock device equipped. clockEquipped :: GameState -> Bool clockEquipped gs = case focusedRobot gs of Nothing -> False - Just r - | countByName "clock" (r ^. equippedDevices) > 0 -> True - | otherwise -> False + Just r -> CExecute Time `Set.member` getCapabilitySet (r ^. robotCapabilities) -- | Format a ticks count as a hexadecimal clock. drawTime :: TickNumber -> Bool -> String