-- UUAGC 0.9.22 (GenerateCode.ag) module GenerateCode where {-# LINE 9 "GenerateCode.ag" #-} import CommonTypes import SequentialTypes import Code hiding (Type) import qualified Code import Options import CodeSyntax import ErrorMessages import GrammarInfo import DeclBlocks import qualified Data.Map as Map import Data.Map(Map) import qualified Data.Set as Set import Data.Set(Set) import qualified Data.Sequence as Seq import Data.Sequence(Seq) import UU.Scanner.Position import TokenDef import HsToken import HsTokenScanner import Data.List(partition,intersperse,intersect,(\\)) import Maybe(fromJust,isJust) {-# LINE 31 "../src-derived/GenerateCode.hs" #-} {-# LINE 2 "./CodeSyntax.ag" #-} import Patterns import CommonTypes import Data.Map(Map) import Data.Set(Set) {-# LINE 39 "../src-derived/GenerateCode.hs" #-} {-# LINE 2 "./Patterns.ag" #-} -- Patterns.ag imports import UU.Scanner.Position(Pos) import CommonTypes (ConstructorIdent,Identifier) {-# LINE 46 "../src-derived/GenerateCode.hs" #-} {-# LINE 2 "./DeclBlocks.ag" #-} import Code (Decl,Expr) {-# LINE 51 "../src-derived/GenerateCode.hs" #-} {-# LINE 101 "GenerateCode.ag" #-} -- remove possible @v references in the types of a data type. cleanupArg :: String -> String cleanupArg s = case idEvalType (SimpleType s) of SimpleType s' -> s' {-# LINE 59 "../src-derived/GenerateCode.hs" #-} {-# LINE 115 "GenerateCode.ag" #-} appContext :: ContextMap -> NontermIdent -> Code.Type -> Code.Type appContext mp nt tp = maybe tp (\ctx -> CtxApp (map (\(n,ns) -> (getName n, ns)) ctx) tp) $ Map.lookup nt mp {-# LINE 66 "../src-derived/GenerateCode.hs" #-} {-# LINE 198 "GenerateCode.ag" #-} mkDecl True lhs rhs _ _ = Bind lhs rhs mkDecl False lhs rhs s1 s2 = Decl lhs rhs s1 s2 unwrapSem :: Bool -> NontermIdent -> Expr -> Expr unwrapSem False _ e = e unwrapSem True nm e = Case e alts where alts = [CaseAlt left right] left = Fun (typeName nm 0) [SimpleExpr "x"] right = SimpleExpr "x" {-# LINE 79 "../src-derived/GenerateCode.hs" #-} {-# LINE 349 "GenerateCode.ag" #-} substSelf nt tp = case tp of NT t tps | t == _SELF -> Haskell (getName nt ++ " " ++ unwords tps) _ -> tp {-# LINE 86 "../src-derived/GenerateCode.hs" #-} {-# LINE 457 "GenerateCode.ag" #-} mkLambdaArg :: String -> Maybe Code.Type -> Expr mkLambdaArg nm Nothing = SimpleExpr nm mkLambdaArg nm (Just tp) = TypedExpr (SimpleExpr nm) tp mkLambda :: Exprs -> Expr -> Expr mkLambda [] e = e mkLambda xs e = Lambda xs e typeAppStrs nm params = TypeApp (SimpleType nm) (map SimpleType params) {-# LINE 99 "../src-derived/GenerateCode.hs" #-} {-# LINE 526 "GenerateCode.ag" #-} mkPartitionedFunction :: String -> Bool -> [Decl] -> [String] -> DeclBlocks -> ([Decl], Expr) mkPartitionedFunction prefix optCase nextVisitDecls lastExprVars cpsTree = let inh = Inh_DeclBlocksRoot { prefix_Inh_DeclBlocksRoot = prefix , optCase_Inh_DeclBlocksRoot = optCase , nextVisitDecls_Inh_DeclBlocksRoot = nextVisitDecls , lastExprVars_Inh_DeclBlocksRoot = lastExprVars } sem = sem_DeclBlocksRoot (DeclBlocksRoot cpsTree) syn = wrap_DeclBlocksRoot sem inh in (lambdas_Syn_DeclBlocksRoot syn, firstCall_Syn_DeclBlocksRoot syn) {-# LINE 113 "../src-derived/GenerateCode.hs" #-} {-# LINE 576 "GenerateCode.ag" #-} freevars :: [String] -> [Decl] -> [String] freevars additional decls = Set.toList (allused `Set.difference` alldefined) where allused = Set.unions (Set.fromList additional : map usedvars decls) alldefined = Set.unions (map definedvars decls) usedvars (Decl _ _ _ uses) = uses usedvars _ = Set.empty definedvars (Decl _ _ defs _) = defs definedvars _ = Set.empty mkBlockLambda :: Bool -> String -> [String] -> [Decl] -> Expr -> Decl mkBlockLambda optCase name args decls expr = Decl lhs rhs Set.empty Set.empty where lhs = Fun name (map SimpleExpr args) rhs = mkLet optCase decls expr {-# LINE 136 "../src-derived/GenerateCode.hs" #-} {-# LINE 639 "GenerateCode.ag" #-} typeToCodeType :: Maybe NontermIdent -> [String] -> Type -> Code.Type typeToCodeType mbNt params tp = case tp of NT nt tps | nt == _SELF -> NontermType (maybe "Unknown" getName mbNt) params | otherwise -> NontermType (getName nt) tps Haskell t -> SimpleType t evalType :: (String -> String) -> Code.Type -> Code.Type evalType replf t = chase t where chase t = case t of Arr l r -> Arr (chase l) (chase r) TypeApp f as -> TypeApp (chase f) (map chase as) TupleType tps -> TupleType (map chase tps) UnboxedTupleType tps -> UnboxedTupleType (map chase tps) Code.List tp -> Code.List (chase tp) SimpleType txt -> let tks = lexTokens (initPos txt) txt tks' = map replaceTok tks txt' = unlines . showTokens . tokensToStrings $ tks' in SimpleType txt' TMaybe m -> TMaybe (chase m) TEither l r -> TEither (chase l) (chase r) TMap k v -> TMap (chase k) (chase v) TIntMap v -> TIntMap (chase v) _ -> t replaceTok t = case t of AGLocal v p _ -> HsToken (replf $ getName v) p _ -> t idEvalType :: Code.Type -> Code.Type idEvalType = evalType id {-# LINE 175 "../src-derived/GenerateCode.hs" #-} {-# LINE 789 "GenerateCode.ag" #-} makeLocalComment :: Int -> String -> Identifier -> Maybe Type -> String makeLocalComment width what name tp = let x = getName name y = maybe "_" (\t -> case t of (NT nt tps) -> getName nt ++ " " ++ unwords tps; Haskell t -> '{':t++"}") tp in ( what ++ " " ++ x ++ replicate ((width - length x) `max` 0) ' ' ++ " : " ++ y ) {-# LINE 184 "../src-derived/GenerateCode.hs" #-} {-# LINE 820 "GenerateCode.ag" #-} -- Lets or nested Cases? -- or even a do-expression? data DeclsType = DeclsLet | DeclsCase | DeclsDo mkDecls :: DeclsType -> Decls -> Expr -> Expr mkDecls DeclsLet = mkLet False mkDecls DeclsCase = mkLet True mkDecls DeclsDo = \decls -> Do (map toBind decls) where toBind (Decl lhs rhs _ _) = BindLet lhs rhs toBind d = d mkLet :: Bool -> Decls -> Expr -> Expr mkLet False decls body = Let decls body mkLet True decls body = foldr oneCase body decls oneCase :: Decl -> Expr -> Expr oneCase (Decl left rhs _ _) exp = Case rhs [CaseAlt left exp] oneCase _ exp = exp -- Gives the name of the visit function funname field 0 = show field ++ "_" funname field nr = show field ++ "_" ++ show nr -- Gives the name of a semantic function seqSemname :: String -> NontermIdent -> ConstructorIdent -> Int -> String seqSemname pre nt con 0 = semname pre nt con seqSemname pre nt con nr = semname pre nt con ++ "_" ++ show nr -- Gives the name of a type typeName :: NontermIdent -> Int -> String typeName nt 0 = "T_" ++ show nt typeName nt n = "T_" ++ show nt ++ "_" ++ show n ntOfVisit :: NontermIdent -> Int -> NontermIdent ntOfVisit nt 0 = nt ntOfVisit nt n = Ident (show nt ++ "_" ++ show n) (getPos nt) -- Gives the name of a visit function visitname :: String -> NontermIdent -> Int -> String visitname pre nt n = pre ++ getName nt ++ "_" ++ show n {-# LINE 229 "../src-derived/GenerateCode.hs" #-} -- CGrammar ---------------------------------------------------- {- visit 0: inherited attribute: options : Options synthesized attributes: errors : Seq Error output : Program alternatives: alternative CGrammar: child typeSyns : {TypeSyns} child derivings : {Derivings} child wrappers : {Set NontermIdent} child nonts : CNonterminals child pragmas : {PragmaMap} child paramMap : {ParamMap} child contextMap : {ContextMap} child aroundsMap : {Map NontermIdent (Map ConstructorIdent (Set Identifier))} visit 0: local aroundMap : _ local unfoldSemDom : _ -} -- cata sem_CGrammar :: CGrammar -> T_CGrammar sem_CGrammar (CGrammar _typeSyns _derivings _wrappers _nonts _pragmas _paramMap _contextMap _aroundsMap ) = (sem_CGrammar_CGrammar _typeSyns _derivings _wrappers (sem_CNonterminals _nonts ) _pragmas _paramMap _contextMap _aroundsMap ) -- semantic domain newtype T_CGrammar = T_CGrammar (Options -> ( (Seq Error),Program)) data Inh_CGrammar = Inh_CGrammar {options_Inh_CGrammar :: !(Options)} data Syn_CGrammar = Syn_CGrammar {errors_Syn_CGrammar :: !((Seq Error)),output_Syn_CGrammar :: !(Program)} wrap_CGrammar :: T_CGrammar -> Inh_CGrammar -> Syn_CGrammar wrap_CGrammar (T_CGrammar sem ) (Inh_CGrammar _lhsIoptions ) = (let ( _lhsOerrors,_lhsOoutput) = (sem _lhsIoptions ) in (Syn_CGrammar _lhsOerrors _lhsOoutput )) sem_CGrammar_CGrammar :: TypeSyns -> Derivings -> (Set NontermIdent) -> T_CNonterminals -> PragmaMap -> ParamMap -> ContextMap -> (Map NontermIdent (Map ConstructorIdent (Set Identifier))) -> T_CGrammar sem_CGrammar_CGrammar typeSyns_ derivings_ wrappers_ (T_CNonterminals nonts_ ) pragmas_ paramMap_ contextMap_ aroundsMap_ = (T_CGrammar (\ _lhsIoptions -> (let _nontsOo_sig :: Bool _nontsOo_cata :: Bool _nontsOo_sem :: Bool _nontsOo_newtypes :: Bool _nontsOo_unbox :: Bool _nontsOo_case :: Bool _nontsOo_pretty :: Bool _nontsOo_rename :: Bool _nontsOo_strictwrap :: Bool _nontsOo_splitsems :: Bool _nontsOo_data :: (Maybe Bool) _nontsOprefix :: String _nontsOo_traces :: Bool _nontsOo_costcentre :: Bool _nontsOo_linePragmas :: Bool _nontsOo_monadic :: Bool _nontsOallPragmas :: PragmaMap _nontsOparamMap :: ParamMap _nontsOcontextMap :: ContextMap _nontsOallNts :: (Set NontermIdent) _nontsOwith_sig :: Bool _nontsOerrors :: (Seq Error) _lhsOoutput :: Program _nontsOtypeSyns :: TypeSyns _nontsOderivings :: Derivings _nontsOwrappers :: (Set NontermIdent) _lhsOerrors :: (Seq Error) _nontsOaroundMap :: (Map NontermIdent (Map ConstructorIdent (Set Identifier))) _nontsOunfoldSemDom :: (NontermIdent -> Int -> [String] -> Code.Type) _nontsIallTpsFound :: Bool _nontsIchunks :: Chunks _nontsIerrors :: (Seq Error) _nontsIgathNts :: (Set NontermIdent) _nontsIsemDomUnfoldGath :: (Map (NontermIdent, Int) ([String], Code.Type)) -- "GenerateCode.ag"(line 50, column 17) _nontsOo_sig = ({-# LINE 50 "GenerateCode.ag" #-} typeSigs _lhsIoptions {-# LINE 318 "GenerateCode.hs" #-}) -- "GenerateCode.ag"(line 50, column 17) _nontsOo_cata = ({-# LINE 51 "GenerateCode.ag" #-} folds _lhsIoptions {-# LINE 323 "GenerateCode.hs" #-}) -- "GenerateCode.ag"(line 50, column 17) _nontsOo_sem = ({-# LINE 52 "GenerateCode.ag" #-} semfuns _lhsIoptions {-# LINE 328 "GenerateCode.hs" #-}) -- "GenerateCode.ag"(line 50, column 17) _nontsOo_newtypes = ({-# LINE 53 "GenerateCode.ag" #-} newtypes _lhsIoptions {-# LINE 333 "GenerateCode.hs" #-}) -- "GenerateCode.ag"(line 50, column 17) _nontsOo_unbox = ({-# LINE 54 "GenerateCode.ag" #-} unbox _lhsIoptions {-# LINE 338 "GenerateCode.hs" #-}) -- "GenerateCode.ag"(line 50, column 17) _nontsOo_case = ({-# LINE 55 "GenerateCode.ag" #-} cases _lhsIoptions {-# LINE 343 "GenerateCode.hs" #-}) -- "GenerateCode.ag"(line 50, column 17) _nontsOo_pretty = ({-# LINE 56 "GenerateCode.ag" #-} attrInfo _lhsIoptions {-# LINE 348 "GenerateCode.hs" #-}) -- "GenerateCode.ag"(line 50, column 17) _nontsOo_rename = ({-# LINE 57 "GenerateCode.ag" #-} rename _lhsIoptions {-# LINE 353 "GenerateCode.hs" #-}) -- "GenerateCode.ag"(line 50, column 17) _nontsOo_strictwrap = ({-# LINE 58 "GenerateCode.ag" #-} strictWrap _lhsIoptions {-# LINE 358 "GenerateCode.hs" #-}) -- "GenerateCode.ag"(line 50, column 17) _nontsOo_splitsems = ({-# LINE 59 "GenerateCode.ag" #-} splitSems _lhsIoptions {-# LINE 363 "GenerateCode.hs" #-}) -- "GenerateCode.ag"(line 50, column 17) _nontsOo_data = ({-# LINE 60 "GenerateCode.ag" #-} if dataTypes _lhsIoptions then Just (strictData _lhsIoptions) else Nothing {-# LINE 368 "GenerateCode.hs" #-}) -- "GenerateCode.ag"(line 50, column 17) _nontsOprefix = ({-# LINE 61 "GenerateCode.ag" #-} prefix _lhsIoptions {-# LINE 373 "GenerateCode.hs" #-}) -- "GenerateCode.ag"(line 50, column 17) _nontsOo_traces = ({-# LINE 62 "GenerateCode.ag" #-} genTraces _lhsIoptions {-# LINE 378 "GenerateCode.hs" #-}) -- "GenerateCode.ag"(line 50, column 17) _nontsOo_costcentre = ({-# LINE 63 "GenerateCode.ag" #-} genCostCentres _lhsIoptions {-# LINE 383 "GenerateCode.hs" #-}) -- "GenerateCode.ag"(line 50, column 17) _nontsOo_linePragmas = ({-# LINE 64 "GenerateCode.ag" #-} genLinePragmas _lhsIoptions {-# LINE 388 "GenerateCode.hs" #-}) -- "GenerateCode.ag"(line 50, column 17) _nontsOo_monadic = ({-# LINE 65 "GenerateCode.ag" #-} monadic _lhsIoptions {-# LINE 393 "GenerateCode.hs" #-}) -- "GenerateCode.ag"(line 70, column 15) _nontsOallPragmas = ({-# LINE 70 "GenerateCode.ag" #-} pragmas_ {-# LINE 398 "GenerateCode.hs" #-}) -- "GenerateCode.ag"(line 92, column 14) _nontsOparamMap = ({-# LINE 92 "GenerateCode.ag" #-} paramMap_ {-# LINE 403 "GenerateCode.hs" #-}) -- "GenerateCode.ag"(line 113, column 7) _nontsOcontextMap = ({-# LINE 113 "GenerateCode.ag" #-} contextMap_ {-# LINE 408 "GenerateCode.hs" #-}) -- "GenerateCode.ag"(line 125, column 7) _nontsOallNts = ({-# LINE 125 "GenerateCode.ag" #-} _nontsIgathNts {-# LINE 413 "GenerateCode.hs" #-}) -- "GenerateCode.ag"(line 491, column 34) _aroundMap = ({-# LINE 491 "GenerateCode.ag" #-} aroundsMap_ {-# LINE 418 "GenerateCode.hs" #-}) -- "GenerateCode.ag"(line 632, column 7) _unfoldSemDom = ({-# LINE 632 "GenerateCode.ag" #-} \nt nr repl -> let (params, tp) = Map.findWithDefault (error ("No such semantic domain: " ++ show nt)) (nt, nr) _nontsIsemDomUnfoldGath replMap = Map.fromList (zip params repl) replace k = Map.findWithDefault ('@':k) k replMap in evalType replace tp {-# LINE 427 "GenerateCode.hs" #-}) -- "GenerateCode.ag"(line 735, column 14) _nontsOwith_sig = ({-# LINE 735 "GenerateCode.ag" #-} typeSigs _lhsIoptions && _nontsIallTpsFound {-# LINE 432 "GenerateCode.hs" #-}) -- "GenerateCode.ag"(line 742, column 15) _nontsOerrors = ({-# LINE 742 "GenerateCode.ag" #-} Seq.empty {-# LINE 437 "GenerateCode.hs" #-}) -- "GenerateCode.ag"(line 806, column 17) _lhsOoutput = ({-# LINE 806 "GenerateCode.ag" #-} Program _nontsIchunks {-# LINE 442 "GenerateCode.hs" #-}) -- "GenerateCode.ag"(line 870, column 14) _nontsOtypeSyns = ({-# LINE 870 "GenerateCode.ag" #-} typeSyns_ {-# LINE 447 "GenerateCode.hs" #-}) -- "GenerateCode.ag"(line 870, column 14) _nontsOderivings = ({-# LINE 871 "GenerateCode.ag" #-} derivings_ {-# LINE 452 "GenerateCode.hs" #-}) -- "GenerateCode.ag"(line 870, column 14) _nontsOwrappers = ({-# LINE 872 "GenerateCode.ag" #-} wrappers_ {-# LINE 457 "GenerateCode.hs" #-}) -- copy rule (up) _lhsOerrors = ({-# LINE 741 "GenerateCode.ag" #-} _nontsIerrors {-# LINE 462 "GenerateCode.hs" #-}) -- copy rule (from local) _nontsOaroundMap = ({-# LINE 484 "GenerateCode.ag" #-} _aroundMap {-# LINE 467 "GenerateCode.hs" #-}) -- copy rule (from local) _nontsOunfoldSemDom = ({-# LINE 628 "GenerateCode.ag" #-} _unfoldSemDom {-# LINE 472 "GenerateCode.hs" #-}) ( _nontsIallTpsFound,_nontsIchunks,_nontsIerrors,_nontsIgathNts,_nontsIsemDomUnfoldGath) = (nonts_ _nontsOallNts _nontsOallPragmas _nontsOaroundMap _nontsOcontextMap _nontsOderivings _nontsOerrors _nontsOo_case _nontsOo_cata _nontsOo_costcentre _nontsOo_data _nontsOo_linePragmas _nontsOo_monadic _nontsOo_newtypes _nontsOo_pretty _nontsOo_rename _nontsOo_sem _nontsOo_sig _nontsOo_splitsems _nontsOo_strictwrap _nontsOo_traces _nontsOo_unbox _nontsOparamMap _nontsOprefix _nontsOtypeSyns _nontsOunfoldSemDom _nontsOwith_sig _nontsOwrappers ) in ( _lhsOerrors,_lhsOoutput))) ) -- CInterface -------------------------------------------------- {- visit 0: inherited attributes: inh : Attributes nt : NontermIdent o_case : Bool o_cata : Bool o_costcentre : Bool o_data : Maybe Bool o_linePragmas : Bool o_monadic : Bool o_newtypes : Bool o_pretty : Bool o_rename : Bool o_sem : Bool o_sig : Bool o_splitsems : Bool o_strictwrap : Bool o_traces : Bool o_unbox : Bool paramMap : ParamMap prefix : String syn : Attributes synthesized attributes: comments : [String] semDom : [Decl] semDomUnfoldGath : Map (NontermIdent, Int) ([String], Code.Type) wrapDecls : Decls alternatives: alternative CInterface: child seg : CSegments -} -- cata sem_CInterface :: CInterface -> T_CInterface sem_CInterface (CInterface _seg ) = (sem_CInterface_CInterface (sem_CSegments _seg ) ) -- semantic domain newtype T_CInterface = T_CInterface (Attributes -> NontermIdent -> Bool -> Bool -> Bool -> (Maybe Bool) -> Bool -> Bool -> Bool -> Bool -> Bool -> Bool -> Bool -> Bool -> Bool -> Bool -> Bool -> ParamMap -> String -> Attributes -> ( ([String]),([Decl]),(Map (NontermIdent, Int) ([String], Code.Type)),Decls)) data Inh_CInterface = Inh_CInterface {inh_Inh_CInterface :: !(Attributes),nt_Inh_CInterface :: !(NontermIdent),o_case_Inh_CInterface :: !(Bool),o_cata_Inh_CInterface :: !(Bool),o_costcentre_Inh_CInterface :: !(Bool),o_data_Inh_CInterface :: !((Maybe Bool)),o_linePragmas_Inh_CInterface :: !(Bool),o_monadic_Inh_CInterface :: !(Bool),o_newtypes_Inh_CInterface :: !(Bool),o_pretty_Inh_CInterface :: !(Bool),o_rename_Inh_CInterface :: !(Bool),o_sem_Inh_CInterface :: !(Bool),o_sig_Inh_CInterface :: !(Bool),o_splitsems_Inh_CInterface :: !(Bool),o_strictwrap_Inh_CInterface :: !(Bool),o_traces_Inh_CInterface :: !(Bool),o_unbox_Inh_CInterface :: !(Bool),paramMap_Inh_CInterface :: !(ParamMap),prefix_Inh_CInterface :: !(String),syn_Inh_CInterface :: !(Attributes)} data Syn_CInterface = Syn_CInterface {comments_Syn_CInterface :: !(([String])),semDom_Syn_CInterface :: !(([Decl])),semDomUnfoldGath_Syn_CInterface :: !((Map (NontermIdent, Int) ([String], Code.Type))),wrapDecls_Syn_CInterface :: !(Decls)} wrap_CInterface :: T_CInterface -> Inh_CInterface -> Syn_CInterface wrap_CInterface (T_CInterface sem ) (Inh_CInterface _lhsIinh _lhsInt _lhsIo_case _lhsIo_cata _lhsIo_costcentre _lhsIo_data _lhsIo_linePragmas _lhsIo_monadic _lhsIo_newtypes _lhsIo_pretty _lhsIo_rename _lhsIo_sem _lhsIo_sig _lhsIo_splitsems _lhsIo_strictwrap _lhsIo_traces _lhsIo_unbox _lhsIparamMap _lhsIprefix _lhsIsyn ) = (let ( _lhsOcomments,_lhsOsemDom,_lhsOsemDomUnfoldGath,_lhsOwrapDecls) = (sem _lhsIinh _lhsInt _lhsIo_case _lhsIo_cata _lhsIo_costcentre _lhsIo_data _lhsIo_linePragmas _lhsIo_monadic _lhsIo_newtypes _lhsIo_pretty _lhsIo_rename _lhsIo_sem _lhsIo_sig _lhsIo_splitsems _lhsIo_strictwrap _lhsIo_traces _lhsIo_unbox _lhsIparamMap _lhsIprefix _lhsIsyn ) in (Syn_CInterface _lhsOcomments _lhsOsemDom _lhsOsemDomUnfoldGath _lhsOwrapDecls )) sem_CInterface_CInterface :: T_CSegments -> T_CInterface sem_CInterface_CInterface (T_CSegments seg_ ) = (T_CInterface (\ _lhsIinh _lhsInt _lhsIo_case _lhsIo_cata _lhsIo_costcentre _lhsIo_data _lhsIo_linePragmas _lhsIo_monadic _lhsIo_newtypes _lhsIo_pretty _lhsIo_rename _lhsIo_sem _lhsIo_sig _lhsIo_splitsems _lhsIo_strictwrap _lhsIo_traces _lhsIo_unbox _lhsIparamMap _lhsIprefix _lhsIsyn -> (let _segOnr :: Int _lhsOsemDom :: ([Decl]) _lhsOcomments :: ([String]) _lhsOsemDomUnfoldGath :: (Map (NontermIdent, Int) ([String], Code.Type)) _lhsOwrapDecls :: Decls _segOinh :: Attributes _segOnt :: NontermIdent _segOo_case :: Bool _segOo_cata :: Bool _segOo_costcentre :: Bool _segOo_data :: (Maybe Bool) _segOo_linePragmas :: Bool _segOo_monadic :: Bool _segOo_newtypes :: Bool _segOo_pretty :: Bool _segOo_rename :: Bool _segOo_sem :: Bool _segOo_sig :: Bool _segOo_splitsems :: Bool _segOo_strictwrap :: Bool _segOo_traces :: Bool _segOo_unbox :: Bool _segOparamMap :: ParamMap _segOprefix :: String _segOsyn :: Attributes _segIcomments :: ([String]) _segIisNil :: Bool _segIsemDom :: ([Decl]) _segIsemDomUnfoldGath :: (Map (NontermIdent, Int) ([String], Code.Type)) _segIwrapDecls :: Decls -- "GenerateCode.ag"(line 235, column 17) _segOnr = ({-# LINE 235 "GenerateCode.ag" #-} 0 {-# LINE 602 "GenerateCode.hs" #-}) -- "GenerateCode.ag"(line 605, column 18) _lhsOsemDom = ({-# LINE 605 "GenerateCode.ag" #-} Comment "semantic domain" : _segIsemDom {-# LINE 607 "GenerateCode.hs" #-}) -- use rule "GenerateCode.ag"(line 759, column 52) _lhsOcomments = ({-# LINE 759 "GenerateCode.ag" #-} _segIcomments {-# LINE 612 "GenerateCode.hs" #-}) -- use rule "GenerateCode.ag"(line 622, column 86) _lhsOsemDomUnfoldGath = ({-# LINE 622 "GenerateCode.ag" #-} _segIsemDomUnfoldGath {-# LINE 617 "GenerateCode.hs" #-}) -- use rule "GenerateCode.ag"(line 708, column 52) _lhsOwrapDecls = ({-# LINE 708 "GenerateCode.ag" #-} _segIwrapDecls {-# LINE 622 "GenerateCode.hs" #-}) -- copy rule (down) _segOinh = ({-# LINE 78 "GenerateCode.ag" #-} _lhsIinh {-# LINE 627 "GenerateCode.hs" #-}) -- copy rule (down) _segOnt = ({-# LINE 78 "GenerateCode.ag" #-} _lhsInt {-# LINE 632 "GenerateCode.hs" #-}) -- copy rule (down) _segOo_case = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_case {-# LINE 637 "GenerateCode.hs" #-}) -- copy rule (down) _segOo_cata = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_cata {-# LINE 642 "GenerateCode.hs" #-}) -- copy rule (down) _segOo_costcentre = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_costcentre {-# LINE 647 "GenerateCode.hs" #-}) -- copy rule (down) _segOo_data = ({-# LINE 46 "GenerateCode.ag" #-} _lhsIo_data {-# LINE 652 "GenerateCode.hs" #-}) -- copy rule (down) _segOo_linePragmas = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_linePragmas {-# LINE 657 "GenerateCode.hs" #-}) -- copy rule (down) _segOo_monadic = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_monadic {-# LINE 662 "GenerateCode.hs" #-}) -- copy rule (down) _segOo_newtypes = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_newtypes {-# LINE 667 "GenerateCode.hs" #-}) -- copy rule (down) _segOo_pretty = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_pretty {-# LINE 672 "GenerateCode.hs" #-}) -- copy rule (down) _segOo_rename = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_rename {-# LINE 677 "GenerateCode.hs" #-}) -- copy rule (down) _segOo_sem = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_sem {-# LINE 682 "GenerateCode.hs" #-}) -- copy rule (down) _segOo_sig = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_sig {-# LINE 687 "GenerateCode.hs" #-}) -- copy rule (down) _segOo_splitsems = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_splitsems {-# LINE 692 "GenerateCode.hs" #-}) -- copy rule (down) _segOo_strictwrap = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_strictwrap {-# LINE 697 "GenerateCode.hs" #-}) -- copy rule (down) _segOo_traces = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_traces {-# LINE 702 "GenerateCode.hs" #-}) -- copy rule (down) _segOo_unbox = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_unbox {-# LINE 707 "GenerateCode.hs" #-}) -- copy rule (down) _segOparamMap = ({-# LINE 89 "GenerateCode.ag" #-} _lhsIparamMap {-# LINE 712 "GenerateCode.hs" #-}) -- copy rule (down) _segOprefix = ({-# LINE 47 "GenerateCode.ag" #-} _lhsIprefix {-# LINE 717 "GenerateCode.hs" #-}) -- copy rule (down) _segOsyn = ({-# LINE 78 "GenerateCode.ag" #-} _lhsIsyn {-# LINE 722 "GenerateCode.hs" #-}) ( _segIcomments,_segIisNil,_segIsemDom,_segIsemDomUnfoldGath,_segIwrapDecls) = (seg_ _segOinh _segOnr _segOnt _segOo_case _segOo_cata _segOo_costcentre _segOo_data _segOo_linePragmas _segOo_monadic _segOo_newtypes _segOo_pretty _segOo_rename _segOo_sem _segOo_sig _segOo_splitsems _segOo_strictwrap _segOo_traces _segOo_unbox _segOparamMap _segOprefix _segOsyn ) in ( _lhsOcomments,_lhsOsemDom,_lhsOsemDomUnfoldGath,_lhsOwrapDecls))) ) -- CNonterminal ------------------------------------------------ {- visit 0: inherited attributes: allNts : Set NontermIdent allPragmas : PragmaMap aroundMap : Map NontermIdent (Map ConstructorIdent (Set Identifier)) contextMap : ContextMap derivings : Derivings o_case : Bool o_cata : Bool o_costcentre : Bool o_data : Maybe Bool o_linePragmas : Bool o_monadic : Bool o_newtypes : Bool o_pretty : Bool o_rename : Bool o_sem : Bool o_sig : Bool o_splitsems : Bool o_strictwrap : Bool o_traces : Bool o_unbox : Bool paramMap : ParamMap prefix : String typeSyns : TypeSyns unfoldSemDom : NontermIdent -> Int -> [String] -> Code.Type with_sig : Bool wrappers : Set NontermIdent chained attribute: errors : Seq Error synthesized attributes: allTpsFound : Bool chunks : Chunks gathNts : Set NontermIdent semDomUnfoldGath : Map (NontermIdent, Int) ([String], Code.Type) alternatives: alternative CNonterminal: child nt : {NontermIdent} child params : {[Identifier]} child inh : {Attributes} child syn : {Attributes} child prods : CProductions child inter : CInterface visit 0: local _tup1 : {(Attributes,Attributes,NontermIdent)} local _tup2 : {(Attributes,Attributes,NontermIdent)} local aroundMap : _ local semWrapper : _ local comment : _ local dataDef : _ local cataFun : _ -} -- cata sem_CNonterminal :: CNonterminal -> T_CNonterminal sem_CNonterminal (CNonterminal _nt _params _inh _syn _prods _inter ) = (sem_CNonterminal_CNonterminal _nt _params _inh _syn (sem_CProductions _prods ) (sem_CInterface _inter ) ) -- semantic domain newtype T_CNonterminal = T_CNonterminal ((Set NontermIdent) -> PragmaMap -> (Map NontermIdent (Map ConstructorIdent (Set Identifier))) -> ContextMap -> Derivings -> (Seq Error) -> Bool -> Bool -> Bool -> (Maybe Bool) -> Bool -> Bool -> Bool -> Bool -> Bool -> Bool -> Bool -> Bool -> Bool -> Bool -> Bool -> ParamMap -> String -> TypeSyns -> (NontermIdent -> Int -> [String] -> Code.Type) -> Bool -> (Set NontermIdent) -> ( Bool,Chunks,(Seq Error),(Set NontermIdent),(Map (NontermIdent, Int) ([String], Code.Type)))) data Inh_CNonterminal = Inh_CNonterminal {allNts_Inh_CNonterminal :: !((Set NontermIdent)),allPragmas_Inh_CNonterminal :: !(PragmaMap),aroundMap_Inh_CNonterminal :: !((Map NontermIdent (Map ConstructorIdent (Set Identifier)))),contextMap_Inh_CNonterminal :: !(ContextMap),derivings_Inh_CNonterminal :: !(Derivings),errors_Inh_CNonterminal :: !((Seq Error)),o_case_Inh_CNonterminal :: !(Bool),o_cata_Inh_CNonterminal :: !(Bool),o_costcentre_Inh_CNonterminal :: !(Bool),o_data_Inh_CNonterminal :: !((Maybe Bool)),o_linePragmas_Inh_CNonterminal :: !(Bool),o_monadic_Inh_CNonterminal :: !(Bool),o_newtypes_Inh_CNonterminal :: !(Bool),o_pretty_Inh_CNonterminal :: !(Bool),o_rename_Inh_CNonterminal :: !(Bool),o_sem_Inh_CNonterminal :: !(Bool),o_sig_Inh_CNonterminal :: !(Bool),o_splitsems_Inh_CNonterminal :: !(Bool),o_strictwrap_Inh_CNonterminal :: !(Bool),o_traces_Inh_CNonterminal :: !(Bool),o_unbox_Inh_CNonterminal :: !(Bool),paramMap_Inh_CNonterminal :: !(ParamMap),prefix_Inh_CNonterminal :: !(String),typeSyns_Inh_CNonterminal :: !(TypeSyns),unfoldSemDom_Inh_CNonterminal :: !((NontermIdent -> Int -> [String] -> Code.Type)),with_sig_Inh_CNonterminal :: !(Bool),wrappers_Inh_CNonterminal :: !((Set NontermIdent))} data Syn_CNonterminal = Syn_CNonterminal {allTpsFound_Syn_CNonterminal :: !(Bool),chunks_Syn_CNonterminal :: !(Chunks),errors_Syn_CNonterminal :: !((Seq Error)),gathNts_Syn_CNonterminal :: !((Set NontermIdent)),semDomUnfoldGath_Syn_CNonterminal :: !((Map (NontermIdent, Int) ([String], Code.Type)))} wrap_CNonterminal :: T_CNonterminal -> Inh_CNonterminal -> Syn_CNonterminal wrap_CNonterminal (T_CNonterminal sem ) (Inh_CNonterminal _lhsIallNts _lhsIallPragmas _lhsIaroundMap _lhsIcontextMap _lhsIderivings _lhsIerrors _lhsIo_case _lhsIo_cata _lhsIo_costcentre _lhsIo_data _lhsIo_linePragmas _lhsIo_monadic _lhsIo_newtypes _lhsIo_pretty _lhsIo_rename _lhsIo_sem _lhsIo_sig _lhsIo_splitsems _lhsIo_strictwrap _lhsIo_traces _lhsIo_unbox _lhsIparamMap _lhsIprefix _lhsItypeSyns _lhsIunfoldSemDom _lhsIwith_sig _lhsIwrappers ) = (let ( _lhsOallTpsFound,_lhsOchunks,_lhsOerrors,_lhsOgathNts,_lhsOsemDomUnfoldGath) = (sem _lhsIallNts _lhsIallPragmas _lhsIaroundMap _lhsIcontextMap _lhsIderivings _lhsIerrors _lhsIo_case _lhsIo_cata _lhsIo_costcentre _lhsIo_data _lhsIo_linePragmas _lhsIo_monadic _lhsIo_newtypes _lhsIo_pretty _lhsIo_rename _lhsIo_sem _lhsIo_sig _lhsIo_splitsems _lhsIo_strictwrap _lhsIo_traces _lhsIo_unbox _lhsIparamMap _lhsIprefix _lhsItypeSyns _lhsIunfoldSemDom _lhsIwith_sig _lhsIwrappers ) in (Syn_CNonterminal _lhsOallTpsFound _lhsOchunks _lhsOerrors _lhsOgathNts _lhsOsemDomUnfoldGath )) sem_CNonterminal_CNonterminal :: NontermIdent -> ([Identifier]) -> Attributes -> Attributes -> T_CProductions -> T_CInterface -> T_CNonterminal sem_CNonterminal_CNonterminal nt_ params_ inh_ syn_ (T_CProductions prods_ ) (T_CInterface inter_ ) = (T_CNonterminal (\ _lhsIallNts _lhsIallPragmas _lhsIaroundMap _lhsIcontextMap _lhsIderivings _lhsIerrors _lhsIo_case _lhsIo_cata _lhsIo_costcentre _lhsIo_data _lhsIo_linePragmas _lhsIo_monadic _lhsIo_newtypes _lhsIo_pretty _lhsIo_rename _lhsIo_sem _lhsIo_sig _lhsIo_splitsems _lhsIo_strictwrap _lhsIo_traces _lhsIo_unbox _lhsIparamMap _lhsIprefix _lhsItypeSyns _lhsIunfoldSemDom _lhsIwith_sig _lhsIwrappers -> (let __tup1 :: ((Attributes,Attributes,NontermIdent)) _interOinh :: Attributes _interOsyn :: Attributes _interOnt :: NontermIdent __tup2 :: ((Attributes,Attributes,NontermIdent)) _prodsOinh :: Attributes _prodsOsyn :: Attributes _prodsOnt :: NontermIdent _lhsOgathNts :: (Set NontermIdent) _lhsOchunks :: Chunks _lhsOallTpsFound :: Bool _lhsOerrors :: (Seq Error) _lhsOsemDomUnfoldGath :: (Map (NontermIdent, Int) ([String], Code.Type)) _prodsOallNts :: (Set NontermIdent) _prodsOallPragmas :: PragmaMap _prodsOaroundMap :: (Map ConstructorIdent (Set Identifier)) _prodsOcontextMap :: ContextMap _prodsOerrors :: (Seq Error) _prodsOo_case :: Bool _prodsOo_cata :: Bool _prodsOo_costcentre :: Bool _prodsOo_data :: (Maybe Bool) _prodsOo_linePragmas :: Bool _prodsOo_monadic :: Bool _prodsOo_newtypes :: Bool _prodsOo_pretty :: Bool _prodsOo_rename :: Bool _prodsOo_sem :: Bool _prodsOo_sig :: Bool _prodsOo_splitsems :: Bool _prodsOo_strictwrap :: Bool _prodsOo_traces :: Bool _prodsOo_unbox :: Bool _prodsOparamMap :: ParamMap _prodsOprefix :: String _prodsOunfoldSemDom :: (NontermIdent -> Int -> [String] -> Code.Type) _prodsOwith_sig :: Bool _interOo_case :: Bool _interOo_cata :: Bool _interOo_costcentre :: Bool _interOo_data :: (Maybe Bool) _interOo_linePragmas :: Bool _interOo_monadic :: Bool _interOo_newtypes :: Bool _interOo_pretty :: Bool _interOo_rename :: Bool _interOo_sem :: Bool _interOo_sig :: Bool _interOo_splitsems :: Bool _interOo_strictwrap :: Bool _interOo_traces :: Bool _interOo_unbox :: Bool _interOparamMap :: ParamMap _interOprefix :: String _prodsIallTpsFound :: Bool _prodsIcataAlts :: Decls _prodsIcomments :: ([String]) _prodsIdataAlts :: DataAlts _prodsIdecls :: Decls _prodsIerrors :: (Seq Error) _prodsIsemNames :: ([String]) _interIcomments :: ([String]) _interIsemDom :: ([Decl]) _interIsemDomUnfoldGath :: (Map (NontermIdent, Int) ([String], Code.Type)) _interIwrapDecls :: Decls -- "GenerateCode.ag"(line 80, column 26) __tup1 = ({-# LINE 80 "GenerateCode.ag" #-} (inh_,syn_,nt_) {-# LINE 927 "GenerateCode.hs" #-}) -- "GenerateCode.ag"(line 80, column 26) (_interOinh,_,_) = ({-# LINE 80 "GenerateCode.ag" #-} __tup1 {-# LINE 932 "GenerateCode.hs" #-}) -- "GenerateCode.ag"(line 80, column 26) (_,_interOsyn,_) = ({-# LINE 80 "GenerateCode.ag" #-} __tup1 {-# LINE 937 "GenerateCode.hs" #-}) -- "GenerateCode.ag"(line 80, column 26) (_,_,_interOnt) = ({-# LINE 80 "GenerateCode.ag" #-} __tup1 {-# LINE 942 "GenerateCode.hs" #-}) -- "GenerateCode.ag"(line 81, column 25) __tup2 = ({-# LINE 81 "GenerateCode.ag" #-} (inh_,syn_,nt_) {-# LINE 947 "GenerateCode.hs" #-}) -- "GenerateCode.ag"(line 81, column 25) (_prodsOinh,_,_) = ({-# LINE 81 "GenerateCode.ag" #-} __tup2 {-# LINE 952 "GenerateCode.hs" #-}) -- "GenerateCode.ag"(line 81, column 25) (_,_prodsOsyn,_) = ({-# LINE 81 "GenerateCode.ag" #-} __tup2 {-# LINE 957 "GenerateCode.hs" #-}) -- "GenerateCode.ag"(line 81, column 25) (_,_,_prodsOnt) = ({-# LINE 81 "GenerateCode.ag" #-} __tup2 {-# LINE 962 "GenerateCode.hs" #-}) -- "GenerateCode.ag"(line 131, column 7) _lhsOgathNts = ({-# LINE 131 "GenerateCode.ag" #-} Set.singleton nt_ {-# LINE 967 "GenerateCode.hs" #-}) -- "GenerateCode.ag"(line 492, column 34) _aroundMap = ({-# LINE 492 "GenerateCode.ag" #-} Map.findWithDefault Map.empty nt_ _lhsIaroundMap {-# LINE 972 "GenerateCode.hs" #-}) -- "GenerateCode.ag"(line 682, column 18) _semWrapper = ({-# LINE 682 "GenerateCode.ag" #-} let params' = map getName params_ inhAttrs = Map.toList inh_ synAttrs = Map.toList syn_ inhVars = [ SimpleExpr (attrname True _LHS a) | (a,_) <- inhAttrs ] synVars = [ SimpleExpr (attrname False _LHS a) | (a,_) <- synAttrs ] var = "sem" wrapNT = "wrap" ++ "_" ++ getName nt_ inhNT = "Inh" ++ "_" ++ getName nt_ synNT = "Syn" ++ "_" ++ getName nt_ varPat = if _lhsIo_newtypes then App (sdtype nt_) [SimpleExpr var] else SimpleExpr var evalTp | null params' = id | otherwise = idEvalType appParams nm = TypeApp (SimpleType nm) (map SimpleType params') typeSig = TSig wrapNT (evalTp $ appParams (sdtype nt_) `Arr` (appParams inhNT `Arr` appParams synNT)) mkstrict = Named _lhsIo_strictwrap mkdata n attrs = Data n params' [Record n [mkstrict (getName f++"_"++n) $ evalTp $ typeToCodeType (Just nt_) params' t | (f,t) <- attrs]] False [] datas = [mkdata inhNT inhAttrs, mkdata synNT synAttrs] in datas ++ [ typeSig , Decl (Fun wrapNT [varPat, App inhNT inhVars]) (Let _interIwrapDecls (App synNT synVars)) Set.empty Set.empty ] {-# LINE 1000 "GenerateCode.hs" #-}) -- "GenerateCode.ag"(line 755, column 18) _comment = ({-# LINE 755 "GenerateCode.ag" #-} Comment . unlines . map ind $ ( _interIcomments ++ ("alternatives:" : map ind _prodsIcomments) ) {-# LINE 1005 "GenerateCode.hs" #-}) -- "GenerateCode.ag"(line 809, column 19) _lhsOchunks = ({-# LINE 809 "GenerateCode.ag" #-} [ Chunk (getName nt_) (Comment (getName nt_ ++ " " ++ replicate (60 - length (getName nt_)) '-')) (if _lhsIo_pretty then [_comment ] else []) (if isJust _lhsIo_data then [_dataDef ] else []) (if _lhsIo_cata then _cataFun else []) (if _lhsIo_sig then _interIsemDom else []) (if nt_ `Set.member` _lhsIwrappers then _semWrapper else []) (if _lhsIo_sem then _prodsIdecls else []) (if _lhsIo_sem then _prodsIsemNames else []) ] {-# LINE 1019 "GenerateCode.hs" #-}) -- "GenerateCode.ag"(line 875, column 18) _dataDef = ({-# LINE 875 "GenerateCode.ag" #-} let params' = map getName params_ typeSyn tp = let theType = case tp of CommonTypes.Maybe t -> TMaybe $ typeToCodeType (Just nt_) params' t CommonTypes.Either t1 t2 -> TEither (typeToCodeType (Just nt_) params' t1) (typeToCodeType (Just nt_) params' t2) CommonTypes.Map t1 t2 -> TMap (typeToCodeType (Just nt_) params' t1) (typeToCodeType (Just nt_) params' t2) CommonTypes.IntMap t -> TIntMap $ typeToCodeType (Just nt_) params' t CommonTypes.List t -> Code.List $ typeToCodeType (Just nt_) params' t CommonTypes.Tuple ts -> Code.TupleType [typeToCodeType (Just nt_) params' t | (_,t) <- ts ] in Code.Type (getName nt_) params' (idEvalType theType) derivings = maybe [] (map getName . Set.toList) (Map.lookup nt_ _lhsIderivings) dataDef = Data (getName nt_) (map getName params_) _prodsIdataAlts (maybe False id _lhsIo_data) derivings in maybe dataDef typeSyn $ lookup nt_ _lhsItypeSyns {-# LINE 1038 "GenerateCode.hs" #-}) -- "GenerateCode.ag"(line 907, column 18) _cataFun = ({-# LINE 907 "GenerateCode.ag" #-} let appParams nm = TypeApp (SimpleType nm) (map SimpleType (map getName params_)) evalTp | null params_ = id | otherwise = idEvalType tSig = TSig (cataname _lhsIprefix nt_) (appContext _lhsIcontextMap nt_ $ evalTp $ appParams (getName nt_) `Arr` appParams (sdtype nt_)) special typ = case typ of CommonTypes.List tp -> let cons = SimpleExpr (semname _lhsIprefix nt_ (identifier "Cons")) nil = SimpleExpr (semname _lhsIprefix nt_ (identifier "Nil" )) arg = SimpleExpr "list" rarg = case tp of NT t _ -> let t' = maybe t id (deforestedNt t) in SimpleExpr ("(Prelude.map " ++ (cataname _lhsIprefix t') ++ " list)") _ -> arg lhs = Fun (cataname _lhsIprefix nt_) [arg] rhs = (App "Prelude.foldr" [cons,nil,rarg]) in [Decl lhs rhs Set.empty Set.empty] CommonTypes.Maybe tp -> let just = semname _lhsIprefix nt_ (identifier "Just") nothing = semname _lhsIprefix nt_ (identifier "Nothing" ) arg = SimpleExpr "x" rarg = case tp of NT t _ -> let t' = maybe t id (deforestedNt t) in App (cataname _lhsIprefix t') [arg] _ -> arg lhs a = Fun (cataname _lhsIprefix nt_) [a] in [Decl (lhs (App "Prelude.Just" [arg])) (App just [rarg]) Set.empty Set.empty ,Decl (lhs (SimpleExpr "Prelude.Nothing")) (SimpleExpr nothing) Set.empty Set.empty ] CommonTypes.Either tp1 tp2 -> let left = semname _lhsIprefix nt_ (identifier "Left") right = semname _lhsIprefix nt_ (identifier "Right" ) arg = SimpleExpr "x" rarg0 = case tp1 of NT t _ -> let t' = maybe t id (deforestedNt t) in App (cataname _lhsIprefix t') [arg] _ -> arg rarg1 = case tp2 of NT t _ -> let t' = maybe t id (deforestedNt t) in App (cataname _lhsIprefix t') [arg] _ -> arg lhs a = Fun (cataname _lhsIprefix nt_) [a] in [Decl (lhs (App "Prelude.Left" [arg])) (App left [rarg0]) Set.empty Set.empty ,Decl (lhs (App "Prelude.Right" [arg])) (App right [rarg1]) Set.empty Set.empty ] CommonTypes.Map _ tp -> let entry = SimpleExpr (semname _lhsIprefix nt_ (identifier "Entry")) nil = SimpleExpr (semname _lhsIprefix nt_ (identifier "Nil")) arg = SimpleExpr "m" rarg = case tp of NT t _ -> let t' = maybe t id (deforestedNt t) in App "Map.map" [SimpleExpr $ cataname _lhsIprefix t', arg] _ -> arg lhs = Fun (cataname _lhsIprefix nt_) [arg] rhs = App "Map.foldWithKey" [entry,nil,rarg] in [Decl lhs rhs Set.empty Set.empty] CommonTypes.IntMap tp -> let entry = SimpleExpr (semname _lhsIprefix nt_ (identifier "Entry")) nil = SimpleExpr (semname _lhsIprefix nt_ (identifier "Nil")) arg = SimpleExpr "m" rarg = case tp of NT t _ -> let t' = maybe t id (deforestedNt t) in App "IntMap.map" [SimpleExpr $ cataname _lhsIprefix t', arg] _ -> arg lhs = Fun (cataname _lhsIprefix nt_) [arg] rhs = App "IntMap.foldWithKey" [entry,nil,rarg] in [Decl lhs rhs Set.empty Set.empty] CommonTypes.Tuple tps -> let con = semname _lhsIprefix nt_ (identifier "Tuple") tps' = [ (SimpleExpr (getName x),y) | (x,y) <- tps] rargs = map rarg tps' rarg (n, tp) = case tp of NT t _ -> let t' = maybe t id (deforestedNt t) in App (cataname _lhsIprefix t') [n] _ -> n lhs = Fun (cataname _lhsIprefix nt_) [TupleExpr (map fst tps')] rhs = App con rargs in [Decl lhs rhs Set.empty Set.empty] in Comment "cata" : (if _lhsIo_sig then [tSig] else []) ++ maybe _prodsIcataAlts special (lookup nt_ _lhsItypeSyns) {-# LINE 1123 "GenerateCode.hs" #-}) -- use rule "GenerateCode.ag"(line 727, column 39) _lhsOallTpsFound = ({-# LINE 727 "GenerateCode.ag" #-} _prodsIallTpsFound {-# LINE 1128 "GenerateCode.hs" #-}) -- use rule "GenerateCode.ag"(line 740, column 32) _lhsOerrors = ({-# LINE 740 "GenerateCode.ag" #-} _prodsIerrors {-# LINE 1133 "GenerateCode.hs" #-}) -- use rule "GenerateCode.ag"(line 622, column 86) _lhsOsemDomUnfoldGath = ({-# LINE 622 "GenerateCode.ag" #-} _interIsemDomUnfoldGath {-# LINE 1138 "GenerateCode.hs" #-}) -- copy rule (down) _prodsOallNts = ({-# LINE 121 "GenerateCode.ag" #-} _lhsIallNts {-# LINE 1143 "GenerateCode.hs" #-}) -- copy rule (down) _prodsOallPragmas = ({-# LINE 67 "GenerateCode.ag" #-} _lhsIallPragmas {-# LINE 1148 "GenerateCode.hs" #-}) -- copy rule (from local) _prodsOaroundMap = ({-# LINE 487 "GenerateCode.ag" #-} _aroundMap {-# LINE 1153 "GenerateCode.hs" #-}) -- copy rule (down) _prodsOcontextMap = ({-# LINE 109 "GenerateCode.ag" #-} _lhsIcontextMap {-# LINE 1158 "GenerateCode.hs" #-}) -- copy rule (down) _prodsOerrors = ({-# LINE 740 "GenerateCode.ag" #-} _lhsIerrors {-# LINE 1163 "GenerateCode.hs" #-}) -- copy rule (down) _prodsOo_case = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_case {-# LINE 1168 "GenerateCode.hs" #-}) -- copy rule (down) _prodsOo_cata = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_cata {-# LINE 1173 "GenerateCode.hs" #-}) -- copy rule (down) _prodsOo_costcentre = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_costcentre {-# LINE 1178 "GenerateCode.hs" #-}) -- copy rule (down) _prodsOo_data = ({-# LINE 46 "GenerateCode.ag" #-} _lhsIo_data {-# LINE 1183 "GenerateCode.hs" #-}) -- copy rule (down) _prodsOo_linePragmas = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_linePragmas {-# LINE 1188 "GenerateCode.hs" #-}) -- copy rule (down) _prodsOo_monadic = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_monadic {-# LINE 1193 "GenerateCode.hs" #-}) -- copy rule (down) _prodsOo_newtypes = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_newtypes {-# LINE 1198 "GenerateCode.hs" #-}) -- copy rule (down) _prodsOo_pretty = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_pretty {-# LINE 1203 "GenerateCode.hs" #-}) -- copy rule (down) _prodsOo_rename = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_rename {-# LINE 1208 "GenerateCode.hs" #-}) -- copy rule (down) _prodsOo_sem = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_sem {-# LINE 1213 "GenerateCode.hs" #-}) -- copy rule (down) _prodsOo_sig = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_sig {-# LINE 1218 "GenerateCode.hs" #-}) -- copy rule (down) _prodsOo_splitsems = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_splitsems {-# LINE 1223 "GenerateCode.hs" #-}) -- copy rule (down) _prodsOo_strictwrap = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_strictwrap {-# LINE 1228 "GenerateCode.hs" #-}) -- copy rule (down) _prodsOo_traces = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_traces {-# LINE 1233 "GenerateCode.hs" #-}) -- copy rule (down) _prodsOo_unbox = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_unbox {-# LINE 1238 "GenerateCode.hs" #-}) -- copy rule (down) _prodsOparamMap = ({-# LINE 89 "GenerateCode.ag" #-} _lhsIparamMap {-# LINE 1243 "GenerateCode.hs" #-}) -- copy rule (down) _prodsOprefix = ({-# LINE 47 "GenerateCode.ag" #-} _lhsIprefix {-# LINE 1248 "GenerateCode.hs" #-}) -- copy rule (down) _prodsOunfoldSemDom = ({-# LINE 628 "GenerateCode.ag" #-} _lhsIunfoldSemDom {-# LINE 1253 "GenerateCode.hs" #-}) -- copy rule (down) _prodsOwith_sig = ({-# LINE 730 "GenerateCode.ag" #-} _lhsIwith_sig {-# LINE 1258 "GenerateCode.hs" #-}) -- copy rule (down) _interOo_case = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_case {-# LINE 1263 "GenerateCode.hs" #-}) -- copy rule (down) _interOo_cata = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_cata {-# LINE 1268 "GenerateCode.hs" #-}) -- copy rule (down) _interOo_costcentre = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_costcentre {-# LINE 1273 "GenerateCode.hs" #-}) -- copy rule (down) _interOo_data = ({-# LINE 46 "GenerateCode.ag" #-} _lhsIo_data {-# LINE 1278 "GenerateCode.hs" #-}) -- copy rule (down) _interOo_linePragmas = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_linePragmas {-# LINE 1283 "GenerateCode.hs" #-}) -- copy rule (down) _interOo_monadic = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_monadic {-# LINE 1288 "GenerateCode.hs" #-}) -- copy rule (down) _interOo_newtypes = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_newtypes {-# LINE 1293 "GenerateCode.hs" #-}) -- copy rule (down) _interOo_pretty = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_pretty {-# LINE 1298 "GenerateCode.hs" #-}) -- copy rule (down) _interOo_rename = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_rename {-# LINE 1303 "GenerateCode.hs" #-}) -- copy rule (down) _interOo_sem = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_sem {-# LINE 1308 "GenerateCode.hs" #-}) -- copy rule (down) _interOo_sig = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_sig {-# LINE 1313 "GenerateCode.hs" #-}) -- copy rule (down) _interOo_splitsems = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_splitsems {-# LINE 1318 "GenerateCode.hs" #-}) -- copy rule (down) _interOo_strictwrap = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_strictwrap {-# LINE 1323 "GenerateCode.hs" #-}) -- copy rule (down) _interOo_traces = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_traces {-# LINE 1328 "GenerateCode.hs" #-}) -- copy rule (down) _interOo_unbox = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_unbox {-# LINE 1333 "GenerateCode.hs" #-}) -- copy rule (down) _interOparamMap = ({-# LINE 89 "GenerateCode.ag" #-} _lhsIparamMap {-# LINE 1338 "GenerateCode.hs" #-}) -- copy rule (down) _interOprefix = ({-# LINE 47 "GenerateCode.ag" #-} _lhsIprefix {-# LINE 1343 "GenerateCode.hs" #-}) ( _prodsIallTpsFound,_prodsIcataAlts,_prodsIcomments,_prodsIdataAlts,_prodsIdecls,_prodsIerrors,_prodsIsemNames) = (prods_ _prodsOallNts _prodsOallPragmas _prodsOaroundMap _prodsOcontextMap _prodsOerrors _prodsOinh _prodsOnt _prodsOo_case _prodsOo_cata _prodsOo_costcentre _prodsOo_data _prodsOo_linePragmas _prodsOo_monadic _prodsOo_newtypes _prodsOo_pretty _prodsOo_rename _prodsOo_sem _prodsOo_sig _prodsOo_splitsems _prodsOo_strictwrap _prodsOo_traces _prodsOo_unbox _prodsOparamMap _prodsOprefix _prodsOsyn _prodsOunfoldSemDom _prodsOwith_sig ) ( _interIcomments,_interIsemDom,_interIsemDomUnfoldGath,_interIwrapDecls) = (inter_ _interOinh _interOnt _interOo_case _interOo_cata _interOo_costcentre _interOo_data _interOo_linePragmas _interOo_monadic _interOo_newtypes _interOo_pretty _interOo_rename _interOo_sem _interOo_sig _interOo_splitsems _interOo_strictwrap _interOo_traces _interOo_unbox _interOparamMap _interOprefix _interOsyn ) in ( _lhsOallTpsFound,_lhsOchunks,_lhsOerrors,_lhsOgathNts,_lhsOsemDomUnfoldGath))) ) -- CNonterminals ----------------------------------------------- {- visit 0: inherited attributes: allNts : Set NontermIdent allPragmas : PragmaMap aroundMap : Map NontermIdent (Map ConstructorIdent (Set Identifier)) contextMap : ContextMap derivings : Derivings o_case : Bool o_cata : Bool o_costcentre : Bool o_data : Maybe Bool o_linePragmas : Bool o_monadic : Bool o_newtypes : Bool o_pretty : Bool o_rename : Bool o_sem : Bool o_sig : Bool o_splitsems : Bool o_strictwrap : Bool o_traces : Bool o_unbox : Bool paramMap : ParamMap prefix : String typeSyns : TypeSyns unfoldSemDom : NontermIdent -> Int -> [String] -> Code.Type with_sig : Bool wrappers : Set NontermIdent chained attribute: errors : Seq Error synthesized attributes: allTpsFound : Bool chunks : Chunks gathNts : Set NontermIdent semDomUnfoldGath : Map (NontermIdent, Int) ([String], Code.Type) alternatives: alternative Cons: child hd : CNonterminal child tl : CNonterminals alternative Nil: -} -- cata sem_CNonterminals :: CNonterminals -> T_CNonterminals sem_CNonterminals list = (Prelude.foldr sem_CNonterminals_Cons sem_CNonterminals_Nil (Prelude.map sem_CNonterminal list) ) -- semantic domain newtype T_CNonterminals = T_CNonterminals ((Set NontermIdent) -> PragmaMap -> (Map NontermIdent (Map ConstructorIdent (Set Identifier))) -> ContextMap -> Derivings -> (Seq Error) -> Bool -> Bool -> Bool -> (Maybe Bool) -> Bool -> Bool -> Bool -> Bool -> Bool -> Bool -> Bool -> Bool -> Bool -> Bool -> Bool -> ParamMap -> String -> TypeSyns -> (NontermIdent -> Int -> [String] -> Code.Type) -> Bool -> (Set NontermIdent) -> ( Bool,Chunks,(Seq Error),(Set NontermIdent),(Map (NontermIdent, Int) ([String], Code.Type)))) data Inh_CNonterminals = Inh_CNonterminals {allNts_Inh_CNonterminals :: !((Set NontermIdent)),allPragmas_Inh_CNonterminals :: !(PragmaMap),aroundMap_Inh_CNonterminals :: !((Map NontermIdent (Map ConstructorIdent (Set Identifier)))),contextMap_Inh_CNonterminals :: !(ContextMap),derivings_Inh_CNonterminals :: !(Derivings),errors_Inh_CNonterminals :: !((Seq Error)),o_case_Inh_CNonterminals :: !(Bool),o_cata_Inh_CNonterminals :: !(Bool),o_costcentre_Inh_CNonterminals :: !(Bool),o_data_Inh_CNonterminals :: !((Maybe Bool)),o_linePragmas_Inh_CNonterminals :: !(Bool),o_monadic_Inh_CNonterminals :: !(Bool),o_newtypes_Inh_CNonterminals :: !(Bool),o_pretty_Inh_CNonterminals :: !(Bool),o_rename_Inh_CNonterminals :: !(Bool),o_sem_Inh_CNonterminals :: !(Bool),o_sig_Inh_CNonterminals :: !(Bool),o_splitsems_Inh_CNonterminals :: !(Bool),o_strictwrap_Inh_CNonterminals :: !(Bool),o_traces_Inh_CNonterminals :: !(Bool),o_unbox_Inh_CNonterminals :: !(Bool),paramMap_Inh_CNonterminals :: !(ParamMap),prefix_Inh_CNonterminals :: !(String),typeSyns_Inh_CNonterminals :: !(TypeSyns),unfoldSemDom_Inh_CNonterminals :: !((NontermIdent -> Int -> [String] -> Code.Type)),with_sig_Inh_CNonterminals :: !(Bool),wrappers_Inh_CNonterminals :: !((Set NontermIdent))} data Syn_CNonterminals = Syn_CNonterminals {allTpsFound_Syn_CNonterminals :: !(Bool),chunks_Syn_CNonterminals :: !(Chunks),errors_Syn_CNonterminals :: !((Seq Error)),gathNts_Syn_CNonterminals :: !((Set NontermIdent)),semDomUnfoldGath_Syn_CNonterminals :: !((Map (NontermIdent, Int) ([String], Code.Type)))} wrap_CNonterminals :: T_CNonterminals -> Inh_CNonterminals -> Syn_CNonterminals wrap_CNonterminals (T_CNonterminals sem ) (Inh_CNonterminals _lhsIallNts _lhsIallPragmas _lhsIaroundMap _lhsIcontextMap _lhsIderivings _lhsIerrors _lhsIo_case _lhsIo_cata _lhsIo_costcentre _lhsIo_data _lhsIo_linePragmas _lhsIo_monadic _lhsIo_newtypes _lhsIo_pretty _lhsIo_rename _lhsIo_sem _lhsIo_sig _lhsIo_splitsems _lhsIo_strictwrap _lhsIo_traces _lhsIo_unbox _lhsIparamMap _lhsIprefix _lhsItypeSyns _lhsIunfoldSemDom _lhsIwith_sig _lhsIwrappers ) = (let ( _lhsOallTpsFound,_lhsOchunks,_lhsOerrors,_lhsOgathNts,_lhsOsemDomUnfoldGath) = (sem _lhsIallNts _lhsIallPragmas _lhsIaroundMap _lhsIcontextMap _lhsIderivings _lhsIerrors _lhsIo_case _lhsIo_cata _lhsIo_costcentre _lhsIo_data _lhsIo_linePragmas _lhsIo_monadic _lhsIo_newtypes _lhsIo_pretty _lhsIo_rename _lhsIo_sem _lhsIo_sig _lhsIo_splitsems _lhsIo_strictwrap _lhsIo_traces _lhsIo_unbox _lhsIparamMap _lhsIprefix _lhsItypeSyns _lhsIunfoldSemDom _lhsIwith_sig _lhsIwrappers ) in (Syn_CNonterminals _lhsOallTpsFound _lhsOchunks _lhsOerrors _lhsOgathNts _lhsOsemDomUnfoldGath )) sem_CNonterminals_Cons :: T_CNonterminal -> T_CNonterminals -> T_CNonterminals sem_CNonterminals_Cons (T_CNonterminal hd_ ) (T_CNonterminals tl_ ) = (T_CNonterminals (\ _lhsIallNts _lhsIallPragmas _lhsIaroundMap _lhsIcontextMap _lhsIderivings _lhsIerrors _lhsIo_case _lhsIo_cata _lhsIo_costcentre _lhsIo_data _lhsIo_linePragmas _lhsIo_monadic _lhsIo_newtypes _lhsIo_pretty _lhsIo_rename _lhsIo_sem _lhsIo_sig _lhsIo_splitsems _lhsIo_strictwrap _lhsIo_traces _lhsIo_unbox _lhsIparamMap _lhsIprefix _lhsItypeSyns _lhsIunfoldSemDom _lhsIwith_sig _lhsIwrappers -> (let _lhsOallTpsFound :: Bool _lhsOchunks :: Chunks _lhsOerrors :: (Seq Error) _lhsOgathNts :: (Set NontermIdent) _lhsOsemDomUnfoldGath :: (Map (NontermIdent, Int) ([String], Code.Type)) _hdOallNts :: (Set NontermIdent) _hdOallPragmas :: PragmaMap _hdOaroundMap :: (Map NontermIdent (Map ConstructorIdent (Set Identifier))) _hdOcontextMap :: ContextMap _hdOderivings :: Derivings _hdOerrors :: (Seq Error) _hdOo_case :: Bool _hdOo_cata :: Bool _hdOo_costcentre :: Bool _hdOo_data :: (Maybe Bool) _hdOo_linePragmas :: Bool _hdOo_monadic :: Bool _hdOo_newtypes :: Bool _hdOo_pretty :: Bool _hdOo_rename :: Bool _hdOo_sem :: Bool _hdOo_sig :: Bool _hdOo_splitsems :: Bool _hdOo_strictwrap :: Bool _hdOo_traces :: Bool _hdOo_unbox :: Bool _hdOparamMap :: ParamMap _hdOprefix :: String _hdOtypeSyns :: TypeSyns _hdOunfoldSemDom :: (NontermIdent -> Int -> [String] -> Code.Type) _hdOwith_sig :: Bool _hdOwrappers :: (Set NontermIdent) _tlOallNts :: (Set NontermIdent) _tlOallPragmas :: PragmaMap _tlOaroundMap :: (Map NontermIdent (Map ConstructorIdent (Set Identifier))) _tlOcontextMap :: ContextMap _tlOderivings :: Derivings _tlOerrors :: (Seq Error) _tlOo_case :: Bool _tlOo_cata :: Bool _tlOo_costcentre :: Bool _tlOo_data :: (Maybe Bool) _tlOo_linePragmas :: Bool _tlOo_monadic :: Bool _tlOo_newtypes :: Bool _tlOo_pretty :: Bool _tlOo_rename :: Bool _tlOo_sem :: Bool _tlOo_sig :: Bool _tlOo_splitsems :: Bool _tlOo_strictwrap :: Bool _tlOo_traces :: Bool _tlOo_unbox :: Bool _tlOparamMap :: ParamMap _tlOprefix :: String _tlOtypeSyns :: TypeSyns _tlOunfoldSemDom :: (NontermIdent -> Int -> [String] -> Code.Type) _tlOwith_sig :: Bool _tlOwrappers :: (Set NontermIdent) _hdIallTpsFound :: Bool _hdIchunks :: Chunks _hdIerrors :: (Seq Error) _hdIgathNts :: (Set NontermIdent) _hdIsemDomUnfoldGath :: (Map (NontermIdent, Int) ([String], Code.Type)) _tlIallTpsFound :: Bool _tlIchunks :: Chunks _tlIerrors :: (Seq Error) _tlIgathNts :: (Set NontermIdent) _tlIsemDomUnfoldGath :: (Map (NontermIdent, Int) ([String], Code.Type)) -- use rule "GenerateCode.ag"(line 727, column 39) _lhsOallTpsFound = ({-# LINE 727 "GenerateCode.ag" #-} _hdIallTpsFound && _tlIallTpsFound {-# LINE 1539 "GenerateCode.hs" #-}) -- use rule "GenerateCode.ag"(line 801, column 49) _lhsOchunks = ({-# LINE 801 "GenerateCode.ag" #-} _hdIchunks ++ _tlIchunks {-# LINE 1544 "GenerateCode.hs" #-}) -- use rule "GenerateCode.ag"(line 740, column 32) _lhsOerrors = ({-# LINE 740 "GenerateCode.ag" #-} _hdIerrors Seq.>< _tlIerrors {-# LINE 1549 "GenerateCode.hs" #-}) -- use rule "GenerateCode.ag"(line 127, column 47) _lhsOgathNts = ({-# LINE 127 "GenerateCode.ag" #-} _hdIgathNts `Set.union` _tlIgathNts {-# LINE 1554 "GenerateCode.hs" #-}) -- use rule "GenerateCode.ag"(line 622, column 86) _lhsOsemDomUnfoldGath = ({-# LINE 622 "GenerateCode.ag" #-} _hdIsemDomUnfoldGath `Map.union` _tlIsemDomUnfoldGath {-# LINE 1559 "GenerateCode.hs" #-}) -- copy rule (down) _hdOallNts = ({-# LINE 121 "GenerateCode.ag" #-} _lhsIallNts {-# LINE 1564 "GenerateCode.hs" #-}) -- copy rule (down) _hdOallPragmas = ({-# LINE 67 "GenerateCode.ag" #-} _lhsIallPragmas {-# LINE 1569 "GenerateCode.hs" #-}) -- copy rule (down) _hdOaroundMap = ({-# LINE 484 "GenerateCode.ag" #-} _lhsIaroundMap {-# LINE 1574 "GenerateCode.hs" #-}) -- copy rule (down) _hdOcontextMap = ({-# LINE 109 "GenerateCode.ag" #-} _lhsIcontextMap {-# LINE 1579 "GenerateCode.hs" #-}) -- copy rule (down) _hdOderivings = ({-# LINE 868 "GenerateCode.ag" #-} _lhsIderivings {-# LINE 1584 "GenerateCode.hs" #-}) -- copy rule (down) _hdOerrors = ({-# LINE 740 "GenerateCode.ag" #-} _lhsIerrors {-# LINE 1589 "GenerateCode.hs" #-}) -- copy rule (down) _hdOo_case = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_case {-# LINE 1594 "GenerateCode.hs" #-}) -- copy rule (down) _hdOo_cata = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_cata {-# LINE 1599 "GenerateCode.hs" #-}) -- copy rule (down) _hdOo_costcentre = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_costcentre {-# LINE 1604 "GenerateCode.hs" #-}) -- copy rule (down) _hdOo_data = ({-# LINE 46 "GenerateCode.ag" #-} _lhsIo_data {-# LINE 1609 "GenerateCode.hs" #-}) -- copy rule (down) _hdOo_linePragmas = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_linePragmas {-# LINE 1614 "GenerateCode.hs" #-}) -- copy rule (down) _hdOo_monadic = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_monadic {-# LINE 1619 "GenerateCode.hs" #-}) -- copy rule (down) _hdOo_newtypes = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_newtypes {-# LINE 1624 "GenerateCode.hs" #-}) -- copy rule (down) _hdOo_pretty = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_pretty {-# LINE 1629 "GenerateCode.hs" #-}) -- copy rule (down) _hdOo_rename = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_rename {-# LINE 1634 "GenerateCode.hs" #-}) -- copy rule (down) _hdOo_sem = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_sem {-# LINE 1639 "GenerateCode.hs" #-}) -- copy rule (down) _hdOo_sig = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_sig {-# LINE 1644 "GenerateCode.hs" #-}) -- copy rule (down) _hdOo_splitsems = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_splitsems {-# LINE 1649 "GenerateCode.hs" #-}) -- copy rule (down) _hdOo_strictwrap = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_strictwrap {-# LINE 1654 "GenerateCode.hs" #-}) -- copy rule (down) _hdOo_traces = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_traces {-# LINE 1659 "GenerateCode.hs" #-}) -- copy rule (down) _hdOo_unbox = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_unbox {-# LINE 1664 "GenerateCode.hs" #-}) -- copy rule (down) _hdOparamMap = ({-# LINE 89 "GenerateCode.ag" #-} _lhsIparamMap {-# LINE 1669 "GenerateCode.hs" #-}) -- copy rule (down) _hdOprefix = ({-# LINE 47 "GenerateCode.ag" #-} _lhsIprefix {-# LINE 1674 "GenerateCode.hs" #-}) -- copy rule (down) _hdOtypeSyns = ({-# LINE 868 "GenerateCode.ag" #-} _lhsItypeSyns {-# LINE 1679 "GenerateCode.hs" #-}) -- copy rule (down) _hdOunfoldSemDom = ({-# LINE 628 "GenerateCode.ag" #-} _lhsIunfoldSemDom {-# LINE 1684 "GenerateCode.hs" #-}) -- copy rule (down) _hdOwith_sig = ({-# LINE 730 "GenerateCode.ag" #-} _lhsIwith_sig {-# LINE 1689 "GenerateCode.hs" #-}) -- copy rule (down) _hdOwrappers = ({-# LINE 868 "GenerateCode.ag" #-} _lhsIwrappers {-# LINE 1694 "GenerateCode.hs" #-}) -- copy rule (down) _tlOallNts = ({-# LINE 121 "GenerateCode.ag" #-} _lhsIallNts {-# LINE 1699 "GenerateCode.hs" #-}) -- copy rule (down) _tlOallPragmas = ({-# LINE 67 "GenerateCode.ag" #-} _lhsIallPragmas {-# LINE 1704 "GenerateCode.hs" #-}) -- copy rule (down) _tlOaroundMap = ({-# LINE 484 "GenerateCode.ag" #-} _lhsIaroundMap {-# LINE 1709 "GenerateCode.hs" #-}) -- copy rule (down) _tlOcontextMap = ({-# LINE 109 "GenerateCode.ag" #-} _lhsIcontextMap {-# LINE 1714 "GenerateCode.hs" #-}) -- copy rule (down) _tlOderivings = ({-# LINE 868 "GenerateCode.ag" #-} _lhsIderivings {-# LINE 1719 "GenerateCode.hs" #-}) -- copy rule (chain) _tlOerrors = ({-# LINE 740 "GenerateCode.ag" #-} _hdIerrors {-# LINE 1724 "GenerateCode.hs" #-}) -- copy rule (down) _tlOo_case = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_case {-# LINE 1729 "GenerateCode.hs" #-}) -- copy rule (down) _tlOo_cata = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_cata {-# LINE 1734 "GenerateCode.hs" #-}) -- copy rule (down) _tlOo_costcentre = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_costcentre {-# LINE 1739 "GenerateCode.hs" #-}) -- copy rule (down) _tlOo_data = ({-# LINE 46 "GenerateCode.ag" #-} _lhsIo_data {-# LINE 1744 "GenerateCode.hs" #-}) -- copy rule (down) _tlOo_linePragmas = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_linePragmas {-# LINE 1749 "GenerateCode.hs" #-}) -- copy rule (down) _tlOo_monadic = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_monadic {-# LINE 1754 "GenerateCode.hs" #-}) -- copy rule (down) _tlOo_newtypes = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_newtypes {-# LINE 1759 "GenerateCode.hs" #-}) -- copy rule (down) _tlOo_pretty = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_pretty {-# LINE 1764 "GenerateCode.hs" #-}) -- copy rule (down) _tlOo_rename = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_rename {-# LINE 1769 "GenerateCode.hs" #-}) -- copy rule (down) _tlOo_sem = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_sem {-# LINE 1774 "GenerateCode.hs" #-}) -- copy rule (down) _tlOo_sig = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_sig {-# LINE 1779 "GenerateCode.hs" #-}) -- copy rule (down) _tlOo_splitsems = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_splitsems {-# LINE 1784 "GenerateCode.hs" #-}) -- copy rule (down) _tlOo_strictwrap = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_strictwrap {-# LINE 1789 "GenerateCode.hs" #-}) -- copy rule (down) _tlOo_traces = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_traces {-# LINE 1794 "GenerateCode.hs" #-}) -- copy rule (down) _tlOo_unbox = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_unbox {-# LINE 1799 "GenerateCode.hs" #-}) -- copy rule (down) _tlOparamMap = ({-# LINE 89 "GenerateCode.ag" #-} _lhsIparamMap {-# LINE 1804 "GenerateCode.hs" #-}) -- copy rule (down) _tlOprefix = ({-# LINE 47 "GenerateCode.ag" #-} _lhsIprefix {-# LINE 1809 "GenerateCode.hs" #-}) -- copy rule (down) _tlOtypeSyns = ({-# LINE 868 "GenerateCode.ag" #-} _lhsItypeSyns {-# LINE 1814 "GenerateCode.hs" #-}) -- copy rule (down) _tlOunfoldSemDom = ({-# LINE 628 "GenerateCode.ag" #-} _lhsIunfoldSemDom {-# LINE 1819 "GenerateCode.hs" #-}) -- copy rule (down) _tlOwith_sig = ({-# LINE 730 "GenerateCode.ag" #-} _lhsIwith_sig {-# LINE 1824 "GenerateCode.hs" #-}) -- copy rule (down) _tlOwrappers = ({-# LINE 868 "GenerateCode.ag" #-} _lhsIwrappers {-# LINE 1829 "GenerateCode.hs" #-}) ( _hdIallTpsFound,_hdIchunks,_hdIerrors,_hdIgathNts,_hdIsemDomUnfoldGath) = (hd_ _hdOallNts _hdOallPragmas _hdOaroundMap _hdOcontextMap _hdOderivings _hdOerrors _hdOo_case _hdOo_cata _hdOo_costcentre _hdOo_data _hdOo_linePragmas _hdOo_monadic _hdOo_newtypes _hdOo_pretty _hdOo_rename _hdOo_sem _hdOo_sig _hdOo_splitsems _hdOo_strictwrap _hdOo_traces _hdOo_unbox _hdOparamMap _hdOprefix _hdOtypeSyns _hdOunfoldSemDom _hdOwith_sig _hdOwrappers ) ( _tlIallTpsFound,_tlIchunks,_tlIerrors,_tlIgathNts,_tlIsemDomUnfoldGath) = (tl_ _tlOallNts _tlOallPragmas _tlOaroundMap _tlOcontextMap _tlOderivings _tlOerrors _tlOo_case _tlOo_cata _tlOo_costcentre _tlOo_data _tlOo_linePragmas _tlOo_monadic _tlOo_newtypes _tlOo_pretty _tlOo_rename _tlOo_sem _tlOo_sig _tlOo_splitsems _tlOo_strictwrap _tlOo_traces _tlOo_unbox _tlOparamMap _tlOprefix _tlOtypeSyns _tlOunfoldSemDom _tlOwith_sig _tlOwrappers ) in ( _lhsOallTpsFound,_lhsOchunks,_lhsOerrors,_lhsOgathNts,_lhsOsemDomUnfoldGath))) ) sem_CNonterminals_Nil :: T_CNonterminals sem_CNonterminals_Nil = (T_CNonterminals (\ _lhsIallNts _lhsIallPragmas _lhsIaroundMap _lhsIcontextMap _lhsIderivings _lhsIerrors _lhsIo_case _lhsIo_cata _lhsIo_costcentre _lhsIo_data _lhsIo_linePragmas _lhsIo_monadic _lhsIo_newtypes _lhsIo_pretty _lhsIo_rename _lhsIo_sem _lhsIo_sig _lhsIo_splitsems _lhsIo_strictwrap _lhsIo_traces _lhsIo_unbox _lhsIparamMap _lhsIprefix _lhsItypeSyns _lhsIunfoldSemDom _lhsIwith_sig _lhsIwrappers -> (let _lhsOallTpsFound :: Bool _lhsOchunks :: Chunks _lhsOerrors :: (Seq Error) _lhsOgathNts :: (Set NontermIdent) _lhsOsemDomUnfoldGath :: (Map (NontermIdent, Int) ([String], Code.Type)) -- use rule "GenerateCode.ag"(line 727, column 39) _lhsOallTpsFound = ({-# LINE 727 "GenerateCode.ag" #-} True {-# LINE 1873 "GenerateCode.hs" #-}) -- use rule "GenerateCode.ag"(line 801, column 49) _lhsOchunks = ({-# LINE 801 "GenerateCode.ag" #-} [] {-# LINE 1878 "GenerateCode.hs" #-}) -- use rule "GenerateCode.ag"(line 740, column 32) _lhsOerrors = ({-# LINE 740 "GenerateCode.ag" #-} Seq.empty {-# LINE 1883 "GenerateCode.hs" #-}) -- use rule "GenerateCode.ag"(line 127, column 47) _lhsOgathNts = ({-# LINE 127 "GenerateCode.ag" #-} Set.empty {-# LINE 1888 "GenerateCode.hs" #-}) -- use rule "GenerateCode.ag"(line 622, column 86) _lhsOsemDomUnfoldGath = ({-# LINE 622 "GenerateCode.ag" #-} Map.empty {-# LINE 1893 "GenerateCode.hs" #-}) in ( _lhsOallTpsFound,_lhsOchunks,_lhsOerrors,_lhsOgathNts,_lhsOsemDomUnfoldGath))) ) -- CProduction ------------------------------------------------- {- visit 0: inherited attributes: allNts : Set NontermIdent allPragmas : PragmaMap aroundMap : Map ConstructorIdent (Set Identifier) contextMap : ContextMap inh : Attributes nt : NontermIdent o_case : Bool o_cata : Bool o_costcentre : Bool o_data : Maybe Bool o_linePragmas : Bool o_monadic : Bool o_newtypes : Bool o_pretty : Bool o_rename : Bool o_sem : Bool o_sig : Bool o_splitsems : Bool o_strictwrap : Bool o_traces : Bool o_unbox : Bool paramMap : ParamMap prefix : String syn : Attributes unfoldSemDom : NontermIdent -> Int -> [String] -> Code.Type with_sig : Bool chained attribute: errors : Seq Error synthesized attributes: allTpsFound : Bool cataAlt : Decl comments : [String] dataAlt : DataAlt decls : Decls semNames : [String] alternatives: alternative CProduction: child con : {ConstructorIdent} child visits : CVisits child children : {[(Identifier,Type,Bool)]} child terminals : {[Identifier]} visit 0: local paramInstMap : _ local aroundMap : _ local firstOrderChildren : _ local params : _ -} -- cata sem_CProduction :: CProduction -> T_CProduction sem_CProduction (CProduction _con _visits _children _terminals ) = (sem_CProduction_CProduction _con (sem_CVisits _visits ) _children _terminals ) -- semantic domain newtype T_CProduction = T_CProduction ((Set NontermIdent) -> PragmaMap -> (Map ConstructorIdent (Set Identifier)) -> ContextMap -> (Seq Error) -> Attributes -> NontermIdent -> Bool -> Bool -> Bool -> (Maybe Bool) -> Bool -> Bool -> Bool -> Bool -> Bool -> Bool -> Bool -> Bool -> Bool -> Bool -> Bool -> ParamMap -> String -> Attributes -> (NontermIdent -> Int -> [String] -> Code.Type) -> Bool -> ( Bool,Decl,([String]),DataAlt,Decls,(Seq Error),([String]))) data Inh_CProduction = Inh_CProduction {allNts_Inh_CProduction :: !((Set NontermIdent)),allPragmas_Inh_CProduction :: !(PragmaMap),aroundMap_Inh_CProduction :: !((Map ConstructorIdent (Set Identifier))),contextMap_Inh_CProduction :: !(ContextMap),errors_Inh_CProduction :: !((Seq Error)),inh_Inh_CProduction :: !(Attributes),nt_Inh_CProduction :: !(NontermIdent),o_case_Inh_CProduction :: !(Bool),o_cata_Inh_CProduction :: !(Bool),o_costcentre_Inh_CProduction :: !(Bool),o_data_Inh_CProduction :: !((Maybe Bool)),o_linePragmas_Inh_CProduction :: !(Bool),o_monadic_Inh_CProduction :: !(Bool),o_newtypes_Inh_CProduction :: !(Bool),o_pretty_Inh_CProduction :: !(Bool),o_rename_Inh_CProduction :: !(Bool),o_sem_Inh_CProduction :: !(Bool),o_sig_Inh_CProduction :: !(Bool),o_splitsems_Inh_CProduction :: !(Bool),o_strictwrap_Inh_CProduction :: !(Bool),o_traces_Inh_CProduction :: !(Bool),o_unbox_Inh_CProduction :: !(Bool),paramMap_Inh_CProduction :: !(ParamMap),prefix_Inh_CProduction :: !(String),syn_Inh_CProduction :: !(Attributes),unfoldSemDom_Inh_CProduction :: !((NontermIdent -> Int -> [String] -> Code.Type)),with_sig_Inh_CProduction :: !(Bool)} data Syn_CProduction = Syn_CProduction {allTpsFound_Syn_CProduction :: !(Bool),cataAlt_Syn_CProduction :: !(Decl),comments_Syn_CProduction :: !(([String])),dataAlt_Syn_CProduction :: !(DataAlt),decls_Syn_CProduction :: !(Decls),errors_Syn_CProduction :: !((Seq Error)),semNames_Syn_CProduction :: !(([String]))} wrap_CProduction :: T_CProduction -> Inh_CProduction -> Syn_CProduction wrap_CProduction (T_CProduction sem ) (Inh_CProduction _lhsIallNts _lhsIallPragmas _lhsIaroundMap _lhsIcontextMap _lhsIerrors _lhsIinh _lhsInt _lhsIo_case _lhsIo_cata _lhsIo_costcentre _lhsIo_data _lhsIo_linePragmas _lhsIo_monadic _lhsIo_newtypes _lhsIo_pretty _lhsIo_rename _lhsIo_sem _lhsIo_sig _lhsIo_splitsems _lhsIo_strictwrap _lhsIo_traces _lhsIo_unbox _lhsIparamMap _lhsIprefix _lhsIsyn _lhsIunfoldSemDom _lhsIwith_sig ) = (let ( _lhsOallTpsFound,_lhsOcataAlt,_lhsOcomments,_lhsOdataAlt,_lhsOdecls,_lhsOerrors,_lhsOsemNames) = (sem _lhsIallNts _lhsIallPragmas _lhsIaroundMap _lhsIcontextMap _lhsIerrors _lhsIinh _lhsInt _lhsIo_case _lhsIo_cata _lhsIo_costcentre _lhsIo_data _lhsIo_linePragmas _lhsIo_monadic _lhsIo_newtypes _lhsIo_pretty _lhsIo_rename _lhsIo_sem _lhsIo_sig _lhsIo_splitsems _lhsIo_strictwrap _lhsIo_traces _lhsIo_unbox _lhsIparamMap _lhsIprefix _lhsIsyn _lhsIunfoldSemDom _lhsIwith_sig ) in (Syn_CProduction _lhsOallTpsFound _lhsOcataAlt _lhsOcomments _lhsOdataAlt _lhsOdecls _lhsOerrors _lhsOsemNames )) sem_CProduction_CProduction :: ConstructorIdent -> T_CVisits -> ([(Identifier,Type,Bool)]) -> ([Identifier]) -> T_CProduction sem_CProduction_CProduction con_ (T_CVisits visits_ ) children_ terminals_ = (T_CProduction (\ _lhsIallNts _lhsIallPragmas _lhsIaroundMap _lhsIcontextMap _lhsIerrors _lhsIinh _lhsInt _lhsIo_case _lhsIo_cata _lhsIo_costcentre _lhsIo_data _lhsIo_linePragmas _lhsIo_monadic _lhsIo_newtypes _lhsIo_pretty _lhsIo_rename _lhsIo_sem _lhsIo_sig _lhsIo_splitsems _lhsIo_strictwrap _lhsIo_traces _lhsIo_unbox _lhsIparamMap _lhsIprefix _lhsIsyn _lhsIunfoldSemDom _lhsIwith_sig -> (let _visitsOcon :: ConstructorIdent _visitsOterminals :: ([Identifier]) _visitsOnr :: Int _visitsOchildren :: ([(Identifier,Type,Bool)]) _visitsOinstVisitNrs :: (Map Identifier Int) _lhsOcomments :: ([String]) _lhsOdataAlt :: DataAlt _lhsOcataAlt :: Decl _lhsOallTpsFound :: Bool _lhsOdecls :: Decls _lhsOerrors :: (Seq Error) _lhsOsemNames :: ([String]) _visitsOallNts :: (Set NontermIdent) _visitsOallPragmas :: PragmaMap _visitsOaroundMap :: (Set Identifier) _visitsOcontextMap :: ContextMap _visitsOerrors :: (Seq Error) _visitsOinh :: Attributes _visitsOnt :: NontermIdent _visitsOo_case :: Bool _visitsOo_cata :: Bool _visitsOo_costcentre :: Bool _visitsOo_data :: (Maybe Bool) _visitsOo_linePragmas :: Bool _visitsOo_monadic :: Bool _visitsOo_newtypes :: Bool _visitsOo_pretty :: Bool _visitsOo_rename :: Bool _visitsOo_sem :: Bool _visitsOo_sig :: Bool _visitsOo_splitsems :: Bool _visitsOo_strictwrap :: Bool _visitsOo_traces :: Bool _visitsOo_unbox :: Bool _visitsOparamInstMap :: (Map Identifier (NontermIdent, [String])) _visitsOparamMap :: ParamMap _visitsOprefix :: String _visitsOsyn :: Attributes _visitsOunfoldSemDom :: (NontermIdent -> Int -> [String] -> Code.Type) _visitsOwith_sig :: Bool _visitsIallTpsFound :: Bool _visitsIcomments :: ([String]) _visitsIdecls :: Decls _visitsIerrors :: (Seq Error) _visitsIgatherInstVisitNrs :: (Map Identifier Int) _visitsIintra :: Exprs _visitsIintraVars :: (Set String) _visitsIisNil :: Bool _visitsIsemNames :: ([String]) -- "GenerateCode.ag"(line 86, column 19) _visitsOcon = ({-# LINE 86 "GenerateCode.ag" #-} con_ {-# LINE 2075 "GenerateCode.hs" #-}) -- "GenerateCode.ag"(line 87, column 20) _visitsOterminals = ({-# LINE 87 "GenerateCode.ag" #-} terminals_ {-# LINE 2080 "GenerateCode.hs" #-}) -- "GenerateCode.ag"(line 99, column 7) _paramInstMap = ({-# LINE 99 "GenerateCode.ag" #-} Map.fromList [(nm, (extractNonterminal tp, tps)) | (nm,tp,_) <- children_, let tps = map cleanupArg $ nontermArgs tp, not (null tps) ] {-# LINE 2085 "GenerateCode.hs" #-}) -- "GenerateCode.ag"(line 231, column 18) _visitsOnr = ({-# LINE 231 "GenerateCode.ag" #-} 0 {-# LINE 2090 "GenerateCode.hs" #-}) -- "GenerateCode.ag"(line 357, column 18) _visitsOchildren = ({-# LINE 357 "GenerateCode.ag" #-} children_ {-# LINE 2095 "GenerateCode.hs" #-}) -- "GenerateCode.ag"(line 473, column 7) _visitsOinstVisitNrs = ({-# LINE 473 "GenerateCode.ag" #-} _visitsIgatherInstVisitNrs {-# LINE 2100 "GenerateCode.hs" #-}) -- "GenerateCode.ag"(line 493, column 34) _aroundMap = ({-# LINE 493 "GenerateCode.ag" #-} Map.findWithDefault Set.empty con_ _lhsIaroundMap {-# LINE 2105 "GenerateCode.hs" #-}) -- "GenerateCode.ag"(line 770, column 17) _firstOrderChildren = ({-# LINE 770 "GenerateCode.ag" #-} filter (\(_,_,ho) -> not ho) children_ {-# LINE 2110 "GenerateCode.hs" #-}) -- "GenerateCode.ag"(line 771, column 18) _lhsOcomments = ({-# LINE 771 "GenerateCode.ag" #-} ("alternative " ++ getName con_ ++ ":") : map ind ( map (\(x,y,_) -> makeLocalComment 14 "child" x (Just y)) _firstOrderChildren ++ _visitsIcomments ) {-# LINE 2118 "GenerateCode.hs" #-}) -- "GenerateCode.ag"(line 899, column 17) _params = ({-# LINE 899 "GenerateCode.ag" #-} map getName $ Map.findWithDefault [] _lhsInt _lhsIparamMap {-# LINE 2123 "GenerateCode.hs" #-}) -- "GenerateCode.ag"(line 900, column 17) _lhsOdataAlt = ({-# LINE 900 "GenerateCode.ag" #-} DataAlt (conname _lhsIo_rename _lhsInt con_) (map (\(_,t,_) -> typeToCodeType (Just _lhsInt) _params t) _firstOrderChildren ) {-# LINE 2128 "GenerateCode.hs" #-}) -- "GenerateCode.ag"(line 999, column 17) _lhsOcataAlt = ({-# LINE 999 "GenerateCode.ag" #-} let lhs = Fun (cataname _lhsIprefix _lhsInt) [lhs_pat] lhs_pat = App (conname _lhsIo_rename _lhsInt con_) (map (\(n,_,_) -> SimpleExpr $ locname $ n) _firstOrderChildren ) rhs = App (semname _lhsIprefix _lhsInt con_) (map argument _firstOrderChildren ) argument (nm,NT tp _,_) = let tp' = maybe tp id (deforestedNt tp) in App (cataname _lhsIprefix tp') [SimpleExpr (locname nm)] argument (nm, _,_) = SimpleExpr (locname nm) in Decl lhs rhs Set.empty Set.empty {-# LINE 2142 "GenerateCode.hs" #-}) -- use rule "GenerateCode.ag"(line 727, column 39) _lhsOallTpsFound = ({-# LINE 727 "GenerateCode.ag" #-} _visitsIallTpsFound {-# LINE 2147 "GenerateCode.hs" #-}) -- use rule "GenerateCode.ag"(line 802, column 44) _lhsOdecls = ({-# LINE 802 "GenerateCode.ag" #-} _visitsIdecls {-# LINE 2152 "GenerateCode.hs" #-}) -- use rule "GenerateCode.ag"(line 740, column 32) _lhsOerrors = ({-# LINE 740 "GenerateCode.ag" #-} _visitsIerrors {-# LINE 2157 "GenerateCode.hs" #-}) -- use rule "GenerateCode.ag"(line 1015, column 61) _lhsOsemNames = ({-# LINE 1015 "GenerateCode.ag" #-} _visitsIsemNames {-# LINE 2162 "GenerateCode.hs" #-}) -- copy rule (down) _visitsOallNts = ({-# LINE 121 "GenerateCode.ag" #-} _lhsIallNts {-# LINE 2167 "GenerateCode.hs" #-}) -- copy rule (down) _visitsOallPragmas = ({-# LINE 67 "GenerateCode.ag" #-} _lhsIallPragmas {-# LINE 2172 "GenerateCode.hs" #-}) -- copy rule (from local) _visitsOaroundMap = ({-# LINE 489 "GenerateCode.ag" #-} _aroundMap {-# LINE 2177 "GenerateCode.hs" #-}) -- copy rule (down) _visitsOcontextMap = ({-# LINE 109 "GenerateCode.ag" #-} _lhsIcontextMap {-# LINE 2182 "GenerateCode.hs" #-}) -- copy rule (down) _visitsOerrors = ({-# LINE 740 "GenerateCode.ag" #-} _lhsIerrors {-# LINE 2187 "GenerateCode.hs" #-}) -- copy rule (down) _visitsOinh = ({-# LINE 78 "GenerateCode.ag" #-} _lhsIinh {-# LINE 2192 "GenerateCode.hs" #-}) -- copy rule (down) _visitsOnt = ({-# LINE 78 "GenerateCode.ag" #-} _lhsInt {-# LINE 2197 "GenerateCode.hs" #-}) -- copy rule (down) _visitsOo_case = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_case {-# LINE 2202 "GenerateCode.hs" #-}) -- copy rule (down) _visitsOo_cata = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_cata {-# LINE 2207 "GenerateCode.hs" #-}) -- copy rule (down) _visitsOo_costcentre = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_costcentre {-# LINE 2212 "GenerateCode.hs" #-}) -- copy rule (down) _visitsOo_data = ({-# LINE 46 "GenerateCode.ag" #-} _lhsIo_data {-# LINE 2217 "GenerateCode.hs" #-}) -- copy rule (down) _visitsOo_linePragmas = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_linePragmas {-# LINE 2222 "GenerateCode.hs" #-}) -- copy rule (down) _visitsOo_monadic = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_monadic {-# LINE 2227 "GenerateCode.hs" #-}) -- copy rule (down) _visitsOo_newtypes = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_newtypes {-# LINE 2232 "GenerateCode.hs" #-}) -- copy rule (down) _visitsOo_pretty = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_pretty {-# LINE 2237 "GenerateCode.hs" #-}) -- copy rule (down) _visitsOo_rename = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_rename {-# LINE 2242 "GenerateCode.hs" #-}) -- copy rule (down) _visitsOo_sem = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_sem {-# LINE 2247 "GenerateCode.hs" #-}) -- copy rule (down) _visitsOo_sig = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_sig {-# LINE 2252 "GenerateCode.hs" #-}) -- copy rule (down) _visitsOo_splitsems = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_splitsems {-# LINE 2257 "GenerateCode.hs" #-}) -- copy rule (down) _visitsOo_strictwrap = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_strictwrap {-# LINE 2262 "GenerateCode.hs" #-}) -- copy rule (down) _visitsOo_traces = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_traces {-# LINE 2267 "GenerateCode.hs" #-}) -- copy rule (down) _visitsOo_unbox = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_unbox {-# LINE 2272 "GenerateCode.hs" #-}) -- copy rule (from local) _visitsOparamInstMap = ({-# LINE 95 "GenerateCode.ag" #-} _paramInstMap {-# LINE 2277 "GenerateCode.hs" #-}) -- copy rule (down) _visitsOparamMap = ({-# LINE 89 "GenerateCode.ag" #-} _lhsIparamMap {-# LINE 2282 "GenerateCode.hs" #-}) -- copy rule (down) _visitsOprefix = ({-# LINE 47 "GenerateCode.ag" #-} _lhsIprefix {-# LINE 2287 "GenerateCode.hs" #-}) -- copy rule (down) _visitsOsyn = ({-# LINE 78 "GenerateCode.ag" #-} _lhsIsyn {-# LINE 2292 "GenerateCode.hs" #-}) -- copy rule (down) _visitsOunfoldSemDom = ({-# LINE 628 "GenerateCode.ag" #-} _lhsIunfoldSemDom {-# LINE 2297 "GenerateCode.hs" #-}) -- copy rule (down) _visitsOwith_sig = ({-# LINE 730 "GenerateCode.ag" #-} _lhsIwith_sig {-# LINE 2302 "GenerateCode.hs" #-}) ( _visitsIallTpsFound,_visitsIcomments,_visitsIdecls,_visitsIerrors,_visitsIgatherInstVisitNrs,_visitsIintra,_visitsIintraVars,_visitsIisNil,_visitsIsemNames) = (visits_ _visitsOallNts _visitsOallPragmas _visitsOaroundMap _visitsOchildren _visitsOcon _visitsOcontextMap _visitsOerrors _visitsOinh _visitsOinstVisitNrs _visitsOnr _visitsOnt _visitsOo_case _visitsOo_cata _visitsOo_costcentre _visitsOo_data _visitsOo_linePragmas _visitsOo_monadic _visitsOo_newtypes _visitsOo_pretty _visitsOo_rename _visitsOo_sem _visitsOo_sig _visitsOo_splitsems _visitsOo_strictwrap _visitsOo_traces _visitsOo_unbox _visitsOparamInstMap _visitsOparamMap _visitsOprefix _visitsOsyn _visitsOterminals _visitsOunfoldSemDom _visitsOwith_sig ) in ( _lhsOallTpsFound,_lhsOcataAlt,_lhsOcomments,_lhsOdataAlt,_lhsOdecls,_lhsOerrors,_lhsOsemNames))) ) -- CProductions ------------------------------------------------ {- visit 0: inherited attributes: allNts : Set NontermIdent allPragmas : PragmaMap aroundMap : Map ConstructorIdent (Set Identifier) contextMap : ContextMap inh : Attributes nt : NontermIdent o_case : Bool o_cata : Bool o_costcentre : Bool o_data : Maybe Bool o_linePragmas : Bool o_monadic : Bool o_newtypes : Bool o_pretty : Bool o_rename : Bool o_sem : Bool o_sig : Bool o_splitsems : Bool o_strictwrap : Bool o_traces : Bool o_unbox : Bool paramMap : ParamMap prefix : String syn : Attributes unfoldSemDom : NontermIdent -> Int -> [String] -> Code.Type with_sig : Bool chained attribute: errors : Seq Error synthesized attributes: allTpsFound : Bool cataAlts : Decls comments : [String] dataAlts : DataAlts decls : Decls semNames : [String] alternatives: alternative Cons: child hd : CProduction child tl : CProductions alternative Nil: -} -- cata sem_CProductions :: CProductions -> T_CProductions sem_CProductions list = (Prelude.foldr sem_CProductions_Cons sem_CProductions_Nil (Prelude.map sem_CProduction list) ) -- semantic domain newtype T_CProductions = T_CProductions ((Set NontermIdent) -> PragmaMap -> (Map ConstructorIdent (Set Identifier)) -> ContextMap -> (Seq Error) -> Attributes -> NontermIdent -> Bool -> Bool -> Bool -> (Maybe Bool) -> Bool -> Bool -> Bool -> Bool -> Bool -> Bool -> Bool -> Bool -> Bool -> Bool -> Bool -> ParamMap -> String -> Attributes -> (NontermIdent -> Int -> [String] -> Code.Type) -> Bool -> ( Bool,Decls,([String]),DataAlts,Decls,(Seq Error),([String]))) data Inh_CProductions = Inh_CProductions {allNts_Inh_CProductions :: !((Set NontermIdent)),allPragmas_Inh_CProductions :: !(PragmaMap),aroundMap_Inh_CProductions :: !((Map ConstructorIdent (Set Identifier))),contextMap_Inh_CProductions :: !(ContextMap),errors_Inh_CProductions :: !((Seq Error)),inh_Inh_CProductions :: !(Attributes),nt_Inh_CProductions :: !(NontermIdent),o_case_Inh_CProductions :: !(Bool),o_cata_Inh_CProductions :: !(Bool),o_costcentre_Inh_CProductions :: !(Bool),o_data_Inh_CProductions :: !((Maybe Bool)),o_linePragmas_Inh_CProductions :: !(Bool),o_monadic_Inh_CProductions :: !(Bool),o_newtypes_Inh_CProductions :: !(Bool),o_pretty_Inh_CProductions :: !(Bool),o_rename_Inh_CProductions :: !(Bool),o_sem_Inh_CProductions :: !(Bool),o_sig_Inh_CProductions :: !(Bool),o_splitsems_Inh_CProductions :: !(Bool),o_strictwrap_Inh_CProductions :: !(Bool),o_traces_Inh_CProductions :: !(Bool),o_unbox_Inh_CProductions :: !(Bool),paramMap_Inh_CProductions :: !(ParamMap),prefix_Inh_CProductions :: !(String),syn_Inh_CProductions :: !(Attributes),unfoldSemDom_Inh_CProductions :: !((NontermIdent -> Int -> [String] -> Code.Type)),with_sig_Inh_CProductions :: !(Bool)} data Syn_CProductions = Syn_CProductions {allTpsFound_Syn_CProductions :: !(Bool),cataAlts_Syn_CProductions :: !(Decls),comments_Syn_CProductions :: !(([String])),dataAlts_Syn_CProductions :: !(DataAlts),decls_Syn_CProductions :: !(Decls),errors_Syn_CProductions :: !((Seq Error)),semNames_Syn_CProductions :: !(([String]))} wrap_CProductions :: T_CProductions -> Inh_CProductions -> Syn_CProductions wrap_CProductions (T_CProductions sem ) (Inh_CProductions _lhsIallNts _lhsIallPragmas _lhsIaroundMap _lhsIcontextMap _lhsIerrors _lhsIinh _lhsInt _lhsIo_case _lhsIo_cata _lhsIo_costcentre _lhsIo_data _lhsIo_linePragmas _lhsIo_monadic _lhsIo_newtypes _lhsIo_pretty _lhsIo_rename _lhsIo_sem _lhsIo_sig _lhsIo_splitsems _lhsIo_strictwrap _lhsIo_traces _lhsIo_unbox _lhsIparamMap _lhsIprefix _lhsIsyn _lhsIunfoldSemDom _lhsIwith_sig ) = (let ( _lhsOallTpsFound,_lhsOcataAlts,_lhsOcomments,_lhsOdataAlts,_lhsOdecls,_lhsOerrors,_lhsOsemNames) = (sem _lhsIallNts _lhsIallPragmas _lhsIaroundMap _lhsIcontextMap _lhsIerrors _lhsIinh _lhsInt _lhsIo_case _lhsIo_cata _lhsIo_costcentre _lhsIo_data _lhsIo_linePragmas _lhsIo_monadic _lhsIo_newtypes _lhsIo_pretty _lhsIo_rename _lhsIo_sem _lhsIo_sig _lhsIo_splitsems _lhsIo_strictwrap _lhsIo_traces _lhsIo_unbox _lhsIparamMap _lhsIprefix _lhsIsyn _lhsIunfoldSemDom _lhsIwith_sig ) in (Syn_CProductions _lhsOallTpsFound _lhsOcataAlts _lhsOcomments _lhsOdataAlts _lhsOdecls _lhsOerrors _lhsOsemNames )) sem_CProductions_Cons :: T_CProduction -> T_CProductions -> T_CProductions sem_CProductions_Cons (T_CProduction hd_ ) (T_CProductions tl_ ) = (T_CProductions (\ _lhsIallNts _lhsIallPragmas _lhsIaroundMap _lhsIcontextMap _lhsIerrors _lhsIinh _lhsInt _lhsIo_case _lhsIo_cata _lhsIo_costcentre _lhsIo_data _lhsIo_linePragmas _lhsIo_monadic _lhsIo_newtypes _lhsIo_pretty _lhsIo_rename _lhsIo_sem _lhsIo_sig _lhsIo_splitsems _lhsIo_strictwrap _lhsIo_traces _lhsIo_unbox _lhsIparamMap _lhsIprefix _lhsIsyn _lhsIunfoldSemDom _lhsIwith_sig -> (let _lhsOdataAlts :: DataAlts _lhsOcataAlts :: Decls _lhsOallTpsFound :: Bool _lhsOcomments :: ([String]) _lhsOdecls :: Decls _lhsOerrors :: (Seq Error) _lhsOsemNames :: ([String]) _hdOallNts :: (Set NontermIdent) _hdOallPragmas :: PragmaMap _hdOaroundMap :: (Map ConstructorIdent (Set Identifier)) _hdOcontextMap :: ContextMap _hdOerrors :: (Seq Error) _hdOinh :: Attributes _hdOnt :: NontermIdent _hdOo_case :: Bool _hdOo_cata :: Bool _hdOo_costcentre :: Bool _hdOo_data :: (Maybe Bool) _hdOo_linePragmas :: Bool _hdOo_monadic :: Bool _hdOo_newtypes :: Bool _hdOo_pretty :: Bool _hdOo_rename :: Bool _hdOo_sem :: Bool _hdOo_sig :: Bool _hdOo_splitsems :: Bool _hdOo_strictwrap :: Bool _hdOo_traces :: Bool _hdOo_unbox :: Bool _hdOparamMap :: ParamMap _hdOprefix :: String _hdOsyn :: Attributes _hdOunfoldSemDom :: (NontermIdent -> Int -> [String] -> Code.Type) _hdOwith_sig :: Bool _tlOallNts :: (Set NontermIdent) _tlOallPragmas :: PragmaMap _tlOaroundMap :: (Map ConstructorIdent (Set Identifier)) _tlOcontextMap :: ContextMap _tlOerrors :: (Seq Error) _tlOinh :: Attributes _tlOnt :: NontermIdent _tlOo_case :: Bool _tlOo_cata :: Bool _tlOo_costcentre :: Bool _tlOo_data :: (Maybe Bool) _tlOo_linePragmas :: Bool _tlOo_monadic :: Bool _tlOo_newtypes :: Bool _tlOo_pretty :: Bool _tlOo_rename :: Bool _tlOo_sem :: Bool _tlOo_sig :: Bool _tlOo_splitsems :: Bool _tlOo_strictwrap :: Bool _tlOo_traces :: Bool _tlOo_unbox :: Bool _tlOparamMap :: ParamMap _tlOprefix :: String _tlOsyn :: Attributes _tlOunfoldSemDom :: (NontermIdent -> Int -> [String] -> Code.Type) _tlOwith_sig :: Bool _hdIallTpsFound :: Bool _hdIcataAlt :: Decl _hdIcomments :: ([String]) _hdIdataAlt :: DataAlt _hdIdecls :: Decls _hdIerrors :: (Seq Error) _hdIsemNames :: ([String]) _tlIallTpsFound :: Bool _tlIcataAlts :: Decls _tlIcomments :: ([String]) _tlIdataAlts :: DataAlts _tlIdecls :: Decls _tlIerrors :: (Seq Error) _tlIsemNames :: ([String]) -- "GenerateCode.ag"(line 895, column 17) _lhsOdataAlts = ({-# LINE 895 "GenerateCode.ag" #-} _hdIdataAlt : _tlIdataAlts {-# LINE 2504 "GenerateCode.hs" #-}) -- "GenerateCode.ag"(line 995, column 10) _lhsOcataAlts = ({-# LINE 995 "GenerateCode.ag" #-} _hdIcataAlt : _tlIcataAlts {-# LINE 2509 "GenerateCode.hs" #-}) -- use rule "GenerateCode.ag"(line 727, column 39) _lhsOallTpsFound = ({-# LINE 727 "GenerateCode.ag" #-} _hdIallTpsFound && _tlIallTpsFound {-# LINE 2514 "GenerateCode.hs" #-}) -- use rule "GenerateCode.ag"(line 759, column 52) _lhsOcomments = ({-# LINE 759 "GenerateCode.ag" #-} _hdIcomments ++ _tlIcomments {-# LINE 2519 "GenerateCode.hs" #-}) -- use rule "GenerateCode.ag"(line 802, column 44) _lhsOdecls = ({-# LINE 802 "GenerateCode.ag" #-} _hdIdecls ++ _tlIdecls {-# LINE 2524 "GenerateCode.hs" #-}) -- use rule "GenerateCode.ag"(line 740, column 32) _lhsOerrors = ({-# LINE 740 "GenerateCode.ag" #-} _hdIerrors Seq.>< _tlIerrors {-# LINE 2529 "GenerateCode.hs" #-}) -- use rule "GenerateCode.ag"(line 1015, column 61) _lhsOsemNames = ({-# LINE 1015 "GenerateCode.ag" #-} _hdIsemNames ++ _tlIsemNames {-# LINE 2534 "GenerateCode.hs" #-}) -- copy rule (down) _hdOallNts = ({-# LINE 121 "GenerateCode.ag" #-} _lhsIallNts {-# LINE 2539 "GenerateCode.hs" #-}) -- copy rule (down) _hdOallPragmas = ({-# LINE 67 "GenerateCode.ag" #-} _lhsIallPragmas {-# LINE 2544 "GenerateCode.hs" #-}) -- copy rule (down) _hdOaroundMap = ({-# LINE 487 "GenerateCode.ag" #-} _lhsIaroundMap {-# LINE 2549 "GenerateCode.hs" #-}) -- copy rule (down) _hdOcontextMap = ({-# LINE 109 "GenerateCode.ag" #-} _lhsIcontextMap {-# LINE 2554 "GenerateCode.hs" #-}) -- copy rule (down) _hdOerrors = ({-# LINE 740 "GenerateCode.ag" #-} _lhsIerrors {-# LINE 2559 "GenerateCode.hs" #-}) -- copy rule (down) _hdOinh = ({-# LINE 78 "GenerateCode.ag" #-} _lhsIinh {-# LINE 2564 "GenerateCode.hs" #-}) -- copy rule (down) _hdOnt = ({-# LINE 78 "GenerateCode.ag" #-} _lhsInt {-# LINE 2569 "GenerateCode.hs" #-}) -- copy rule (down) _hdOo_case = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_case {-# LINE 2574 "GenerateCode.hs" #-}) -- copy rule (down) _hdOo_cata = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_cata {-# LINE 2579 "GenerateCode.hs" #-}) -- copy rule (down) _hdOo_costcentre = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_costcentre {-# LINE 2584 "GenerateCode.hs" #-}) -- copy rule (down) _hdOo_data = ({-# LINE 46 "GenerateCode.ag" #-} _lhsIo_data {-# LINE 2589 "GenerateCode.hs" #-}) -- copy rule (down) _hdOo_linePragmas = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_linePragmas {-# LINE 2594 "GenerateCode.hs" #-}) -- copy rule (down) _hdOo_monadic = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_monadic {-# LINE 2599 "GenerateCode.hs" #-}) -- copy rule (down) _hdOo_newtypes = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_newtypes {-# LINE 2604 "GenerateCode.hs" #-}) -- copy rule (down) _hdOo_pretty = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_pretty {-# LINE 2609 "GenerateCode.hs" #-}) -- copy rule (down) _hdOo_rename = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_rename {-# LINE 2614 "GenerateCode.hs" #-}) -- copy rule (down) _hdOo_sem = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_sem {-# LINE 2619 "GenerateCode.hs" #-}) -- copy rule (down) _hdOo_sig = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_sig {-# LINE 2624 "GenerateCode.hs" #-}) -- copy rule (down) _hdOo_splitsems = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_splitsems {-# LINE 2629 "GenerateCode.hs" #-}) -- copy rule (down) _hdOo_strictwrap = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_strictwrap {-# LINE 2634 "GenerateCode.hs" #-}) -- copy rule (down) _hdOo_traces = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_traces {-# LINE 2639 "GenerateCode.hs" #-}) -- copy rule (down) _hdOo_unbox = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_unbox {-# LINE 2644 "GenerateCode.hs" #-}) -- copy rule (down) _hdOparamMap = ({-# LINE 89 "GenerateCode.ag" #-} _lhsIparamMap {-# LINE 2649 "GenerateCode.hs" #-}) -- copy rule (down) _hdOprefix = ({-# LINE 47 "GenerateCode.ag" #-} _lhsIprefix {-# LINE 2654 "GenerateCode.hs" #-}) -- copy rule (down) _hdOsyn = ({-# LINE 78 "GenerateCode.ag" #-} _lhsIsyn {-# LINE 2659 "GenerateCode.hs" #-}) -- copy rule (down) _hdOunfoldSemDom = ({-# LINE 628 "GenerateCode.ag" #-} _lhsIunfoldSemDom {-# LINE 2664 "GenerateCode.hs" #-}) -- copy rule (down) _hdOwith_sig = ({-# LINE 730 "GenerateCode.ag" #-} _lhsIwith_sig {-# LINE 2669 "GenerateCode.hs" #-}) -- copy rule (down) _tlOallNts = ({-# LINE 121 "GenerateCode.ag" #-} _lhsIallNts {-# LINE 2674 "GenerateCode.hs" #-}) -- copy rule (down) _tlOallPragmas = ({-# LINE 67 "GenerateCode.ag" #-} _lhsIallPragmas {-# LINE 2679 "GenerateCode.hs" #-}) -- copy rule (down) _tlOaroundMap = ({-# LINE 487 "GenerateCode.ag" #-} _lhsIaroundMap {-# LINE 2684 "GenerateCode.hs" #-}) -- copy rule (down) _tlOcontextMap = ({-# LINE 109 "GenerateCode.ag" #-} _lhsIcontextMap {-# LINE 2689 "GenerateCode.hs" #-}) -- copy rule (chain) _tlOerrors = ({-# LINE 740 "GenerateCode.ag" #-} _hdIerrors {-# LINE 2694 "GenerateCode.hs" #-}) -- copy rule (down) _tlOinh = ({-# LINE 78 "GenerateCode.ag" #-} _lhsIinh {-# LINE 2699 "GenerateCode.hs" #-}) -- copy rule (down) _tlOnt = ({-# LINE 78 "GenerateCode.ag" #-} _lhsInt {-# LINE 2704 "GenerateCode.hs" #-}) -- copy rule (down) _tlOo_case = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_case {-# LINE 2709 "GenerateCode.hs" #-}) -- copy rule (down) _tlOo_cata = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_cata {-# LINE 2714 "GenerateCode.hs" #-}) -- copy rule (down) _tlOo_costcentre = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_costcentre {-# LINE 2719 "GenerateCode.hs" #-}) -- copy rule (down) _tlOo_data = ({-# LINE 46 "GenerateCode.ag" #-} _lhsIo_data {-# LINE 2724 "GenerateCode.hs" #-}) -- copy rule (down) _tlOo_linePragmas = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_linePragmas {-# LINE 2729 "GenerateCode.hs" #-}) -- copy rule (down) _tlOo_monadic = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_monadic {-# LINE 2734 "GenerateCode.hs" #-}) -- copy rule (down) _tlOo_newtypes = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_newtypes {-# LINE 2739 "GenerateCode.hs" #-}) -- copy rule (down) _tlOo_pretty = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_pretty {-# LINE 2744 "GenerateCode.hs" #-}) -- copy rule (down) _tlOo_rename = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_rename {-# LINE 2749 "GenerateCode.hs" #-}) -- copy rule (down) _tlOo_sem = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_sem {-# LINE 2754 "GenerateCode.hs" #-}) -- copy rule (down) _tlOo_sig = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_sig {-# LINE 2759 "GenerateCode.hs" #-}) -- copy rule (down) _tlOo_splitsems = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_splitsems {-# LINE 2764 "GenerateCode.hs" #-}) -- copy rule (down) _tlOo_strictwrap = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_strictwrap {-# LINE 2769 "GenerateCode.hs" #-}) -- copy rule (down) _tlOo_traces = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_traces {-# LINE 2774 "GenerateCode.hs" #-}) -- copy rule (down) _tlOo_unbox = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_unbox {-# LINE 2779 "GenerateCode.hs" #-}) -- copy rule (down) _tlOparamMap = ({-# LINE 89 "GenerateCode.ag" #-} _lhsIparamMap {-# LINE 2784 "GenerateCode.hs" #-}) -- copy rule (down) _tlOprefix = ({-# LINE 47 "GenerateCode.ag" #-} _lhsIprefix {-# LINE 2789 "GenerateCode.hs" #-}) -- copy rule (down) _tlOsyn = ({-# LINE 78 "GenerateCode.ag" #-} _lhsIsyn {-# LINE 2794 "GenerateCode.hs" #-}) -- copy rule (down) _tlOunfoldSemDom = ({-# LINE 628 "GenerateCode.ag" #-} _lhsIunfoldSemDom {-# LINE 2799 "GenerateCode.hs" #-}) -- copy rule (down) _tlOwith_sig = ({-# LINE 730 "GenerateCode.ag" #-} _lhsIwith_sig {-# LINE 2804 "GenerateCode.hs" #-}) ( _hdIallTpsFound,_hdIcataAlt,_hdIcomments,_hdIdataAlt,_hdIdecls,_hdIerrors,_hdIsemNames) = (hd_ _hdOallNts _hdOallPragmas _hdOaroundMap _hdOcontextMap _hdOerrors _hdOinh _hdOnt _hdOo_case _hdOo_cata _hdOo_costcentre _hdOo_data _hdOo_linePragmas _hdOo_monadic _hdOo_newtypes _hdOo_pretty _hdOo_rename _hdOo_sem _hdOo_sig _hdOo_splitsems _hdOo_strictwrap _hdOo_traces _hdOo_unbox _hdOparamMap _hdOprefix _hdOsyn _hdOunfoldSemDom _hdOwith_sig ) ( _tlIallTpsFound,_tlIcataAlts,_tlIcomments,_tlIdataAlts,_tlIdecls,_tlIerrors,_tlIsemNames) = (tl_ _tlOallNts _tlOallPragmas _tlOaroundMap _tlOcontextMap _tlOerrors _tlOinh _tlOnt _tlOo_case _tlOo_cata _tlOo_costcentre _tlOo_data _tlOo_linePragmas _tlOo_monadic _tlOo_newtypes _tlOo_pretty _tlOo_rename _tlOo_sem _tlOo_sig _tlOo_splitsems _tlOo_strictwrap _tlOo_traces _tlOo_unbox _tlOparamMap _tlOprefix _tlOsyn _tlOunfoldSemDom _tlOwith_sig ) in ( _lhsOallTpsFound,_lhsOcataAlts,_lhsOcomments,_lhsOdataAlts,_lhsOdecls,_lhsOerrors,_lhsOsemNames))) ) sem_CProductions_Nil :: T_CProductions sem_CProductions_Nil = (T_CProductions (\ _lhsIallNts _lhsIallPragmas _lhsIaroundMap _lhsIcontextMap _lhsIerrors _lhsIinh _lhsInt _lhsIo_case _lhsIo_cata _lhsIo_costcentre _lhsIo_data _lhsIo_linePragmas _lhsIo_monadic _lhsIo_newtypes _lhsIo_pretty _lhsIo_rename _lhsIo_sem _lhsIo_sig _lhsIo_splitsems _lhsIo_strictwrap _lhsIo_traces _lhsIo_unbox _lhsIparamMap _lhsIprefix _lhsIsyn _lhsIunfoldSemDom _lhsIwith_sig -> (let _lhsOdataAlts :: DataAlts _lhsOcataAlts :: Decls _lhsOallTpsFound :: Bool _lhsOcomments :: ([String]) _lhsOdecls :: Decls _lhsOerrors :: (Seq Error) _lhsOsemNames :: ([String]) -- "GenerateCode.ag"(line 896, column 17) _lhsOdataAlts = ({-# LINE 896 "GenerateCode.ag" #-} [] {-# LINE 2850 "GenerateCode.hs" #-}) -- "GenerateCode.ag"(line 996, column 10) _lhsOcataAlts = ({-# LINE 996 "GenerateCode.ag" #-} [] {-# LINE 2855 "GenerateCode.hs" #-}) -- use rule "GenerateCode.ag"(line 727, column 39) _lhsOallTpsFound = ({-# LINE 727 "GenerateCode.ag" #-} True {-# LINE 2860 "GenerateCode.hs" #-}) -- use rule "GenerateCode.ag"(line 759, column 52) _lhsOcomments = ({-# LINE 759 "GenerateCode.ag" #-} [] {-# LINE 2865 "GenerateCode.hs" #-}) -- use rule "GenerateCode.ag"(line 802, column 44) _lhsOdecls = ({-# LINE 802 "GenerateCode.ag" #-} [] {-# LINE 2870 "GenerateCode.hs" #-}) -- use rule "GenerateCode.ag"(line 740, column 32) _lhsOerrors = ({-# LINE 740 "GenerateCode.ag" #-} Seq.empty {-# LINE 2875 "GenerateCode.hs" #-}) -- use rule "GenerateCode.ag"(line 1015, column 61) _lhsOsemNames = ({-# LINE 1015 "GenerateCode.ag" #-} [] {-# LINE 2880 "GenerateCode.hs" #-}) in ( _lhsOallTpsFound,_lhsOcataAlts,_lhsOcomments,_lhsOdataAlts,_lhsOdecls,_lhsOerrors,_lhsOsemNames))) ) -- CRule ------------------------------------------------------- {- visit 0: inherited attributes: allNts : Set NontermIdent aroundMap : Set Identifier children : [(Identifier,Type,Bool)] con : ConstructorIdent higherOrderChildren : [(Identifier,Type,Bool)] inh : Attributes instVisitNrs : Map Identifier Int nr : Int nt : NontermIdent o_case : Bool o_cata : Bool o_costcentre : Bool o_data : Maybe Bool o_linePragmas : Bool o_monadic : Bool o_newtypes : Bool o_pretty : Bool o_rename : Bool o_sem : Bool o_sig : Bool o_splitsems : Bool o_strictwrap : Bool o_traces : Bool o_unbox : Bool paramInstMap : Map Identifier (NontermIdent, [String]) paramMap : ParamMap prefix : String syn : Attributes terminals : [Identifier] unfoldSemDom : NontermIdent -> Int -> [String] -> Code.Type what : String chained attributes: declsAbove : [Decl] errors : Seq Error synthesized attributes: allTpsFound : Bool bldBlocksFun : DeclBlocks -> DeclBlocks comments : [String] decls : Decls definedInsts : [Identifier] exprs : Exprs tSigs : [Decl] tps : [Type] usedVars : Set String alternatives: alternative CChildVisit: child name : {Identifier} child nt : {NontermIdent} child nr : {Int} child inh : {Attributes} child syn : {Attributes} child isLast : {Bool} visit 0: local costCentreDescr : _ local addCostCentre : _ local decls : _ local isSuperfluousHigherOrderIntra : _ local names : _ local mkTp : _ local definedTps : _ local nextTp : _ local orgParams : _ local instParams : _ local replParamMap : _ local replace : _ local evalTp : _ alternative CRule: child name : {Identifier} child isIn : {Bool} child hasCode : {Bool} child nt : {NontermIdent} child con : {ConstructorIdent} child field : {Identifier} child childnt : {Maybe NontermIdent} child tp : {Maybe Type} child pattern : Pattern child rhs : {[String]} child defines : {Map Int (Identifier,Identifier,Maybe Type)} child owrt : {Bool} child origin : {String} child uses : {Set (Identifier, Identifier)} child explicit : {Bool} child mbNamed : {Maybe Identifier} visit 0: local instTypes : _ local originComment : _ local instDecls : _ local patDescr : _ local traceDescr : _ local addTrace : _ local costCentreDescr : _ local addCostCentre : _ local addLinePragma : _ local decls : _ local definedInsts : _ local rulename : _ local mkTp : _ local orgParams : _ local evalTp : _ local _tup3 : {([Type],Bool)} -} -- cata sem_CRule :: CRule -> T_CRule sem_CRule (CChildVisit _name _nt _nr _inh _syn _isLast ) = (sem_CRule_CChildVisit _name _nt _nr _inh _syn _isLast ) sem_CRule (CRule _name _isIn _hasCode _nt _con _field _childnt _tp _pattern _rhs _defines _owrt _origin _uses _explicit _mbNamed ) = (sem_CRule_CRule _name _isIn _hasCode _nt _con _field _childnt _tp (sem_Pattern _pattern ) _rhs _defines _owrt _origin _uses _explicit _mbNamed ) -- semantic domain newtype T_CRule = T_CRule ((Set NontermIdent) -> (Set Identifier) -> ([(Identifier,Type,Bool)]) -> ConstructorIdent -> ([Decl]) -> (Seq Error) -> ([(Identifier,Type,Bool)]) -> Attributes -> (Map Identifier Int) -> Int -> NontermIdent -> Bool -> Bool -> Bool -> (Maybe Bool) -> Bool -> Bool -> Bool -> Bool -> Bool -> Bool -> Bool -> Bool -> Bool -> Bool -> Bool -> (Map Identifier (NontermIdent, [String])) -> ParamMap -> String -> Attributes -> ([Identifier]) -> (NontermIdent -> Int -> [String] -> Code.Type) -> String -> ( Bool,(DeclBlocks -> DeclBlocks),([String]),Decls,([Decl]),([Identifier]),(Seq Error),Exprs,([Decl]),([Type]),(Set String))) data Inh_CRule = Inh_CRule {allNts_Inh_CRule :: !((Set NontermIdent)),aroundMap_Inh_CRule :: !((Set Identifier)),children_Inh_CRule :: !(([(Identifier,Type,Bool)])),con_Inh_CRule :: !(ConstructorIdent),declsAbove_Inh_CRule :: !(([Decl])),errors_Inh_CRule :: !((Seq Error)),higherOrderChildren_Inh_CRule :: !(([(Identifier,Type,Bool)])),inh_Inh_CRule :: !(Attributes),instVisitNrs_Inh_CRule :: !((Map Identifier Int)),nr_Inh_CRule :: !(Int),nt_Inh_CRule :: !(NontermIdent),o_case_Inh_CRule :: !(Bool),o_cata_Inh_CRule :: !(Bool),o_costcentre_Inh_CRule :: !(Bool),o_data_Inh_CRule :: !((Maybe Bool)),o_linePragmas_Inh_CRule :: !(Bool),o_monadic_Inh_CRule :: !(Bool),o_newtypes_Inh_CRule :: !(Bool),o_pretty_Inh_CRule :: !(Bool),o_rename_Inh_CRule :: !(Bool),o_sem_Inh_CRule :: !(Bool),o_sig_Inh_CRule :: !(Bool),o_splitsems_Inh_CRule :: !(Bool),o_strictwrap_Inh_CRule :: !(Bool),o_traces_Inh_CRule :: !(Bool),o_unbox_Inh_CRule :: !(Bool),paramInstMap_Inh_CRule :: !((Map Identifier (NontermIdent, [String]))),paramMap_Inh_CRule :: !(ParamMap),prefix_Inh_CRule :: !(String),syn_Inh_CRule :: !(Attributes),terminals_Inh_CRule :: !(([Identifier])),unfoldSemDom_Inh_CRule :: !((NontermIdent -> Int -> [String] -> Code.Type)),what_Inh_CRule :: !(String)} data Syn_CRule = Syn_CRule {allTpsFound_Syn_CRule :: !(Bool),bldBlocksFun_Syn_CRule :: !((DeclBlocks -> DeclBlocks)),comments_Syn_CRule :: !(([String])),decls_Syn_CRule :: !(Decls),declsAbove_Syn_CRule :: !(([Decl])),definedInsts_Syn_CRule :: !(([Identifier])),errors_Syn_CRule :: !((Seq Error)),exprs_Syn_CRule :: !(Exprs),tSigs_Syn_CRule :: !(([Decl])),tps_Syn_CRule :: !(([Type])),usedVars_Syn_CRule :: !((Set String))} wrap_CRule :: T_CRule -> Inh_CRule -> Syn_CRule wrap_CRule (T_CRule sem ) (Inh_CRule _lhsIallNts _lhsIaroundMap _lhsIchildren _lhsIcon _lhsIdeclsAbove _lhsIerrors _lhsIhigherOrderChildren _lhsIinh _lhsIinstVisitNrs _lhsInr _lhsInt _lhsIo_case _lhsIo_cata _lhsIo_costcentre _lhsIo_data _lhsIo_linePragmas _lhsIo_monadic _lhsIo_newtypes _lhsIo_pretty _lhsIo_rename _lhsIo_sem _lhsIo_sig _lhsIo_splitsems _lhsIo_strictwrap _lhsIo_traces _lhsIo_unbox _lhsIparamInstMap _lhsIparamMap _lhsIprefix _lhsIsyn _lhsIterminals _lhsIunfoldSemDom _lhsIwhat ) = (let ( _lhsOallTpsFound,_lhsObldBlocksFun,_lhsOcomments,_lhsOdecls,_lhsOdeclsAbove,_lhsOdefinedInsts,_lhsOerrors,_lhsOexprs,_lhsOtSigs,_lhsOtps,_lhsOusedVars) = (sem _lhsIallNts _lhsIaroundMap _lhsIchildren _lhsIcon _lhsIdeclsAbove _lhsIerrors _lhsIhigherOrderChildren _lhsIinh _lhsIinstVisitNrs _lhsInr _lhsInt _lhsIo_case _lhsIo_cata _lhsIo_costcentre _lhsIo_data _lhsIo_linePragmas _lhsIo_monadic _lhsIo_newtypes _lhsIo_pretty _lhsIo_rename _lhsIo_sem _lhsIo_sig _lhsIo_splitsems _lhsIo_strictwrap _lhsIo_traces _lhsIo_unbox _lhsIparamInstMap _lhsIparamMap _lhsIprefix _lhsIsyn _lhsIterminals _lhsIunfoldSemDom _lhsIwhat ) in (Syn_CRule _lhsOallTpsFound _lhsObldBlocksFun _lhsOcomments _lhsOdecls _lhsOdeclsAbove _lhsOdefinedInsts _lhsOerrors _lhsOexprs _lhsOtSigs _lhsOtps _lhsOusedVars )) sem_CRule_CChildVisit :: Identifier -> NontermIdent -> Int -> Attributes -> Attributes -> Bool -> T_CRule sem_CRule_CChildVisit name_ nt_ nr_ inh_ syn_ isLast_ = (T_CRule (\ _lhsIallNts _lhsIaroundMap _lhsIchildren _lhsIcon _lhsIdeclsAbove _lhsIerrors _lhsIhigherOrderChildren _lhsIinh _lhsIinstVisitNrs _lhsInr _lhsInt _lhsIo_case _lhsIo_cata _lhsIo_costcentre _lhsIo_data _lhsIo_linePragmas _lhsIo_monadic _lhsIo_newtypes _lhsIo_pretty _lhsIo_rename _lhsIo_sem _lhsIo_sig _lhsIo_splitsems _lhsIo_strictwrap _lhsIo_traces _lhsIo_unbox _lhsIparamInstMap _lhsIparamMap _lhsIprefix _lhsIsyn _lhsIterminals _lhsIunfoldSemDom _lhsIwhat -> (let _lhsOexprs :: Exprs _lhsOusedVars :: (Set String) _lhsOtSigs :: ([Decl]) _lhsOtps :: ([Type]) _lhsOdeclsAbove :: ([Decl]) _lhsObldBlocksFun :: (DeclBlocks -> DeclBlocks) _lhsOallTpsFound :: Bool _lhsOcomments :: ([String]) _lhsOdecls :: Decls _lhsOdefinedInsts :: ([Identifier]) _lhsOerrors :: (Seq Error) -- "GenerateCode.ag"(line 183, column 18) _costCentreDescr = ({-# LINE 183 "GenerateCode.ag" #-} show _lhsInt ++ ":" ++ show _lhsIcon ++ ":" ++ show name_ ++ ":" ++ show nt_ ++ ":" ++ show nr_ {-# LINE 3094 "GenerateCode.hs" #-}) -- "GenerateCode.ag"(line 184, column 18) _addCostCentre = ({-# LINE 184 "GenerateCode.ag" #-} \v -> if _lhsIo_costcentre then PragmaExpr True False ("SCC \"" ++ _costCentreDescr ++ "\"") v else v {-# LINE 3101 "GenerateCode.hs" #-}) -- "GenerateCode.ag"(line 187, column 18) _decls = ({-# LINE 187 "GenerateCode.ag" #-} let lhsVars = map (attrname True name_) (Map.keys syn_) ++ if isLast_ then [] else [unwrap ++ funname name_ (nr_+1)] rhsVars = map (attrname False name_) (Map.keys inh_) unwrap = if _lhsIo_newtypes then typeName nt_ (nr_ + 1) ++ " " else "" tuple = mkTupleLhs _lhsIo_unbox (null $ Map.keys inh_) lhsVars rhs = _addCostCentre $ App fun (map SimpleExpr rhsVars) fun | nr_ == 0 && Set.member name_ _lhsIaroundMap = locname name_ ++ "_around " ++ funname name_ 0 | otherwise = funname name_ nr_ in [mkDecl _lhsIo_monadic tuple rhs (Set.fromList lhsVars) (Set.fromList (funname name_ nr_ : rhsVars))] {-# LINE 3115 "GenerateCode.hs" #-}) -- "GenerateCode.ag"(line 278, column 7) _isSuperfluousHigherOrderIntra = ({-# LINE 278 "GenerateCode.ag" #-} _lhsInr <= Map.findWithDefault (-1) name_ _lhsIinstVisitNrs {-# LINE 3120 "GenerateCode.hs" #-}) -- "GenerateCode.ag"(line 292, column 8) _names = ({-# LINE 292 "GenerateCode.ag" #-} if _isSuperfluousHigherOrderIntra then [] else [funname name_ (nr_+1)] {-# LINE 3127 "GenerateCode.hs" #-}) -- "GenerateCode.ag"(line 296, column 8) _lhsOexprs = ({-# LINE 296 "GenerateCode.ag" #-} let wrap = if _lhsIo_newtypes then \x -> App (typeName nt_ (nr_ + 1)) [x] else id addType expr | null _instParams = expr | otherwise = TypedExpr expr (_lhsIunfoldSemDom nt_ (nr_+1) _instParams ) in map (wrap . addType . SimpleExpr) _names {-# LINE 3135 "GenerateCode.hs" #-}) -- "GenerateCode.ag"(line 308, column 7) _lhsOusedVars = ({-# LINE 308 "GenerateCode.ag" #-} Set.fromList _names {-# LINE 3140 "GenerateCode.hs" #-}) -- "GenerateCode.ag"(line 332, column 19) _mkTp = ({-# LINE 332 "GenerateCode.ag" #-} _evalTp . typeToCodeType (Just nt_) _orgParams {-# LINE 3145 "GenerateCode.hs" #-}) -- "GenerateCode.ag"(line 333, column 19) _definedTps = ({-# LINE 333 "GenerateCode.ag" #-} [ TSig (attrname True name_ a) (_mkTp tp) | (a,tp) <- Map.toList syn_ ] {-# LINE 3150 "GenerateCode.hs" #-}) -- "GenerateCode.ag"(line 334, column 19) _nextTp = ({-# LINE 334 "GenerateCode.ag" #-} typeName nt_ (nr_+1) {-# LINE 3155 "GenerateCode.hs" #-}) -- "GenerateCode.ag"(line 335, column 19) _lhsOtSigs = ({-# LINE 335 "GenerateCode.ag" #-} (if isLast_ then id else (TSig (funname name_ (nr_+1)) (TypeApp (SimpleType _nextTp) (map SimpleType _instParams )) :)) _definedTps {-# LINE 3160 "GenerateCode.hs" #-}) -- "GenerateCode.ag"(line 337, column 19) _orgParams = ({-# LINE 337 "GenerateCode.ag" #-} map getName $ Map.findWithDefault [] nt_ _lhsIparamMap {-# LINE 3165 "GenerateCode.hs" #-}) -- "GenerateCode.ag"(line 338, column 19) _instParams = ({-# LINE 338 "GenerateCode.ag" #-} snd $ Map.findWithDefault (nt_,[]) name_ _lhsIparamInstMap {-# LINE 3170 "GenerateCode.hs" #-}) -- "GenerateCode.ag"(line 339, column 19) _replParamMap = ({-# LINE 339 "GenerateCode.ag" #-} Map.fromList (zip _orgParams _instParams ) {-# LINE 3175 "GenerateCode.hs" #-}) -- "GenerateCode.ag"(line 340, column 19) _replace = ({-# LINE 340 "GenerateCode.ag" #-} \k -> Map.findWithDefault k k _replParamMap {-# LINE 3180 "GenerateCode.hs" #-}) -- "GenerateCode.ag"(line 341, column 19) _evalTp = ({-# LINE 341 "GenerateCode.ag" #-} if null _orgParams then id else evalType _replace {-# LINE 3185 "GenerateCode.hs" #-}) -- "GenerateCode.ag"(line 364, column 19) _lhsOtps = ({-# LINE 364 "GenerateCode.ag" #-} if _isSuperfluousHigherOrderIntra then [] else [NT (ntOfVisit nt_ (nr_+1)) _instParams ] {-# LINE 3192 "GenerateCode.hs" #-}) -- "GenerateCode.ag"(line 511, column 7) _lhsOdeclsAbove = ({-# LINE 511 "GenerateCode.ag" #-} [] {-# LINE 3197 "GenerateCode.hs" #-}) -- "GenerateCode.ag"(line 524, column 7) _lhsObldBlocksFun = ({-# LINE 524 "GenerateCode.ag" #-} DeclBlock _lhsIdeclsAbove (head _decls ) {-# LINE 3202 "GenerateCode.hs" #-}) -- use rule "GenerateCode.ag"(line 361, column 39) _lhsOallTpsFound = ({-# LINE 361 "GenerateCode.ag" #-} True {-# LINE 3207 "GenerateCode.hs" #-}) -- use rule "GenerateCode.ag"(line 759, column 52) _lhsOcomments = ({-# LINE 759 "GenerateCode.ag" #-} [] {-# LINE 3212 "GenerateCode.hs" #-}) -- use rule "GenerateCode.ag"(line 139, column 34) _lhsOdecls = ({-# LINE 139 "GenerateCode.ag" #-} _decls {-# LINE 3217 "GenerateCode.hs" #-}) -- use rule "GenerateCode.ag"(line 212, column 55) _lhsOdefinedInsts = ({-# LINE 212 "GenerateCode.ag" #-} [] {-# LINE 3222 "GenerateCode.hs" #-}) -- use rule "GenerateCode.ag"(line 740, column 32) _lhsOerrors = ({-# LINE 740 "GenerateCode.ag" #-} Seq.empty {-# LINE 3227 "GenerateCode.hs" #-}) in ( _lhsOallTpsFound,_lhsObldBlocksFun,_lhsOcomments,_lhsOdecls,_lhsOdeclsAbove,_lhsOdefinedInsts,_lhsOerrors,_lhsOexprs,_lhsOtSigs,_lhsOtps,_lhsOusedVars))) ) sem_CRule_CRule :: Identifier -> Bool -> Bool -> NontermIdent -> ConstructorIdent -> Identifier -> (Maybe NontermIdent) -> (Maybe Type) -> T_Pattern -> ([String]) -> (Map Int (Identifier,Identifier,Maybe Type)) -> Bool -> String -> (Set (Identifier, Identifier)) -> Bool -> (Maybe Identifier) -> T_CRule sem_CRule_CRule name_ isIn_ hasCode_ nt_ con_ field_ childnt_ tp_ (T_Pattern pattern_ ) rhs_ defines_ owrt_ origin_ uses_ explicit_ mbNamed_ = (T_CRule (\ _lhsIallNts _lhsIaroundMap _lhsIchildren _lhsIcon _lhsIdeclsAbove _lhsIerrors _lhsIhigherOrderChildren _lhsIinh _lhsIinstVisitNrs _lhsInr _lhsInt _lhsIo_case _lhsIo_cata _lhsIo_costcentre _lhsIo_data _lhsIo_linePragmas _lhsIo_monadic _lhsIo_newtypes _lhsIo_pretty _lhsIo_rename _lhsIo_sem _lhsIo_sig _lhsIo_splitsems _lhsIo_strictwrap _lhsIo_traces _lhsIo_unbox _lhsIparamInstMap _lhsIparamMap _lhsIprefix _lhsIsyn _lhsIterminals _lhsIunfoldSemDom _lhsIwhat -> (let _lhsOexprs :: Exprs _lhsOusedVars :: (Set String) _lhsOtSigs :: ([Decl]) __tup3 :: (([Type],Bool)) _lhsOtps :: ([Type]) _lhsOallTpsFound :: Bool _lhsOdeclsAbove :: ([Decl]) _lhsObldBlocksFun :: (DeclBlocks -> DeclBlocks) _lhsOerrors :: (Seq Error) _lhsOcomments :: ([String]) _lhsOdecls :: Decls _lhsOdefinedInsts :: ([Identifier]) _patternIcopy :: Pattern _patternIdefinedInsts :: ([Identifier]) _patternIpatternAttributes :: ([(Identifier, Identifier)]) -- "GenerateCode.ag"(line 141, column 12) _instTypes = ({-# LINE 141 "GenerateCode.ag" #-} map (\(n,NT t _,_) -> (n,t)) _lhsIhigherOrderChildren {-# LINE 3299 "GenerateCode.hs" #-}) -- "GenerateCode.ag"(line 142, column 12) _originComment = ({-# LINE 142 "GenerateCode.ag" #-} if _lhsIo_pretty then (Comment origin_:) else id {-# LINE 3306 "GenerateCode.hs" #-}) -- "GenerateCode.ag"(line 145, column 12) _instDecls = ({-# LINE 145 "GenerateCode.ag" #-} [ mkDecl _lhsIo_monadic (Pattern3 (Alias _INST' inst (Underscore (getPos inst)) [])) ( let nm = fromJust $ inst `lookup` _instTypes in unwrapSem _lhsIo_newtypes (maybe nm id (deforestedNt nm)) $ case nm `Set.member` _lhsIallNts of True -> App (cataname _lhsIprefix nm) [SimpleExpr instLocFieldName] False -> SimpleExpr instLocFieldName ) (Set.singleton instSemFieldName) (Set.singleton instLocFieldName) | inst <- _definedInsts , let instLocFieldName = attrname True _INST inst , let instSemFieldName = attrname False _INST' inst ] {-# LINE 3323 "GenerateCode.hs" #-}) -- "GenerateCode.ag"(line 158, column 12) _patDescr = ({-# LINE 158 "GenerateCode.ag" #-} if isIn_ then "_" else concat $ intersperse "," (map (\(f,a) -> show f ++ "." ++ show a) _patternIpatternAttributes) {-# LINE 3330 "GenerateCode.hs" #-}) -- "GenerateCode.ag"(line 161, column 12) _traceDescr = ({-# LINE 161 "GenerateCode.ag" #-} (maybe "" (\nm -> show nm ++ ":") mbNamed_) ++ show nt_ ++ " :: " ++ show con_ ++ " :: " ++ _patDescr {-# LINE 3335 "GenerateCode.hs" #-}) -- "GenerateCode.ag"(line 163, column 12) _addTrace = ({-# LINE 163 "GenerateCode.ag" #-} \v -> if _lhsIo_traces then Trace _traceDescr v else v {-# LINE 3342 "GenerateCode.hs" #-}) -- "GenerateCode.ag"(line 166, column 12) _costCentreDescr = ({-# LINE 166 "GenerateCode.ag" #-} show nt_ ++ ":" ++ show con_ ++ ":" ++ _patDescr {-# LINE 3347 "GenerateCode.hs" #-}) -- "GenerateCode.ag"(line 167, column 12) _addCostCentre = ({-# LINE 167 "GenerateCode.ag" #-} \v -> if _lhsIo_costcentre then PragmaExpr True False ("SCC \"" ++ _costCentreDescr ++ "\"") v else v {-# LINE 3354 "GenerateCode.hs" #-}) -- "GenerateCode.ag"(line 170, column 12) _addLinePragma = ({-# LINE 170 "GenerateCode.ag" #-} \v -> let p = getPos name_ hasPos = line p > 0 && column p >= 0 && not (null (file p)) in if _lhsIo_linePragmas && hasPos then PragmaExpr True True ("LINE " ++ show (line p) ++ " " ++ show (file p)) $ LineExpr $ v else v {-# LINE 3365 "GenerateCode.hs" #-}) -- "GenerateCode.ag"(line 177, column 12) _decls = ({-# LINE 177 "GenerateCode.ag" #-} if hasCode_ then _originComment ( mkDecl (_lhsIo_monadic && explicit_) (Pattern3 _patternIcopy) (_addTrace $ _addCostCentre $ _addLinePragma $ (TextExpr rhs_)) (Set.fromList [attrname False fld nm | (fld,nm,_) <- Map.elems defines_]) (Set.fromList [attrname True fld nm | (fld,nm) <- Set.toList uses_]) : _instDecls ) else _instDecls {-# LINE 3375 "GenerateCode.hs" #-}) -- "GenerateCode.ag"(line 217, column 12) _definedInsts = ({-# LINE 217 "GenerateCode.ag" #-} if isIn_ then [] else _patternIdefinedInsts {-# LINE 3380 "GenerateCode.hs" #-}) -- "GenerateCode.ag"(line 287, column 12) _rulename = ({-# LINE 287 "GenerateCode.ag" #-} if field_ == _LOC && name_ `elem` _lhsIterminals then funname name_ 0 else attrname isIn_ field_ name_ {-# LINE 3387 "GenerateCode.hs" #-}) -- "GenerateCode.ag"(line 290, column 12) _lhsOexprs = ({-# LINE 290 "GenerateCode.ag" #-} [SimpleExpr _rulename ] {-# LINE 3392 "GenerateCode.hs" #-}) -- "GenerateCode.ag"(line 306, column 7) _lhsOusedVars = ({-# LINE 306 "GenerateCode.ag" #-} Set.singleton _rulename {-# LINE 3397 "GenerateCode.hs" #-}) -- "GenerateCode.ag"(line 316, column 19) _mkTp = ({-# LINE 316 "GenerateCode.ag" #-} typeToCodeType (Just _lhsInt) _orgParams {-# LINE 3402 "GenerateCode.hs" #-}) -- "GenerateCode.ag"(line 317, column 19) _lhsOtSigs = ({-# LINE 317 "GenerateCode.ag" #-} [ TSig (attrname False field attr) (_evalTp field $ _mkTp (fromJust tp)) | (field,attr,tp) <- Map.elems defines_, isJust tp ] {-# LINE 3408 "GenerateCode.hs" #-}) -- "GenerateCode.ag"(line 320, column 19) _orgParams = ({-# LINE 320 "GenerateCode.ag" #-} map getName $ Map.findWithDefault [] _lhsInt _lhsIparamMap {-# LINE 3413 "GenerateCode.hs" #-}) -- "GenerateCode.ag"(line 321, column 19) _evalTp = ({-# LINE 321 "GenerateCode.ag" #-} \field tp -> let orgFldParams = map getName $ Map.findWithDefault [] childNt _lhsIparamMap (childNt,instParams) = Map.findWithDefault (_lhsInt,[]) field _lhsIparamInstMap replMap = Map.fromList (zip orgFldParams instParams) replace k = Map.findWithDefault ('@':k) k replMap in if null instParams then if null _orgParams then tp else idEvalType tp else evalType replace tp {-# LINE 3426 "GenerateCode.hs" #-}) -- "GenerateCode.ag"(line 363, column 23) __tup3 = ({-# LINE 363 "GenerateCode.ag" #-} maybe ([],False) (\tp -> ([substSelf (fromJust childnt_) tp],True)) tp_ {-# LINE 3431 "GenerateCode.hs" #-}) -- "GenerateCode.ag"(line 363, column 23) (_lhsOtps,_) = ({-# LINE 363 "GenerateCode.ag" #-} __tup3 {-# LINE 3436 "GenerateCode.hs" #-}) -- "GenerateCode.ag"(line 363, column 23) (_,_lhsOallTpsFound) = ({-# LINE 363 "GenerateCode.ag" #-} __tup3 {-# LINE 3441 "GenerateCode.hs" #-}) -- "GenerateCode.ag"(line 509, column 7) _lhsOdeclsAbove = ({-# LINE 509 "GenerateCode.ag" #-} _lhsIdeclsAbove ++ _decls {-# LINE 3446 "GenerateCode.hs" #-}) -- "GenerateCode.ag"(line 522, column 7) _lhsObldBlocksFun = ({-# LINE 522 "GenerateCode.ag" #-} id {-# LINE 3451 "GenerateCode.hs" #-}) -- "GenerateCode.ag"(line 746, column 12) _lhsOerrors = ({-# LINE 746 "GenerateCode.ag" #-} let nameOf (Alias _ _ _ pats@(_:_)) = Ident (show (map (\(Alias _ a _ _)->a) pats)) (getPos name_) nameOf _ = name_ in maybe (Seq.singleton (MissingTypeSig _lhsInt _lhsIcon (nameOf _patternIcopy))) (const Seq.empty) tp_ {-# LINE 3458 "GenerateCode.hs" #-}) -- "GenerateCode.ag"(line 786, column 18) _lhsOcomments = ({-# LINE 786 "GenerateCode.ag" #-} [ makeLocalComment 11 _lhsIwhat name tp | (field,name,tp) <- Map.elems defines_, field == _LOC ] ++ [ makeLocalComment 11 "inst " name tp | (field,name,tp) <- Map.elems defines_, field == _INST ] {-# LINE 3464 "GenerateCode.hs" #-}) -- use rule "GenerateCode.ag"(line 139, column 34) _lhsOdecls = ({-# LINE 139 "GenerateCode.ag" #-} _decls {-# LINE 3469 "GenerateCode.hs" #-}) -- use rule "GenerateCode.ag"(line 212, column 55) _lhsOdefinedInsts = ({-# LINE 212 "GenerateCode.ag" #-} _definedInsts {-# LINE 3474 "GenerateCode.hs" #-}) ( _patternIcopy,_patternIdefinedInsts,_patternIpatternAttributes) = (pattern_ ) in ( _lhsOallTpsFound,_lhsObldBlocksFun,_lhsOcomments,_lhsOdecls,_lhsOdeclsAbove,_lhsOdefinedInsts,_lhsOerrors,_lhsOexprs,_lhsOtSigs,_lhsOtps,_lhsOusedVars))) ) -- CSegment ---------------------------------------------------- {- visit 0: inherited attributes: inh : Attributes isLast : Bool nr : Int nt : NontermIdent o_case : Bool o_cata : Bool o_costcentre : Bool o_data : Maybe Bool o_linePragmas : Bool o_monadic : Bool o_newtypes : Bool o_pretty : Bool o_rename : Bool o_sem : Bool o_sig : Bool o_splitsems : Bool o_strictwrap : Bool o_traces : Bool o_unbox : Bool paramMap : ParamMap prefix : String syn : Attributes synthesized attributes: comments : [String] semDom : [Decl] semDomUnfoldGath : Map (NontermIdent, Int) ([String], Code.Type) wrapDecls : Decls alternatives: alternative CSegment: child inh : {Attributes} child syn : {Attributes} visit 0: local tp : _ local inhTps : _ local synTps : _ local continuation : _ local params : _ -} -- cata sem_CSegment :: CSegment -> T_CSegment sem_CSegment (CSegment _inh _syn ) = (sem_CSegment_CSegment _inh _syn ) -- semantic domain newtype T_CSegment = T_CSegment (Attributes -> Bool -> Int -> NontermIdent -> Bool -> Bool -> Bool -> (Maybe Bool) -> Bool -> Bool -> Bool -> Bool -> Bool -> Bool -> Bool -> Bool -> Bool -> Bool -> Bool -> ParamMap -> String -> Attributes -> ( ([String]),([Decl]),(Map (NontermIdent, Int) ([String], Code.Type)),Decls)) data Inh_CSegment = Inh_CSegment {inh_Inh_CSegment :: !(Attributes),isLast_Inh_CSegment :: !(Bool),nr_Inh_CSegment :: !(Int),nt_Inh_CSegment :: !(NontermIdent),o_case_Inh_CSegment :: !(Bool),o_cata_Inh_CSegment :: !(Bool),o_costcentre_Inh_CSegment :: !(Bool),o_data_Inh_CSegment :: !((Maybe Bool)),o_linePragmas_Inh_CSegment :: !(Bool),o_monadic_Inh_CSegment :: !(Bool),o_newtypes_Inh_CSegment :: !(Bool),o_pretty_Inh_CSegment :: !(Bool),o_rename_Inh_CSegment :: !(Bool),o_sem_Inh_CSegment :: !(Bool),o_sig_Inh_CSegment :: !(Bool),o_splitsems_Inh_CSegment :: !(Bool),o_strictwrap_Inh_CSegment :: !(Bool),o_traces_Inh_CSegment :: !(Bool),o_unbox_Inh_CSegment :: !(Bool),paramMap_Inh_CSegment :: !(ParamMap),prefix_Inh_CSegment :: !(String),syn_Inh_CSegment :: !(Attributes)} data Syn_CSegment = Syn_CSegment {comments_Syn_CSegment :: !(([String])),semDom_Syn_CSegment :: !(([Decl])),semDomUnfoldGath_Syn_CSegment :: !((Map (NontermIdent, Int) ([String], Code.Type))),wrapDecls_Syn_CSegment :: !(Decls)} wrap_CSegment :: T_CSegment -> Inh_CSegment -> Syn_CSegment wrap_CSegment (T_CSegment sem ) (Inh_CSegment _lhsIinh _lhsIisLast _lhsInr _lhsInt _lhsIo_case _lhsIo_cata _lhsIo_costcentre _lhsIo_data _lhsIo_linePragmas _lhsIo_monadic _lhsIo_newtypes _lhsIo_pretty _lhsIo_rename _lhsIo_sem _lhsIo_sig _lhsIo_splitsems _lhsIo_strictwrap _lhsIo_traces _lhsIo_unbox _lhsIparamMap _lhsIprefix _lhsIsyn ) = (let ( _lhsOcomments,_lhsOsemDom,_lhsOsemDomUnfoldGath,_lhsOwrapDecls) = (sem _lhsIinh _lhsIisLast _lhsInr _lhsInt _lhsIo_case _lhsIo_cata _lhsIo_costcentre _lhsIo_data _lhsIo_linePragmas _lhsIo_monadic _lhsIo_newtypes _lhsIo_pretty _lhsIo_rename _lhsIo_sem _lhsIo_sig _lhsIo_splitsems _lhsIo_strictwrap _lhsIo_traces _lhsIo_unbox _lhsIparamMap _lhsIprefix _lhsIsyn ) in (Syn_CSegment _lhsOcomments _lhsOsemDom _lhsOsemDomUnfoldGath _lhsOwrapDecls )) sem_CSegment_CSegment :: Attributes -> Attributes -> T_CSegment sem_CSegment_CSegment inh_ syn_ = (T_CSegment (\ _lhsIinh _lhsIisLast _lhsInr _lhsInt _lhsIo_case _lhsIo_cata _lhsIo_costcentre _lhsIo_data _lhsIo_linePragmas _lhsIo_monadic _lhsIo_newtypes _lhsIo_pretty _lhsIo_rename _lhsIo_sem _lhsIo_sig _lhsIo_splitsems _lhsIo_strictwrap _lhsIo_traces _lhsIo_unbox _lhsIparamMap _lhsIprefix _lhsIsyn -> (let _lhsOsemDom :: ([Decl]) _lhsOsemDomUnfoldGath :: (Map (NontermIdent, Int) ([String], Code.Type)) _lhsOwrapDecls :: Decls _lhsOcomments :: ([String]) -- "GenerateCode.ag"(line 608, column 15) _tp = ({-# LINE 608 "GenerateCode.ag" #-} foldr Arr _synTps _inhTps {-# LINE 3592 "GenerateCode.hs" #-}) -- "GenerateCode.ag"(line 609, column 15) _inhTps = ({-# LINE 609 "GenerateCode.ag" #-} [typeToCodeType (Just _lhsInt) _params tp | tp <- Map.elems inh_] {-# LINE 3597 "GenerateCode.hs" #-}) -- "GenerateCode.ag"(line 610, column 15) _synTps = ({-# LINE 610 "GenerateCode.ag" #-} mkTupleType _lhsIo_unbox (null _inhTps ) ([typeToCodeType (Just _lhsInt) _params tp | tp <- Map.elems syn_] ++ _continuation ) {-# LINE 3602 "GenerateCode.hs" #-}) -- "GenerateCode.ag"(line 611, column 15) _continuation = ({-# LINE 611 "GenerateCode.ag" #-} if _lhsIisLast then [] else [TypeApp (SimpleType (typeName _lhsInt (_lhsInr + 1))) (map (SimpleType . ('@':)) _params )] {-# LINE 3609 "GenerateCode.hs" #-}) -- "GenerateCode.ag"(line 614, column 15) _params = ({-# LINE 614 "GenerateCode.ag" #-} map getName $ Map.findWithDefault [] _lhsInt _lhsIparamMap {-# LINE 3614 "GenerateCode.hs" #-}) -- "GenerateCode.ag"(line 615, column 15) _lhsOsemDom = ({-# LINE 615 "GenerateCode.ag" #-} let name = typeName _lhsInt _lhsInr evalTp | null _params = id | otherwise = idEvalType in if _lhsIo_newtypes then [ Code.NewType name _params name (evalTp _tp ) ] else [ Code.Type name _params (evalTp _tp ) ] {-# LINE 3624 "GenerateCode.hs" #-}) -- "GenerateCode.ag"(line 626, column 7) _lhsOsemDomUnfoldGath = ({-# LINE 626 "GenerateCode.ag" #-} Map.singleton (_lhsInt, _lhsInr) (_params , _tp ) {-# LINE 3629 "GenerateCode.hs" #-}) -- "GenerateCode.ag"(line 710, column 15) _lhsOwrapDecls = ({-# LINE 710 "GenerateCode.ag" #-} let lhsVars = map (lhsname False) (Map.keys syn_) ++ if _lhsIisLast then [] else [unwrap ++ sem (_lhsInr+1)] rhsVars = map (lhsname True) (Map.keys inh_) rhs = map SimpleExpr rhsVars unwrap = if _lhsIo_newtypes then typeName _lhsInt (_lhsInr + 1) ++ " " else "" var = "sem" sem 0 = var sem n = var ++ "_" ++ show n in [ Decl (mkTupleLhs _lhsIo_unbox (null $ Map.keys inh_) lhsVars) (App (sem _lhsInr) rhs) (Set.fromList lhsVars) (Set.fromList rhsVars) ] {-# LINE 3642 "GenerateCode.hs" #-}) -- "GenerateCode.ag"(line 764, column 18) _lhsOcomments = ({-# LINE 764 "GenerateCode.ag" #-} let body = map ind (showsSegment (CSegment inh_ syn_)) in if null body then [] else ("visit " ++ show _lhsInr ++ ":") : body {-# LINE 3650 "GenerateCode.hs" #-}) in ( _lhsOcomments,_lhsOsemDom,_lhsOsemDomUnfoldGath,_lhsOwrapDecls))) ) -- CSegments --------------------------------------------------- {- visit 0: inherited attributes: inh : Attributes nr : Int nt : NontermIdent o_case : Bool o_cata : Bool o_costcentre : Bool o_data : Maybe Bool o_linePragmas : Bool o_monadic : Bool o_newtypes : Bool o_pretty : Bool o_rename : Bool o_sem : Bool o_sig : Bool o_splitsems : Bool o_strictwrap : Bool o_traces : Bool o_unbox : Bool paramMap : ParamMap prefix : String syn : Attributes synthesized attributes: comments : [String] isNil : Bool semDom : [Decl] semDomUnfoldGath : Map (NontermIdent, Int) ([String], Code.Type) wrapDecls : Decls alternatives: alternative Cons: child hd : CSegment child tl : CSegments alternative Nil: -} -- cata sem_CSegments :: CSegments -> T_CSegments sem_CSegments list = (Prelude.foldr sem_CSegments_Cons sem_CSegments_Nil (Prelude.map sem_CSegment list) ) -- semantic domain newtype T_CSegments = T_CSegments (Attributes -> Int -> NontermIdent -> Bool -> Bool -> Bool -> (Maybe Bool) -> Bool -> Bool -> Bool -> Bool -> Bool -> Bool -> Bool -> Bool -> Bool -> Bool -> Bool -> ParamMap -> String -> Attributes -> ( ([String]),Bool,([Decl]),(Map (NontermIdent, Int) ([String], Code.Type)),Decls)) data Inh_CSegments = Inh_CSegments {inh_Inh_CSegments :: !(Attributes),nr_Inh_CSegments :: !(Int),nt_Inh_CSegments :: !(NontermIdent),o_case_Inh_CSegments :: !(Bool),o_cata_Inh_CSegments :: !(Bool),o_costcentre_Inh_CSegments :: !(Bool),o_data_Inh_CSegments :: !((Maybe Bool)),o_linePragmas_Inh_CSegments :: !(Bool),o_monadic_Inh_CSegments :: !(Bool),o_newtypes_Inh_CSegments :: !(Bool),o_pretty_Inh_CSegments :: !(Bool),o_rename_Inh_CSegments :: !(Bool),o_sem_Inh_CSegments :: !(Bool),o_sig_Inh_CSegments :: !(Bool),o_splitsems_Inh_CSegments :: !(Bool),o_strictwrap_Inh_CSegments :: !(Bool),o_traces_Inh_CSegments :: !(Bool),o_unbox_Inh_CSegments :: !(Bool),paramMap_Inh_CSegments :: !(ParamMap),prefix_Inh_CSegments :: !(String),syn_Inh_CSegments :: !(Attributes)} data Syn_CSegments = Syn_CSegments {comments_Syn_CSegments :: !(([String])),isNil_Syn_CSegments :: !(Bool),semDom_Syn_CSegments :: !(([Decl])),semDomUnfoldGath_Syn_CSegments :: !((Map (NontermIdent, Int) ([String], Code.Type))),wrapDecls_Syn_CSegments :: !(Decls)} wrap_CSegments :: T_CSegments -> Inh_CSegments -> Syn_CSegments wrap_CSegments (T_CSegments sem ) (Inh_CSegments _lhsIinh _lhsInr _lhsInt _lhsIo_case _lhsIo_cata _lhsIo_costcentre _lhsIo_data _lhsIo_linePragmas _lhsIo_monadic _lhsIo_newtypes _lhsIo_pretty _lhsIo_rename _lhsIo_sem _lhsIo_sig _lhsIo_splitsems _lhsIo_strictwrap _lhsIo_traces _lhsIo_unbox _lhsIparamMap _lhsIprefix _lhsIsyn ) = (let ( _lhsOcomments,_lhsOisNil,_lhsOsemDom,_lhsOsemDomUnfoldGath,_lhsOwrapDecls) = (sem _lhsIinh _lhsInr _lhsInt _lhsIo_case _lhsIo_cata _lhsIo_costcentre _lhsIo_data _lhsIo_linePragmas _lhsIo_monadic _lhsIo_newtypes _lhsIo_pretty _lhsIo_rename _lhsIo_sem _lhsIo_sig _lhsIo_splitsems _lhsIo_strictwrap _lhsIo_traces _lhsIo_unbox _lhsIparamMap _lhsIprefix _lhsIsyn ) in (Syn_CSegments _lhsOcomments _lhsOisNil _lhsOsemDom _lhsOsemDomUnfoldGath _lhsOwrapDecls )) sem_CSegments_Cons :: T_CSegment -> T_CSegments -> T_CSegments sem_CSegments_Cons (T_CSegment hd_ ) (T_CSegments tl_ ) = (T_CSegments (\ _lhsIinh _lhsInr _lhsInt _lhsIo_case _lhsIo_cata _lhsIo_costcentre _lhsIo_data _lhsIo_linePragmas _lhsIo_monadic _lhsIo_newtypes _lhsIo_pretty _lhsIo_rename _lhsIo_sem _lhsIo_sig _lhsIo_splitsems _lhsIo_strictwrap _lhsIo_traces _lhsIo_unbox _lhsIparamMap _lhsIprefix _lhsIsyn -> (let _tlOnr :: Int _lhsOisNil :: Bool _hdOisLast :: Bool _lhsOcomments :: ([String]) _lhsOsemDom :: ([Decl]) _lhsOsemDomUnfoldGath :: (Map (NontermIdent, Int) ([String], Code.Type)) _lhsOwrapDecls :: Decls _hdOinh :: Attributes _hdOnr :: Int _hdOnt :: NontermIdent _hdOo_case :: Bool _hdOo_cata :: Bool _hdOo_costcentre :: Bool _hdOo_data :: (Maybe Bool) _hdOo_linePragmas :: Bool _hdOo_monadic :: Bool _hdOo_newtypes :: Bool _hdOo_pretty :: Bool _hdOo_rename :: Bool _hdOo_sem :: Bool _hdOo_sig :: Bool _hdOo_splitsems :: Bool _hdOo_strictwrap :: Bool _hdOo_traces :: Bool _hdOo_unbox :: Bool _hdOparamMap :: ParamMap _hdOprefix :: String _hdOsyn :: Attributes _tlOinh :: Attributes _tlOnt :: NontermIdent _tlOo_case :: Bool _tlOo_cata :: Bool _tlOo_costcentre :: Bool _tlOo_data :: (Maybe Bool) _tlOo_linePragmas :: Bool _tlOo_monadic :: Bool _tlOo_newtypes :: Bool _tlOo_pretty :: Bool _tlOo_rename :: Bool _tlOo_sem :: Bool _tlOo_sig :: Bool _tlOo_splitsems :: Bool _tlOo_strictwrap :: Bool _tlOo_traces :: Bool _tlOo_unbox :: Bool _tlOparamMap :: ParamMap _tlOprefix :: String _tlOsyn :: Attributes _hdIcomments :: ([String]) _hdIsemDom :: ([Decl]) _hdIsemDomUnfoldGath :: (Map (NontermIdent, Int) ([String], Code.Type)) _hdIwrapDecls :: Decls _tlIcomments :: ([String]) _tlIisNil :: Bool _tlIsemDom :: ([Decl]) _tlIsemDomUnfoldGath :: (Map (NontermIdent, Int) ([String], Code.Type)) _tlIwrapDecls :: Decls -- "GenerateCode.ag"(line 237, column 11) _tlOnr = ({-# LINE 237 "GenerateCode.ag" #-} _lhsInr + 1 {-# LINE 3812 "GenerateCode.hs" #-}) -- "GenerateCode.ag"(line 250, column 12) _lhsOisNil = ({-# LINE 250 "GenerateCode.ag" #-} False {-# LINE 3817 "GenerateCode.hs" #-}) -- "GenerateCode.ag"(line 251, column 12) _hdOisLast = ({-# LINE 251 "GenerateCode.ag" #-} _tlIisNil {-# LINE 3822 "GenerateCode.hs" #-}) -- use rule "GenerateCode.ag"(line 759, column 52) _lhsOcomments = ({-# LINE 759 "GenerateCode.ag" #-} _hdIcomments ++ _tlIcomments {-# LINE 3827 "GenerateCode.hs" #-}) -- use rule "GenerateCode.ag"(line 603, column 50) _lhsOsemDom = ({-# LINE 603 "GenerateCode.ag" #-} _hdIsemDom ++ _tlIsemDom {-# LINE 3832 "GenerateCode.hs" #-}) -- use rule "GenerateCode.ag"(line 622, column 86) _lhsOsemDomUnfoldGath = ({-# LINE 622 "GenerateCode.ag" #-} _hdIsemDomUnfoldGath `Map.union` _tlIsemDomUnfoldGath {-# LINE 3837 "GenerateCode.hs" #-}) -- use rule "GenerateCode.ag"(line 708, column 52) _lhsOwrapDecls = ({-# LINE 708 "GenerateCode.ag" #-} _hdIwrapDecls ++ _tlIwrapDecls {-# LINE 3842 "GenerateCode.hs" #-}) -- copy rule (down) _hdOinh = ({-# LINE 78 "GenerateCode.ag" #-} _lhsIinh {-# LINE 3847 "GenerateCode.hs" #-}) -- copy rule (down) _hdOnr = ({-# LINE 229 "GenerateCode.ag" #-} _lhsInr {-# LINE 3852 "GenerateCode.hs" #-}) -- copy rule (down) _hdOnt = ({-# LINE 78 "GenerateCode.ag" #-} _lhsInt {-# LINE 3857 "GenerateCode.hs" #-}) -- copy rule (down) _hdOo_case = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_case {-# LINE 3862 "GenerateCode.hs" #-}) -- copy rule (down) _hdOo_cata = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_cata {-# LINE 3867 "GenerateCode.hs" #-}) -- copy rule (down) _hdOo_costcentre = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_costcentre {-# LINE 3872 "GenerateCode.hs" #-}) -- copy rule (down) _hdOo_data = ({-# LINE 46 "GenerateCode.ag" #-} _lhsIo_data {-# LINE 3877 "GenerateCode.hs" #-}) -- copy rule (down) _hdOo_linePragmas = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_linePragmas {-# LINE 3882 "GenerateCode.hs" #-}) -- copy rule (down) _hdOo_monadic = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_monadic {-# LINE 3887 "GenerateCode.hs" #-}) -- copy rule (down) _hdOo_newtypes = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_newtypes {-# LINE 3892 "GenerateCode.hs" #-}) -- copy rule (down) _hdOo_pretty = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_pretty {-# LINE 3897 "GenerateCode.hs" #-}) -- copy rule (down) _hdOo_rename = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_rename {-# LINE 3902 "GenerateCode.hs" #-}) -- copy rule (down) _hdOo_sem = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_sem {-# LINE 3907 "GenerateCode.hs" #-}) -- copy rule (down) _hdOo_sig = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_sig {-# LINE 3912 "GenerateCode.hs" #-}) -- copy rule (down) _hdOo_splitsems = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_splitsems {-# LINE 3917 "GenerateCode.hs" #-}) -- copy rule (down) _hdOo_strictwrap = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_strictwrap {-# LINE 3922 "GenerateCode.hs" #-}) -- copy rule (down) _hdOo_traces = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_traces {-# LINE 3927 "GenerateCode.hs" #-}) -- copy rule (down) _hdOo_unbox = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_unbox {-# LINE 3932 "GenerateCode.hs" #-}) -- copy rule (down) _hdOparamMap = ({-# LINE 89 "GenerateCode.ag" #-} _lhsIparamMap {-# LINE 3937 "GenerateCode.hs" #-}) -- copy rule (down) _hdOprefix = ({-# LINE 47 "GenerateCode.ag" #-} _lhsIprefix {-# LINE 3942 "GenerateCode.hs" #-}) -- copy rule (down) _hdOsyn = ({-# LINE 78 "GenerateCode.ag" #-} _lhsIsyn {-# LINE 3947 "GenerateCode.hs" #-}) -- copy rule (down) _tlOinh = ({-# LINE 78 "GenerateCode.ag" #-} _lhsIinh {-# LINE 3952 "GenerateCode.hs" #-}) -- copy rule (down) _tlOnt = ({-# LINE 78 "GenerateCode.ag" #-} _lhsInt {-# LINE 3957 "GenerateCode.hs" #-}) -- copy rule (down) _tlOo_case = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_case {-# LINE 3962 "GenerateCode.hs" #-}) -- copy rule (down) _tlOo_cata = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_cata {-# LINE 3967 "GenerateCode.hs" #-}) -- copy rule (down) _tlOo_costcentre = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_costcentre {-# LINE 3972 "GenerateCode.hs" #-}) -- copy rule (down) _tlOo_data = ({-# LINE 46 "GenerateCode.ag" #-} _lhsIo_data {-# LINE 3977 "GenerateCode.hs" #-}) -- copy rule (down) _tlOo_linePragmas = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_linePragmas {-# LINE 3982 "GenerateCode.hs" #-}) -- copy rule (down) _tlOo_monadic = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_monadic {-# LINE 3987 "GenerateCode.hs" #-}) -- copy rule (down) _tlOo_newtypes = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_newtypes {-# LINE 3992 "GenerateCode.hs" #-}) -- copy rule (down) _tlOo_pretty = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_pretty {-# LINE 3997 "GenerateCode.hs" #-}) -- copy rule (down) _tlOo_rename = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_rename {-# LINE 4002 "GenerateCode.hs" #-}) -- copy rule (down) _tlOo_sem = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_sem {-# LINE 4007 "GenerateCode.hs" #-}) -- copy rule (down) _tlOo_sig = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_sig {-# LINE 4012 "GenerateCode.hs" #-}) -- copy rule (down) _tlOo_splitsems = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_splitsems {-# LINE 4017 "GenerateCode.hs" #-}) -- copy rule (down) _tlOo_strictwrap = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_strictwrap {-# LINE 4022 "GenerateCode.hs" #-}) -- copy rule (down) _tlOo_traces = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_traces {-# LINE 4027 "GenerateCode.hs" #-}) -- copy rule (down) _tlOo_unbox = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_unbox {-# LINE 4032 "GenerateCode.hs" #-}) -- copy rule (down) _tlOparamMap = ({-# LINE 89 "GenerateCode.ag" #-} _lhsIparamMap {-# LINE 4037 "GenerateCode.hs" #-}) -- copy rule (down) _tlOprefix = ({-# LINE 47 "GenerateCode.ag" #-} _lhsIprefix {-# LINE 4042 "GenerateCode.hs" #-}) -- copy rule (down) _tlOsyn = ({-# LINE 78 "GenerateCode.ag" #-} _lhsIsyn {-# LINE 4047 "GenerateCode.hs" #-}) ( _hdIcomments,_hdIsemDom,_hdIsemDomUnfoldGath,_hdIwrapDecls) = (hd_ _hdOinh _hdOisLast _hdOnr _hdOnt _hdOo_case _hdOo_cata _hdOo_costcentre _hdOo_data _hdOo_linePragmas _hdOo_monadic _hdOo_newtypes _hdOo_pretty _hdOo_rename _hdOo_sem _hdOo_sig _hdOo_splitsems _hdOo_strictwrap _hdOo_traces _hdOo_unbox _hdOparamMap _hdOprefix _hdOsyn ) ( _tlIcomments,_tlIisNil,_tlIsemDom,_tlIsemDomUnfoldGath,_tlIwrapDecls) = (tl_ _tlOinh _tlOnr _tlOnt _tlOo_case _tlOo_cata _tlOo_costcentre _tlOo_data _tlOo_linePragmas _tlOo_monadic _tlOo_newtypes _tlOo_pretty _tlOo_rename _tlOo_sem _tlOo_sig _tlOo_splitsems _tlOo_strictwrap _tlOo_traces _tlOo_unbox _tlOparamMap _tlOprefix _tlOsyn ) in ( _lhsOcomments,_lhsOisNil,_lhsOsemDom,_lhsOsemDomUnfoldGath,_lhsOwrapDecls))) ) sem_CSegments_Nil :: T_CSegments sem_CSegments_Nil = (T_CSegments (\ _lhsIinh _lhsInr _lhsInt _lhsIo_case _lhsIo_cata _lhsIo_costcentre _lhsIo_data _lhsIo_linePragmas _lhsIo_monadic _lhsIo_newtypes _lhsIo_pretty _lhsIo_rename _lhsIo_sem _lhsIo_sig _lhsIo_splitsems _lhsIo_strictwrap _lhsIo_traces _lhsIo_unbox _lhsIparamMap _lhsIprefix _lhsIsyn -> (let _lhsOisNil :: Bool _lhsOcomments :: ([String]) _lhsOsemDom :: ([Decl]) _lhsOsemDomUnfoldGath :: (Map (NontermIdent, Int) ([String], Code.Type)) _lhsOwrapDecls :: Decls -- "GenerateCode.ag"(line 252, column 10) _lhsOisNil = ({-# LINE 252 "GenerateCode.ag" #-} True {-# LINE 4085 "GenerateCode.hs" #-}) -- use rule "GenerateCode.ag"(line 759, column 52) _lhsOcomments = ({-# LINE 759 "GenerateCode.ag" #-} [] {-# LINE 4090 "GenerateCode.hs" #-}) -- use rule "GenerateCode.ag"(line 603, column 50) _lhsOsemDom = ({-# LINE 603 "GenerateCode.ag" #-} [] {-# LINE 4095 "GenerateCode.hs" #-}) -- use rule "GenerateCode.ag"(line 622, column 86) _lhsOsemDomUnfoldGath = ({-# LINE 622 "GenerateCode.ag" #-} Map.empty {-# LINE 4100 "GenerateCode.hs" #-}) -- use rule "GenerateCode.ag"(line 708, column 52) _lhsOwrapDecls = ({-# LINE 708 "GenerateCode.ag" #-} [] {-# LINE 4105 "GenerateCode.hs" #-}) in ( _lhsOcomments,_lhsOisNil,_lhsOsemDom,_lhsOsemDomUnfoldGath,_lhsOwrapDecls))) ) -- CVisit ------------------------------------------------------ {- visit 0: inherited attributes: allNts : Set NontermIdent allPragmas : PragmaMap aroundMap : Set Identifier children : [(Identifier,Type,Bool)] con : ConstructorIdent contextMap : ContextMap inh : Attributes instVisitNrs : Map Identifier Int isLast : Bool nextIntra : Exprs nextIntraVars : Set String nr : Int nt : NontermIdent o_case : Bool o_cata : Bool o_costcentre : Bool o_data : Maybe Bool o_linePragmas : Bool o_monadic : Bool o_newtypes : Bool o_pretty : Bool o_rename : Bool o_sem : Bool o_sig : Bool o_splitsems : Bool o_strictwrap : Bool o_traces : Bool o_unbox : Bool paramInstMap : Map Identifier (NontermIdent, [String]) paramMap : ParamMap prefix : String syn : Attributes terminals : [Identifier] unfoldSemDom : NontermIdent -> Int -> [String] -> Code.Type with_sig : Bool chained attribute: errors : Seq Error synthesized attributes: allTpsFound : Bool comments : [String] decls : Decls gatherInstVisitNrs : Map Identifier Int intra : Exprs intraVars : Set String semNames : [String] alternatives: alternative CVisit: child inh : {Attributes} child syn : {Attributes} child vss : Sequence child intra : Sequence child ordered : {Bool} visit 0: local _tup4 : _ local higherOrderChildren : _ local firstOrderChildren : _ local funcname : _ local nextVisitName : _ local nextVisitDecl : _ local decls : _ local lastExprVars : _ local _tup5 : _ local blockFunDecls : _ local blockFirstFunCall : _ local costCentreDescr : _ local addCostCentre : _ local params : _ local semFun : _ local tsig : _ local semType : _ local typeSigs : _ local o_do : _ local o_case : _ local declsType : _ local o_splitsems : _ -} -- cata sem_CVisit :: CVisit -> T_CVisit sem_CVisit (CVisit _inh _syn _vss _intra _ordered ) = (sem_CVisit_CVisit _inh _syn (sem_Sequence _vss ) (sem_Sequence _intra ) _ordered ) -- semantic domain newtype T_CVisit = T_CVisit ((Set NontermIdent) -> PragmaMap -> (Set Identifier) -> ([(Identifier,Type,Bool)]) -> ConstructorIdent -> ContextMap -> (Seq Error) -> Attributes -> (Map Identifier Int) -> Bool -> Exprs -> (Set String) -> Int -> NontermIdent -> Bool -> Bool -> Bool -> (Maybe Bool) -> Bool -> Bool -> Bool -> Bool -> Bool -> Bool -> Bool -> Bool -> Bool -> Bool -> Bool -> (Map Identifier (NontermIdent, [String])) -> ParamMap -> String -> Attributes -> ([Identifier]) -> (NontermIdent -> Int -> [String] -> Code.Type) -> Bool -> ( Bool,([String]),Decls,(Seq Error),(Map Identifier Int),Exprs,(Set String),([String]))) data Inh_CVisit = Inh_CVisit {allNts_Inh_CVisit :: !((Set NontermIdent)),allPragmas_Inh_CVisit :: !(PragmaMap),aroundMap_Inh_CVisit :: !((Set Identifier)),children_Inh_CVisit :: !(([(Identifier,Type,Bool)])),con_Inh_CVisit :: !(ConstructorIdent),contextMap_Inh_CVisit :: !(ContextMap),errors_Inh_CVisit :: !((Seq Error)),inh_Inh_CVisit :: !(Attributes),instVisitNrs_Inh_CVisit :: !((Map Identifier Int)),isLast_Inh_CVisit :: !(Bool),nextIntra_Inh_CVisit :: !(Exprs),nextIntraVars_Inh_CVisit :: !((Set String)),nr_Inh_CVisit :: !(Int),nt_Inh_CVisit :: !(NontermIdent),o_case_Inh_CVisit :: !(Bool),o_cata_Inh_CVisit :: !(Bool),o_costcentre_Inh_CVisit :: !(Bool),o_data_Inh_CVisit :: !((Maybe Bool)),o_linePragmas_Inh_CVisit :: !(Bool),o_monadic_Inh_CVisit :: !(Bool),o_newtypes_Inh_CVisit :: !(Bool),o_pretty_Inh_CVisit :: !(Bool),o_rename_Inh_CVisit :: !(Bool),o_sem_Inh_CVisit :: !(Bool),o_sig_Inh_CVisit :: !(Bool),o_splitsems_Inh_CVisit :: !(Bool),o_strictwrap_Inh_CVisit :: !(Bool),o_traces_Inh_CVisit :: !(Bool),o_unbox_Inh_CVisit :: !(Bool),paramInstMap_Inh_CVisit :: !((Map Identifier (NontermIdent, [String]))),paramMap_Inh_CVisit :: !(ParamMap),prefix_Inh_CVisit :: !(String),syn_Inh_CVisit :: !(Attributes),terminals_Inh_CVisit :: !(([Identifier])),unfoldSemDom_Inh_CVisit :: !((NontermIdent -> Int -> [String] -> Code.Type)),with_sig_Inh_CVisit :: !(Bool)} data Syn_CVisit = Syn_CVisit {allTpsFound_Syn_CVisit :: !(Bool),comments_Syn_CVisit :: !(([String])),decls_Syn_CVisit :: !(Decls),errors_Syn_CVisit :: !((Seq Error)),gatherInstVisitNrs_Syn_CVisit :: !((Map Identifier Int)),intra_Syn_CVisit :: !(Exprs),intraVars_Syn_CVisit :: !((Set String)),semNames_Syn_CVisit :: !(([String]))} wrap_CVisit :: T_CVisit -> Inh_CVisit -> Syn_CVisit wrap_CVisit (T_CVisit sem ) (Inh_CVisit _lhsIallNts _lhsIallPragmas _lhsIaroundMap _lhsIchildren _lhsIcon _lhsIcontextMap _lhsIerrors _lhsIinh _lhsIinstVisitNrs _lhsIisLast _lhsInextIntra _lhsInextIntraVars _lhsInr _lhsInt _lhsIo_case _lhsIo_cata _lhsIo_costcentre _lhsIo_data _lhsIo_linePragmas _lhsIo_monadic _lhsIo_newtypes _lhsIo_pretty _lhsIo_rename _lhsIo_sem _lhsIo_sig _lhsIo_splitsems _lhsIo_strictwrap _lhsIo_traces _lhsIo_unbox _lhsIparamInstMap _lhsIparamMap _lhsIprefix _lhsIsyn _lhsIterminals _lhsIunfoldSemDom _lhsIwith_sig ) = (let ( _lhsOallTpsFound,_lhsOcomments,_lhsOdecls,_lhsOerrors,_lhsOgatherInstVisitNrs,_lhsOintra,_lhsOintraVars,_lhsOsemNames) = (sem _lhsIallNts _lhsIallPragmas _lhsIaroundMap _lhsIchildren _lhsIcon _lhsIcontextMap _lhsIerrors _lhsIinh _lhsIinstVisitNrs _lhsIisLast _lhsInextIntra _lhsInextIntraVars _lhsInr _lhsInt _lhsIo_case _lhsIo_cata _lhsIo_costcentre _lhsIo_data _lhsIo_linePragmas _lhsIo_monadic _lhsIo_newtypes _lhsIo_pretty _lhsIo_rename _lhsIo_sem _lhsIo_sig _lhsIo_splitsems _lhsIo_strictwrap _lhsIo_traces _lhsIo_unbox _lhsIparamInstMap _lhsIparamMap _lhsIprefix _lhsIsyn _lhsIterminals _lhsIunfoldSemDom _lhsIwith_sig ) in (Syn_CVisit _lhsOallTpsFound _lhsOcomments _lhsOdecls _lhsOerrors _lhsOgatherInstVisitNrs _lhsOintra _lhsOintraVars _lhsOsemNames )) sem_CVisit_CVisit :: Attributes -> Attributes -> T_Sequence -> T_Sequence -> Bool -> T_CVisit sem_CVisit_CVisit inh_ syn_ (T_Sequence vss_ ) (T_Sequence intra_ ) ordered_ = (T_CVisit (\ _lhsIallNts _lhsIallPragmas _lhsIaroundMap _lhsIchildren _lhsIcon _lhsIcontextMap _lhsIerrors _lhsIinh _lhsIinstVisitNrs _lhsIisLast _lhsInextIntra _lhsInextIntraVars _lhsInr _lhsInt _lhsIo_case _lhsIo_cata _lhsIo_costcentre _lhsIo_data _lhsIo_linePragmas _lhsIo_monadic _lhsIo_newtypes _lhsIo_pretty _lhsIo_rename _lhsIo_sem _lhsIo_sig _lhsIo_splitsems _lhsIo_strictwrap _lhsIo_traces _lhsIo_unbox _lhsIparamInstMap _lhsIparamMap _lhsIprefix _lhsIsyn _lhsIterminals _lhsIunfoldSemDom _lhsIwith_sig -> (let _lhsOintra :: Exprs _lhsOintraVars :: (Set String) _vssOlastExpr :: Expr _intraOlastExpr :: Expr _lhsOdecls :: Decls _lhsOgatherInstVisitNrs :: (Map Identifier Int) _vssOdeclsAbove :: ([Decl]) _intraOdeclsAbove :: ([Decl]) _lhsOallTpsFound :: Bool _lhsOerrors :: (Seq Error) _lhsOcomments :: ([String]) _vssOwhat :: String _intraOwhat :: String _lhsOsemNames :: ([String]) _vssOallNts :: (Set NontermIdent) _vssOaroundMap :: (Set Identifier) _vssOchildren :: ([(Identifier,Type,Bool)]) _vssOcon :: ConstructorIdent _vssOerrors :: (Seq Error) _vssOhigherOrderChildren :: ([(Identifier,Type,Bool)]) _vssOinh :: Attributes _vssOinstVisitNrs :: (Map Identifier Int) _vssOnr :: Int _vssOnt :: NontermIdent _vssOo_case :: Bool _vssOo_cata :: Bool _vssOo_costcentre :: Bool _vssOo_data :: (Maybe Bool) _vssOo_linePragmas :: Bool _vssOo_monadic :: Bool _vssOo_newtypes :: Bool _vssOo_pretty :: Bool _vssOo_rename :: Bool _vssOo_sem :: Bool _vssOo_sig :: Bool _vssOo_splitsems :: Bool _vssOo_strictwrap :: Bool _vssOo_traces :: Bool _vssOo_unbox :: Bool _vssOparamInstMap :: (Map Identifier (NontermIdent, [String])) _vssOparamMap :: ParamMap _vssOprefix :: String _vssOsyn :: Attributes _vssOterminals :: ([Identifier]) _vssOunfoldSemDom :: (NontermIdent -> Int -> [String] -> Code.Type) _intraOallNts :: (Set NontermIdent) _intraOaroundMap :: (Set Identifier) _intraOchildren :: ([(Identifier,Type,Bool)]) _intraOcon :: ConstructorIdent _intraOerrors :: (Seq Error) _intraOhigherOrderChildren :: ([(Identifier,Type,Bool)]) _intraOinh :: Attributes _intraOinstVisitNrs :: (Map Identifier Int) _intraOnr :: Int _intraOnt :: NontermIdent _intraOo_case :: Bool _intraOo_cata :: Bool _intraOo_costcentre :: Bool _intraOo_data :: (Maybe Bool) _intraOo_linePragmas :: Bool _intraOo_monadic :: Bool _intraOo_newtypes :: Bool _intraOo_pretty :: Bool _intraOo_rename :: Bool _intraOo_sem :: Bool _intraOo_sig :: Bool _intraOo_splitsems :: Bool _intraOo_strictwrap :: Bool _intraOo_traces :: Bool _intraOo_unbox :: Bool _intraOparamInstMap :: (Map Identifier (NontermIdent, [String])) _intraOparamMap :: ParamMap _intraOprefix :: String _intraOsyn :: Attributes _intraOterminals :: ([Identifier]) _intraOunfoldSemDom :: (NontermIdent -> Int -> [String] -> Code.Type) _vssIallTpsFound :: Bool _vssIblockDecls :: DeclBlocks _vssIcomments :: ([String]) _vssIdecls :: Decls _vssIdeclsAbove :: ([Decl]) _vssIdefinedInsts :: ([Identifier]) _vssIerrors :: (Seq Error) _vssIexprs :: Exprs _vssItSigs :: ([Decl]) _vssItps :: ([Type]) _vssIusedVars :: (Set String) _intraIallTpsFound :: Bool _intraIblockDecls :: DeclBlocks _intraIcomments :: ([String]) _intraIdecls :: Decls _intraIdeclsAbove :: ([Decl]) _intraIdefinedInsts :: ([Identifier]) _intraIerrors :: (Seq Error) _intraIexprs :: Exprs _intraItSigs :: ([Decl]) _intraItps :: ([Type]) _intraIusedVars :: (Set String) -- "GenerateCode.ag"(line 261, column 13) _lhsOintra = ({-# LINE 261 "GenerateCode.ag" #-} _intraIexprs {-# LINE 4384 "GenerateCode.hs" #-}) -- "GenerateCode.ag"(line 262, column 13) _lhsOintraVars = ({-# LINE 262 "GenerateCode.ag" #-} _intraIusedVars {-# LINE 4389 "GenerateCode.hs" #-}) -- "GenerateCode.ag"(line 374, column 13) __tup4 = ({-# LINE 374 "GenerateCode.ag" #-} partition (\(_,_,ho) -> ho) _lhsIchildren {-# LINE 4394 "GenerateCode.hs" #-}) -- "GenerateCode.ag"(line 374, column 13) (_higherOrderChildren,_) = ({-# LINE 374 "GenerateCode.ag" #-} __tup4 {-# LINE 4399 "GenerateCode.hs" #-}) -- "GenerateCode.ag"(line 374, column 13) (_,_firstOrderChildren) = ({-# LINE 374 "GenerateCode.ag" #-} __tup4 {-# LINE 4404 "GenerateCode.hs" #-}) -- "GenerateCode.ag"(line 375, column 13) _funcname = ({-# LINE 375 "GenerateCode.ag" #-} seqSemname _lhsIprefix _lhsInt _lhsIcon _lhsInr {-# LINE 4409 "GenerateCode.hs" #-}) -- "GenerateCode.ag"(line 376, column 13) _nextVisitName = ({-# LINE 376 "GenerateCode.ag" #-} if _lhsIisLast then [] else [visitname _lhsIprefix _lhsInt (_lhsInr+1)] {-# LINE 4414 "GenerateCode.hs" #-}) -- "GenerateCode.ag"(line 377, column 13) _nextVisitDecl = ({-# LINE 377 "GenerateCode.ag" #-} let lhs = TupleLhs _nextVisitName rhs = App fun _lhsInextIntra fun = seqSemname _lhsIprefix _lhsInt _lhsIcon (_lhsInr+1) in if _lhsIisLast then [] else [Decl lhs rhs (Set.fromList _nextVisitName) _lhsInextIntraVars] {-# LINE 4424 "GenerateCode.hs" #-}) -- "GenerateCode.ag"(line 383, column 13) _decls = ({-# LINE 383 "GenerateCode.ag" #-} _typeSigs ++ _vssIdecls ++ _nextVisitDecl {-# LINE 4429 "GenerateCode.hs" #-}) -- "GenerateCode.ag"(line 384, column 13) _vssOlastExpr = ({-# LINE 384 "GenerateCode.ag" #-} mkTupleExpr _lhsIo_unbox (null $ Map.keys inh_) $ map (SimpleExpr . lhsname False) (Map.keys syn_) ++ map SimpleExpr _nextVisitName {-# LINE 4434 "GenerateCode.hs" #-}) -- "GenerateCode.ag"(line 385, column 13) _intraOlastExpr = ({-# LINE 385 "GenerateCode.ag" #-} error "lastExpr: not used here" {-# LINE 4439 "GenerateCode.hs" #-}) -- "GenerateCode.ag"(line 386, column 13) _lastExprVars = ({-# LINE 386 "GenerateCode.ag" #-} map (lhsname False) (Map.keys syn_) ++ _nextVisitName {-# LINE 4444 "GenerateCode.hs" #-}) -- "GenerateCode.ag"(line 387, column 13) __tup5 = ({-# LINE 387 "GenerateCode.ag" #-} mkPartitionedFunction _funcname _o_case _nextVisitDecl _lastExprVars _vssIblockDecls {-# LINE 4449 "GenerateCode.hs" #-}) -- "GenerateCode.ag"(line 387, column 13) (_blockFunDecls,_) = ({-# LINE 387 "GenerateCode.ag" #-} __tup5 {-# LINE 4454 "GenerateCode.hs" #-}) -- "GenerateCode.ag"(line 387, column 13) (_,_blockFirstFunCall) = ({-# LINE 387 "GenerateCode.ag" #-} __tup5 {-# LINE 4459 "GenerateCode.hs" #-}) -- "GenerateCode.ag"(line 389, column 13) _costCentreDescr = ({-# LINE 389 "GenerateCode.ag" #-} "b" ++ ":" ++ show _lhsInt ++ ":" ++ show _lhsIcon ++ ":" ++ show _lhsInr {-# LINE 4464 "GenerateCode.hs" #-}) -- "GenerateCode.ag"(line 390, column 13) _addCostCentre = ({-# LINE 390 "GenerateCode.ag" #-} \v -> if _lhsIo_costcentre then PragmaExpr True False ("SCC \"" ++ _costCentreDescr ++ "\"") v else v {-# LINE 4471 "GenerateCode.hs" #-}) -- "GenerateCode.ag"(line 394, column 13) _params = ({-# LINE 394 "GenerateCode.ag" #-} map getName $ Map.findWithDefault [] _lhsInt _lhsIparamMap {-# LINE 4476 "GenerateCode.hs" #-}) -- "GenerateCode.ag"(line 395, column 13) _semFun = ({-# LINE 395 "GenerateCode.ag" #-} let lhs = Fun _funcname lhs_args lhs_args = if _lhsInr == 0 then map field _firstOrderChildren else _intraIexprs field (name,NT tp tps,_) = let unwrap | _lhsIo_newtypes = \x -> App (sdtype tp) [x] | otherwise = id addType expr | null tps = expr | otherwise = TypedExpr expr (_lhsIunfoldSemDom tp 0 tps) in unwrap $ addType $ SimpleExpr $ funname name 0 field (name,tp,_) = let expr = SimpleExpr (funname name 0) in if null _params then expr else TypedExpr expr (idEvalType $ typeToCodeType (Just _lhsInt) _params tp) mbEvalTp | null _params = const Nothing | otherwise = Just . idEvalType rhs = wrap . mkLambda [mkLambdaArg (lhsname True nm) (mbEvalTp $ typeToCodeType (Just _lhsInt) _params tp) | (nm,tp) <- Map.assocs inh_] $ _addCostCentre $ if ordered_ && _o_splitsems then _blockFirstFunCall else mkDecls _declsType _decls . mkTupleExpr _lhsIo_unbox (null $ Map.keys inh_) $ map (SimpleExpr . lhsname False) (Map.keys syn_) ++ map SimpleExpr _nextVisitName wrap = if _lhsIo_newtypes then \x -> App (typeName _lhsInt _lhsInr) [x] else id in Decl lhs rhs Set.empty Set.empty {-# LINE 4505 "GenerateCode.hs" #-}) -- "GenerateCode.ag"(line 425, column 13) _tsig = ({-# LINE 425 "GenerateCode.ag" #-} TSig _funcname _semType {-# LINE 4510 "GenerateCode.hs" #-}) -- "GenerateCode.ag"(line 426, column 13) _semType = ({-# LINE 426 "GenerateCode.ag" #-} let argType (NT tp tps) r | tp /= _SELF = typeAppStrs (sdtype tp) tps `Arr` r | tp == _SELF = error "GenerateCode: found an intra-type with type SELF, which should have been prevented by CRule.tps" argType (Haskell tp) r = SimpleType tp `Arr` r evalTp | null _params = id | otherwise = idEvalType in appContext _lhsIcontextMap _lhsInt $ evalTp $ if _lhsInr == 0 then foldr argType (typeAppStrs (sdtype _lhsInt ) _params ) (map (\(_,t,_) -> t) _firstOrderChildren ) else foldr argType (typeAppStrs (typeName _lhsInt _lhsInr) _params ) _intraItps {-# LINE 4523 "GenerateCode.hs" #-}) -- "GenerateCode.ag"(line 437, column 13) _lhsOdecls = ({-# LINE 437 "GenerateCode.ag" #-} ( if _lhsIwith_sig then [_tsig, _semFun] else [_semFun] ) ++ ( if ordered_ && _o_splitsems then _blockFunDecls else [] ) {-# LINE 4535 "GenerateCode.hs" #-}) -- "GenerateCode.ag"(line 445, column 13) _typeSigs = ({-# LINE 445 "GenerateCode.ag" #-} if _lhsIo_sig && not _o_case then _vssItSigs else [] {-# LINE 4542 "GenerateCode.hs" #-}) -- "GenerateCode.ag"(line 448, column 13) _o_do = ({-# LINE 448 "GenerateCode.ag" #-} ordered_ && _lhsIo_monadic {-# LINE 4547 "GenerateCode.hs" #-}) -- "GenerateCode.ag"(line 449, column 13) _o_case = ({-# LINE 449 "GenerateCode.ag" #-} not _o_do && _lhsIo_case && ordered_ && not (hasPragma _lhsIallPragmas _lhsInt _lhsIcon _NOCASE) {-# LINE 4552 "GenerateCode.hs" #-}) -- "GenerateCode.ag"(line 450, column 13) _declsType = ({-# LINE 450 "GenerateCode.ag" #-} if _o_do then DeclsDo else if _o_case then DeclsCase else DeclsLet {-# LINE 4561 "GenerateCode.hs" #-}) -- "GenerateCode.ag"(line 455, column 13) _o_splitsems = ({-# LINE 455 "GenerateCode.ag" #-} ordered_ && _lhsIo_splitsems {-# LINE 4566 "GenerateCode.hs" #-}) -- "GenerateCode.ag"(line 477, column 7) _lhsOgatherInstVisitNrs = ({-# LINE 477 "GenerateCode.ag" #-} Map.fromList [(i,_lhsInr) | i <- _vssIdefinedInsts] {-# LINE 4571 "GenerateCode.hs" #-}) -- "GenerateCode.ag"(line 504, column 7) _vssOdeclsAbove = ({-# LINE 504 "GenerateCode.ag" #-} [] {-# LINE 4576 "GenerateCode.hs" #-}) -- "GenerateCode.ag"(line 505, column 7) _intraOdeclsAbove = ({-# LINE 505 "GenerateCode.ag" #-} error "declsAbove: not used here" {-# LINE 4581 "GenerateCode.hs" #-}) -- "GenerateCode.ag"(line 733, column 13) _lhsOallTpsFound = ({-# LINE 733 "GenerateCode.ag" #-} _intraIallTpsFound {-# LINE 4586 "GenerateCode.hs" #-}) -- "GenerateCode.ag"(line 744, column 13) _lhsOerrors = ({-# LINE 744 "GenerateCode.ag" #-} _intraIerrors {-# LINE 4591 "GenerateCode.hs" #-}) -- "GenerateCode.ag"(line 777, column 18) _lhsOcomments = ({-# LINE 777 "GenerateCode.ag" #-} let body = map ind (_vssIcomments ++ _intraIcomments) in if null body then [] else ("visit " ++ show _lhsInr ++ ":") : body {-# LINE 4599 "GenerateCode.hs" #-}) -- "GenerateCode.ag"(line 781, column 18) _vssOwhat = ({-# LINE 781 "GenerateCode.ag" #-} "local" {-# LINE 4604 "GenerateCode.hs" #-}) -- "GenerateCode.ag"(line 782, column 18) _intraOwhat = ({-# LINE 782 "GenerateCode.ag" #-} "intra" {-# LINE 4609 "GenerateCode.hs" #-}) -- "GenerateCode.ag"(line 1025, column 7) _lhsOsemNames = ({-# LINE 1025 "GenerateCode.ag" #-} [_funcname ] {-# LINE 4614 "GenerateCode.hs" #-}) -- copy rule (down) _vssOallNts = ({-# LINE 121 "GenerateCode.ag" #-} _lhsIallNts {-# LINE 4619 "GenerateCode.hs" #-}) -- copy rule (down) _vssOaroundMap = ({-# LINE 489 "GenerateCode.ag" #-} _lhsIaroundMap {-# LINE 4624 "GenerateCode.hs" #-}) -- copy rule (down) _vssOchildren = ({-# LINE 355 "GenerateCode.ag" #-} _lhsIchildren {-# LINE 4629 "GenerateCode.hs" #-}) -- copy rule (down) _vssOcon = ({-# LINE 83 "GenerateCode.ag" #-} _lhsIcon {-# LINE 4634 "GenerateCode.hs" #-}) -- copy rule (down) _vssOerrors = ({-# LINE 740 "GenerateCode.ag" #-} _lhsIerrors {-# LINE 4639 "GenerateCode.hs" #-}) -- copy rule (from local) _vssOhigherOrderChildren = ({-# LINE 210 "GenerateCode.ag" #-} _higherOrderChildren {-# LINE 4644 "GenerateCode.hs" #-}) -- copy rule (down) _vssOinh = ({-# LINE 78 "GenerateCode.ag" #-} _lhsIinh {-# LINE 4649 "GenerateCode.hs" #-}) -- copy rule (down) _vssOinstVisitNrs = ({-# LINE 469 "GenerateCode.ag" #-} _lhsIinstVisitNrs {-# LINE 4654 "GenerateCode.hs" #-}) -- copy rule (down) _vssOnr = ({-# LINE 229 "GenerateCode.ag" #-} _lhsInr {-# LINE 4659 "GenerateCode.hs" #-}) -- copy rule (down) _vssOnt = ({-# LINE 78 "GenerateCode.ag" #-} _lhsInt {-# LINE 4664 "GenerateCode.hs" #-}) -- copy rule (from local) _vssOo_case = ({-# LINE 45 "GenerateCode.ag" #-} _o_case {-# LINE 4669 "GenerateCode.hs" #-}) -- copy rule (down) _vssOo_cata = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_cata {-# LINE 4674 "GenerateCode.hs" #-}) -- copy rule (down) _vssOo_costcentre = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_costcentre {-# LINE 4679 "GenerateCode.hs" #-}) -- copy rule (down) _vssOo_data = ({-# LINE 46 "GenerateCode.ag" #-} _lhsIo_data {-# LINE 4684 "GenerateCode.hs" #-}) -- copy rule (down) _vssOo_linePragmas = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_linePragmas {-# LINE 4689 "GenerateCode.hs" #-}) -- copy rule (down) _vssOo_monadic = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_monadic {-# LINE 4694 "GenerateCode.hs" #-}) -- copy rule (down) _vssOo_newtypes = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_newtypes {-# LINE 4699 "GenerateCode.hs" #-}) -- copy rule (down) _vssOo_pretty = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_pretty {-# LINE 4704 "GenerateCode.hs" #-}) -- copy rule (down) _vssOo_rename = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_rename {-# LINE 4709 "GenerateCode.hs" #-}) -- copy rule (down) _vssOo_sem = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_sem {-# LINE 4714 "GenerateCode.hs" #-}) -- copy rule (down) _vssOo_sig = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_sig {-# LINE 4719 "GenerateCode.hs" #-}) -- copy rule (from local) _vssOo_splitsems = ({-# LINE 45 "GenerateCode.ag" #-} _o_splitsems {-# LINE 4724 "GenerateCode.hs" #-}) -- copy rule (down) _vssOo_strictwrap = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_strictwrap {-# LINE 4729 "GenerateCode.hs" #-}) -- copy rule (down) _vssOo_traces = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_traces {-# LINE 4734 "GenerateCode.hs" #-}) -- copy rule (down) _vssOo_unbox = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_unbox {-# LINE 4739 "GenerateCode.hs" #-}) -- copy rule (down) _vssOparamInstMap = ({-# LINE 95 "GenerateCode.ag" #-} _lhsIparamInstMap {-# LINE 4744 "GenerateCode.hs" #-}) -- copy rule (down) _vssOparamMap = ({-# LINE 89 "GenerateCode.ag" #-} _lhsIparamMap {-# LINE 4749 "GenerateCode.hs" #-}) -- copy rule (down) _vssOprefix = ({-# LINE 47 "GenerateCode.ag" #-} _lhsIprefix {-# LINE 4754 "GenerateCode.hs" #-}) -- copy rule (down) _vssOsyn = ({-# LINE 78 "GenerateCode.ag" #-} _lhsIsyn {-# LINE 4759 "GenerateCode.hs" #-}) -- copy rule (down) _vssOterminals = ({-# LINE 84 "GenerateCode.ag" #-} _lhsIterminals {-# LINE 4764 "GenerateCode.hs" #-}) -- copy rule (down) _vssOunfoldSemDom = ({-# LINE 628 "GenerateCode.ag" #-} _lhsIunfoldSemDom {-# LINE 4769 "GenerateCode.hs" #-}) -- copy rule (down) _intraOallNts = ({-# LINE 121 "GenerateCode.ag" #-} _lhsIallNts {-# LINE 4774 "GenerateCode.hs" #-}) -- copy rule (down) _intraOaroundMap = ({-# LINE 489 "GenerateCode.ag" #-} _lhsIaroundMap {-# LINE 4779 "GenerateCode.hs" #-}) -- copy rule (down) _intraOchildren = ({-# LINE 355 "GenerateCode.ag" #-} _lhsIchildren {-# LINE 4784 "GenerateCode.hs" #-}) -- copy rule (down) _intraOcon = ({-# LINE 83 "GenerateCode.ag" #-} _lhsIcon {-# LINE 4789 "GenerateCode.hs" #-}) -- copy rule (chain) _intraOerrors = ({-# LINE 740 "GenerateCode.ag" #-} _vssIerrors {-# LINE 4794 "GenerateCode.hs" #-}) -- copy rule (from local) _intraOhigherOrderChildren = ({-# LINE 210 "GenerateCode.ag" #-} _higherOrderChildren {-# LINE 4799 "GenerateCode.hs" #-}) -- copy rule (down) _intraOinh = ({-# LINE 78 "GenerateCode.ag" #-} _lhsIinh {-# LINE 4804 "GenerateCode.hs" #-}) -- copy rule (down) _intraOinstVisitNrs = ({-# LINE 469 "GenerateCode.ag" #-} _lhsIinstVisitNrs {-# LINE 4809 "GenerateCode.hs" #-}) -- copy rule (down) _intraOnr = ({-# LINE 229 "GenerateCode.ag" #-} _lhsInr {-# LINE 4814 "GenerateCode.hs" #-}) -- copy rule (down) _intraOnt = ({-# LINE 78 "GenerateCode.ag" #-} _lhsInt {-# LINE 4819 "GenerateCode.hs" #-}) -- copy rule (from local) _intraOo_case = ({-# LINE 45 "GenerateCode.ag" #-} _o_case {-# LINE 4824 "GenerateCode.hs" #-}) -- copy rule (down) _intraOo_cata = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_cata {-# LINE 4829 "GenerateCode.hs" #-}) -- copy rule (down) _intraOo_costcentre = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_costcentre {-# LINE 4834 "GenerateCode.hs" #-}) -- copy rule (down) _intraOo_data = ({-# LINE 46 "GenerateCode.ag" #-} _lhsIo_data {-# LINE 4839 "GenerateCode.hs" #-}) -- copy rule (down) _intraOo_linePragmas = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_linePragmas {-# LINE 4844 "GenerateCode.hs" #-}) -- copy rule (down) _intraOo_monadic = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_monadic {-# LINE 4849 "GenerateCode.hs" #-}) -- copy rule (down) _intraOo_newtypes = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_newtypes {-# LINE 4854 "GenerateCode.hs" #-}) -- copy rule (down) _intraOo_pretty = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_pretty {-# LINE 4859 "GenerateCode.hs" #-}) -- copy rule (down) _intraOo_rename = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_rename {-# LINE 4864 "GenerateCode.hs" #-}) -- copy rule (down) _intraOo_sem = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_sem {-# LINE 4869 "GenerateCode.hs" #-}) -- copy rule (down) _intraOo_sig = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_sig {-# LINE 4874 "GenerateCode.hs" #-}) -- copy rule (from local) _intraOo_splitsems = ({-# LINE 45 "GenerateCode.ag" #-} _o_splitsems {-# LINE 4879 "GenerateCode.hs" #-}) -- copy rule (down) _intraOo_strictwrap = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_strictwrap {-# LINE 4884 "GenerateCode.hs" #-}) -- copy rule (down) _intraOo_traces = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_traces {-# LINE 4889 "GenerateCode.hs" #-}) -- copy rule (down) _intraOo_unbox = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_unbox {-# LINE 4894 "GenerateCode.hs" #-}) -- copy rule (down) _intraOparamInstMap = ({-# LINE 95 "GenerateCode.ag" #-} _lhsIparamInstMap {-# LINE 4899 "GenerateCode.hs" #-}) -- copy rule (down) _intraOparamMap = ({-# LINE 89 "GenerateCode.ag" #-} _lhsIparamMap {-# LINE 4904 "GenerateCode.hs" #-}) -- copy rule (down) _intraOprefix = ({-# LINE 47 "GenerateCode.ag" #-} _lhsIprefix {-# LINE 4909 "GenerateCode.hs" #-}) -- copy rule (down) _intraOsyn = ({-# LINE 78 "GenerateCode.ag" #-} _lhsIsyn {-# LINE 4914 "GenerateCode.hs" #-}) -- copy rule (down) _intraOterminals = ({-# LINE 84 "GenerateCode.ag" #-} _lhsIterminals {-# LINE 4919 "GenerateCode.hs" #-}) -- copy rule (down) _intraOunfoldSemDom = ({-# LINE 628 "GenerateCode.ag" #-} _lhsIunfoldSemDom {-# LINE 4924 "GenerateCode.hs" #-}) ( _vssIallTpsFound,_vssIblockDecls,_vssIcomments,_vssIdecls,_vssIdeclsAbove,_vssIdefinedInsts,_vssIerrors,_vssIexprs,_vssItSigs,_vssItps,_vssIusedVars) = (vss_ _vssOallNts _vssOaroundMap _vssOchildren _vssOcon _vssOdeclsAbove _vssOerrors _vssOhigherOrderChildren _vssOinh _vssOinstVisitNrs _vssOlastExpr _vssOnr _vssOnt _vssOo_case _vssOo_cata _vssOo_costcentre _vssOo_data _vssOo_linePragmas _vssOo_monadic _vssOo_newtypes _vssOo_pretty _vssOo_rename _vssOo_sem _vssOo_sig _vssOo_splitsems _vssOo_strictwrap _vssOo_traces _vssOo_unbox _vssOparamInstMap _vssOparamMap _vssOprefix _vssOsyn _vssOterminals _vssOunfoldSemDom _vssOwhat ) ( _intraIallTpsFound,_intraIblockDecls,_intraIcomments,_intraIdecls,_intraIdeclsAbove,_intraIdefinedInsts,_intraIerrors,_intraIexprs,_intraItSigs,_intraItps,_intraIusedVars) = (intra_ _intraOallNts _intraOaroundMap _intraOchildren _intraOcon _intraOdeclsAbove _intraOerrors _intraOhigherOrderChildren _intraOinh _intraOinstVisitNrs _intraOlastExpr _intraOnr _intraOnt _intraOo_case _intraOo_cata _intraOo_costcentre _intraOo_data _intraOo_linePragmas _intraOo_monadic _intraOo_newtypes _intraOo_pretty _intraOo_rename _intraOo_sem _intraOo_sig _intraOo_splitsems _intraOo_strictwrap _intraOo_traces _intraOo_unbox _intraOparamInstMap _intraOparamMap _intraOprefix _intraOsyn _intraOterminals _intraOunfoldSemDom _intraOwhat ) in ( _lhsOallTpsFound,_lhsOcomments,_lhsOdecls,_lhsOerrors,_lhsOgatherInstVisitNrs,_lhsOintra,_lhsOintraVars,_lhsOsemNames))) ) -- CVisits ----------------------------------------------------- {- visit 0: inherited attributes: allNts : Set NontermIdent allPragmas : PragmaMap aroundMap : Set Identifier children : [(Identifier,Type,Bool)] con : ConstructorIdent contextMap : ContextMap inh : Attributes instVisitNrs : Map Identifier Int nr : Int nt : NontermIdent o_case : Bool o_cata : Bool o_costcentre : Bool o_data : Maybe Bool o_linePragmas : Bool o_monadic : Bool o_newtypes : Bool o_pretty : Bool o_rename : Bool o_sem : Bool o_sig : Bool o_splitsems : Bool o_strictwrap : Bool o_traces : Bool o_unbox : Bool paramInstMap : Map Identifier (NontermIdent, [String]) paramMap : ParamMap prefix : String syn : Attributes terminals : [Identifier] unfoldSemDom : NontermIdent -> Int -> [String] -> Code.Type with_sig : Bool chained attribute: errors : Seq Error synthesized attributes: allTpsFound : Bool comments : [String] decls : Decls gatherInstVisitNrs : Map Identifier Int intra : Exprs intraVars : Set String isNil : Bool semNames : [String] alternatives: alternative Cons: child hd : CVisit child tl : CVisits alternative Nil: -} -- cata sem_CVisits :: CVisits -> T_CVisits sem_CVisits list = (Prelude.foldr sem_CVisits_Cons sem_CVisits_Nil (Prelude.map sem_CVisit list) ) -- semantic domain newtype T_CVisits = T_CVisits ((Set NontermIdent) -> PragmaMap -> (Set Identifier) -> ([(Identifier,Type,Bool)]) -> ConstructorIdent -> ContextMap -> (Seq Error) -> Attributes -> (Map Identifier Int) -> Int -> NontermIdent -> Bool -> Bool -> Bool -> (Maybe Bool) -> Bool -> Bool -> Bool -> Bool -> Bool -> Bool -> Bool -> Bool -> Bool -> Bool -> Bool -> (Map Identifier (NontermIdent, [String])) -> ParamMap -> String -> Attributes -> ([Identifier]) -> (NontermIdent -> Int -> [String] -> Code.Type) -> Bool -> ( Bool,([String]),Decls,(Seq Error),(Map Identifier Int),Exprs,(Set String),Bool,([String]))) data Inh_CVisits = Inh_CVisits {allNts_Inh_CVisits :: !((Set NontermIdent)),allPragmas_Inh_CVisits :: !(PragmaMap),aroundMap_Inh_CVisits :: !((Set Identifier)),children_Inh_CVisits :: !(([(Identifier,Type,Bool)])),con_Inh_CVisits :: !(ConstructorIdent),contextMap_Inh_CVisits :: !(ContextMap),errors_Inh_CVisits :: !((Seq Error)),inh_Inh_CVisits :: !(Attributes),instVisitNrs_Inh_CVisits :: !((Map Identifier Int)),nr_Inh_CVisits :: !(Int),nt_Inh_CVisits :: !(NontermIdent),o_case_Inh_CVisits :: !(Bool),o_cata_Inh_CVisits :: !(Bool),o_costcentre_Inh_CVisits :: !(Bool),o_data_Inh_CVisits :: !((Maybe Bool)),o_linePragmas_Inh_CVisits :: !(Bool),o_monadic_Inh_CVisits :: !(Bool),o_newtypes_Inh_CVisits :: !(Bool),o_pretty_Inh_CVisits :: !(Bool),o_rename_Inh_CVisits :: !(Bool),o_sem_Inh_CVisits :: !(Bool),o_sig_Inh_CVisits :: !(Bool),o_splitsems_Inh_CVisits :: !(Bool),o_strictwrap_Inh_CVisits :: !(Bool),o_traces_Inh_CVisits :: !(Bool),o_unbox_Inh_CVisits :: !(Bool),paramInstMap_Inh_CVisits :: !((Map Identifier (NontermIdent, [String]))),paramMap_Inh_CVisits :: !(ParamMap),prefix_Inh_CVisits :: !(String),syn_Inh_CVisits :: !(Attributes),terminals_Inh_CVisits :: !(([Identifier])),unfoldSemDom_Inh_CVisits :: !((NontermIdent -> Int -> [String] -> Code.Type)),with_sig_Inh_CVisits :: !(Bool)} data Syn_CVisits = Syn_CVisits {allTpsFound_Syn_CVisits :: !(Bool),comments_Syn_CVisits :: !(([String])),decls_Syn_CVisits :: !(Decls),errors_Syn_CVisits :: !((Seq Error)),gatherInstVisitNrs_Syn_CVisits :: !((Map Identifier Int)),intra_Syn_CVisits :: !(Exprs),intraVars_Syn_CVisits :: !((Set String)),isNil_Syn_CVisits :: !(Bool),semNames_Syn_CVisits :: !(([String]))} wrap_CVisits :: T_CVisits -> Inh_CVisits -> Syn_CVisits wrap_CVisits (T_CVisits sem ) (Inh_CVisits _lhsIallNts _lhsIallPragmas _lhsIaroundMap _lhsIchildren _lhsIcon _lhsIcontextMap _lhsIerrors _lhsIinh _lhsIinstVisitNrs _lhsInr _lhsInt _lhsIo_case _lhsIo_cata _lhsIo_costcentre _lhsIo_data _lhsIo_linePragmas _lhsIo_monadic _lhsIo_newtypes _lhsIo_pretty _lhsIo_rename _lhsIo_sem _lhsIo_sig _lhsIo_splitsems _lhsIo_strictwrap _lhsIo_traces _lhsIo_unbox _lhsIparamInstMap _lhsIparamMap _lhsIprefix _lhsIsyn _lhsIterminals _lhsIunfoldSemDom _lhsIwith_sig ) = (let ( _lhsOallTpsFound,_lhsOcomments,_lhsOdecls,_lhsOerrors,_lhsOgatherInstVisitNrs,_lhsOintra,_lhsOintraVars,_lhsOisNil,_lhsOsemNames) = (sem _lhsIallNts _lhsIallPragmas _lhsIaroundMap _lhsIchildren _lhsIcon _lhsIcontextMap _lhsIerrors _lhsIinh _lhsIinstVisitNrs _lhsInr _lhsInt _lhsIo_case _lhsIo_cata _lhsIo_costcentre _lhsIo_data _lhsIo_linePragmas _lhsIo_monadic _lhsIo_newtypes _lhsIo_pretty _lhsIo_rename _lhsIo_sem _lhsIo_sig _lhsIo_splitsems _lhsIo_strictwrap _lhsIo_traces _lhsIo_unbox _lhsIparamInstMap _lhsIparamMap _lhsIprefix _lhsIsyn _lhsIterminals _lhsIunfoldSemDom _lhsIwith_sig ) in (Syn_CVisits _lhsOallTpsFound _lhsOcomments _lhsOdecls _lhsOerrors _lhsOgatherInstVisitNrs _lhsOintra _lhsOintraVars _lhsOisNil _lhsOsemNames )) sem_CVisits_Cons :: T_CVisit -> T_CVisits -> T_CVisits sem_CVisits_Cons (T_CVisit hd_ ) (T_CVisits tl_ ) = (T_CVisits (\ _lhsIallNts _lhsIallPragmas _lhsIaroundMap _lhsIchildren _lhsIcon _lhsIcontextMap _lhsIerrors _lhsIinh _lhsIinstVisitNrs _lhsInr _lhsInt _lhsIo_case _lhsIo_cata _lhsIo_costcentre _lhsIo_data _lhsIo_linePragmas _lhsIo_monadic _lhsIo_newtypes _lhsIo_pretty _lhsIo_rename _lhsIo_sem _lhsIo_sig _lhsIo_splitsems _lhsIo_strictwrap _lhsIo_traces _lhsIo_unbox _lhsIparamInstMap _lhsIparamMap _lhsIprefix _lhsIsyn _lhsIterminals _lhsIunfoldSemDom _lhsIwith_sig -> (let _tlOnr :: Int _lhsOisNil :: Bool _hdOisLast :: Bool _hdOnextIntra :: Exprs _hdOnextIntraVars :: (Set String) _lhsOintra :: Exprs _lhsOintraVars :: (Set String) _lhsOallTpsFound :: Bool _lhsOcomments :: ([String]) _lhsOdecls :: Decls _lhsOerrors :: (Seq Error) _lhsOgatherInstVisitNrs :: (Map Identifier Int) _lhsOsemNames :: ([String]) _hdOallNts :: (Set NontermIdent) _hdOallPragmas :: PragmaMap _hdOaroundMap :: (Set Identifier) _hdOchildren :: ([(Identifier,Type,Bool)]) _hdOcon :: ConstructorIdent _hdOcontextMap :: ContextMap _hdOerrors :: (Seq Error) _hdOinh :: Attributes _hdOinstVisitNrs :: (Map Identifier Int) _hdOnr :: Int _hdOnt :: NontermIdent _hdOo_case :: Bool _hdOo_cata :: Bool _hdOo_costcentre :: Bool _hdOo_data :: (Maybe Bool) _hdOo_linePragmas :: Bool _hdOo_monadic :: Bool _hdOo_newtypes :: Bool _hdOo_pretty :: Bool _hdOo_rename :: Bool _hdOo_sem :: Bool _hdOo_sig :: Bool _hdOo_splitsems :: Bool _hdOo_strictwrap :: Bool _hdOo_traces :: Bool _hdOo_unbox :: Bool _hdOparamInstMap :: (Map Identifier (NontermIdent, [String])) _hdOparamMap :: ParamMap _hdOprefix :: String _hdOsyn :: Attributes _hdOterminals :: ([Identifier]) _hdOunfoldSemDom :: (NontermIdent -> Int -> [String] -> Code.Type) _hdOwith_sig :: Bool _tlOallNts :: (Set NontermIdent) _tlOallPragmas :: PragmaMap _tlOaroundMap :: (Set Identifier) _tlOchildren :: ([(Identifier,Type,Bool)]) _tlOcon :: ConstructorIdent _tlOcontextMap :: ContextMap _tlOerrors :: (Seq Error) _tlOinh :: Attributes _tlOinstVisitNrs :: (Map Identifier Int) _tlOnt :: NontermIdent _tlOo_case :: Bool _tlOo_cata :: Bool _tlOo_costcentre :: Bool _tlOo_data :: (Maybe Bool) _tlOo_linePragmas :: Bool _tlOo_monadic :: Bool _tlOo_newtypes :: Bool _tlOo_pretty :: Bool _tlOo_rename :: Bool _tlOo_sem :: Bool _tlOo_sig :: Bool _tlOo_splitsems :: Bool _tlOo_strictwrap :: Bool _tlOo_traces :: Bool _tlOo_unbox :: Bool _tlOparamInstMap :: (Map Identifier (NontermIdent, [String])) _tlOparamMap :: ParamMap _tlOprefix :: String _tlOsyn :: Attributes _tlOterminals :: ([Identifier]) _tlOunfoldSemDom :: (NontermIdent -> Int -> [String] -> Code.Type) _tlOwith_sig :: Bool _hdIallTpsFound :: Bool _hdIcomments :: ([String]) _hdIdecls :: Decls _hdIerrors :: (Seq Error) _hdIgatherInstVisitNrs :: (Map Identifier Int) _hdIintra :: Exprs _hdIintraVars :: (Set String) _hdIsemNames :: ([String]) _tlIallTpsFound :: Bool _tlIcomments :: ([String]) _tlIdecls :: Decls _tlIerrors :: (Seq Error) _tlIgatherInstVisitNrs :: (Map Identifier Int) _tlIintra :: Exprs _tlIintraVars :: (Set String) _tlIisNil :: Bool _tlIsemNames :: ([String]) -- "GenerateCode.ag"(line 233, column 11) _tlOnr = ({-# LINE 233 "GenerateCode.ag" #-} _lhsInr + 1 {-# LINE 5168 "GenerateCode.hs" #-}) -- "GenerateCode.ag"(line 246, column 12) _lhsOisNil = ({-# LINE 246 "GenerateCode.ag" #-} False {-# LINE 5173 "GenerateCode.hs" #-}) -- "GenerateCode.ag"(line 247, column 12) _hdOisLast = ({-# LINE 247 "GenerateCode.ag" #-} _tlIisNil {-# LINE 5178 "GenerateCode.hs" #-}) -- "GenerateCode.ag"(line 264, column 12) _hdOnextIntra = ({-# LINE 264 "GenerateCode.ag" #-} _tlIintra {-# LINE 5183 "GenerateCode.hs" #-}) -- "GenerateCode.ag"(line 265, column 12) _hdOnextIntraVars = ({-# LINE 265 "GenerateCode.ag" #-} _tlIintraVars {-# LINE 5188 "GenerateCode.hs" #-}) -- "GenerateCode.ag"(line 266, column 12) _lhsOintra = ({-# LINE 266 "GenerateCode.ag" #-} _hdIintra {-# LINE 5193 "GenerateCode.hs" #-}) -- "GenerateCode.ag"(line 267, column 12) _lhsOintraVars = ({-# LINE 267 "GenerateCode.ag" #-} _hdIintraVars {-# LINE 5198 "GenerateCode.hs" #-}) -- use rule "GenerateCode.ag"(line 727, column 39) _lhsOallTpsFound = ({-# LINE 727 "GenerateCode.ag" #-} _hdIallTpsFound && _tlIallTpsFound {-# LINE 5203 "GenerateCode.hs" #-}) -- use rule "GenerateCode.ag"(line 759, column 52) _lhsOcomments = ({-# LINE 759 "GenerateCode.ag" #-} _hdIcomments ++ _tlIcomments {-# LINE 5208 "GenerateCode.hs" #-}) -- use rule "GenerateCode.ag"(line 372, column 33) _lhsOdecls = ({-# LINE 372 "GenerateCode.ag" #-} _hdIdecls ++ _tlIdecls {-# LINE 5213 "GenerateCode.hs" #-}) -- use rule "GenerateCode.ag"(line 740, column 32) _lhsOerrors = ({-# LINE 740 "GenerateCode.ag" #-} _hdIerrors Seq.>< _tlIerrors {-# LINE 5218 "GenerateCode.hs" #-}) -- use rule "GenerateCode.ag"(line 470, column 44) _lhsOgatherInstVisitNrs = ({-# LINE 470 "GenerateCode.ag" #-} _hdIgatherInstVisitNrs `Map.union` _tlIgatherInstVisitNrs {-# LINE 5223 "GenerateCode.hs" #-}) -- use rule "GenerateCode.ag"(line 1015, column 61) _lhsOsemNames = ({-# LINE 1015 "GenerateCode.ag" #-} _hdIsemNames ++ _tlIsemNames {-# LINE 5228 "GenerateCode.hs" #-}) -- copy rule (down) _hdOallNts = ({-# LINE 121 "GenerateCode.ag" #-} _lhsIallNts {-# LINE 5233 "GenerateCode.hs" #-}) -- copy rule (down) _hdOallPragmas = ({-# LINE 67 "GenerateCode.ag" #-} _lhsIallPragmas {-# LINE 5238 "GenerateCode.hs" #-}) -- copy rule (down) _hdOaroundMap = ({-# LINE 489 "GenerateCode.ag" #-} _lhsIaroundMap {-# LINE 5243 "GenerateCode.hs" #-}) -- copy rule (down) _hdOchildren = ({-# LINE 355 "GenerateCode.ag" #-} _lhsIchildren {-# LINE 5248 "GenerateCode.hs" #-}) -- copy rule (down) _hdOcon = ({-# LINE 83 "GenerateCode.ag" #-} _lhsIcon {-# LINE 5253 "GenerateCode.hs" #-}) -- copy rule (down) _hdOcontextMap = ({-# LINE 109 "GenerateCode.ag" #-} _lhsIcontextMap {-# LINE 5258 "GenerateCode.hs" #-}) -- copy rule (down) _hdOerrors = ({-# LINE 740 "GenerateCode.ag" #-} _lhsIerrors {-# LINE 5263 "GenerateCode.hs" #-}) -- copy rule (down) _hdOinh = ({-# LINE 78 "GenerateCode.ag" #-} _lhsIinh {-# LINE 5268 "GenerateCode.hs" #-}) -- copy rule (down) _hdOinstVisitNrs = ({-# LINE 469 "GenerateCode.ag" #-} _lhsIinstVisitNrs {-# LINE 5273 "GenerateCode.hs" #-}) -- copy rule (down) _hdOnr = ({-# LINE 229 "GenerateCode.ag" #-} _lhsInr {-# LINE 5278 "GenerateCode.hs" #-}) -- copy rule (down) _hdOnt = ({-# LINE 78 "GenerateCode.ag" #-} _lhsInt {-# LINE 5283 "GenerateCode.hs" #-}) -- copy rule (down) _hdOo_case = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_case {-# LINE 5288 "GenerateCode.hs" #-}) -- copy rule (down) _hdOo_cata = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_cata {-# LINE 5293 "GenerateCode.hs" #-}) -- copy rule (down) _hdOo_costcentre = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_costcentre {-# LINE 5298 "GenerateCode.hs" #-}) -- copy rule (down) _hdOo_data = ({-# LINE 46 "GenerateCode.ag" #-} _lhsIo_data {-# LINE 5303 "GenerateCode.hs" #-}) -- copy rule (down) _hdOo_linePragmas = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_linePragmas {-# LINE 5308 "GenerateCode.hs" #-}) -- copy rule (down) _hdOo_monadic = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_monadic {-# LINE 5313 "GenerateCode.hs" #-}) -- copy rule (down) _hdOo_newtypes = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_newtypes {-# LINE 5318 "GenerateCode.hs" #-}) -- copy rule (down) _hdOo_pretty = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_pretty {-# LINE 5323 "GenerateCode.hs" #-}) -- copy rule (down) _hdOo_rename = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_rename {-# LINE 5328 "GenerateCode.hs" #-}) -- copy rule (down) _hdOo_sem = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_sem {-# LINE 5333 "GenerateCode.hs" #-}) -- copy rule (down) _hdOo_sig = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_sig {-# LINE 5338 "GenerateCode.hs" #-}) -- copy rule (down) _hdOo_splitsems = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_splitsems {-# LINE 5343 "GenerateCode.hs" #-}) -- copy rule (down) _hdOo_strictwrap = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_strictwrap {-# LINE 5348 "GenerateCode.hs" #-}) -- copy rule (down) _hdOo_traces = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_traces {-# LINE 5353 "GenerateCode.hs" #-}) -- copy rule (down) _hdOo_unbox = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_unbox {-# LINE 5358 "GenerateCode.hs" #-}) -- copy rule (down) _hdOparamInstMap = ({-# LINE 95 "GenerateCode.ag" #-} _lhsIparamInstMap {-# LINE 5363 "GenerateCode.hs" #-}) -- copy rule (down) _hdOparamMap = ({-# LINE 89 "GenerateCode.ag" #-} _lhsIparamMap {-# LINE 5368 "GenerateCode.hs" #-}) -- copy rule (down) _hdOprefix = ({-# LINE 47 "GenerateCode.ag" #-} _lhsIprefix {-# LINE 5373 "GenerateCode.hs" #-}) -- copy rule (down) _hdOsyn = ({-# LINE 78 "GenerateCode.ag" #-} _lhsIsyn {-# LINE 5378 "GenerateCode.hs" #-}) -- copy rule (down) _hdOterminals = ({-# LINE 84 "GenerateCode.ag" #-} _lhsIterminals {-# LINE 5383 "GenerateCode.hs" #-}) -- copy rule (down) _hdOunfoldSemDom = ({-# LINE 628 "GenerateCode.ag" #-} _lhsIunfoldSemDom {-# LINE 5388 "GenerateCode.hs" #-}) -- copy rule (down) _hdOwith_sig = ({-# LINE 730 "GenerateCode.ag" #-} _lhsIwith_sig {-# LINE 5393 "GenerateCode.hs" #-}) -- copy rule (down) _tlOallNts = ({-# LINE 121 "GenerateCode.ag" #-} _lhsIallNts {-# LINE 5398 "GenerateCode.hs" #-}) -- copy rule (down) _tlOallPragmas = ({-# LINE 67 "GenerateCode.ag" #-} _lhsIallPragmas {-# LINE 5403 "GenerateCode.hs" #-}) -- copy rule (down) _tlOaroundMap = ({-# LINE 489 "GenerateCode.ag" #-} _lhsIaroundMap {-# LINE 5408 "GenerateCode.hs" #-}) -- copy rule (down) _tlOchildren = ({-# LINE 355 "GenerateCode.ag" #-} _lhsIchildren {-# LINE 5413 "GenerateCode.hs" #-}) -- copy rule (down) _tlOcon = ({-# LINE 83 "GenerateCode.ag" #-} _lhsIcon {-# LINE 5418 "GenerateCode.hs" #-}) -- copy rule (down) _tlOcontextMap = ({-# LINE 109 "GenerateCode.ag" #-} _lhsIcontextMap {-# LINE 5423 "GenerateCode.hs" #-}) -- copy rule (chain) _tlOerrors = ({-# LINE 740 "GenerateCode.ag" #-} _hdIerrors {-# LINE 5428 "GenerateCode.hs" #-}) -- copy rule (down) _tlOinh = ({-# LINE 78 "GenerateCode.ag" #-} _lhsIinh {-# LINE 5433 "GenerateCode.hs" #-}) -- copy rule (down) _tlOinstVisitNrs = ({-# LINE 469 "GenerateCode.ag" #-} _lhsIinstVisitNrs {-# LINE 5438 "GenerateCode.hs" #-}) -- copy rule (down) _tlOnt = ({-# LINE 78 "GenerateCode.ag" #-} _lhsInt {-# LINE 5443 "GenerateCode.hs" #-}) -- copy rule (down) _tlOo_case = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_case {-# LINE 5448 "GenerateCode.hs" #-}) -- copy rule (down) _tlOo_cata = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_cata {-# LINE 5453 "GenerateCode.hs" #-}) -- copy rule (down) _tlOo_costcentre = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_costcentre {-# LINE 5458 "GenerateCode.hs" #-}) -- copy rule (down) _tlOo_data = ({-# LINE 46 "GenerateCode.ag" #-} _lhsIo_data {-# LINE 5463 "GenerateCode.hs" #-}) -- copy rule (down) _tlOo_linePragmas = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_linePragmas {-# LINE 5468 "GenerateCode.hs" #-}) -- copy rule (down) _tlOo_monadic = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_monadic {-# LINE 5473 "GenerateCode.hs" #-}) -- copy rule (down) _tlOo_newtypes = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_newtypes {-# LINE 5478 "GenerateCode.hs" #-}) -- copy rule (down) _tlOo_pretty = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_pretty {-# LINE 5483 "GenerateCode.hs" #-}) -- copy rule (down) _tlOo_rename = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_rename {-# LINE 5488 "GenerateCode.hs" #-}) -- copy rule (down) _tlOo_sem = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_sem {-# LINE 5493 "GenerateCode.hs" #-}) -- copy rule (down) _tlOo_sig = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_sig {-# LINE 5498 "GenerateCode.hs" #-}) -- copy rule (down) _tlOo_splitsems = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_splitsems {-# LINE 5503 "GenerateCode.hs" #-}) -- copy rule (down) _tlOo_strictwrap = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_strictwrap {-# LINE 5508 "GenerateCode.hs" #-}) -- copy rule (down) _tlOo_traces = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_traces {-# LINE 5513 "GenerateCode.hs" #-}) -- copy rule (down) _tlOo_unbox = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_unbox {-# LINE 5518 "GenerateCode.hs" #-}) -- copy rule (down) _tlOparamInstMap = ({-# LINE 95 "GenerateCode.ag" #-} _lhsIparamInstMap {-# LINE 5523 "GenerateCode.hs" #-}) -- copy rule (down) _tlOparamMap = ({-# LINE 89 "GenerateCode.ag" #-} _lhsIparamMap {-# LINE 5528 "GenerateCode.hs" #-}) -- copy rule (down) _tlOprefix = ({-# LINE 47 "GenerateCode.ag" #-} _lhsIprefix {-# LINE 5533 "GenerateCode.hs" #-}) -- copy rule (down) _tlOsyn = ({-# LINE 78 "GenerateCode.ag" #-} _lhsIsyn {-# LINE 5538 "GenerateCode.hs" #-}) -- copy rule (down) _tlOterminals = ({-# LINE 84 "GenerateCode.ag" #-} _lhsIterminals {-# LINE 5543 "GenerateCode.hs" #-}) -- copy rule (down) _tlOunfoldSemDom = ({-# LINE 628 "GenerateCode.ag" #-} _lhsIunfoldSemDom {-# LINE 5548 "GenerateCode.hs" #-}) -- copy rule (down) _tlOwith_sig = ({-# LINE 730 "GenerateCode.ag" #-} _lhsIwith_sig {-# LINE 5553 "GenerateCode.hs" #-}) ( _hdIallTpsFound,_hdIcomments,_hdIdecls,_hdIerrors,_hdIgatherInstVisitNrs,_hdIintra,_hdIintraVars,_hdIsemNames) = (hd_ _hdOallNts _hdOallPragmas _hdOaroundMap _hdOchildren _hdOcon _hdOcontextMap _hdOerrors _hdOinh _hdOinstVisitNrs _hdOisLast _hdOnextIntra _hdOnextIntraVars _hdOnr _hdOnt _hdOo_case _hdOo_cata _hdOo_costcentre _hdOo_data _hdOo_linePragmas _hdOo_monadic _hdOo_newtypes _hdOo_pretty _hdOo_rename _hdOo_sem _hdOo_sig _hdOo_splitsems _hdOo_strictwrap _hdOo_traces _hdOo_unbox _hdOparamInstMap _hdOparamMap _hdOprefix _hdOsyn _hdOterminals _hdOunfoldSemDom _hdOwith_sig ) ( _tlIallTpsFound,_tlIcomments,_tlIdecls,_tlIerrors,_tlIgatherInstVisitNrs,_tlIintra,_tlIintraVars,_tlIisNil,_tlIsemNames) = (tl_ _tlOallNts _tlOallPragmas _tlOaroundMap _tlOchildren _tlOcon _tlOcontextMap _tlOerrors _tlOinh _tlOinstVisitNrs _tlOnr _tlOnt _tlOo_case _tlOo_cata _tlOo_costcentre _tlOo_data _tlOo_linePragmas _tlOo_monadic _tlOo_newtypes _tlOo_pretty _tlOo_rename _tlOo_sem _tlOo_sig _tlOo_splitsems _tlOo_strictwrap _tlOo_traces _tlOo_unbox _tlOparamInstMap _tlOparamMap _tlOprefix _tlOsyn _tlOterminals _tlOunfoldSemDom _tlOwith_sig ) in ( _lhsOallTpsFound,_lhsOcomments,_lhsOdecls,_lhsOerrors,_lhsOgatherInstVisitNrs,_lhsOintra,_lhsOintraVars,_lhsOisNil,_lhsOsemNames))) ) sem_CVisits_Nil :: T_CVisits sem_CVisits_Nil = (T_CVisits (\ _lhsIallNts _lhsIallPragmas _lhsIaroundMap _lhsIchildren _lhsIcon _lhsIcontextMap _lhsIerrors _lhsIinh _lhsIinstVisitNrs _lhsInr _lhsInt _lhsIo_case _lhsIo_cata _lhsIo_costcentre _lhsIo_data _lhsIo_linePragmas _lhsIo_monadic _lhsIo_newtypes _lhsIo_pretty _lhsIo_rename _lhsIo_sem _lhsIo_sig _lhsIo_splitsems _lhsIo_strictwrap _lhsIo_traces _lhsIo_unbox _lhsIparamInstMap _lhsIparamMap _lhsIprefix _lhsIsyn _lhsIterminals _lhsIunfoldSemDom _lhsIwith_sig -> (let _lhsOisNil :: Bool _lhsOintra :: Exprs _lhsOintraVars :: (Set String) _lhsOallTpsFound :: Bool _lhsOcomments :: ([String]) _lhsOdecls :: Decls _lhsOerrors :: (Seq Error) _lhsOgatherInstVisitNrs :: (Map Identifier Int) _lhsOsemNames :: ([String]) -- "GenerateCode.ag"(line 248, column 10) _lhsOisNil = ({-# LINE 248 "GenerateCode.ag" #-} True {-# LINE 5607 "GenerateCode.hs" #-}) -- "GenerateCode.ag"(line 268, column 10) _lhsOintra = ({-# LINE 268 "GenerateCode.ag" #-} [] {-# LINE 5612 "GenerateCode.hs" #-}) -- "GenerateCode.ag"(line 269, column 10) _lhsOintraVars = ({-# LINE 269 "GenerateCode.ag" #-} Set.empty {-# LINE 5617 "GenerateCode.hs" #-}) -- use rule "GenerateCode.ag"(line 727, column 39) _lhsOallTpsFound = ({-# LINE 727 "GenerateCode.ag" #-} True {-# LINE 5622 "GenerateCode.hs" #-}) -- use rule "GenerateCode.ag"(line 759, column 52) _lhsOcomments = ({-# LINE 759 "GenerateCode.ag" #-} [] {-# LINE 5627 "GenerateCode.hs" #-}) -- use rule "GenerateCode.ag"(line 372, column 33) _lhsOdecls = ({-# LINE 372 "GenerateCode.ag" #-} [] {-# LINE 5632 "GenerateCode.hs" #-}) -- use rule "GenerateCode.ag"(line 740, column 32) _lhsOerrors = ({-# LINE 740 "GenerateCode.ag" #-} Seq.empty {-# LINE 5637 "GenerateCode.hs" #-}) -- use rule "GenerateCode.ag"(line 470, column 44) _lhsOgatherInstVisitNrs = ({-# LINE 470 "GenerateCode.ag" #-} Map.empty {-# LINE 5642 "GenerateCode.hs" #-}) -- use rule "GenerateCode.ag"(line 1015, column 61) _lhsOsemNames = ({-# LINE 1015 "GenerateCode.ag" #-} [] {-# LINE 5647 "GenerateCode.hs" #-}) in ( _lhsOallTpsFound,_lhsOcomments,_lhsOdecls,_lhsOerrors,_lhsOgatherInstVisitNrs,_lhsOintra,_lhsOintraVars,_lhsOisNil,_lhsOsemNames))) ) -- DeclBlocks -------------------------------------------------- {- visit 0: inherited attributes: blockNr : Int lastExprVars : [String] nextVisitDecls : [Decl] optCase : Bool prefix : String synthesized attributes: callExpr : Expr decls : [Decl] freeVars : [String] alternatives: alternative DeclBlock: child defs : {[Decl]} child visit : {Decl} child next : DeclBlocks visit 0: local lambdaName : _ local pragmaDecl : _ local freeVars : _ local decl : _ alternative DeclTerminator: child defs : {[Decl]} child result : {Expr} visit 0: local lambdaName : _ local pragmaDecl : _ local freeVars : _ -} -- cata sem_DeclBlocks :: DeclBlocks -> T_DeclBlocks sem_DeclBlocks (DeclBlock _defs _visit _next ) = (sem_DeclBlocks_DeclBlock _defs _visit (sem_DeclBlocks _next ) ) sem_DeclBlocks (DeclTerminator _defs _result ) = (sem_DeclBlocks_DeclTerminator _defs _result ) -- semantic domain newtype T_DeclBlocks = T_DeclBlocks (Int -> ([String]) -> ([Decl]) -> Bool -> String -> ( Expr,([Decl]),([String]))) data Inh_DeclBlocks = Inh_DeclBlocks {blockNr_Inh_DeclBlocks :: !(Int),lastExprVars_Inh_DeclBlocks :: !(([String])),nextVisitDecls_Inh_DeclBlocks :: !(([Decl])),optCase_Inh_DeclBlocks :: !(Bool),prefix_Inh_DeclBlocks :: !(String)} data Syn_DeclBlocks = Syn_DeclBlocks {callExpr_Syn_DeclBlocks :: !(Expr),decls_Syn_DeclBlocks :: !(([Decl])),freeVars_Syn_DeclBlocks :: !(([String]))} wrap_DeclBlocks :: T_DeclBlocks -> Inh_DeclBlocks -> Syn_DeclBlocks wrap_DeclBlocks (T_DeclBlocks sem ) (Inh_DeclBlocks _lhsIblockNr _lhsIlastExprVars _lhsInextVisitDecls _lhsIoptCase _lhsIprefix ) = (let ( _lhsOcallExpr,_lhsOdecls,_lhsOfreeVars) = (sem _lhsIblockNr _lhsIlastExprVars _lhsInextVisitDecls _lhsIoptCase _lhsIprefix ) in (Syn_DeclBlocks _lhsOcallExpr _lhsOdecls _lhsOfreeVars )) sem_DeclBlocks_DeclBlock :: ([Decl]) -> Decl -> T_DeclBlocks -> T_DeclBlocks sem_DeclBlocks_DeclBlock defs_ visit_ (T_DeclBlocks next_ ) = (T_DeclBlocks (\ _lhsIblockNr _lhsIlastExprVars _lhsInextVisitDecls _lhsIoptCase _lhsIprefix -> (let _nextOblockNr :: Int _lhsOcallExpr :: Expr _lhsOdecls :: ([Decl]) _lhsOfreeVars :: ([String]) _nextOlastExprVars :: ([String]) _nextOnextVisitDecls :: ([Decl]) _nextOoptCase :: Bool _nextOprefix :: String _nextIcallExpr :: Expr _nextIdecls :: ([Decl]) _nextIfreeVars :: ([String]) -- "GenerateCode.ag"(line 555, column 7) _nextOblockNr = ({-# LINE 555 "GenerateCode.ag" #-} _lhsIblockNr + 1 {-# LINE 5728 "GenerateCode.hs" #-}) -- "GenerateCode.ag"(line 560, column 7) _lambdaName = ({-# LINE 560 "GenerateCode.ag" #-} _lhsIprefix ++ "_block" ++ show _lhsIblockNr {-# LINE 5733 "GenerateCode.hs" #-}) -- "GenerateCode.ag"(line 561, column 7) _pragmaDecl = ({-# LINE 561 "GenerateCode.ag" #-} PragmaDecl ("NOINLINE " ++ _lambdaName ) {-# LINE 5738 "GenerateCode.hs" #-}) -- "GenerateCode.ag"(line 562, column 7) _lhsOcallExpr = ({-# LINE 562 "GenerateCode.ag" #-} App _lambdaName (map SimpleExpr _freeVars ) {-# LINE 5743 "GenerateCode.hs" #-}) -- "GenerateCode.ag"(line 566, column 7) _freeVars = ({-# LINE 566 "GenerateCode.ag" #-} freevars _nextIfreeVars (visit_ : defs_) {-# LINE 5748 "GenerateCode.hs" #-}) -- "GenerateCode.ag"(line 573, column 7) _decl = ({-# LINE 573 "GenerateCode.ag" #-} mkBlockLambda _lhsIoptCase _lambdaName _freeVars (defs_ ++ [visit_]) _nextIcallExpr {-# LINE 5753 "GenerateCode.hs" #-}) -- "GenerateCode.ag"(line 574, column 7) _lhsOdecls = ({-# LINE 574 "GenerateCode.ag" #-} (if _lhsIblockNr > 1 then [_pragmaDecl ] else []) ++ [_decl ] ++ _nextIdecls {-# LINE 5758 "GenerateCode.hs" #-}) -- copy rule (from local) _lhsOfreeVars = ({-# LINE 557 "GenerateCode.ag" #-} _freeVars {-# LINE 5763 "GenerateCode.hs" #-}) -- copy rule (down) _nextOlastExprVars = ({-# LINE 541 "GenerateCode.ag" #-} _lhsIlastExprVars {-# LINE 5768 "GenerateCode.hs" #-}) -- copy rule (down) _nextOnextVisitDecls = ({-# LINE 541 "GenerateCode.ag" #-} _lhsInextVisitDecls {-# LINE 5773 "GenerateCode.hs" #-}) -- copy rule (down) _nextOoptCase = ({-# LINE 541 "GenerateCode.ag" #-} _lhsIoptCase {-# LINE 5778 "GenerateCode.hs" #-}) -- copy rule (down) _nextOprefix = ({-# LINE 541 "GenerateCode.ag" #-} _lhsIprefix {-# LINE 5783 "GenerateCode.hs" #-}) ( _nextIcallExpr,_nextIdecls,_nextIfreeVars) = (next_ _nextOblockNr _nextOlastExprVars _nextOnextVisitDecls _nextOoptCase _nextOprefix ) in ( _lhsOcallExpr,_lhsOdecls,_lhsOfreeVars))) ) sem_DeclBlocks_DeclTerminator :: ([Decl]) -> Expr -> T_DeclBlocks sem_DeclBlocks_DeclTerminator defs_ result_ = (T_DeclBlocks (\ _lhsIblockNr _lhsIlastExprVars _lhsInextVisitDecls _lhsIoptCase _lhsIprefix -> (let _lhsOcallExpr :: Expr _lhsOdecls :: ([Decl]) _lhsOfreeVars :: ([String]) -- "GenerateCode.ag"(line 560, column 7) _lambdaName = ({-# LINE 560 "GenerateCode.ag" #-} _lhsIprefix ++ "_block" ++ show _lhsIblockNr {-# LINE 5803 "GenerateCode.hs" #-}) -- "GenerateCode.ag"(line 561, column 7) _pragmaDecl = ({-# LINE 561 "GenerateCode.ag" #-} PragmaDecl ("NOINLINE " ++ _lambdaName ) {-# LINE 5808 "GenerateCode.hs" #-}) -- "GenerateCode.ag"(line 562, column 7) _lhsOcallExpr = ({-# LINE 562 "GenerateCode.ag" #-} App _lambdaName (map SimpleExpr _freeVars ) {-# LINE 5813 "GenerateCode.hs" #-}) -- "GenerateCode.ag"(line 564, column 7) _freeVars = ({-# LINE 564 "GenerateCode.ag" #-} freevars _lhsIlastExprVars (defs_ ++ _lhsInextVisitDecls) {-# LINE 5818 "GenerateCode.hs" #-}) -- "GenerateCode.ag"(line 571, column 7) _lhsOdecls = ({-# LINE 571 "GenerateCode.ag" #-} [ mkBlockLambda _lhsIoptCase _lambdaName _freeVars (defs_ ++ _lhsInextVisitDecls) result_ ] {-# LINE 5823 "GenerateCode.hs" #-}) -- copy rule (from local) _lhsOfreeVars = ({-# LINE 557 "GenerateCode.ag" #-} _freeVars {-# LINE 5828 "GenerateCode.hs" #-}) in ( _lhsOcallExpr,_lhsOdecls,_lhsOfreeVars))) ) -- DeclBlocksRoot ---------------------------------------------- {- visit 0: inherited attributes: lastExprVars : [String] nextVisitDecls : [Decl] optCase : Bool prefix : String synthesized attributes: firstCall : Expr lambdas : [Decl] alternatives: alternative DeclBlocksRoot: child blocks : DeclBlocks -} -- cata sem_DeclBlocksRoot :: DeclBlocksRoot -> T_DeclBlocksRoot sem_DeclBlocksRoot (DeclBlocksRoot _blocks ) = (sem_DeclBlocksRoot_DeclBlocksRoot (sem_DeclBlocks _blocks ) ) -- semantic domain newtype T_DeclBlocksRoot = T_DeclBlocksRoot (([String]) -> ([Decl]) -> Bool -> String -> ( Expr,([Decl]))) data Inh_DeclBlocksRoot = Inh_DeclBlocksRoot {lastExprVars_Inh_DeclBlocksRoot :: !(([String])),nextVisitDecls_Inh_DeclBlocksRoot :: !(([Decl])),optCase_Inh_DeclBlocksRoot :: !(Bool),prefix_Inh_DeclBlocksRoot :: !(String)} data Syn_DeclBlocksRoot = Syn_DeclBlocksRoot {firstCall_Syn_DeclBlocksRoot :: !(Expr),lambdas_Syn_DeclBlocksRoot :: !(([Decl]))} wrap_DeclBlocksRoot :: T_DeclBlocksRoot -> Inh_DeclBlocksRoot -> Syn_DeclBlocksRoot wrap_DeclBlocksRoot (T_DeclBlocksRoot sem ) (Inh_DeclBlocksRoot _lhsIlastExprVars _lhsInextVisitDecls _lhsIoptCase _lhsIprefix ) = (let ( _lhsOfirstCall,_lhsOlambdas) = (sem _lhsIlastExprVars _lhsInextVisitDecls _lhsIoptCase _lhsIprefix ) in (Syn_DeclBlocksRoot _lhsOfirstCall _lhsOlambdas )) sem_DeclBlocksRoot_DeclBlocksRoot :: T_DeclBlocks -> T_DeclBlocksRoot sem_DeclBlocksRoot_DeclBlocksRoot (T_DeclBlocks blocks_ ) = (T_DeclBlocksRoot (\ _lhsIlastExprVars _lhsInextVisitDecls _lhsIoptCase _lhsIprefix -> (let _lhsOlambdas :: ([Decl]) _lhsOfirstCall :: Expr _blocksOblockNr :: Int _blocksOlastExprVars :: ([String]) _blocksOnextVisitDecls :: ([Decl]) _blocksOoptCase :: Bool _blocksOprefix :: String _blocksIcallExpr :: Expr _blocksIdecls :: ([Decl]) _blocksIfreeVars :: ([String]) -- "GenerateCode.ag"(line 546, column 7) _lhsOlambdas = ({-# LINE 546 "GenerateCode.ag" #-} _blocksIdecls {-# LINE 5886 "GenerateCode.hs" #-}) -- "GenerateCode.ag"(line 547, column 7) _lhsOfirstCall = ({-# LINE 547 "GenerateCode.ag" #-} _blocksIcallExpr {-# LINE 5891 "GenerateCode.hs" #-}) -- "GenerateCode.ag"(line 552, column 7) _blocksOblockNr = ({-# LINE 552 "GenerateCode.ag" #-} 1 {-# LINE 5896 "GenerateCode.hs" #-}) -- copy rule (down) _blocksOlastExprVars = ({-# LINE 541 "GenerateCode.ag" #-} _lhsIlastExprVars {-# LINE 5901 "GenerateCode.hs" #-}) -- copy rule (down) _blocksOnextVisitDecls = ({-# LINE 541 "GenerateCode.ag" #-} _lhsInextVisitDecls {-# LINE 5906 "GenerateCode.hs" #-}) -- copy rule (down) _blocksOoptCase = ({-# LINE 541 "GenerateCode.ag" #-} _lhsIoptCase {-# LINE 5911 "GenerateCode.hs" #-}) -- copy rule (down) _blocksOprefix = ({-# LINE 541 "GenerateCode.ag" #-} _lhsIprefix {-# LINE 5916 "GenerateCode.hs" #-}) ( _blocksIcallExpr,_blocksIdecls,_blocksIfreeVars) = (blocks_ _blocksOblockNr _blocksOlastExprVars _blocksOnextVisitDecls _blocksOoptCase _blocksOprefix ) in ( _lhsOfirstCall,_lhsOlambdas))) ) -- Pattern ----------------------------------------------------- {- visit 0: synthesized attributes: copy : SELF definedInsts : [Identifier] patternAttributes : [(Identifier, Identifier)] alternatives: alternative Alias: child field : {Identifier} child attr : {Identifier} child pat : Pattern child parts : Patterns visit 0: local copy : _ alternative Constr: child name : {ConstructorIdent} child pats : Patterns visit 0: local copy : _ alternative Irrefutable: child pat : Pattern visit 0: local copy : _ alternative Product: child pos : {Pos} child pats : Patterns visit 0: local copy : _ alternative Underscore: child pos : {Pos} visit 0: local copy : _ -} -- cata sem_Pattern :: Pattern -> T_Pattern sem_Pattern (Alias _field _attr _pat _parts ) = (sem_Pattern_Alias _field _attr (sem_Pattern _pat ) (sem_Patterns _parts ) ) sem_Pattern (Constr _name _pats ) = (sem_Pattern_Constr _name (sem_Patterns _pats ) ) sem_Pattern (Irrefutable _pat ) = (sem_Pattern_Irrefutable (sem_Pattern _pat ) ) sem_Pattern (Product _pos _pats ) = (sem_Pattern_Product _pos (sem_Patterns _pats ) ) sem_Pattern (Underscore _pos ) = (sem_Pattern_Underscore _pos ) -- semantic domain newtype T_Pattern = T_Pattern (( Pattern ,([Identifier]),([(Identifier, Identifier)]))) data Inh_Pattern = Inh_Pattern {} data Syn_Pattern = Syn_Pattern {copy_Syn_Pattern :: !(Pattern ),definedInsts_Syn_Pattern :: !(([Identifier])),patternAttributes_Syn_Pattern :: !(([(Identifier, Identifier)]))} wrap_Pattern :: T_Pattern -> Inh_Pattern -> Syn_Pattern wrap_Pattern (T_Pattern sem ) (Inh_Pattern ) = (let ( _lhsOcopy,_lhsOdefinedInsts,_lhsOpatternAttributes) = (sem ) in (Syn_Pattern _lhsOcopy _lhsOdefinedInsts _lhsOpatternAttributes )) sem_Pattern_Alias :: Identifier -> Identifier -> T_Pattern -> T_Patterns -> T_Pattern sem_Pattern_Alias field_ attr_ (T_Pattern pat_ ) (T_Patterns parts_ ) = (T_Pattern (let _lhsOdefinedInsts :: ([Identifier]) _lhsOpatternAttributes :: ([(Identifier, Identifier)]) _lhsOcopy :: Pattern _patIcopy :: Pattern _patIdefinedInsts :: ([Identifier]) _patIpatternAttributes :: ([(Identifier, Identifier)]) _partsIcopy :: Patterns _partsIdefinedInsts :: ([Identifier]) _partsIpatternAttributes :: ([(Identifier, Identifier)]) -- "GenerateCode.ag"(line 214, column 11) _lhsOdefinedInsts = ({-# LINE 214 "GenerateCode.ag" #-} (if field_ == _INST then [attr_] else []) ++ _patIdefinedInsts {-# LINE 5997 "GenerateCode.hs" #-}) -- "GenerateCode.ag"(line 222, column 7) _lhsOpatternAttributes = ({-# LINE 222 "GenerateCode.ag" #-} (field_,attr_) : (_patIpatternAttributes ++ _partsIpatternAttributes) {-# LINE 6002 "GenerateCode.hs" #-}) -- self rule _copy = ({-# LINE 23 "./Patterns.ag" #-} Alias field_ attr_ _patIcopy _partsIcopy {-# LINE 6007 "GenerateCode.hs" #-}) -- self rule _lhsOcopy = ({-# LINE 23 "./Patterns.ag" #-} _copy {-# LINE 6012 "GenerateCode.hs" #-}) ( _patIcopy,_patIdefinedInsts,_patIpatternAttributes) = (pat_ ) ( _partsIcopy,_partsIdefinedInsts,_partsIpatternAttributes) = (parts_ ) in ( _lhsOcopy,_lhsOdefinedInsts,_lhsOpatternAttributes)) ) sem_Pattern_Constr :: ConstructorIdent -> T_Patterns -> T_Pattern sem_Pattern_Constr name_ (T_Patterns pats_ ) = (T_Pattern (let _lhsOdefinedInsts :: ([Identifier]) _lhsOpatternAttributes :: ([(Identifier, Identifier)]) _lhsOcopy :: Pattern _patsIcopy :: Patterns _patsIdefinedInsts :: ([Identifier]) _patsIpatternAttributes :: ([(Identifier, Identifier)]) -- use rule "GenerateCode.ag"(line 212, column 55) _lhsOdefinedInsts = ({-# LINE 212 "GenerateCode.ag" #-} _patsIdefinedInsts {-# LINE 6032 "GenerateCode.hs" #-}) -- use rule "GenerateCode.ag"(line 219, column 47) _lhsOpatternAttributes = ({-# LINE 219 "GenerateCode.ag" #-} _patsIpatternAttributes {-# LINE 6037 "GenerateCode.hs" #-}) -- self rule _copy = ({-# LINE 23 "./Patterns.ag" #-} Constr name_ _patsIcopy {-# LINE 6042 "GenerateCode.hs" #-}) -- self rule _lhsOcopy = ({-# LINE 23 "./Patterns.ag" #-} _copy {-# LINE 6047 "GenerateCode.hs" #-}) ( _patsIcopy,_patsIdefinedInsts,_patsIpatternAttributes) = (pats_ ) in ( _lhsOcopy,_lhsOdefinedInsts,_lhsOpatternAttributes)) ) sem_Pattern_Irrefutable :: T_Pattern -> T_Pattern sem_Pattern_Irrefutable (T_Pattern pat_ ) = (T_Pattern (let _lhsOdefinedInsts :: ([Identifier]) _lhsOpatternAttributes :: ([(Identifier, Identifier)]) _lhsOcopy :: Pattern _patIcopy :: Pattern _patIdefinedInsts :: ([Identifier]) _patIpatternAttributes :: ([(Identifier, Identifier)]) -- use rule "GenerateCode.ag"(line 212, column 55) _lhsOdefinedInsts = ({-# LINE 212 "GenerateCode.ag" #-} _patIdefinedInsts {-# LINE 6064 "GenerateCode.hs" #-}) -- use rule "GenerateCode.ag"(line 219, column 47) _lhsOpatternAttributes = ({-# LINE 219 "GenerateCode.ag" #-} _patIpatternAttributes {-# LINE 6069 "GenerateCode.hs" #-}) -- self rule _copy = ({-# LINE 23 "./Patterns.ag" #-} Irrefutable _patIcopy {-# LINE 6074 "GenerateCode.hs" #-}) -- self rule _lhsOcopy = ({-# LINE 23 "./Patterns.ag" #-} _copy {-# LINE 6079 "GenerateCode.hs" #-}) ( _patIcopy,_patIdefinedInsts,_patIpatternAttributes) = (pat_ ) in ( _lhsOcopy,_lhsOdefinedInsts,_lhsOpatternAttributes)) ) sem_Pattern_Product :: Pos -> T_Patterns -> T_Pattern sem_Pattern_Product pos_ (T_Patterns pats_ ) = (T_Pattern (let _lhsOdefinedInsts :: ([Identifier]) _lhsOpatternAttributes :: ([(Identifier, Identifier)]) _lhsOcopy :: Pattern _patsIcopy :: Patterns _patsIdefinedInsts :: ([Identifier]) _patsIpatternAttributes :: ([(Identifier, Identifier)]) -- use rule "GenerateCode.ag"(line 212, column 55) _lhsOdefinedInsts = ({-# LINE 212 "GenerateCode.ag" #-} _patsIdefinedInsts {-# LINE 6097 "GenerateCode.hs" #-}) -- use rule "GenerateCode.ag"(line 219, column 47) _lhsOpatternAttributes = ({-# LINE 219 "GenerateCode.ag" #-} _patsIpatternAttributes {-# LINE 6102 "GenerateCode.hs" #-}) -- self rule _copy = ({-# LINE 23 "./Patterns.ag" #-} Product pos_ _patsIcopy {-# LINE 6107 "GenerateCode.hs" #-}) -- self rule _lhsOcopy = ({-# LINE 23 "./Patterns.ag" #-} _copy {-# LINE 6112 "GenerateCode.hs" #-}) ( _patsIcopy,_patsIdefinedInsts,_patsIpatternAttributes) = (pats_ ) in ( _lhsOcopy,_lhsOdefinedInsts,_lhsOpatternAttributes)) ) sem_Pattern_Underscore :: Pos -> T_Pattern sem_Pattern_Underscore pos_ = (T_Pattern (let _lhsOdefinedInsts :: ([Identifier]) _lhsOpatternAttributes :: ([(Identifier, Identifier)]) _lhsOcopy :: Pattern -- use rule "GenerateCode.ag"(line 212, column 55) _lhsOdefinedInsts = ({-# LINE 212 "GenerateCode.ag" #-} [] {-# LINE 6126 "GenerateCode.hs" #-}) -- use rule "GenerateCode.ag"(line 219, column 47) _lhsOpatternAttributes = ({-# LINE 219 "GenerateCode.ag" #-} [] {-# LINE 6131 "GenerateCode.hs" #-}) -- self rule _copy = ({-# LINE 23 "./Patterns.ag" #-} Underscore pos_ {-# LINE 6136 "GenerateCode.hs" #-}) -- self rule _lhsOcopy = ({-# LINE 23 "./Patterns.ag" #-} _copy {-# LINE 6141 "GenerateCode.hs" #-}) in ( _lhsOcopy,_lhsOdefinedInsts,_lhsOpatternAttributes)) ) -- Patterns ---------------------------------------------------- {- visit 0: synthesized attributes: copy : SELF definedInsts : [Identifier] patternAttributes : [(Identifier, Identifier)] alternatives: alternative Cons: child hd : Pattern child tl : Patterns visit 0: local copy : _ alternative Nil: visit 0: local copy : _ -} -- cata sem_Patterns :: Patterns -> T_Patterns sem_Patterns list = (Prelude.foldr sem_Patterns_Cons sem_Patterns_Nil (Prelude.map sem_Pattern list) ) -- semantic domain newtype T_Patterns = T_Patterns (( Patterns ,([Identifier]),([(Identifier, Identifier)]))) data Inh_Patterns = Inh_Patterns {} data Syn_Patterns = Syn_Patterns {copy_Syn_Patterns :: !(Patterns ),definedInsts_Syn_Patterns :: !(([Identifier])),patternAttributes_Syn_Patterns :: !(([(Identifier, Identifier)]))} wrap_Patterns :: T_Patterns -> Inh_Patterns -> Syn_Patterns wrap_Patterns (T_Patterns sem ) (Inh_Patterns ) = (let ( _lhsOcopy,_lhsOdefinedInsts,_lhsOpatternAttributes) = (sem ) in (Syn_Patterns _lhsOcopy _lhsOdefinedInsts _lhsOpatternAttributes )) sem_Patterns_Cons :: T_Pattern -> T_Patterns -> T_Patterns sem_Patterns_Cons (T_Pattern hd_ ) (T_Patterns tl_ ) = (T_Patterns (let _lhsOdefinedInsts :: ([Identifier]) _lhsOpatternAttributes :: ([(Identifier, Identifier)]) _lhsOcopy :: Patterns _hdIcopy :: Pattern _hdIdefinedInsts :: ([Identifier]) _hdIpatternAttributes :: ([(Identifier, Identifier)]) _tlIcopy :: Patterns _tlIdefinedInsts :: ([Identifier]) _tlIpatternAttributes :: ([(Identifier, Identifier)]) -- use rule "GenerateCode.ag"(line 212, column 55) _lhsOdefinedInsts = ({-# LINE 212 "GenerateCode.ag" #-} _hdIdefinedInsts ++ _tlIdefinedInsts {-# LINE 6193 "GenerateCode.hs" #-}) -- use rule "GenerateCode.ag"(line 219, column 47) _lhsOpatternAttributes = ({-# LINE 219 "GenerateCode.ag" #-} _hdIpatternAttributes ++ _tlIpatternAttributes {-# LINE 6198 "GenerateCode.hs" #-}) -- self rule _copy = ({-# LINE 23 "./Patterns.ag" #-} (:) _hdIcopy _tlIcopy {-# LINE 6203 "GenerateCode.hs" #-}) -- self rule _lhsOcopy = ({-# LINE 23 "./Patterns.ag" #-} _copy {-# LINE 6208 "GenerateCode.hs" #-}) ( _hdIcopy,_hdIdefinedInsts,_hdIpatternAttributes) = (hd_ ) ( _tlIcopy,_tlIdefinedInsts,_tlIpatternAttributes) = (tl_ ) in ( _lhsOcopy,_lhsOdefinedInsts,_lhsOpatternAttributes)) ) sem_Patterns_Nil :: T_Patterns sem_Patterns_Nil = (T_Patterns (let _lhsOdefinedInsts :: ([Identifier]) _lhsOpatternAttributes :: ([(Identifier, Identifier)]) _lhsOcopy :: Patterns -- use rule "GenerateCode.ag"(line 212, column 55) _lhsOdefinedInsts = ({-# LINE 212 "GenerateCode.ag" #-} [] {-# LINE 6223 "GenerateCode.hs" #-}) -- use rule "GenerateCode.ag"(line 219, column 47) _lhsOpatternAttributes = ({-# LINE 219 "GenerateCode.ag" #-} [] {-# LINE 6228 "GenerateCode.hs" #-}) -- self rule _copy = ({-# LINE 23 "./Patterns.ag" #-} [] {-# LINE 6233 "GenerateCode.hs" #-}) -- self rule _lhsOcopy = ({-# LINE 23 "./Patterns.ag" #-} _copy {-# LINE 6238 "GenerateCode.hs" #-}) in ( _lhsOcopy,_lhsOdefinedInsts,_lhsOpatternAttributes)) ) -- Sequence ---------------------------------------------------- {- visit 0: inherited attributes: allNts : Set NontermIdent aroundMap : Set Identifier children : [(Identifier,Type,Bool)] con : ConstructorIdent higherOrderChildren : [(Identifier,Type,Bool)] inh : Attributes instVisitNrs : Map Identifier Int lastExpr : Expr nr : Int nt : NontermIdent o_case : Bool o_cata : Bool o_costcentre : Bool o_data : Maybe Bool o_linePragmas : Bool o_monadic : Bool o_newtypes : Bool o_pretty : Bool o_rename : Bool o_sem : Bool o_sig : Bool o_splitsems : Bool o_strictwrap : Bool o_traces : Bool o_unbox : Bool paramInstMap : Map Identifier (NontermIdent, [String]) paramMap : ParamMap prefix : String syn : Attributes terminals : [Identifier] unfoldSemDom : NontermIdent -> Int -> [String] -> Code.Type what : String chained attributes: declsAbove : [Decl] errors : Seq Error synthesized attributes: allTpsFound : Bool blockDecls : DeclBlocks comments : [String] decls : Decls definedInsts : [Identifier] exprs : Exprs tSigs : [Decl] tps : [Type] usedVars : Set String alternatives: alternative Cons: child hd : CRule child tl : Sequence alternative Nil: -} -- cata sem_Sequence :: Sequence -> T_Sequence sem_Sequence list = (Prelude.foldr sem_Sequence_Cons sem_Sequence_Nil (Prelude.map sem_CRule list) ) -- semantic domain newtype T_Sequence = T_Sequence ((Set NontermIdent) -> (Set Identifier) -> ([(Identifier,Type,Bool)]) -> ConstructorIdent -> ([Decl]) -> (Seq Error) -> ([(Identifier,Type,Bool)]) -> Attributes -> (Map Identifier Int) -> Expr -> Int -> NontermIdent -> Bool -> Bool -> Bool -> (Maybe Bool) -> Bool -> Bool -> Bool -> Bool -> Bool -> Bool -> Bool -> Bool -> Bool -> Bool -> Bool -> (Map Identifier (NontermIdent, [String])) -> ParamMap -> String -> Attributes -> ([Identifier]) -> (NontermIdent -> Int -> [String] -> Code.Type) -> String -> ( Bool,DeclBlocks ,([String]),Decls,([Decl]),([Identifier]),(Seq Error),Exprs,([Decl]),([Type]),(Set String))) data Inh_Sequence = Inh_Sequence {allNts_Inh_Sequence :: !((Set NontermIdent)),aroundMap_Inh_Sequence :: !((Set Identifier)),children_Inh_Sequence :: !(([(Identifier,Type,Bool)])),con_Inh_Sequence :: !(ConstructorIdent),declsAbove_Inh_Sequence :: !(([Decl])),errors_Inh_Sequence :: !((Seq Error)),higherOrderChildren_Inh_Sequence :: !(([(Identifier,Type,Bool)])),inh_Inh_Sequence :: !(Attributes),instVisitNrs_Inh_Sequence :: !((Map Identifier Int)),lastExpr_Inh_Sequence :: !(Expr),nr_Inh_Sequence :: !(Int),nt_Inh_Sequence :: !(NontermIdent),o_case_Inh_Sequence :: !(Bool),o_cata_Inh_Sequence :: !(Bool),o_costcentre_Inh_Sequence :: !(Bool),o_data_Inh_Sequence :: !((Maybe Bool)),o_linePragmas_Inh_Sequence :: !(Bool),o_monadic_Inh_Sequence :: !(Bool),o_newtypes_Inh_Sequence :: !(Bool),o_pretty_Inh_Sequence :: !(Bool),o_rename_Inh_Sequence :: !(Bool),o_sem_Inh_Sequence :: !(Bool),o_sig_Inh_Sequence :: !(Bool),o_splitsems_Inh_Sequence :: !(Bool),o_strictwrap_Inh_Sequence :: !(Bool),o_traces_Inh_Sequence :: !(Bool),o_unbox_Inh_Sequence :: !(Bool),paramInstMap_Inh_Sequence :: !((Map Identifier (NontermIdent, [String]))),paramMap_Inh_Sequence :: !(ParamMap),prefix_Inh_Sequence :: !(String),syn_Inh_Sequence :: !(Attributes),terminals_Inh_Sequence :: !(([Identifier])),unfoldSemDom_Inh_Sequence :: !((NontermIdent -> Int -> [String] -> Code.Type)),what_Inh_Sequence :: !(String)} data Syn_Sequence = Syn_Sequence {allTpsFound_Syn_Sequence :: !(Bool),blockDecls_Syn_Sequence :: !(DeclBlocks ),comments_Syn_Sequence :: !(([String])),decls_Syn_Sequence :: !(Decls),declsAbove_Syn_Sequence :: !(([Decl])),definedInsts_Syn_Sequence :: !(([Identifier])),errors_Syn_Sequence :: !((Seq Error)),exprs_Syn_Sequence :: !(Exprs),tSigs_Syn_Sequence :: !(([Decl])),tps_Syn_Sequence :: !(([Type])),usedVars_Syn_Sequence :: !((Set String))} wrap_Sequence :: T_Sequence -> Inh_Sequence -> Syn_Sequence wrap_Sequence (T_Sequence sem ) (Inh_Sequence _lhsIallNts _lhsIaroundMap _lhsIchildren _lhsIcon _lhsIdeclsAbove _lhsIerrors _lhsIhigherOrderChildren _lhsIinh _lhsIinstVisitNrs _lhsIlastExpr _lhsInr _lhsInt _lhsIo_case _lhsIo_cata _lhsIo_costcentre _lhsIo_data _lhsIo_linePragmas _lhsIo_monadic _lhsIo_newtypes _lhsIo_pretty _lhsIo_rename _lhsIo_sem _lhsIo_sig _lhsIo_splitsems _lhsIo_strictwrap _lhsIo_traces _lhsIo_unbox _lhsIparamInstMap _lhsIparamMap _lhsIprefix _lhsIsyn _lhsIterminals _lhsIunfoldSemDom _lhsIwhat ) = (let ( _lhsOallTpsFound,_lhsOblockDecls,_lhsOcomments,_lhsOdecls,_lhsOdeclsAbove,_lhsOdefinedInsts,_lhsOerrors,_lhsOexprs,_lhsOtSigs,_lhsOtps,_lhsOusedVars) = (sem _lhsIallNts _lhsIaroundMap _lhsIchildren _lhsIcon _lhsIdeclsAbove _lhsIerrors _lhsIhigherOrderChildren _lhsIinh _lhsIinstVisitNrs _lhsIlastExpr _lhsInr _lhsInt _lhsIo_case _lhsIo_cata _lhsIo_costcentre _lhsIo_data _lhsIo_linePragmas _lhsIo_monadic _lhsIo_newtypes _lhsIo_pretty _lhsIo_rename _lhsIo_sem _lhsIo_sig _lhsIo_splitsems _lhsIo_strictwrap _lhsIo_traces _lhsIo_unbox _lhsIparamInstMap _lhsIparamMap _lhsIprefix _lhsIsyn _lhsIterminals _lhsIunfoldSemDom _lhsIwhat ) in (Syn_Sequence _lhsOallTpsFound _lhsOblockDecls _lhsOcomments _lhsOdecls _lhsOdeclsAbove _lhsOdefinedInsts _lhsOerrors _lhsOexprs _lhsOtSigs _lhsOtps _lhsOusedVars )) sem_Sequence_Cons :: T_CRule -> T_Sequence -> T_Sequence sem_Sequence_Cons (T_CRule hd_ ) (T_Sequence tl_ ) = (T_Sequence (\ _lhsIallNts _lhsIaroundMap _lhsIchildren _lhsIcon _lhsIdeclsAbove _lhsIerrors _lhsIhigherOrderChildren _lhsIinh _lhsIinstVisitNrs _lhsIlastExpr _lhsInr _lhsInt _lhsIo_case _lhsIo_cata _lhsIo_costcentre _lhsIo_data _lhsIo_linePragmas _lhsIo_monadic _lhsIo_newtypes _lhsIo_pretty _lhsIo_rename _lhsIo_sem _lhsIo_sig _lhsIo_splitsems _lhsIo_strictwrap _lhsIo_traces _lhsIo_unbox _lhsIparamInstMap _lhsIparamMap _lhsIprefix _lhsIsyn _lhsIterminals _lhsIunfoldSemDom _lhsIwhat -> (let _lhsOblockDecls :: DeclBlocks _lhsOallTpsFound :: Bool _lhsOcomments :: ([String]) _lhsOdecls :: Decls _lhsOdefinedInsts :: ([Identifier]) _lhsOerrors :: (Seq Error) _lhsOexprs :: Exprs _lhsOtSigs :: ([Decl]) _lhsOtps :: ([Type]) _lhsOusedVars :: (Set String) _lhsOdeclsAbove :: ([Decl]) _hdOallNts :: (Set NontermIdent) _hdOaroundMap :: (Set Identifier) _hdOchildren :: ([(Identifier,Type,Bool)]) _hdOcon :: ConstructorIdent _hdOdeclsAbove :: ([Decl]) _hdOerrors :: (Seq Error) _hdOhigherOrderChildren :: ([(Identifier,Type,Bool)]) _hdOinh :: Attributes _hdOinstVisitNrs :: (Map Identifier Int) _hdOnr :: Int _hdOnt :: NontermIdent _hdOo_case :: Bool _hdOo_cata :: Bool _hdOo_costcentre :: Bool _hdOo_data :: (Maybe Bool) _hdOo_linePragmas :: Bool _hdOo_monadic :: Bool _hdOo_newtypes :: Bool _hdOo_pretty :: Bool _hdOo_rename :: Bool _hdOo_sem :: Bool _hdOo_sig :: Bool _hdOo_splitsems :: Bool _hdOo_strictwrap :: Bool _hdOo_traces :: Bool _hdOo_unbox :: Bool _hdOparamInstMap :: (Map Identifier (NontermIdent, [String])) _hdOparamMap :: ParamMap _hdOprefix :: String _hdOsyn :: Attributes _hdOterminals :: ([Identifier]) _hdOunfoldSemDom :: (NontermIdent -> Int -> [String] -> Code.Type) _hdOwhat :: String _tlOallNts :: (Set NontermIdent) _tlOaroundMap :: (Set Identifier) _tlOchildren :: ([(Identifier,Type,Bool)]) _tlOcon :: ConstructorIdent _tlOdeclsAbove :: ([Decl]) _tlOerrors :: (Seq Error) _tlOhigherOrderChildren :: ([(Identifier,Type,Bool)]) _tlOinh :: Attributes _tlOinstVisitNrs :: (Map Identifier Int) _tlOlastExpr :: Expr _tlOnr :: Int _tlOnt :: NontermIdent _tlOo_case :: Bool _tlOo_cata :: Bool _tlOo_costcentre :: Bool _tlOo_data :: (Maybe Bool) _tlOo_linePragmas :: Bool _tlOo_monadic :: Bool _tlOo_newtypes :: Bool _tlOo_pretty :: Bool _tlOo_rename :: Bool _tlOo_sem :: Bool _tlOo_sig :: Bool _tlOo_splitsems :: Bool _tlOo_strictwrap :: Bool _tlOo_traces :: Bool _tlOo_unbox :: Bool _tlOparamInstMap :: (Map Identifier (NontermIdent, [String])) _tlOparamMap :: ParamMap _tlOprefix :: String _tlOsyn :: Attributes _tlOterminals :: ([Identifier]) _tlOunfoldSemDom :: (NontermIdent -> Int -> [String] -> Code.Type) _tlOwhat :: String _hdIallTpsFound :: Bool _hdIbldBlocksFun :: (DeclBlocks -> DeclBlocks) _hdIcomments :: ([String]) _hdIdecls :: Decls _hdIdeclsAbove :: ([Decl]) _hdIdefinedInsts :: ([Identifier]) _hdIerrors :: (Seq Error) _hdIexprs :: Exprs _hdItSigs :: ([Decl]) _hdItps :: ([Type]) _hdIusedVars :: (Set String) _tlIallTpsFound :: Bool _tlIblockDecls :: DeclBlocks _tlIcomments :: ([String]) _tlIdecls :: Decls _tlIdeclsAbove :: ([Decl]) _tlIdefinedInsts :: ([Identifier]) _tlIerrors :: (Seq Error) _tlIexprs :: Exprs _tlItSigs :: ([Decl]) _tlItps :: ([Type]) _tlIusedVars :: (Set String) -- "GenerateCode.ag"(line 515, column 7) _lhsOblockDecls = ({-# LINE 515 "GenerateCode.ag" #-} _hdIbldBlocksFun _tlIblockDecls {-# LINE 6487 "GenerateCode.hs" #-}) -- use rule "GenerateCode.ag"(line 361, column 39) _lhsOallTpsFound = ({-# LINE 361 "GenerateCode.ag" #-} _hdIallTpsFound && _tlIallTpsFound {-# LINE 6492 "GenerateCode.hs" #-}) -- use rule "GenerateCode.ag"(line 759, column 52) _lhsOcomments = ({-# LINE 759 "GenerateCode.ag" #-} _hdIcomments ++ _tlIcomments {-# LINE 6497 "GenerateCode.hs" #-}) -- use rule "GenerateCode.ag"(line 139, column 34) _lhsOdecls = ({-# LINE 139 "GenerateCode.ag" #-} _hdIdecls ++ _tlIdecls {-# LINE 6502 "GenerateCode.hs" #-}) -- use rule "GenerateCode.ag"(line 212, column 55) _lhsOdefinedInsts = ({-# LINE 212 "GenerateCode.ag" #-} _hdIdefinedInsts ++ _tlIdefinedInsts {-# LINE 6507 "GenerateCode.hs" #-}) -- use rule "GenerateCode.ag"(line 740, column 32) _lhsOerrors = ({-# LINE 740 "GenerateCode.ag" #-} _hdIerrors Seq.>< _tlIerrors {-# LINE 6512 "GenerateCode.hs" #-}) -- use rule "GenerateCode.ag"(line 285, column 34) _lhsOexprs = ({-# LINE 285 "GenerateCode.ag" #-} _hdIexprs ++ _tlIexprs {-# LINE 6517 "GenerateCode.hs" #-}) -- use rule "GenerateCode.ag"(line 314, column 33) _lhsOtSigs = ({-# LINE 314 "GenerateCode.ag" #-} _hdItSigs ++ _tlItSigs {-# LINE 6522 "GenerateCode.hs" #-}) -- use rule "GenerateCode.ag"(line 360, column 31) _lhsOtps = ({-# LINE 360 "GenerateCode.ag" #-} _hdItps ++ _tlItps {-# LINE 6527 "GenerateCode.hs" #-}) -- use rule "GenerateCode.ag"(line 303, column 37) _lhsOusedVars = ({-# LINE 303 "GenerateCode.ag" #-} _hdIusedVars `Set.union` _tlIusedVars {-# LINE 6532 "GenerateCode.hs" #-}) -- copy rule (up) _lhsOdeclsAbove = ({-# LINE 501 "GenerateCode.ag" #-} _tlIdeclsAbove {-# LINE 6537 "GenerateCode.hs" #-}) -- copy rule (down) _hdOallNts = ({-# LINE 121 "GenerateCode.ag" #-} _lhsIallNts {-# LINE 6542 "GenerateCode.hs" #-}) -- copy rule (down) _hdOaroundMap = ({-# LINE 489 "GenerateCode.ag" #-} _lhsIaroundMap {-# LINE 6547 "GenerateCode.hs" #-}) -- copy rule (down) _hdOchildren = ({-# LINE 355 "GenerateCode.ag" #-} _lhsIchildren {-# LINE 6552 "GenerateCode.hs" #-}) -- copy rule (down) _hdOcon = ({-# LINE 83 "GenerateCode.ag" #-} _lhsIcon {-# LINE 6557 "GenerateCode.hs" #-}) -- copy rule (down) _hdOdeclsAbove = ({-# LINE 501 "GenerateCode.ag" #-} _lhsIdeclsAbove {-# LINE 6562 "GenerateCode.hs" #-}) -- copy rule (down) _hdOerrors = ({-# LINE 740 "GenerateCode.ag" #-} _lhsIerrors {-# LINE 6567 "GenerateCode.hs" #-}) -- copy rule (down) _hdOhigherOrderChildren = ({-# LINE 210 "GenerateCode.ag" #-} _lhsIhigherOrderChildren {-# LINE 6572 "GenerateCode.hs" #-}) -- copy rule (down) _hdOinh = ({-# LINE 78 "GenerateCode.ag" #-} _lhsIinh {-# LINE 6577 "GenerateCode.hs" #-}) -- copy rule (down) _hdOinstVisitNrs = ({-# LINE 469 "GenerateCode.ag" #-} _lhsIinstVisitNrs {-# LINE 6582 "GenerateCode.hs" #-}) -- copy rule (down) _hdOnr = ({-# LINE 229 "GenerateCode.ag" #-} _lhsInr {-# LINE 6587 "GenerateCode.hs" #-}) -- copy rule (down) _hdOnt = ({-# LINE 78 "GenerateCode.ag" #-} _lhsInt {-# LINE 6592 "GenerateCode.hs" #-}) -- copy rule (down) _hdOo_case = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_case {-# LINE 6597 "GenerateCode.hs" #-}) -- copy rule (down) _hdOo_cata = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_cata {-# LINE 6602 "GenerateCode.hs" #-}) -- copy rule (down) _hdOo_costcentre = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_costcentre {-# LINE 6607 "GenerateCode.hs" #-}) -- copy rule (down) _hdOo_data = ({-# LINE 46 "GenerateCode.ag" #-} _lhsIo_data {-# LINE 6612 "GenerateCode.hs" #-}) -- copy rule (down) _hdOo_linePragmas = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_linePragmas {-# LINE 6617 "GenerateCode.hs" #-}) -- copy rule (down) _hdOo_monadic = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_monadic {-# LINE 6622 "GenerateCode.hs" #-}) -- copy rule (down) _hdOo_newtypes = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_newtypes {-# LINE 6627 "GenerateCode.hs" #-}) -- copy rule (down) _hdOo_pretty = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_pretty {-# LINE 6632 "GenerateCode.hs" #-}) -- copy rule (down) _hdOo_rename = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_rename {-# LINE 6637 "GenerateCode.hs" #-}) -- copy rule (down) _hdOo_sem = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_sem {-# LINE 6642 "GenerateCode.hs" #-}) -- copy rule (down) _hdOo_sig = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_sig {-# LINE 6647 "GenerateCode.hs" #-}) -- copy rule (down) _hdOo_splitsems = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_splitsems {-# LINE 6652 "GenerateCode.hs" #-}) -- copy rule (down) _hdOo_strictwrap = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_strictwrap {-# LINE 6657 "GenerateCode.hs" #-}) -- copy rule (down) _hdOo_traces = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_traces {-# LINE 6662 "GenerateCode.hs" #-}) -- copy rule (down) _hdOo_unbox = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_unbox {-# LINE 6667 "GenerateCode.hs" #-}) -- copy rule (down) _hdOparamInstMap = ({-# LINE 95 "GenerateCode.ag" #-} _lhsIparamInstMap {-# LINE 6672 "GenerateCode.hs" #-}) -- copy rule (down) _hdOparamMap = ({-# LINE 89 "GenerateCode.ag" #-} _lhsIparamMap {-# LINE 6677 "GenerateCode.hs" #-}) -- copy rule (down) _hdOprefix = ({-# LINE 47 "GenerateCode.ag" #-} _lhsIprefix {-# LINE 6682 "GenerateCode.hs" #-}) -- copy rule (down) _hdOsyn = ({-# LINE 78 "GenerateCode.ag" #-} _lhsIsyn {-# LINE 6687 "GenerateCode.hs" #-}) -- copy rule (down) _hdOterminals = ({-# LINE 84 "GenerateCode.ag" #-} _lhsIterminals {-# LINE 6692 "GenerateCode.hs" #-}) -- copy rule (down) _hdOunfoldSemDom = ({-# LINE 628 "GenerateCode.ag" #-} _lhsIunfoldSemDom {-# LINE 6697 "GenerateCode.hs" #-}) -- copy rule (down) _hdOwhat = ({-# LINE 761 "GenerateCode.ag" #-} _lhsIwhat {-# LINE 6702 "GenerateCode.hs" #-}) -- copy rule (down) _tlOallNts = ({-# LINE 121 "GenerateCode.ag" #-} _lhsIallNts {-# LINE 6707 "GenerateCode.hs" #-}) -- copy rule (down) _tlOaroundMap = ({-# LINE 489 "GenerateCode.ag" #-} _lhsIaroundMap {-# LINE 6712 "GenerateCode.hs" #-}) -- copy rule (down) _tlOchildren = ({-# LINE 355 "GenerateCode.ag" #-} _lhsIchildren {-# LINE 6717 "GenerateCode.hs" #-}) -- copy rule (down) _tlOcon = ({-# LINE 83 "GenerateCode.ag" #-} _lhsIcon {-# LINE 6722 "GenerateCode.hs" #-}) -- copy rule (chain) _tlOdeclsAbove = ({-# LINE 501 "GenerateCode.ag" #-} _hdIdeclsAbove {-# LINE 6727 "GenerateCode.hs" #-}) -- copy rule (chain) _tlOerrors = ({-# LINE 740 "GenerateCode.ag" #-} _hdIerrors {-# LINE 6732 "GenerateCode.hs" #-}) -- copy rule (down) _tlOhigherOrderChildren = ({-# LINE 210 "GenerateCode.ag" #-} _lhsIhigherOrderChildren {-# LINE 6737 "GenerateCode.hs" #-}) -- copy rule (down) _tlOinh = ({-# LINE 78 "GenerateCode.ag" #-} _lhsIinh {-# LINE 6742 "GenerateCode.hs" #-}) -- copy rule (down) _tlOinstVisitNrs = ({-# LINE 469 "GenerateCode.ag" #-} _lhsIinstVisitNrs {-# LINE 6747 "GenerateCode.hs" #-}) -- copy rule (down) _tlOlastExpr = ({-# LINE 499 "GenerateCode.ag" #-} _lhsIlastExpr {-# LINE 6752 "GenerateCode.hs" #-}) -- copy rule (down) _tlOnr = ({-# LINE 229 "GenerateCode.ag" #-} _lhsInr {-# LINE 6757 "GenerateCode.hs" #-}) -- copy rule (down) _tlOnt = ({-# LINE 78 "GenerateCode.ag" #-} _lhsInt {-# LINE 6762 "GenerateCode.hs" #-}) -- copy rule (down) _tlOo_case = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_case {-# LINE 6767 "GenerateCode.hs" #-}) -- copy rule (down) _tlOo_cata = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_cata {-# LINE 6772 "GenerateCode.hs" #-}) -- copy rule (down) _tlOo_costcentre = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_costcentre {-# LINE 6777 "GenerateCode.hs" #-}) -- copy rule (down) _tlOo_data = ({-# LINE 46 "GenerateCode.ag" #-} _lhsIo_data {-# LINE 6782 "GenerateCode.hs" #-}) -- copy rule (down) _tlOo_linePragmas = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_linePragmas {-# LINE 6787 "GenerateCode.hs" #-}) -- copy rule (down) _tlOo_monadic = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_monadic {-# LINE 6792 "GenerateCode.hs" #-}) -- copy rule (down) _tlOo_newtypes = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_newtypes {-# LINE 6797 "GenerateCode.hs" #-}) -- copy rule (down) _tlOo_pretty = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_pretty {-# LINE 6802 "GenerateCode.hs" #-}) -- copy rule (down) _tlOo_rename = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_rename {-# LINE 6807 "GenerateCode.hs" #-}) -- copy rule (down) _tlOo_sem = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_sem {-# LINE 6812 "GenerateCode.hs" #-}) -- copy rule (down) _tlOo_sig = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_sig {-# LINE 6817 "GenerateCode.hs" #-}) -- copy rule (down) _tlOo_splitsems = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_splitsems {-# LINE 6822 "GenerateCode.hs" #-}) -- copy rule (down) _tlOo_strictwrap = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_strictwrap {-# LINE 6827 "GenerateCode.hs" #-}) -- copy rule (down) _tlOo_traces = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_traces {-# LINE 6832 "GenerateCode.hs" #-}) -- copy rule (down) _tlOo_unbox = ({-# LINE 45 "GenerateCode.ag" #-} _lhsIo_unbox {-# LINE 6837 "GenerateCode.hs" #-}) -- copy rule (down) _tlOparamInstMap = ({-# LINE 95 "GenerateCode.ag" #-} _lhsIparamInstMap {-# LINE 6842 "GenerateCode.hs" #-}) -- copy rule (down) _tlOparamMap = ({-# LINE 89 "GenerateCode.ag" #-} _lhsIparamMap {-# LINE 6847 "GenerateCode.hs" #-}) -- copy rule (down) _tlOprefix = ({-# LINE 47 "GenerateCode.ag" #-} _lhsIprefix {-# LINE 6852 "GenerateCode.hs" #-}) -- copy rule (down) _tlOsyn = ({-# LINE 78 "GenerateCode.ag" #-} _lhsIsyn {-# LINE 6857 "GenerateCode.hs" #-}) -- copy rule (down) _tlOterminals = ({-# LINE 84 "GenerateCode.ag" #-} _lhsIterminals {-# LINE 6862 "GenerateCode.hs" #-}) -- copy rule (down) _tlOunfoldSemDom = ({-# LINE 628 "GenerateCode.ag" #-} _lhsIunfoldSemDom {-# LINE 6867 "GenerateCode.hs" #-}) -- copy rule (down) _tlOwhat = ({-# LINE 761 "GenerateCode.ag" #-} _lhsIwhat {-# LINE 6872 "GenerateCode.hs" #-}) ( _hdIallTpsFound,_hdIbldBlocksFun,_hdIcomments,_hdIdecls,_hdIdeclsAbove,_hdIdefinedInsts,_hdIerrors,_hdIexprs,_hdItSigs,_hdItps,_hdIusedVars) = (hd_ _hdOallNts _hdOaroundMap _hdOchildren _hdOcon _hdOdeclsAbove _hdOerrors _hdOhigherOrderChildren _hdOinh _hdOinstVisitNrs _hdOnr _hdOnt _hdOo_case _hdOo_cata _hdOo_costcentre _hdOo_data _hdOo_linePragmas _hdOo_monadic _hdOo_newtypes _hdOo_pretty _hdOo_rename _hdOo_sem _hdOo_sig _hdOo_splitsems _hdOo_strictwrap _hdOo_traces _hdOo_unbox _hdOparamInstMap _hdOparamMap _hdOprefix _hdOsyn _hdOterminals _hdOunfoldSemDom _hdOwhat ) ( _tlIallTpsFound,_tlIblockDecls,_tlIcomments,_tlIdecls,_tlIdeclsAbove,_tlIdefinedInsts,_tlIerrors,_tlIexprs,_tlItSigs,_tlItps,_tlIusedVars) = (tl_ _tlOallNts _tlOaroundMap _tlOchildren _tlOcon _tlOdeclsAbove _tlOerrors _tlOhigherOrderChildren _tlOinh _tlOinstVisitNrs _tlOlastExpr _tlOnr _tlOnt _tlOo_case _tlOo_cata _tlOo_costcentre _tlOo_data _tlOo_linePragmas _tlOo_monadic _tlOo_newtypes _tlOo_pretty _tlOo_rename _tlOo_sem _tlOo_sig _tlOo_splitsems _tlOo_strictwrap _tlOo_traces _tlOo_unbox _tlOparamInstMap _tlOparamMap _tlOprefix _tlOsyn _tlOterminals _tlOunfoldSemDom _tlOwhat ) in ( _lhsOallTpsFound,_lhsOblockDecls,_lhsOcomments,_lhsOdecls,_lhsOdeclsAbove,_lhsOdefinedInsts,_lhsOerrors,_lhsOexprs,_lhsOtSigs,_lhsOtps,_lhsOusedVars))) ) sem_Sequence_Nil :: T_Sequence sem_Sequence_Nil = (T_Sequence (\ _lhsIallNts _lhsIaroundMap _lhsIchildren _lhsIcon _lhsIdeclsAbove _lhsIerrors _lhsIhigherOrderChildren _lhsIinh _lhsIinstVisitNrs _lhsIlastExpr _lhsInr _lhsInt _lhsIo_case _lhsIo_cata _lhsIo_costcentre _lhsIo_data _lhsIo_linePragmas _lhsIo_monadic _lhsIo_newtypes _lhsIo_pretty _lhsIo_rename _lhsIo_sem _lhsIo_sig _lhsIo_splitsems _lhsIo_strictwrap _lhsIo_traces _lhsIo_unbox _lhsIparamInstMap _lhsIparamMap _lhsIprefix _lhsIsyn _lhsIterminals _lhsIunfoldSemDom _lhsIwhat -> (let _lhsOblockDecls :: DeclBlocks _lhsOallTpsFound :: Bool _lhsOcomments :: ([String]) _lhsOdecls :: Decls _lhsOdefinedInsts :: ([Identifier]) _lhsOerrors :: (Seq Error) _lhsOexprs :: Exprs _lhsOtSigs :: ([Decl]) _lhsOtps :: ([Type]) _lhsOusedVars :: (Set String) _lhsOdeclsAbove :: ([Decl]) -- "GenerateCode.ag"(line 517, column 7) _lhsOblockDecls = ({-# LINE 517 "GenerateCode.ag" #-} DeclTerminator _lhsIdeclsAbove _lhsIlastExpr {-# LINE 6929 "GenerateCode.hs" #-}) -- use rule "GenerateCode.ag"(line 361, column 39) _lhsOallTpsFound = ({-# LINE 361 "GenerateCode.ag" #-} True {-# LINE 6934 "GenerateCode.hs" #-}) -- use rule "GenerateCode.ag"(line 759, column 52) _lhsOcomments = ({-# LINE 759 "GenerateCode.ag" #-} [] {-# LINE 6939 "GenerateCode.hs" #-}) -- use rule "GenerateCode.ag"(line 139, column 34) _lhsOdecls = ({-# LINE 139 "GenerateCode.ag" #-} [] {-# LINE 6944 "GenerateCode.hs" #-}) -- use rule "GenerateCode.ag"(line 212, column 55) _lhsOdefinedInsts = ({-# LINE 212 "GenerateCode.ag" #-} [] {-# LINE 6949 "GenerateCode.hs" #-}) -- use rule "GenerateCode.ag"(line 740, column 32) _lhsOerrors = ({-# LINE 740 "GenerateCode.ag" #-} Seq.empty {-# LINE 6954 "GenerateCode.hs" #-}) -- use rule "GenerateCode.ag"(line 285, column 34) _lhsOexprs = ({-# LINE 285 "GenerateCode.ag" #-} [] {-# LINE 6959 "GenerateCode.hs" #-}) -- use rule "GenerateCode.ag"(line 314, column 33) _lhsOtSigs = ({-# LINE 314 "GenerateCode.ag" #-} [] {-# LINE 6964 "GenerateCode.hs" #-}) -- use rule "GenerateCode.ag"(line 360, column 31) _lhsOtps = ({-# LINE 360 "GenerateCode.ag" #-} [] {-# LINE 6969 "GenerateCode.hs" #-}) -- use rule "GenerateCode.ag"(line 303, column 37) _lhsOusedVars = ({-# LINE 303 "GenerateCode.ag" #-} Set.empty {-# LINE 6974 "GenerateCode.hs" #-}) -- copy rule (chain) _lhsOdeclsAbove = ({-# LINE 501 "GenerateCode.ag" #-} _lhsIdeclsAbove {-# LINE 6979 "GenerateCode.hs" #-}) in ( _lhsOallTpsFound,_lhsOblockDecls,_lhsOcomments,_lhsOdecls,_lhsOdeclsAbove,_lhsOdefinedInsts,_lhsOerrors,_lhsOexprs,_lhsOtSigs,_lhsOtps,_lhsOusedVars))) )