From 64904b409767c77d4a741b73c920927d18094eaa Mon Sep 17 00:00:00 2001 From: Thomas Bleher Date: Tue, 1 Dec 2020 21:27:49 +0100 Subject: [PATCH] tttool play: improve handling of the J command (#231) The J() command is executed after all other commands in the line have executed. The 2s pause if no P() follows J() (as documented in https://github.com/entropia/tip-toi-reveng/issues/179#issuecomment-374037262) is not implemented yet. --- src/GMERun.hs | 11 ++++++++++- 1 file changed, 10 insertions(+), 1 deletion(-) diff --git a/src/GMERun.hs b/src/GMERun.hs index fda58d65..bdce211d 100644 --- a/src/GMERun.hs +++ b/src/GMERun.hs @@ -102,8 +102,17 @@ playTTAudio i = do let bs = ttAudioFiles tt !! fromIntegral i liftIO $ playSound bs +-- Rules for J(): jumps are executed last; the last J() wins. +-- Effectively this is like a jump register is set, which is consulted after +-- all other commands have executed. Simulate this by moving the last Jump +-- to the end of the list and discarding all others. +moveJumpsLast Nothing [] = [] +moveJumpsLast (Just x) [] = [x] +moveJumpsLast _ (Jump v : acts) = moveJumpsLast (Just (Jump v)) acts +moveJumpsLast j (x : acts) = x : (moveJumpsLast j acts) + applyLine :: Line Word16 -> GMEM Word16 () -applyLine (Line _ _ acts playlist) = go acts +applyLine (Line _ _ acts playlist) = go (moveJumpsLast Nothing acts) where go (Neg r : acts) = do modReg r neg