-- UUAGC 0.9.39.1.0 (src-ag/ExecutionPlan2Hs.ag) module ExecutionPlan2Hs where {-# LINE 7 "src-ag/ExecutionPlan2Hs.ag" #-} import ExecutionPlan import Pretty import PPUtil import Options import Data.Monoid(mappend,mempty) import Data.Maybe import Debug.Trace import System.IO import System.Directory import System.FilePath import UU.Scanner.Position import TokenDef import HsToken import ErrorMessages import Data.Set (Set) import qualified Data.Set as Set import Data.Map (Map) import qualified Data.Map as Map import Data.Sequence(Seq) import qualified Data.Sequence as Seq import Data.Foldable(toList) {-# LINE 31 "dist/build/uuagc/uuagc-tmp/ExecutionPlan2Hs.hs" #-} {-# LINE 2 "src-ag/ExecutionPlan.ag" #-} -- VisitSyntax.ag imports import Patterns (Pattern(..),Patterns) import Expression (Expression(..)) import CommonTypes import ErrorMessages import qualified Data.Set as Set import Data.Set(Set) import qualified Data.Map as Map import Data.Map(Map) {-# LINE 45 "dist/build/uuagc/uuagc-tmp/ExecutionPlan2Hs.hs" #-} {-# LINE 2 "src-ag/Patterns.ag" #-} -- Patterns.ag imports import UU.Scanner.Position(Pos) import CommonTypes (ConstructorIdent,Identifier) {-# LINE 52 "dist/build/uuagc/uuagc-tmp/ExecutionPlan2Hs.hs" #-} {-# LINE 2 "src-ag/Expression.ag" #-} import UU.Scanner.Position(Pos) import HsToken {-# LINE 58 "dist/build/uuagc/uuagc-tmp/ExecutionPlan2Hs.hs" #-} {-# LINE 2 "src-ag/HsToken.ag" #-} import CommonTypes import UU.Scanner.Position(Pos) {-# LINE 64 "dist/build/uuagc/uuagc-tmp/ExecutionPlan2Hs.hs" #-} {-# LINE 161 "src-ag/ExecutionPlan2Hs.ag" #-} classCtxsToDocs :: ClassContext -> [PP_Doc] classCtxsToDocs = map toDoc where toDoc (ident,args) = (ident >#< ppSpaced (map pp_parens args)) classConstrsToDocs :: [Type] -> [PP_Doc] classConstrsToDocs = map ppTp ppClasses :: [PP_Doc] -> PP_Doc ppClasses [] = empty ppClasses xs = pp_block "(" ")" "," xs >#< "=>" ppQuants :: [Identifier] -> PP_Doc ppQuants [] = empty ppQuants ps = "forall" >#< ppSpaced ps >#< "." {-# LINE 81 "dist/build/uuagc/uuagc-tmp/ExecutionPlan2Hs.hs" #-} {-# LINE 190 "src-ag/ExecutionPlan2Hs.ag" #-} -- first parameter indicates: generate a record or not ppConFields :: Bool -> [PP_Doc] -> PP_Doc ppConFields True flds = ppListSep "{" "}" ", " flds ppConFields False flds = ppSpaced flds {-# LINE 89 "dist/build/uuagc/uuagc-tmp/ExecutionPlan2Hs.hs" #-} {-# LINE 216 "src-ag/ExecutionPlan2Hs.ag" #-} ppTp :: Type -> PP_Doc ppTp (Haskell s) = text s ppTp (NT nt args for) = prefix >|< nt >#< ppSpaced (map pp_parens args) where prefix | for = text "T_" | otherwise = empty {-# LINE 98 "dist/build/uuagc/uuagc-tmp/ExecutionPlan2Hs.hs" #-} {-# LINE 332 "src-ag/ExecutionPlan2Hs.ag" #-} type VisitStateState = (VisitIdentifier,StateIdentifier, StateIdentifier) {-# LINE 102 "dist/build/uuagc/uuagc-tmp/ExecutionPlan2Hs.hs" #-} {-# LINE 428 "src-ag/ExecutionPlan2Hs.ag" #-} conNmTVisit nt vId = "T_" >|< nt >|< "_v" >|< vId conNmTVisitIn nt vId = "T_" >|< nt >|< "_vIn" >|< vId conNmTVisitOut nt vId = "T_" >|< nt >|< "_vOut" >|< vId conNmTNextVisit nt stId = "T_" >|< nt >|< "_s" >|< stId ppMonadType :: Options -> PP_Doc ppMonadType opts | parallelInvoke opts = text "IO" | otherwise = text "Identity" {-# LINE 115 "dist/build/uuagc/uuagc-tmp/ExecutionPlan2Hs.hs" #-} {-# LINE 578 "src-ag/ExecutionPlan2Hs.ag" #-} ppDefor :: Type -> PP_Doc ppDefor (NT nt args _) = "T_" >|< nt >#< ppSpaced (map pp_parens args) ppDefor (Haskell s) = text s {-# LINE 122 "dist/build/uuagc/uuagc-tmp/ExecutionPlan2Hs.hs" #-} {-# LINE 693 "src-ag/ExecutionPlan2Hs.ag" #-} mklet :: (PP a, PP b, PP c) => a -> b -> c -> PP_Doc mklet prefix defs body = prefix >#< "let" >-< indent 3 defs >-< indent 2 "in" >#< body {-# LINE 131 "dist/build/uuagc/uuagc-tmp/ExecutionPlan2Hs.hs" #-} {-# LINE 759 "src-ag/ExecutionPlan2Hs.ag" #-} resultValName :: String resultValName = "__result_" nextStName :: String nextStName = "__st_" {-# LINE 140 "dist/build/uuagc/uuagc-tmp/ExecutionPlan2Hs.hs" #-} {-# LINE 830 "src-ag/ExecutionPlan2Hs.ag" #-} parResultName :: String parResultName = "__outcome_" fmtDecl :: PP a => Bool -> FormatMode -> a -> PP_Doc fmtDecl declPure fmt decl = case fmt of FormatLetDecl -> pp decl FormatLetLine -> "let" >#< decl >#< "in" FormatDo | declPure -> "let" >#< decl | otherwise -> pp decl {-# LINE 153 "dist/build/uuagc/uuagc-tmp/ExecutionPlan2Hs.hs" #-} {-# LINE 944 "src-ag/ExecutionPlan2Hs.ag" #-} stname :: Identifier -> Int -> String stname child st = "_" ++ getName child ++ "X" ++ show st -- should actually return some conversion info compatibleAttach :: VisitKind -> NontermIdent -> Options -> Bool compatibleAttach _ _ _ = True unMon :: Options -> PP_Doc unMon options | parallelInvoke options = text "System.IO.Unsafe.unsafePerformIO" -- IO monad | otherwise = text "Control.Monad.Identity.runIdentity" -- identity monad {-# LINE 168 "dist/build/uuagc/uuagc-tmp/ExecutionPlan2Hs.hs" #-} {-# LINE 1041 "src-ag/ExecutionPlan2Hs.ag" #-} dummyPat :: Options -> Bool -> PP_Doc dummyPat opts noArgs | not noArgs && tupleAsDummyToken opts = empty -- no unnecessary tuples | tupleAsDummyToken opts = if strictDummyToken opts then text "()" else text "(_ :: ())" | otherwise = let match | strictDummyToken opts = "!_" | otherwise = "_" in pp_parens (match >#< "::" >#< dummyType opts noArgs) where match | strictDummyToken opts = "(!_)" | otherwise = "_" dummyArg :: Options -> Bool -> PP_Doc dummyArg opts noArgs | not noArgs && tupleAsDummyToken opts = empty -- no unnecessary tuples | tupleAsDummyToken opts = text "()" | otherwise = text "GHC.Prim.realWorld#" dummyType :: Options -> Bool -> PP_Doc dummyType opts noArgs | not noArgs && tupleAsDummyToken opts = empty -- no unnecessary tuples | tupleAsDummyToken opts = text "()" | otherwise = text "(GHC.Prim.State# GHC.Prim.RealWorld)" {-# LINE 195 "dist/build/uuagc/uuagc-tmp/ExecutionPlan2Hs.hs" #-} {-# LINE 1067 "src-ag/ExecutionPlan2Hs.ag" #-} -- rules are "deinlined" to prevent needless code duplication. -- if there is only a bit of duplication, we allow ghc to decide if it is worth it. -- if the duplication crosses this threshold, however, we tell ghc definitely not to inline it. ruleInlineThresholdSoft :: Int ruleInlineThresholdSoft = 3 ruleInlineThresholdHard :: Int ruleInlineThresholdHard = 5 reallyOftenUsedThreshold :: Int reallyOftenUsedThreshold = 12 {-# LINE 210 "dist/build/uuagc/uuagc-tmp/ExecutionPlan2Hs.hs" #-} {-# LINE 1122 "src-ag/ExecutionPlan2Hs.ag" #-} data NonLocalAttr = AttrInh Identifier Identifier | AttrSyn Identifier Identifier mkNonLocalAttr :: Bool -> Identifier -> Identifier -> NonLocalAttr mkNonLocalAttr True = AttrInh -- True: inherited attr mkNonLocalAttr False = AttrSyn lookupAttrType :: NonLocalAttr -> Map Identifier Attributes -> Map Identifier Attributes -> Map Identifier Type -> Maybe PP_Doc lookupAttrType (AttrInh child name) inhs _ = lookupType child name inhs lookupAttrType (AttrSyn child name) _ syns = lookupType child name syns -- Note: if the child takes type parameters, the type of an attribute of this child may refer to these parameters. This means that -- the actual type of the attribute needs to have its type parameters substituted with the actual type argument of the child. -- However, for now we simply decide to return Nothing in this case, which skips the type annotation. lookupType :: Identifier -> Identifier -> Map Identifier Attributes -> Map Identifier Type -> Maybe PP_Doc lookupType child name attrMp childMp | noParameters childTp = Just ppDoc | otherwise = Nothing where attrTp = Map.findWithDefault (error "lookupType: the attribute is not in the attrs of the child") name childAttrs childAttrs = Map.findWithDefault (error "lookupType: the attributes of the nonterm are not in the map") nonterm attrMp nonterm = extractNonterminal childTp childTp = Map.findWithDefault (error ("lookupType: the child " ++ show child ++ "is not in the appropriate map")) child childMp ppDoc = ppTp attrTp noParameters :: Type -> Bool noParameters (Haskell _) = True noParameters (NT _ args _) = null args {-# LINE 243 "dist/build/uuagc/uuagc-tmp/ExecutionPlan2Hs.hs" #-} {-# LINE 1208 "src-ag/ExecutionPlan2Hs.ag" #-} -- a `compatibleKind` b means: can kind b be invoked from a compatibleKind :: VisitKind -> VisitKind -> Bool compatibleKind _ _ = True compatibleRule :: VisitKind -> Bool -> Bool compatibleRule (VisitPure _) False = False compatibleRule _ _ = True {-# LINE 254 "dist/build/uuagc/uuagc-tmp/ExecutionPlan2Hs.hs" #-} {-# LINE 1230 "src-ag/ExecutionPlan2Hs.ag" #-} unionWithSum = Map.unionWith (+) {-# LINE 259 "dist/build/uuagc/uuagc-tmp/ExecutionPlan2Hs.hs" #-} {-# LINE 1253 "src-ag/ExecutionPlan2Hs.ag" #-} uwSetUnion :: (Ord a, Ord b) => Map a (Set b) -> Map a (Set b) -> Map a (Set b) uwSetUnion = Map.unionWith Set.union uwMapUnion :: (Ord a, Ord b) => Map a (Map b c) -> Map a (Map b c) -> Map a (Map b c) uwMapUnion = Map.unionWith Map.union {-# LINE 268 "dist/build/uuagc/uuagc-tmp/ExecutionPlan2Hs.hs" #-} {-# LINE 1470 "src-ag/ExecutionPlan2Hs.ag" #-} renderDocs :: [PP_Doc] -> String renderDocs pps = foldr (.) id (map (\d -> (disp d 50000) . ( '\n':) ) pps) "" writeModule :: FilePath -> [PP_Doc] -> IO () writeModule path docs = do bExists <- doesFileExist path if bExists then do input <- readFile path seq (length input) (return ()) if input /= output then dumpIt else return () else dumpIt where output = renderDocs docs dumpIt = writeFile path output {-# LINE 288 "dist/build/uuagc/uuagc-tmp/ExecutionPlan2Hs.hs" #-} {-# LINE 1617 "src-ag/ExecutionPlan2Hs.ag" #-} ppNoInline :: PP a => a -> PP_Doc ppNoInline = ppPragmaBinding "NOINLINE" ppInline :: PP a => a -> PP_Doc ppInline = ppPragmaBinding "INLINE" ppInlinable :: PP a => a -> PP_Doc ppInlinable = ppPragmaBinding "INLINABLE" ppPragmaBinding :: (PP a, PP b) => a -> b -> PP_Doc ppPragmaBinding pragma nm = "{-#" >#< pragma >#< nm >#< "#-}" ppCostCentre :: PP a => a -> PP_Doc ppCostCentre nm = "{-#" >#< "SCC" >#< "\"" >|< nm >|< "\"" >#< "#-}" warrenFlagsPP :: Options -> PP_Doc warrenFlagsPP options = vlist [ pp "{-# LANGUAGE Rank2Types, GADTs #-}" , if bangpats options then pp "{-# LANGUAGE BangPatterns #-}" else empty , if noPerRuleTypeSigs options && noPerStateTypeSigs options then empty else pp "{-# LANGUAGE ScopedTypeVariables #-}" , if tupleAsDummyToken options then empty else pp "{-# LANGUAGE ScopedTypeVariables, MagicHash #-}" , -- not that the meaning of "unbox" is here that strict fields in data types may be -- unboxed if possible. This may affect user-defined data types declared in the module. -- Unfortunately, we cannot turn it on for only the AG generated data types without -- causing a zillion of warnings. if unbox options && bangpats options then pp $ "{-# OPTIONS_GHC -funbox-strict-fields -fstrictness #-}" else empty , if parallelInvoke options && not (noEagerBlackholing options) then pp $ "{-# OPTIONS_GHC -feager-blackholing #-}" else empty ] {-# LINE 330 "dist/build/uuagc/uuagc-tmp/ExecutionPlan2Hs.hs" #-} -- EChild ------------------------------------------------------ {- visit 0: inherited attributes: allInitStates : Map NontermIdent Int con : ConstructorIdent importBlocks : PP_Doc mainFile : String mainName : String moduleHeader : String -> String -> String -> Bool -> String nt : NontermIdent options : Options pragmaBlocks : String textBlocks : PP_Doc synthesized attributes: argnamesw : PP_Doc argpats : PP_Doc argtps : PP_Doc childTypes : Map Identifier Type childintros : Map Identifier (VisitKind -> FormatMode -> Either Error (PP_Doc, Set String, Map String (Maybe NonLocalAttr))) datatype : PP_Doc terminaldefs : Set String alternatives: alternative EChild: child name : {Identifier} child tp : {Type} child kind : {ChildKind} child hasAround : {Bool} child merges : {Maybe [Identifier]} child isMerged : {Bool} visit 0: local tpDoc : _ local strNm : _ local field : _ local addStrict : _ local argpats : _ local isDefor : _ local valcode : _ local aroundcode : _ local introcode : _ local nt : _ local addbang : _ local initSt : _ alternative ETerm: child name : {Identifier} child tp : {Type} visit 0: local tpDoc : _ local strNm : _ local field : _ local addStrict : _ local argpats : _ local addbang : _ -} -- cata sem_EChild :: EChild -> T_EChild sem_EChild (EChild _name _tp _kind _hasAround _merges _isMerged ) = (sem_EChild_EChild _name _tp _kind _hasAround _merges _isMerged ) sem_EChild (ETerm _name _tp ) = (sem_EChild_ETerm _name _tp ) -- semantic domain newtype T_EChild = T_EChild ((Map NontermIdent Int) -> ConstructorIdent -> PP_Doc -> String -> String -> (String -> String -> String -> Bool -> String) -> NontermIdent -> Options -> String -> PP_Doc -> ( ( PP_Doc ),( PP_Doc ),( PP_Doc ),(Map Identifier Type),(Map Identifier (VisitKind -> FormatMode -> Either Error (PP_Doc, Set String, Map String (Maybe NonLocalAttr)))),PP_Doc,(Set String))) data Inh_EChild = Inh_EChild {allInitStates_Inh_EChild :: (Map NontermIdent Int),con_Inh_EChild :: ConstructorIdent,importBlocks_Inh_EChild :: PP_Doc,mainFile_Inh_EChild :: String,mainName_Inh_EChild :: String,moduleHeader_Inh_EChild :: (String -> String -> String -> Bool -> String),nt_Inh_EChild :: NontermIdent,options_Inh_EChild :: Options,pragmaBlocks_Inh_EChild :: String,textBlocks_Inh_EChild :: PP_Doc} data Syn_EChild = Syn_EChild {argnamesw_Syn_EChild :: ( PP_Doc ),argpats_Syn_EChild :: ( PP_Doc ),argtps_Syn_EChild :: ( PP_Doc ),childTypes_Syn_EChild :: (Map Identifier Type),childintros_Syn_EChild :: (Map Identifier (VisitKind -> FormatMode -> Either Error (PP_Doc, Set String, Map String (Maybe NonLocalAttr)))),datatype_Syn_EChild :: PP_Doc,terminaldefs_Syn_EChild :: (Set String)} wrap_EChild :: T_EChild -> Inh_EChild -> Syn_EChild wrap_EChild (T_EChild sem ) (Inh_EChild _lhsIallInitStates _lhsIcon _lhsIimportBlocks _lhsImainFile _lhsImainName _lhsImoduleHeader _lhsInt _lhsIoptions _lhsIpragmaBlocks _lhsItextBlocks ) = (let ( _lhsOargnamesw,_lhsOargpats,_lhsOargtps,_lhsOchildTypes,_lhsOchildintros,_lhsOdatatype,_lhsOterminaldefs) = sem _lhsIallInitStates _lhsIcon _lhsIimportBlocks _lhsImainFile _lhsImainName _lhsImoduleHeader _lhsInt _lhsIoptions _lhsIpragmaBlocks _lhsItextBlocks in (Syn_EChild _lhsOargnamesw _lhsOargpats _lhsOargtps _lhsOchildTypes _lhsOchildintros _lhsOdatatype _lhsOterminaldefs )) sem_EChild_EChild :: Identifier -> Type -> ChildKind -> Bool -> (Maybe [Identifier]) -> Bool -> T_EChild sem_EChild_EChild name_ tp_ kind_ hasAround_ merges_ isMerged_ = (T_EChild (\ _lhsIallInitStates _lhsIcon _lhsIimportBlocks _lhsImainFile _lhsImainName _lhsImoduleHeader _lhsInt _lhsIoptions _lhsIpragmaBlocks _lhsItextBlocks -> (let _lhsOdatatype :: PP_Doc _lhsOargnamesw :: ( PP_Doc ) _lhsOargtps :: ( PP_Doc ) _lhsOchildintros :: (Map Identifier (VisitKind -> FormatMode -> Either Error (PP_Doc, Set String, Map String (Maybe NonLocalAttr)))) _lhsOchildTypes :: (Map Identifier Type) _lhsOterminaldefs :: (Set String) _lhsOargpats :: ( PP_Doc ) -- "src-ag/ExecutionPlan2Hs.ag"(line 204, column 7) _tpDoc = ({-# LINE 204 "src-ag/ExecutionPlan2Hs.ag" #-} _addStrict $ pp_parens $ ppTp $ removeDeforested tp_ {-# LINE 441 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 205, column 7) _strNm = ({-# LINE 205 "src-ag/ExecutionPlan2Hs.ag" #-} recordFieldname _lhsInt _lhsIcon name_ {-# LINE 447 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 206, column 7) _field = ({-# LINE 206 "src-ag/ExecutionPlan2Hs.ag" #-} if dataRecords _lhsIoptions then _strNm >#< "::" >#< _tpDoc else _tpDoc {-# LINE 455 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 209, column 7) _addStrict = ({-# LINE 209 "src-ag/ExecutionPlan2Hs.ag" #-} \x -> if strictData _lhsIoptions then "!" >|< x else x {-# LINE 461 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 210, column 13) _lhsOdatatype = ({-# LINE 210 "src-ag/ExecutionPlan2Hs.ag" #-} case kind_ of ChildAttr -> empty _ -> _field {-# LINE 469 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 301, column 12) _lhsOargnamesw = ({-# LINE 301 "src-ag/ExecutionPlan2Hs.ag" #-} case kind_ of ChildSyntax -> "(" >#< "sem_" >|< _nt >#< "field_" >|< name_ >#< ")" ChildAttr -> empty ChildReplace tp -> "(" >#< "sem_" >|< extractNonterminal tp >#< "field_" >|< name_ >#< ")" {-# LINE 478 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 567, column 12) _lhsOargtps = ({-# LINE 567 "src-ag/ExecutionPlan2Hs.ag" #-} case kind_ of ChildSyntax -> ppDefor tp_ >#< "->" ChildReplace tp -> ppDefor tp >#< "->" _ -> empty {-# LINE 487 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 571, column 12) _argpats = ({-# LINE 571 "src-ag/ExecutionPlan2Hs.ag" #-} case kind_ of ChildSyntax -> "field_" >|< name_ ChildReplace _ -> "field_" >|< name_ _ -> empty {-# LINE 496 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 898, column 12) _lhsOchildintros = ({-# LINE 898 "src-ag/ExecutionPlan2Hs.ag" #-} Map.singleton name_ _introcode {-# LINE 502 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 899, column 12) _isDefor = ({-# LINE 899 "src-ag/ExecutionPlan2Hs.ag" #-} case tp_ of NT _ _ defor -> defor _ -> False {-# LINE 510 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 902, column 12) _valcode = ({-# LINE 902 "src-ag/ExecutionPlan2Hs.ag" #-} case kind_ of ChildSyntax -> "field_" >|< name_ ChildAttr -> let prefix | not _isDefor = if lateHigherOrderBinding _lhsIoptions then lateSemNtLabel _nt >#< lhsname True idLateBindingAttr else "sem_" >|< _nt | otherwise = empty in pp_parens (prefix >#< instname name_) ChildReplace _ -> pp_parens (instname name_ >#< "field_" >|< name_) {-# LINE 525 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 913, column 12) _aroundcode = ({-# LINE 913 "src-ag/ExecutionPlan2Hs.ag" #-} if hasAround_ then locname name_ >|< "_around" else empty {-# LINE 533 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 916, column 12) _introcode = ({-# LINE 916 "src-ag/ExecutionPlan2Hs.ag" #-} \kind fmtMode -> let pat = text $ stname name_ _initSt patStrict = _addbang pat attach = "attach_T_" >|< _nt >#< pp_parens (_aroundcode >#< _valcode ) runAttach = unMon _lhsIoptions >#< pp_parens attach decl = case kind of VisitPure False -> pat >#< "=" >#< runAttach VisitPure True -> patStrict >#< "=" >#< runAttach VisitMonadic -> patStrict >#< "<-" >#< attach in if compatibleAttach kind _nt _lhsIoptions then Right ( fmtDecl False fmtMode decl , Set.singleton (stname name_ _initSt ) , case kind_ of ChildAttr -> Map.insert (instname name_) Nothing $ ( if _isDefor || not (lateHigherOrderBinding _lhsIoptions) then id else Map.insert (lhsname True idLateBindingAttr) (Just $ AttrInh _LHS idLateBindingAttr) ) $ ( if hasAround_ then Map.insert (locname (name_) ++ "_around") Nothing else id ) $ Map.empty ChildReplace _ -> Map.singleton (instname name_) Nothing ChildSyntax -> Map.empty ) else Left $ IncompatibleAttachKind name_ kind {-# LINE 564 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 942, column 12) _nt = ({-# LINE 942 "src-ag/ExecutionPlan2Hs.ag" #-} extractNonterminal tp_ {-# LINE 570 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 1498, column 37) _addbang = ({-# LINE 1498 "src-ag/ExecutionPlan2Hs.ag" #-} \x -> if bangpats _lhsIoptions then "!" >|< x else x {-# LINE 576 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 1550, column 3) _lhsOchildTypes = ({-# LINE 1550 "src-ag/ExecutionPlan2Hs.ag" #-} Map.singleton name_ tp_ {-# LINE 582 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 1594, column 3) _initSt = ({-# LINE 1594 "src-ag/ExecutionPlan2Hs.ag" #-} Map.findWithDefault (error "nonterminal not in allInitStates map") _nt _lhsIallInitStates {-# LINE 588 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- use rule "src-ag/ExecutionPlan2Hs.ag"(line 1264, column 42) _lhsOterminaldefs = ({-# LINE 1264 "src-ag/ExecutionPlan2Hs.ag" #-} Set.empty {-# LINE 594 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (from local) _lhsOargpats = ({-# LINE 562 "src-ag/ExecutionPlan2Hs.ag" #-} _argpats {-# LINE 600 "src-ag/ExecutionPlan2Hs.hs" #-} ) in ( _lhsOargnamesw,_lhsOargpats,_lhsOargtps,_lhsOchildTypes,_lhsOchildintros,_lhsOdatatype,_lhsOterminaldefs))) ) sem_EChild_ETerm :: Identifier -> Type -> T_EChild sem_EChild_ETerm name_ tp_ = (T_EChild (\ _lhsIallInitStates _lhsIcon _lhsIimportBlocks _lhsImainFile _lhsImainName _lhsImoduleHeader _lhsInt _lhsIoptions _lhsIpragmaBlocks _lhsItextBlocks -> (let _lhsOdatatype :: PP_Doc _lhsOargnamesw :: ( PP_Doc ) _lhsOargtps :: ( PP_Doc ) _lhsOterminaldefs :: (Set String) _lhsOchildTypes :: (Map Identifier Type) _lhsOchildintros :: (Map Identifier (VisitKind -> FormatMode -> Either Error (PP_Doc, Set String, Map String (Maybe NonLocalAttr)))) _lhsOargpats :: ( PP_Doc ) -- "src-ag/ExecutionPlan2Hs.ag"(line 204, column 7) _tpDoc = ({-# LINE 204 "src-ag/ExecutionPlan2Hs.ag" #-} _addStrict $ pp_parens $ ppTp $ removeDeforested tp_ {-# LINE 628 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 205, column 7) _strNm = ({-# LINE 205 "src-ag/ExecutionPlan2Hs.ag" #-} recordFieldname _lhsInt _lhsIcon name_ {-# LINE 634 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 206, column 7) _field = ({-# LINE 206 "src-ag/ExecutionPlan2Hs.ag" #-} if dataRecords _lhsIoptions then _strNm >#< "::" >#< _tpDoc else _tpDoc {-# LINE 642 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 209, column 7) _addStrict = ({-# LINE 209 "src-ag/ExecutionPlan2Hs.ag" #-} \x -> if strictData _lhsIoptions then "!" >|< x else x {-# LINE 648 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 214, column 13) _lhsOdatatype = ({-# LINE 214 "src-ag/ExecutionPlan2Hs.ag" #-} _field {-# LINE 654 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 305, column 12) _lhsOargnamesw = ({-# LINE 305 "src-ag/ExecutionPlan2Hs.ag" #-} text $ locname name_ {-# LINE 660 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 575, column 12) _lhsOargtps = ({-# LINE 575 "src-ag/ExecutionPlan2Hs.ag" #-} (pp_parens $ show tp_) >#< "->" {-# LINE 666 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 576, column 12) _argpats = ({-# LINE 576 "src-ag/ExecutionPlan2Hs.ag" #-} _addbang $ text $ locname name_ {-# LINE 672 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 1267, column 3) _lhsOterminaldefs = ({-# LINE 1267 "src-ag/ExecutionPlan2Hs.ag" #-} Set.singleton $ locname name_ {-# LINE 678 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 1499, column 37) _addbang = ({-# LINE 1499 "src-ag/ExecutionPlan2Hs.ag" #-} \x -> if bangpats _lhsIoptions then "!" >|< x else x {-# LINE 684 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 1550, column 3) _lhsOchildTypes = ({-# LINE 1550 "src-ag/ExecutionPlan2Hs.ag" #-} Map.singleton name_ tp_ {-# LINE 690 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- use rule "src-ag/ExecutionPlan2Hs.ag"(line 889, column 41) _lhsOchildintros = ({-# LINE 889 "src-ag/ExecutionPlan2Hs.ag" #-} Map.empty {-# LINE 696 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (from local) _lhsOargpats = ({-# LINE 562 "src-ag/ExecutionPlan2Hs.ag" #-} _argpats {-# LINE 702 "src-ag/ExecutionPlan2Hs.hs" #-} ) in ( _lhsOargnamesw,_lhsOargpats,_lhsOargtps,_lhsOchildTypes,_lhsOchildintros,_lhsOdatatype,_lhsOterminaldefs))) ) -- EChildren --------------------------------------------------- {- visit 0: inherited attributes: allInitStates : Map NontermIdent Int con : ConstructorIdent importBlocks : PP_Doc mainFile : String mainName : String moduleHeader : String -> String -> String -> Bool -> String nt : NontermIdent options : Options pragmaBlocks : String textBlocks : PP_Doc synthesized attributes: argnamesw : [PP_Doc] argpats : [PP_Doc] argtps : [PP_Doc] childTypes : Map Identifier Type childintros : Map Identifier (VisitKind -> FormatMode -> Either Error (PP_Doc, Set String, Map String (Maybe NonLocalAttr))) datatype : [PP_Doc] terminaldefs : Set String alternatives: alternative Cons: child hd : EChild child tl : EChildren alternative Nil: -} -- cata sem_EChildren :: EChildren -> T_EChildren sem_EChildren list = (Prelude.foldr sem_EChildren_Cons sem_EChildren_Nil (Prelude.map sem_EChild list) ) -- semantic domain newtype T_EChildren = T_EChildren ((Map NontermIdent Int) -> ConstructorIdent -> PP_Doc -> String -> String -> (String -> String -> String -> Bool -> String) -> NontermIdent -> Options -> String -> PP_Doc -> ( ([PP_Doc]),( [PP_Doc] ),( [PP_Doc] ),(Map Identifier Type),(Map Identifier (VisitKind -> FormatMode -> Either Error (PP_Doc, Set String, Map String (Maybe NonLocalAttr)))),([PP_Doc]),(Set String))) data Inh_EChildren = Inh_EChildren {allInitStates_Inh_EChildren :: (Map NontermIdent Int),con_Inh_EChildren :: ConstructorIdent,importBlocks_Inh_EChildren :: PP_Doc,mainFile_Inh_EChildren :: String,mainName_Inh_EChildren :: String,moduleHeader_Inh_EChildren :: (String -> String -> String -> Bool -> String),nt_Inh_EChildren :: NontermIdent,options_Inh_EChildren :: Options,pragmaBlocks_Inh_EChildren :: String,textBlocks_Inh_EChildren :: PP_Doc} data Syn_EChildren = Syn_EChildren {argnamesw_Syn_EChildren :: ([PP_Doc]),argpats_Syn_EChildren :: ( [PP_Doc] ),argtps_Syn_EChildren :: ( [PP_Doc] ),childTypes_Syn_EChildren :: (Map Identifier Type),childintros_Syn_EChildren :: (Map Identifier (VisitKind -> FormatMode -> Either Error (PP_Doc, Set String, Map String (Maybe NonLocalAttr)))),datatype_Syn_EChildren :: ([PP_Doc]),terminaldefs_Syn_EChildren :: (Set String)} wrap_EChildren :: T_EChildren -> Inh_EChildren -> Syn_EChildren wrap_EChildren (T_EChildren sem ) (Inh_EChildren _lhsIallInitStates _lhsIcon _lhsIimportBlocks _lhsImainFile _lhsImainName _lhsImoduleHeader _lhsInt _lhsIoptions _lhsIpragmaBlocks _lhsItextBlocks ) = (let ( _lhsOargnamesw,_lhsOargpats,_lhsOargtps,_lhsOchildTypes,_lhsOchildintros,_lhsOdatatype,_lhsOterminaldefs) = sem _lhsIallInitStates _lhsIcon _lhsIimportBlocks _lhsImainFile _lhsImainName _lhsImoduleHeader _lhsInt _lhsIoptions _lhsIpragmaBlocks _lhsItextBlocks in (Syn_EChildren _lhsOargnamesw _lhsOargpats _lhsOargtps _lhsOchildTypes _lhsOchildintros _lhsOdatatype _lhsOterminaldefs )) sem_EChildren_Cons :: T_EChild -> T_EChildren -> T_EChildren sem_EChildren_Cons (T_EChild hd_ ) (T_EChildren tl_ ) = (T_EChildren (\ _lhsIallInitStates _lhsIcon _lhsIimportBlocks _lhsImainFile _lhsImainName _lhsImoduleHeader _lhsInt _lhsIoptions _lhsIpragmaBlocks _lhsItextBlocks -> (let _lhsOargnamesw :: ([PP_Doc]) _lhsOargpats :: ( [PP_Doc] ) _lhsOargtps :: ( [PP_Doc] ) _lhsOchildTypes :: (Map Identifier Type) _lhsOchildintros :: (Map Identifier (VisitKind -> FormatMode -> Either Error (PP_Doc, Set String, Map String (Maybe NonLocalAttr)))) _lhsOdatatype :: ([PP_Doc]) _lhsOterminaldefs :: (Set String) _hdOallInitStates :: (Map NontermIdent Int) _hdOcon :: ConstructorIdent _hdOimportBlocks :: PP_Doc _hdOmainFile :: String _hdOmainName :: String _hdOmoduleHeader :: (String -> String -> String -> Bool -> String) _hdOnt :: NontermIdent _hdOoptions :: Options _hdOpragmaBlocks :: String _hdOtextBlocks :: PP_Doc _tlOallInitStates :: (Map NontermIdent Int) _tlOcon :: ConstructorIdent _tlOimportBlocks :: PP_Doc _tlOmainFile :: String _tlOmainName :: String _tlOmoduleHeader :: (String -> String -> String -> Bool -> String) _tlOnt :: NontermIdent _tlOoptions :: Options _tlOpragmaBlocks :: String _tlOtextBlocks :: PP_Doc _hdIargnamesw :: ( PP_Doc ) _hdIargpats :: ( PP_Doc ) _hdIargtps :: ( PP_Doc ) _hdIchildTypes :: (Map Identifier Type) _hdIchildintros :: (Map Identifier (VisitKind -> FormatMode -> Either Error (PP_Doc, Set String, Map String (Maybe NonLocalAttr)))) _hdIdatatype :: PP_Doc _hdIterminaldefs :: (Set String) _tlIargnamesw :: ([PP_Doc]) _tlIargpats :: ( [PP_Doc] ) _tlIargtps :: ( [PP_Doc] ) _tlIchildTypes :: (Map Identifier Type) _tlIchildintros :: (Map Identifier (VisitKind -> FormatMode -> Either Error (PP_Doc, Set String, Map String (Maybe NonLocalAttr)))) _tlIdatatype :: ([PP_Doc]) _tlIterminaldefs :: (Set String) -- use rule "src-ag/ExecutionPlan2Hs.ag"(line 298, column 32) _lhsOargnamesw = ({-# LINE 298 "src-ag/ExecutionPlan2Hs.ag" #-} _hdIargnamesw : _tlIargnamesw {-# LINE 817 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- use rule "src-ag/ExecutionPlan2Hs.ag"(line 564, column 30) _lhsOargpats = ({-# LINE 564 "src-ag/ExecutionPlan2Hs.ag" #-} _hdIargpats : _tlIargpats {-# LINE 823 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- use rule "src-ag/ExecutionPlan2Hs.ag"(line 563, column 30) _lhsOargtps = ({-# LINE 563 "src-ag/ExecutionPlan2Hs.ag" #-} _hdIargtps : _tlIargtps {-# LINE 829 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- use rule "src-ag/ExecutionPlan2Hs.ag"(line 1543, column 40) _lhsOchildTypes = ({-# LINE 1543 "src-ag/ExecutionPlan2Hs.ag" #-} _hdIchildTypes `mappend` _tlIchildTypes {-# LINE 835 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- use rule "src-ag/ExecutionPlan2Hs.ag"(line 889, column 41) _lhsOchildintros = ({-# LINE 889 "src-ag/ExecutionPlan2Hs.ag" #-} _hdIchildintros `Map.union` _tlIchildintros {-# LINE 841 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- use rule "src-ag/ExecutionPlan2Hs.ag"(line 199, column 31) _lhsOdatatype = ({-# LINE 199 "src-ag/ExecutionPlan2Hs.ag" #-} _hdIdatatype : _tlIdatatype {-# LINE 847 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- use rule "src-ag/ExecutionPlan2Hs.ag"(line 1264, column 42) _lhsOterminaldefs = ({-# LINE 1264 "src-ag/ExecutionPlan2Hs.ag" #-} _hdIterminaldefs `Set.union` _tlIterminaldefs {-# LINE 853 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _hdOallInitStates = ({-# LINE 1585 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIallInitStates {-# LINE 859 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _hdOcon = ({-# LINE 66 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIcon {-# LINE 865 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _hdOimportBlocks = ({-# LINE 34 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIimportBlocks {-# LINE 871 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _hdOmainFile = ({-# LINE 38 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsImainFile {-# LINE 877 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _hdOmainName = ({-# LINE 39 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsImainName {-# LINE 883 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _hdOmoduleHeader = ({-# LINE 37 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsImoduleHeader {-# LINE 889 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _hdOnt = ({-# LINE 61 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsInt {-# LINE 895 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _hdOoptions = ({-# LINE 51 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIoptions {-# LINE 901 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _hdOpragmaBlocks = ({-# LINE 35 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIpragmaBlocks {-# LINE 907 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _hdOtextBlocks = ({-# LINE 36 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsItextBlocks {-# LINE 913 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _tlOallInitStates = ({-# LINE 1585 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIallInitStates {-# LINE 919 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _tlOcon = ({-# LINE 66 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIcon {-# LINE 925 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _tlOimportBlocks = ({-# LINE 34 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIimportBlocks {-# LINE 931 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _tlOmainFile = ({-# LINE 38 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsImainFile {-# LINE 937 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _tlOmainName = ({-# LINE 39 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsImainName {-# LINE 943 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _tlOmoduleHeader = ({-# LINE 37 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsImoduleHeader {-# LINE 949 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _tlOnt = ({-# LINE 61 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsInt {-# LINE 955 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _tlOoptions = ({-# LINE 51 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIoptions {-# LINE 961 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _tlOpragmaBlocks = ({-# LINE 35 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIpragmaBlocks {-# LINE 967 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _tlOtextBlocks = ({-# LINE 36 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsItextBlocks {-# LINE 973 "src-ag/ExecutionPlan2Hs.hs" #-} ) ( _hdIargnamesw,_hdIargpats,_hdIargtps,_hdIchildTypes,_hdIchildintros,_hdIdatatype,_hdIterminaldefs) = hd_ _hdOallInitStates _hdOcon _hdOimportBlocks _hdOmainFile _hdOmainName _hdOmoduleHeader _hdOnt _hdOoptions _hdOpragmaBlocks _hdOtextBlocks ( _tlIargnamesw,_tlIargpats,_tlIargtps,_tlIchildTypes,_tlIchildintros,_tlIdatatype,_tlIterminaldefs) = tl_ _tlOallInitStates _tlOcon _tlOimportBlocks _tlOmainFile _tlOmainName _tlOmoduleHeader _tlOnt _tlOoptions _tlOpragmaBlocks _tlOtextBlocks in ( _lhsOargnamesw,_lhsOargpats,_lhsOargtps,_lhsOchildTypes,_lhsOchildintros,_lhsOdatatype,_lhsOterminaldefs))) ) sem_EChildren_Nil :: T_EChildren sem_EChildren_Nil = (T_EChildren (\ _lhsIallInitStates _lhsIcon _lhsIimportBlocks _lhsImainFile _lhsImainName _lhsImoduleHeader _lhsInt _lhsIoptions _lhsIpragmaBlocks _lhsItextBlocks -> (let _lhsOargnamesw :: ([PP_Doc]) _lhsOargpats :: ( [PP_Doc] ) _lhsOargtps :: ( [PP_Doc] ) _lhsOchildTypes :: (Map Identifier Type) _lhsOchildintros :: (Map Identifier (VisitKind -> FormatMode -> Either Error (PP_Doc, Set String, Map String (Maybe NonLocalAttr)))) _lhsOdatatype :: ([PP_Doc]) _lhsOterminaldefs :: (Set String) -- use rule "src-ag/ExecutionPlan2Hs.ag"(line 298, column 32) _lhsOargnamesw = ({-# LINE 298 "src-ag/ExecutionPlan2Hs.ag" #-} [] {-# LINE 1003 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- use rule "src-ag/ExecutionPlan2Hs.ag"(line 564, column 30) _lhsOargpats = ({-# LINE 564 "src-ag/ExecutionPlan2Hs.ag" #-} [] {-# LINE 1009 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- use rule "src-ag/ExecutionPlan2Hs.ag"(line 563, column 30) _lhsOargtps = ({-# LINE 563 "src-ag/ExecutionPlan2Hs.ag" #-} [] {-# LINE 1015 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- use rule "src-ag/ExecutionPlan2Hs.ag"(line 1543, column 40) _lhsOchildTypes = ({-# LINE 1543 "src-ag/ExecutionPlan2Hs.ag" #-} mempty {-# LINE 1021 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- use rule "src-ag/ExecutionPlan2Hs.ag"(line 889, column 41) _lhsOchildintros = ({-# LINE 889 "src-ag/ExecutionPlan2Hs.ag" #-} Map.empty {-# LINE 1027 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- use rule "src-ag/ExecutionPlan2Hs.ag"(line 199, column 31) _lhsOdatatype = ({-# LINE 199 "src-ag/ExecutionPlan2Hs.ag" #-} [] {-# LINE 1033 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- use rule "src-ag/ExecutionPlan2Hs.ag"(line 1264, column 42) _lhsOterminaldefs = ({-# LINE 1264 "src-ag/ExecutionPlan2Hs.ag" #-} Set.empty {-# LINE 1039 "src-ag/ExecutionPlan2Hs.hs" #-} ) in ( _lhsOargnamesw,_lhsOargpats,_lhsOargtps,_lhsOchildTypes,_lhsOchildintros,_lhsOdatatype,_lhsOterminaldefs))) ) -- ENonterminal ------------------------------------------------ {- visit 0: inherited attributes: allFromToStates : Map VisitIdentifier (Int,Int) allInitStates : Map NontermIdent Int allVisitKinds : Map VisitIdentifier VisitKind allchildvisit : Map VisitIdentifier (Identifier -> VisitKind -> Either Error (PP_Doc, PP_Doc)) avisitdefs : Map VisitIdentifier (Set Identifier) avisituses : Map VisitIdentifier (Set Identifier) derivings : Derivings importBlocks : PP_Doc inhmap : Map NontermIdent Attributes localAttrTypes : Map NontermIdent (Map ConstructorIdent (Map Identifier Type)) mainFile : String mainName : String moduleHeader : String -> String -> String -> Bool -> String options : Options pragmaBlocks : String synmap : Map NontermIdent Attributes textBlocks : PP_Doc typeSyns : TypeSyns wrappers : Set NontermIdent synthesized attributes: appendCommon : PP_Doc appendMain : PP_Doc childvisit : Map VisitIdentifier (Identifier -> VisitKind -> Either Error (PP_Doc, PP_Doc)) errors : Seq Error fromToStates : Map VisitIdentifier (Int,Int) genProdIO : IO () imports : [PP_Doc] initStates : Map NontermIdent Int output : PP_Doc semFunBndDefs : Seq PP_Doc semFunBndTps : Seq PP_Doc visitKinds : Map VisitIdentifier VisitKind visitdefs : Map VisitIdentifier (Set Identifier) visituses : Map VisitIdentifier (Set Identifier) alternatives: alternative ENonterminal: child nt : {NontermIdent} child params : {[Identifier]} child classCtxs : {ClassContext} child initial : {StateIdentifier} child initialv : {Maybe VisitIdentifier} child nextVisits : {Map StateIdentifier StateCtx} child prevVisits : {Map StateIdentifier StateCtx} child prods : EProductions child recursive : {Bool} child hoInfo : {HigherOrderInfo} visit 0: local hasWrapper : _ local classPP : _ local aliasPre : _ local datatype : _ local derivings : _ local fsemname : _ local semname : _ local frecarg : _ local sem_tp : _ local quantPP : _ local sem_nt : _ local inlineNt : _ local semPragma : _ local outedges : _ local inedges : _ local allstates : _ local stvisits : _ local t_type : _ local t_params : _ local t_init : _ local t_states : _ local k_type : _ local k_states : _ local wr_inh : _ local wr_syn : _ local genwrap : _ local synAttrs : _ local wr_inhs : _ local wr_inhs1 : _ local wr_filter : _ local wr_syns : _ local inhlist : _ local inhlist1 : _ local synlist : _ local wrapname : _ local inhname : _ local synname : _ local firstVisitInfo : _ local wrapper : _ local wrapPragma : _ local semFunBndDef : _ local semFunBndTp : _ local semFunBndNm : _ local addbang : _ local addbangWrap : _ local ntType : _ -} -- cata sem_ENonterminal :: ENonterminal -> T_ENonterminal sem_ENonterminal (ENonterminal _nt _params _classCtxs _initial _initialv _nextVisits _prevVisits _prods _recursive _hoInfo ) = (sem_ENonterminal_ENonterminal _nt _params _classCtxs _initial _initialv _nextVisits _prevVisits (sem_EProductions _prods ) _recursive _hoInfo ) -- semantic domain newtype T_ENonterminal = T_ENonterminal ((Map VisitIdentifier (Int,Int)) -> (Map NontermIdent Int) -> (Map VisitIdentifier VisitKind) -> (Map VisitIdentifier (Identifier -> VisitKind -> Either Error (PP_Doc, PP_Doc))) -> (Map VisitIdentifier (Set Identifier)) -> (Map VisitIdentifier (Set Identifier)) -> Derivings -> PP_Doc -> (Map NontermIdent Attributes) -> (Map NontermIdent (Map ConstructorIdent (Map Identifier Type))) -> String -> String -> (String -> String -> String -> Bool -> String) -> Options -> String -> (Map NontermIdent Attributes) -> PP_Doc -> TypeSyns -> (Set NontermIdent) -> ( ( PP_Doc ),( PP_Doc ),(Map VisitIdentifier (Identifier -> VisitKind -> Either Error (PP_Doc, PP_Doc))),(Seq Error),(Map VisitIdentifier (Int,Int)),(IO ()),([PP_Doc]),(Map NontermIdent Int),PP_Doc,(Seq PP_Doc),(Seq PP_Doc),(Map VisitIdentifier VisitKind),(Map VisitIdentifier (Set Identifier)),(Map VisitIdentifier (Set Identifier)))) data Inh_ENonterminal = Inh_ENonterminal {allFromToStates_Inh_ENonterminal :: (Map VisitIdentifier (Int,Int)),allInitStates_Inh_ENonterminal :: (Map NontermIdent Int),allVisitKinds_Inh_ENonterminal :: (Map VisitIdentifier VisitKind),allchildvisit_Inh_ENonterminal :: (Map VisitIdentifier (Identifier -> VisitKind -> Either Error (PP_Doc, PP_Doc))),avisitdefs_Inh_ENonterminal :: (Map VisitIdentifier (Set Identifier)),avisituses_Inh_ENonterminal :: (Map VisitIdentifier (Set Identifier)),derivings_Inh_ENonterminal :: Derivings,importBlocks_Inh_ENonterminal :: PP_Doc,inhmap_Inh_ENonterminal :: (Map NontermIdent Attributes),localAttrTypes_Inh_ENonterminal :: (Map NontermIdent (Map ConstructorIdent (Map Identifier Type))),mainFile_Inh_ENonterminal :: String,mainName_Inh_ENonterminal :: String,moduleHeader_Inh_ENonterminal :: (String -> String -> String -> Bool -> String),options_Inh_ENonterminal :: Options,pragmaBlocks_Inh_ENonterminal :: String,synmap_Inh_ENonterminal :: (Map NontermIdent Attributes),textBlocks_Inh_ENonterminal :: PP_Doc,typeSyns_Inh_ENonterminal :: TypeSyns,wrappers_Inh_ENonterminal :: (Set NontermIdent)} data Syn_ENonterminal = Syn_ENonterminal {appendCommon_Syn_ENonterminal :: ( PP_Doc ),appendMain_Syn_ENonterminal :: ( PP_Doc ),childvisit_Syn_ENonterminal :: (Map VisitIdentifier (Identifier -> VisitKind -> Either Error (PP_Doc, PP_Doc))),errors_Syn_ENonterminal :: (Seq Error),fromToStates_Syn_ENonterminal :: (Map VisitIdentifier (Int,Int)),genProdIO_Syn_ENonterminal :: (IO ()),imports_Syn_ENonterminal :: ([PP_Doc]),initStates_Syn_ENonterminal :: (Map NontermIdent Int),output_Syn_ENonterminal :: PP_Doc,semFunBndDefs_Syn_ENonterminal :: (Seq PP_Doc),semFunBndTps_Syn_ENonterminal :: (Seq PP_Doc),visitKinds_Syn_ENonterminal :: (Map VisitIdentifier VisitKind),visitdefs_Syn_ENonterminal :: (Map VisitIdentifier (Set Identifier)),visituses_Syn_ENonterminal :: (Map VisitIdentifier (Set Identifier))} wrap_ENonterminal :: T_ENonterminal -> Inh_ENonterminal -> Syn_ENonterminal wrap_ENonterminal (T_ENonterminal sem ) (Inh_ENonterminal _lhsIallFromToStates _lhsIallInitStates _lhsIallVisitKinds _lhsIallchildvisit _lhsIavisitdefs _lhsIavisituses _lhsIderivings _lhsIimportBlocks _lhsIinhmap _lhsIlocalAttrTypes _lhsImainFile _lhsImainName _lhsImoduleHeader _lhsIoptions _lhsIpragmaBlocks _lhsIsynmap _lhsItextBlocks _lhsItypeSyns _lhsIwrappers ) = (let ( _lhsOappendCommon,_lhsOappendMain,_lhsOchildvisit,_lhsOerrors,_lhsOfromToStates,_lhsOgenProdIO,_lhsOimports,_lhsOinitStates,_lhsOoutput,_lhsOsemFunBndDefs,_lhsOsemFunBndTps,_lhsOvisitKinds,_lhsOvisitdefs,_lhsOvisituses) = sem _lhsIallFromToStates _lhsIallInitStates _lhsIallVisitKinds _lhsIallchildvisit _lhsIavisitdefs _lhsIavisituses _lhsIderivings _lhsIimportBlocks _lhsIinhmap _lhsIlocalAttrTypes _lhsImainFile _lhsImainName _lhsImoduleHeader _lhsIoptions _lhsIpragmaBlocks _lhsIsynmap _lhsItextBlocks _lhsItypeSyns _lhsIwrappers in (Syn_ENonterminal _lhsOappendCommon _lhsOappendMain _lhsOchildvisit _lhsOerrors _lhsOfromToStates _lhsOgenProdIO _lhsOimports _lhsOinitStates _lhsOoutput _lhsOsemFunBndDefs _lhsOsemFunBndTps _lhsOvisitKinds _lhsOvisitdefs _lhsOvisituses )) sem_ENonterminal_ENonterminal :: NontermIdent -> ([Identifier]) -> ClassContext -> StateIdentifier -> (Maybe VisitIdentifier) -> (Map StateIdentifier StateCtx) -> (Map StateIdentifier StateCtx) -> T_EProductions -> Bool -> HigherOrderInfo -> T_ENonterminal sem_ENonterminal_ENonterminal nt_ params_ classCtxs_ initial_ initialv_ nextVisits_ prevVisits_ (T_EProductions prods_ ) recursive_ hoInfo_ = (T_ENonterminal (\ _lhsIallFromToStates _lhsIallInitStates _lhsIallVisitKinds _lhsIallchildvisit _lhsIavisitdefs _lhsIavisituses _lhsIderivings _lhsIimportBlocks _lhsIinhmap _lhsIlocalAttrTypes _lhsImainFile _lhsImainName _lhsImoduleHeader _lhsIoptions _lhsIpragmaBlocks _lhsIsynmap _lhsItextBlocks _lhsItypeSyns _lhsIwrappers -> (let _prodsOrename :: Bool _prodsOnt :: NontermIdent _prodsOparams :: ([Identifier]) _prodsOclassCtxs :: ClassContext _lhsOoutput :: PP_Doc _prodsOinhmap :: Attributes _prodsOsynmap :: Attributes _prodsOallInhmap :: (Map NontermIdent Attributes) _prodsOallSynmap :: (Map NontermIdent Attributes) _lhsOsemFunBndDefs :: (Seq PP_Doc) _lhsOsemFunBndTps :: (Seq PP_Doc) _prodsOinitial :: StateIdentifier _prodsOallstates :: (Set StateIdentifier) _lhsOappendMain :: ( PP_Doc ) _lhsOappendCommon :: ( PP_Doc ) _prodsOnextVisits :: (Map StateIdentifier StateCtx) _prodsOprevVisits :: (Map StateIdentifier StateCtx) _prodsOlocalAttrTypes :: (Map ConstructorIdent (Map Identifier Type)) _lhsOinitStates :: (Map NontermIdent Int) _lhsOchildvisit :: (Map VisitIdentifier (Identifier -> VisitKind -> Either Error (PP_Doc, PP_Doc))) _lhsOerrors :: (Seq Error) _lhsOfromToStates :: (Map VisitIdentifier (Int,Int)) _lhsOgenProdIO :: (IO ()) _lhsOimports :: ([PP_Doc]) _lhsOvisitKinds :: (Map VisitIdentifier VisitKind) _lhsOvisitdefs :: (Map VisitIdentifier (Set Identifier)) _lhsOvisituses :: (Map VisitIdentifier (Set Identifier)) _prodsOallFromToStates :: (Map VisitIdentifier (Int,Int)) _prodsOallInitStates :: (Map NontermIdent Int) _prodsOallVisitKinds :: (Map VisitIdentifier VisitKind) _prodsOallchildvisit :: (Map VisitIdentifier (Identifier -> VisitKind -> Either Error (PP_Doc, PP_Doc))) _prodsOavisitdefs :: (Map VisitIdentifier (Set Identifier)) _prodsOavisituses :: (Map VisitIdentifier (Set Identifier)) _prodsOimportBlocks :: PP_Doc _prodsOmainFile :: String _prodsOmainName :: String _prodsOmoduleHeader :: (String -> String -> String -> Bool -> String) _prodsOntType :: Type _prodsOoptions :: Options _prodsOpragmaBlocks :: String _prodsOtextBlocks :: PP_Doc _prodsIallvisits :: ([VisitStateState]) _prodsIchildvisit :: (Map VisitIdentifier (Identifier -> VisitKind -> Either Error (PP_Doc, PP_Doc))) _prodsIcount :: Int _prodsIdatatype :: ([PP_Doc]) _prodsIerrors :: (Seq Error) _prodsIfromToStates :: (Map VisitIdentifier (Int,Int)) _prodsIgenProdIO :: (IO ()) _prodsIimports :: ([PP_Doc]) _prodsIsemFunBndDefs :: (Seq PP_Doc) _prodsIsemFunBndTps :: (Seq PP_Doc) _prodsIsem_nt :: PP_Doc _prodsIsem_prod :: PP_Doc _prodsIt_visits :: PP_Doc _prodsIvisitKinds :: (Map VisitIdentifier VisitKind) _prodsIvisitdefs :: (Map VisitIdentifier (Set Identifier)) _prodsIvisituses :: (Map VisitIdentifier (Set Identifier)) -- "src-ag/ExecutionPlan2Hs.ag"(line 55, column 18) _prodsOrename = ({-# LINE 55 "src-ag/ExecutionPlan2Hs.ag" #-} rename _lhsIoptions {-# LINE 1266 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 63, column 18) _prodsOnt = ({-# LINE 63 "src-ag/ExecutionPlan2Hs.ag" #-} nt_ {-# LINE 1272 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 75, column 3) _prodsOparams = ({-# LINE 75 "src-ag/ExecutionPlan2Hs.ag" #-} params_ {-# LINE 1278 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 79, column 3) _prodsOclassCtxs = ({-# LINE 79 "src-ag/ExecutionPlan2Hs.ag" #-} classCtxs_ {-# LINE 1284 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 96, column 18) _lhsOoutput = ({-# LINE 96 "src-ag/ExecutionPlan2Hs.ag" #-} ("-- " ++ getName nt_ ++ " " ++ replicate (60 - length (getName nt_)) '-') >-< (if dataTypes _lhsIoptions then "-- data" >-< _datatype >-< "" else empty) >-< (if _hasWrapper then "-- wrapper" >-< _wr_inh >-< _wr_syn >-< _wrapper >-< "" else empty) >-< (if folds _lhsIoptions then "-- cata" >-< _sem_nt >-< "" else empty) >-< (if semfuns _lhsIoptions then "-- semantic domain" >-< _t_init >-< _t_states >-< _k_states >-< _prodsIt_visits >-< _prodsIsem_prod >-< "" else empty) {-# LINE 1316 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 123, column 18) _hasWrapper = ({-# LINE 123 "src-ag/ExecutionPlan2Hs.ag" #-} nt_ `Set.member` _lhsIwrappers {-# LINE 1322 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 136, column 18) _classPP = ({-# LINE 136 "src-ag/ExecutionPlan2Hs.ag" #-} ppClasses $ classCtxsToDocs classCtxs_ {-# LINE 1328 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 137, column 18) _aliasPre = ({-# LINE 137 "src-ag/ExecutionPlan2Hs.ag" #-} "type" >#< _classPP >#< nt_ >#< _t_params >#< "=" {-# LINE 1334 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 138, column 18) _datatype = ({-# LINE 138 "src-ag/ExecutionPlan2Hs.ag" #-} case lookup nt_ _lhsItypeSyns of Nothing -> "data" >#< _classPP >#< nt_ >#< _t_params >-< ( if null _prodsIdatatype then empty else indent 2 $ vlist $ ( ("=" >#< head _prodsIdatatype) : (map ("|" >#<) $ tail _prodsIdatatype)) ) >-< indent 2 _derivings Just (List t) -> _aliasPre >#< "[" >#< show t >#< "]" Just (Maybe t) -> _aliasPre >#< "Maybe" >#< show t Just (Tuple ts) -> _aliasPre >#< pp_parens (ppCommas $ map (show . snd) ts) Just (Either l r) -> _aliasPre >#< "Either" >#< show l >#< show r Just (Map k v) -> _aliasPre >#< "Data.Map" >#< pp_parens (show k) >#< show v Just (IntMap t) -> _aliasPre >#< "Data.IntMap.IntMap" >#< show t Just (OrdSet t) -> _aliasPre >#< "Data.Set.Set" >#< show t Just IntSet -> _aliasPre >#< "Data.IntSet.IntSet" {-# LINE 1355 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 155, column 18) _derivings = ({-# LINE 155 "src-ag/ExecutionPlan2Hs.ag" #-} case Map.lookup nt_ _lhsIderivings of Nothing -> empty Just s -> if Set.null s then empty else "deriving" >#< (pp_parens $ ppCommas $ map pp $ Set.toList s) {-# LINE 1365 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 228, column 18) _fsemname = ({-# LINE 228 "src-ag/ExecutionPlan2Hs.ag" #-} \x -> "sem_" ++ show x {-# LINE 1371 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 229, column 18) _semname = ({-# LINE 229 "src-ag/ExecutionPlan2Hs.ag" #-} _fsemname nt_ {-# LINE 1377 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 230, column 18) _frecarg = ({-# LINE 230 "src-ag/ExecutionPlan2Hs.ag" #-} \t x -> case t of NT nt _ _ -> pp_parens (_fsemname nt >#< x) _ -> pp x {-# LINE 1385 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 236, column 18) _sem_tp = ({-# LINE 236 "src-ag/ExecutionPlan2Hs.ag" #-} _quantPP >#< _classPP >#< nt_ >#< _t_params >#< "->" >#< _t_type >#< _t_params {-# LINE 1391 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 237, column 18) _quantPP = ({-# LINE 237 "src-ag/ExecutionPlan2Hs.ag" #-} ppQuants params_ {-# LINE 1397 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 238, column 18) _sem_nt = ({-# LINE 238 "src-ag/ExecutionPlan2Hs.ag" #-} _semPragma >-< _semname >#< "::" >#< _sem_tp >-< case lookup nt_ _lhsItypeSyns of Nothing -> _prodsIsem_nt Just (List t) -> _semname >#< "list" >#< "=" >#< "Prelude.foldr" >#< _semname >|< "_Cons" >#< _semname >|< "_Nil" >#< case t of NT nt _ _ -> pp_parens ("Prelude.map" >#< _fsemname nt >#< "list") _ -> pp "list" Just (Maybe t) -> _semname >#< "Prelude.Nothing" >#< "=" >#< _semname >|< "_Nothing" >-< _semname >#< pp_parens ("Prelude.Just just") >#< "=" >#< _semname >|< "_Just" >#< _frecarg t "just" Just (Tuple ts) -> _semname >#< pp_parens (ppCommas $ map fst ts) >#< "=" >#< _semname >|< "_Tuple" >#< ppSpaced (map (\t -> _frecarg (snd t) (show $ fst t)) ts) Just (Either l r) -> _semname >#< "(Prelude.Left left)" >#< "=" >#< _semname >|< "_Left" >#< _frecarg l "left" >-< _semname >#< "(Prelude.Right right)" >#< "=" >#< _semname >|< "_Right" >#< _frecarg r "right" Just (Map k v) -> _semname >#< "m" >#< "=" >#< "Data.Map.foldrWithKey" >#< _semname >|< "_Entry" >#< _semname >|< "_Nil" >#< case v of NT nt _ _ -> pp_parens ("Data.Map.map" >#< _fsemname nt >#< "m") _ -> pp "m" Just (IntMap v) -> _semname >#< "m" >#< "=" >#< "Data.IntMap.foldWithKey" >#< _semname >|< "_Entry" >#< _semname >|< "_Nil" >#< case v of NT nt _ _ -> pp_parens ("Data.IntMap.map" >#< _fsemname nt >#< "m") _ -> pp "m" Just (OrdSet t) -> _semname >#< "s" >#< "=" >#< "Prelude.foldr" >#< _semname >|< "_Entry" >#< _semname >|< "_Nil" >#< pp_parens ( ( case t of NT nt _ _ -> pp_parens ("Prelude.map" >#< _fsemname nt) _ -> empty ) >#< pp_parens ("Data.IntSet.elems" >#< "s") ) Just IntSet -> _semname >#< "s" >#< "=" >#< "Prelude.foldr" >#< _semname >|< "_Entry" >#< _semname >|< "_Nil" >#< pp_parens ("Data.IntSet.elems" >#< "s") {-# LINE 1439 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 278, column 17) _inlineNt = ({-# LINE 278 "src-ag/ExecutionPlan2Hs.ag" #-} not (lateHigherOrderBinding _lhsIoptions) && not recursive_ && (_prodsIcount == 1 || (aggressiveInlinePragmas _lhsIoptions && not _hasWrapper )) {-# LINE 1445 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 279, column 17) _semPragma = ({-# LINE 279 "src-ag/ExecutionPlan2Hs.ag" #-} if noInlinePragmas _lhsIoptions then empty else if _inlineNt then ppInline _semname else if helpInlining _lhsIoptions && not (lateHigherOrderBinding _lhsIoptions) then ppInlinable _semname else ppNoInline _semname {-# LINE 1457 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 324, column 19) (Just _prodsOinhmap ) = ({-# LINE 324 "src-ag/ExecutionPlan2Hs.ag" #-} Map.lookup nt_ _lhsIinhmap {-# LINE 1463 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 325, column 19) (Just _prodsOsynmap ) = ({-# LINE 325 "src-ag/ExecutionPlan2Hs.ag" #-} Map.lookup nt_ _lhsIsynmap {-# LINE 1469 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 326, column 18) _prodsOallInhmap = ({-# LINE 326 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIinhmap {-# LINE 1475 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 327, column 18) _prodsOallSynmap = ({-# LINE 327 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIsynmap {-# LINE 1481 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 348, column 18) _outedges = ({-# LINE 348 "src-ag/ExecutionPlan2Hs.ag" #-} Set.fromList $ map (\(_,f,_) -> f) _prodsIallvisits {-# LINE 1487 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 349, column 18) _inedges = ({-# LINE 349 "src-ag/ExecutionPlan2Hs.ag" #-} Set.fromList $ map (\(_,_,t) -> t) _prodsIallvisits {-# LINE 1493 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 350, column 18) _allstates = ({-# LINE 350 "src-ag/ExecutionPlan2Hs.ag" #-} Set.insert initial_ $ _inedges `Set.union` _outedges {-# LINE 1499 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 351, column 18) _stvisits = ({-# LINE 351 "src-ag/ExecutionPlan2Hs.ag" #-} \st -> filter (\(v,f,t) -> f == st) _prodsIallvisits {-# LINE 1505 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 352, column 18) _t_type = ({-# LINE 352 "src-ag/ExecutionPlan2Hs.ag" #-} "T_" >|< nt_ {-# LINE 1511 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 353, column 18) _t_params = ({-# LINE 353 "src-ag/ExecutionPlan2Hs.ag" #-} ppSpaced params_ {-# LINE 1517 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 354, column 18) _t_init = ({-# LINE 354 "src-ag/ExecutionPlan2Hs.ag" #-} "newtype" >#< _t_type >#< _t_params >#< "=" >#< _t_type >#< pp_braces ( "attach_">|< _t_type >#< "::" >#< ppMonadType _lhsIoptions >#< pp_parens (_t_type >|< "_s" >|< initial_ >#< _t_params )) {-# LINE 1526 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 358, column 18) _t_states = ({-# LINE 358 "src-ag/ExecutionPlan2Hs.ag" #-} vlist $ map (\st -> let nt_st = nt_ >|< "_s" >|< st t_st = "T_" >|< nt_st k_st = "K_" >|< nt_st c_st = "C_" >|< nt_st inv_st = "inv_" >|< nt_st nextVisit = Map.findWithDefault ManyVis st nextVisits_ in case nextVisit of NoneVis -> "data" >#< t_st >#< _t_params >#< "=" >#< c_st OneVis vId -> "newtype" >#< t_st >#< _t_params >#< "=" >#< c_st >#< (pp_braces $ inv_st >#< "::" >#< pp_parens (conNmTVisit nt_ vId >#< _t_params )) ManyVis -> "data" >#< t_st >#< _t_params >#< "where" >#< c_st >#< "::" >#< (pp_braces $ inv_st >#< "::" >#< "!" >|< pp_parens ("forall t." >#< k_st >#< _t_params >#< "t" >#< "->" >#< "t")) >#< "->" >#< t_st >#< _t_params ) $ Set.toList _allstates {-# LINE 1546 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 376, column 18) _k_type = ({-# LINE 376 "src-ag/ExecutionPlan2Hs.ag" #-} "K_" ++ show nt_ {-# LINE 1552 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 377, column 18) _k_states = ({-# LINE 377 "src-ag/ExecutionPlan2Hs.ag" #-} vlist $ map (\st -> let nt_st = nt_ >|< "_s" >|< st k_st = "K_" >|< nt_st outg = filter (\(v,f,t) -> f == st) _prodsIallvisits visitlist = vlist $ map (\(v,f,t) -> _k_type >|< "_v" >|< v >#< "::" >#< k_st >#< _t_params >#< pp_parens (_t_type >|< "_v" >|< v >#< _t_params ) ) outg nextVisit = Map.findWithDefault ManyVis st nextVisits_ decl = "data" >#< k_st >#< "k" >#< _t_params >#< "where" >-< indent 3 visitlist in case nextVisit of NoneVis -> empty OneVis _ -> empty ManyVis -> decl ) $ Set.toList _allstates {-# LINE 1571 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 444, column 18) _wr_inh = ({-# LINE 444 "src-ag/ExecutionPlan2Hs.ag" #-} _genwrap "Inh" _wr_inhs {-# LINE 1577 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 445, column 18) _wr_syn = ({-# LINE 445 "src-ag/ExecutionPlan2Hs.ag" #-} _genwrap "Syn" _wr_syns {-# LINE 1583 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 446, column 18) _genwrap = ({-# LINE 446 "src-ag/ExecutionPlan2Hs.ag" #-} \nm attr -> "data" >#< nm >|< "_" >|< nt_ >#< _t_params >#< "=" >#< nm >|< "_" >|< nt_ >#< "{" >#< (ppCommas $ map (\(i,t) -> i >|< "_" >|< nm >|< "_" >|< nt_ >#< "::" >#< (_addbang $ pp_parens $ typeToHaskellString (Just nt_) [] t)) attr) >#< "}" {-# LINE 1591 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 449, column 18) _synAttrs = ({-# LINE 449 "src-ag/ExecutionPlan2Hs.ag" #-} fromJust $ Map.lookup nt_ _lhsIinhmap {-# LINE 1597 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 450, column 18) _wr_inhs = ({-# LINE 450 "src-ag/ExecutionPlan2Hs.ag" #-} Map.toList $ _wr_filter $ _synAttrs {-# LINE 1603 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 451, column 18) _wr_inhs1 = ({-# LINE 451 "src-ag/ExecutionPlan2Hs.ag" #-} Map.toList _synAttrs {-# LINE 1609 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 452, column 18) _wr_filter = ({-# LINE 452 "src-ag/ExecutionPlan2Hs.ag" #-} if kennedyWarren _lhsIoptions && lateHigherOrderBinding _lhsIoptions then Map.delete idLateBindingAttr else id {-# LINE 1617 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 455, column 18) _wr_syns = ({-# LINE 455 "src-ag/ExecutionPlan2Hs.ag" #-} Map.toList $ fromJust $ Map.lookup nt_ _lhsIsynmap {-# LINE 1623 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 456, column 18) _inhlist = ({-# LINE 456 "src-ag/ExecutionPlan2Hs.ag" #-} map (lhsname True . fst) _wr_inhs {-# LINE 1629 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 457, column 18) _inhlist1 = ({-# LINE 457 "src-ag/ExecutionPlan2Hs.ag" #-} map (lhsname True . fst) _wr_inhs1 {-# LINE 1635 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 458, column 18) _synlist = ({-# LINE 458 "src-ag/ExecutionPlan2Hs.ag" #-} map (lhsname False . fst) _wr_syns {-# LINE 1641 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 459, column 18) _wrapname = ({-# LINE 459 "src-ag/ExecutionPlan2Hs.ag" #-} "wrap_" ++ show nt_ {-# LINE 1647 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 460, column 18) _inhname = ({-# LINE 460 "src-ag/ExecutionPlan2Hs.ag" #-} "Inh_" ++ show nt_ {-# LINE 1653 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 461, column 18) _synname = ({-# LINE 461 "src-ag/ExecutionPlan2Hs.ag" #-} "Syn_" ++ show nt_ {-# LINE 1659 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 462, column 18) _firstVisitInfo = ({-# LINE 462 "src-ag/ExecutionPlan2Hs.ag" #-} Map.findWithDefault ManyVis initial_ nextVisits_ {-# LINE 1665 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 463, column 18) _wrapper = ({-# LINE 463 "src-ag/ExecutionPlan2Hs.ag" #-} _wrapPragma >-< (_wrapname >#< "::" >#< _quantPP >#< _classPP >#< _t_type >#< _t_params >#< "->" >#< _inhname >#< _t_params >#< "->" >#< ( if monadicWrappers _lhsIoptions then ppMonadType _lhsIoptions else empty) >#< pp_parens (_synname >#< _t_params )) >-< (_wrapname >#< (_addbang $ pp_parens (_t_type >#< pp "act")) >#< (_addbang $ pp_parens (_inhname >#< (ppSpaced $ map (_addbangWrap . pp) _inhlist )) >#< "=")) >-< indent 3 (case initialv_ of Nothing -> _synname >#< " { }" Just initv -> let inCon = conNmTVisitIn nt_ initv outCon = conNmTVisitOut nt_ initv pat = _addbang $ pp_parens $ pat0 pat0 = outCon >#< ppSpaced _synlist arg = inCon >#< ppSpaced _inhlist1 ind = case _firstVisitInfo of NoneVis -> error "wrapper: initial state should have a next visit but it has none" OneVis _ -> empty ManyVis -> _k_type >|< "_v" >|< initv extra = if dummyTokenVisit _lhsIoptions then pp $ dummyArg _lhsIoptions True else empty convert = case Map.lookup initv _lhsIallVisitKinds of Just kind -> case kind of VisitPure _ -> text "return" VisitMonadic -> empty unMonad | monadicWrappers _lhsIoptions = empty | otherwise = unMon _lhsIoptions in unMonad >#< "(" >-< indent 2 ( "do" >#< ( _addbang (pp "sem") >#< "<-" >#< "act" >-< "let" >#< _addbangWrap (pp "arg") >#< "=" >#< arg >-< pat >#< "<-" >#< convert >#< pp_parens ("inv_" >|< nt_ >|< "_s" >|< initial_ >#< "sem" >#< ind >#< "arg" >#< extra) >-< "return" >#< pp_parens (_synname >#< ppSpaced _synlist ) ) ) >-< ")" ) >-< if kennedyWarren _lhsIoptions && lateHigherOrderBinding _lhsIoptions then indent 2 ("where" >#< lhsname True idLateBindingAttr >#< "=" >#< lateBindingFieldNm _lhsImainName) else empty {-# LINE 1710 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 504, column 18) _wrapPragma = ({-# LINE 504 "src-ag/ExecutionPlan2Hs.ag" #-} if parallelInvoke _lhsIoptions && not (monadicWrappers _lhsIoptions) then ppNoInline _wrapname else if noInlinePragmas _lhsIoptions then empty else ppInlinable _wrapname {-# LINE 1720 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 516, column 3) _lhsOsemFunBndDefs = ({-# LINE 516 "src-ag/ExecutionPlan2Hs.ag" #-} _semFunBndDef Seq.<| _prodsIsemFunBndDefs {-# LINE 1726 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 517, column 3) _lhsOsemFunBndTps = ({-# LINE 517 "src-ag/ExecutionPlan2Hs.ag" #-} _semFunBndTp Seq.<| _prodsIsemFunBndTps {-# LINE 1732 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 518, column 3) _semFunBndDef = ({-# LINE 518 "src-ag/ExecutionPlan2Hs.ag" #-} _semFunBndNm >#< "=" >#< _semname {-# LINE 1738 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 519, column 3) _semFunBndTp = ({-# LINE 519 "src-ag/ExecutionPlan2Hs.ag" #-} _semFunBndNm >#< "::" >#< _sem_tp {-# LINE 1744 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 520, column 3) _semFunBndNm = ({-# LINE 520 "src-ag/ExecutionPlan2Hs.ag" #-} lateSemNtLabel nt_ {-# LINE 1750 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 558, column 18) _prodsOinitial = ({-# LINE 558 "src-ag/ExecutionPlan2Hs.ag" #-} initial_ {-# LINE 1756 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 559, column 18) _prodsOallstates = ({-# LINE 559 "src-ag/ExecutionPlan2Hs.ag" #-} _allstates {-# LINE 1762 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 1430, column 18) _lhsOappendMain = ({-# LINE 1430 "src-ag/ExecutionPlan2Hs.ag" #-} (if nt_ `Set.member` _lhsIwrappers then _wr_inh >-< _wr_syn >-< _wrapper else empty) >-< _sem_nt {-# LINE 1773 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 1436, column 18) _lhsOappendCommon = ({-# LINE 1436 "src-ag/ExecutionPlan2Hs.ag" #-} (if dataTypes _lhsIoptions then _datatype else empty) >-< _t_init >-< _t_states >-< _k_states >-< _prodsIt_visits {-# LINE 1783 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 1496, column 37) _addbang = ({-# LINE 1496 "src-ag/ExecutionPlan2Hs.ag" #-} \x -> if bangpats _lhsIoptions then "!" >|< x else x {-# LINE 1789 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 1504, column 37) _addbangWrap = ({-# LINE 1504 "src-ag/ExecutionPlan2Hs.ag" #-} if strictWrap _lhsIoptions then _addbang else id {-# LINE 1795 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 1516, column 3) _prodsOnextVisits = ({-# LINE 1516 "src-ag/ExecutionPlan2Hs.ag" #-} nextVisits_ {-# LINE 1801 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 1517, column 3) _prodsOprevVisits = ({-# LINE 1517 "src-ag/ExecutionPlan2Hs.ag" #-} prevVisits_ {-# LINE 1807 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 1561, column 3) _prodsOlocalAttrTypes = ({-# LINE 1561 "src-ag/ExecutionPlan2Hs.ag" #-} Map.findWithDefault Map.empty nt_ _lhsIlocalAttrTypes {-# LINE 1813 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 1588, column 3) _lhsOinitStates = ({-# LINE 1588 "src-ag/ExecutionPlan2Hs.ag" #-} Map.singleton nt_ initial_ {-# LINE 1819 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 1602, column 3) _ntType = ({-# LINE 1602 "src-ag/ExecutionPlan2Hs.ag" #-} NT nt_ (map show params_) False {-# LINE 1825 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- use rule "src-ag/ExecutionPlan2Hs.ag"(line 1167, column 37) _lhsOchildvisit = ({-# LINE 1167 "src-ag/ExecutionPlan2Hs.ag" #-} _prodsIchildvisit {-# LINE 1831 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- use rule "src-ag/ExecutionPlan2Hs.ag"(line 1609, column 132) _lhsOerrors = ({-# LINE 1609 "src-ag/ExecutionPlan2Hs.ag" #-} _prodsIerrors {-# LINE 1837 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- use rule "src-ag/ExecutionPlan2Hs.ag"(line 1524, column 22) _lhsOfromToStates = ({-# LINE 1524 "src-ag/ExecutionPlan2Hs.ag" #-} _prodsIfromToStates {-# LINE 1843 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- use rule "src-ag/ExecutionPlan2Hs.ag"(line 1444, column 49) _lhsOgenProdIO = ({-# LINE 1444 "src-ag/ExecutionPlan2Hs.ag" #-} _prodsIgenProdIO {-# LINE 1849 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- use rule "src-ag/ExecutionPlan2Hs.ag"(line 1443, column 47) _lhsOimports = ({-# LINE 1443 "src-ag/ExecutionPlan2Hs.ag" #-} _prodsIimports {-# LINE 1855 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- use rule "src-ag/ExecutionPlan2Hs.ag"(line 1571, column 68) _lhsOvisitKinds = ({-# LINE 1571 "src-ag/ExecutionPlan2Hs.ag" #-} _prodsIvisitKinds {-# LINE 1861 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- use rule "src-ag/ExecutionPlan2Hs.ag"(line 1302, column 36) _lhsOvisitdefs = ({-# LINE 1302 "src-ag/ExecutionPlan2Hs.ag" #-} _prodsIvisitdefs {-# LINE 1867 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- use rule "src-ag/ExecutionPlan2Hs.ag"(line 1303, column 36) _lhsOvisituses = ({-# LINE 1303 "src-ag/ExecutionPlan2Hs.ag" #-} _prodsIvisituses {-# LINE 1873 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _prodsOallFromToStates = ({-# LINE 1527 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIallFromToStates {-# LINE 1879 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _prodsOallInitStates = ({-# LINE 1585 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIallInitStates {-# LINE 1885 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _prodsOallVisitKinds = ({-# LINE 1571 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIallVisitKinds {-# LINE 1891 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _prodsOallchildvisit = ({-# LINE 1166 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIallchildvisit {-# LINE 1897 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _prodsOavisitdefs = ({-# LINE 1312 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIavisitdefs {-# LINE 1903 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _prodsOavisituses = ({-# LINE 1313 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIavisituses {-# LINE 1909 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _prodsOimportBlocks = ({-# LINE 34 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIimportBlocks {-# LINE 1915 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _prodsOmainFile = ({-# LINE 38 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsImainFile {-# LINE 1921 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _prodsOmainName = ({-# LINE 39 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsImainName {-# LINE 1927 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _prodsOmoduleHeader = ({-# LINE 37 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsImoduleHeader {-# LINE 1933 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (from local) _prodsOntType = ({-# LINE 1600 "src-ag/ExecutionPlan2Hs.ag" #-} _ntType {-# LINE 1939 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _prodsOoptions = ({-# LINE 51 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIoptions {-# LINE 1945 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _prodsOpragmaBlocks = ({-# LINE 35 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIpragmaBlocks {-# LINE 1951 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _prodsOtextBlocks = ({-# LINE 36 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsItextBlocks {-# LINE 1957 "src-ag/ExecutionPlan2Hs.hs" #-} ) ( _prodsIallvisits,_prodsIchildvisit,_prodsIcount,_prodsIdatatype,_prodsIerrors,_prodsIfromToStates,_prodsIgenProdIO,_prodsIimports,_prodsIsemFunBndDefs,_prodsIsemFunBndTps,_prodsIsem_nt,_prodsIsem_prod,_prodsIt_visits,_prodsIvisitKinds,_prodsIvisitdefs,_prodsIvisituses) = prods_ _prodsOallFromToStates _prodsOallInhmap _prodsOallInitStates _prodsOallSynmap _prodsOallVisitKinds _prodsOallchildvisit _prodsOallstates _prodsOavisitdefs _prodsOavisituses _prodsOclassCtxs _prodsOimportBlocks _prodsOinhmap _prodsOinitial _prodsOlocalAttrTypes _prodsOmainFile _prodsOmainName _prodsOmoduleHeader _prodsOnextVisits _prodsOnt _prodsOntType _prodsOoptions _prodsOparams _prodsOpragmaBlocks _prodsOprevVisits _prodsOrename _prodsOsynmap _prodsOtextBlocks in ( _lhsOappendCommon,_lhsOappendMain,_lhsOchildvisit,_lhsOerrors,_lhsOfromToStates,_lhsOgenProdIO,_lhsOimports,_lhsOinitStates,_lhsOoutput,_lhsOsemFunBndDefs,_lhsOsemFunBndTps,_lhsOvisitKinds,_lhsOvisitdefs,_lhsOvisituses))) ) -- ENonterminals ----------------------------------------------- {- visit 0: inherited attributes: allFromToStates : Map VisitIdentifier (Int,Int) allInitStates : Map NontermIdent Int allVisitKinds : Map VisitIdentifier VisitKind allchildvisit : Map VisitIdentifier (Identifier -> VisitKind -> Either Error (PP_Doc, PP_Doc)) avisitdefs : Map VisitIdentifier (Set Identifier) avisituses : Map VisitIdentifier (Set Identifier) derivings : Derivings importBlocks : PP_Doc inhmap : Map NontermIdent Attributes localAttrTypes : Map NontermIdent (Map ConstructorIdent (Map Identifier Type)) mainFile : String mainName : String moduleHeader : String -> String -> String -> Bool -> String options : Options pragmaBlocks : String synmap : Map NontermIdent Attributes textBlocks : PP_Doc typeSyns : TypeSyns wrappers : Set NontermIdent synthesized attributes: appendCommon : [PP_Doc] appendMain : [PP_Doc] childvisit : Map VisitIdentifier (Identifier -> VisitKind -> Either Error (PP_Doc, PP_Doc)) errors : Seq Error fromToStates : Map VisitIdentifier (Int,Int) genProdIO : IO () imports : [PP_Doc] initStates : Map NontermIdent Int output : PP_Doc semFunBndDefs : Seq PP_Doc semFunBndTps : Seq PP_Doc visitKinds : Map VisitIdentifier VisitKind visitdefs : Map VisitIdentifier (Set Identifier) visituses : Map VisitIdentifier (Set Identifier) alternatives: alternative Cons: child hd : ENonterminal child tl : ENonterminals alternative Nil: -} -- cata sem_ENonterminals :: ENonterminals -> T_ENonterminals sem_ENonterminals list = (Prelude.foldr sem_ENonterminals_Cons sem_ENonterminals_Nil (Prelude.map sem_ENonterminal list) ) -- semantic domain newtype T_ENonterminals = T_ENonterminals ((Map VisitIdentifier (Int,Int)) -> (Map NontermIdent Int) -> (Map VisitIdentifier VisitKind) -> (Map VisitIdentifier (Identifier -> VisitKind -> Either Error (PP_Doc, PP_Doc))) -> (Map VisitIdentifier (Set Identifier)) -> (Map VisitIdentifier (Set Identifier)) -> Derivings -> PP_Doc -> (Map NontermIdent Attributes) -> (Map NontermIdent (Map ConstructorIdent (Map Identifier Type))) -> String -> String -> (String -> String -> String -> Bool -> String) -> Options -> String -> (Map NontermIdent Attributes) -> PP_Doc -> TypeSyns -> (Set NontermIdent) -> ( ([PP_Doc]),([PP_Doc]),(Map VisitIdentifier (Identifier -> VisitKind -> Either Error (PP_Doc, PP_Doc))),(Seq Error),(Map VisitIdentifier (Int,Int)),(IO ()),([PP_Doc]),(Map NontermIdent Int),PP_Doc,(Seq PP_Doc),(Seq PP_Doc),(Map VisitIdentifier VisitKind),(Map VisitIdentifier (Set Identifier)),(Map VisitIdentifier (Set Identifier)))) data Inh_ENonterminals = Inh_ENonterminals {allFromToStates_Inh_ENonterminals :: (Map VisitIdentifier (Int,Int)),allInitStates_Inh_ENonterminals :: (Map NontermIdent Int),allVisitKinds_Inh_ENonterminals :: (Map VisitIdentifier VisitKind),allchildvisit_Inh_ENonterminals :: (Map VisitIdentifier (Identifier -> VisitKind -> Either Error (PP_Doc, PP_Doc))),avisitdefs_Inh_ENonterminals :: (Map VisitIdentifier (Set Identifier)),avisituses_Inh_ENonterminals :: (Map VisitIdentifier (Set Identifier)),derivings_Inh_ENonterminals :: Derivings,importBlocks_Inh_ENonterminals :: PP_Doc,inhmap_Inh_ENonterminals :: (Map NontermIdent Attributes),localAttrTypes_Inh_ENonterminals :: (Map NontermIdent (Map ConstructorIdent (Map Identifier Type))),mainFile_Inh_ENonterminals :: String,mainName_Inh_ENonterminals :: String,moduleHeader_Inh_ENonterminals :: (String -> String -> String -> Bool -> String),options_Inh_ENonterminals :: Options,pragmaBlocks_Inh_ENonterminals :: String,synmap_Inh_ENonterminals :: (Map NontermIdent Attributes),textBlocks_Inh_ENonterminals :: PP_Doc,typeSyns_Inh_ENonterminals :: TypeSyns,wrappers_Inh_ENonterminals :: (Set NontermIdent)} data Syn_ENonterminals = Syn_ENonterminals {appendCommon_Syn_ENonterminals :: ([PP_Doc]),appendMain_Syn_ENonterminals :: ([PP_Doc]),childvisit_Syn_ENonterminals :: (Map VisitIdentifier (Identifier -> VisitKind -> Either Error (PP_Doc, PP_Doc))),errors_Syn_ENonterminals :: (Seq Error),fromToStates_Syn_ENonterminals :: (Map VisitIdentifier (Int,Int)),genProdIO_Syn_ENonterminals :: (IO ()),imports_Syn_ENonterminals :: ([PP_Doc]),initStates_Syn_ENonterminals :: (Map NontermIdent Int),output_Syn_ENonterminals :: PP_Doc,semFunBndDefs_Syn_ENonterminals :: (Seq PP_Doc),semFunBndTps_Syn_ENonterminals :: (Seq PP_Doc),visitKinds_Syn_ENonterminals :: (Map VisitIdentifier VisitKind),visitdefs_Syn_ENonterminals :: (Map VisitIdentifier (Set Identifier)),visituses_Syn_ENonterminals :: (Map VisitIdentifier (Set Identifier))} wrap_ENonterminals :: T_ENonterminals -> Inh_ENonterminals -> Syn_ENonterminals wrap_ENonterminals (T_ENonterminals sem ) (Inh_ENonterminals _lhsIallFromToStates _lhsIallInitStates _lhsIallVisitKinds _lhsIallchildvisit _lhsIavisitdefs _lhsIavisituses _lhsIderivings _lhsIimportBlocks _lhsIinhmap _lhsIlocalAttrTypes _lhsImainFile _lhsImainName _lhsImoduleHeader _lhsIoptions _lhsIpragmaBlocks _lhsIsynmap _lhsItextBlocks _lhsItypeSyns _lhsIwrappers ) = (let ( _lhsOappendCommon,_lhsOappendMain,_lhsOchildvisit,_lhsOerrors,_lhsOfromToStates,_lhsOgenProdIO,_lhsOimports,_lhsOinitStates,_lhsOoutput,_lhsOsemFunBndDefs,_lhsOsemFunBndTps,_lhsOvisitKinds,_lhsOvisitdefs,_lhsOvisituses) = sem _lhsIallFromToStates _lhsIallInitStates _lhsIallVisitKinds _lhsIallchildvisit _lhsIavisitdefs _lhsIavisituses _lhsIderivings _lhsIimportBlocks _lhsIinhmap _lhsIlocalAttrTypes _lhsImainFile _lhsImainName _lhsImoduleHeader _lhsIoptions _lhsIpragmaBlocks _lhsIsynmap _lhsItextBlocks _lhsItypeSyns _lhsIwrappers in (Syn_ENonterminals _lhsOappendCommon _lhsOappendMain _lhsOchildvisit _lhsOerrors _lhsOfromToStates _lhsOgenProdIO _lhsOimports _lhsOinitStates _lhsOoutput _lhsOsemFunBndDefs _lhsOsemFunBndTps _lhsOvisitKinds _lhsOvisitdefs _lhsOvisituses )) sem_ENonterminals_Cons :: T_ENonterminal -> T_ENonterminals -> T_ENonterminals sem_ENonterminals_Cons (T_ENonterminal hd_ ) (T_ENonterminals tl_ ) = (T_ENonterminals (\ _lhsIallFromToStates _lhsIallInitStates _lhsIallVisitKinds _lhsIallchildvisit _lhsIavisitdefs _lhsIavisituses _lhsIderivings _lhsIimportBlocks _lhsIinhmap _lhsIlocalAttrTypes _lhsImainFile _lhsImainName _lhsImoduleHeader _lhsIoptions _lhsIpragmaBlocks _lhsIsynmap _lhsItextBlocks _lhsItypeSyns _lhsIwrappers -> (let _lhsOappendCommon :: ([PP_Doc]) _lhsOappendMain :: ([PP_Doc]) _lhsOchildvisit :: (Map VisitIdentifier (Identifier -> VisitKind -> Either Error (PP_Doc, PP_Doc))) _lhsOerrors :: (Seq Error) _lhsOfromToStates :: (Map VisitIdentifier (Int,Int)) _lhsOgenProdIO :: (IO ()) _lhsOimports :: ([PP_Doc]) _lhsOinitStates :: (Map NontermIdent Int) _lhsOoutput :: PP_Doc _lhsOsemFunBndDefs :: (Seq PP_Doc) _lhsOsemFunBndTps :: (Seq PP_Doc) _lhsOvisitKinds :: (Map VisitIdentifier VisitKind) _lhsOvisitdefs :: (Map VisitIdentifier (Set Identifier)) _lhsOvisituses :: (Map VisitIdentifier (Set Identifier)) _hdOallFromToStates :: (Map VisitIdentifier (Int,Int)) _hdOallInitStates :: (Map NontermIdent Int) _hdOallVisitKinds :: (Map VisitIdentifier VisitKind) _hdOallchildvisit :: (Map VisitIdentifier (Identifier -> VisitKind -> Either Error (PP_Doc, PP_Doc))) _hdOavisitdefs :: (Map VisitIdentifier (Set Identifier)) _hdOavisituses :: (Map VisitIdentifier (Set Identifier)) _hdOderivings :: Derivings _hdOimportBlocks :: PP_Doc _hdOinhmap :: (Map NontermIdent Attributes) _hdOlocalAttrTypes :: (Map NontermIdent (Map ConstructorIdent (Map Identifier Type))) _hdOmainFile :: String _hdOmainName :: String _hdOmoduleHeader :: (String -> String -> String -> Bool -> String) _hdOoptions :: Options _hdOpragmaBlocks :: String _hdOsynmap :: (Map NontermIdent Attributes) _hdOtextBlocks :: PP_Doc _hdOtypeSyns :: TypeSyns _hdOwrappers :: (Set NontermIdent) _tlOallFromToStates :: (Map VisitIdentifier (Int,Int)) _tlOallInitStates :: (Map NontermIdent Int) _tlOallVisitKinds :: (Map VisitIdentifier VisitKind) _tlOallchildvisit :: (Map VisitIdentifier (Identifier -> VisitKind -> Either Error (PP_Doc, PP_Doc))) _tlOavisitdefs :: (Map VisitIdentifier (Set Identifier)) _tlOavisituses :: (Map VisitIdentifier (Set Identifier)) _tlOderivings :: Derivings _tlOimportBlocks :: PP_Doc _tlOinhmap :: (Map NontermIdent Attributes) _tlOlocalAttrTypes :: (Map NontermIdent (Map ConstructorIdent (Map Identifier Type))) _tlOmainFile :: String _tlOmainName :: String _tlOmoduleHeader :: (String -> String -> String -> Bool -> String) _tlOoptions :: Options _tlOpragmaBlocks :: String _tlOsynmap :: (Map NontermIdent Attributes) _tlOtextBlocks :: PP_Doc _tlOtypeSyns :: TypeSyns _tlOwrappers :: (Set NontermIdent) _hdIappendCommon :: ( PP_Doc ) _hdIappendMain :: ( PP_Doc ) _hdIchildvisit :: (Map VisitIdentifier (Identifier -> VisitKind -> Either Error (PP_Doc, PP_Doc))) _hdIerrors :: (Seq Error) _hdIfromToStates :: (Map VisitIdentifier (Int,Int)) _hdIgenProdIO :: (IO ()) _hdIimports :: ([PP_Doc]) _hdIinitStates :: (Map NontermIdent Int) _hdIoutput :: PP_Doc _hdIsemFunBndDefs :: (Seq PP_Doc) _hdIsemFunBndTps :: (Seq PP_Doc) _hdIvisitKinds :: (Map VisitIdentifier VisitKind) _hdIvisitdefs :: (Map VisitIdentifier (Set Identifier)) _hdIvisituses :: (Map VisitIdentifier (Set Identifier)) _tlIappendCommon :: ([PP_Doc]) _tlIappendMain :: ([PP_Doc]) _tlIchildvisit :: (Map VisitIdentifier (Identifier -> VisitKind -> Either Error (PP_Doc, PP_Doc))) _tlIerrors :: (Seq Error) _tlIfromToStates :: (Map VisitIdentifier (Int,Int)) _tlIgenProdIO :: (IO ()) _tlIimports :: ([PP_Doc]) _tlIinitStates :: (Map NontermIdent Int) _tlIoutput :: PP_Doc _tlIsemFunBndDefs :: (Seq PP_Doc) _tlIsemFunBndTps :: (Seq PP_Doc) _tlIvisitKinds :: (Map VisitIdentifier VisitKind) _tlIvisitdefs :: (Map VisitIdentifier (Set Identifier)) _tlIvisituses :: (Map VisitIdentifier (Set Identifier)) -- use rule "src-ag/ExecutionPlan2Hs.ag"(line 1427, column 51) _lhsOappendCommon = ({-# LINE 1427 "src-ag/ExecutionPlan2Hs.ag" #-} _hdIappendCommon : _tlIappendCommon {-# LINE 2147 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- use rule "src-ag/ExecutionPlan2Hs.ag"(line 1427, column 51) _lhsOappendMain = ({-# LINE 1427 "src-ag/ExecutionPlan2Hs.ag" #-} _hdIappendMain : _tlIappendMain {-# LINE 2153 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- use rule "src-ag/ExecutionPlan2Hs.ag"(line 1167, column 37) _lhsOchildvisit = ({-# LINE 1167 "src-ag/ExecutionPlan2Hs.ag" #-} _hdIchildvisit `Map.union` _tlIchildvisit {-# LINE 2159 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- use rule "src-ag/ExecutionPlan2Hs.ag"(line 1609, column 132) _lhsOerrors = ({-# LINE 1609 "src-ag/ExecutionPlan2Hs.ag" #-} _hdIerrors Seq.>< _tlIerrors {-# LINE 2165 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- use rule "src-ag/ExecutionPlan2Hs.ag"(line 1524, column 22) _lhsOfromToStates = ({-# LINE 1524 "src-ag/ExecutionPlan2Hs.ag" #-} _hdIfromToStates `mappend` _tlIfromToStates {-# LINE 2171 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- use rule "src-ag/ExecutionPlan2Hs.ag"(line 1444, column 49) _lhsOgenProdIO = ({-# LINE 1444 "src-ag/ExecutionPlan2Hs.ag" #-} _hdIgenProdIO >> _tlIgenProdIO {-# LINE 2177 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- use rule "src-ag/ExecutionPlan2Hs.ag"(line 1443, column 47) _lhsOimports = ({-# LINE 1443 "src-ag/ExecutionPlan2Hs.ag" #-} _hdIimports ++ _tlIimports {-# LINE 2183 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- use rule "src-ag/ExecutionPlan2Hs.ag"(line 1583, column 50) _lhsOinitStates = ({-# LINE 1583 "src-ag/ExecutionPlan2Hs.ag" #-} _hdIinitStates `mappend` _tlIinitStates {-# LINE 2189 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- use rule "src-ag/ExecutionPlan2Hs.ag"(line 90, column 45) _lhsOoutput = ({-# LINE 90 "src-ag/ExecutionPlan2Hs.ag" #-} _hdIoutput >-< _tlIoutput {-# LINE 2195 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- use rule "src-ag/ExecutionPlan2Hs.ag"(line 514, column 92) _lhsOsemFunBndDefs = ({-# LINE 514 "src-ag/ExecutionPlan2Hs.ag" #-} _hdIsemFunBndDefs Seq.>< _tlIsemFunBndDefs {-# LINE 2201 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- use rule "src-ag/ExecutionPlan2Hs.ag"(line 514, column 92) _lhsOsemFunBndTps = ({-# LINE 514 "src-ag/ExecutionPlan2Hs.ag" #-} _hdIsemFunBndTps Seq.>< _tlIsemFunBndTps {-# LINE 2207 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- use rule "src-ag/ExecutionPlan2Hs.ag"(line 1571, column 68) _lhsOvisitKinds = ({-# LINE 1571 "src-ag/ExecutionPlan2Hs.ag" #-} _hdIvisitKinds `mappend` _tlIvisitKinds {-# LINE 2213 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- use rule "src-ag/ExecutionPlan2Hs.ag"(line 1302, column 36) _lhsOvisitdefs = ({-# LINE 1302 "src-ag/ExecutionPlan2Hs.ag" #-} _hdIvisitdefs `uwSetUnion` _tlIvisitdefs {-# LINE 2219 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- use rule "src-ag/ExecutionPlan2Hs.ag"(line 1303, column 36) _lhsOvisituses = ({-# LINE 1303 "src-ag/ExecutionPlan2Hs.ag" #-} _hdIvisituses `uwSetUnion` _tlIvisituses {-# LINE 2225 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _hdOallFromToStates = ({-# LINE 1527 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIallFromToStates {-# LINE 2231 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _hdOallInitStates = ({-# LINE 1585 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIallInitStates {-# LINE 2237 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _hdOallVisitKinds = ({-# LINE 1571 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIallVisitKinds {-# LINE 2243 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _hdOallchildvisit = ({-# LINE 1166 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIallchildvisit {-# LINE 2249 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _hdOavisitdefs = ({-# LINE 1312 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIavisitdefs {-# LINE 2255 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _hdOavisituses = ({-# LINE 1313 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIavisituses {-# LINE 2261 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _hdOderivings = ({-# LINE 129 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIderivings {-# LINE 2267 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _hdOimportBlocks = ({-# LINE 34 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIimportBlocks {-# LINE 2273 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _hdOinhmap = ({-# LINE 312 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIinhmap {-# LINE 2279 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _hdOlocalAttrTypes = ({-# LINE 1556 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIlocalAttrTypes {-# LINE 2285 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _hdOmainFile = ({-# LINE 38 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsImainFile {-# LINE 2291 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _hdOmainName = ({-# LINE 39 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsImainName {-# LINE 2297 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _hdOmoduleHeader = ({-# LINE 37 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsImoduleHeader {-# LINE 2303 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _hdOoptions = ({-# LINE 51 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIoptions {-# LINE 2309 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _hdOpragmaBlocks = ({-# LINE 35 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIpragmaBlocks {-# LINE 2315 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _hdOsynmap = ({-# LINE 313 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIsynmap {-# LINE 2321 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _hdOtextBlocks = ({-# LINE 36 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsItextBlocks {-# LINE 2327 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _hdOtypeSyns = ({-# LINE 128 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsItypeSyns {-# LINE 2333 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _hdOwrappers = ({-# LINE 89 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIwrappers {-# LINE 2339 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _tlOallFromToStates = ({-# LINE 1527 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIallFromToStates {-# LINE 2345 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _tlOallInitStates = ({-# LINE 1585 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIallInitStates {-# LINE 2351 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _tlOallVisitKinds = ({-# LINE 1571 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIallVisitKinds {-# LINE 2357 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _tlOallchildvisit = ({-# LINE 1166 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIallchildvisit {-# LINE 2363 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _tlOavisitdefs = ({-# LINE 1312 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIavisitdefs {-# LINE 2369 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _tlOavisituses = ({-# LINE 1313 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIavisituses {-# LINE 2375 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _tlOderivings = ({-# LINE 129 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIderivings {-# LINE 2381 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _tlOimportBlocks = ({-# LINE 34 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIimportBlocks {-# LINE 2387 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _tlOinhmap = ({-# LINE 312 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIinhmap {-# LINE 2393 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _tlOlocalAttrTypes = ({-# LINE 1556 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIlocalAttrTypes {-# LINE 2399 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _tlOmainFile = ({-# LINE 38 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsImainFile {-# LINE 2405 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _tlOmainName = ({-# LINE 39 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsImainName {-# LINE 2411 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _tlOmoduleHeader = ({-# LINE 37 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsImoduleHeader {-# LINE 2417 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _tlOoptions = ({-# LINE 51 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIoptions {-# LINE 2423 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _tlOpragmaBlocks = ({-# LINE 35 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIpragmaBlocks {-# LINE 2429 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _tlOsynmap = ({-# LINE 313 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIsynmap {-# LINE 2435 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _tlOtextBlocks = ({-# LINE 36 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsItextBlocks {-# LINE 2441 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _tlOtypeSyns = ({-# LINE 128 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsItypeSyns {-# LINE 2447 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _tlOwrappers = ({-# LINE 89 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIwrappers {-# LINE 2453 "src-ag/ExecutionPlan2Hs.hs" #-} ) ( _hdIappendCommon,_hdIappendMain,_hdIchildvisit,_hdIerrors,_hdIfromToStates,_hdIgenProdIO,_hdIimports,_hdIinitStates,_hdIoutput,_hdIsemFunBndDefs,_hdIsemFunBndTps,_hdIvisitKinds,_hdIvisitdefs,_hdIvisituses) = hd_ _hdOallFromToStates _hdOallInitStates _hdOallVisitKinds _hdOallchildvisit _hdOavisitdefs _hdOavisituses _hdOderivings _hdOimportBlocks _hdOinhmap _hdOlocalAttrTypes _hdOmainFile _hdOmainName _hdOmoduleHeader _hdOoptions _hdOpragmaBlocks _hdOsynmap _hdOtextBlocks _hdOtypeSyns _hdOwrappers ( _tlIappendCommon,_tlIappendMain,_tlIchildvisit,_tlIerrors,_tlIfromToStates,_tlIgenProdIO,_tlIimports,_tlIinitStates,_tlIoutput,_tlIsemFunBndDefs,_tlIsemFunBndTps,_tlIvisitKinds,_tlIvisitdefs,_tlIvisituses) = tl_ _tlOallFromToStates _tlOallInitStates _tlOallVisitKinds _tlOallchildvisit _tlOavisitdefs _tlOavisituses _tlOderivings _tlOimportBlocks _tlOinhmap _tlOlocalAttrTypes _tlOmainFile _tlOmainName _tlOmoduleHeader _tlOoptions _tlOpragmaBlocks _tlOsynmap _tlOtextBlocks _tlOtypeSyns _tlOwrappers in ( _lhsOappendCommon,_lhsOappendMain,_lhsOchildvisit,_lhsOerrors,_lhsOfromToStates,_lhsOgenProdIO,_lhsOimports,_lhsOinitStates,_lhsOoutput,_lhsOsemFunBndDefs,_lhsOsemFunBndTps,_lhsOvisitKinds,_lhsOvisitdefs,_lhsOvisituses))) ) sem_ENonterminals_Nil :: T_ENonterminals sem_ENonterminals_Nil = (T_ENonterminals (\ _lhsIallFromToStates _lhsIallInitStates _lhsIallVisitKinds _lhsIallchildvisit _lhsIavisitdefs _lhsIavisituses _lhsIderivings _lhsIimportBlocks _lhsIinhmap _lhsIlocalAttrTypes _lhsImainFile _lhsImainName _lhsImoduleHeader _lhsIoptions _lhsIpragmaBlocks _lhsIsynmap _lhsItextBlocks _lhsItypeSyns _lhsIwrappers -> (let _lhsOappendCommon :: ([PP_Doc]) _lhsOappendMain :: ([PP_Doc]) _lhsOchildvisit :: (Map VisitIdentifier (Identifier -> VisitKind -> Either Error (PP_Doc, PP_Doc))) _lhsOerrors :: (Seq Error) _lhsOfromToStates :: (Map VisitIdentifier (Int,Int)) _lhsOgenProdIO :: (IO ()) _lhsOimports :: ([PP_Doc]) _lhsOinitStates :: (Map NontermIdent Int) _lhsOoutput :: PP_Doc _lhsOsemFunBndDefs :: (Seq PP_Doc) _lhsOsemFunBndTps :: (Seq PP_Doc) _lhsOvisitKinds :: (Map VisitIdentifier VisitKind) _lhsOvisitdefs :: (Map VisitIdentifier (Set Identifier)) _lhsOvisituses :: (Map VisitIdentifier (Set Identifier)) -- use rule "src-ag/ExecutionPlan2Hs.ag"(line 1427, column 51) _lhsOappendCommon = ({-# LINE 1427 "src-ag/ExecutionPlan2Hs.ag" #-} [] {-# LINE 2499 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- use rule "src-ag/ExecutionPlan2Hs.ag"(line 1427, column 51) _lhsOappendMain = ({-# LINE 1427 "src-ag/ExecutionPlan2Hs.ag" #-} [] {-# LINE 2505 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- use rule "src-ag/ExecutionPlan2Hs.ag"(line 1167, column 37) _lhsOchildvisit = ({-# LINE 1167 "src-ag/ExecutionPlan2Hs.ag" #-} Map.empty {-# LINE 2511 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- use rule "src-ag/ExecutionPlan2Hs.ag"(line 1609, column 132) _lhsOerrors = ({-# LINE 1609 "src-ag/ExecutionPlan2Hs.ag" #-} Seq.empty {-# LINE 2517 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- use rule "src-ag/ExecutionPlan2Hs.ag"(line 1524, column 22) _lhsOfromToStates = ({-# LINE 1524 "src-ag/ExecutionPlan2Hs.ag" #-} mempty {-# LINE 2523 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- use rule "src-ag/ExecutionPlan2Hs.ag"(line 1444, column 49) _lhsOgenProdIO = ({-# LINE 1444 "src-ag/ExecutionPlan2Hs.ag" #-} return () {-# LINE 2529 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- use rule "src-ag/ExecutionPlan2Hs.ag"(line 1443, column 47) _lhsOimports = ({-# LINE 1443 "src-ag/ExecutionPlan2Hs.ag" #-} [] {-# LINE 2535 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- use rule "src-ag/ExecutionPlan2Hs.ag"(line 1583, column 50) _lhsOinitStates = ({-# LINE 1583 "src-ag/ExecutionPlan2Hs.ag" #-} mempty {-# LINE 2541 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- use rule "src-ag/ExecutionPlan2Hs.ag"(line 90, column 45) _lhsOoutput = ({-# LINE 90 "src-ag/ExecutionPlan2Hs.ag" #-} empty {-# LINE 2547 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- use rule "src-ag/ExecutionPlan2Hs.ag"(line 514, column 92) _lhsOsemFunBndDefs = ({-# LINE 514 "src-ag/ExecutionPlan2Hs.ag" #-} Seq.empty {-# LINE 2553 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- use rule "src-ag/ExecutionPlan2Hs.ag"(line 514, column 92) _lhsOsemFunBndTps = ({-# LINE 514 "src-ag/ExecutionPlan2Hs.ag" #-} Seq.empty {-# LINE 2559 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- use rule "src-ag/ExecutionPlan2Hs.ag"(line 1571, column 68) _lhsOvisitKinds = ({-# LINE 1571 "src-ag/ExecutionPlan2Hs.ag" #-} mempty {-# LINE 2565 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- use rule "src-ag/ExecutionPlan2Hs.ag"(line 1302, column 36) _lhsOvisitdefs = ({-# LINE 1302 "src-ag/ExecutionPlan2Hs.ag" #-} Map.empty {-# LINE 2571 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- use rule "src-ag/ExecutionPlan2Hs.ag"(line 1303, column 36) _lhsOvisituses = ({-# LINE 1303 "src-ag/ExecutionPlan2Hs.ag" #-} Map.empty {-# LINE 2577 "src-ag/ExecutionPlan2Hs.hs" #-} ) in ( _lhsOappendCommon,_lhsOappendMain,_lhsOchildvisit,_lhsOerrors,_lhsOfromToStates,_lhsOgenProdIO,_lhsOimports,_lhsOinitStates,_lhsOoutput,_lhsOsemFunBndDefs,_lhsOsemFunBndTps,_lhsOvisitKinds,_lhsOvisitdefs,_lhsOvisituses))) ) -- EProduction ------------------------------------------------- {- visit 0: inherited attributes: allFromToStates : Map VisitIdentifier (Int,Int) allInhmap : Map NontermIdent Attributes allInitStates : Map NontermIdent Int allSynmap : Map NontermIdent Attributes allVisitKinds : Map VisitIdentifier VisitKind allchildvisit : Map VisitIdentifier (Identifier -> VisitKind -> Either Error (PP_Doc, PP_Doc)) allstates : Set StateIdentifier avisitdefs : Map VisitIdentifier (Set Identifier) avisituses : Map VisitIdentifier (Set Identifier) classCtxs : ClassContext importBlocks : PP_Doc inhmap : Attributes initial : StateIdentifier localAttrTypes : Map ConstructorIdent (Map Identifier Type) mainFile : String mainName : String moduleHeader : String -> String -> String -> Bool -> String nextVisits : Map StateIdentifier StateCtx nt : NontermIdent ntType : Type options : Options params : [Identifier] pragmaBlocks : String prevVisits : Map StateIdentifier StateCtx rename : Bool synmap : Attributes textBlocks : PP_Doc synthesized attributes: allvisits : [VisitStateState] childvisit : Map VisitIdentifier (Identifier -> VisitKind -> Either Error (PP_Doc, PP_Doc)) count : Int datatype : PP_Doc errors : Seq Error fromToStates : Map VisitIdentifier (Int,Int) genProdIO : IO () imports : [PP_Doc] semFunBndDefs : Seq PP_Doc semFunBndTps : Seq PP_Doc sem_nt : PP_Doc sem_prod : PP_Doc t_visits : PP_Doc visitKinds : Map VisitIdentifier VisitKind visitdefs : Map VisitIdentifier (Set Identifier) visituses : Map VisitIdentifier (Set Identifier) alternatives: alternative EProduction: child con : {ConstructorIdent} child params : {[Identifier]} child constraints : {[Type]} child rules : ERules child children : EChildren child visits : Visits visit 0: local classPP1 : _ local quantPP1 : _ local semFunBndDef : _ local semFunBndTp : _ local semFunBndNm : _ local t_type : _ local t_params : _ local args : _ local semname : _ local sem_tp : _ local classPP2 : _ local quantPP2 : _ local sem_prod : _ local mkSemBody : _ local mbInitializer : _ local scc : _ local semInlinePragma : _ local outerlet : _ local statefns : _ local genstfn : _ local stargs : _ local stks : _ local stvisits : _ local stvs : _ local lazyIntras : _ local moduleName : _ local suffix : _ local outputfile : _ local ppMonadImports : _ local addbang : _ local childTypes : _ local localAttrTypes : _ -} -- cata sem_EProduction :: EProduction -> T_EProduction sem_EProduction (EProduction _con _params _constraints _rules _children _visits ) = (sem_EProduction_EProduction _con _params _constraints (sem_ERules _rules ) (sem_EChildren _children ) (sem_Visits _visits ) ) -- semantic domain newtype T_EProduction = T_EProduction ((Map VisitIdentifier (Int,Int)) -> (Map NontermIdent Attributes) -> (Map NontermIdent Int) -> (Map NontermIdent Attributes) -> (Map VisitIdentifier VisitKind) -> (Map VisitIdentifier (Identifier -> VisitKind -> Either Error (PP_Doc, PP_Doc))) -> (Set StateIdentifier) -> (Map VisitIdentifier (Set Identifier)) -> (Map VisitIdentifier (Set Identifier)) -> ClassContext -> PP_Doc -> Attributes -> StateIdentifier -> (Map ConstructorIdent (Map Identifier Type)) -> String -> String -> (String -> String -> String -> Bool -> String) -> (Map StateIdentifier StateCtx) -> NontermIdent -> Type -> Options -> ([Identifier]) -> String -> (Map StateIdentifier StateCtx) -> Bool -> Attributes -> PP_Doc -> ( ([VisitStateState]),(Map VisitIdentifier (Identifier -> VisitKind -> Either Error (PP_Doc, PP_Doc))),Int,PP_Doc,(Seq Error),(Map VisitIdentifier (Int,Int)),(IO ()),([PP_Doc]),(Seq PP_Doc),(Seq PP_Doc),PP_Doc,PP_Doc,PP_Doc,(Map VisitIdentifier VisitKind),(Map VisitIdentifier (Set Identifier)),(Map VisitIdentifier (Set Identifier)))) data Inh_EProduction = Inh_EProduction {allFromToStates_Inh_EProduction :: (Map VisitIdentifier (Int,Int)),allInhmap_Inh_EProduction :: (Map NontermIdent Attributes),allInitStates_Inh_EProduction :: (Map NontermIdent Int),allSynmap_Inh_EProduction :: (Map NontermIdent Attributes),allVisitKinds_Inh_EProduction :: (Map VisitIdentifier VisitKind),allchildvisit_Inh_EProduction :: (Map VisitIdentifier (Identifier -> VisitKind -> Either Error (PP_Doc, PP_Doc))),allstates_Inh_EProduction :: (Set StateIdentifier),avisitdefs_Inh_EProduction :: (Map VisitIdentifier (Set Identifier)),avisituses_Inh_EProduction :: (Map VisitIdentifier (Set Identifier)),classCtxs_Inh_EProduction :: ClassContext,importBlocks_Inh_EProduction :: PP_Doc,inhmap_Inh_EProduction :: Attributes,initial_Inh_EProduction :: StateIdentifier,localAttrTypes_Inh_EProduction :: (Map ConstructorIdent (Map Identifier Type)),mainFile_Inh_EProduction :: String,mainName_Inh_EProduction :: String,moduleHeader_Inh_EProduction :: (String -> String -> String -> Bool -> String),nextVisits_Inh_EProduction :: (Map StateIdentifier StateCtx),nt_Inh_EProduction :: NontermIdent,ntType_Inh_EProduction :: Type,options_Inh_EProduction :: Options,params_Inh_EProduction :: ([Identifier]),pragmaBlocks_Inh_EProduction :: String,prevVisits_Inh_EProduction :: (Map StateIdentifier StateCtx),rename_Inh_EProduction :: Bool,synmap_Inh_EProduction :: Attributes,textBlocks_Inh_EProduction :: PP_Doc} data Syn_EProduction = Syn_EProduction {allvisits_Syn_EProduction :: ([VisitStateState]),childvisit_Syn_EProduction :: (Map VisitIdentifier (Identifier -> VisitKind -> Either Error (PP_Doc, PP_Doc))),count_Syn_EProduction :: Int,datatype_Syn_EProduction :: PP_Doc,errors_Syn_EProduction :: (Seq Error),fromToStates_Syn_EProduction :: (Map VisitIdentifier (Int,Int)),genProdIO_Syn_EProduction :: (IO ()),imports_Syn_EProduction :: ([PP_Doc]),semFunBndDefs_Syn_EProduction :: (Seq PP_Doc),semFunBndTps_Syn_EProduction :: (Seq PP_Doc),sem_nt_Syn_EProduction :: PP_Doc,sem_prod_Syn_EProduction :: PP_Doc,t_visits_Syn_EProduction :: PP_Doc,visitKinds_Syn_EProduction :: (Map VisitIdentifier VisitKind),visitdefs_Syn_EProduction :: (Map VisitIdentifier (Set Identifier)),visituses_Syn_EProduction :: (Map VisitIdentifier (Set Identifier))} wrap_EProduction :: T_EProduction -> Inh_EProduction -> Syn_EProduction wrap_EProduction (T_EProduction sem ) (Inh_EProduction _lhsIallFromToStates _lhsIallInhmap _lhsIallInitStates _lhsIallSynmap _lhsIallVisitKinds _lhsIallchildvisit _lhsIallstates _lhsIavisitdefs _lhsIavisituses _lhsIclassCtxs _lhsIimportBlocks _lhsIinhmap _lhsIinitial _lhsIlocalAttrTypes _lhsImainFile _lhsImainName _lhsImoduleHeader _lhsInextVisits _lhsInt _lhsIntType _lhsIoptions _lhsIparams _lhsIpragmaBlocks _lhsIprevVisits _lhsIrename _lhsIsynmap _lhsItextBlocks ) = (let ( _lhsOallvisits,_lhsOchildvisit,_lhsOcount,_lhsOdatatype,_lhsOerrors,_lhsOfromToStates,_lhsOgenProdIO,_lhsOimports,_lhsOsemFunBndDefs,_lhsOsemFunBndTps,_lhsOsem_nt,_lhsOsem_prod,_lhsOt_visits,_lhsOvisitKinds,_lhsOvisitdefs,_lhsOvisituses) = sem _lhsIallFromToStates _lhsIallInhmap _lhsIallInitStates _lhsIallSynmap _lhsIallVisitKinds _lhsIallchildvisit _lhsIallstates _lhsIavisitdefs _lhsIavisituses _lhsIclassCtxs _lhsIimportBlocks _lhsIinhmap _lhsIinitial _lhsIlocalAttrTypes _lhsImainFile _lhsImainName _lhsImoduleHeader _lhsInextVisits _lhsInt _lhsIntType _lhsIoptions _lhsIparams _lhsIpragmaBlocks _lhsIprevVisits _lhsIrename _lhsIsynmap _lhsItextBlocks in (Syn_EProduction _lhsOallvisits _lhsOchildvisit _lhsOcount _lhsOdatatype _lhsOerrors _lhsOfromToStates _lhsOgenProdIO _lhsOimports _lhsOsemFunBndDefs _lhsOsemFunBndTps _lhsOsem_nt _lhsOsem_prod _lhsOt_visits _lhsOvisitKinds _lhsOvisitdefs _lhsOvisituses )) sem_EProduction_EProduction :: ConstructorIdent -> ([Identifier]) -> ([Type]) -> T_ERules -> T_EChildren -> T_Visits -> T_EProduction sem_EProduction_EProduction con_ params_ constraints_ (T_ERules rules_ ) (T_EChildren children_ ) (T_Visits visits_ ) = (T_EProduction (\ _lhsIallFromToStates _lhsIallInhmap _lhsIallInitStates _lhsIallSynmap _lhsIallVisitKinds _lhsIallchildvisit _lhsIallstates _lhsIavisitdefs _lhsIavisituses _lhsIclassCtxs _lhsIimportBlocks _lhsIinhmap _lhsIinitial _lhsIlocalAttrTypes _lhsImainFile _lhsImainName _lhsImoduleHeader _lhsInextVisits _lhsInt _lhsIntType _lhsIoptions _lhsIparams _lhsIpragmaBlocks _lhsIprevVisits _lhsIrename _lhsIsynmap _lhsItextBlocks -> (let _childrenOcon :: ConstructorIdent _rulesOcon :: ConstructorIdent _visitsOcon :: ConstructorIdent _lhsOdatatype :: PP_Doc _lhsOcount :: Int _lhsOsem_nt :: PP_Doc _lhsOsemFunBndDefs :: (Seq PP_Doc) _lhsOsemFunBndTps :: (Seq PP_Doc) _visitsOmrules :: (Map Identifier (VisitKind -> FormatMode -> Either Error PP_Doc)) _visitsOchildintros :: (Map Identifier (VisitKind -> FormatMode -> Either Error (PP_Doc, Set String, Map String (Maybe NonLocalAttr)))) _rulesOusageInfo :: (Map Identifier Int) _rulesOruleKinds :: (Map Identifier (Set VisitKind)) _visitsOallintramap :: (Map StateIdentifier (Map String (Maybe NonLocalAttr))) _visitsOterminaldefs :: (Set String) _visitsOruledefs :: (Map Identifier (Set String)) _visitsOruleuses :: (Map Identifier (Map String (Maybe NonLocalAttr))) _lhsOimports :: ([PP_Doc]) _lhsOgenProdIO :: (IO ()) _lhsOchildvisit :: (Map VisitIdentifier (Identifier -> VisitKind -> Either Error (PP_Doc, PP_Doc))) _lhsOerrors :: (Seq Error) _lhsOfromToStates :: (Map VisitIdentifier (Int,Int)) _lhsOt_visits :: PP_Doc _lhsOvisitKinds :: (Map VisitIdentifier VisitKind) _lhsOvisitdefs :: (Map VisitIdentifier (Set Identifier)) _lhsOvisituses :: (Map VisitIdentifier (Set Identifier)) _lhsOallvisits :: ([VisitStateState]) _lhsOsem_prod :: PP_Doc _rulesOallInhmap :: (Map NontermIdent Attributes) _rulesOallSynmap :: (Map NontermIdent Attributes) _rulesOchildTypes :: (Map Identifier Type) _rulesOimportBlocks :: PP_Doc _rulesOinhmap :: Attributes _rulesOlazyIntras :: (Set String) _rulesOlocalAttrTypes :: (Map Identifier Type) _rulesOmainFile :: String _rulesOmainName :: String _rulesOmoduleHeader :: (String -> String -> String -> Bool -> String) _rulesOnt :: NontermIdent _rulesOoptions :: Options _rulesOpragmaBlocks :: String _rulesOsynmap :: Attributes _rulesOtextBlocks :: PP_Doc _childrenOallInitStates :: (Map NontermIdent Int) _childrenOimportBlocks :: PP_Doc _childrenOmainFile :: String _childrenOmainName :: String _childrenOmoduleHeader :: (String -> String -> String -> Bool -> String) _childrenOnt :: NontermIdent _childrenOoptions :: Options _childrenOpragmaBlocks :: String _childrenOtextBlocks :: PP_Doc _visitsOallFromToStates :: (Map VisitIdentifier (Int,Int)) _visitsOallInhmap :: (Map NontermIdent Attributes) _visitsOallInitStates :: (Map NontermIdent Int) _visitsOallSynmap :: (Map NontermIdent Attributes) _visitsOallVisitKinds :: (Map VisitIdentifier VisitKind) _visitsOallchildvisit :: (Map VisitIdentifier (Identifier -> VisitKind -> Either Error (PP_Doc, PP_Doc))) _visitsOavisitdefs :: (Map VisitIdentifier (Set Identifier)) _visitsOavisituses :: (Map VisitIdentifier (Set Identifier)) _visitsOchildTypes :: (Map Identifier Type) _visitsOinhmap :: Attributes _visitsOnextVisits :: (Map StateIdentifier StateCtx) _visitsOnt :: NontermIdent _visitsOoptions :: Options _visitsOparams :: ([Identifier]) _visitsOprevVisits :: (Map StateIdentifier StateCtx) _visitsOsynmap :: Attributes _rulesIerrors :: (Seq Error) _rulesImrules :: (Map Identifier (VisitKind -> FormatMode -> Either Error PP_Doc)) _rulesIruledefs :: (Map Identifier (Set String)) _rulesIruleuses :: (Map Identifier (Map String (Maybe NonLocalAttr))) _rulesIsem_rules :: PP_Doc _childrenIargnamesw :: ([PP_Doc]) _childrenIargpats :: ( [PP_Doc] ) _childrenIargtps :: ( [PP_Doc] ) _childrenIchildTypes :: (Map Identifier Type) _childrenIchildintros :: (Map Identifier (VisitKind -> FormatMode -> Either Error (PP_Doc, Set String, Map String (Maybe NonLocalAttr)))) _childrenIdatatype :: ([PP_Doc]) _childrenIterminaldefs :: (Set String) _visitsIallvisits :: ([VisitStateState]) _visitsIchildvisit :: (Map VisitIdentifier (Identifier -> VisitKind -> Either Error (PP_Doc, PP_Doc))) _visitsIerrors :: (Seq Error) _visitsIfromToStates :: (Map VisitIdentifier (Int,Int)) _visitsIintramap :: (Map StateIdentifier (Map String (Maybe NonLocalAttr))) _visitsIlazyIntras :: (Set String) _visitsIruleKinds :: (Map Identifier (Set VisitKind)) _visitsIruleUsage :: (Map Identifier Int) _visitsIsem_visit :: ( [(StateIdentifier,Bool -> PP_Doc)] ) _visitsIt_visits :: PP_Doc _visitsIvisitKinds :: (Map VisitIdentifier VisitKind) _visitsIvisitdefs :: (Map VisitIdentifier (Set Identifier)) _visitsIvisituses :: (Map VisitIdentifier (Set Identifier)) -- "src-ag/ExecutionPlan2Hs.ag"(line 69, column 17) _childrenOcon = ({-# LINE 69 "src-ag/ExecutionPlan2Hs.ag" #-} con_ {-# LINE 2843 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 70, column 17) _rulesOcon = ({-# LINE 70 "src-ag/ExecutionPlan2Hs.ag" #-} con_ {-# LINE 2849 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 71, column 17) _visitsOcon = ({-# LINE 71 "src-ag/ExecutionPlan2Hs.ag" #-} con_ {-# LINE 2855 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 184, column 17) _lhsOdatatype = ({-# LINE 184 "src-ag/ExecutionPlan2Hs.ag" #-} _quantPP1 >#< _classPP1 >#< conname _lhsIrename _lhsInt con_ >#< ppConFields (dataRecords _lhsIoptions) _childrenIdatatype {-# LINE 2863 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 187, column 17) _classPP1 = ({-# LINE 187 "src-ag/ExecutionPlan2Hs.ag" #-} ppClasses (classConstrsToDocs constraints_) {-# LINE 2869 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 188, column 17) _quantPP1 = ({-# LINE 188 "src-ag/ExecutionPlan2Hs.ag" #-} ppQuants params_ {-# LINE 2875 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 289, column 32) _lhsOcount = ({-# LINE 289 "src-ag/ExecutionPlan2Hs.ag" #-} 1 {-# LINE 2881 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 294, column 17) _lhsOsem_nt = ({-# LINE 294 "src-ag/ExecutionPlan2Hs.ag" #-} "sem_" >|< _lhsInt >#< "(" >#< conname _lhsIrename _lhsInt con_ >#< ppSpaced _childrenIargpats >#< ")" >#< "=" >#< "sem_" >|< _lhsInt >|< "_" >|< con_ >#< ppSpaced _childrenIargnamesw {-# LINE 2888 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 523, column 3) _lhsOsemFunBndDefs = ({-# LINE 523 "src-ag/ExecutionPlan2Hs.ag" #-} Seq.singleton _semFunBndDef {-# LINE 2894 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 524, column 3) _lhsOsemFunBndTps = ({-# LINE 524 "src-ag/ExecutionPlan2Hs.ag" #-} Seq.singleton _semFunBndTp {-# LINE 2900 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 525, column 3) _semFunBndDef = ({-# LINE 525 "src-ag/ExecutionPlan2Hs.ag" #-} _semFunBndNm >#< "=" >#< _semname {-# LINE 2906 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 526, column 3) _semFunBndTp = ({-# LINE 526 "src-ag/ExecutionPlan2Hs.ag" #-} _semFunBndNm >#< "::" >#< _sem_tp {-# LINE 2912 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 527, column 3) _semFunBndNm = ({-# LINE 527 "src-ag/ExecutionPlan2Hs.ag" #-} lateSemConLabel _lhsInt con_ {-# LINE 2918 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 585, column 17) _t_type = ({-# LINE 585 "src-ag/ExecutionPlan2Hs.ag" #-} "T_" >|< _lhsInt {-# LINE 2924 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 586, column 17) _t_params = ({-# LINE 586 "src-ag/ExecutionPlan2Hs.ag" #-} ppSpaced _lhsIparams {-# LINE 2930 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 587, column 17) _args = ({-# LINE 587 "src-ag/ExecutionPlan2Hs.ag" #-} _childrenIargpats {-# LINE 2936 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 588, column 17) _semname = ({-# LINE 588 "src-ag/ExecutionPlan2Hs.ag" #-} "sem_" ++ show _lhsInt ++ "_" ++ show con_ {-# LINE 2942 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 589, column 17) _sem_tp = ({-# LINE 589 "src-ag/ExecutionPlan2Hs.ag" #-} _quantPP2 >#< _classPP2 >#< ppSpaced _childrenIargtps >#< _t_type >#< _t_params {-# LINE 2948 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 590, column 17) _classPP2 = ({-# LINE 590 "src-ag/ExecutionPlan2Hs.ag" #-} ppClasses (classCtxsToDocs _lhsIclassCtxs ++ classConstrsToDocs constraints_) {-# LINE 2954 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 591, column 17) _quantPP2 = ({-# LINE 591 "src-ag/ExecutionPlan2Hs.ag" #-} ppQuants (_lhsIparams ++ params_) {-# LINE 2960 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 592, column 17) _sem_prod = ({-# LINE 592 "src-ag/ExecutionPlan2Hs.ag" #-} _semInlinePragma >-< _semname >#< "::" >#< _sem_tp >-< _mkSemBody (_semname >#< ppSpaced _args >#< "=" >#< _scc >#< _t_type ) _mbInitializer _outerlet ("return" >#< "st" >|< _lhsIinitial) {-# LINE 2969 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 596, column 17) _mkSemBody = ({-# LINE 596 "src-ag/ExecutionPlan2Hs.ag" #-} \prefix mbInit outerlet ret -> case mbInit of Nothing -> prefix >#< pp_parens ret >#< "where" >-< indent 3 outerlet Just m -> prefix >#< "(" >#< "do" >-< indent 1 ( m >-< "let" >-< indent 2 outerlet >-< ret ) >-< indent 1 ")" {-# LINE 2985 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 608, column 17) _mbInitializer = ({-# LINE 608 "src-ag/ExecutionPlan2Hs.ag" #-} if parallelInvoke _lhsIoptions then (Nothing :: Maybe PP_Doc) else Nothing {-# LINE 2993 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 614, column 17) _scc = ({-# LINE 614 "src-ag/ExecutionPlan2Hs.ag" #-} if genCostCentres _lhsIoptions then ppCostCentre _semname else empty {-# LINE 3001 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 617, column 17) _semInlinePragma = ({-# LINE 617 "src-ag/ExecutionPlan2Hs.ag" #-} if noInlinePragmas _lhsIoptions then empty else ppNoInline _semname {-# LINE 3009 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 620, column 17) _outerlet = ({-# LINE 620 "src-ag/ExecutionPlan2Hs.ag" #-} vlist _statefns >-< _rulesIsem_rules {-# LINE 3015 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 621, column 17) _statefns = ({-# LINE 621 "src-ag/ExecutionPlan2Hs.ag" #-} map _genstfn $ Set.toList _lhsIallstates {-# LINE 3021 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 622, column 17) _genstfn = ({-# LINE 622 "src-ag/ExecutionPlan2Hs.ag" #-} \st -> let nextVisitInfo = Map.findWithDefault ManyVis st _lhsInextVisits prevVisitInfo = Map.findWithDefault ManyVis st _lhsIprevVisits stNm = "st" >|< st lhs = pragma >-< bang stNm >#< "=" >#< ( if st == _lhsIinitial then empty else "\\" >#< _stargs st >#< "->" ) pragma = if noInlinePragmas _lhsIoptions then empty else if helpInlining _lhsIoptions then case prevVisitInfo of ManyVis -> ppNoInline stNm OneVis _ -> if aggressiveInlinePragmas _lhsIoptions then ppInline stNm else ppInlinable stNm NoneVis -> if st /= _lhsIinitial then error ("State " ++ show st ++ " is not reachable from the initial state.") else if aggressiveInlinePragmas _lhsIoptions then ppInline stNm else ppInlinable stNm else ppNoInline stNm cCon = "C_" >|< _lhsInt >|< "_s" >|< st bang | st == _lhsIinitial = _addbang | otherwise = id in case nextVisitInfo of NoneVis -> if st == _lhsIinitial then lhs >#< cCon else empty OneVis vId -> mklet lhs (_stvs st False) (cCon >#< "v" >|< vId) ManyVis -> mklet lhs (_stks st >-< _stvs st True) (cCon >#< "k" >|< st) {-# LINE 3059 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 664, column 17) _stargs = ({-# LINE 664 "src-ag/ExecutionPlan2Hs.ag" #-} \st -> let attrs = maybe Map.empty id $ Map.lookup st _visitsIintramap in ppSpaced [ let match | str `Set.member` _lazyIntras = pp str | otherwise = _addbang (pp str) in case mbAttr of Just (AttrSyn child nm) | child == _LOC && not (noPerStateTypeSigs _lhsIoptions) -> case Map.lookup nm _localAttrTypes of Just tp -> pp_parens (pp_parens match >#< "::" >#< ppTp tp) Nothing -> match Just attr | not (noPerStateTypeSigs _lhsIoptions) -> case lookupAttrType attr _lhsIallInhmap _lhsIallSynmap _childTypes of Just tpDoc -> pp_parens (pp_parens match >#< "::" >#< tpDoc) Nothing -> match _ -> match | (str,mbAttr) <- Map.assocs attrs ] >#< dummyPat _lhsIoptions (Map.null attrs) {-# LINE 3079 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 680, column 17) _stks = ({-# LINE 680 "src-ag/ExecutionPlan2Hs.ag" #-} \st -> if null (_stvisits st) then empty else ( if not (noInlinePragmas _lhsIoptions) && helpInlining _lhsIoptions then ppNoInline ("k" >|< st) else empty ) >-< "k" >|< st >#< "::" >#< "K_" >|< _lhsInt >|< "_s" >|< st >#< "t" >#< "->" >#< "t" >-< vlist (map (\(v,f,t) -> "k" >|< st >#< "K_" >|< _lhsInt >|< "_v" >|< v >#< "=" >#< "v" >|< v) $ _stvisits st) {-# LINE 3093 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 689, column 17) _stvisits = ({-# LINE 689 "src-ag/ExecutionPlan2Hs.ag" #-} \st -> filter (\(v,f,t) -> f == st) _visitsIallvisits {-# LINE 3099 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 690, column 17) _stvs = ({-# LINE 690 "src-ag/ExecutionPlan2Hs.ag" #-} \st inlinePragma -> vlist [ppf inlinePragma | (f,ppf) <- _visitsIsem_visit, f == st] {-# LINE 3105 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 691, column 17) _visitsOmrules = ({-# LINE 691 "src-ag/ExecutionPlan2Hs.ag" #-} _rulesImrules {-# LINE 3111 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 895, column 17) _visitsOchildintros = ({-# LINE 895 "src-ag/ExecutionPlan2Hs.ag" #-} _childrenIchildintros {-# LINE 3117 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 1226, column 32) _rulesOusageInfo = ({-# LINE 1226 "src-ag/ExecutionPlan2Hs.ag" #-} _visitsIruleUsage {-# LINE 3123 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 1241, column 3) _rulesOruleKinds = ({-# LINE 1241 "src-ag/ExecutionPlan2Hs.ag" #-} _visitsIruleKinds {-# LINE 3129 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 1270, column 3) _visitsOallintramap = ({-# LINE 1270 "src-ag/ExecutionPlan2Hs.ag" #-} _visitsIintramap {-# LINE 3135 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 1271, column 3) _visitsOterminaldefs = ({-# LINE 1271 "src-ag/ExecutionPlan2Hs.ag" #-} _childrenIterminaldefs {-# LINE 3141 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 1295, column 17) _visitsOruledefs = ({-# LINE 1295 "src-ag/ExecutionPlan2Hs.ag" #-} _rulesIruledefs {-# LINE 3147 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 1296, column 17) _visitsOruleuses = ({-# LINE 1296 "src-ag/ExecutionPlan2Hs.ag" #-} _rulesIruleuses {-# LINE 3153 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 1350, column 3) _lazyIntras = ({-# LINE 1350 "src-ag/ExecutionPlan2Hs.ag" #-} _visitsIlazyIntras {-# LINE 3159 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 1447, column 17) _lhsOimports = ({-# LINE 1447 "src-ag/ExecutionPlan2Hs.ag" #-} [pp $ "import " ++ _moduleName ] {-# LINE 3165 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 1448, column 17) _moduleName = ({-# LINE 1448 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsImainName ++ _suffix {-# LINE 3171 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 1449, column 17) _suffix = ({-# LINE 1449 "src-ag/ExecutionPlan2Hs.ag" #-} "_" ++ show _lhsInt ++ "_" ++ show con_ {-# LINE 3177 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 1450, column 17) _outputfile = ({-# LINE 1450 "src-ag/ExecutionPlan2Hs.ag" #-} replaceBaseName _lhsImainFile (takeBaseName _lhsImainFile ++ _suffix ) {-# LINE 3183 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 1451, column 17) _ppMonadImports = ({-# LINE 1451 "src-ag/ExecutionPlan2Hs.ag" #-} if parallelInvoke _lhsIoptions then pp "import qualified System.IO.Unsafe(unsafePerformIO)" >-< pp "import System.IO(IO)" >-< pp "import Control.Concurrent(newEmptyMVar,forkIO,putMVar,takeMVar)" else pp "import Control.Monad.Identity" {-# LINE 3193 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 1456, column 17) _lhsOgenProdIO = ({-# LINE 1456 "src-ag/ExecutionPlan2Hs.ag" #-} writeModule _outputfile [ warrenFlagsPP _lhsIoptions , pp $ _lhsIpragmaBlocks , pp $ _lhsImoduleHeader _lhsImainName _suffix _semname True , _lhsIimportBlocks , _ppMonadImports , ( if tupleAsDummyToken _lhsIoptions then empty else pp "import GHC.Prim" ) , pp $ "import " ++ _lhsImainName ++ "_common" , _sem_prod ] {-# LINE 3211 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 1497, column 37) _addbang = ({-# LINE 1497 "src-ag/ExecutionPlan2Hs.ag" #-} \x -> if bangpats _lhsIoptions then "!" >|< x else x {-# LINE 3217 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 1547, column 3) _childTypes = ({-# LINE 1547 "src-ag/ExecutionPlan2Hs.ag" #-} Map.singleton _LHS _lhsIntType `Map.union` _childrenIchildTypes {-# LINE 3223 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 1564, column 3) _localAttrTypes = ({-# LINE 1564 "src-ag/ExecutionPlan2Hs.ag" #-} Map.findWithDefault Map.empty con_ _lhsIlocalAttrTypes {-# LINE 3229 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- use rule "src-ag/ExecutionPlan2Hs.ag"(line 1167, column 37) _lhsOchildvisit = ({-# LINE 1167 "src-ag/ExecutionPlan2Hs.ag" #-} _visitsIchildvisit {-# LINE 3235 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- use rule "src-ag/ExecutionPlan2Hs.ag"(line 1609, column 132) _lhsOerrors = ({-# LINE 1609 "src-ag/ExecutionPlan2Hs.ag" #-} _rulesIerrors Seq.>< _visitsIerrors {-# LINE 3241 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- use rule "src-ag/ExecutionPlan2Hs.ag"(line 1524, column 22) _lhsOfromToStates = ({-# LINE 1524 "src-ag/ExecutionPlan2Hs.ag" #-} _visitsIfromToStates {-# LINE 3247 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- use rule "src-ag/ExecutionPlan2Hs.ag"(line 393, column 59) _lhsOt_visits = ({-# LINE 393 "src-ag/ExecutionPlan2Hs.ag" #-} _visitsIt_visits {-# LINE 3253 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- use rule "src-ag/ExecutionPlan2Hs.ag"(line 1571, column 68) _lhsOvisitKinds = ({-# LINE 1571 "src-ag/ExecutionPlan2Hs.ag" #-} _visitsIvisitKinds {-# LINE 3259 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- use rule "src-ag/ExecutionPlan2Hs.ag"(line 1302, column 36) _lhsOvisitdefs = ({-# LINE 1302 "src-ag/ExecutionPlan2Hs.ag" #-} _visitsIvisitdefs {-# LINE 3265 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- use rule "src-ag/ExecutionPlan2Hs.ag"(line 1303, column 36) _lhsOvisituses = ({-# LINE 1303 "src-ag/ExecutionPlan2Hs.ag" #-} _visitsIvisituses {-# LINE 3271 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (up) _lhsOallvisits = ({-# LINE 337 "src-ag/ExecutionPlan2Hs.ag" #-} _visitsIallvisits {-# LINE 3277 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (from local) _lhsOsem_prod = ({-# LINE 552 "src-ag/ExecutionPlan2Hs.ag" #-} _sem_prod {-# LINE 3283 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _rulesOallInhmap = ({-# LINE 320 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIallInhmap {-# LINE 3289 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _rulesOallSynmap = ({-# LINE 321 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIallSynmap {-# LINE 3295 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (from local) _rulesOchildTypes = ({-# LINE 1544 "src-ag/ExecutionPlan2Hs.ag" #-} _childTypes {-# LINE 3301 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _rulesOimportBlocks = ({-# LINE 34 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIimportBlocks {-# LINE 3307 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _rulesOinhmap = ({-# LINE 318 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIinhmap {-# LINE 3313 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (from local) _rulesOlazyIntras = ({-# LINE 1336 "src-ag/ExecutionPlan2Hs.ag" #-} _lazyIntras {-# LINE 3319 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (from local) _rulesOlocalAttrTypes = ({-# LINE 1558 "src-ag/ExecutionPlan2Hs.ag" #-} _localAttrTypes {-# LINE 3325 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _rulesOmainFile = ({-# LINE 38 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsImainFile {-# LINE 3331 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _rulesOmainName = ({-# LINE 39 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsImainName {-# LINE 3337 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _rulesOmoduleHeader = ({-# LINE 37 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsImoduleHeader {-# LINE 3343 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _rulesOnt = ({-# LINE 61 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsInt {-# LINE 3349 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _rulesOoptions = ({-# LINE 51 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIoptions {-# LINE 3355 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _rulesOpragmaBlocks = ({-# LINE 35 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIpragmaBlocks {-# LINE 3361 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _rulesOsynmap = ({-# LINE 319 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIsynmap {-# LINE 3367 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _rulesOtextBlocks = ({-# LINE 36 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsItextBlocks {-# LINE 3373 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _childrenOallInitStates = ({-# LINE 1585 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIallInitStates {-# LINE 3379 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _childrenOimportBlocks = ({-# LINE 34 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIimportBlocks {-# LINE 3385 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _childrenOmainFile = ({-# LINE 38 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsImainFile {-# LINE 3391 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _childrenOmainName = ({-# LINE 39 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsImainName {-# LINE 3397 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _childrenOmoduleHeader = ({-# LINE 37 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsImoduleHeader {-# LINE 3403 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _childrenOnt = ({-# LINE 61 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsInt {-# LINE 3409 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _childrenOoptions = ({-# LINE 51 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIoptions {-# LINE 3415 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _childrenOpragmaBlocks = ({-# LINE 35 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIpragmaBlocks {-# LINE 3421 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _childrenOtextBlocks = ({-# LINE 36 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsItextBlocks {-# LINE 3427 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _visitsOallFromToStates = ({-# LINE 1527 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIallFromToStates {-# LINE 3433 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _visitsOallInhmap = ({-# LINE 320 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIallInhmap {-# LINE 3439 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _visitsOallInitStates = ({-# LINE 1585 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIallInitStates {-# LINE 3445 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _visitsOallSynmap = ({-# LINE 321 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIallSynmap {-# LINE 3451 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _visitsOallVisitKinds = ({-# LINE 1571 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIallVisitKinds {-# LINE 3457 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _visitsOallchildvisit = ({-# LINE 1166 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIallchildvisit {-# LINE 3463 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _visitsOavisitdefs = ({-# LINE 1312 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIavisitdefs {-# LINE 3469 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _visitsOavisituses = ({-# LINE 1313 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIavisituses {-# LINE 3475 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (from local) _visitsOchildTypes = ({-# LINE 1544 "src-ag/ExecutionPlan2Hs.ag" #-} _childTypes {-# LINE 3481 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _visitsOinhmap = ({-# LINE 318 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIinhmap {-# LINE 3487 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _visitsOnextVisits = ({-# LINE 1513 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsInextVisits {-# LINE 3493 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _visitsOnt = ({-# LINE 61 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsInt {-# LINE 3499 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _visitsOoptions = ({-# LINE 51 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIoptions {-# LINE 3505 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _visitsOparams = ({-# LINE 73 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIparams {-# LINE 3511 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _visitsOprevVisits = ({-# LINE 1513 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIprevVisits {-# LINE 3517 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _visitsOsynmap = ({-# LINE 319 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIsynmap {-# LINE 3523 "src-ag/ExecutionPlan2Hs.hs" #-} ) ( _rulesIerrors,_rulesImrules,_rulesIruledefs,_rulesIruleuses,_rulesIsem_rules) = rules_ _rulesOallInhmap _rulesOallSynmap _rulesOchildTypes _rulesOcon _rulesOimportBlocks _rulesOinhmap _rulesOlazyIntras _rulesOlocalAttrTypes _rulesOmainFile _rulesOmainName _rulesOmoduleHeader _rulesOnt _rulesOoptions _rulesOpragmaBlocks _rulesOruleKinds _rulesOsynmap _rulesOtextBlocks _rulesOusageInfo ( _childrenIargnamesw,_childrenIargpats,_childrenIargtps,_childrenIchildTypes,_childrenIchildintros,_childrenIdatatype,_childrenIterminaldefs) = children_ _childrenOallInitStates _childrenOcon _childrenOimportBlocks _childrenOmainFile _childrenOmainName _childrenOmoduleHeader _childrenOnt _childrenOoptions _childrenOpragmaBlocks _childrenOtextBlocks ( _visitsIallvisits,_visitsIchildvisit,_visitsIerrors,_visitsIfromToStates,_visitsIintramap,_visitsIlazyIntras,_visitsIruleKinds,_visitsIruleUsage,_visitsIsem_visit,_visitsIt_visits,_visitsIvisitKinds,_visitsIvisitdefs,_visitsIvisituses) = visits_ _visitsOallFromToStates _visitsOallInhmap _visitsOallInitStates _visitsOallSynmap _visitsOallVisitKinds _visitsOallchildvisit _visitsOallintramap _visitsOavisitdefs _visitsOavisituses _visitsOchildTypes _visitsOchildintros _visitsOcon _visitsOinhmap _visitsOmrules _visitsOnextVisits _visitsOnt _visitsOoptions _visitsOparams _visitsOprevVisits _visitsOruledefs _visitsOruleuses _visitsOsynmap _visitsOterminaldefs in ( _lhsOallvisits,_lhsOchildvisit,_lhsOcount,_lhsOdatatype,_lhsOerrors,_lhsOfromToStates,_lhsOgenProdIO,_lhsOimports,_lhsOsemFunBndDefs,_lhsOsemFunBndTps,_lhsOsem_nt,_lhsOsem_prod,_lhsOt_visits,_lhsOvisitKinds,_lhsOvisitdefs,_lhsOvisituses))) ) -- EProductions ------------------------------------------------ {- visit 0: inherited attributes: allFromToStates : Map VisitIdentifier (Int,Int) allInhmap : Map NontermIdent Attributes allInitStates : Map NontermIdent Int allSynmap : Map NontermIdent Attributes allVisitKinds : Map VisitIdentifier VisitKind allchildvisit : Map VisitIdentifier (Identifier -> VisitKind -> Either Error (PP_Doc, PP_Doc)) allstates : Set StateIdentifier avisitdefs : Map VisitIdentifier (Set Identifier) avisituses : Map VisitIdentifier (Set Identifier) classCtxs : ClassContext importBlocks : PP_Doc inhmap : Attributes initial : StateIdentifier localAttrTypes : Map ConstructorIdent (Map Identifier Type) mainFile : String mainName : String moduleHeader : String -> String -> String -> Bool -> String nextVisits : Map StateIdentifier StateCtx nt : NontermIdent ntType : Type options : Options params : [Identifier] pragmaBlocks : String prevVisits : Map StateIdentifier StateCtx rename : Bool synmap : Attributes textBlocks : PP_Doc synthesized attributes: allvisits : [VisitStateState] childvisit : Map VisitIdentifier (Identifier -> VisitKind -> Either Error (PP_Doc, PP_Doc)) count : Int datatype : [PP_Doc] errors : Seq Error fromToStates : Map VisitIdentifier (Int,Int) genProdIO : IO () imports : [PP_Doc] semFunBndDefs : Seq PP_Doc semFunBndTps : Seq PP_Doc sem_nt : PP_Doc sem_prod : PP_Doc t_visits : PP_Doc visitKinds : Map VisitIdentifier VisitKind visitdefs : Map VisitIdentifier (Set Identifier) visituses : Map VisitIdentifier (Set Identifier) alternatives: alternative Cons: child hd : EProduction child tl : EProductions alternative Nil: -} -- cata sem_EProductions :: EProductions -> T_EProductions sem_EProductions list = (Prelude.foldr sem_EProductions_Cons sem_EProductions_Nil (Prelude.map sem_EProduction list) ) -- semantic domain newtype T_EProductions = T_EProductions ((Map VisitIdentifier (Int,Int)) -> (Map NontermIdent Attributes) -> (Map NontermIdent Int) -> (Map NontermIdent Attributes) -> (Map VisitIdentifier VisitKind) -> (Map VisitIdentifier (Identifier -> VisitKind -> Either Error (PP_Doc, PP_Doc))) -> (Set StateIdentifier) -> (Map VisitIdentifier (Set Identifier)) -> (Map VisitIdentifier (Set Identifier)) -> ClassContext -> PP_Doc -> Attributes -> StateIdentifier -> (Map ConstructorIdent (Map Identifier Type)) -> String -> String -> (String -> String -> String -> Bool -> String) -> (Map StateIdentifier StateCtx) -> NontermIdent -> Type -> Options -> ([Identifier]) -> String -> (Map StateIdentifier StateCtx) -> Bool -> Attributes -> PP_Doc -> ( ([VisitStateState]),(Map VisitIdentifier (Identifier -> VisitKind -> Either Error (PP_Doc, PP_Doc))),Int,([PP_Doc]),(Seq Error),(Map VisitIdentifier (Int,Int)),(IO ()),([PP_Doc]),(Seq PP_Doc),(Seq PP_Doc),PP_Doc,PP_Doc,PP_Doc,(Map VisitIdentifier VisitKind),(Map VisitIdentifier (Set Identifier)),(Map VisitIdentifier (Set Identifier)))) data Inh_EProductions = Inh_EProductions {allFromToStates_Inh_EProductions :: (Map VisitIdentifier (Int,Int)),allInhmap_Inh_EProductions :: (Map NontermIdent Attributes),allInitStates_Inh_EProductions :: (Map NontermIdent Int),allSynmap_Inh_EProductions :: (Map NontermIdent Attributes),allVisitKinds_Inh_EProductions :: (Map VisitIdentifier VisitKind),allchildvisit_Inh_EProductions :: (Map VisitIdentifier (Identifier -> VisitKind -> Either Error (PP_Doc, PP_Doc))),allstates_Inh_EProductions :: (Set StateIdentifier),avisitdefs_Inh_EProductions :: (Map VisitIdentifier (Set Identifier)),avisituses_Inh_EProductions :: (Map VisitIdentifier (Set Identifier)),classCtxs_Inh_EProductions :: ClassContext,importBlocks_Inh_EProductions :: PP_Doc,inhmap_Inh_EProductions :: Attributes,initial_Inh_EProductions :: StateIdentifier,localAttrTypes_Inh_EProductions :: (Map ConstructorIdent (Map Identifier Type)),mainFile_Inh_EProductions :: String,mainName_Inh_EProductions :: String,moduleHeader_Inh_EProductions :: (String -> String -> String -> Bool -> String),nextVisits_Inh_EProductions :: (Map StateIdentifier StateCtx),nt_Inh_EProductions :: NontermIdent,ntType_Inh_EProductions :: Type,options_Inh_EProductions :: Options,params_Inh_EProductions :: ([Identifier]),pragmaBlocks_Inh_EProductions :: String,prevVisits_Inh_EProductions :: (Map StateIdentifier StateCtx),rename_Inh_EProductions :: Bool,synmap_Inh_EProductions :: Attributes,textBlocks_Inh_EProductions :: PP_Doc} data Syn_EProductions = Syn_EProductions {allvisits_Syn_EProductions :: ([VisitStateState]),childvisit_Syn_EProductions :: (Map VisitIdentifier (Identifier -> VisitKind -> Either Error (PP_Doc, PP_Doc))),count_Syn_EProductions :: Int,datatype_Syn_EProductions :: ([PP_Doc]),errors_Syn_EProductions :: (Seq Error),fromToStates_Syn_EProductions :: (Map VisitIdentifier (Int,Int)),genProdIO_Syn_EProductions :: (IO ()),imports_Syn_EProductions :: ([PP_Doc]),semFunBndDefs_Syn_EProductions :: (Seq PP_Doc),semFunBndTps_Syn_EProductions :: (Seq PP_Doc),sem_nt_Syn_EProductions :: PP_Doc,sem_prod_Syn_EProductions :: PP_Doc,t_visits_Syn_EProductions :: PP_Doc,visitKinds_Syn_EProductions :: (Map VisitIdentifier VisitKind),visitdefs_Syn_EProductions :: (Map VisitIdentifier (Set Identifier)),visituses_Syn_EProductions :: (Map VisitIdentifier (Set Identifier))} wrap_EProductions :: T_EProductions -> Inh_EProductions -> Syn_EProductions wrap_EProductions (T_EProductions sem ) (Inh_EProductions _lhsIallFromToStates _lhsIallInhmap _lhsIallInitStates _lhsIallSynmap _lhsIallVisitKinds _lhsIallchildvisit _lhsIallstates _lhsIavisitdefs _lhsIavisituses _lhsIclassCtxs _lhsIimportBlocks _lhsIinhmap _lhsIinitial _lhsIlocalAttrTypes _lhsImainFile _lhsImainName _lhsImoduleHeader _lhsInextVisits _lhsInt _lhsIntType _lhsIoptions _lhsIparams _lhsIpragmaBlocks _lhsIprevVisits _lhsIrename _lhsIsynmap _lhsItextBlocks ) = (let ( _lhsOallvisits,_lhsOchildvisit,_lhsOcount,_lhsOdatatype,_lhsOerrors,_lhsOfromToStates,_lhsOgenProdIO,_lhsOimports,_lhsOsemFunBndDefs,_lhsOsemFunBndTps,_lhsOsem_nt,_lhsOsem_prod,_lhsOt_visits,_lhsOvisitKinds,_lhsOvisitdefs,_lhsOvisituses) = sem _lhsIallFromToStates _lhsIallInhmap _lhsIallInitStates _lhsIallSynmap _lhsIallVisitKinds _lhsIallchildvisit _lhsIallstates _lhsIavisitdefs _lhsIavisituses _lhsIclassCtxs _lhsIimportBlocks _lhsIinhmap _lhsIinitial _lhsIlocalAttrTypes _lhsImainFile _lhsImainName _lhsImoduleHeader _lhsInextVisits _lhsInt _lhsIntType _lhsIoptions _lhsIparams _lhsIpragmaBlocks _lhsIprevVisits _lhsIrename _lhsIsynmap _lhsItextBlocks in (Syn_EProductions _lhsOallvisits _lhsOchildvisit _lhsOcount _lhsOdatatype _lhsOerrors _lhsOfromToStates _lhsOgenProdIO _lhsOimports _lhsOsemFunBndDefs _lhsOsemFunBndTps _lhsOsem_nt _lhsOsem_prod _lhsOt_visits _lhsOvisitKinds _lhsOvisitdefs _lhsOvisituses )) sem_EProductions_Cons :: T_EProduction -> T_EProductions -> T_EProductions sem_EProductions_Cons (T_EProduction hd_ ) (T_EProductions tl_ ) = (T_EProductions (\ _lhsIallFromToStates _lhsIallInhmap _lhsIallInitStates _lhsIallSynmap _lhsIallVisitKinds _lhsIallchildvisit _lhsIallstates _lhsIavisitdefs _lhsIavisituses _lhsIclassCtxs _lhsIimportBlocks _lhsIinhmap _lhsIinitial _lhsIlocalAttrTypes _lhsImainFile _lhsImainName _lhsImoduleHeader _lhsInextVisits _lhsInt _lhsIntType _lhsIoptions _lhsIparams _lhsIpragmaBlocks _lhsIprevVisits _lhsIrename _lhsIsynmap _lhsItextBlocks -> (let _lhsOallvisits :: ([VisitStateState]) _lhsOt_visits :: PP_Doc _lhsOchildvisit :: (Map VisitIdentifier (Identifier -> VisitKind -> Either Error (PP_Doc, PP_Doc))) _lhsOcount :: Int _lhsOdatatype :: ([PP_Doc]) _lhsOerrors :: (Seq Error) _lhsOfromToStates :: (Map VisitIdentifier (Int,Int)) _lhsOgenProdIO :: (IO ()) _lhsOimports :: ([PP_Doc]) _lhsOsemFunBndDefs :: (Seq PP_Doc) _lhsOsemFunBndTps :: (Seq PP_Doc) _lhsOsem_nt :: PP_Doc _lhsOsem_prod :: PP_Doc _lhsOvisitKinds :: (Map VisitIdentifier VisitKind) _lhsOvisitdefs :: (Map VisitIdentifier (Set Identifier)) _lhsOvisituses :: (Map VisitIdentifier (Set Identifier)) _hdOallFromToStates :: (Map VisitIdentifier (Int,Int)) _hdOallInhmap :: (Map NontermIdent Attributes) _hdOallInitStates :: (Map NontermIdent Int) _hdOallSynmap :: (Map NontermIdent Attributes) _hdOallVisitKinds :: (Map VisitIdentifier VisitKind) _hdOallchildvisit :: (Map VisitIdentifier (Identifier -> VisitKind -> Either Error (PP_Doc, PP_Doc))) _hdOallstates :: (Set StateIdentifier) _hdOavisitdefs :: (Map VisitIdentifier (Set Identifier)) _hdOavisituses :: (Map VisitIdentifier (Set Identifier)) _hdOclassCtxs :: ClassContext _hdOimportBlocks :: PP_Doc _hdOinhmap :: Attributes _hdOinitial :: StateIdentifier _hdOlocalAttrTypes :: (Map ConstructorIdent (Map Identifier Type)) _hdOmainFile :: String _hdOmainName :: String _hdOmoduleHeader :: (String -> String -> String -> Bool -> String) _hdOnextVisits :: (Map StateIdentifier StateCtx) _hdOnt :: NontermIdent _hdOntType :: Type _hdOoptions :: Options _hdOparams :: ([Identifier]) _hdOpragmaBlocks :: String _hdOprevVisits :: (Map StateIdentifier StateCtx) _hdOrename :: Bool _hdOsynmap :: Attributes _hdOtextBlocks :: PP_Doc _tlOallFromToStates :: (Map VisitIdentifier (Int,Int)) _tlOallInhmap :: (Map NontermIdent Attributes) _tlOallInitStates :: (Map NontermIdent Int) _tlOallSynmap :: (Map NontermIdent Attributes) _tlOallVisitKinds :: (Map VisitIdentifier VisitKind) _tlOallchildvisit :: (Map VisitIdentifier (Identifier -> VisitKind -> Either Error (PP_Doc, PP_Doc))) _tlOallstates :: (Set StateIdentifier) _tlOavisitdefs :: (Map VisitIdentifier (Set Identifier)) _tlOavisituses :: (Map VisitIdentifier (Set Identifier)) _tlOclassCtxs :: ClassContext _tlOimportBlocks :: PP_Doc _tlOinhmap :: Attributes _tlOinitial :: StateIdentifier _tlOlocalAttrTypes :: (Map ConstructorIdent (Map Identifier Type)) _tlOmainFile :: String _tlOmainName :: String _tlOmoduleHeader :: (String -> String -> String -> Bool -> String) _tlOnextVisits :: (Map StateIdentifier StateCtx) _tlOnt :: NontermIdent _tlOntType :: Type _tlOoptions :: Options _tlOparams :: ([Identifier]) _tlOpragmaBlocks :: String _tlOprevVisits :: (Map StateIdentifier StateCtx) _tlOrename :: Bool _tlOsynmap :: Attributes _tlOtextBlocks :: PP_Doc _hdIallvisits :: ([VisitStateState]) _hdIchildvisit :: (Map VisitIdentifier (Identifier -> VisitKind -> Either Error (PP_Doc, PP_Doc))) _hdIcount :: Int _hdIdatatype :: PP_Doc _hdIerrors :: (Seq Error) _hdIfromToStates :: (Map VisitIdentifier (Int,Int)) _hdIgenProdIO :: (IO ()) _hdIimports :: ([PP_Doc]) _hdIsemFunBndDefs :: (Seq PP_Doc) _hdIsemFunBndTps :: (Seq PP_Doc) _hdIsem_nt :: PP_Doc _hdIsem_prod :: PP_Doc _hdIt_visits :: PP_Doc _hdIvisitKinds :: (Map VisitIdentifier VisitKind) _hdIvisitdefs :: (Map VisitIdentifier (Set Identifier)) _hdIvisituses :: (Map VisitIdentifier (Set Identifier)) _tlIallvisits :: ([VisitStateState]) _tlIchildvisit :: (Map VisitIdentifier (Identifier -> VisitKind -> Either Error (PP_Doc, PP_Doc))) _tlIcount :: Int _tlIdatatype :: ([PP_Doc]) _tlIerrors :: (Seq Error) _tlIfromToStates :: (Map VisitIdentifier (Int,Int)) _tlIgenProdIO :: (IO ()) _tlIimports :: ([PP_Doc]) _tlIsemFunBndDefs :: (Seq PP_Doc) _tlIsemFunBndTps :: (Seq PP_Doc) _tlIsem_nt :: PP_Doc _tlIsem_prod :: PP_Doc _tlIt_visits :: PP_Doc _tlIvisitKinds :: (Map VisitIdentifier VisitKind) _tlIvisitdefs :: (Map VisitIdentifier (Set Identifier)) _tlIvisituses :: (Map VisitIdentifier (Set Identifier)) -- "src-ag/ExecutionPlan2Hs.ag"(line 343, column 10) _lhsOallvisits = ({-# LINE 343 "src-ag/ExecutionPlan2Hs.ag" #-} _hdIallvisits {-# LINE 3765 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 396, column 10) _lhsOt_visits = ({-# LINE 396 "src-ag/ExecutionPlan2Hs.ag" #-} _hdIt_visits {-# LINE 3771 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- use rule "src-ag/ExecutionPlan2Hs.ag"(line 1167, column 37) _lhsOchildvisit = ({-# LINE 1167 "src-ag/ExecutionPlan2Hs.ag" #-} _hdIchildvisit `Map.union` _tlIchildvisit {-# LINE 3777 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- use rule "src-ag/ExecutionPlan2Hs.ag"(line 288, column 43) _lhsOcount = ({-# LINE 288 "src-ag/ExecutionPlan2Hs.ag" #-} _hdIcount + _tlIcount {-# LINE 3783 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- use rule "src-ag/ExecutionPlan2Hs.ag"(line 179, column 34) _lhsOdatatype = ({-# LINE 179 "src-ag/ExecutionPlan2Hs.ag" #-} _hdIdatatype : _tlIdatatype {-# LINE 3789 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- use rule "src-ag/ExecutionPlan2Hs.ag"(line 1609, column 132) _lhsOerrors = ({-# LINE 1609 "src-ag/ExecutionPlan2Hs.ag" #-} _hdIerrors Seq.>< _tlIerrors {-# LINE 3795 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- use rule "src-ag/ExecutionPlan2Hs.ag"(line 1524, column 22) _lhsOfromToStates = ({-# LINE 1524 "src-ag/ExecutionPlan2Hs.ag" #-} _hdIfromToStates `mappend` _tlIfromToStates {-# LINE 3801 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- use rule "src-ag/ExecutionPlan2Hs.ag"(line 1444, column 49) _lhsOgenProdIO = ({-# LINE 1444 "src-ag/ExecutionPlan2Hs.ag" #-} _hdIgenProdIO >> _tlIgenProdIO {-# LINE 3807 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- use rule "src-ag/ExecutionPlan2Hs.ag"(line 1443, column 47) _lhsOimports = ({-# LINE 1443 "src-ag/ExecutionPlan2Hs.ag" #-} _hdIimports ++ _tlIimports {-# LINE 3813 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- use rule "src-ag/ExecutionPlan2Hs.ag"(line 514, column 92) _lhsOsemFunBndDefs = ({-# LINE 514 "src-ag/ExecutionPlan2Hs.ag" #-} _hdIsemFunBndDefs Seq.>< _tlIsemFunBndDefs {-# LINE 3819 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- use rule "src-ag/ExecutionPlan2Hs.ag"(line 514, column 92) _lhsOsemFunBndTps = ({-# LINE 514 "src-ag/ExecutionPlan2Hs.ag" #-} _hdIsemFunBndTps Seq.>< _tlIsemFunBndTps {-# LINE 3825 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- use rule "src-ag/ExecutionPlan2Hs.ag"(line 292, column 44) _lhsOsem_nt = ({-# LINE 292 "src-ag/ExecutionPlan2Hs.ag" #-} _hdIsem_nt >-< _tlIsem_nt {-# LINE 3831 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- use rule "src-ag/ExecutionPlan2Hs.ag"(line 553, column 34) _lhsOsem_prod = ({-# LINE 553 "src-ag/ExecutionPlan2Hs.ag" #-} _hdIsem_prod >-< _tlIsem_prod {-# LINE 3837 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- use rule "src-ag/ExecutionPlan2Hs.ag"(line 1571, column 68) _lhsOvisitKinds = ({-# LINE 1571 "src-ag/ExecutionPlan2Hs.ag" #-} _hdIvisitKinds `mappend` _tlIvisitKinds {-# LINE 3843 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- use rule "src-ag/ExecutionPlan2Hs.ag"(line 1302, column 36) _lhsOvisitdefs = ({-# LINE 1302 "src-ag/ExecutionPlan2Hs.ag" #-} _hdIvisitdefs `uwSetUnion` _tlIvisitdefs {-# LINE 3849 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- use rule "src-ag/ExecutionPlan2Hs.ag"(line 1303, column 36) _lhsOvisituses = ({-# LINE 1303 "src-ag/ExecutionPlan2Hs.ag" #-} _hdIvisituses `uwSetUnion` _tlIvisituses {-# LINE 3855 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _hdOallFromToStates = ({-# LINE 1527 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIallFromToStates {-# LINE 3861 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _hdOallInhmap = ({-# LINE 320 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIallInhmap {-# LINE 3867 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _hdOallInitStates = ({-# LINE 1585 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIallInitStates {-# LINE 3873 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _hdOallSynmap = ({-# LINE 321 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIallSynmap {-# LINE 3879 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _hdOallVisitKinds = ({-# LINE 1571 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIallVisitKinds {-# LINE 3885 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _hdOallchildvisit = ({-# LINE 1166 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIallchildvisit {-# LINE 3891 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _hdOallstates = ({-# LINE 556 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIallstates {-# LINE 3897 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _hdOavisitdefs = ({-# LINE 1312 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIavisitdefs {-# LINE 3903 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _hdOavisituses = ({-# LINE 1313 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIavisituses {-# LINE 3909 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _hdOclassCtxs = ({-# LINE 77 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIclassCtxs {-# LINE 3915 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _hdOimportBlocks = ({-# LINE 34 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIimportBlocks {-# LINE 3921 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _hdOinhmap = ({-# LINE 318 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIinhmap {-# LINE 3927 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _hdOinitial = ({-# LINE 555 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIinitial {-# LINE 3933 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _hdOlocalAttrTypes = ({-# LINE 1557 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIlocalAttrTypes {-# LINE 3939 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _hdOmainFile = ({-# LINE 38 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsImainFile {-# LINE 3945 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _hdOmainName = ({-# LINE 39 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsImainName {-# LINE 3951 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _hdOmoduleHeader = ({-# LINE 37 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsImoduleHeader {-# LINE 3957 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _hdOnextVisits = ({-# LINE 1513 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsInextVisits {-# LINE 3963 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _hdOnt = ({-# LINE 61 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsInt {-# LINE 3969 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _hdOntType = ({-# LINE 1600 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIntType {-# LINE 3975 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _hdOoptions = ({-# LINE 51 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIoptions {-# LINE 3981 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _hdOparams = ({-# LINE 73 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIparams {-# LINE 3987 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _hdOpragmaBlocks = ({-# LINE 35 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIpragmaBlocks {-# LINE 3993 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _hdOprevVisits = ({-# LINE 1513 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIprevVisits {-# LINE 3999 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _hdOrename = ({-# LINE 52 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIrename {-# LINE 4005 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _hdOsynmap = ({-# LINE 319 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIsynmap {-# LINE 4011 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _hdOtextBlocks = ({-# LINE 36 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsItextBlocks {-# LINE 4017 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _tlOallFromToStates = ({-# LINE 1527 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIallFromToStates {-# LINE 4023 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _tlOallInhmap = ({-# LINE 320 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIallInhmap {-# LINE 4029 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _tlOallInitStates = ({-# LINE 1585 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIallInitStates {-# LINE 4035 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _tlOallSynmap = ({-# LINE 321 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIallSynmap {-# LINE 4041 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _tlOallVisitKinds = ({-# LINE 1571 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIallVisitKinds {-# LINE 4047 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _tlOallchildvisit = ({-# LINE 1166 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIallchildvisit {-# LINE 4053 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _tlOallstates = ({-# LINE 556 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIallstates {-# LINE 4059 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _tlOavisitdefs = ({-# LINE 1312 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIavisitdefs {-# LINE 4065 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _tlOavisituses = ({-# LINE 1313 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIavisituses {-# LINE 4071 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _tlOclassCtxs = ({-# LINE 77 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIclassCtxs {-# LINE 4077 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _tlOimportBlocks = ({-# LINE 34 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIimportBlocks {-# LINE 4083 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _tlOinhmap = ({-# LINE 318 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIinhmap {-# LINE 4089 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _tlOinitial = ({-# LINE 555 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIinitial {-# LINE 4095 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _tlOlocalAttrTypes = ({-# LINE 1557 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIlocalAttrTypes {-# LINE 4101 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _tlOmainFile = ({-# LINE 38 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsImainFile {-# LINE 4107 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _tlOmainName = ({-# LINE 39 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsImainName {-# LINE 4113 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _tlOmoduleHeader = ({-# LINE 37 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsImoduleHeader {-# LINE 4119 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _tlOnextVisits = ({-# LINE 1513 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsInextVisits {-# LINE 4125 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _tlOnt = ({-# LINE 61 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsInt {-# LINE 4131 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _tlOntType = ({-# LINE 1600 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIntType {-# LINE 4137 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _tlOoptions = ({-# LINE 51 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIoptions {-# LINE 4143 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _tlOparams = ({-# LINE 73 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIparams {-# LINE 4149 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _tlOpragmaBlocks = ({-# LINE 35 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIpragmaBlocks {-# LINE 4155 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _tlOprevVisits = ({-# LINE 1513 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIprevVisits {-# LINE 4161 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _tlOrename = ({-# LINE 52 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIrename {-# LINE 4167 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _tlOsynmap = ({-# LINE 319 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIsynmap {-# LINE 4173 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _tlOtextBlocks = ({-# LINE 36 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsItextBlocks {-# LINE 4179 "src-ag/ExecutionPlan2Hs.hs" #-} ) ( _hdIallvisits,_hdIchildvisit,_hdIcount,_hdIdatatype,_hdIerrors,_hdIfromToStates,_hdIgenProdIO,_hdIimports,_hdIsemFunBndDefs,_hdIsemFunBndTps,_hdIsem_nt,_hdIsem_prod,_hdIt_visits,_hdIvisitKinds,_hdIvisitdefs,_hdIvisituses) = hd_ _hdOallFromToStates _hdOallInhmap _hdOallInitStates _hdOallSynmap _hdOallVisitKinds _hdOallchildvisit _hdOallstates _hdOavisitdefs _hdOavisituses _hdOclassCtxs _hdOimportBlocks _hdOinhmap _hdOinitial _hdOlocalAttrTypes _hdOmainFile _hdOmainName _hdOmoduleHeader _hdOnextVisits _hdOnt _hdOntType _hdOoptions _hdOparams _hdOpragmaBlocks _hdOprevVisits _hdOrename _hdOsynmap _hdOtextBlocks ( _tlIallvisits,_tlIchildvisit,_tlIcount,_tlIdatatype,_tlIerrors,_tlIfromToStates,_tlIgenProdIO,_tlIimports,_tlIsemFunBndDefs,_tlIsemFunBndTps,_tlIsem_nt,_tlIsem_prod,_tlIt_visits,_tlIvisitKinds,_tlIvisitdefs,_tlIvisituses) = tl_ _tlOallFromToStates _tlOallInhmap _tlOallInitStates _tlOallSynmap _tlOallVisitKinds _tlOallchildvisit _tlOallstates _tlOavisitdefs _tlOavisituses _tlOclassCtxs _tlOimportBlocks _tlOinhmap _tlOinitial _tlOlocalAttrTypes _tlOmainFile _tlOmainName _tlOmoduleHeader _tlOnextVisits _tlOnt _tlOntType _tlOoptions _tlOparams _tlOpragmaBlocks _tlOprevVisits _tlOrename _tlOsynmap _tlOtextBlocks in ( _lhsOallvisits,_lhsOchildvisit,_lhsOcount,_lhsOdatatype,_lhsOerrors,_lhsOfromToStates,_lhsOgenProdIO,_lhsOimports,_lhsOsemFunBndDefs,_lhsOsemFunBndTps,_lhsOsem_nt,_lhsOsem_prod,_lhsOt_visits,_lhsOvisitKinds,_lhsOvisitdefs,_lhsOvisituses))) ) sem_EProductions_Nil :: T_EProductions sem_EProductions_Nil = (T_EProductions (\ _lhsIallFromToStates _lhsIallInhmap _lhsIallInitStates _lhsIallSynmap _lhsIallVisitKinds _lhsIallchildvisit _lhsIallstates _lhsIavisitdefs _lhsIavisituses _lhsIclassCtxs _lhsIimportBlocks _lhsIinhmap _lhsIinitial _lhsIlocalAttrTypes _lhsImainFile _lhsImainName _lhsImoduleHeader _lhsInextVisits _lhsInt _lhsIntType _lhsIoptions _lhsIparams _lhsIpragmaBlocks _lhsIprevVisits _lhsIrename _lhsIsynmap _lhsItextBlocks -> (let _lhsOallvisits :: ([VisitStateState]) _lhsOchildvisit :: (Map VisitIdentifier (Identifier -> VisitKind -> Either Error (PP_Doc, PP_Doc))) _lhsOcount :: Int _lhsOdatatype :: ([PP_Doc]) _lhsOerrors :: (Seq Error) _lhsOfromToStates :: (Map VisitIdentifier (Int,Int)) _lhsOgenProdIO :: (IO ()) _lhsOimports :: ([PP_Doc]) _lhsOsemFunBndDefs :: (Seq PP_Doc) _lhsOsemFunBndTps :: (Seq PP_Doc) _lhsOsem_nt :: PP_Doc _lhsOsem_prod :: PP_Doc _lhsOt_visits :: PP_Doc _lhsOvisitKinds :: (Map VisitIdentifier VisitKind) _lhsOvisitdefs :: (Map VisitIdentifier (Set Identifier)) _lhsOvisituses :: (Map VisitIdentifier (Set Identifier)) -- "src-ag/ExecutionPlan2Hs.ag"(line 344, column 10) _lhsOallvisits = ({-# LINE 344 "src-ag/ExecutionPlan2Hs.ag" #-} error "Every nonterminal should have at least 1 production" {-# LINE 4235 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- use rule "src-ag/ExecutionPlan2Hs.ag"(line 1167, column 37) _lhsOchildvisit = ({-# LINE 1167 "src-ag/ExecutionPlan2Hs.ag" #-} Map.empty {-# LINE 4241 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- use rule "src-ag/ExecutionPlan2Hs.ag"(line 288, column 43) _lhsOcount = ({-# LINE 288 "src-ag/ExecutionPlan2Hs.ag" #-} 0 {-# LINE 4247 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- use rule "src-ag/ExecutionPlan2Hs.ag"(line 179, column 34) _lhsOdatatype = ({-# LINE 179 "src-ag/ExecutionPlan2Hs.ag" #-} [] {-# LINE 4253 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- use rule "src-ag/ExecutionPlan2Hs.ag"(line 1609, column 132) _lhsOerrors = ({-# LINE 1609 "src-ag/ExecutionPlan2Hs.ag" #-} Seq.empty {-# LINE 4259 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- use rule "src-ag/ExecutionPlan2Hs.ag"(line 1524, column 22) _lhsOfromToStates = ({-# LINE 1524 "src-ag/ExecutionPlan2Hs.ag" #-} mempty {-# LINE 4265 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- use rule "src-ag/ExecutionPlan2Hs.ag"(line 1444, column 49) _lhsOgenProdIO = ({-# LINE 1444 "src-ag/ExecutionPlan2Hs.ag" #-} return () {-# LINE 4271 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- use rule "src-ag/ExecutionPlan2Hs.ag"(line 1443, column 47) _lhsOimports = ({-# LINE 1443 "src-ag/ExecutionPlan2Hs.ag" #-} [] {-# LINE 4277 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- use rule "src-ag/ExecutionPlan2Hs.ag"(line 514, column 92) _lhsOsemFunBndDefs = ({-# LINE 514 "src-ag/ExecutionPlan2Hs.ag" #-} Seq.empty {-# LINE 4283 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- use rule "src-ag/ExecutionPlan2Hs.ag"(line 514, column 92) _lhsOsemFunBndTps = ({-# LINE 514 "src-ag/ExecutionPlan2Hs.ag" #-} Seq.empty {-# LINE 4289 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- use rule "src-ag/ExecutionPlan2Hs.ag"(line 292, column 44) _lhsOsem_nt = ({-# LINE 292 "src-ag/ExecutionPlan2Hs.ag" #-} empty {-# LINE 4295 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- use rule "src-ag/ExecutionPlan2Hs.ag"(line 553, column 34) _lhsOsem_prod = ({-# LINE 553 "src-ag/ExecutionPlan2Hs.ag" #-} empty {-# LINE 4301 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- use rule "src-ag/ExecutionPlan2Hs.ag"(line 393, column 59) _lhsOt_visits = ({-# LINE 393 "src-ag/ExecutionPlan2Hs.ag" #-} empty {-# LINE 4307 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- use rule "src-ag/ExecutionPlan2Hs.ag"(line 1571, column 68) _lhsOvisitKinds = ({-# LINE 1571 "src-ag/ExecutionPlan2Hs.ag" #-} mempty {-# LINE 4313 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- use rule "src-ag/ExecutionPlan2Hs.ag"(line 1302, column 36) _lhsOvisitdefs = ({-# LINE 1302 "src-ag/ExecutionPlan2Hs.ag" #-} Map.empty {-# LINE 4319 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- use rule "src-ag/ExecutionPlan2Hs.ag"(line 1303, column 36) _lhsOvisituses = ({-# LINE 1303 "src-ag/ExecutionPlan2Hs.ag" #-} Map.empty {-# LINE 4325 "src-ag/ExecutionPlan2Hs.hs" #-} ) in ( _lhsOallvisits,_lhsOchildvisit,_lhsOcount,_lhsOdatatype,_lhsOerrors,_lhsOfromToStates,_lhsOgenProdIO,_lhsOimports,_lhsOsemFunBndDefs,_lhsOsemFunBndTps,_lhsOsem_nt,_lhsOsem_prod,_lhsOt_visits,_lhsOvisitKinds,_lhsOvisitdefs,_lhsOvisituses))) ) -- ERule ------------------------------------------------------- {- visit 0: inherited attributes: allInhmap : Map NontermIdent Attributes allSynmap : Map NontermIdent Attributes childTypes : Map Identifier Type con : ConstructorIdent importBlocks : PP_Doc inhmap : Attributes lazyIntras : Set String localAttrTypes : Map Identifier Type mainFile : String mainName : String moduleHeader : String -> String -> String -> Bool -> String nt : NontermIdent options : Options pragmaBlocks : String ruleKinds : Map Identifier (Set VisitKind) synmap : Attributes textBlocks : PP_Doc usageInfo : Map Identifier Int synthesized attributes: errors : Seq Error mrules : Map Identifier (VisitKind -> FormatMode -> Either Error PP_Doc) ruledefs : Map Identifier (Set String) ruleuses : Map Identifier (Map String (Maybe NonLocalAttr)) sem_rules : PP_Doc alternatives: alternative ERule: child name : {Identifier} child pattern : Pattern child rhs : Expression child owrt : {Bool} child origin : {String} child explicit : {Bool} child pure : {Bool} child mbError : {Maybe Error} visit 0: local rulecode : _ local rulePragma : _ local scc : _ local pragma : _ local endpragma : _ local genpragma : _ local haspos : _ local lambda : _ local argPats : _ local argExprs : _ local stepcode : _ local used : _ local kinds : _ local anyLazyKind : _ local addbang : _ local addbang1 : _ -} -- cata sem_ERule :: ERule -> T_ERule sem_ERule (ERule _name _pattern _rhs _owrt _origin _explicit _pure _mbError ) = (sem_ERule_ERule _name (sem_Pattern _pattern ) (sem_Expression _rhs ) _owrt _origin _explicit _pure _mbError ) -- semantic domain newtype T_ERule = T_ERule ((Map NontermIdent Attributes) -> (Map NontermIdent Attributes) -> (Map Identifier Type) -> ConstructorIdent -> PP_Doc -> Attributes -> (Set String) -> (Map Identifier Type) -> String -> String -> (String -> String -> String -> Bool -> String) -> NontermIdent -> Options -> String -> (Map Identifier (Set VisitKind)) -> Attributes -> PP_Doc -> (Map Identifier Int) -> ( (Seq Error),(Map Identifier (VisitKind -> FormatMode -> Either Error PP_Doc)),(Map Identifier (Set String)),(Map Identifier (Map String (Maybe NonLocalAttr))),PP_Doc)) data Inh_ERule = Inh_ERule {allInhmap_Inh_ERule :: (Map NontermIdent Attributes),allSynmap_Inh_ERule :: (Map NontermIdent Attributes),childTypes_Inh_ERule :: (Map Identifier Type),con_Inh_ERule :: ConstructorIdent,importBlocks_Inh_ERule :: PP_Doc,inhmap_Inh_ERule :: Attributes,lazyIntras_Inh_ERule :: (Set String),localAttrTypes_Inh_ERule :: (Map Identifier Type),mainFile_Inh_ERule :: String,mainName_Inh_ERule :: String,moduleHeader_Inh_ERule :: (String -> String -> String -> Bool -> String),nt_Inh_ERule :: NontermIdent,options_Inh_ERule :: Options,pragmaBlocks_Inh_ERule :: String,ruleKinds_Inh_ERule :: (Map Identifier (Set VisitKind)),synmap_Inh_ERule :: Attributes,textBlocks_Inh_ERule :: PP_Doc,usageInfo_Inh_ERule :: (Map Identifier Int)} data Syn_ERule = Syn_ERule {errors_Syn_ERule :: (Seq Error),mrules_Syn_ERule :: (Map Identifier (VisitKind -> FormatMode -> Either Error PP_Doc)),ruledefs_Syn_ERule :: (Map Identifier (Set String)),ruleuses_Syn_ERule :: (Map Identifier (Map String (Maybe NonLocalAttr))),sem_rules_Syn_ERule :: PP_Doc} wrap_ERule :: T_ERule -> Inh_ERule -> Syn_ERule wrap_ERule (T_ERule sem ) (Inh_ERule _lhsIallInhmap _lhsIallSynmap _lhsIchildTypes _lhsIcon _lhsIimportBlocks _lhsIinhmap _lhsIlazyIntras _lhsIlocalAttrTypes _lhsImainFile _lhsImainName _lhsImoduleHeader _lhsInt _lhsIoptions _lhsIpragmaBlocks _lhsIruleKinds _lhsIsynmap _lhsItextBlocks _lhsIusageInfo ) = (let ( _lhsOerrors,_lhsOmrules,_lhsOruledefs,_lhsOruleuses,_lhsOsem_rules) = sem _lhsIallInhmap _lhsIallSynmap _lhsIchildTypes _lhsIcon _lhsIimportBlocks _lhsIinhmap _lhsIlazyIntras _lhsIlocalAttrTypes _lhsImainFile _lhsImainName _lhsImoduleHeader _lhsInt _lhsIoptions _lhsIpragmaBlocks _lhsIruleKinds _lhsIsynmap _lhsItextBlocks _lhsIusageInfo in (Syn_ERule _lhsOerrors _lhsOmrules _lhsOruledefs _lhsOruleuses _lhsOsem_rules )) sem_ERule_ERule :: Identifier -> T_Pattern -> T_Expression -> Bool -> String -> Bool -> Bool -> (Maybe Error) -> T_ERule sem_ERule_ERule name_ (T_Pattern pattern_ ) (T_Expression rhs_ ) owrt_ origin_ explicit_ pure_ mbError_ = (T_ERule (\ _lhsIallInhmap _lhsIallSynmap _lhsIchildTypes _lhsIcon _lhsIimportBlocks _lhsIinhmap _lhsIlazyIntras _lhsIlocalAttrTypes _lhsImainFile _lhsImainName _lhsImoduleHeader _lhsInt _lhsIoptions _lhsIpragmaBlocks _lhsIruleKinds _lhsIsynmap _lhsItextBlocks _lhsIusageInfo -> (let _lhsOsem_rules :: PP_Doc _lhsOmrules :: (Map Identifier (VisitKind -> FormatMode -> Either Error PP_Doc)) _lhsOruledefs :: (Map Identifier (Set String)) _lhsOruleuses :: (Map Identifier (Map String (Maybe NonLocalAttr))) _lhsOerrors :: (Seq Error) _patternOanyLazyKind :: Bool _patternOoptions :: Options _patternIattrs :: (Set String) _patternIcopy :: Pattern _patternIisUnderscore :: Bool _patternIsem_lhs :: ( PP_Doc ) _rhsIattrs :: (Map String (Maybe NonLocalAttr)) _rhsIpos :: Pos _rhsIsemfunc :: PP_Doc -- "src-ag/ExecutionPlan2Hs.ag"(line 963, column 6) _lhsOsem_rules = ({-# LINE 963 "src-ag/ExecutionPlan2Hs.ag" #-} if _used == 0 then empty else _rulePragma >-< _rulecode {-# LINE 4465 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 966, column 6) _rulecode = ({-# LINE 966 "src-ag/ExecutionPlan2Hs.ag" #-} ( if _genpragma then _pragma else empty ) >-< _lambda >#< _scc >-< indent ((column _rhsIpos - 2) `max` 2) ( if _genpragma then _pragma >-< _rhsIsemfunc >-< _endpragma else _rhsIsemfunc ) {-# LINE 4480 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 978, column 7) _rulePragma = ({-# LINE 978 "src-ag/ExecutionPlan2Hs.ag" #-} ( let reallyInlineStr = "INLINE" reallyNoInlineStr = "NOINLINE" in if noInlinePragmas _lhsIoptions then empty else if _used == 1 then ppPragmaBinding reallyInlineStr name_ else if helpInlining _lhsIoptions then if not explicit_ && _used <= reallyOftenUsedThreshold then ppPragmaBinding "INLINE[1]" name_ else if _used > ruleInlineThresholdSoft && explicit_ then if _used > ruleInlineThresholdHard then ppPragmaBinding reallyNoInlineStr name_ else if aggressiveInlinePragmas _lhsIoptions then ppPragmaBinding "NOINLINE[2]" name_ else ppNoInline name_ else if aggressiveInlinePragmas _lhsIoptions then ppPragmaBinding "NOINLINE[1]" name_ else ppNoInline name_ else if not explicit_ || _used <= ruleInlineThresholdSoft then ppPragmaBinding "NOINLINE[1]" name_ else ppNoInline name_ ) {-# LINE 4507 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 1000, column 7) _scc = ({-# LINE 1000 "src-ag/ExecutionPlan2Hs.ag" #-} if genCostCentres _lhsIoptions && explicit_ && pure_ && not (noPerRuleCostCentres _lhsIoptions) then ppCostCentre (name_ >|< "_" >|< line _rhsIpos >|< "_" >|< _lhsInt >|< "_" >|< _lhsIcon) else empty {-# LINE 4515 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 1003, column 7) _pragma = ({-# LINE 1003 "src-ag/ExecutionPlan2Hs.ag" #-} "{-# LINE" >#< show (line _rhsIpos) >#< show (file _rhsIpos) >#< "#-}" {-# LINE 4521 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 1004, column 7) _endpragma = ({-# LINE 1004 "src-ag/ExecutionPlan2Hs.ag" #-} ppWithLineNr (\ln -> "{-# LINE " ++ show (ln+1) ++ " " ++ show _lhsImainFile ++ "#-}") {-# LINE 4527 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 1005, column 7) _genpragma = ({-# LINE 1005 "src-ag/ExecutionPlan2Hs.ag" #-} genLinePragmas _lhsIoptions && explicit_ && _haspos {-# LINE 4533 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 1006, column 7) _haspos = ({-# LINE 1006 "src-ag/ExecutionPlan2Hs.ag" #-} line _rhsIpos > 0 && column _rhsIpos >= 0 && not (null (file _rhsIpos)) {-# LINE 4539 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 1015, column 7) _lambda = ({-# LINE 1015 "src-ag/ExecutionPlan2Hs.ag" #-} name_ >#< "=" >#< "\\" >#< _argPats >#< dummyPat _lhsIoptions (Map.null _rhsIattrs) >#< "->" {-# LINE 4545 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 1017, column 7) _argPats = ({-# LINE 1017 "src-ag/ExecutionPlan2Hs.ag" #-} ppSpaced [ let match | str `Set.member` _lhsIlazyIntras = pp str | otherwise = _addbang1 (pp str) in case mbAttr of Just (AttrSyn child nm) | child == _LOC && not (noPerStateTypeSigs _lhsIoptions) -> case Map.lookup nm _lhsIlocalAttrTypes of Just tp -> pp_parens (pp_parens match >#< "::" >#< ppTp tp) Nothing -> match Just attr | not (noPerRuleTypeSigs _lhsIoptions) -> case lookupAttrType attr _lhsIallInhmap _lhsIallSynmap _lhsIchildTypes of Just tpDoc -> pp_parens (pp_parens match >#< "::" >#< tpDoc) Nothing -> match _ -> match | (str,mbAttr) <- Map.assocs _rhsIattrs ] {-# LINE 4564 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 1031, column 7) _argExprs = ({-# LINE 1031 "src-ag/ExecutionPlan2Hs.ag" #-} ppSpaced $ Map.keys _rhsIattrs {-# LINE 4570 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 1032, column 7) _stepcode = ({-# LINE 1032 "src-ag/ExecutionPlan2Hs.ag" #-} \kind fmtMode -> if kind `compatibleRule` pure_ then Right $ let oper | pure_ = "=" | otherwise = "<-" decl = _patternIsem_lhs >#< oper >#< name_ >#< _argExprs >#< dummyArg _lhsIoptions (Map.null _rhsIattrs) in fmtDecl pure_ fmtMode decl else Left $ IncompatibleRuleKind name_ kind {-# LINE 4581 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 1039, column 7) _lhsOmrules = ({-# LINE 1039 "src-ag/ExecutionPlan2Hs.ag" #-} Map.singleton name_ _stepcode {-# LINE 4587 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 1228, column 32) _used = ({-# LINE 1228 "src-ag/ExecutionPlan2Hs.ag" #-} Map.findWithDefault 0 name_ _lhsIusageInfo {-# LINE 4593 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 1244, column 3) _kinds = ({-# LINE 1244 "src-ag/ExecutionPlan2Hs.ag" #-} Map.findWithDefault Set.empty name_ _lhsIruleKinds {-# LINE 4599 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 1245, column 3) _anyLazyKind = ({-# LINE 1245 "src-ag/ExecutionPlan2Hs.ag" #-} Set.fold (\k r -> isLazyKind k || r) False _kinds {-# LINE 4605 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 1291, column 11) _lhsOruledefs = ({-# LINE 1291 "src-ag/ExecutionPlan2Hs.ag" #-} Map.singleton name_ _patternIattrs {-# LINE 4611 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 1292, column 11) _lhsOruleuses = ({-# LINE 1292 "src-ag/ExecutionPlan2Hs.ag" #-} Map.singleton name_ _rhsIattrs {-# LINE 4617 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 1494, column 37) _addbang = ({-# LINE 1494 "src-ag/ExecutionPlan2Hs.ag" #-} \x -> if bangpats _lhsIoptions then "!" >|< x else x {-# LINE 4623 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 1505, column 37) _addbang1 = ({-# LINE 1505 "src-ag/ExecutionPlan2Hs.ag" #-} if _anyLazyKind then id else _addbang {-# LINE 4629 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 1611, column 3) _lhsOerrors = ({-# LINE 1611 "src-ag/ExecutionPlan2Hs.ag" #-} case mbError_ of Just e | _used > 0 -> Seq.singleton e _ -> Seq.empty {-# LINE 4637 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (from local) _patternOanyLazyKind = ({-# LINE 1247 "src-ag/ExecutionPlan2Hs.ag" #-} _anyLazyKind {-# LINE 4643 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _patternOoptions = ({-# LINE 51 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIoptions {-# LINE 4649 "src-ag/ExecutionPlan2Hs.hs" #-} ) ( _patternIattrs,_patternIcopy,_patternIisUnderscore,_patternIsem_lhs) = pattern_ _patternOanyLazyKind _patternOoptions ( _rhsIattrs,_rhsIpos,_rhsIsemfunc) = rhs_ in ( _lhsOerrors,_lhsOmrules,_lhsOruledefs,_lhsOruleuses,_lhsOsem_rules))) ) -- ERules ------------------------------------------------------ {- visit 0: inherited attributes: allInhmap : Map NontermIdent Attributes allSynmap : Map NontermIdent Attributes childTypes : Map Identifier Type con : ConstructorIdent importBlocks : PP_Doc inhmap : Attributes lazyIntras : Set String localAttrTypes : Map Identifier Type mainFile : String mainName : String moduleHeader : String -> String -> String -> Bool -> String nt : NontermIdent options : Options pragmaBlocks : String ruleKinds : Map Identifier (Set VisitKind) synmap : Attributes textBlocks : PP_Doc usageInfo : Map Identifier Int synthesized attributes: errors : Seq Error mrules : Map Identifier (VisitKind -> FormatMode -> Either Error PP_Doc) ruledefs : Map Identifier (Set String) ruleuses : Map Identifier (Map String (Maybe NonLocalAttr)) sem_rules : PP_Doc alternatives: alternative Cons: child hd : ERule child tl : ERules alternative Nil: -} -- cata sem_ERules :: ERules -> T_ERules sem_ERules list = (Prelude.foldr sem_ERules_Cons sem_ERules_Nil (Prelude.map sem_ERule list) ) -- semantic domain newtype T_ERules = T_ERules ((Map NontermIdent Attributes) -> (Map NontermIdent Attributes) -> (Map Identifier Type) -> ConstructorIdent -> PP_Doc -> Attributes -> (Set String) -> (Map Identifier Type) -> String -> String -> (String -> String -> String -> Bool -> String) -> NontermIdent -> Options -> String -> (Map Identifier (Set VisitKind)) -> Attributes -> PP_Doc -> (Map Identifier Int) -> ( (Seq Error),(Map Identifier (VisitKind -> FormatMode -> Either Error PP_Doc)),(Map Identifier (Set String)),(Map Identifier (Map String (Maybe NonLocalAttr))),PP_Doc)) data Inh_ERules = Inh_ERules {allInhmap_Inh_ERules :: (Map NontermIdent Attributes),allSynmap_Inh_ERules :: (Map NontermIdent Attributes),childTypes_Inh_ERules :: (Map Identifier Type),con_Inh_ERules :: ConstructorIdent,importBlocks_Inh_ERules :: PP_Doc,inhmap_Inh_ERules :: Attributes,lazyIntras_Inh_ERules :: (Set String),localAttrTypes_Inh_ERules :: (Map Identifier Type),mainFile_Inh_ERules :: String,mainName_Inh_ERules :: String,moduleHeader_Inh_ERules :: (String -> String -> String -> Bool -> String),nt_Inh_ERules :: NontermIdent,options_Inh_ERules :: Options,pragmaBlocks_Inh_ERules :: String,ruleKinds_Inh_ERules :: (Map Identifier (Set VisitKind)),synmap_Inh_ERules :: Attributes,textBlocks_Inh_ERules :: PP_Doc,usageInfo_Inh_ERules :: (Map Identifier Int)} data Syn_ERules = Syn_ERules {errors_Syn_ERules :: (Seq Error),mrules_Syn_ERules :: (Map Identifier (VisitKind -> FormatMode -> Either Error PP_Doc)),ruledefs_Syn_ERules :: (Map Identifier (Set String)),ruleuses_Syn_ERules :: (Map Identifier (Map String (Maybe NonLocalAttr))),sem_rules_Syn_ERules :: PP_Doc} wrap_ERules :: T_ERules -> Inh_ERules -> Syn_ERules wrap_ERules (T_ERules sem ) (Inh_ERules _lhsIallInhmap _lhsIallSynmap _lhsIchildTypes _lhsIcon _lhsIimportBlocks _lhsIinhmap _lhsIlazyIntras _lhsIlocalAttrTypes _lhsImainFile _lhsImainName _lhsImoduleHeader _lhsInt _lhsIoptions _lhsIpragmaBlocks _lhsIruleKinds _lhsIsynmap _lhsItextBlocks _lhsIusageInfo ) = (let ( _lhsOerrors,_lhsOmrules,_lhsOruledefs,_lhsOruleuses,_lhsOsem_rules) = sem _lhsIallInhmap _lhsIallSynmap _lhsIchildTypes _lhsIcon _lhsIimportBlocks _lhsIinhmap _lhsIlazyIntras _lhsIlocalAttrTypes _lhsImainFile _lhsImainName _lhsImoduleHeader _lhsInt _lhsIoptions _lhsIpragmaBlocks _lhsIruleKinds _lhsIsynmap _lhsItextBlocks _lhsIusageInfo in (Syn_ERules _lhsOerrors _lhsOmrules _lhsOruledefs _lhsOruleuses _lhsOsem_rules )) sem_ERules_Cons :: T_ERule -> T_ERules -> T_ERules sem_ERules_Cons (T_ERule hd_ ) (T_ERules tl_ ) = (T_ERules (\ _lhsIallInhmap _lhsIallSynmap _lhsIchildTypes _lhsIcon _lhsIimportBlocks _lhsIinhmap _lhsIlazyIntras _lhsIlocalAttrTypes _lhsImainFile _lhsImainName _lhsImoduleHeader _lhsInt _lhsIoptions _lhsIpragmaBlocks _lhsIruleKinds _lhsIsynmap _lhsItextBlocks _lhsIusageInfo -> (let _lhsOerrors :: (Seq Error) _lhsOmrules :: (Map Identifier (VisitKind -> FormatMode -> Either Error PP_Doc)) _lhsOruledefs :: (Map Identifier (Set String)) _lhsOruleuses :: (Map Identifier (Map String (Maybe NonLocalAttr))) _lhsOsem_rules :: PP_Doc _hdOallInhmap :: (Map NontermIdent Attributes) _hdOallSynmap :: (Map NontermIdent Attributes) _hdOchildTypes :: (Map Identifier Type) _hdOcon :: ConstructorIdent _hdOimportBlocks :: PP_Doc _hdOinhmap :: Attributes _hdOlazyIntras :: (Set String) _hdOlocalAttrTypes :: (Map Identifier Type) _hdOmainFile :: String _hdOmainName :: String _hdOmoduleHeader :: (String -> String -> String -> Bool -> String) _hdOnt :: NontermIdent _hdOoptions :: Options _hdOpragmaBlocks :: String _hdOruleKinds :: (Map Identifier (Set VisitKind)) _hdOsynmap :: Attributes _hdOtextBlocks :: PP_Doc _hdOusageInfo :: (Map Identifier Int) _tlOallInhmap :: (Map NontermIdent Attributes) _tlOallSynmap :: (Map NontermIdent Attributes) _tlOchildTypes :: (Map Identifier Type) _tlOcon :: ConstructorIdent _tlOimportBlocks :: PP_Doc _tlOinhmap :: Attributes _tlOlazyIntras :: (Set String) _tlOlocalAttrTypes :: (Map Identifier Type) _tlOmainFile :: String _tlOmainName :: String _tlOmoduleHeader :: (String -> String -> String -> Bool -> String) _tlOnt :: NontermIdent _tlOoptions :: Options _tlOpragmaBlocks :: String _tlOruleKinds :: (Map Identifier (Set VisitKind)) _tlOsynmap :: Attributes _tlOtextBlocks :: PP_Doc _tlOusageInfo :: (Map Identifier Int) _hdIerrors :: (Seq Error) _hdImrules :: (Map Identifier (VisitKind -> FormatMode -> Either Error PP_Doc)) _hdIruledefs :: (Map Identifier (Set String)) _hdIruleuses :: (Map Identifier (Map String (Maybe NonLocalAttr))) _hdIsem_rules :: PP_Doc _tlIerrors :: (Seq Error) _tlImrules :: (Map Identifier (VisitKind -> FormatMode -> Either Error PP_Doc)) _tlIruledefs :: (Map Identifier (Set String)) _tlIruleuses :: (Map Identifier (Map String (Maybe NonLocalAttr))) _tlIsem_rules :: PP_Doc -- use rule "src-ag/ExecutionPlan2Hs.ag"(line 1609, column 132) _lhsOerrors = ({-# LINE 1609 "src-ag/ExecutionPlan2Hs.ag" #-} _hdIerrors Seq.>< _tlIerrors {-# LINE 4800 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- use rule "src-ag/ExecutionPlan2Hs.ag"(line 960, column 32) _lhsOmrules = ({-# LINE 960 "src-ag/ExecutionPlan2Hs.ag" #-} _hdImrules `Map.union` _tlImrules {-# LINE 4806 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- use rule "src-ag/ExecutionPlan2Hs.ag"(line 1284, column 34) _lhsOruledefs = ({-# LINE 1284 "src-ag/ExecutionPlan2Hs.ag" #-} _hdIruledefs `uwSetUnion` _tlIruledefs {-# LINE 4812 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- use rule "src-ag/ExecutionPlan2Hs.ag"(line 1285, column 34) _lhsOruleuses = ({-# LINE 1285 "src-ag/ExecutionPlan2Hs.ag" #-} _hdIruleuses `uwMapUnion` _tlIruleuses {-# LINE 4818 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- use rule "src-ag/ExecutionPlan2Hs.ag"(line 959, column 35) _lhsOsem_rules = ({-# LINE 959 "src-ag/ExecutionPlan2Hs.ag" #-} _hdIsem_rules >-< _tlIsem_rules {-# LINE 4824 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _hdOallInhmap = ({-# LINE 320 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIallInhmap {-# LINE 4830 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _hdOallSynmap = ({-# LINE 321 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIallSynmap {-# LINE 4836 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _hdOchildTypes = ({-# LINE 1544 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIchildTypes {-# LINE 4842 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _hdOcon = ({-# LINE 66 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIcon {-# LINE 4848 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _hdOimportBlocks = ({-# LINE 34 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIimportBlocks {-# LINE 4854 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _hdOinhmap = ({-# LINE 318 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIinhmap {-# LINE 4860 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _hdOlazyIntras = ({-# LINE 1336 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIlazyIntras {-# LINE 4866 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _hdOlocalAttrTypes = ({-# LINE 1558 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIlocalAttrTypes {-# LINE 4872 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _hdOmainFile = ({-# LINE 38 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsImainFile {-# LINE 4878 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _hdOmainName = ({-# LINE 39 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsImainName {-# LINE 4884 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _hdOmoduleHeader = ({-# LINE 37 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsImoduleHeader {-# LINE 4890 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _hdOnt = ({-# LINE 61 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsInt {-# LINE 4896 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _hdOoptions = ({-# LINE 51 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIoptions {-# LINE 4902 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _hdOpragmaBlocks = ({-# LINE 35 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIpragmaBlocks {-# LINE 4908 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _hdOruleKinds = ({-# LINE 1239 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIruleKinds {-# LINE 4914 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _hdOsynmap = ({-# LINE 319 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIsynmap {-# LINE 4920 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _hdOtextBlocks = ({-# LINE 36 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsItextBlocks {-# LINE 4926 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _hdOusageInfo = ({-# LINE 1224 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIusageInfo {-# LINE 4932 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _tlOallInhmap = ({-# LINE 320 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIallInhmap {-# LINE 4938 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _tlOallSynmap = ({-# LINE 321 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIallSynmap {-# LINE 4944 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _tlOchildTypes = ({-# LINE 1544 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIchildTypes {-# LINE 4950 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _tlOcon = ({-# LINE 66 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIcon {-# LINE 4956 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _tlOimportBlocks = ({-# LINE 34 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIimportBlocks {-# LINE 4962 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _tlOinhmap = ({-# LINE 318 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIinhmap {-# LINE 4968 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _tlOlazyIntras = ({-# LINE 1336 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIlazyIntras {-# LINE 4974 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _tlOlocalAttrTypes = ({-# LINE 1558 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIlocalAttrTypes {-# LINE 4980 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _tlOmainFile = ({-# LINE 38 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsImainFile {-# LINE 4986 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _tlOmainName = ({-# LINE 39 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsImainName {-# LINE 4992 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _tlOmoduleHeader = ({-# LINE 37 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsImoduleHeader {-# LINE 4998 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _tlOnt = ({-# LINE 61 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsInt {-# LINE 5004 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _tlOoptions = ({-# LINE 51 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIoptions {-# LINE 5010 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _tlOpragmaBlocks = ({-# LINE 35 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIpragmaBlocks {-# LINE 5016 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _tlOruleKinds = ({-# LINE 1239 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIruleKinds {-# LINE 5022 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _tlOsynmap = ({-# LINE 319 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIsynmap {-# LINE 5028 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _tlOtextBlocks = ({-# LINE 36 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsItextBlocks {-# LINE 5034 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _tlOusageInfo = ({-# LINE 1224 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIusageInfo {-# LINE 5040 "src-ag/ExecutionPlan2Hs.hs" #-} ) ( _hdIerrors,_hdImrules,_hdIruledefs,_hdIruleuses,_hdIsem_rules) = hd_ _hdOallInhmap _hdOallSynmap _hdOchildTypes _hdOcon _hdOimportBlocks _hdOinhmap _hdOlazyIntras _hdOlocalAttrTypes _hdOmainFile _hdOmainName _hdOmoduleHeader _hdOnt _hdOoptions _hdOpragmaBlocks _hdOruleKinds _hdOsynmap _hdOtextBlocks _hdOusageInfo ( _tlIerrors,_tlImrules,_tlIruledefs,_tlIruleuses,_tlIsem_rules) = tl_ _tlOallInhmap _tlOallSynmap _tlOchildTypes _tlOcon _tlOimportBlocks _tlOinhmap _tlOlazyIntras _tlOlocalAttrTypes _tlOmainFile _tlOmainName _tlOmoduleHeader _tlOnt _tlOoptions _tlOpragmaBlocks _tlOruleKinds _tlOsynmap _tlOtextBlocks _tlOusageInfo in ( _lhsOerrors,_lhsOmrules,_lhsOruledefs,_lhsOruleuses,_lhsOsem_rules))) ) sem_ERules_Nil :: T_ERules sem_ERules_Nil = (T_ERules (\ _lhsIallInhmap _lhsIallSynmap _lhsIchildTypes _lhsIcon _lhsIimportBlocks _lhsIinhmap _lhsIlazyIntras _lhsIlocalAttrTypes _lhsImainFile _lhsImainName _lhsImoduleHeader _lhsInt _lhsIoptions _lhsIpragmaBlocks _lhsIruleKinds _lhsIsynmap _lhsItextBlocks _lhsIusageInfo -> (let _lhsOerrors :: (Seq Error) _lhsOmrules :: (Map Identifier (VisitKind -> FormatMode -> Either Error PP_Doc)) _lhsOruledefs :: (Map Identifier (Set String)) _lhsOruleuses :: (Map Identifier (Map String (Maybe NonLocalAttr))) _lhsOsem_rules :: PP_Doc -- use rule "src-ag/ExecutionPlan2Hs.ag"(line 1609, column 132) _lhsOerrors = ({-# LINE 1609 "src-ag/ExecutionPlan2Hs.ag" #-} Seq.empty {-# LINE 5076 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- use rule "src-ag/ExecutionPlan2Hs.ag"(line 960, column 32) _lhsOmrules = ({-# LINE 960 "src-ag/ExecutionPlan2Hs.ag" #-} Map.empty {-# LINE 5082 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- use rule "src-ag/ExecutionPlan2Hs.ag"(line 1284, column 34) _lhsOruledefs = ({-# LINE 1284 "src-ag/ExecutionPlan2Hs.ag" #-} Map.empty {-# LINE 5088 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- use rule "src-ag/ExecutionPlan2Hs.ag"(line 1285, column 34) _lhsOruleuses = ({-# LINE 1285 "src-ag/ExecutionPlan2Hs.ag" #-} Map.empty {-# LINE 5094 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- use rule "src-ag/ExecutionPlan2Hs.ag"(line 959, column 35) _lhsOsem_rules = ({-# LINE 959 "src-ag/ExecutionPlan2Hs.ag" #-} empty {-# LINE 5100 "src-ag/ExecutionPlan2Hs.hs" #-} ) in ( _lhsOerrors,_lhsOmrules,_lhsOruledefs,_lhsOruleuses,_lhsOsem_rules))) ) -- ExecutionPlan ----------------------------------------------- {- visit 0: inherited attributes: importBlocks : PP_Doc inhmap : Map NontermIdent Attributes localAttrTypes : Map NontermIdent (Map ConstructorIdent (Map Identifier Type)) mainBlocksDoc : PP_Doc mainFile : String mainName : String moduleHeader : String -> String -> String -> Bool -> String options : Options pragmaBlocks : String synmap : Map NontermIdent Attributes textBlockMap : Map BlockInfo PP_Doc textBlocks : PP_Doc synthesized attributes: errors : Seq Error genIO : IO () output : PP_Doc alternatives: alternative ExecutionPlan: child nonts : ENonterminals child typeSyns : {TypeSyns} child wrappers : {Set NontermIdent} child derivings : {Derivings} visit 0: local wrappersExtra : _ local commonExtra : _ local lateSemBndTp : _ local lateSemBndDef : _ local mainModuleFile : _ local ppMonadImports : _ local genMainModule : _ local commonFile : _ local genCommonModule : _ -} -- cata sem_ExecutionPlan :: ExecutionPlan -> T_ExecutionPlan sem_ExecutionPlan (ExecutionPlan _nonts _typeSyns _wrappers _derivings ) = (sem_ExecutionPlan_ExecutionPlan (sem_ENonterminals _nonts ) _typeSyns _wrappers _derivings ) -- semantic domain newtype T_ExecutionPlan = T_ExecutionPlan (PP_Doc -> (Map NontermIdent Attributes) -> (Map NontermIdent (Map ConstructorIdent (Map Identifier Type))) -> PP_Doc -> String -> String -> (String -> String -> String -> Bool -> String) -> Options -> String -> (Map NontermIdent Attributes) -> (Map BlockInfo PP_Doc) -> PP_Doc -> ( (Seq Error),(IO ()),PP_Doc)) data Inh_ExecutionPlan = Inh_ExecutionPlan {importBlocks_Inh_ExecutionPlan :: PP_Doc,inhmap_Inh_ExecutionPlan :: (Map NontermIdent Attributes),localAttrTypes_Inh_ExecutionPlan :: (Map NontermIdent (Map ConstructorIdent (Map Identifier Type))),mainBlocksDoc_Inh_ExecutionPlan :: PP_Doc,mainFile_Inh_ExecutionPlan :: String,mainName_Inh_ExecutionPlan :: String,moduleHeader_Inh_ExecutionPlan :: (String -> String -> String -> Bool -> String),options_Inh_ExecutionPlan :: Options,pragmaBlocks_Inh_ExecutionPlan :: String,synmap_Inh_ExecutionPlan :: (Map NontermIdent Attributes),textBlockMap_Inh_ExecutionPlan :: (Map BlockInfo PP_Doc),textBlocks_Inh_ExecutionPlan :: PP_Doc} data Syn_ExecutionPlan = Syn_ExecutionPlan {errors_Syn_ExecutionPlan :: (Seq Error),genIO_Syn_ExecutionPlan :: (IO ()),output_Syn_ExecutionPlan :: PP_Doc} wrap_ExecutionPlan :: T_ExecutionPlan -> Inh_ExecutionPlan -> Syn_ExecutionPlan wrap_ExecutionPlan (T_ExecutionPlan sem ) (Inh_ExecutionPlan _lhsIimportBlocks _lhsIinhmap _lhsIlocalAttrTypes _lhsImainBlocksDoc _lhsImainFile _lhsImainName _lhsImoduleHeader _lhsIoptions _lhsIpragmaBlocks _lhsIsynmap _lhsItextBlockMap _lhsItextBlocks ) = (let ( _lhsOerrors,_lhsOgenIO,_lhsOoutput) = sem _lhsIimportBlocks _lhsIinhmap _lhsIlocalAttrTypes _lhsImainBlocksDoc _lhsImainFile _lhsImainName _lhsImoduleHeader _lhsIoptions _lhsIpragmaBlocks _lhsIsynmap _lhsItextBlockMap _lhsItextBlocks in (Syn_ExecutionPlan _lhsOerrors _lhsOgenIO _lhsOoutput )) sem_ExecutionPlan_ExecutionPlan :: T_ENonterminals -> TypeSyns -> (Set NontermIdent) -> Derivings -> T_ExecutionPlan sem_ExecutionPlan_ExecutionPlan (T_ENonterminals nonts_ ) typeSyns_ wrappers_ derivings_ = (T_ExecutionPlan (\ _lhsIimportBlocks _lhsIinhmap _lhsIlocalAttrTypes _lhsImainBlocksDoc _lhsImainFile _lhsImainName _lhsImoduleHeader _lhsIoptions _lhsIpragmaBlocks _lhsIsynmap _lhsItextBlockMap _lhsItextBlocks -> (let _lhsOoutput :: PP_Doc _nontsOwrappers :: (Set NontermIdent) _nontsOtypeSyns :: TypeSyns _nontsOderivings :: Derivings _nontsOallchildvisit :: (Map VisitIdentifier (Identifier -> VisitKind -> Either Error (PP_Doc, PP_Doc))) _nontsOavisitdefs :: (Map VisitIdentifier (Set Identifier)) _nontsOavisituses :: (Map VisitIdentifier (Set Identifier)) _lhsOgenIO :: (IO ()) _nontsOallFromToStates :: (Map VisitIdentifier (Int,Int)) _nontsOallVisitKinds :: (Map VisitIdentifier VisitKind) _nontsOallInitStates :: (Map NontermIdent Int) _lhsOerrors :: (Seq Error) _nontsOimportBlocks :: PP_Doc _nontsOinhmap :: (Map NontermIdent Attributes) _nontsOlocalAttrTypes :: (Map NontermIdent (Map ConstructorIdent (Map Identifier Type))) _nontsOmainFile :: String _nontsOmainName :: String _nontsOmoduleHeader :: (String -> String -> String -> Bool -> String) _nontsOoptions :: Options _nontsOpragmaBlocks :: String _nontsOsynmap :: (Map NontermIdent Attributes) _nontsOtextBlocks :: PP_Doc _nontsIappendCommon :: ([PP_Doc]) _nontsIappendMain :: ([PP_Doc]) _nontsIchildvisit :: (Map VisitIdentifier (Identifier -> VisitKind -> Either Error (PP_Doc, PP_Doc))) _nontsIerrors :: (Seq Error) _nontsIfromToStates :: (Map VisitIdentifier (Int,Int)) _nontsIgenProdIO :: (IO ()) _nontsIimports :: ([PP_Doc]) _nontsIinitStates :: (Map NontermIdent Int) _nontsIoutput :: PP_Doc _nontsIsemFunBndDefs :: (Seq PP_Doc) _nontsIsemFunBndTps :: (Seq PP_Doc) _nontsIvisitKinds :: (Map VisitIdentifier VisitKind) _nontsIvisitdefs :: (Map VisitIdentifier (Set Identifier)) _nontsIvisituses :: (Map VisitIdentifier (Set Identifier)) -- "src-ag/ExecutionPlan2Hs.ag"(line 87, column 19) _lhsOoutput = ({-# LINE 87 "src-ag/ExecutionPlan2Hs.ag" #-} _nontsIoutput >-< _commonExtra >-< _wrappersExtra {-# LINE 5225 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 93, column 19) _nontsOwrappers = ({-# LINE 93 "src-ag/ExecutionPlan2Hs.ag" #-} wrappers_ {-# LINE 5231 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 132, column 19) _nontsOtypeSyns = ({-# LINE 132 "src-ag/ExecutionPlan2Hs.ag" #-} typeSyns_ {-# LINE 5237 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 133, column 19) _nontsOderivings = ({-# LINE 133 "src-ag/ExecutionPlan2Hs.ag" #-} derivings_ {-# LINE 5243 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 531, column 3) _wrappersExtra = ({-# LINE 531 "src-ag/ExecutionPlan2Hs.ag" #-} if kennedyWarren _lhsIoptions && lateHigherOrderBinding _lhsIoptions then _lateSemBndDef else empty {-# LINE 5251 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 534, column 3) _commonExtra = ({-# LINE 534 "src-ag/ExecutionPlan2Hs.ag" #-} if kennedyWarren _lhsIoptions && lateHigherOrderBinding _lhsIoptions then _lateSemBndTp else empty {-# LINE 5259 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 537, column 3) _lateSemBndTp = ({-# LINE 537 "src-ag/ExecutionPlan2Hs.ag" #-} "data" >#< lateBindingTypeNm _lhsImainName >#< "=" >#< lateBindingTypeNm _lhsImainName >-< (indent 2 $ pp_block "{" "}" "," $ toList _nontsIsemFunBndTps) {-# LINE 5266 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 539, column 3) _lateSemBndDef = ({-# LINE 539 "src-ag/ExecutionPlan2Hs.ag" #-} ( if noInlinePragmas _lhsIoptions then empty else if helpInlining _lhsIoptions && Set.size wrappers_ == 1 then ppInline $ lateBindingFieldNm _lhsImainName else ppNoInline $ lateBindingFieldNm _lhsImainName ) >-< lateBindingFieldNm _lhsImainName >#< "::" >#< lateBindingTypeNm _lhsImainName >-< lateBindingFieldNm _lhsImainName >#< "=" >#< lateBindingTypeNm _lhsImainName >-< (indent 2 $ pp_block "{" "}" "," $ toList _nontsIsemFunBndDefs ) {-# LINE 5280 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 1172, column 19) _nontsOallchildvisit = ({-# LINE 1172 "src-ag/ExecutionPlan2Hs.ag" #-} _nontsIchildvisit {-# LINE 5286 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 1316, column 19) _nontsOavisitdefs = ({-# LINE 1316 "src-ag/ExecutionPlan2Hs.ag" #-} _nontsIvisitdefs {-# LINE 5292 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 1317, column 19) _nontsOavisituses = ({-# LINE 1317 "src-ag/ExecutionPlan2Hs.ag" #-} _nontsIvisituses {-# LINE 5298 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 1388, column 19) _lhsOgenIO = ({-# LINE 1388 "src-ag/ExecutionPlan2Hs.ag" #-} do _genMainModule _genCommonModule _nontsIgenProdIO {-# LINE 5306 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 1391, column 19) _mainModuleFile = ({-# LINE 1391 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsImainFile {-# LINE 5312 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 1392, column 19) _ppMonadImports = ({-# LINE 1392 "src-ag/ExecutionPlan2Hs.ag" #-} ( if tupleAsDummyToken _lhsIoptions then empty else pp "import GHC.Prim" ) >-< if parallelInvoke _lhsIoptions then pp "import qualified System.IO.Unsafe(unsafePerformIO)" >-< pp "import System.IO(IO)" >-< pp "import Control.Concurrent(newEmptyMVar,forkIO,putMVar,takeMVar)" else pp "import Control.Monad.Identity" {-# LINE 5326 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 1401, column 19) _genMainModule = ({-# LINE 1401 "src-ag/ExecutionPlan2Hs.ag" #-} writeModule _mainModuleFile ( [ warrenFlagsPP _lhsIoptions , pp $ _lhsIpragmaBlocks , pp $ _lhsImoduleHeader _lhsImainName "" "" False , _ppMonadImports , pp $ "import " ++ _lhsImainName ++ "_common" ] ++ _nontsIimports ++ [_lhsImainBlocksDoc] ++ [_wrappersExtra ] ++ _nontsIappendMain ) {-# LINE 5343 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 1413, column 19) _commonFile = ({-# LINE 1413 "src-ag/ExecutionPlan2Hs.ag" #-} replaceBaseName _lhsImainFile (takeBaseName _lhsImainFile ++ "_common") {-# LINE 5349 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 1414, column 19) _genCommonModule = ({-# LINE 1414 "src-ag/ExecutionPlan2Hs.ag" #-} writeModule _commonFile ( [ pp $ "{-# LANGUAGE GADTs #-}" , pp $ _lhsIpragmaBlocks , pp $ _lhsImoduleHeader _lhsImainName "_common" "" True , _ppMonadImports , _lhsIimportBlocks , _lhsItextBlocks , _commonExtra ] ++ _nontsIappendCommon ) {-# LINE 5365 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 1533, column 3) _nontsOallFromToStates = ({-# LINE 1533 "src-ag/ExecutionPlan2Hs.ag" #-} _nontsIfromToStates {-# LINE 5371 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 1577, column 3) _nontsOallVisitKinds = ({-# LINE 1577 "src-ag/ExecutionPlan2Hs.ag" #-} _nontsIvisitKinds {-# LINE 5377 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 1591, column 3) _nontsOallInitStates = ({-# LINE 1591 "src-ag/ExecutionPlan2Hs.ag" #-} _nontsIinitStates {-# LINE 5383 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- use rule "src-ag/ExecutionPlan2Hs.ag"(line 1609, column 132) _lhsOerrors = ({-# LINE 1609 "src-ag/ExecutionPlan2Hs.ag" #-} _nontsIerrors {-# LINE 5389 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _nontsOimportBlocks = ({-# LINE 34 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIimportBlocks {-# LINE 5395 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _nontsOinhmap = ({-# LINE 312 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIinhmap {-# LINE 5401 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _nontsOlocalAttrTypes = ({-# LINE 1556 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIlocalAttrTypes {-# LINE 5407 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _nontsOmainFile = ({-# LINE 38 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsImainFile {-# LINE 5413 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _nontsOmainName = ({-# LINE 39 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsImainName {-# LINE 5419 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _nontsOmoduleHeader = ({-# LINE 37 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsImoduleHeader {-# LINE 5425 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _nontsOoptions = ({-# LINE 51 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIoptions {-# LINE 5431 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _nontsOpragmaBlocks = ({-# LINE 35 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIpragmaBlocks {-# LINE 5437 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _nontsOsynmap = ({-# LINE 313 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIsynmap {-# LINE 5443 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _nontsOtextBlocks = ({-# LINE 36 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsItextBlocks {-# LINE 5449 "src-ag/ExecutionPlan2Hs.hs" #-} ) ( _nontsIappendCommon,_nontsIappendMain,_nontsIchildvisit,_nontsIerrors,_nontsIfromToStates,_nontsIgenProdIO,_nontsIimports,_nontsIinitStates,_nontsIoutput,_nontsIsemFunBndDefs,_nontsIsemFunBndTps,_nontsIvisitKinds,_nontsIvisitdefs,_nontsIvisituses) = nonts_ _nontsOallFromToStates _nontsOallInitStates _nontsOallVisitKinds _nontsOallchildvisit _nontsOavisitdefs _nontsOavisituses _nontsOderivings _nontsOimportBlocks _nontsOinhmap _nontsOlocalAttrTypes _nontsOmainFile _nontsOmainName _nontsOmoduleHeader _nontsOoptions _nontsOpragmaBlocks _nontsOsynmap _nontsOtextBlocks _nontsOtypeSyns _nontsOwrappers in ( _lhsOerrors,_lhsOgenIO,_lhsOoutput))) ) -- Expression -------------------------------------------------- {- visit 0: synthesized attributes: attrs : Map String (Maybe NonLocalAttr) pos : Pos semfunc : PP_Doc alternatives: alternative Expression: child pos : {Pos} child tks : {[HsToken]} -} -- cata sem_Expression :: Expression -> T_Expression sem_Expression (Expression _pos _tks ) = (sem_Expression_Expression _pos _tks ) -- semantic domain newtype T_Expression = T_Expression (( (Map String (Maybe NonLocalAttr)),Pos,PP_Doc)) data Inh_Expression = Inh_Expression {} data Syn_Expression = Syn_Expression {attrs_Syn_Expression :: (Map String (Maybe NonLocalAttr)),pos_Syn_Expression :: Pos,semfunc_Syn_Expression :: PP_Doc} wrap_Expression :: T_Expression -> Inh_Expression -> Syn_Expression wrap_Expression (T_Expression sem ) (Inh_Expression ) = (let ( _lhsOattrs,_lhsOpos,_lhsOsemfunc) = sem in (Syn_Expression _lhsOattrs _lhsOpos _lhsOsemfunc )) sem_Expression_Expression :: Pos -> ([HsToken]) -> T_Expression sem_Expression_Expression pos_ tks_ = (T_Expression (let _lhsOpos :: Pos _lhsOattrs :: (Map String (Maybe NonLocalAttr)) _lhsOsemfunc :: PP_Doc -- "src-ag/ExecutionPlan2Hs.ag"(line 1082, column 29) _lhsOpos = ({-# LINE 1082 "src-ag/ExecutionPlan2Hs.ag" #-} pos_ {-# LINE 5492 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 1157, column 16) _lhsOattrs = ({-# LINE 1157 "src-ag/ExecutionPlan2Hs.ag" #-} Map.unions $ map (\tok -> attrs_Syn_HsToken (wrap_HsToken (sem_HsToken tok) Inh_HsToken)) tks_ {-# LINE 5498 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 1158, column 16) _lhsOsemfunc = ({-# LINE 1158 "src-ag/ExecutionPlan2Hs.ag" #-} vlist $ showTokens $ map (\tok -> tok_Syn_HsToken (wrap_HsToken (sem_HsToken tok) Inh_HsToken)) tks_ {-# LINE 5504 "src-ag/ExecutionPlan2Hs.hs" #-} ) in ( _lhsOattrs,_lhsOpos,_lhsOsemfunc)) ) -- HsToken ----------------------------------------------------- {- visit 0: synthesized attributes: attrs : Map String (Maybe NonLocalAttr) tok : (Pos,String) alternatives: alternative AGField: child field : {Identifier} child attr : {Identifier} child pos : {Pos} child rdesc : {Maybe String} visit 0: local mbAttr : _ local addTrace : _ alternative AGLocal: child var : {Identifier} child pos : {Pos} child rdesc : {Maybe String} visit 0: local tok : _ alternative CharToken: child value : {String} child pos : {Pos} alternative Err: child mesg : {String} child pos : {Pos} alternative HsToken: child value : {String} child pos : {Pos} alternative StrToken: child value : {String} child pos : {Pos} -} -- cata sem_HsToken :: HsToken -> T_HsToken sem_HsToken (AGField _field _attr _pos _rdesc ) = (sem_HsToken_AGField _field _attr _pos _rdesc ) sem_HsToken (AGLocal _var _pos _rdesc ) = (sem_HsToken_AGLocal _var _pos _rdesc ) sem_HsToken (CharToken _value _pos ) = (sem_HsToken_CharToken _value _pos ) sem_HsToken (Err _mesg _pos ) = (sem_HsToken_Err _mesg _pos ) sem_HsToken (HsToken _value _pos ) = (sem_HsToken_HsToken _value _pos ) sem_HsToken (StrToken _value _pos ) = (sem_HsToken_StrToken _value _pos ) -- semantic domain newtype T_HsToken = T_HsToken (( (Map String (Maybe NonLocalAttr)),((Pos,String)))) data Inh_HsToken = Inh_HsToken {} data Syn_HsToken = Syn_HsToken {attrs_Syn_HsToken :: (Map String (Maybe NonLocalAttr)),tok_Syn_HsToken :: ((Pos,String))} wrap_HsToken :: T_HsToken -> Inh_HsToken -> Syn_HsToken wrap_HsToken (T_HsToken sem ) (Inh_HsToken ) = (let ( _lhsOattrs,_lhsOtok) = sem in (Syn_HsToken _lhsOattrs _lhsOtok )) sem_HsToken_AGField :: Identifier -> Identifier -> Pos -> (Maybe String) -> T_HsToken sem_HsToken_AGField field_ attr_ pos_ rdesc_ = (T_HsToken (let _lhsOattrs :: (Map String (Maybe NonLocalAttr)) _lhsOtok :: ((Pos,String)) -- "src-ag/ExecutionPlan2Hs.ag"(line 1117, column 15) _mbAttr = ({-# LINE 1117 "src-ag/ExecutionPlan2Hs.ag" #-} if field_ == _INST || field_ == _FIELD || field_ == _INST' then Nothing else Just $ mkNonLocalAttr (field_ == _LHS) field_ attr_ {-# LINE 5580 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 1120, column 15) _lhsOattrs = ({-# LINE 1120 "src-ag/ExecutionPlan2Hs.ag" #-} Map.singleton (attrname True field_ attr_) _mbAttr {-# LINE 5586 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 1365, column 8) _addTrace = ({-# LINE 1365 "src-ag/ExecutionPlan2Hs.ag" #-} case rdesc_ of Just d -> \x -> "(trace " ++ show (d ++ " -> " ++ show field_ ++ "." ++ show attr_) ++ " (" ++ x ++ "))" Nothing -> id {-# LINE 5594 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 1368, column 8) _lhsOtok = ({-# LINE 1368 "src-ag/ExecutionPlan2Hs.ag" #-} (pos_, _addTrace $ attrname True field_ attr_) {-# LINE 5600 "src-ag/ExecutionPlan2Hs.hs" #-} ) in ( _lhsOattrs,_lhsOtok)) ) sem_HsToken_AGLocal :: Identifier -> Pos -> (Maybe String) -> T_HsToken sem_HsToken_AGLocal var_ pos_ rdesc_ = (T_HsToken (let _lhsOattrs :: (Map String (Maybe NonLocalAttr)) _lhsOtok :: ((Pos,String)) -- "src-ag/ExecutionPlan2Hs.ag"(line 1116, column 15) _lhsOattrs = ({-# LINE 1116 "src-ag/ExecutionPlan2Hs.ag" #-} Map.singleton (locname var_) Nothing {-# LINE 5614 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 1361, column 15) _tok = ({-# LINE 1361 "src-ag/ExecutionPlan2Hs.ag" #-} (pos_,locname var_) {-# LINE 5620 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (from local) _lhsOtok = ({-# LINE 1363 "src-ag/ExecutionPlan2Hs.ag" #-} _tok {-# LINE 5626 "src-ag/ExecutionPlan2Hs.hs" #-} ) in ( _lhsOattrs,_lhsOtok)) ) sem_HsToken_CharToken :: String -> Pos -> T_HsToken sem_HsToken_CharToken value_ pos_ = (T_HsToken (let _lhsOtok :: ((Pos,String)) _lhsOattrs :: (Map String (Maybe NonLocalAttr)) -- "src-ag/ExecutionPlan2Hs.ag"(line 1372, column 16) _lhsOtok = ({-# LINE 1372 "src-ag/ExecutionPlan2Hs.ag" #-} (pos_, if null value_ then "" else showCharShort (head value_) ) {-# LINE 5642 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- use rule "src-ag/ExecutionPlan2Hs.ag"(line 1114, column 37) _lhsOattrs = ({-# LINE 1114 "src-ag/ExecutionPlan2Hs.ag" #-} Map.empty {-# LINE 5648 "src-ag/ExecutionPlan2Hs.hs" #-} ) in ( _lhsOattrs,_lhsOtok)) ) sem_HsToken_Err :: String -> Pos -> T_HsToken sem_HsToken_Err mesg_ pos_ = (T_HsToken (let _lhsOtok :: ((Pos,String)) _lhsOattrs :: (Map String (Maybe NonLocalAttr)) -- "src-ag/ExecutionPlan2Hs.ag"(line 1378, column 16) _lhsOtok = ({-# LINE 1378 "src-ag/ExecutionPlan2Hs.ag" #-} (pos_, "") {-# LINE 5661 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- use rule "src-ag/ExecutionPlan2Hs.ag"(line 1114, column 37) _lhsOattrs = ({-# LINE 1114 "src-ag/ExecutionPlan2Hs.ag" #-} Map.empty {-# LINE 5667 "src-ag/ExecutionPlan2Hs.hs" #-} ) in ( _lhsOattrs,_lhsOtok)) ) sem_HsToken_HsToken :: String -> Pos -> T_HsToken sem_HsToken_HsToken value_ pos_ = (T_HsToken (let _lhsOtok :: ((Pos,String)) _lhsOattrs :: (Map String (Maybe NonLocalAttr)) -- "src-ag/ExecutionPlan2Hs.ag"(line 1370, column 14) _lhsOtok = ({-# LINE 1370 "src-ag/ExecutionPlan2Hs.ag" #-} (pos_, value_) {-# LINE 5680 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- use rule "src-ag/ExecutionPlan2Hs.ag"(line 1114, column 37) _lhsOattrs = ({-# LINE 1114 "src-ag/ExecutionPlan2Hs.ag" #-} Map.empty {-# LINE 5686 "src-ag/ExecutionPlan2Hs.hs" #-} ) in ( _lhsOattrs,_lhsOtok)) ) sem_HsToken_StrToken :: String -> Pos -> T_HsToken sem_HsToken_StrToken value_ pos_ = (T_HsToken (let _lhsOtok :: ((Pos,String)) _lhsOattrs :: (Map String (Maybe NonLocalAttr)) -- "src-ag/ExecutionPlan2Hs.ag"(line 1377, column 16) _lhsOtok = ({-# LINE 1377 "src-ag/ExecutionPlan2Hs.ag" #-} (pos_, showStrShort value_) {-# LINE 5699 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- use rule "src-ag/ExecutionPlan2Hs.ag"(line 1114, column 37) _lhsOattrs = ({-# LINE 1114 "src-ag/ExecutionPlan2Hs.ag" #-} Map.empty {-# LINE 5705 "src-ag/ExecutionPlan2Hs.hs" #-} ) in ( _lhsOattrs,_lhsOtok)) ) -- HsTokens ---------------------------------------------------- {- visit 0: synthesized attribute: tks : [(Pos,String)] alternatives: alternative Cons: child hd : HsToken child tl : HsTokens alternative Nil: -} -- cata sem_HsTokens :: HsTokens -> T_HsTokens sem_HsTokens list = (Prelude.foldr sem_HsTokens_Cons sem_HsTokens_Nil (Prelude.map sem_HsToken list) ) -- semantic domain newtype T_HsTokens = T_HsTokens (( ([(Pos,String)]))) data Inh_HsTokens = Inh_HsTokens {} data Syn_HsTokens = Syn_HsTokens {tks_Syn_HsTokens :: ([(Pos,String)])} wrap_HsTokens :: T_HsTokens -> Inh_HsTokens -> Syn_HsTokens wrap_HsTokens (T_HsTokens sem ) (Inh_HsTokens ) = (let ( _lhsOtks) = sem in (Syn_HsTokens _lhsOtks )) sem_HsTokens_Cons :: T_HsToken -> T_HsTokens -> T_HsTokens sem_HsTokens_Cons (T_HsToken hd_ ) (T_HsTokens tl_ ) = (T_HsTokens (let _lhsOtks :: ([(Pos,String)]) _hdIattrs :: (Map String (Maybe NonLocalAttr)) _hdItok :: ((Pos,String)) _tlItks :: ([(Pos,String)]) -- "src-ag/ExecutionPlan2Hs.ag"(line 1357, column 10) _lhsOtks = ({-# LINE 1357 "src-ag/ExecutionPlan2Hs.ag" #-} _hdItok : _tlItks {-# LINE 5746 "src-ag/ExecutionPlan2Hs.hs" #-} ) ( _hdIattrs,_hdItok) = hd_ ( _tlItks) = tl_ in ( _lhsOtks)) ) sem_HsTokens_Nil :: T_HsTokens sem_HsTokens_Nil = (T_HsTokens (let _lhsOtks :: ([(Pos,String)]) -- "src-ag/ExecutionPlan2Hs.ag"(line 1358, column 10) _lhsOtks = ({-# LINE 1358 "src-ag/ExecutionPlan2Hs.ag" #-} [] {-# LINE 5760 "src-ag/ExecutionPlan2Hs.hs" #-} ) in ( _lhsOtks)) ) -- HsTokensRoot ------------------------------------------------ {- alternatives: alternative HsTokensRoot: child tokens : HsTokens -} -- cata sem_HsTokensRoot :: HsTokensRoot -> T_HsTokensRoot sem_HsTokensRoot (HsTokensRoot _tokens ) = (sem_HsTokensRoot_HsTokensRoot (sem_HsTokens _tokens ) ) -- semantic domain newtype T_HsTokensRoot = T_HsTokensRoot (( )) data Inh_HsTokensRoot = Inh_HsTokensRoot {} data Syn_HsTokensRoot = Syn_HsTokensRoot {} wrap_HsTokensRoot :: T_HsTokensRoot -> Inh_HsTokensRoot -> Syn_HsTokensRoot wrap_HsTokensRoot (T_HsTokensRoot sem ) (Inh_HsTokensRoot ) = (let ( ) = sem in (Syn_HsTokensRoot )) sem_HsTokensRoot_HsTokensRoot :: T_HsTokens -> T_HsTokensRoot sem_HsTokensRoot_HsTokensRoot (T_HsTokens tokens_ ) = (T_HsTokensRoot (let _tokensItks :: ([(Pos,String)]) ( _tokensItks) = tokens_ in ( )) ) -- Pattern ----------------------------------------------------- {- visit 0: inherited attributes: anyLazyKind : Bool options : Options synthesized attributes: attrs : Set String copy : SELF isUnderscore : Bool sem_lhs : PP_Doc alternatives: alternative Alias: child field : {Identifier} child attr : {Identifier} child pat : Pattern visit 0: local varPat : _ local patExpr : _ local addbang : _ local addbang1 : _ local copy : _ alternative Constr: child name : {ConstructorIdent} child pats : Patterns visit 0: local addbang : _ local addbang1 : _ local copy : _ alternative Irrefutable: child pat : Pattern visit 0: local copy : _ alternative Product: child pos : {Pos} child pats : Patterns visit 0: local addbang : _ local addbang1 : _ local copy : _ alternative Underscore: child pos : {Pos} visit 0: local copy : _ -} -- cata sem_Pattern :: Pattern -> T_Pattern sem_Pattern (Alias _field _attr _pat ) = (sem_Pattern_Alias _field _attr (sem_Pattern _pat ) ) 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 (Bool -> Options -> ( (Set String),Pattern ,Bool,( PP_Doc ))) data Inh_Pattern = Inh_Pattern {anyLazyKind_Inh_Pattern :: Bool,options_Inh_Pattern :: Options} data Syn_Pattern = Syn_Pattern {attrs_Syn_Pattern :: (Set String),copy_Syn_Pattern :: Pattern ,isUnderscore_Syn_Pattern :: Bool,sem_lhs_Syn_Pattern :: ( PP_Doc )} wrap_Pattern :: T_Pattern -> Inh_Pattern -> Syn_Pattern wrap_Pattern (T_Pattern sem ) (Inh_Pattern _lhsIanyLazyKind _lhsIoptions ) = (let ( _lhsOattrs,_lhsOcopy,_lhsOisUnderscore,_lhsOsem_lhs) = sem _lhsIanyLazyKind _lhsIoptions in (Syn_Pattern _lhsOattrs _lhsOcopy _lhsOisUnderscore _lhsOsem_lhs )) sem_Pattern_Alias :: Identifier -> Identifier -> T_Pattern -> T_Pattern sem_Pattern_Alias field_ attr_ (T_Pattern pat_ ) = (T_Pattern (\ _lhsIanyLazyKind _lhsIoptions -> (let _lhsOsem_lhs :: ( PP_Doc ) _lhsOisUnderscore :: Bool _lhsOattrs :: (Set String) _lhsOcopy :: Pattern _patOanyLazyKind :: Bool _patOoptions :: Options _patIattrs :: (Set String) _patIcopy :: Pattern _patIisUnderscore :: Bool _patIsem_lhs :: ( PP_Doc ) -- "src-ag/ExecutionPlan2Hs.ag"(line 1090, column 17) _varPat = ({-# LINE 1090 "src-ag/ExecutionPlan2Hs.ag" #-} text $ attrname False field_ attr_ {-# LINE 5882 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 1091, column 17) _patExpr = ({-# LINE 1091 "src-ag/ExecutionPlan2Hs.ag" #-} if _patIisUnderscore then _varPat else _varPat >|< "@" >|< _patIsem_lhs {-# LINE 5890 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 1094, column 17) _lhsOsem_lhs = ({-# LINE 1094 "src-ag/ExecutionPlan2Hs.ag" #-} _addbang1 _patExpr {-# LINE 5896 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 1105, column 16) _lhsOisUnderscore = ({-# LINE 1105 "src-ag/ExecutionPlan2Hs.ag" #-} False {-# LINE 5902 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 1111, column 3) _lhsOattrs = ({-# LINE 1111 "src-ag/ExecutionPlan2Hs.ag" #-} Set.insert (attrname False field_ attr_) _patIattrs {-# LINE 5908 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 1501, column 37) _addbang = ({-# LINE 1501 "src-ag/ExecutionPlan2Hs.ag" #-} \x -> if bangpats _lhsIoptions then "!" >|< x else x {-# LINE 5914 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 1506, column 37) _addbang1 = ({-# LINE 1506 "src-ag/ExecutionPlan2Hs.ag" #-} if _lhsIanyLazyKind then id else _addbang {-# LINE 5920 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- self rule _copy = ({-# LINE 22 "src-ag/Patterns.ag" #-} Alias field_ attr_ _patIcopy {-# LINE 5926 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- self rule _lhsOcopy = ({-# LINE 22 "src-ag/Patterns.ag" #-} _copy {-# LINE 5932 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _patOanyLazyKind = ({-# LINE 1247 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIanyLazyKind {-# LINE 5938 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _patOoptions = ({-# LINE 51 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIoptions {-# LINE 5944 "src-ag/ExecutionPlan2Hs.hs" #-} ) ( _patIattrs,_patIcopy,_patIisUnderscore,_patIsem_lhs) = pat_ _patOanyLazyKind _patOoptions in ( _lhsOattrs,_lhsOcopy,_lhsOisUnderscore,_lhsOsem_lhs))) ) sem_Pattern_Constr :: ConstructorIdent -> T_Patterns -> T_Pattern sem_Pattern_Constr name_ (T_Patterns pats_ ) = (T_Pattern (\ _lhsIanyLazyKind _lhsIoptions -> (let _lhsOsem_lhs :: ( PP_Doc ) _lhsOisUnderscore :: Bool _lhsOattrs :: (Set String) _lhsOcopy :: Pattern _patsOanyLazyKind :: Bool _patsOoptions :: Options _patsIattrs :: (Set String) _patsIcopy :: Patterns _patsIsem_lhs :: ([PP_Doc]) -- "src-ag/ExecutionPlan2Hs.ag"(line 1096, column 17) _lhsOsem_lhs = ({-# LINE 1096 "src-ag/ExecutionPlan2Hs.ag" #-} _addbang1 $ pp_parens $ name_ >#< hv_sp _patsIsem_lhs {-# LINE 5968 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 1103, column 16) _lhsOisUnderscore = ({-# LINE 1103 "src-ag/ExecutionPlan2Hs.ag" #-} False {-# LINE 5974 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 1501, column 37) _addbang = ({-# LINE 1501 "src-ag/ExecutionPlan2Hs.ag" #-} \x -> if bangpats _lhsIoptions then "!" >|< x else x {-# LINE 5980 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 1506, column 37) _addbang1 = ({-# LINE 1506 "src-ag/ExecutionPlan2Hs.ag" #-} if _lhsIanyLazyKind then id else _addbang {-# LINE 5986 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- use rule "src-ag/ExecutionPlan2Hs.ag"(line 1109, column 36) _lhsOattrs = ({-# LINE 1109 "src-ag/ExecutionPlan2Hs.ag" #-} _patsIattrs {-# LINE 5992 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- self rule _copy = ({-# LINE 22 "src-ag/Patterns.ag" #-} Constr name_ _patsIcopy {-# LINE 5998 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- self rule _lhsOcopy = ({-# LINE 22 "src-ag/Patterns.ag" #-} _copy {-# LINE 6004 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _patsOanyLazyKind = ({-# LINE 1247 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIanyLazyKind {-# LINE 6010 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _patsOoptions = ({-# LINE 51 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIoptions {-# LINE 6016 "src-ag/ExecutionPlan2Hs.hs" #-} ) ( _patsIattrs,_patsIcopy,_patsIsem_lhs) = pats_ _patsOanyLazyKind _patsOoptions in ( _lhsOattrs,_lhsOcopy,_lhsOisUnderscore,_lhsOsem_lhs))) ) sem_Pattern_Irrefutable :: T_Pattern -> T_Pattern sem_Pattern_Irrefutable (T_Pattern pat_ ) = (T_Pattern (\ _lhsIanyLazyKind _lhsIoptions -> (let _lhsOsem_lhs :: ( PP_Doc ) _lhsOattrs :: (Set String) _lhsOcopy :: Pattern _lhsOisUnderscore :: Bool _patOanyLazyKind :: Bool _patOoptions :: Options _patIattrs :: (Set String) _patIcopy :: Pattern _patIisUnderscore :: Bool _patIsem_lhs :: ( PP_Doc ) -- "src-ag/ExecutionPlan2Hs.ag"(line 1098, column 17) _lhsOsem_lhs = ({-# LINE 1098 "src-ag/ExecutionPlan2Hs.ag" #-} text "~" >|< pp_parens _patIsem_lhs {-# LINE 6040 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- use rule "src-ag/ExecutionPlan2Hs.ag"(line 1109, column 36) _lhsOattrs = ({-# LINE 1109 "src-ag/ExecutionPlan2Hs.ag" #-} _patIattrs {-# LINE 6046 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- self rule _copy = ({-# LINE 22 "src-ag/Patterns.ag" #-} Irrefutable _patIcopy {-# LINE 6052 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- self rule _lhsOcopy = ({-# LINE 22 "src-ag/Patterns.ag" #-} _copy {-# LINE 6058 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (up) _lhsOisUnderscore = ({-# LINE 1101 "src-ag/ExecutionPlan2Hs.ag" #-} _patIisUnderscore {-# LINE 6064 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _patOanyLazyKind = ({-# LINE 1247 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIanyLazyKind {-# LINE 6070 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _patOoptions = ({-# LINE 51 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIoptions {-# LINE 6076 "src-ag/ExecutionPlan2Hs.hs" #-} ) ( _patIattrs,_patIcopy,_patIisUnderscore,_patIsem_lhs) = pat_ _patOanyLazyKind _patOoptions in ( _lhsOattrs,_lhsOcopy,_lhsOisUnderscore,_lhsOsem_lhs))) ) sem_Pattern_Product :: Pos -> T_Patterns -> T_Pattern sem_Pattern_Product pos_ (T_Patterns pats_ ) = (T_Pattern (\ _lhsIanyLazyKind _lhsIoptions -> (let _lhsOsem_lhs :: ( PP_Doc ) _lhsOisUnderscore :: Bool _lhsOattrs :: (Set String) _lhsOcopy :: Pattern _patsOanyLazyKind :: Bool _patsOoptions :: Options _patsIattrs :: (Set String) _patsIcopy :: Patterns _patsIsem_lhs :: ([PP_Doc]) -- "src-ag/ExecutionPlan2Hs.ag"(line 1095, column 17) _lhsOsem_lhs = ({-# LINE 1095 "src-ag/ExecutionPlan2Hs.ag" #-} _addbang1 $ pp_block "(" ")" "," _patsIsem_lhs {-# LINE 6100 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 1104, column 16) _lhsOisUnderscore = ({-# LINE 1104 "src-ag/ExecutionPlan2Hs.ag" #-} False {-# LINE 6106 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 1501, column 37) _addbang = ({-# LINE 1501 "src-ag/ExecutionPlan2Hs.ag" #-} \x -> if bangpats _lhsIoptions then "!" >|< x else x {-# LINE 6112 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 1506, column 37) _addbang1 = ({-# LINE 1506 "src-ag/ExecutionPlan2Hs.ag" #-} if _lhsIanyLazyKind then id else _addbang {-# LINE 6118 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- use rule "src-ag/ExecutionPlan2Hs.ag"(line 1109, column 36) _lhsOattrs = ({-# LINE 1109 "src-ag/ExecutionPlan2Hs.ag" #-} _patsIattrs {-# LINE 6124 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- self rule _copy = ({-# LINE 22 "src-ag/Patterns.ag" #-} Product pos_ _patsIcopy {-# LINE 6130 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- self rule _lhsOcopy = ({-# LINE 22 "src-ag/Patterns.ag" #-} _copy {-# LINE 6136 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _patsOanyLazyKind = ({-# LINE 1247 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIanyLazyKind {-# LINE 6142 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _patsOoptions = ({-# LINE 51 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIoptions {-# LINE 6148 "src-ag/ExecutionPlan2Hs.hs" #-} ) ( _patsIattrs,_patsIcopy,_patsIsem_lhs) = pats_ _patsOanyLazyKind _patsOoptions in ( _lhsOattrs,_lhsOcopy,_lhsOisUnderscore,_lhsOsem_lhs))) ) sem_Pattern_Underscore :: Pos -> T_Pattern sem_Pattern_Underscore pos_ = (T_Pattern (\ _lhsIanyLazyKind _lhsIoptions -> (let _lhsOsem_lhs :: ( PP_Doc ) _lhsOisUnderscore :: Bool _lhsOattrs :: (Set String) _lhsOcopy :: Pattern -- "src-ag/ExecutionPlan2Hs.ag"(line 1097, column 17) _lhsOsem_lhs = ({-# LINE 1097 "src-ag/ExecutionPlan2Hs.ag" #-} text "_" {-# LINE 6166 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 1106, column 16) _lhsOisUnderscore = ({-# LINE 1106 "src-ag/ExecutionPlan2Hs.ag" #-} True {-# LINE 6172 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- use rule "src-ag/ExecutionPlan2Hs.ag"(line 1109, column 36) _lhsOattrs = ({-# LINE 1109 "src-ag/ExecutionPlan2Hs.ag" #-} Set.empty {-# LINE 6178 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- self rule _copy = ({-# LINE 22 "src-ag/Patterns.ag" #-} Underscore pos_ {-# LINE 6184 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- self rule _lhsOcopy = ({-# LINE 22 "src-ag/Patterns.ag" #-} _copy {-# LINE 6190 "src-ag/ExecutionPlan2Hs.hs" #-} ) in ( _lhsOattrs,_lhsOcopy,_lhsOisUnderscore,_lhsOsem_lhs))) ) -- Patterns ---------------------------------------------------- {- visit 0: inherited attributes: anyLazyKind : Bool options : Options synthesized attributes: attrs : Set String copy : SELF sem_lhs : [PP_Doc] 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 (Bool -> Options -> ( (Set String),Patterns ,([PP_Doc]))) data Inh_Patterns = Inh_Patterns {anyLazyKind_Inh_Patterns :: Bool,options_Inh_Patterns :: Options} data Syn_Patterns = Syn_Patterns {attrs_Syn_Patterns :: (Set String),copy_Syn_Patterns :: Patterns ,sem_lhs_Syn_Patterns :: ([PP_Doc])} wrap_Patterns :: T_Patterns -> Inh_Patterns -> Syn_Patterns wrap_Patterns (T_Patterns sem ) (Inh_Patterns _lhsIanyLazyKind _lhsIoptions ) = (let ( _lhsOattrs,_lhsOcopy,_lhsOsem_lhs) = sem _lhsIanyLazyKind _lhsIoptions in (Syn_Patterns _lhsOattrs _lhsOcopy _lhsOsem_lhs )) sem_Patterns_Cons :: T_Pattern -> T_Patterns -> T_Patterns sem_Patterns_Cons (T_Pattern hd_ ) (T_Patterns tl_ ) = (T_Patterns (\ _lhsIanyLazyKind _lhsIoptions -> (let _lhsOattrs :: (Set String) _lhsOsem_lhs :: ([PP_Doc]) _lhsOcopy :: Patterns _hdOanyLazyKind :: Bool _hdOoptions :: Options _tlOanyLazyKind :: Bool _tlOoptions :: Options _hdIattrs :: (Set String) _hdIcopy :: Pattern _hdIisUnderscore :: Bool _hdIsem_lhs :: ( PP_Doc ) _tlIattrs :: (Set String) _tlIcopy :: Patterns _tlIsem_lhs :: ([PP_Doc]) -- use rule "src-ag/ExecutionPlan2Hs.ag"(line 1109, column 36) _lhsOattrs = ({-# LINE 1109 "src-ag/ExecutionPlan2Hs.ag" #-} _hdIattrs `Set.union` _tlIattrs {-# LINE 6254 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- use rule "src-ag/ExecutionPlan2Hs.ag"(line 1086, column 29) _lhsOsem_lhs = ({-# LINE 1086 "src-ag/ExecutionPlan2Hs.ag" #-} _hdIsem_lhs : _tlIsem_lhs {-# LINE 6260 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- self rule _copy = ({-# LINE 22 "src-ag/Patterns.ag" #-} (:) _hdIcopy _tlIcopy {-# LINE 6266 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- self rule _lhsOcopy = ({-# LINE 22 "src-ag/Patterns.ag" #-} _copy {-# LINE 6272 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _hdOanyLazyKind = ({-# LINE 1247 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIanyLazyKind {-# LINE 6278 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _hdOoptions = ({-# LINE 51 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIoptions {-# LINE 6284 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _tlOanyLazyKind = ({-# LINE 1247 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIanyLazyKind {-# LINE 6290 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _tlOoptions = ({-# LINE 51 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIoptions {-# LINE 6296 "src-ag/ExecutionPlan2Hs.hs" #-} ) ( _hdIattrs,_hdIcopy,_hdIisUnderscore,_hdIsem_lhs) = hd_ _hdOanyLazyKind _hdOoptions ( _tlIattrs,_tlIcopy,_tlIsem_lhs) = tl_ _tlOanyLazyKind _tlOoptions in ( _lhsOattrs,_lhsOcopy,_lhsOsem_lhs))) ) sem_Patterns_Nil :: T_Patterns sem_Patterns_Nil = (T_Patterns (\ _lhsIanyLazyKind _lhsIoptions -> (let _lhsOattrs :: (Set String) _lhsOsem_lhs :: ([PP_Doc]) _lhsOcopy :: Patterns -- use rule "src-ag/ExecutionPlan2Hs.ag"(line 1109, column 36) _lhsOattrs = ({-# LINE 1109 "src-ag/ExecutionPlan2Hs.ag" #-} Set.empty {-# LINE 6314 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- use rule "src-ag/ExecutionPlan2Hs.ag"(line 1086, column 29) _lhsOsem_lhs = ({-# LINE 1086 "src-ag/ExecutionPlan2Hs.ag" #-} [] {-# LINE 6320 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- self rule _copy = ({-# LINE 22 "src-ag/Patterns.ag" #-} [] {-# LINE 6326 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- self rule _lhsOcopy = ({-# LINE 22 "src-ag/Patterns.ag" #-} _copy {-# LINE 6332 "src-ag/ExecutionPlan2Hs.hs" #-} ) in ( _lhsOattrs,_lhsOcopy,_lhsOsem_lhs))) ) -- Visit ------------------------------------------------------- {- visit 0: inherited attributes: allFromToStates : Map VisitIdentifier (Int,Int) allInhmap : Map NontermIdent Attributes allInitStates : Map NontermIdent Int allSynmap : Map NontermIdent Attributes allVisitKinds : Map VisitIdentifier VisitKind allchildvisit : Map VisitIdentifier (Identifier -> VisitKind -> Either Error (PP_Doc, PP_Doc)) allintramap : Map StateIdentifier (Map String (Maybe NonLocalAttr)) avisitdefs : Map VisitIdentifier (Set Identifier) avisituses : Map VisitIdentifier (Set Identifier) childTypes : Map Identifier Type childintros : Map Identifier (VisitKind -> FormatMode -> Either Error (PP_Doc, Set String, Map String (Maybe NonLocalAttr))) con : ConstructorIdent inhmap : Attributes mrules : Map Identifier (VisitKind -> FormatMode -> Either Error PP_Doc) nextVisits : Map StateIdentifier StateCtx nt : NontermIdent options : Options params : [Identifier] prevVisits : Map StateIdentifier StateCtx ruledefs : Map Identifier (Set String) ruleuses : Map Identifier (Map String (Maybe NonLocalAttr)) synmap : Attributes terminaldefs : Set String synthesized attributes: allvisits : VisitStateState childvisit : Map VisitIdentifier (Identifier -> VisitKind -> Either Error (PP_Doc, PP_Doc)) errors : Seq Error fromToStates : Map VisitIdentifier (Int,Int) intramap : Map StateIdentifier (Map String (Maybe NonLocalAttr)) lazyIntras : Set String ruleKinds : Map Identifier (Set VisitKind) ruleUsage : Map Identifier Int sem_visit : (StateIdentifier,Bool -> PP_Doc) t_visits : PP_Doc visitKinds : Map VisitIdentifier VisitKind visitdefs : Map VisitIdentifier (Set Identifier) visituses : Map VisitIdentifier (Set Identifier) alternatives: alternative Visit: child ident : {VisitIdentifier} child from : {StateIdentifier} child to : {StateIdentifier} child inh : {Set Identifier} child syn : {Set Identifier} child steps : VisitSteps child kind : {VisitKind} visit 0: local nameT_visit : _ local nameTIn_visit : _ local nameTOut_visit : _ local nameTNext_visit : _ local nextVisitInfo : _ local typecon : _ local t_params : _ local inhpart : _ local synpart : _ local ppTypeList : _ local stepsInitial : _ local stepsClosing : _ local vname : _ local inhpats : _ local inhargs : _ local synargs : _ local nextargsMp : _ local nextargs : _ local nextst : _ local resultval : _ local _tup1 : _ local nextStBuild : _ local nextStRef : _ local prevVisitInfo : _ local invokecode : _ local thisintra : _ local nextintra : _ local uses : _ local inhVarNms : _ local defs : _ local defsAsMap : _ local lazyIntrasInh : _ local addbang : _ local addbang1 : _ -} -- cata sem_Visit :: Visit -> T_Visit sem_Visit (Visit _ident _from _to _inh _syn _steps _kind ) = (sem_Visit_Visit _ident _from _to _inh _syn (sem_VisitSteps _steps ) _kind ) -- semantic domain newtype T_Visit = T_Visit ((Map VisitIdentifier (Int,Int)) -> (Map NontermIdent Attributes) -> (Map NontermIdent Int) -> (Map NontermIdent Attributes) -> (Map VisitIdentifier VisitKind) -> (Map VisitIdentifier (Identifier -> VisitKind -> Either Error (PP_Doc, PP_Doc))) -> (Map StateIdentifier (Map String (Maybe NonLocalAttr))) -> (Map VisitIdentifier (Set Identifier)) -> (Map VisitIdentifier (Set Identifier)) -> (Map Identifier Type) -> (Map Identifier (VisitKind -> FormatMode -> Either Error (PP_Doc, Set String, Map String (Maybe NonLocalAttr)))) -> ConstructorIdent -> Attributes -> (Map Identifier (VisitKind -> FormatMode -> Either Error PP_Doc)) -> (Map StateIdentifier StateCtx) -> NontermIdent -> Options -> ([Identifier]) -> (Map StateIdentifier StateCtx) -> (Map Identifier (Set String)) -> (Map Identifier (Map String (Maybe NonLocalAttr))) -> Attributes -> (Set String) -> ( ( VisitStateState ),(Map VisitIdentifier (Identifier -> VisitKind -> Either Error (PP_Doc, PP_Doc))),(Seq Error),(Map VisitIdentifier (Int,Int)),(Map StateIdentifier (Map String (Maybe NonLocalAttr))),(Set String),(Map Identifier (Set VisitKind)),(Map Identifier Int),( (StateIdentifier,Bool -> PP_Doc) ),PP_Doc,(Map VisitIdentifier VisitKind),(Map VisitIdentifier (Set Identifier)),(Map VisitIdentifier (Set Identifier)))) data Inh_Visit = Inh_Visit {allFromToStates_Inh_Visit :: (Map VisitIdentifier (Int,Int)),allInhmap_Inh_Visit :: (Map NontermIdent Attributes),allInitStates_Inh_Visit :: (Map NontermIdent Int),allSynmap_Inh_Visit :: (Map NontermIdent Attributes),allVisitKinds_Inh_Visit :: (Map VisitIdentifier VisitKind),allchildvisit_Inh_Visit :: (Map VisitIdentifier (Identifier -> VisitKind -> Either Error (PP_Doc, PP_Doc))),allintramap_Inh_Visit :: (Map StateIdentifier (Map String (Maybe NonLocalAttr))),avisitdefs_Inh_Visit :: (Map VisitIdentifier (Set Identifier)),avisituses_Inh_Visit :: (Map VisitIdentifier (Set Identifier)),childTypes_Inh_Visit :: (Map Identifier Type),childintros_Inh_Visit :: (Map Identifier (VisitKind -> FormatMode -> Either Error (PP_Doc, Set String, Map String (Maybe NonLocalAttr)))),con_Inh_Visit :: ConstructorIdent,inhmap_Inh_Visit :: Attributes,mrules_Inh_Visit :: (Map Identifier (VisitKind -> FormatMode -> Either Error PP_Doc)),nextVisits_Inh_Visit :: (Map StateIdentifier StateCtx),nt_Inh_Visit :: NontermIdent,options_Inh_Visit :: Options,params_Inh_Visit :: ([Identifier]),prevVisits_Inh_Visit :: (Map StateIdentifier StateCtx),ruledefs_Inh_Visit :: (Map Identifier (Set String)),ruleuses_Inh_Visit :: (Map Identifier (Map String (Maybe NonLocalAttr))),synmap_Inh_Visit :: Attributes,terminaldefs_Inh_Visit :: (Set String)} data Syn_Visit = Syn_Visit {allvisits_Syn_Visit :: ( VisitStateState ),childvisit_Syn_Visit :: (Map VisitIdentifier (Identifier -> VisitKind -> Either Error (PP_Doc, PP_Doc))),errors_Syn_Visit :: (Seq Error),fromToStates_Syn_Visit :: (Map VisitIdentifier (Int,Int)),intramap_Syn_Visit :: (Map StateIdentifier (Map String (Maybe NonLocalAttr))),lazyIntras_Syn_Visit :: (Set String),ruleKinds_Syn_Visit :: (Map Identifier (Set VisitKind)),ruleUsage_Syn_Visit :: (Map Identifier Int),sem_visit_Syn_Visit :: ( (StateIdentifier,Bool -> PP_Doc) ),t_visits_Syn_Visit :: PP_Doc,visitKinds_Syn_Visit :: (Map VisitIdentifier VisitKind),visitdefs_Syn_Visit :: (Map VisitIdentifier (Set Identifier)),visituses_Syn_Visit :: (Map VisitIdentifier (Set Identifier))} wrap_Visit :: T_Visit -> Inh_Visit -> Syn_Visit wrap_Visit (T_Visit sem ) (Inh_Visit _lhsIallFromToStates _lhsIallInhmap _lhsIallInitStates _lhsIallSynmap _lhsIallVisitKinds _lhsIallchildvisit _lhsIallintramap _lhsIavisitdefs _lhsIavisituses _lhsIchildTypes _lhsIchildintros _lhsIcon _lhsIinhmap _lhsImrules _lhsInextVisits _lhsInt _lhsIoptions _lhsIparams _lhsIprevVisits _lhsIruledefs _lhsIruleuses _lhsIsynmap _lhsIterminaldefs ) = (let ( _lhsOallvisits,_lhsOchildvisit,_lhsOerrors,_lhsOfromToStates,_lhsOintramap,_lhsOlazyIntras,_lhsOruleKinds,_lhsOruleUsage,_lhsOsem_visit,_lhsOt_visits,_lhsOvisitKinds,_lhsOvisitdefs,_lhsOvisituses) = sem _lhsIallFromToStates _lhsIallInhmap _lhsIallInitStates _lhsIallSynmap _lhsIallVisitKinds _lhsIallchildvisit _lhsIallintramap _lhsIavisitdefs _lhsIavisituses _lhsIchildTypes _lhsIchildintros _lhsIcon _lhsIinhmap _lhsImrules _lhsInextVisits _lhsInt _lhsIoptions _lhsIparams _lhsIprevVisits _lhsIruledefs _lhsIruleuses _lhsIsynmap _lhsIterminaldefs in (Syn_Visit _lhsOallvisits _lhsOchildvisit _lhsOerrors _lhsOfromToStates _lhsOintramap _lhsOlazyIntras _lhsOruleKinds _lhsOruleUsage _lhsOsem_visit _lhsOt_visits _lhsOvisitKinds _lhsOvisitdefs _lhsOvisituses )) sem_Visit_Visit :: VisitIdentifier -> StateIdentifier -> StateIdentifier -> (Set Identifier) -> (Set Identifier) -> T_VisitSteps -> VisitKind -> T_Visit sem_Visit_Visit ident_ from_ to_ inh_ syn_ (T_VisitSteps steps_ ) kind_ = (T_Visit (\ _lhsIallFromToStates _lhsIallInhmap _lhsIallInitStates _lhsIallSynmap _lhsIallVisitKinds _lhsIallchildvisit _lhsIallintramap _lhsIavisitdefs _lhsIavisituses _lhsIchildTypes _lhsIchildintros _lhsIcon _lhsIinhmap _lhsImrules _lhsInextVisits _lhsInt _lhsIoptions _lhsIparams _lhsIprevVisits _lhsIruledefs _lhsIruleuses _lhsIsynmap _lhsIterminaldefs -> (let _lhsOallvisits :: ( VisitStateState ) _lhsOt_visits :: PP_Doc _lhsOsem_visit :: ( (StateIdentifier,Bool -> PP_Doc) ) _stepsOkind :: VisitKind _stepsOfmtMode :: FormatMode _stepsOindex :: Int _stepsOprevMaxSimRefs :: Int _stepsOuseParallel :: Bool _lhsOchildvisit :: (Map VisitIdentifier (Identifier -> VisitKind -> Either Error (PP_Doc, PP_Doc))) _lhsOintramap :: (Map StateIdentifier (Map String (Maybe NonLocalAttr))) _lhsOvisitdefs :: (Map VisitIdentifier (Set Identifier)) _lhsOvisituses :: (Map VisitIdentifier (Set Identifier)) _lhsOlazyIntras :: (Set String) _lhsOfromToStates :: (Map VisitIdentifier (Int,Int)) _lhsOvisitKinds :: (Map VisitIdentifier VisitKind) _lhsOerrors :: (Seq Error) _lhsOruleKinds :: (Map Identifier (Set VisitKind)) _lhsOruleUsage :: (Map Identifier Int) _stepsOallFromToStates :: (Map VisitIdentifier (Int,Int)) _stepsOallInitStates :: (Map NontermIdent Int) _stepsOallVisitKinds :: (Map VisitIdentifier VisitKind) _stepsOallchildvisit :: (Map VisitIdentifier (Identifier -> VisitKind -> Either Error (PP_Doc, PP_Doc))) _stepsOavisitdefs :: (Map VisitIdentifier (Set Identifier)) _stepsOavisituses :: (Map VisitIdentifier (Set Identifier)) _stepsOchildTypes :: (Map Identifier Type) _stepsOchildintros :: (Map Identifier (VisitKind -> FormatMode -> Either Error (PP_Doc, Set String, Map String (Maybe NonLocalAttr)))) _stepsOmrules :: (Map Identifier (VisitKind -> FormatMode -> Either Error PP_Doc)) _stepsOoptions :: Options _stepsOruledefs :: (Map Identifier (Set String)) _stepsOruleuses :: (Map Identifier (Map String (Maybe NonLocalAttr))) _stepsIdefs :: (Set String) _stepsIerrors :: (Seq Error) _stepsIindex :: Int _stepsIisLast :: Bool _stepsIlazyIntras :: (Set String) _stepsIprevMaxSimRefs :: Int _stepsIruleKinds :: (Map Identifier (Set VisitKind)) _stepsIruleUsage :: (Map Identifier Int) _stepsIsem_steps :: PP_Doc _stepsIsize :: Int _stepsIsync_steps :: PP_Doc _stepsIuses :: (Map String (Maybe NonLocalAttr)) _stepsIvisitKinds :: (Map VisitIdentifier VisitKind) -- "src-ag/ExecutionPlan2Hs.ag"(line 340, column 11) _lhsOallvisits = ({-# LINE 340 "src-ag/ExecutionPlan2Hs.ag" #-} (ident_, from_, to_) {-# LINE 6538 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 399, column 11) _nameT_visit = ({-# LINE 399 "src-ag/ExecutionPlan2Hs.ag" #-} conNmTVisit _lhsInt ident_ {-# LINE 6544 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 400, column 11) _nameTIn_visit = ({-# LINE 400 "src-ag/ExecutionPlan2Hs.ag" #-} conNmTVisitIn _lhsInt ident_ {-# LINE 6550 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 401, column 11) _nameTOut_visit = ({-# LINE 401 "src-ag/ExecutionPlan2Hs.ag" #-} conNmTVisitOut _lhsInt ident_ {-# LINE 6556 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 402, column 11) _nameTNext_visit = ({-# LINE 402 "src-ag/ExecutionPlan2Hs.ag" #-} conNmTNextVisit _lhsInt to_ {-# LINE 6562 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 404, column 11) _nextVisitInfo = ({-# LINE 404 "src-ag/ExecutionPlan2Hs.ag" #-} Map.findWithDefault ManyVis to_ _lhsInextVisits {-# LINE 6568 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 405, column 11) _typecon = ({-# LINE 405 "src-ag/ExecutionPlan2Hs.ag" #-} case kind_ of VisitPure _ -> empty VisitMonadic -> ppMonadType _lhsIoptions {-# LINE 6576 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 409, column 11) _t_params = ({-# LINE 409 "src-ag/ExecutionPlan2Hs.ag" #-} ppSpaced _lhsIparams {-# LINE 6582 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 410, column 11) _lhsOt_visits = ({-# LINE 410 "src-ag/ExecutionPlan2Hs.ag" #-} "type" >#< _nameT_visit >#< _t_params >#< "=" >#< pp_parens (_nameTIn_visit >#< _t_params ) >#< ( if dummyTokenVisit _lhsIoptions then "->" >#< dummyType _lhsIoptions True else empty ) >#< "->" >#< _typecon >#< pp_parens (_nameTOut_visit >#< _t_params ) >-< "data" >#< _nameTIn_visit >#< _t_params >#< "=" >#< _nameTIn_visit >#< _inhpart >-< "data" >#< _nameTOut_visit >#< _t_params >#< "=" >#< _nameTOut_visit >#< _synpart >#< case _nextVisitInfo of NoneVis -> empty _ -> _addbang1 $ pp_parens (_nameTNext_visit >#< _t_params ) {-# LINE 6600 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 423, column 11) _inhpart = ({-# LINE 423 "src-ag/ExecutionPlan2Hs.ag" #-} _ppTypeList inh_ _lhsIinhmap {-# LINE 6606 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 424, column 11) _synpart = ({-# LINE 424 "src-ag/ExecutionPlan2Hs.ag" #-} _ppTypeList syn_ _lhsIsynmap {-# LINE 6612 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 425, column 11) _ppTypeList = ({-# LINE 425 "src-ag/ExecutionPlan2Hs.ag" #-} \s m -> ppSpaced $ map (\i -> _addbang1 $ pp_parens $ case Map.lookup i m of Just tp -> ppTp tp ) $ Set.toList s {-# LINE 6619 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 708, column 11) _lhsOsem_visit = ({-# LINE 708 "src-ag/ExecutionPlan2Hs.ag" #-} ( from_ , \addInlinePragma -> ( if noInlinePragmas _lhsIoptions then empty else if addInlinePragma && aggressiveInlinePragmas _lhsIoptions then ppInline _vname else if helpInlining _lhsIoptions then ppNoInline _vname else empty ) >-< "v" >|< ident_ >#< "::" >#< _nameT_visit >#< _t_params >-< "v" >|< ident_ >#< "=" >#< "\\" >#< (_addbang $ pp_parens (_nameTIn_visit >#< _inhpats )) >#< ( if dummyTokenVisit _lhsIoptions then pp $ dummyPat _lhsIoptions True else empty ) >#< "->" >#< ( if genCostCentres _lhsIoptions then ppCostCentre (_vname >|< "_" >|< _lhsInt >|< "_" >|< _lhsIcon) else empty ) >#< "(" >#< _stepsInitial >-< indent 3 (_stepsIsem_steps >-< _stepsClosing >#< ")") ) {-# LINE 6647 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 733, column 11) _stepsInitial = ({-# LINE 733 "src-ag/ExecutionPlan2Hs.ag" #-} case kind_ of VisitPure False -> text "let" VisitPure True -> empty VisitMonadic -> text "do" {-# LINE 6656 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 737, column 11) _stepsClosing = ({-# LINE 737 "src-ag/ExecutionPlan2Hs.ag" #-} let decls = _nextStBuild >-< _addbang (pp resultValName) >#< "=" >#< _resultval in case kind_ of VisitPure False -> decls >-< "in" >#< resultValName VisitPure True -> "let" >#< decls >-< indent 1 ("in" >#< resultValName) VisitMonadic -> "let" >#< decls >-< "return" >#< resultValName {-# LINE 6670 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 746, column 11) _vname = ({-# LINE 746 "src-ag/ExecutionPlan2Hs.ag" #-} "v" >|< ident_ {-# LINE 6676 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 747, column 11) _inhpats = ({-# LINE 747 "src-ag/ExecutionPlan2Hs.ag" #-} ppSpaced $ map (\arg -> _addbang $ pp $ attrname True _LHS arg) $ Set.toList inh_ {-# LINE 6682 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 748, column 11) _inhargs = ({-# LINE 748 "src-ag/ExecutionPlan2Hs.ag" #-} \chn -> ppSpaced $ map (attrname False chn) $ Set.toList inh_ {-# LINE 6688 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 749, column 11) _synargs = ({-# LINE 749 "src-ag/ExecutionPlan2Hs.ag" #-} ppSpaced $ map (\arg -> attrname False _LHS arg) $ Set.toList syn_ {-# LINE 6694 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 750, column 11) _nextargsMp = ({-# LINE 750 "src-ag/ExecutionPlan2Hs.ag" #-} maybe Map.empty id $ Map.lookup to_ _lhsIallintramap {-# LINE 6700 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 751, column 11) _nextargs = ({-# LINE 751 "src-ag/ExecutionPlan2Hs.ag" #-} ppSpaced $ Map.keys $ _nextargsMp {-# LINE 6706 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 752, column 11) _nextst = ({-# LINE 752 "src-ag/ExecutionPlan2Hs.ag" #-} "st" >|< to_ >#< _nextargs >#< dummyArg _lhsIoptions (Map.null _nextargsMp ) {-# LINE 6712 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 753, column 11) _resultval = ({-# LINE 753 "src-ag/ExecutionPlan2Hs.ag" #-} _nameTOut_visit >#< _synargs >#< _nextStRef {-# LINE 6718 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 754, column 11) __tup1 = ({-# LINE 754 "src-ag/ExecutionPlan2Hs.ag" #-} case _nextVisitInfo of NoneVis -> (empty, empty) _ -> (_addbang (pp nextStName) >#< "=" >#< _nextst , pp nextStName) {-# LINE 6726 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 754, column 11) (_nextStBuild,_) = ({-# LINE 754 "src-ag/ExecutionPlan2Hs.ag" #-} __tup1 {-# LINE 6732 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 754, column 11) (_,_nextStRef) = ({-# LINE 754 "src-ag/ExecutionPlan2Hs.ag" #-} __tup1 {-# LINE 6738 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 769, column 20) _stepsOkind = ({-# LINE 769 "src-ag/ExecutionPlan2Hs.ag" #-} kind_ {-# LINE 6744 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 820, column 3) _stepsOfmtMode = ({-# LINE 820 "src-ag/ExecutionPlan2Hs.ag" #-} case kind_ of VisitPure False -> FormatLetDecl VisitPure True -> FormatLetLine VisitMonadic -> FormatDo {-# LINE 6753 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 858, column 22) _stepsOindex = ({-# LINE 858 "src-ag/ExecutionPlan2Hs.ag" #-} 0 {-# LINE 6759 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 865, column 22) _stepsOprevMaxSimRefs = ({-# LINE 865 "src-ag/ExecutionPlan2Hs.ag" #-} 0 {-# LINE 6765 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 881, column 22) _stepsOuseParallel = ({-# LINE 881 "src-ag/ExecutionPlan2Hs.ag" #-} False {-# LINE 6771 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 1176, column 6) _prevVisitInfo = ({-# LINE 1176 "src-ag/ExecutionPlan2Hs.ag" #-} Map.findWithDefault ManyVis from_ _lhsInextVisits {-# LINE 6777 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 1177, column 6) _lhsOchildvisit = ({-# LINE 1177 "src-ag/ExecutionPlan2Hs.ag" #-} Map.singleton ident_ _invokecode {-# LINE 6783 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 1178, column 6) _invokecode = ({-# LINE 1178 "src-ag/ExecutionPlan2Hs.ag" #-} \chn kind -> if kind `compatibleKind` kind_ then Right $ let pat | isLazyKind kind_ = pat0 | otherwise = _addbang pat0 pat0 = pp_parens pat1 pat1 = _nameTOut_visit >#< (ppSpaced $ map (attrname True chn) $ Set.toList syn_) >#< cont cont = case _nextVisitInfo of NoneVis -> empty _ -> ch1 ch0 = text $ stname chn from_ ch1 = text $ stname chn to_ expr = case (kind, kind_) of (VisitPure _, VisitPure _) -> expr0 (VisitPure _, VisitMonadic) -> unMon _lhsIoptions >#< expr0 (VisitMonadic, VisitPure _) -> "return" >#< expr0 (VisitMonadic, VisitMonadic) -> expr0 expr0 = case _prevVisitInfo of NoneVis -> error "error: invocation of a visit from a state that has no next visits" OneVis _ -> "inv_" >|< _lhsInt >|< "_s" >|< from_ >#< ch0 >#< args ManyVis -> "inv_" >|< _lhsInt >|< "_s" >|< from_ >#< ch0 >#< "K_" >|< _lhsInt >|< "_v" >|< ident_ >#< args args = pp_parens args0 >#< args1 args0 = _nameTIn_visit >#< _inhargs chn args1 | dummyTokenVisit _lhsIoptions = pp $ dummyArg _lhsIoptions True | otherwise = empty in (pat, expr) else Left $ IncompatibleVisitKind chn ident_ kind kind_ {-# LINE 6817 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 1274, column 11) _thisintra = ({-# LINE 1274 "src-ag/ExecutionPlan2Hs.ag" #-} (_uses `Map.union` _nextintra ) `Map.difference` _defsAsMap {-# LINE 6823 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 1275, column 11) _lhsOintramap = ({-# LINE 1275 "src-ag/ExecutionPlan2Hs.ag" #-} Map.singleton from_ _thisintra {-# LINE 6829 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 1276, column 11) _nextintra = ({-# LINE 1276 "src-ag/ExecutionPlan2Hs.ag" #-} maybe Map.empty id $ Map.lookup to_ _lhsIallintramap {-# LINE 6835 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 1277, column 11) _uses = ({-# LINE 1277 "src-ag/ExecutionPlan2Hs.ag" #-} let mp1 = _stepsIuses mp2 = Map.fromList [ (lhsname False i, Just (AttrSyn _LHS i)) | i <- Set.elems syn_ ] in mp1 `Map.union` mp2 {-# LINE 6843 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 1280, column 11) _inhVarNms = ({-# LINE 1280 "src-ag/ExecutionPlan2Hs.ag" #-} Set.map (lhsname True) inh_ {-# LINE 6849 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 1281, column 11) _defs = ({-# LINE 1281 "src-ag/ExecutionPlan2Hs.ag" #-} _stepsIdefs `Set.union` _inhVarNms `Set.union` _lhsIterminaldefs {-# LINE 6855 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 1282, column 11) _defsAsMap = ({-# LINE 1282 "src-ag/ExecutionPlan2Hs.ag" #-} Map.fromList [ (a, Nothing) | a <- Set.elems _defs ] {-# LINE 6861 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 1306, column 11) _lhsOvisitdefs = ({-# LINE 1306 "src-ag/ExecutionPlan2Hs.ag" #-} Map.singleton ident_ syn_ {-# LINE 6867 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 1307, column 11) _lhsOvisituses = ({-# LINE 1307 "src-ag/ExecutionPlan2Hs.ag" #-} Map.singleton ident_ inh_ {-# LINE 6873 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 1339, column 3) _lazyIntrasInh = ({-# LINE 1339 "src-ag/ExecutionPlan2Hs.ag" #-} case kind_ of VisitPure False -> _inhVarNms `Set.union` _stepsIdefs _ -> Set.empty {-# LINE 6881 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 1342, column 3) _lhsOlazyIntras = ({-# LINE 1342 "src-ag/ExecutionPlan2Hs.ag" #-} _lazyIntrasInh `Set.union` _stepsIlazyIntras {-# LINE 6887 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 1495, column 37) _addbang = ({-# LINE 1495 "src-ag/ExecutionPlan2Hs.ag" #-} \x -> if bangpats _lhsIoptions then "!" >|< x else x {-# LINE 6893 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 1503, column 37) _addbang1 = ({-# LINE 1503 "src-ag/ExecutionPlan2Hs.ag" #-} if isLazyKind kind_ then id else _addbang {-# LINE 6899 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 1530, column 3) _lhsOfromToStates = ({-# LINE 1530 "src-ag/ExecutionPlan2Hs.ag" #-} Map.singleton ident_ (from_, to_) {-# LINE 6905 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 1574, column 3) _lhsOvisitKinds = ({-# LINE 1574 "src-ag/ExecutionPlan2Hs.ag" #-} Map.singleton ident_ kind_ {-# LINE 6911 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- use rule "src-ag/ExecutionPlan2Hs.ag"(line 1609, column 132) _lhsOerrors = ({-# LINE 1609 "src-ag/ExecutionPlan2Hs.ag" #-} _stepsIerrors {-# LINE 6917 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- use rule "src-ag/ExecutionPlan2Hs.ag"(line 1235, column 56) _lhsOruleKinds = ({-# LINE 1235 "src-ag/ExecutionPlan2Hs.ag" #-} _stepsIruleKinds {-# LINE 6923 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- use rule "src-ag/ExecutionPlan2Hs.ag"(line 1223, column 56) _lhsOruleUsage = ({-# LINE 1223 "src-ag/ExecutionPlan2Hs.ag" #-} _stepsIruleUsage {-# LINE 6929 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _stepsOallFromToStates = ({-# LINE 1527 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIallFromToStates {-# LINE 6935 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _stepsOallInitStates = ({-# LINE 1585 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIallInitStates {-# LINE 6941 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _stepsOallVisitKinds = ({-# LINE 1571 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIallVisitKinds {-# LINE 6947 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _stepsOallchildvisit = ({-# LINE 1169 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIallchildvisit {-# LINE 6953 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _stepsOavisitdefs = ({-# LINE 1312 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIavisitdefs {-# LINE 6959 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _stepsOavisituses = ({-# LINE 1313 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIavisituses {-# LINE 6965 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _stepsOchildTypes = ({-# LINE 1544 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIchildTypes {-# LINE 6971 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _stepsOchildintros = ({-# LINE 892 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIchildintros {-# LINE 6977 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _stepsOmrules = ({-# LINE 775 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsImrules {-# LINE 6983 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _stepsOoptions = ({-# LINE 51 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIoptions {-# LINE 6989 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _stepsOruledefs = ({-# LINE 1287 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIruledefs {-# LINE 6995 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _stepsOruleuses = ({-# LINE 1288 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIruleuses {-# LINE 7001 "src-ag/ExecutionPlan2Hs.hs" #-} ) ( _stepsIdefs,_stepsIerrors,_stepsIindex,_stepsIisLast,_stepsIlazyIntras,_stepsIprevMaxSimRefs,_stepsIruleKinds,_stepsIruleUsage,_stepsIsem_steps,_stepsIsize,_stepsIsync_steps,_stepsIuses,_stepsIvisitKinds) = steps_ _stepsOallFromToStates _stepsOallInitStates _stepsOallVisitKinds _stepsOallchildvisit _stepsOavisitdefs _stepsOavisituses _stepsOchildTypes _stepsOchildintros _stepsOfmtMode _stepsOindex _stepsOkind _stepsOmrules _stepsOoptions _stepsOprevMaxSimRefs _stepsOruledefs _stepsOruleuses _stepsOuseParallel in ( _lhsOallvisits,_lhsOchildvisit,_lhsOerrors,_lhsOfromToStates,_lhsOintramap,_lhsOlazyIntras,_lhsOruleKinds,_lhsOruleUsage,_lhsOsem_visit,_lhsOt_visits,_lhsOvisitKinds,_lhsOvisitdefs,_lhsOvisituses))) ) -- VisitStep --------------------------------------------------- {- visit 0: inherited attributes: allFromToStates : Map VisitIdentifier (Int,Int) allInitStates : Map NontermIdent Int allVisitKinds : Map VisitIdentifier VisitKind allchildvisit : Map VisitIdentifier (Identifier -> VisitKind -> Either Error (PP_Doc, PP_Doc)) avisitdefs : Map VisitIdentifier (Set Identifier) avisituses : Map VisitIdentifier (Set Identifier) childTypes : Map Identifier Type childintros : Map Identifier (VisitKind -> FormatMode -> Either Error (PP_Doc, Set String, Map String (Maybe NonLocalAttr))) fmtMode : FormatMode kind : VisitKind mrules : Map Identifier (VisitKind -> FormatMode -> Either Error PP_Doc) options : Options ruledefs : Map Identifier (Set String) ruleuses : Map Identifier (Map String (Maybe NonLocalAttr)) useParallel : Bool chained attributes: index : Int isLast : Bool prevMaxSimRefs : Int synthesized attributes: defs : Set String errors : Seq Error lazyIntras : Set String ruleKinds : Map Identifier (Set VisitKind) ruleUsage : Map Identifier Int sem_steps : PP_Doc sync_steps : PP_Doc uses : Map String (Maybe NonLocalAttr) visitKinds : Map VisitIdentifier VisitKind alternatives: alternative ChildIntro: child child : {Identifier} visit 0: local attachItf : _ local _tup2 : {(Seq Error,PP_Doc,Set String,Map String (Maybe NonLocalAttr))} alternative ChildVisit: child child : {Identifier} child nonterm : {NontermIdent} child visit : {VisitIdentifier} visit 0: local visitItf : _ local _tup3 : _ local patPP : _ local exprPP : _ local useParallel : _ local convToMonad : _ local callKind : _ local addbang : _ local _tup4 : _ local from : _ local to : _ alternative PureGroup: child steps : VisitSteps child ordered : {Bool} alternative Sem: child name : {Identifier} visit 0: local ruleItf : _ local _tup5 : _ local sem_steps : _ alternative Sim: child steps : VisitSteps visit 0: local useParallel : _ local isMonadic : _ -} -- cata sem_VisitStep :: VisitStep -> T_VisitStep sem_VisitStep (ChildIntro _child ) = (sem_VisitStep_ChildIntro _child ) sem_VisitStep (ChildVisit _child _nonterm _visit ) = (sem_VisitStep_ChildVisit _child _nonterm _visit ) sem_VisitStep (PureGroup _steps _ordered ) = (sem_VisitStep_PureGroup (sem_VisitSteps _steps ) _ordered ) sem_VisitStep (Sem _name ) = (sem_VisitStep_Sem _name ) sem_VisitStep (Sim _steps ) = (sem_VisitStep_Sim (sem_VisitSteps _steps ) ) -- semantic domain newtype T_VisitStep = T_VisitStep ((Map VisitIdentifier (Int,Int)) -> (Map NontermIdent Int) -> (Map VisitIdentifier VisitKind) -> (Map VisitIdentifier (Identifier -> VisitKind -> Either Error (PP_Doc, PP_Doc))) -> (Map VisitIdentifier (Set Identifier)) -> (Map VisitIdentifier (Set Identifier)) -> (Map Identifier Type) -> (Map Identifier (VisitKind -> FormatMode -> Either Error (PP_Doc, Set String, Map String (Maybe NonLocalAttr)))) -> FormatMode -> Int -> Bool -> VisitKind -> (Map Identifier (VisitKind -> FormatMode -> Either Error PP_Doc)) -> Options -> Int -> (Map Identifier (Set String)) -> (Map Identifier (Map String (Maybe NonLocalAttr))) -> Bool -> ( (Set String),(Seq Error),Int,Bool,(Set String),Int,(Map Identifier (Set VisitKind)),(Map Identifier Int),PP_Doc,PP_Doc,(Map String (Maybe NonLocalAttr)),(Map VisitIdentifier VisitKind))) data Inh_VisitStep = Inh_VisitStep {allFromToStates_Inh_VisitStep :: (Map VisitIdentifier (Int,Int)),allInitStates_Inh_VisitStep :: (Map NontermIdent Int),allVisitKinds_Inh_VisitStep :: (Map VisitIdentifier VisitKind),allchildvisit_Inh_VisitStep :: (Map VisitIdentifier (Identifier -> VisitKind -> Either Error (PP_Doc, PP_Doc))),avisitdefs_Inh_VisitStep :: (Map VisitIdentifier (Set Identifier)),avisituses_Inh_VisitStep :: (Map VisitIdentifier (Set Identifier)),childTypes_Inh_VisitStep :: (Map Identifier Type),childintros_Inh_VisitStep :: (Map Identifier (VisitKind -> FormatMode -> Either Error (PP_Doc, Set String, Map String (Maybe NonLocalAttr)))),fmtMode_Inh_VisitStep :: FormatMode,index_Inh_VisitStep :: Int,isLast_Inh_VisitStep :: Bool,kind_Inh_VisitStep :: VisitKind,mrules_Inh_VisitStep :: (Map Identifier (VisitKind -> FormatMode -> Either Error PP_Doc)),options_Inh_VisitStep :: Options,prevMaxSimRefs_Inh_VisitStep :: Int,ruledefs_Inh_VisitStep :: (Map Identifier (Set String)),ruleuses_Inh_VisitStep :: (Map Identifier (Map String (Maybe NonLocalAttr))),useParallel_Inh_VisitStep :: Bool} data Syn_VisitStep = Syn_VisitStep {defs_Syn_VisitStep :: (Set String),errors_Syn_VisitStep :: (Seq Error),index_Syn_VisitStep :: Int,isLast_Syn_VisitStep :: Bool,lazyIntras_Syn_VisitStep :: (Set String),prevMaxSimRefs_Syn_VisitStep :: Int,ruleKinds_Syn_VisitStep :: (Map Identifier (Set VisitKind)),ruleUsage_Syn_VisitStep :: (Map Identifier Int),sem_steps_Syn_VisitStep :: PP_Doc,sync_steps_Syn_VisitStep :: PP_Doc,uses_Syn_VisitStep :: (Map String (Maybe NonLocalAttr)),visitKinds_Syn_VisitStep :: (Map VisitIdentifier VisitKind)} wrap_VisitStep :: T_VisitStep -> Inh_VisitStep -> Syn_VisitStep wrap_VisitStep (T_VisitStep sem ) (Inh_VisitStep _lhsIallFromToStates _lhsIallInitStates _lhsIallVisitKinds _lhsIallchildvisit _lhsIavisitdefs _lhsIavisituses _lhsIchildTypes _lhsIchildintros _lhsIfmtMode _lhsIindex _lhsIisLast _lhsIkind _lhsImrules _lhsIoptions _lhsIprevMaxSimRefs _lhsIruledefs _lhsIruleuses _lhsIuseParallel ) = (let ( _lhsOdefs,_lhsOerrors,_lhsOindex,_lhsOisLast,_lhsOlazyIntras,_lhsOprevMaxSimRefs,_lhsOruleKinds,_lhsOruleUsage,_lhsOsem_steps,_lhsOsync_steps,_lhsOuses,_lhsOvisitKinds) = sem _lhsIallFromToStates _lhsIallInitStates _lhsIallVisitKinds _lhsIallchildvisit _lhsIavisitdefs _lhsIavisituses _lhsIchildTypes _lhsIchildintros _lhsIfmtMode _lhsIindex _lhsIisLast _lhsIkind _lhsImrules _lhsIoptions _lhsIprevMaxSimRefs _lhsIruledefs _lhsIruleuses _lhsIuseParallel in (Syn_VisitStep _lhsOdefs _lhsOerrors _lhsOindex _lhsOisLast _lhsOlazyIntras _lhsOprevMaxSimRefs _lhsOruleKinds _lhsOruleUsage _lhsOsem_steps _lhsOsync_steps _lhsOuses _lhsOvisitKinds )) sem_VisitStep_ChildIntro :: Identifier -> T_VisitStep sem_VisitStep_ChildIntro child_ = (T_VisitStep (\ _lhsIallFromToStates _lhsIallInitStates _lhsIallVisitKinds _lhsIallchildvisit _lhsIavisitdefs _lhsIavisituses _lhsIchildTypes _lhsIchildintros _lhsIfmtMode _lhsIindex _lhsIisLast _lhsIkind _lhsImrules _lhsIoptions _lhsIprevMaxSimRefs _lhsIruledefs _lhsIruleuses _lhsIuseParallel -> (let __tup2 :: ((Seq Error,PP_Doc,Set String,Map String (Maybe NonLocalAttr))) _lhsOerrors :: (Seq Error) _lhsOsem_steps :: PP_Doc _lhsOdefs :: (Set String) _lhsOuses :: (Map String (Maybe NonLocalAttr)) _lhsOlazyIntras :: (Set String) _lhsOruleKinds :: (Map Identifier (Set VisitKind)) _lhsOruleUsage :: (Map Identifier Int) _lhsOsync_steps :: PP_Doc _lhsOvisitKinds :: (Map VisitIdentifier VisitKind) _lhsOindex :: Int _lhsOisLast :: Bool _lhsOprevMaxSimRefs :: Int -- "src-ag/ExecutionPlan2Hs.ag"(line 782, column 16) _attachItf = ({-# LINE 782 "src-ag/ExecutionPlan2Hs.ag" #-} Map.findWithDefault (error $ "Child " ++ show child_ ++ " not found") child_ _lhsIchildintros {-# LINE 7155 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 783, column 16) __tup2 = ({-# LINE 783 "src-ag/ExecutionPlan2Hs.ag" #-} case _attachItf _lhsIkind _lhsIfmtMode of Left e -> (Seq.singleton e, empty, Set.empty, Map.empty) Right (code, defs, uses) -> (Seq.empty, code, defs, uses) {-# LINE 7163 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 783, column 16) (_lhsOerrors,_,_,_) = ({-# LINE 783 "src-ag/ExecutionPlan2Hs.ag" #-} __tup2 {-# LINE 7169 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 783, column 16) (_,_lhsOsem_steps,_,_) = ({-# LINE 783 "src-ag/ExecutionPlan2Hs.ag" #-} __tup2 {-# LINE 7175 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 783, column 16) (_,_,_lhsOdefs,_) = ({-# LINE 783 "src-ag/ExecutionPlan2Hs.ag" #-} __tup2 {-# LINE 7181 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 783, column 16) (_,_,_,_lhsOuses) = ({-# LINE 783 "src-ag/ExecutionPlan2Hs.ag" #-} __tup2 {-# LINE 7187 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- use rule "src-ag/ExecutionPlan2Hs.ag"(line 1335, column 57) _lhsOlazyIntras = ({-# LINE 1335 "src-ag/ExecutionPlan2Hs.ag" #-} Set.empty {-# LINE 7193 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- use rule "src-ag/ExecutionPlan2Hs.ag"(line 1235, column 56) _lhsOruleKinds = ({-# LINE 1235 "src-ag/ExecutionPlan2Hs.ag" #-} Map.empty {-# LINE 7199 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- use rule "src-ag/ExecutionPlan2Hs.ag"(line 1223, column 56) _lhsOruleUsage = ({-# LINE 1223 "src-ag/ExecutionPlan2Hs.ag" #-} Map.empty {-# LINE 7205 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- use rule "src-ag/ExecutionPlan2Hs.ag"(line 809, column 44) _lhsOsync_steps = ({-# LINE 809 "src-ag/ExecutionPlan2Hs.ag" #-} empty {-# LINE 7211 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- use rule "src-ag/ExecutionPlan2Hs.ag"(line 1571, column 68) _lhsOvisitKinds = ({-# LINE 1571 "src-ag/ExecutionPlan2Hs.ag" #-} mempty {-# LINE 7217 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (chain) _lhsOindex = ({-# LINE 853 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIindex {-# LINE 7223 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (chain) _lhsOisLast = ({-# LINE 872 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIisLast {-# LINE 7229 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (chain) _lhsOprevMaxSimRefs = ({-# LINE 864 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIprevMaxSimRefs {-# LINE 7235 "src-ag/ExecutionPlan2Hs.hs" #-} ) in ( _lhsOdefs,_lhsOerrors,_lhsOindex,_lhsOisLast,_lhsOlazyIntras,_lhsOprevMaxSimRefs,_lhsOruleKinds,_lhsOruleUsage,_lhsOsem_steps,_lhsOsync_steps,_lhsOuses,_lhsOvisitKinds))) ) sem_VisitStep_ChildVisit :: Identifier -> NontermIdent -> VisitIdentifier -> T_VisitStep sem_VisitStep_ChildVisit child_ nonterm_ visit_ = (T_VisitStep (\ _lhsIallFromToStates _lhsIallInitStates _lhsIallVisitKinds _lhsIallchildvisit _lhsIavisitdefs _lhsIavisituses _lhsIchildTypes _lhsIchildintros _lhsIfmtMode _lhsIindex _lhsIisLast _lhsIkind _lhsImrules _lhsIoptions _lhsIprevMaxSimRefs _lhsIruledefs _lhsIruleuses _lhsIuseParallel -> (let _lhsOerrors :: (Seq Error) _lhsOsem_steps :: PP_Doc _lhsOsync_steps :: PP_Doc _lhsOdefs :: (Set String) _lhsOuses :: (Map String (Maybe NonLocalAttr)) _lhsOlazyIntras :: (Set String) _lhsOruleKinds :: (Map Identifier (Set VisitKind)) _lhsOruleUsage :: (Map Identifier Int) _lhsOvisitKinds :: (Map VisitIdentifier VisitKind) _lhsOindex :: Int _lhsOisLast :: Bool _lhsOprevMaxSimRefs :: Int -- "src-ag/ExecutionPlan2Hs.ag"(line 787, column 16) _visitItf = ({-# LINE 787 "src-ag/ExecutionPlan2Hs.ag" #-} Map.findWithDefault (error $ "Visit " ++ show visit_ ++ " not found") visit_ _lhsIallchildvisit {-# LINE 7277 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 788, column 16) __tup3 = ({-# LINE 788 "src-ag/ExecutionPlan2Hs.ag" #-} case _visitItf child_ _lhsIkind of Left e -> (Seq.singleton e, empty, empty) Right (pat,expr) -> (Seq.empty, pat, expr) {-# LINE 7285 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 788, column 16) (_lhsOerrors,_,_) = ({-# LINE 788 "src-ag/ExecutionPlan2Hs.ag" #-} __tup3 {-# LINE 7291 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 788, column 16) (_,_patPP,_) = ({-# LINE 788 "src-ag/ExecutionPlan2Hs.ag" #-} __tup3 {-# LINE 7297 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 788, column 16) (_,_,_exprPP) = ({-# LINE 788 "src-ag/ExecutionPlan2Hs.ag" #-} __tup3 {-# LINE 7303 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 792, column 16) _useParallel = ({-# LINE 792 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIuseParallel && not _lhsIisLast {-# LINE 7309 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 793, column 16) _lhsOsem_steps = ({-# LINE 793 "src-ag/ExecutionPlan2Hs.ag" #-} if _useParallel then _addbang ("sync_" >|< _lhsIindex) >#< "<- newEmptyMVar" >-< "forkIO" >#< pp_parens (_convToMonad >#< pp_parens _exprPP >#< ">>= \\" >#< _addbang (pp parResultName) >#< " -> putMVar sync_" >|< _lhsIindex >#< parResultName) else let decl = case _lhsIkind of VisitPure _ -> _patPP >#< "=" >#< _exprPP VisitMonadic -> _patPP >#< "<-" >#< _exprPP in fmtDecl False _lhsIfmtMode decl {-# LINE 7321 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 800, column 16) _convToMonad = ({-# LINE 800 "src-ag/ExecutionPlan2Hs.ag" #-} case _callKind of VisitPure _ -> text "return" VisitMonadic -> empty {-# LINE 7329 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 803, column 16) _callKind = ({-# LINE 803 "src-ag/ExecutionPlan2Hs.ag" #-} Map.findWithDefault (error "visit kind should be in the map") visit_ _lhsIallVisitKinds {-# LINE 7335 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 811, column 3) _lhsOsync_steps = ({-# LINE 811 "src-ag/ExecutionPlan2Hs.ag" #-} if _useParallel then _patPP >#< "<-" >#< "takeMVar sync_" >|< _lhsIindex else empty {-# LINE 7343 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 1324, column 16) _lhsOdefs = ({-# LINE 1324 "src-ag/ExecutionPlan2Hs.ag" #-} Set.insert (stname child_ _to) $ maybe (error "Visit not found") (Set.map $ attrname True child_) $ Map.lookup visit_ _lhsIavisitdefs {-# LINE 7349 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 1325, column 16) _lhsOuses = ({-# LINE 1325 "src-ag/ExecutionPlan2Hs.ag" #-} let convert attrs = Map.fromList [ (attrname False child_ attr, Just $ mkNonLocalAttr True child_ attr) | attr <- Set.elems attrs ] in Map.insert (stname child_ _from) Nothing $ convert $ maybe (error "Visit not found") id $ Map.lookup visit_ _lhsIavisituses {-# LINE 7357 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 1500, column 37) _addbang = ({-# LINE 1500 "src-ag/ExecutionPlan2Hs.ag" #-} \x -> if bangpats _lhsIoptions then "!" >|< x else x {-# LINE 7363 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 1536, column 3) __tup4 = ({-# LINE 1536 "src-ag/ExecutionPlan2Hs.ag" #-} Map.findWithDefault (error "visit not in allFromToStates") visit_ _lhsIallFromToStates {-# LINE 7369 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 1536, column 3) (_from,_) = ({-# LINE 1536 "src-ag/ExecutionPlan2Hs.ag" #-} __tup4 {-# LINE 7375 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 1536, column 3) (_,_to) = ({-# LINE 1536 "src-ag/ExecutionPlan2Hs.ag" #-} __tup4 {-# LINE 7381 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- use rule "src-ag/ExecutionPlan2Hs.ag"(line 1335, column 57) _lhsOlazyIntras = ({-# LINE 1335 "src-ag/ExecutionPlan2Hs.ag" #-} Set.empty {-# LINE 7387 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- use rule "src-ag/ExecutionPlan2Hs.ag"(line 1235, column 56) _lhsOruleKinds = ({-# LINE 1235 "src-ag/ExecutionPlan2Hs.ag" #-} Map.empty {-# LINE 7393 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- use rule "src-ag/ExecutionPlan2Hs.ag"(line 1223, column 56) _lhsOruleUsage = ({-# LINE 1223 "src-ag/ExecutionPlan2Hs.ag" #-} Map.empty {-# LINE 7399 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- use rule "src-ag/ExecutionPlan2Hs.ag"(line 1571, column 68) _lhsOvisitKinds = ({-# LINE 1571 "src-ag/ExecutionPlan2Hs.ag" #-} mempty {-# LINE 7405 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (chain) _lhsOindex = ({-# LINE 853 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIindex {-# LINE 7411 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (chain) _lhsOisLast = ({-# LINE 872 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIisLast {-# LINE 7417 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (chain) _lhsOprevMaxSimRefs = ({-# LINE 864 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIprevMaxSimRefs {-# LINE 7423 "src-ag/ExecutionPlan2Hs.hs" #-} ) in ( _lhsOdefs,_lhsOerrors,_lhsOindex,_lhsOisLast,_lhsOlazyIntras,_lhsOprevMaxSimRefs,_lhsOruleKinds,_lhsOruleUsage,_lhsOsem_steps,_lhsOsync_steps,_lhsOuses,_lhsOvisitKinds))) ) sem_VisitStep_PureGroup :: T_VisitSteps -> Bool -> T_VisitStep sem_VisitStep_PureGroup (T_VisitSteps steps_ ) ordered_ = (T_VisitStep (\ _lhsIallFromToStates _lhsIallInitStates _lhsIallVisitKinds _lhsIallchildvisit _lhsIavisitdefs _lhsIavisituses _lhsIchildTypes _lhsIchildintros _lhsIfmtMode _lhsIindex _lhsIisLast _lhsIkind _lhsImrules _lhsIoptions _lhsIprevMaxSimRefs _lhsIruledefs _lhsIruleuses _lhsIuseParallel -> (let _stepsOkind :: VisitKind _lhsOsem_steps :: PP_Doc _stepsOfmtMode :: FormatMode _lhsOlazyIntras :: (Set String) _lhsOdefs :: (Set String) _lhsOerrors :: (Seq Error) _lhsOruleKinds :: (Map Identifier (Set VisitKind)) _lhsOruleUsage :: (Map Identifier Int) _lhsOsync_steps :: PP_Doc _lhsOuses :: (Map String (Maybe NonLocalAttr)) _lhsOvisitKinds :: (Map VisitIdentifier VisitKind) _lhsOindex :: Int _lhsOisLast :: Bool _lhsOprevMaxSimRefs :: Int _stepsOallFromToStates :: (Map VisitIdentifier (Int,Int)) _stepsOallInitStates :: (Map NontermIdent Int) _stepsOallVisitKinds :: (Map VisitIdentifier VisitKind) _stepsOallchildvisit :: (Map VisitIdentifier (Identifier -> VisitKind -> Either Error (PP_Doc, PP_Doc))) _stepsOavisitdefs :: (Map VisitIdentifier (Set Identifier)) _stepsOavisituses :: (Map VisitIdentifier (Set Identifier)) _stepsOchildTypes :: (Map Identifier Type) _stepsOchildintros :: (Map Identifier (VisitKind -> FormatMode -> Either Error (PP_Doc, Set String, Map String (Maybe NonLocalAttr)))) _stepsOindex :: Int _stepsOmrules :: (Map Identifier (VisitKind -> FormatMode -> Either Error PP_Doc)) _stepsOoptions :: Options _stepsOprevMaxSimRefs :: Int _stepsOruledefs :: (Map Identifier (Set String)) _stepsOruleuses :: (Map Identifier (Map String (Maybe NonLocalAttr))) _stepsOuseParallel :: Bool _stepsIdefs :: (Set String) _stepsIerrors :: (Seq Error) _stepsIindex :: Int _stepsIisLast :: Bool _stepsIlazyIntras :: (Set String) _stepsIprevMaxSimRefs :: Int _stepsIruleKinds :: (Map Identifier (Set VisitKind)) _stepsIruleUsage :: (Map Identifier Int) _stepsIsem_steps :: PP_Doc _stepsIsize :: Int _stepsIsync_steps :: PP_Doc _stepsIuses :: (Map String (Maybe NonLocalAttr)) _stepsIvisitKinds :: (Map VisitIdentifier VisitKind) -- "src-ag/ExecutionPlan2Hs.ag"(line 773, column 3) _stepsOkind = ({-# LINE 773 "src-ag/ExecutionPlan2Hs.ag" #-} VisitPure ordered_ {-# LINE 7494 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 805, column 16) _lhsOsem_steps = ({-# LINE 805 "src-ag/ExecutionPlan2Hs.ag" #-} case _lhsIfmtMode of FormatDo -> "let" >#< _stepsIsem_steps _ -> _stepsIsem_steps {-# LINE 7502 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 826, column 3) _stepsOfmtMode = ({-# LINE 826 "src-ag/ExecutionPlan2Hs.ag" #-} case _lhsIfmtMode of FormatDo -> FormatLetDecl mode -> mode {-# LINE 7510 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 1345, column 3) _lhsOlazyIntras = ({-# LINE 1345 "src-ag/ExecutionPlan2Hs.ag" #-} if ordered_ then _stepsIlazyIntras else _stepsIdefs {-# LINE 7518 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- use rule "src-ag/ExecutionPlan2Hs.ag"(line 1319, column 38) _lhsOdefs = ({-# LINE 1319 "src-ag/ExecutionPlan2Hs.ag" #-} _stepsIdefs {-# LINE 7524 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- use rule "src-ag/ExecutionPlan2Hs.ag"(line 1609, column 132) _lhsOerrors = ({-# LINE 1609 "src-ag/ExecutionPlan2Hs.ag" #-} _stepsIerrors {-# LINE 7530 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- use rule "src-ag/ExecutionPlan2Hs.ag"(line 1235, column 56) _lhsOruleKinds = ({-# LINE 1235 "src-ag/ExecutionPlan2Hs.ag" #-} _stepsIruleKinds {-# LINE 7536 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- use rule "src-ag/ExecutionPlan2Hs.ag"(line 1223, column 56) _lhsOruleUsage = ({-# LINE 1223 "src-ag/ExecutionPlan2Hs.ag" #-} _stepsIruleUsage {-# LINE 7542 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- use rule "src-ag/ExecutionPlan2Hs.ag"(line 809, column 44) _lhsOsync_steps = ({-# LINE 809 "src-ag/ExecutionPlan2Hs.ag" #-} _stepsIsync_steps {-# LINE 7548 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- use rule "src-ag/ExecutionPlan2Hs.ag"(line 1320, column 38) _lhsOuses = ({-# LINE 1320 "src-ag/ExecutionPlan2Hs.ag" #-} _stepsIuses {-# LINE 7554 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- use rule "src-ag/ExecutionPlan2Hs.ag"(line 1571, column 68) _lhsOvisitKinds = ({-# LINE 1571 "src-ag/ExecutionPlan2Hs.ag" #-} _stepsIvisitKinds {-# LINE 7560 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (up) _lhsOindex = ({-# LINE 853 "src-ag/ExecutionPlan2Hs.ag" #-} _stepsIindex {-# LINE 7566 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (up) _lhsOisLast = ({-# LINE 872 "src-ag/ExecutionPlan2Hs.ag" #-} _stepsIisLast {-# LINE 7572 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (up) _lhsOprevMaxSimRefs = ({-# LINE 864 "src-ag/ExecutionPlan2Hs.ag" #-} _stepsIprevMaxSimRefs {-# LINE 7578 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _stepsOallFromToStates = ({-# LINE 1527 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIallFromToStates {-# LINE 7584 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _stepsOallInitStates = ({-# LINE 1585 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIallInitStates {-# LINE 7590 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _stepsOallVisitKinds = ({-# LINE 1571 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIallVisitKinds {-# LINE 7596 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _stepsOallchildvisit = ({-# LINE 1169 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIallchildvisit {-# LINE 7602 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _stepsOavisitdefs = ({-# LINE 1312 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIavisitdefs {-# LINE 7608 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _stepsOavisituses = ({-# LINE 1313 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIavisituses {-# LINE 7614 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _stepsOchildTypes = ({-# LINE 1544 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIchildTypes {-# LINE 7620 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _stepsOchildintros = ({-# LINE 892 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIchildintros {-# LINE 7626 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _stepsOindex = ({-# LINE 853 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIindex {-# LINE 7632 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _stepsOmrules = ({-# LINE 775 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsImrules {-# LINE 7638 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _stepsOoptions = ({-# LINE 51 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIoptions {-# LINE 7644 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _stepsOprevMaxSimRefs = ({-# LINE 864 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIprevMaxSimRefs {-# LINE 7650 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _stepsOruledefs = ({-# LINE 1287 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIruledefs {-# LINE 7656 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _stepsOruleuses = ({-# LINE 1288 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIruleuses {-# LINE 7662 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _stepsOuseParallel = ({-# LINE 880 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIuseParallel {-# LINE 7668 "src-ag/ExecutionPlan2Hs.hs" #-} ) ( _stepsIdefs,_stepsIerrors,_stepsIindex,_stepsIisLast,_stepsIlazyIntras,_stepsIprevMaxSimRefs,_stepsIruleKinds,_stepsIruleUsage,_stepsIsem_steps,_stepsIsize,_stepsIsync_steps,_stepsIuses,_stepsIvisitKinds) = steps_ _stepsOallFromToStates _stepsOallInitStates _stepsOallVisitKinds _stepsOallchildvisit _stepsOavisitdefs _stepsOavisituses _stepsOchildTypes _stepsOchildintros _stepsOfmtMode _stepsOindex _stepsOkind _stepsOmrules _stepsOoptions _stepsOprevMaxSimRefs _stepsOruledefs _stepsOruleuses _stepsOuseParallel in ( _lhsOdefs,_lhsOerrors,_lhsOindex,_lhsOisLast,_lhsOlazyIntras,_lhsOprevMaxSimRefs,_lhsOruleKinds,_lhsOruleUsage,_lhsOsem_steps,_lhsOsync_steps,_lhsOuses,_lhsOvisitKinds))) ) sem_VisitStep_Sem :: Identifier -> T_VisitStep sem_VisitStep_Sem name_ = (T_VisitStep (\ _lhsIallFromToStates _lhsIallInitStates _lhsIallVisitKinds _lhsIallchildvisit _lhsIavisitdefs _lhsIavisituses _lhsIchildTypes _lhsIchildintros _lhsIfmtMode _lhsIindex _lhsIisLast _lhsIkind _lhsImrules _lhsIoptions _lhsIprevMaxSimRefs _lhsIruledefs _lhsIruleuses _lhsIuseParallel -> (let _lhsOerrors :: (Seq Error) _lhsOruleUsage :: (Map Identifier Int) _lhsOruleKinds :: (Map Identifier (Set VisitKind)) _lhsOdefs :: (Set String) _lhsOuses :: (Map String (Maybe NonLocalAttr)) _lhsOlazyIntras :: (Set String) _lhsOsem_steps :: PP_Doc _lhsOsync_steps :: PP_Doc _lhsOvisitKinds :: (Map VisitIdentifier VisitKind) _lhsOindex :: Int _lhsOisLast :: Bool _lhsOprevMaxSimRefs :: Int -- "src-ag/ExecutionPlan2Hs.ag"(line 778, column 16) _ruleItf = ({-# LINE 778 "src-ag/ExecutionPlan2Hs.ag" #-} Map.findWithDefault (error $ "Rule " ++ show name_ ++ " not found") name_ _lhsImrules {-# LINE 7710 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 779, column 16) __tup5 = ({-# LINE 779 "src-ag/ExecutionPlan2Hs.ag" #-} case _ruleItf _lhsIkind _lhsIfmtMode of Left e -> (Seq.singleton e, empty) Right stmt -> (Seq.empty, stmt) {-# LINE 7718 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 779, column 16) (_lhsOerrors,_) = ({-# LINE 779 "src-ag/ExecutionPlan2Hs.ag" #-} __tup5 {-# LINE 7724 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 779, column 16) (_,_sem_steps) = ({-# LINE 779 "src-ag/ExecutionPlan2Hs.ag" #-} __tup5 {-# LINE 7730 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 1227, column 32) _lhsOruleUsage = ({-# LINE 1227 "src-ag/ExecutionPlan2Hs.ag" #-} Map.singleton name_ 1 {-# LINE 7736 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 1237, column 3) _lhsOruleKinds = ({-# LINE 1237 "src-ag/ExecutionPlan2Hs.ag" #-} Map.singleton name_ (Set.singleton _lhsIkind) {-# LINE 7742 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 1322, column 16) _lhsOdefs = ({-# LINE 1322 "src-ag/ExecutionPlan2Hs.ag" #-} maybe (error "Rule not found") id $ Map.lookup name_ _lhsIruledefs {-# LINE 7748 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 1323, column 16) _lhsOuses = ({-# LINE 1323 "src-ag/ExecutionPlan2Hs.ag" #-} maybe (error "Rule not found") id $ Map.lookup name_ _lhsIruleuses {-# LINE 7754 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- use rule "src-ag/ExecutionPlan2Hs.ag"(line 1335, column 57) _lhsOlazyIntras = ({-# LINE 1335 "src-ag/ExecutionPlan2Hs.ag" #-} Set.empty {-# LINE 7760 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- use rule "src-ag/ExecutionPlan2Hs.ag"(line 776, column 43) _lhsOsem_steps = ({-# LINE 776 "src-ag/ExecutionPlan2Hs.ag" #-} _sem_steps {-# LINE 7766 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- use rule "src-ag/ExecutionPlan2Hs.ag"(line 809, column 44) _lhsOsync_steps = ({-# LINE 809 "src-ag/ExecutionPlan2Hs.ag" #-} empty {-# LINE 7772 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- use rule "src-ag/ExecutionPlan2Hs.ag"(line 1571, column 68) _lhsOvisitKinds = ({-# LINE 1571 "src-ag/ExecutionPlan2Hs.ag" #-} mempty {-# LINE 7778 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (chain) _lhsOindex = ({-# LINE 853 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIindex {-# LINE 7784 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (chain) _lhsOisLast = ({-# LINE 872 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIisLast {-# LINE 7790 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (chain) _lhsOprevMaxSimRefs = ({-# LINE 864 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIprevMaxSimRefs {-# LINE 7796 "src-ag/ExecutionPlan2Hs.hs" #-} ) in ( _lhsOdefs,_lhsOerrors,_lhsOindex,_lhsOisLast,_lhsOlazyIntras,_lhsOprevMaxSimRefs,_lhsOruleKinds,_lhsOruleUsage,_lhsOsem_steps,_lhsOsync_steps,_lhsOuses,_lhsOvisitKinds))) ) sem_VisitStep_Sim :: T_VisitSteps -> T_VisitStep sem_VisitStep_Sim (T_VisitSteps steps_ ) = (T_VisitStep (\ _lhsIallFromToStates _lhsIallInitStates _lhsIallVisitKinds _lhsIallchildvisit _lhsIavisitdefs _lhsIavisituses _lhsIchildTypes _lhsIchildintros _lhsIfmtMode _lhsIindex _lhsIisLast _lhsIkind _lhsImrules _lhsIoptions _lhsIprevMaxSimRefs _lhsIruledefs _lhsIruleuses _lhsIuseParallel -> (let _lhsOsem_steps :: PP_Doc _stepsOindex :: Int _lhsOindex :: Int _lhsOprevMaxSimRefs :: Int _lhsOdefs :: (Set String) _lhsOerrors :: (Seq Error) _lhsOlazyIntras :: (Set String) _lhsOruleKinds :: (Map Identifier (Set VisitKind)) _lhsOruleUsage :: (Map Identifier Int) _lhsOsync_steps :: PP_Doc _lhsOuses :: (Map String (Maybe NonLocalAttr)) _lhsOvisitKinds :: (Map VisitIdentifier VisitKind) _lhsOisLast :: Bool _stepsOallFromToStates :: (Map VisitIdentifier (Int,Int)) _stepsOallInitStates :: (Map NontermIdent Int) _stepsOallVisitKinds :: (Map VisitIdentifier VisitKind) _stepsOallchildvisit :: (Map VisitIdentifier (Identifier -> VisitKind -> Either Error (PP_Doc, PP_Doc))) _stepsOavisitdefs :: (Map VisitIdentifier (Set Identifier)) _stepsOavisituses :: (Map VisitIdentifier (Set Identifier)) _stepsOchildTypes :: (Map Identifier Type) _stepsOchildintros :: (Map Identifier (VisitKind -> FormatMode -> Either Error (PP_Doc, Set String, Map String (Maybe NonLocalAttr)))) _stepsOfmtMode :: FormatMode _stepsOkind :: VisitKind _stepsOmrules :: (Map Identifier (VisitKind -> FormatMode -> Either Error PP_Doc)) _stepsOoptions :: Options _stepsOprevMaxSimRefs :: Int _stepsOruledefs :: (Map Identifier (Set String)) _stepsOruleuses :: (Map Identifier (Map String (Maybe NonLocalAttr))) _stepsOuseParallel :: Bool _stepsIdefs :: (Set String) _stepsIerrors :: (Seq Error) _stepsIindex :: Int _stepsIisLast :: Bool _stepsIlazyIntras :: (Set String) _stepsIprevMaxSimRefs :: Int _stepsIruleKinds :: (Map Identifier (Set VisitKind)) _stepsIruleUsage :: (Map Identifier Int) _stepsIsem_steps :: PP_Doc _stepsIsize :: Int _stepsIsync_steps :: PP_Doc _stepsIuses :: (Map String (Maybe NonLocalAttr)) _stepsIvisitKinds :: (Map VisitIdentifier VisitKind) -- "src-ag/ExecutionPlan2Hs.ag"(line 804, column 16) _lhsOsem_steps = ({-# LINE 804 "src-ag/ExecutionPlan2Hs.ag" #-} _stepsIsem_steps >-< _stepsIsync_steps {-# LINE 7866 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 859, column 22) _stepsOindex = ({-# LINE 859 "src-ag/ExecutionPlan2Hs.ag" #-} 0 {-# LINE 7872 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 860, column 22) _lhsOindex = ({-# LINE 860 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIindex {-# LINE 7878 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 867, column 3) _lhsOprevMaxSimRefs = ({-# LINE 867 "src-ag/ExecutionPlan2Hs.ag" #-} if _useParallel then _lhsIprevMaxSimRefs `max` (_stepsIindex - 1) else _lhsIprevMaxSimRefs {-# LINE 7886 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 882, column 22) _useParallel = ({-# LINE 882 "src-ag/ExecutionPlan2Hs.ag" #-} parallelInvoke _lhsIoptions && _stepsIsize > 1 && _isMonadic {-# LINE 7892 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 883, column 22) _isMonadic = ({-# LINE 883 "src-ag/ExecutionPlan2Hs.ag" #-} case _lhsIkind of VisitMonadic -> True _ -> False {-# LINE 7900 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- use rule "src-ag/ExecutionPlan2Hs.ag"(line 1319, column 38) _lhsOdefs = ({-# LINE 1319 "src-ag/ExecutionPlan2Hs.ag" #-} _stepsIdefs {-# LINE 7906 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- use rule "src-ag/ExecutionPlan2Hs.ag"(line 1609, column 132) _lhsOerrors = ({-# LINE 1609 "src-ag/ExecutionPlan2Hs.ag" #-} _stepsIerrors {-# LINE 7912 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- use rule "src-ag/ExecutionPlan2Hs.ag"(line 1335, column 57) _lhsOlazyIntras = ({-# LINE 1335 "src-ag/ExecutionPlan2Hs.ag" #-} _stepsIlazyIntras {-# LINE 7918 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- use rule "src-ag/ExecutionPlan2Hs.ag"(line 1235, column 56) _lhsOruleKinds = ({-# LINE 1235 "src-ag/ExecutionPlan2Hs.ag" #-} _stepsIruleKinds {-# LINE 7924 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- use rule "src-ag/ExecutionPlan2Hs.ag"(line 1223, column 56) _lhsOruleUsage = ({-# LINE 1223 "src-ag/ExecutionPlan2Hs.ag" #-} _stepsIruleUsage {-# LINE 7930 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- use rule "src-ag/ExecutionPlan2Hs.ag"(line 809, column 44) _lhsOsync_steps = ({-# LINE 809 "src-ag/ExecutionPlan2Hs.ag" #-} _stepsIsync_steps {-# LINE 7936 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- use rule "src-ag/ExecutionPlan2Hs.ag"(line 1320, column 38) _lhsOuses = ({-# LINE 1320 "src-ag/ExecutionPlan2Hs.ag" #-} _stepsIuses {-# LINE 7942 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- use rule "src-ag/ExecutionPlan2Hs.ag"(line 1571, column 68) _lhsOvisitKinds = ({-# LINE 1571 "src-ag/ExecutionPlan2Hs.ag" #-} _stepsIvisitKinds {-# LINE 7948 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (up) _lhsOisLast = ({-# LINE 872 "src-ag/ExecutionPlan2Hs.ag" #-} _stepsIisLast {-# LINE 7954 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _stepsOallFromToStates = ({-# LINE 1527 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIallFromToStates {-# LINE 7960 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _stepsOallInitStates = ({-# LINE 1585 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIallInitStates {-# LINE 7966 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _stepsOallVisitKinds = ({-# LINE 1571 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIallVisitKinds {-# LINE 7972 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _stepsOallchildvisit = ({-# LINE 1169 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIallchildvisit {-# LINE 7978 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _stepsOavisitdefs = ({-# LINE 1312 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIavisitdefs {-# LINE 7984 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _stepsOavisituses = ({-# LINE 1313 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIavisituses {-# LINE 7990 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _stepsOchildTypes = ({-# LINE 1544 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIchildTypes {-# LINE 7996 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _stepsOchildintros = ({-# LINE 892 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIchildintros {-# LINE 8002 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _stepsOfmtMode = ({-# LINE 818 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIfmtMode {-# LINE 8008 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _stepsOkind = ({-# LINE 768 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIkind {-# LINE 8014 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _stepsOmrules = ({-# LINE 775 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsImrules {-# LINE 8020 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _stepsOoptions = ({-# LINE 51 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIoptions {-# LINE 8026 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _stepsOprevMaxSimRefs = ({-# LINE 864 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIprevMaxSimRefs {-# LINE 8032 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _stepsOruledefs = ({-# LINE 1287 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIruledefs {-# LINE 8038 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _stepsOruleuses = ({-# LINE 1288 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIruleuses {-# LINE 8044 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (from local) _stepsOuseParallel = ({-# LINE 880 "src-ag/ExecutionPlan2Hs.ag" #-} _useParallel {-# LINE 8050 "src-ag/ExecutionPlan2Hs.hs" #-} ) ( _stepsIdefs,_stepsIerrors,_stepsIindex,_stepsIisLast,_stepsIlazyIntras,_stepsIprevMaxSimRefs,_stepsIruleKinds,_stepsIruleUsage,_stepsIsem_steps,_stepsIsize,_stepsIsync_steps,_stepsIuses,_stepsIvisitKinds) = steps_ _stepsOallFromToStates _stepsOallInitStates _stepsOallVisitKinds _stepsOallchildvisit _stepsOavisitdefs _stepsOavisituses _stepsOchildTypes _stepsOchildintros _stepsOfmtMode _stepsOindex _stepsOkind _stepsOmrules _stepsOoptions _stepsOprevMaxSimRefs _stepsOruledefs _stepsOruleuses _stepsOuseParallel in ( _lhsOdefs,_lhsOerrors,_lhsOindex,_lhsOisLast,_lhsOlazyIntras,_lhsOprevMaxSimRefs,_lhsOruleKinds,_lhsOruleUsage,_lhsOsem_steps,_lhsOsync_steps,_lhsOuses,_lhsOvisitKinds))) ) -- VisitSteps -------------------------------------------------- {- visit 0: inherited attributes: allFromToStates : Map VisitIdentifier (Int,Int) allInitStates : Map NontermIdent Int allVisitKinds : Map VisitIdentifier VisitKind allchildvisit : Map VisitIdentifier (Identifier -> VisitKind -> Either Error (PP_Doc, PP_Doc)) avisitdefs : Map VisitIdentifier (Set Identifier) avisituses : Map VisitIdentifier (Set Identifier) childTypes : Map Identifier Type childintros : Map Identifier (VisitKind -> FormatMode -> Either Error (PP_Doc, Set String, Map String (Maybe NonLocalAttr))) fmtMode : FormatMode kind : VisitKind mrules : Map Identifier (VisitKind -> FormatMode -> Either Error PP_Doc) options : Options ruledefs : Map Identifier (Set String) ruleuses : Map Identifier (Map String (Maybe NonLocalAttr)) useParallel : Bool chained attributes: index : Int prevMaxSimRefs : Int synthesized attributes: defs : Set String errors : Seq Error isLast : Bool lazyIntras : Set String ruleKinds : Map Identifier (Set VisitKind) ruleUsage : Map Identifier Int sem_steps : PP_Doc size : Int sync_steps : PP_Doc uses : Map String (Maybe NonLocalAttr) visitKinds : Map VisitIdentifier VisitKind alternatives: alternative Cons: child hd : VisitStep child tl : VisitSteps alternative Nil: -} -- cata sem_VisitSteps :: VisitSteps -> T_VisitSteps sem_VisitSteps list = (Prelude.foldr sem_VisitSteps_Cons sem_VisitSteps_Nil (Prelude.map sem_VisitStep list) ) -- semantic domain newtype T_VisitSteps = T_VisitSteps ((Map VisitIdentifier (Int,Int)) -> (Map NontermIdent Int) -> (Map VisitIdentifier VisitKind) -> (Map VisitIdentifier (Identifier -> VisitKind -> Either Error (PP_Doc, PP_Doc))) -> (Map VisitIdentifier (Set Identifier)) -> (Map VisitIdentifier (Set Identifier)) -> (Map Identifier Type) -> (Map Identifier (VisitKind -> FormatMode -> Either Error (PP_Doc, Set String, Map String (Maybe NonLocalAttr)))) -> FormatMode -> Int -> VisitKind -> (Map Identifier (VisitKind -> FormatMode -> Either Error PP_Doc)) -> Options -> Int -> (Map Identifier (Set String)) -> (Map Identifier (Map String (Maybe NonLocalAttr))) -> Bool -> ( (Set String),(Seq Error),Int,Bool,(Set String),Int,(Map Identifier (Set VisitKind)),(Map Identifier Int),PP_Doc,Int,PP_Doc,(Map String (Maybe NonLocalAttr)),(Map VisitIdentifier VisitKind))) data Inh_VisitSteps = Inh_VisitSteps {allFromToStates_Inh_VisitSteps :: (Map VisitIdentifier (Int,Int)),allInitStates_Inh_VisitSteps :: (Map NontermIdent Int),allVisitKinds_Inh_VisitSteps :: (Map VisitIdentifier VisitKind),allchildvisit_Inh_VisitSteps :: (Map VisitIdentifier (Identifier -> VisitKind -> Either Error (PP_Doc, PP_Doc))),avisitdefs_Inh_VisitSteps :: (Map VisitIdentifier (Set Identifier)),avisituses_Inh_VisitSteps :: (Map VisitIdentifier (Set Identifier)),childTypes_Inh_VisitSteps :: (Map Identifier Type),childintros_Inh_VisitSteps :: (Map Identifier (VisitKind -> FormatMode -> Either Error (PP_Doc, Set String, Map String (Maybe NonLocalAttr)))),fmtMode_Inh_VisitSteps :: FormatMode,index_Inh_VisitSteps :: Int,kind_Inh_VisitSteps :: VisitKind,mrules_Inh_VisitSteps :: (Map Identifier (VisitKind -> FormatMode -> Either Error PP_Doc)),options_Inh_VisitSteps :: Options,prevMaxSimRefs_Inh_VisitSteps :: Int,ruledefs_Inh_VisitSteps :: (Map Identifier (Set String)),ruleuses_Inh_VisitSteps :: (Map Identifier (Map String (Maybe NonLocalAttr))),useParallel_Inh_VisitSteps :: Bool} data Syn_VisitSteps = Syn_VisitSteps {defs_Syn_VisitSteps :: (Set String),errors_Syn_VisitSteps :: (Seq Error),index_Syn_VisitSteps :: Int,isLast_Syn_VisitSteps :: Bool,lazyIntras_Syn_VisitSteps :: (Set String),prevMaxSimRefs_Syn_VisitSteps :: Int,ruleKinds_Syn_VisitSteps :: (Map Identifier (Set VisitKind)),ruleUsage_Syn_VisitSteps :: (Map Identifier Int),sem_steps_Syn_VisitSteps :: PP_Doc,size_Syn_VisitSteps :: Int,sync_steps_Syn_VisitSteps :: PP_Doc,uses_Syn_VisitSteps :: (Map String (Maybe NonLocalAttr)),visitKinds_Syn_VisitSteps :: (Map VisitIdentifier VisitKind)} wrap_VisitSteps :: T_VisitSteps -> Inh_VisitSteps -> Syn_VisitSteps wrap_VisitSteps (T_VisitSteps sem ) (Inh_VisitSteps _lhsIallFromToStates _lhsIallInitStates _lhsIallVisitKinds _lhsIallchildvisit _lhsIavisitdefs _lhsIavisituses _lhsIchildTypes _lhsIchildintros _lhsIfmtMode _lhsIindex _lhsIkind _lhsImrules _lhsIoptions _lhsIprevMaxSimRefs _lhsIruledefs _lhsIruleuses _lhsIuseParallel ) = (let ( _lhsOdefs,_lhsOerrors,_lhsOindex,_lhsOisLast,_lhsOlazyIntras,_lhsOprevMaxSimRefs,_lhsOruleKinds,_lhsOruleUsage,_lhsOsem_steps,_lhsOsize,_lhsOsync_steps,_lhsOuses,_lhsOvisitKinds) = sem _lhsIallFromToStates _lhsIallInitStates _lhsIallVisitKinds _lhsIallchildvisit _lhsIavisitdefs _lhsIavisituses _lhsIchildTypes _lhsIchildintros _lhsIfmtMode _lhsIindex _lhsIkind _lhsImrules _lhsIoptions _lhsIprevMaxSimRefs _lhsIruledefs _lhsIruleuses _lhsIuseParallel in (Syn_VisitSteps _lhsOdefs _lhsOerrors _lhsOindex _lhsOisLast _lhsOlazyIntras _lhsOprevMaxSimRefs _lhsOruleKinds _lhsOruleUsage _lhsOsem_steps _lhsOsize _lhsOsync_steps _lhsOuses _lhsOvisitKinds )) sem_VisitSteps_Cons :: T_VisitStep -> T_VisitSteps -> T_VisitSteps sem_VisitSteps_Cons (T_VisitStep hd_ ) (T_VisitSteps tl_ ) = (T_VisitSteps (\ _lhsIallFromToStates _lhsIallInitStates _lhsIallVisitKinds _lhsIallchildvisit _lhsIavisitdefs _lhsIavisituses _lhsIchildTypes _lhsIchildintros _lhsIfmtMode _lhsIindex _lhsIkind _lhsImrules _lhsIoptions _lhsIprevMaxSimRefs _lhsIruledefs _lhsIruleuses _lhsIuseParallel -> (let _lhsOsize :: Int _hdOindex :: Int _tlOindex :: Int _lhsOindex :: Int _lhsOisLast :: Bool _hdOisLast :: Bool _lhsOdefs :: (Set String) _lhsOerrors :: (Seq Error) _lhsOlazyIntras :: (Set String) _lhsOruleKinds :: (Map Identifier (Set VisitKind)) _lhsOruleUsage :: (Map Identifier Int) _lhsOsem_steps :: PP_Doc _lhsOsync_steps :: PP_Doc _lhsOuses :: (Map String (Maybe NonLocalAttr)) _lhsOvisitKinds :: (Map VisitIdentifier VisitKind) _lhsOprevMaxSimRefs :: Int _hdOallFromToStates :: (Map VisitIdentifier (Int,Int)) _hdOallInitStates :: (Map NontermIdent Int) _hdOallVisitKinds :: (Map VisitIdentifier VisitKind) _hdOallchildvisit :: (Map VisitIdentifier (Identifier -> VisitKind -> Either Error (PP_Doc, PP_Doc))) _hdOavisitdefs :: (Map VisitIdentifier (Set Identifier)) _hdOavisituses :: (Map VisitIdentifier (Set Identifier)) _hdOchildTypes :: (Map Identifier Type) _hdOchildintros :: (Map Identifier (VisitKind -> FormatMode -> Either Error (PP_Doc, Set String, Map String (Maybe NonLocalAttr)))) _hdOfmtMode :: FormatMode _hdOkind :: VisitKind _hdOmrules :: (Map Identifier (VisitKind -> FormatMode -> Either Error PP_Doc)) _hdOoptions :: Options _hdOprevMaxSimRefs :: Int _hdOruledefs :: (Map Identifier (Set String)) _hdOruleuses :: (Map Identifier (Map String (Maybe NonLocalAttr))) _hdOuseParallel :: Bool _tlOallFromToStates :: (Map VisitIdentifier (Int,Int)) _tlOallInitStates :: (Map NontermIdent Int) _tlOallVisitKinds :: (Map VisitIdentifier VisitKind) _tlOallchildvisit :: (Map VisitIdentifier (Identifier -> VisitKind -> Either Error (PP_Doc, PP_Doc))) _tlOavisitdefs :: (Map VisitIdentifier (Set Identifier)) _tlOavisituses :: (Map VisitIdentifier (Set Identifier)) _tlOchildTypes :: (Map Identifier Type) _tlOchildintros :: (Map Identifier (VisitKind -> FormatMode -> Either Error (PP_Doc, Set String, Map String (Maybe NonLocalAttr)))) _tlOfmtMode :: FormatMode _tlOkind :: VisitKind _tlOmrules :: (Map Identifier (VisitKind -> FormatMode -> Either Error PP_Doc)) _tlOoptions :: Options _tlOprevMaxSimRefs :: Int _tlOruledefs :: (Map Identifier (Set String)) _tlOruleuses :: (Map Identifier (Map String (Maybe NonLocalAttr))) _tlOuseParallel :: Bool _hdIdefs :: (Set String) _hdIerrors :: (Seq Error) _hdIindex :: Int _hdIisLast :: Bool _hdIlazyIntras :: (Set String) _hdIprevMaxSimRefs :: Int _hdIruleKinds :: (Map Identifier (Set VisitKind)) _hdIruleUsage :: (Map Identifier Int) _hdIsem_steps :: PP_Doc _hdIsync_steps :: PP_Doc _hdIuses :: (Map String (Maybe NonLocalAttr)) _hdIvisitKinds :: (Map VisitIdentifier VisitKind) _tlIdefs :: (Set String) _tlIerrors :: (Seq Error) _tlIindex :: Int _tlIisLast :: Bool _tlIlazyIntras :: (Set String) _tlIprevMaxSimRefs :: Int _tlIruleKinds :: (Map Identifier (Set VisitKind)) _tlIruleUsage :: (Map Identifier Int) _tlIsem_steps :: PP_Doc _tlIsize :: Int _tlIsync_steps :: PP_Doc _tlIuses :: (Map String (Maybe NonLocalAttr)) _tlIvisitKinds :: (Map VisitIdentifier VisitKind) -- "src-ag/ExecutionPlan2Hs.ag"(line 850, column 10) _lhsOsize = ({-# LINE 850 "src-ag/ExecutionPlan2Hs.ag" #-} 1 + _tlIsize {-# LINE 8225 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 855, column 3) _hdOindex = ({-# LINE 855 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIindex {-# LINE 8231 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 856, column 3) _tlOindex = ({-# LINE 856 "src-ag/ExecutionPlan2Hs.ag" #-} 1 + _lhsIindex {-# LINE 8237 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 857, column 3) _lhsOindex = ({-# LINE 857 "src-ag/ExecutionPlan2Hs.ag" #-} _tlIindex {-# LINE 8243 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 876, column 11) _lhsOisLast = ({-# LINE 876 "src-ag/ExecutionPlan2Hs.ag" #-} False {-# LINE 8249 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 877, column 11) _hdOisLast = ({-# LINE 877 "src-ag/ExecutionPlan2Hs.ag" #-} _tlIisLast {-# LINE 8255 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- use rule "src-ag/ExecutionPlan2Hs.ag"(line 1319, column 38) _lhsOdefs = ({-# LINE 1319 "src-ag/ExecutionPlan2Hs.ag" #-} _hdIdefs `Set.union` _tlIdefs {-# LINE 8261 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- use rule "src-ag/ExecutionPlan2Hs.ag"(line 1609, column 132) _lhsOerrors = ({-# LINE 1609 "src-ag/ExecutionPlan2Hs.ag" #-} _hdIerrors Seq.>< _tlIerrors {-# LINE 8267 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- use rule "src-ag/ExecutionPlan2Hs.ag"(line 1335, column 57) _lhsOlazyIntras = ({-# LINE 1335 "src-ag/ExecutionPlan2Hs.ag" #-} _hdIlazyIntras `Set.union` _tlIlazyIntras {-# LINE 8273 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- use rule "src-ag/ExecutionPlan2Hs.ag"(line 1235, column 56) _lhsOruleKinds = ({-# LINE 1235 "src-ag/ExecutionPlan2Hs.ag" #-} _hdIruleKinds `unionWithMappend` _tlIruleKinds {-# LINE 8279 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- use rule "src-ag/ExecutionPlan2Hs.ag"(line 1223, column 56) _lhsOruleUsage = ({-# LINE 1223 "src-ag/ExecutionPlan2Hs.ag" #-} _hdIruleUsage `unionWithSum` _tlIruleUsage {-# LINE 8285 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- use rule "src-ag/ExecutionPlan2Hs.ag"(line 776, column 43) _lhsOsem_steps = ({-# LINE 776 "src-ag/ExecutionPlan2Hs.ag" #-} _hdIsem_steps >-< _tlIsem_steps {-# LINE 8291 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- use rule "src-ag/ExecutionPlan2Hs.ag"(line 809, column 44) _lhsOsync_steps = ({-# LINE 809 "src-ag/ExecutionPlan2Hs.ag" #-} _hdIsync_steps >-< _tlIsync_steps {-# LINE 8297 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- use rule "src-ag/ExecutionPlan2Hs.ag"(line 1320, column 38) _lhsOuses = ({-# LINE 1320 "src-ag/ExecutionPlan2Hs.ag" #-} _hdIuses `Map.union` _tlIuses {-# LINE 8303 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- use rule "src-ag/ExecutionPlan2Hs.ag"(line 1571, column 68) _lhsOvisitKinds = ({-# LINE 1571 "src-ag/ExecutionPlan2Hs.ag" #-} _hdIvisitKinds `mappend` _tlIvisitKinds {-# LINE 8309 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (up) _lhsOprevMaxSimRefs = ({-# LINE 864 "src-ag/ExecutionPlan2Hs.ag" #-} _tlIprevMaxSimRefs {-# LINE 8315 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _hdOallFromToStates = ({-# LINE 1527 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIallFromToStates {-# LINE 8321 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _hdOallInitStates = ({-# LINE 1585 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIallInitStates {-# LINE 8327 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _hdOallVisitKinds = ({-# LINE 1571 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIallVisitKinds {-# LINE 8333 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _hdOallchildvisit = ({-# LINE 1169 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIallchildvisit {-# LINE 8339 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _hdOavisitdefs = ({-# LINE 1312 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIavisitdefs {-# LINE 8345 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _hdOavisituses = ({-# LINE 1313 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIavisituses {-# LINE 8351 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _hdOchildTypes = ({-# LINE 1544 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIchildTypes {-# LINE 8357 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _hdOchildintros = ({-# LINE 892 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIchildintros {-# LINE 8363 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _hdOfmtMode = ({-# LINE 818 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIfmtMode {-# LINE 8369 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _hdOkind = ({-# LINE 768 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIkind {-# LINE 8375 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _hdOmrules = ({-# LINE 775 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsImrules {-# LINE 8381 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _hdOoptions = ({-# LINE 51 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIoptions {-# LINE 8387 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _hdOprevMaxSimRefs = ({-# LINE 864 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIprevMaxSimRefs {-# LINE 8393 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _hdOruledefs = ({-# LINE 1287 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIruledefs {-# LINE 8399 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _hdOruleuses = ({-# LINE 1288 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIruleuses {-# LINE 8405 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _hdOuseParallel = ({-# LINE 880 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIuseParallel {-# LINE 8411 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _tlOallFromToStates = ({-# LINE 1527 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIallFromToStates {-# LINE 8417 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _tlOallInitStates = ({-# LINE 1585 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIallInitStates {-# LINE 8423 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _tlOallVisitKinds = ({-# LINE 1571 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIallVisitKinds {-# LINE 8429 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _tlOallchildvisit = ({-# LINE 1169 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIallchildvisit {-# LINE 8435 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _tlOavisitdefs = ({-# LINE 1312 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIavisitdefs {-# LINE 8441 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _tlOavisituses = ({-# LINE 1313 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIavisituses {-# LINE 8447 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _tlOchildTypes = ({-# LINE 1544 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIchildTypes {-# LINE 8453 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _tlOchildintros = ({-# LINE 892 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIchildintros {-# LINE 8459 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _tlOfmtMode = ({-# LINE 818 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIfmtMode {-# LINE 8465 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _tlOkind = ({-# LINE 768 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIkind {-# LINE 8471 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _tlOmrules = ({-# LINE 775 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsImrules {-# LINE 8477 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _tlOoptions = ({-# LINE 51 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIoptions {-# LINE 8483 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (chain) _tlOprevMaxSimRefs = ({-# LINE 864 "src-ag/ExecutionPlan2Hs.ag" #-} _hdIprevMaxSimRefs {-# LINE 8489 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _tlOruledefs = ({-# LINE 1287 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIruledefs {-# LINE 8495 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _tlOruleuses = ({-# LINE 1288 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIruleuses {-# LINE 8501 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _tlOuseParallel = ({-# LINE 880 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIuseParallel {-# LINE 8507 "src-ag/ExecutionPlan2Hs.hs" #-} ) ( _hdIdefs,_hdIerrors,_hdIindex,_hdIisLast,_hdIlazyIntras,_hdIprevMaxSimRefs,_hdIruleKinds,_hdIruleUsage,_hdIsem_steps,_hdIsync_steps,_hdIuses,_hdIvisitKinds) = hd_ _hdOallFromToStates _hdOallInitStates _hdOallVisitKinds _hdOallchildvisit _hdOavisitdefs _hdOavisituses _hdOchildTypes _hdOchildintros _hdOfmtMode _hdOindex _hdOisLast _hdOkind _hdOmrules _hdOoptions _hdOprevMaxSimRefs _hdOruledefs _hdOruleuses _hdOuseParallel ( _tlIdefs,_tlIerrors,_tlIindex,_tlIisLast,_tlIlazyIntras,_tlIprevMaxSimRefs,_tlIruleKinds,_tlIruleUsage,_tlIsem_steps,_tlIsize,_tlIsync_steps,_tlIuses,_tlIvisitKinds) = tl_ _tlOallFromToStates _tlOallInitStates _tlOallVisitKinds _tlOallchildvisit _tlOavisitdefs _tlOavisituses _tlOchildTypes _tlOchildintros _tlOfmtMode _tlOindex _tlOkind _tlOmrules _tlOoptions _tlOprevMaxSimRefs _tlOruledefs _tlOruleuses _tlOuseParallel in ( _lhsOdefs,_lhsOerrors,_lhsOindex,_lhsOisLast,_lhsOlazyIntras,_lhsOprevMaxSimRefs,_lhsOruleKinds,_lhsOruleUsage,_lhsOsem_steps,_lhsOsize,_lhsOsync_steps,_lhsOuses,_lhsOvisitKinds))) ) sem_VisitSteps_Nil :: T_VisitSteps sem_VisitSteps_Nil = (T_VisitSteps (\ _lhsIallFromToStates _lhsIallInitStates _lhsIallVisitKinds _lhsIallchildvisit _lhsIavisitdefs _lhsIavisituses _lhsIchildTypes _lhsIchildintros _lhsIfmtMode _lhsIindex _lhsIkind _lhsImrules _lhsIoptions _lhsIprevMaxSimRefs _lhsIruledefs _lhsIruleuses _lhsIuseParallel -> (let _lhsOsize :: Int _lhsOisLast :: Bool _lhsOdefs :: (Set String) _lhsOerrors :: (Seq Error) _lhsOlazyIntras :: (Set String) _lhsOruleKinds :: (Map Identifier (Set VisitKind)) _lhsOruleUsage :: (Map Identifier Int) _lhsOsem_steps :: PP_Doc _lhsOsync_steps :: PP_Doc _lhsOuses :: (Map String (Maybe NonLocalAttr)) _lhsOvisitKinds :: (Map VisitIdentifier VisitKind) _lhsOindex :: Int _lhsOprevMaxSimRefs :: Int -- "src-ag/ExecutionPlan2Hs.ag"(line 849, column 10) _lhsOsize = ({-# LINE 849 "src-ag/ExecutionPlan2Hs.ag" #-} 0 {-# LINE 8550 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- "src-ag/ExecutionPlan2Hs.ag"(line 875, column 11) _lhsOisLast = ({-# LINE 875 "src-ag/ExecutionPlan2Hs.ag" #-} True {-# LINE 8556 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- use rule "src-ag/ExecutionPlan2Hs.ag"(line 1319, column 38) _lhsOdefs = ({-# LINE 1319 "src-ag/ExecutionPlan2Hs.ag" #-} Set.empty {-# LINE 8562 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- use rule "src-ag/ExecutionPlan2Hs.ag"(line 1609, column 132) _lhsOerrors = ({-# LINE 1609 "src-ag/ExecutionPlan2Hs.ag" #-} Seq.empty {-# LINE 8568 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- use rule "src-ag/ExecutionPlan2Hs.ag"(line 1335, column 57) _lhsOlazyIntras = ({-# LINE 1335 "src-ag/ExecutionPlan2Hs.ag" #-} Set.empty {-# LINE 8574 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- use rule "src-ag/ExecutionPlan2Hs.ag"(line 1235, column 56) _lhsOruleKinds = ({-# LINE 1235 "src-ag/ExecutionPlan2Hs.ag" #-} Map.empty {-# LINE 8580 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- use rule "src-ag/ExecutionPlan2Hs.ag"(line 1223, column 56) _lhsOruleUsage = ({-# LINE 1223 "src-ag/ExecutionPlan2Hs.ag" #-} Map.empty {-# LINE 8586 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- use rule "src-ag/ExecutionPlan2Hs.ag"(line 776, column 43) _lhsOsem_steps = ({-# LINE 776 "src-ag/ExecutionPlan2Hs.ag" #-} empty {-# LINE 8592 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- use rule "src-ag/ExecutionPlan2Hs.ag"(line 809, column 44) _lhsOsync_steps = ({-# LINE 809 "src-ag/ExecutionPlan2Hs.ag" #-} empty {-# LINE 8598 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- use rule "src-ag/ExecutionPlan2Hs.ag"(line 1320, column 38) _lhsOuses = ({-# LINE 1320 "src-ag/ExecutionPlan2Hs.ag" #-} Map.empty {-# LINE 8604 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- use rule "src-ag/ExecutionPlan2Hs.ag"(line 1571, column 68) _lhsOvisitKinds = ({-# LINE 1571 "src-ag/ExecutionPlan2Hs.ag" #-} mempty {-# LINE 8610 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (chain) _lhsOindex = ({-# LINE 853 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIindex {-# LINE 8616 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (chain) _lhsOprevMaxSimRefs = ({-# LINE 864 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIprevMaxSimRefs {-# LINE 8622 "src-ag/ExecutionPlan2Hs.hs" #-} ) in ( _lhsOdefs,_lhsOerrors,_lhsOindex,_lhsOisLast,_lhsOlazyIntras,_lhsOprevMaxSimRefs,_lhsOruleKinds,_lhsOruleUsage,_lhsOsem_steps,_lhsOsize,_lhsOsync_steps,_lhsOuses,_lhsOvisitKinds))) ) -- Visits ------------------------------------------------------ {- visit 0: inherited attributes: allFromToStates : Map VisitIdentifier (Int,Int) allInhmap : Map NontermIdent Attributes allInitStates : Map NontermIdent Int allSynmap : Map NontermIdent Attributes allVisitKinds : Map VisitIdentifier VisitKind allchildvisit : Map VisitIdentifier (Identifier -> VisitKind -> Either Error (PP_Doc, PP_Doc)) allintramap : Map StateIdentifier (Map String (Maybe NonLocalAttr)) avisitdefs : Map VisitIdentifier (Set Identifier) avisituses : Map VisitIdentifier (Set Identifier) childTypes : Map Identifier Type childintros : Map Identifier (VisitKind -> FormatMode -> Either Error (PP_Doc, Set String, Map String (Maybe NonLocalAttr))) con : ConstructorIdent inhmap : Attributes mrules : Map Identifier (VisitKind -> FormatMode -> Either Error PP_Doc) nextVisits : Map StateIdentifier StateCtx nt : NontermIdent options : Options params : [Identifier] prevVisits : Map StateIdentifier StateCtx ruledefs : Map Identifier (Set String) ruleuses : Map Identifier (Map String (Maybe NonLocalAttr)) synmap : Attributes terminaldefs : Set String synthesized attributes: allvisits : [VisitStateState] childvisit : Map VisitIdentifier (Identifier -> VisitKind -> Either Error (PP_Doc, PP_Doc)) errors : Seq Error fromToStates : Map VisitIdentifier (Int,Int) intramap : Map StateIdentifier (Map String (Maybe NonLocalAttr)) lazyIntras : Set String ruleKinds : Map Identifier (Set VisitKind) ruleUsage : Map Identifier Int sem_visit : [(StateIdentifier,Bool -> PP_Doc)] t_visits : PP_Doc visitKinds : Map VisitIdentifier VisitKind visitdefs : Map VisitIdentifier (Set Identifier) visituses : Map VisitIdentifier (Set Identifier) alternatives: alternative Cons: child hd : Visit child tl : Visits alternative Nil: -} -- cata sem_Visits :: Visits -> T_Visits sem_Visits list = (Prelude.foldr sem_Visits_Cons sem_Visits_Nil (Prelude.map sem_Visit list) ) -- semantic domain newtype T_Visits = T_Visits ((Map VisitIdentifier (Int,Int)) -> (Map NontermIdent Attributes) -> (Map NontermIdent Int) -> (Map NontermIdent Attributes) -> (Map VisitIdentifier VisitKind) -> (Map VisitIdentifier (Identifier -> VisitKind -> Either Error (PP_Doc, PP_Doc))) -> (Map StateIdentifier (Map String (Maybe NonLocalAttr))) -> (Map VisitIdentifier (Set Identifier)) -> (Map VisitIdentifier (Set Identifier)) -> (Map Identifier Type) -> (Map Identifier (VisitKind -> FormatMode -> Either Error (PP_Doc, Set String, Map String (Maybe NonLocalAttr)))) -> ConstructorIdent -> Attributes -> (Map Identifier (VisitKind -> FormatMode -> Either Error PP_Doc)) -> (Map StateIdentifier StateCtx) -> NontermIdent -> Options -> ([Identifier]) -> (Map StateIdentifier StateCtx) -> (Map Identifier (Set String)) -> (Map Identifier (Map String (Maybe NonLocalAttr))) -> Attributes -> (Set String) -> ( ([VisitStateState]),(Map VisitIdentifier (Identifier -> VisitKind -> Either Error (PP_Doc, PP_Doc))),(Seq Error),(Map VisitIdentifier (Int,Int)),(Map StateIdentifier (Map String (Maybe NonLocalAttr))),(Set String),(Map Identifier (Set VisitKind)),(Map Identifier Int),( [(StateIdentifier,Bool -> PP_Doc)] ),PP_Doc,(Map VisitIdentifier VisitKind),(Map VisitIdentifier (Set Identifier)),(Map VisitIdentifier (Set Identifier)))) data Inh_Visits = Inh_Visits {allFromToStates_Inh_Visits :: (Map VisitIdentifier (Int,Int)),allInhmap_Inh_Visits :: (Map NontermIdent Attributes),allInitStates_Inh_Visits :: (Map NontermIdent Int),allSynmap_Inh_Visits :: (Map NontermIdent Attributes),allVisitKinds_Inh_Visits :: (Map VisitIdentifier VisitKind),allchildvisit_Inh_Visits :: (Map VisitIdentifier (Identifier -> VisitKind -> Either Error (PP_Doc, PP_Doc))),allintramap_Inh_Visits :: (Map StateIdentifier (Map String (Maybe NonLocalAttr))),avisitdefs_Inh_Visits :: (Map VisitIdentifier (Set Identifier)),avisituses_Inh_Visits :: (Map VisitIdentifier (Set Identifier)),childTypes_Inh_Visits :: (Map Identifier Type),childintros_Inh_Visits :: (Map Identifier (VisitKind -> FormatMode -> Either Error (PP_Doc, Set String, Map String (Maybe NonLocalAttr)))),con_Inh_Visits :: ConstructorIdent,inhmap_Inh_Visits :: Attributes,mrules_Inh_Visits :: (Map Identifier (VisitKind -> FormatMode -> Either Error PP_Doc)),nextVisits_Inh_Visits :: (Map StateIdentifier StateCtx),nt_Inh_Visits :: NontermIdent,options_Inh_Visits :: Options,params_Inh_Visits :: ([Identifier]),prevVisits_Inh_Visits :: (Map StateIdentifier StateCtx),ruledefs_Inh_Visits :: (Map Identifier (Set String)),ruleuses_Inh_Visits :: (Map Identifier (Map String (Maybe NonLocalAttr))),synmap_Inh_Visits :: Attributes,terminaldefs_Inh_Visits :: (Set String)} data Syn_Visits = Syn_Visits {allvisits_Syn_Visits :: ([VisitStateState]),childvisit_Syn_Visits :: (Map VisitIdentifier (Identifier -> VisitKind -> Either Error (PP_Doc, PP_Doc))),errors_Syn_Visits :: (Seq Error),fromToStates_Syn_Visits :: (Map VisitIdentifier (Int,Int)),intramap_Syn_Visits :: (Map StateIdentifier (Map String (Maybe NonLocalAttr))),lazyIntras_Syn_Visits :: (Set String),ruleKinds_Syn_Visits :: (Map Identifier (Set VisitKind)),ruleUsage_Syn_Visits :: (Map Identifier Int),sem_visit_Syn_Visits :: ( [(StateIdentifier,Bool -> PP_Doc)] ),t_visits_Syn_Visits :: PP_Doc,visitKinds_Syn_Visits :: (Map VisitIdentifier VisitKind),visitdefs_Syn_Visits :: (Map VisitIdentifier (Set Identifier)),visituses_Syn_Visits :: (Map VisitIdentifier (Set Identifier))} wrap_Visits :: T_Visits -> Inh_Visits -> Syn_Visits wrap_Visits (T_Visits sem ) (Inh_Visits _lhsIallFromToStates _lhsIallInhmap _lhsIallInitStates _lhsIallSynmap _lhsIallVisitKinds _lhsIallchildvisit _lhsIallintramap _lhsIavisitdefs _lhsIavisituses _lhsIchildTypes _lhsIchildintros _lhsIcon _lhsIinhmap _lhsImrules _lhsInextVisits _lhsInt _lhsIoptions _lhsIparams _lhsIprevVisits _lhsIruledefs _lhsIruleuses _lhsIsynmap _lhsIterminaldefs ) = (let ( _lhsOallvisits,_lhsOchildvisit,_lhsOerrors,_lhsOfromToStates,_lhsOintramap,_lhsOlazyIntras,_lhsOruleKinds,_lhsOruleUsage,_lhsOsem_visit,_lhsOt_visits,_lhsOvisitKinds,_lhsOvisitdefs,_lhsOvisituses) = sem _lhsIallFromToStates _lhsIallInhmap _lhsIallInitStates _lhsIallSynmap _lhsIallVisitKinds _lhsIallchildvisit _lhsIallintramap _lhsIavisitdefs _lhsIavisituses _lhsIchildTypes _lhsIchildintros _lhsIcon _lhsIinhmap _lhsImrules _lhsInextVisits _lhsInt _lhsIoptions _lhsIparams _lhsIprevVisits _lhsIruledefs _lhsIruleuses _lhsIsynmap _lhsIterminaldefs in (Syn_Visits _lhsOallvisits _lhsOchildvisit _lhsOerrors _lhsOfromToStates _lhsOintramap _lhsOlazyIntras _lhsOruleKinds _lhsOruleUsage _lhsOsem_visit _lhsOt_visits _lhsOvisitKinds _lhsOvisitdefs _lhsOvisituses )) sem_Visits_Cons :: T_Visit -> T_Visits -> T_Visits sem_Visits_Cons (T_Visit hd_ ) (T_Visits tl_ ) = (T_Visits (\ _lhsIallFromToStates _lhsIallInhmap _lhsIallInitStates _lhsIallSynmap _lhsIallVisitKinds _lhsIallchildvisit _lhsIallintramap _lhsIavisitdefs _lhsIavisituses _lhsIchildTypes _lhsIchildintros _lhsIcon _lhsIinhmap _lhsImrules _lhsInextVisits _lhsInt _lhsIoptions _lhsIparams _lhsIprevVisits _lhsIruledefs _lhsIruleuses _lhsIsynmap _lhsIterminaldefs -> (let _lhsOallvisits :: ([VisitStateState]) _lhsOchildvisit :: (Map VisitIdentifier (Identifier -> VisitKind -> Either Error (PP_Doc, PP_Doc))) _lhsOerrors :: (Seq Error) _lhsOfromToStates :: (Map VisitIdentifier (Int,Int)) _lhsOintramap :: (Map StateIdentifier (Map String (Maybe NonLocalAttr))) _lhsOlazyIntras :: (Set String) _lhsOruleKinds :: (Map Identifier (Set VisitKind)) _lhsOruleUsage :: (Map Identifier Int) _lhsOsem_visit :: ( [(StateIdentifier,Bool -> PP_Doc)] ) _lhsOt_visits :: PP_Doc _lhsOvisitKinds :: (Map VisitIdentifier VisitKind) _lhsOvisitdefs :: (Map VisitIdentifier (Set Identifier)) _lhsOvisituses :: (Map VisitIdentifier (Set Identifier)) _hdOallFromToStates :: (Map VisitIdentifier (Int,Int)) _hdOallInhmap :: (Map NontermIdent Attributes) _hdOallInitStates :: (Map NontermIdent Int) _hdOallSynmap :: (Map NontermIdent Attributes) _hdOallVisitKinds :: (Map VisitIdentifier VisitKind) _hdOallchildvisit :: (Map VisitIdentifier (Identifier -> VisitKind -> Either Error (PP_Doc, PP_Doc))) _hdOallintramap :: (Map StateIdentifier (Map String (Maybe NonLocalAttr))) _hdOavisitdefs :: (Map VisitIdentifier (Set Identifier)) _hdOavisituses :: (Map VisitIdentifier (Set Identifier)) _hdOchildTypes :: (Map Identifier Type) _hdOchildintros :: (Map Identifier (VisitKind -> FormatMode -> Either Error (PP_Doc, Set String, Map String (Maybe NonLocalAttr)))) _hdOcon :: ConstructorIdent _hdOinhmap :: Attributes _hdOmrules :: (Map Identifier (VisitKind -> FormatMode -> Either Error PP_Doc)) _hdOnextVisits :: (Map StateIdentifier StateCtx) _hdOnt :: NontermIdent _hdOoptions :: Options _hdOparams :: ([Identifier]) _hdOprevVisits :: (Map StateIdentifier StateCtx) _hdOruledefs :: (Map Identifier (Set String)) _hdOruleuses :: (Map Identifier (Map String (Maybe NonLocalAttr))) _hdOsynmap :: Attributes _hdOterminaldefs :: (Set String) _tlOallFromToStates :: (Map VisitIdentifier (Int,Int)) _tlOallInhmap :: (Map NontermIdent Attributes) _tlOallInitStates :: (Map NontermIdent Int) _tlOallSynmap :: (Map NontermIdent Attributes) _tlOallVisitKinds :: (Map VisitIdentifier VisitKind) _tlOallchildvisit :: (Map VisitIdentifier (Identifier -> VisitKind -> Either Error (PP_Doc, PP_Doc))) _tlOallintramap :: (Map StateIdentifier (Map String (Maybe NonLocalAttr))) _tlOavisitdefs :: (Map VisitIdentifier (Set Identifier)) _tlOavisituses :: (Map VisitIdentifier (Set Identifier)) _tlOchildTypes :: (Map Identifier Type) _tlOchildintros :: (Map Identifier (VisitKind -> FormatMode -> Either Error (PP_Doc, Set String, Map String (Maybe NonLocalAttr)))) _tlOcon :: ConstructorIdent _tlOinhmap :: Attributes _tlOmrules :: (Map Identifier (VisitKind -> FormatMode -> Either Error PP_Doc)) _tlOnextVisits :: (Map StateIdentifier StateCtx) _tlOnt :: NontermIdent _tlOoptions :: Options _tlOparams :: ([Identifier]) _tlOprevVisits :: (Map StateIdentifier StateCtx) _tlOruledefs :: (Map Identifier (Set String)) _tlOruleuses :: (Map Identifier (Map String (Maybe NonLocalAttr))) _tlOsynmap :: Attributes _tlOterminaldefs :: (Set String) _hdIallvisits :: ( VisitStateState ) _hdIchildvisit :: (Map VisitIdentifier (Identifier -> VisitKind -> Either Error (PP_Doc, PP_Doc))) _hdIerrors :: (Seq Error) _hdIfromToStates :: (Map VisitIdentifier (Int,Int)) _hdIintramap :: (Map StateIdentifier (Map String (Maybe NonLocalAttr))) _hdIlazyIntras :: (Set String) _hdIruleKinds :: (Map Identifier (Set VisitKind)) _hdIruleUsage :: (Map Identifier Int) _hdIsem_visit :: ( (StateIdentifier,Bool -> PP_Doc) ) _hdIt_visits :: PP_Doc _hdIvisitKinds :: (Map VisitIdentifier VisitKind) _hdIvisitdefs :: (Map VisitIdentifier (Set Identifier)) _hdIvisituses :: (Map VisitIdentifier (Set Identifier)) _tlIallvisits :: ([VisitStateState]) _tlIchildvisit :: (Map VisitIdentifier (Identifier -> VisitKind -> Either Error (PP_Doc, PP_Doc))) _tlIerrors :: (Seq Error) _tlIfromToStates :: (Map VisitIdentifier (Int,Int)) _tlIintramap :: (Map StateIdentifier (Map String (Maybe NonLocalAttr))) _tlIlazyIntras :: (Set String) _tlIruleKinds :: (Map Identifier (Set VisitKind)) _tlIruleUsage :: (Map Identifier Int) _tlIsem_visit :: ( [(StateIdentifier,Bool -> PP_Doc)] ) _tlIt_visits :: PP_Doc _tlIvisitKinds :: (Map VisitIdentifier VisitKind) _tlIvisitdefs :: (Map VisitIdentifier (Set Identifier)) _tlIvisituses :: (Map VisitIdentifier (Set Identifier)) -- use rule "src-ag/ExecutionPlan2Hs.ag"(line 335, column 29) _lhsOallvisits = ({-# LINE 335 "src-ag/ExecutionPlan2Hs.ag" #-} _hdIallvisits : _tlIallvisits {-# LINE 8826 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- use rule "src-ag/ExecutionPlan2Hs.ag"(line 1167, column 37) _lhsOchildvisit = ({-# LINE 1167 "src-ag/ExecutionPlan2Hs.ag" #-} _hdIchildvisit `Map.union` _tlIchildvisit {-# LINE 8832 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- use rule "src-ag/ExecutionPlan2Hs.ag"(line 1609, column 132) _lhsOerrors = ({-# LINE 1609 "src-ag/ExecutionPlan2Hs.ag" #-} _hdIerrors Seq.>< _tlIerrors {-# LINE 8838 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- use rule "src-ag/ExecutionPlan2Hs.ag"(line 1524, column 22) _lhsOfromToStates = ({-# LINE 1524 "src-ag/ExecutionPlan2Hs.ag" #-} _hdIfromToStates `mappend` _tlIfromToStates {-# LINE 8844 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- use rule "src-ag/ExecutionPlan2Hs.ag"(line 1261, column 34) _lhsOintramap = ({-# LINE 1261 "src-ag/ExecutionPlan2Hs.ag" #-} _hdIintramap `uwMapUnion` _tlIintramap {-# LINE 8850 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- use rule "src-ag/ExecutionPlan2Hs.ag"(line 1335, column 57) _lhsOlazyIntras = ({-# LINE 1335 "src-ag/ExecutionPlan2Hs.ag" #-} _hdIlazyIntras `Set.union` _tlIlazyIntras {-# LINE 8856 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- use rule "src-ag/ExecutionPlan2Hs.ag"(line 1235, column 56) _lhsOruleKinds = ({-# LINE 1235 "src-ag/ExecutionPlan2Hs.ag" #-} _hdIruleKinds `unionWithMappend` _tlIruleKinds {-# LINE 8862 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- use rule "src-ag/ExecutionPlan2Hs.ag"(line 1223, column 56) _lhsOruleUsage = ({-# LINE 1223 "src-ag/ExecutionPlan2Hs.ag" #-} _hdIruleUsage `unionWithSum` _tlIruleUsage {-# LINE 8868 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- use rule "src-ag/ExecutionPlan2Hs.ag"(line 705, column 29) _lhsOsem_visit = ({-# LINE 705 "src-ag/ExecutionPlan2Hs.ag" #-} _hdIsem_visit : _tlIsem_visit {-# LINE 8874 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- use rule "src-ag/ExecutionPlan2Hs.ag"(line 393, column 59) _lhsOt_visits = ({-# LINE 393 "src-ag/ExecutionPlan2Hs.ag" #-} _hdIt_visits >-< _tlIt_visits {-# LINE 8880 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- use rule "src-ag/ExecutionPlan2Hs.ag"(line 1571, column 68) _lhsOvisitKinds = ({-# LINE 1571 "src-ag/ExecutionPlan2Hs.ag" #-} _hdIvisitKinds `mappend` _tlIvisitKinds {-# LINE 8886 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- use rule "src-ag/ExecutionPlan2Hs.ag"(line 1302, column 36) _lhsOvisitdefs = ({-# LINE 1302 "src-ag/ExecutionPlan2Hs.ag" #-} _hdIvisitdefs `uwSetUnion` _tlIvisitdefs {-# LINE 8892 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- use rule "src-ag/ExecutionPlan2Hs.ag"(line 1303, column 36) _lhsOvisituses = ({-# LINE 1303 "src-ag/ExecutionPlan2Hs.ag" #-} _hdIvisituses `uwSetUnion` _tlIvisituses {-# LINE 8898 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _hdOallFromToStates = ({-# LINE 1527 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIallFromToStates {-# LINE 8904 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _hdOallInhmap = ({-# LINE 320 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIallInhmap {-# LINE 8910 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _hdOallInitStates = ({-# LINE 1585 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIallInitStates {-# LINE 8916 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _hdOallSynmap = ({-# LINE 321 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIallSynmap {-# LINE 8922 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _hdOallVisitKinds = ({-# LINE 1571 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIallVisitKinds {-# LINE 8928 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _hdOallchildvisit = ({-# LINE 1166 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIallchildvisit {-# LINE 8934 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _hdOallintramap = ({-# LINE 1260 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIallintramap {-# LINE 8940 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _hdOavisitdefs = ({-# LINE 1312 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIavisitdefs {-# LINE 8946 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _hdOavisituses = ({-# LINE 1313 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIavisituses {-# LINE 8952 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _hdOchildTypes = ({-# LINE 1544 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIchildTypes {-# LINE 8958 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _hdOchildintros = ({-# LINE 892 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIchildintros {-# LINE 8964 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _hdOcon = ({-# LINE 66 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIcon {-# LINE 8970 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _hdOinhmap = ({-# LINE 318 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIinhmap {-# LINE 8976 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _hdOmrules = ({-# LINE 775 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsImrules {-# LINE 8982 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _hdOnextVisits = ({-# LINE 1513 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsInextVisits {-# LINE 8988 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _hdOnt = ({-# LINE 61 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsInt {-# LINE 8994 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _hdOoptions = ({-# LINE 51 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIoptions {-# LINE 9000 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _hdOparams = ({-# LINE 73 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIparams {-# LINE 9006 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _hdOprevVisits = ({-# LINE 1513 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIprevVisits {-# LINE 9012 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _hdOruledefs = ({-# LINE 1287 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIruledefs {-# LINE 9018 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _hdOruleuses = ({-# LINE 1288 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIruleuses {-# LINE 9024 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _hdOsynmap = ({-# LINE 319 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIsynmap {-# LINE 9030 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _hdOterminaldefs = ({-# LINE 1263 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIterminaldefs {-# LINE 9036 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _tlOallFromToStates = ({-# LINE 1527 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIallFromToStates {-# LINE 9042 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _tlOallInhmap = ({-# LINE 320 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIallInhmap {-# LINE 9048 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _tlOallInitStates = ({-# LINE 1585 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIallInitStates {-# LINE 9054 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _tlOallSynmap = ({-# LINE 321 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIallSynmap {-# LINE 9060 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _tlOallVisitKinds = ({-# LINE 1571 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIallVisitKinds {-# LINE 9066 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _tlOallchildvisit = ({-# LINE 1166 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIallchildvisit {-# LINE 9072 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _tlOallintramap = ({-# LINE 1260 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIallintramap {-# LINE 9078 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _tlOavisitdefs = ({-# LINE 1312 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIavisitdefs {-# LINE 9084 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _tlOavisituses = ({-# LINE 1313 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIavisituses {-# LINE 9090 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _tlOchildTypes = ({-# LINE 1544 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIchildTypes {-# LINE 9096 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _tlOchildintros = ({-# LINE 892 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIchildintros {-# LINE 9102 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _tlOcon = ({-# LINE 66 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIcon {-# LINE 9108 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _tlOinhmap = ({-# LINE 318 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIinhmap {-# LINE 9114 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _tlOmrules = ({-# LINE 775 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsImrules {-# LINE 9120 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _tlOnextVisits = ({-# LINE 1513 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsInextVisits {-# LINE 9126 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _tlOnt = ({-# LINE 61 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsInt {-# LINE 9132 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _tlOoptions = ({-# LINE 51 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIoptions {-# LINE 9138 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _tlOparams = ({-# LINE 73 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIparams {-# LINE 9144 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _tlOprevVisits = ({-# LINE 1513 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIprevVisits {-# LINE 9150 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _tlOruledefs = ({-# LINE 1287 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIruledefs {-# LINE 9156 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _tlOruleuses = ({-# LINE 1288 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIruleuses {-# LINE 9162 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _tlOsynmap = ({-# LINE 319 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIsynmap {-# LINE 9168 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- copy rule (down) _tlOterminaldefs = ({-# LINE 1263 "src-ag/ExecutionPlan2Hs.ag" #-} _lhsIterminaldefs {-# LINE 9174 "src-ag/ExecutionPlan2Hs.hs" #-} ) ( _hdIallvisits,_hdIchildvisit,_hdIerrors,_hdIfromToStates,_hdIintramap,_hdIlazyIntras,_hdIruleKinds,_hdIruleUsage,_hdIsem_visit,_hdIt_visits,_hdIvisitKinds,_hdIvisitdefs,_hdIvisituses) = hd_ _hdOallFromToStates _hdOallInhmap _hdOallInitStates _hdOallSynmap _hdOallVisitKinds _hdOallchildvisit _hdOallintramap _hdOavisitdefs _hdOavisituses _hdOchildTypes _hdOchildintros _hdOcon _hdOinhmap _hdOmrules _hdOnextVisits _hdOnt _hdOoptions _hdOparams _hdOprevVisits _hdOruledefs _hdOruleuses _hdOsynmap _hdOterminaldefs ( _tlIallvisits,_tlIchildvisit,_tlIerrors,_tlIfromToStates,_tlIintramap,_tlIlazyIntras,_tlIruleKinds,_tlIruleUsage,_tlIsem_visit,_tlIt_visits,_tlIvisitKinds,_tlIvisitdefs,_tlIvisituses) = tl_ _tlOallFromToStates _tlOallInhmap _tlOallInitStates _tlOallSynmap _tlOallVisitKinds _tlOallchildvisit _tlOallintramap _tlOavisitdefs _tlOavisituses _tlOchildTypes _tlOchildintros _tlOcon _tlOinhmap _tlOmrules _tlOnextVisits _tlOnt _tlOoptions _tlOparams _tlOprevVisits _tlOruledefs _tlOruleuses _tlOsynmap _tlOterminaldefs in ( _lhsOallvisits,_lhsOchildvisit,_lhsOerrors,_lhsOfromToStates,_lhsOintramap,_lhsOlazyIntras,_lhsOruleKinds,_lhsOruleUsage,_lhsOsem_visit,_lhsOt_visits,_lhsOvisitKinds,_lhsOvisitdefs,_lhsOvisituses))) ) sem_Visits_Nil :: T_Visits sem_Visits_Nil = (T_Visits (\ _lhsIallFromToStates _lhsIallInhmap _lhsIallInitStates _lhsIallSynmap _lhsIallVisitKinds _lhsIallchildvisit _lhsIallintramap _lhsIavisitdefs _lhsIavisituses _lhsIchildTypes _lhsIchildintros _lhsIcon _lhsIinhmap _lhsImrules _lhsInextVisits _lhsInt _lhsIoptions _lhsIparams _lhsIprevVisits _lhsIruledefs _lhsIruleuses _lhsIsynmap _lhsIterminaldefs -> (let _lhsOallvisits :: ([VisitStateState]) _lhsOchildvisit :: (Map VisitIdentifier (Identifier -> VisitKind -> Either Error (PP_Doc, PP_Doc))) _lhsOerrors :: (Seq Error) _lhsOfromToStates :: (Map VisitIdentifier (Int,Int)) _lhsOintramap :: (Map StateIdentifier (Map String (Maybe NonLocalAttr))) _lhsOlazyIntras :: (Set String) _lhsOruleKinds :: (Map Identifier (Set VisitKind)) _lhsOruleUsage :: (Map Identifier Int) _lhsOsem_visit :: ( [(StateIdentifier,Bool -> PP_Doc)] ) _lhsOt_visits :: PP_Doc _lhsOvisitKinds :: (Map VisitIdentifier VisitKind) _lhsOvisitdefs :: (Map VisitIdentifier (Set Identifier)) _lhsOvisituses :: (Map VisitIdentifier (Set Identifier)) -- use rule "src-ag/ExecutionPlan2Hs.ag"(line 335, column 29) _lhsOallvisits = ({-# LINE 335 "src-ag/ExecutionPlan2Hs.ag" #-} [] {-# LINE 9223 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- use rule "src-ag/ExecutionPlan2Hs.ag"(line 1167, column 37) _lhsOchildvisit = ({-# LINE 1167 "src-ag/ExecutionPlan2Hs.ag" #-} Map.empty {-# LINE 9229 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- use rule "src-ag/ExecutionPlan2Hs.ag"(line 1609, column 132) _lhsOerrors = ({-# LINE 1609 "src-ag/ExecutionPlan2Hs.ag" #-} Seq.empty {-# LINE 9235 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- use rule "src-ag/ExecutionPlan2Hs.ag"(line 1524, column 22) _lhsOfromToStates = ({-# LINE 1524 "src-ag/ExecutionPlan2Hs.ag" #-} mempty {-# LINE 9241 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- use rule "src-ag/ExecutionPlan2Hs.ag"(line 1261, column 34) _lhsOintramap = ({-# LINE 1261 "src-ag/ExecutionPlan2Hs.ag" #-} Map.empty {-# LINE 9247 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- use rule "src-ag/ExecutionPlan2Hs.ag"(line 1335, column 57) _lhsOlazyIntras = ({-# LINE 1335 "src-ag/ExecutionPlan2Hs.ag" #-} Set.empty {-# LINE 9253 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- use rule "src-ag/ExecutionPlan2Hs.ag"(line 1235, column 56) _lhsOruleKinds = ({-# LINE 1235 "src-ag/ExecutionPlan2Hs.ag" #-} Map.empty {-# LINE 9259 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- use rule "src-ag/ExecutionPlan2Hs.ag"(line 1223, column 56) _lhsOruleUsage = ({-# LINE 1223 "src-ag/ExecutionPlan2Hs.ag" #-} Map.empty {-# LINE 9265 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- use rule "src-ag/ExecutionPlan2Hs.ag"(line 705, column 29) _lhsOsem_visit = ({-# LINE 705 "src-ag/ExecutionPlan2Hs.ag" #-} [] {-# LINE 9271 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- use rule "src-ag/ExecutionPlan2Hs.ag"(line 393, column 59) _lhsOt_visits = ({-# LINE 393 "src-ag/ExecutionPlan2Hs.ag" #-} empty {-# LINE 9277 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- use rule "src-ag/ExecutionPlan2Hs.ag"(line 1571, column 68) _lhsOvisitKinds = ({-# LINE 1571 "src-ag/ExecutionPlan2Hs.ag" #-} mempty {-# LINE 9283 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- use rule "src-ag/ExecutionPlan2Hs.ag"(line 1302, column 36) _lhsOvisitdefs = ({-# LINE 1302 "src-ag/ExecutionPlan2Hs.ag" #-} Map.empty {-# LINE 9289 "src-ag/ExecutionPlan2Hs.hs" #-} ) -- use rule "src-ag/ExecutionPlan2Hs.ag"(line 1303, column 36) _lhsOvisituses = ({-# LINE 1303 "src-ag/ExecutionPlan2Hs.ag" #-} Map.empty {-# LINE 9295 "src-ag/ExecutionPlan2Hs.hs" #-} ) in ( _lhsOallvisits,_lhsOchildvisit,_lhsOerrors,_lhsOfromToStates,_lhsOintramap,_lhsOlazyIntras,_lhsOruleKinds,_lhsOruleUsage,_lhsOsem_visit,_lhsOt_visits,_lhsOvisitKinds,_lhsOvisitdefs,_lhsOvisituses))) )