# HG changeset patch # User unc0rr # Date 1333373298 -14400 # Node ID 3cbfc35f6c2e72073f977371715853f4c693a90d # Parent 59da15acb2f23a7b53844535dc22c9f7c565bc05 - Handle multidimensional arrays better - Error message for WithBlock to check type errors diff -r 59da15acb2f2 -r 3cbfc35f6c2e tools/pas2c.hs --- a/tools/pas2c.hs Mon Apr 02 16:14:29 2012 +0400 +++ b/tools/pas2c.hs Mon Apr 02 17:28:18 2012 +0400 @@ -394,11 +394,16 @@ ph <- phrase2C p return $ text "case" <+> parens (hsep . punctuate (char ',') $ ie) <> char ':' <> nest 4 (ph $+$ text "break;") -phrase2C (WithBlock ref p) = do +phrase2C wb@(WithBlock ref p) = do r <- ref2C ref - (BTRecord rs) <- gets lastType - ph <- withRecordNamespace rs $ phrase2C $ wrapPhrase p - return $ text "namespace" <> parens r $$ ph + t <- gets lastType + case t of + (BTRecord rs) -> do + ph <- withRecordNamespace rs $ phrase2C $ wrapPhrase p + return $ text "namespace" <> parens r $$ ph + a -> do + ns <- gets currentScope + error $ "'with' block referencing non-record type " ++ show a ++ "\n" ++ show wb ++ "\nnamespace: " ++ show (take 100 ns) phrase2C (ForCycle i' e1' e2' p) = do i <- id2C IOLookup i' e1 <- expr2C e1' @@ -448,7 +453,9 @@ t <- gets lastType ns <- gets currentScope case t of - (BTArray _ (BTArray _ t')) -> modify (\st -> st{lastType = t'}) + (BTArray _ ta@(BTArray _ t')) + | length exprs == 2 -> modify (\st -> st{lastType = t'}) + | otherwise -> modify (\st -> st{lastType = ta}) (BTArray _ t') -> modify (\st -> st{lastType = t'}) (BTString) -> modify (\st -> st{lastType = BTChar}) a -> error $ "Getting element of " ++ show a ++ "\nReference: " ++ show ae ++ "\n" ++ show (take 100 ns)