{-# LANGUAGE ScopedTypeVariables #-}
{-# LANGUAGE DataKinds, GADTs, RankNTypes, TypeOperators, KindSignatures #-}
{-# LANGUAGE FlexibleInstances #-}
{-# LANGUAGE PatternSynonyms #-}
module GHC.Wasm.ControlFlow
  ( WasmControl(..), (<>), pattern WasmIf, wasmReturn
  , BrTableInterval(..), inclusiveInterval
  , WasmType, WasmTypeTag(..)
  , TypeList(..)
  , WasmFunctionType(..)
  )
where
import GHC.Prelude
import GHC.CmmToAsm.Wasm.Types
import GHC.Utils.Panic
inclusiveInterval :: Integer -> Integer -> BrTableInterval
inclusiveInterval :: Integer -> Integer -> BrTableInterval
inclusiveInterval Integer
lo Integer
hi
    | Integer
lo forall a. Ord a => a -> a -> Bool
<= Integer
hi = let count :: Integer
count = Integer
hi forall a. Num a => a -> a -> a
- Integer
lo forall a. Num a => a -> a -> a
+ Integer
1
                 in  Integer -> Integer -> BrTableInterval
BrTableInterval Integer
lo Integer
count
    | Bool
otherwise = forall a. HasCallStack => String -> a
panic String
"GHC.Wasm.ControlFlow: empty interval"
(<>) :: forall s e pre mid post
      . WasmControl s e pre mid
     -> WasmControl s e mid post
     -> WasmControl s e pre post
<> :: forall s e (pre :: [WasmType]) (mid :: [WasmType])
       (post :: [WasmType]).
WasmControl s e pre mid
-> WasmControl s e mid post -> WasmControl s e pre post
(<>) = forall s e (pre :: [WasmType]) (mid :: [WasmType])
       (post :: [WasmType]).
WasmControl s e pre mid
-> WasmControl s e mid post -> WasmControl s e pre post
WasmSeq
pattern WasmIf :: WasmFunctionType pre post
               -> e
               -> WasmControl s e pre post
               -> WasmControl s e pre post
               -> WasmControl s e pre post
pattern $bWasmIf :: forall (pre :: [WasmType]) (post :: [WasmType]) e s.
WasmFunctionType pre post
-> e
-> WasmControl s e pre post
-> WasmControl s e pre post
-> WasmControl s e pre post
$mWasmIf :: forall {r} {pre :: [WasmType]} {post :: [WasmType]} {e} {s}.
WasmControl s e pre post
-> (WasmFunctionType pre post
    -> e -> WasmControl s e pre post -> WasmControl s e pre post -> r)
-> ((# #) -> r)
-> r
WasmIf ty e t f =
    WasmPush TagI32 e `WasmSeq` WasmIfTop ty t f
wasmReturn :: WasmTypeTag t -> e -> WasmControl s e (t ': t1star) t2star
wasmReturn :: forall (t :: WasmType) e s (t1star :: [WasmType])
       (t2star :: [WasmType]).
WasmTypeTag t -> e -> WasmControl s e (t : t1star) t2star
wasmReturn WasmTypeTag t
tag e
e = forall (t :: WasmType) b a (c :: [WasmType]).
WasmTypeTag t -> b -> WasmControl a b c (t : c)
WasmPush WasmTypeTag t
tag e
e forall s e (pre :: [WasmType]) (mid :: [WasmType])
       (post :: [WasmType]).
WasmControl s e pre mid
-> WasmControl s e mid post -> WasmControl s e pre post
`WasmSeq` forall (t :: WasmType) a b (t1star :: [WasmType])
       (d :: [WasmType]).
WasmTypeTag t -> WasmControl a b (t : t1star) d
WasmReturnTop WasmTypeTag t
tag