diff options
| author | Tom Smeding <tom@tomsmeding.com> | 2024-10-22 23:46:39 +0200 | 
|---|---|---|
| committer | Tom Smeding <tom@tomsmeding.com> | 2024-10-22 23:47:53 +0200 | 
| commit | 3847c6ae2d5eb581dac88629e7534aa42e143411 (patch) | |
| tree | 63036604613f8ac17efd8978004c579a0a5bb39b /src/AST.hs | |
| parent | d6d07f3bf20b4a3c0e51b4414fb0e4538176d294 (diff) | |
Fix interpreter bug
Diffstat (limited to 'src/AST.hs')
| -rw-r--r-- | src/AST.hs | 10 | 
1 files changed, 5 insertions, 5 deletions
| @@ -92,7 +92,7 @@ data Expr x env t where    EConst :: Show (ScalRep t) => x (TScal t) -> SScalTy t -> ScalRep t -> Expr x env (TScal t)    EIdx0 :: x t -> Expr x env (TArr Z t) -> Expr x env t    EIdx1 :: x (TArr n t) -> Expr x env (TArr (S n) t) -> Expr x env TIx -> Expr x env (TArr n t) -  EIdx :: x t -> SNat n -> Expr x env (TArr n t) -> Expr x env (Tup (Replicate n TIx)) -> Expr x env t +  EIdx :: x t -> Expr x env (TArr n t) -> Expr x env (Tup (Replicate n TIx)) -> Expr x env t    EShape :: x (Tup (Replicate n TIx)) -> Expr x env (TArr n t) -> Expr x env (Tup (Replicate n TIx))    EOp :: x t -> SOp a t -> Expr x env a -> Expr x env t @@ -194,7 +194,7 @@ typeOf = \case    EConst _ t _ -> STScal t    EIdx0 _ e | STArr _ t <- typeOf e -> t    EIdx1 _ e _ | STArr (SS n) t <- typeOf e -> STArr n t -  EIdx _ _ e _ | STArr _ t <- typeOf e -> t +  EIdx _ e _ | STArr _ t <- typeOf e -> t    EShape _ e | STArr n _ <- typeOf e -> tTup (sreplicate n tIx)    EOp _ op _ -> opt2 op @@ -267,7 +267,7 @@ subst' f w = \case    EConst x t v -> EConst x t v    EIdx0 x e -> EIdx0 x (subst' f w e)    EIdx1 x a b -> EIdx1 x (subst' f w a) (subst' f w b) -  EIdx x n e es -> EIdx x n (subst' f w e) (subst' f w es) +  EIdx x e es -> EIdx x (subst' f w e) (subst' f w es)    EShape x e -> EShape x (subst' f w e)    EOp x op e -> EOp x op (subst' f w e)    EWith e1 e2 -> EWith (subst' f w e1) (subst' (sinkF f) (WCopy w) e2) @@ -339,5 +339,5 @@ ebuildUp1 :: SNat n -> Ex env (Tup (Replicate n TIx)) -> Ex env TIx -> Ex (TIx :  ebuildUp1 n sh size f =    EBuild ext (SS n) (EPair ext sh size) $      let arg = EVar ext (tTup (sreplicate (SS n) tIx)) IZ -    in EIdx ext n (ELet ext (ESnd ext arg) (weakenExpr (WCopy WSink) f)) -                  (EFst ext arg) +    in EIdx ext (ELet ext (ESnd ext arg) (weakenExpr (WCopy WSink) f)) +                (EFst ext arg) | 
