-- UUAGC 0.9.40.2 (src-ag/Order.ag)
module Order where
{-# LINE 10 "src-ag/Order.ag" #-}

-- From uuagc
import CommonTypes
import Patterns
import ErrorMessages
import AbstractSyntax
import Code hiding (Type)
import qualified Code
import Expression
import Options
import SequentialComputation
import SequentialTypes
import CodeSyntax
import GrammarInfo
import HsToken(HsTokensRoot(HsTokensRoot))
import HsTokenScanner(lexTokens)
import SemHsTokens(sem_HsTokensRoot,wrap_HsTokensRoot, Syn_HsTokensRoot(..),Inh_HsTokensRoot(..))
-- From uulib
import qualified Data.Map as Map
import qualified Data.Set as Set
import qualified Data.Sequence as Seq
import Data.Map(Map)
import Data.Set(Set)
import Data.Sequence(Seq, (><))
import UU.Util.Utils
import UU.Scanner.Position(Pos(..),initPos)
import Data.Foldable(toList)

-- From haskell libraries
import Control.Monad(liftM)
import qualified Data.Array as Array
import Data.Array((!),bounds,inRange)
import Data.List(elemIndex,partition,sort,mapAccumL,find,nubBy,intersperse,groupBy,transpose)
import qualified Data.Tree as Tree
import Data.Maybe
{-# LINE 42 "dist/build/Order.hs" #-}

{-# LINE 2 "src-ag/Patterns.ag" #-}

-- Patterns.ag imports
import UU.Scanner.Position(Pos)
import CommonTypes (ConstructorIdent,Identifier)
{-# LINE 49 "dist/build/Order.hs" #-}

{-# LINE 2 "src-ag/Expression.ag" #-}

import UU.Scanner.Position(Pos)
import HsToken
{-# LINE 55 "dist/build/Order.hs" #-}

{-# LINE 2 "src-ag/AbstractSyntax.ag" #-}

-- AbstractSyntax.ag imports
import Data.Set(Set)
import Data.Map(Map)
import Patterns    (Pattern(..),Patterns)
import Expression  (Expression(..))
import Macro --marcos
import CommonTypes
import ErrorMessages
{-# LINE 67 "dist/build/Order.hs" #-}
{-# LINE 47 "src-ag/Order.ag" #-}

-- Terminates with an error if the key is not in the map
findWithErr1 :: (Ord k, Show k) => String -> k -> Map k a -> a
findWithErr1 s k
  = Map.findWithDefault (error ("findWithErr1 " ++ s ++ ": key " ++ show k ++ " not in map.")) k

findWithErr2 :: (Ord k, Show k, Show a) => k -> Map k a -> a
findWithErr2 k m
  = Map.findWithDefault (error ("findWithErr2: key " ++ show k ++ " not in map: " ++ show m)) k m
{-# LINE 78 "dist/build/Order.hs" #-}

{-# LINE 72 "src-ag/Order.ag" #-}

startsWith :: String -> String -> Bool
startsWith k h = k == take (length k) h
{-# LINE 84 "dist/build/Order.hs" #-}

{-# LINE 139 "src-ag/Order.ag" #-}

getNtName :: Type -> NontermIdent
getNtName (NT nt _ _) = nt
getNtName _           = nullIdent
{-# LINE 91 "dist/build/Order.hs" #-}

{-# LINE 167 "src-ag/Order.ag" #-}

data AltAttr = AltAttr Identifier Identifier Bool
               deriving (Eq, Ord, Show)
{-# LINE 97 "dist/build/Order.hs" #-}

{-# LINE 237 "src-ag/Order.ag" #-}

substSelf nt tp
  = case tp of
      NT n tps defor | n == _SELF -> NT nt tps defor
      _                           -> tp

haskellTupel :: [Type] -> Maybe Type
haskellTupel ts =  Just ( Haskell ( '(' : (concat (intersperse "," (map show ts))) ++ ")" ))
{-# LINE 108 "dist/build/Order.hs" #-}

{-# LINE 688 "src-ag/Order.ag" #-}

swap (a,b) = (b,a)

showPath :: Table CRule -> [Vertex] -> [String]
showPath ruleTable path
  =  let  look a | inRange (bounds ruleTable) a = [showOrigin (ruleTable ! a)]
                 | otherwise = ["Vertex " ++ show a]
          showOrigin cr  | getHasCode cr && getName (getAttr cr) /= "self" = prettyCRule cr ++ " (" ++ show (getPos (getAttr cr)) ++ ")"
                         | otherwise = prettyCRule cr
     in concatMap look path


showPathLocal :: Table CRule -> [Vertex] -> [String]
showPathLocal _ [] = []
showPathLocal ruleTable xs = showP (xs++[-1])
 where showP []         = []
       showP (v1:v2:vs) = let line  = step v1 v2
                              lines = showP vs
                          in  line:lines
       step v1 v2  = " - " ++ a1
        where r1 = ruleTable ! v1
              a1 = show (getAttr  r1)


limitTo :: Int -> [String] -> [String]
limitTo _ [] = []
limitTo 0 _ = ["....etcetera, etcetera...."]
limitTo n (x:xs) = x : limitTo (n-1) xs

showPathNice :: Table CRule -> [Vertex] -> [String]
showPathNice _ [] = []
showPathNice ruleTable xs = limitTo 100 (showP ((-1):xs++[-1]))
 where [maxf, maxa, maxn, maxc] = maxWidths ruleTable (take 100 xs)
       showP []         = []
       showP (v1:v2:vs) = let line  = step v1 v2
                              lines = showP vs
                          in  if null line  then lines  else line:lines
       step v1 v2  |  last &&      first    = induced
                   |  last &&     isSyn r1  = "pass up        "  ++ alignR maxf ""    ++ " " ++ alignL maxa a1 ++ " in " ++ alignR maxn n1 ++ "|" ++ c1 ++ induced
                   |  first&& not(isSyn r2) = "get from above "  ++ alignR maxf ""    ++ " " ++ alignL maxa a2 ++ " in " ++ alignR maxn n2 ++ "|" ++ c2
                   |  last                  = "pass down      "  ++ alignR maxf f1    ++ "." ++ a1                                                      ++ induced
                   |              isSyn r2  = "get from below "  ++ alignR maxf f2    ++ "." ++ alignL maxa a2 ++ " in " ++ alignR maxn n2 ++ "|" ++ c2
                   |  isLocal r1  = if head a1 == '_'
                                         then ""
                                         else "calculate      "  ++ alignR maxf "loc" ++ "." ++ a1
                   |  otherwise             = "pass down      "  ++ alignR maxf f1    ++ "." ++ alignL maxa a1 ++ " to " ++ alignR maxn n2 ++ "|" ++ c2
          where
              first = v1<0
              last  = v2<0
              r1 = ruleTable ! v1
              r2 = ruleTable ! v2
              a1 = show (getAttr  r1)
              a2 = show (getAttr  r2)
              f1 = show (getField r1)
              f2 = show (getField r2)
              n1 = show (getLhsNt r1)
              n2 = show (getLhsNt r2)
              c1 = show (getCon   r1)
              c2 = show (getCon   r2)
              induced | v2== -2   =  " INDUCED dependency to "
                      | otherwise = ""


maxWidths ruleTable vs
  = map maximum (transpose (map getWidth vs))
  where getWidth v | v<0       = [0,0,0,0]
                   | otherwise = map (length . show . ($ (ruleTable!v))) [getField, getAttr, getLhsNt, getCon]

alignL n xs | k<n       = xs ++ replicate (n-k) ' '
            | otherwise = xs
              where k = length xs

alignR n xs | k<n       = replicate (n-k) ' ' ++ xs
            | otherwise = xs
              where k = length xs

localCycleErr :: Table CRule -> Bool -> Route -> Error
localCycleErr ruleTable o_visit (s:path)
  =  let cr = ruleTable ! s
         attr = getAttr cr
         nt = getLhsNt cr
         con = getCon cr
     in LocalCirc nt con attr o_visit (showPathLocal ruleTable path)

instCycleErr :: Table CRule -> Bool -> Route -> Error
instCycleErr ruleTable o_visit (s:path)
  =  let cr = ruleTable ! s
         attr = getAttr cr
         nt = getLhsNt cr
         con = getCon cr
     in InstCirc nt con attr o_visit (showPathLocal ruleTable path)

directCycleErrs :: Table NTAttr -> Table CRule -> Bool -> [EdgeRoutes] -> [Error]
directCycleErrs attrTable ruleTable o_visit xs
  = let getNont v = case attrTable ! v of
                      NTASyn nt _ _ -> nt
                      NTAInh nt _ _ -> nt
        getAttr v = case attrTable ! v of
                      NTASyn _ a _  -> a
                      NTAInh _ a _  -> a
        sameNont ((v1,_),_,_) ((v2,_),_,_) =  getNont v1 == getNont v2
        procCycle ((v1,v2),p1,p2) = ((getAttr v1, getAttr v2), showPathNice ruleTable p1, showPathNice ruleTable p2)
        wrapGroup gr@(((v1,_),_,_):_) = DirectCirc (getNont v1) o_visit (map procCycle gr)
    in  map wrapGroup (groupBy sameNont xs)

inducedCycleErrs :: Table NTAttr -> Table CRule -> CInterfaceMap -> [EdgeRoutes] -> [Error]
inducedCycleErrs attrTable ruleTable cim xs
  = let getNont v = case attrTable ! v of
                      NTASyn nt _ _ -> nt
                      NTAInh nt _ _ -> nt
        getAttr v = case attrTable ! v of
                      NTASyn _ a _  -> a
                      NTAInh _ a _  -> a
        sameNont ((v1,_),_,_) ((v2,_),_,_) =  getNont v1 == getNont v2
        procCycle ((v1,v2),p1,p2) = ((getAttr v1, getAttr v2), showPathNice ruleTable p1, showPathNice ruleTable p2)
        wrapGroup gr@(((v1,_),_,_):_) = InducedCirc (getNont v1) (findWithErr1 "inducedCycleErr.cinter" (getNont v1) cim) (map procCycle gr)
    in  map wrapGroup (groupBy sameNont xs)
{-# LINE 228 "dist/build/Order.hs" #-}
-- Child -------------------------------------------------------
{-
   visit 0:
      inherited attributes:
         allfields            : [(Identifier,Type,ChildKind)]
         allnts               : [Identifier]
         attrs                : [(Identifier,Identifier)]
         con                  : Identifier
         inh                  : Attributes
         inhMap               : Map Identifier Attributes
         mergeMap             : Map Identifier (Identifier,[Identifier])
         nt                   : Identifier
         o_unbox              : Bool
         syn                  : Attributes
         synMap               : Map Identifier Attributes
      synthesized attributes:
         attributes           : [(Identifier,Attributes,Attributes)]
         collectChildrenInhs  : Map Identifier Attributes 
         collectChildrenSyns  : Map Identifier Attributes 
         errors               : Seq Error
         field                : (Identifier,Type,ChildKind)
         gathAltAttrs         : [AltAttr]
         gathRules            : Seq CRule
         inhs                 : Seq (Identifier,Attributes)
         nts                  : Seq (Identifier,NontermIdent)
         singlevisits         : [CRule]
         terminals            : [Identifier]
   alternatives:
      alternative Child:
         child name           : {Identifier}
         child tp             : {Type}
         child kind           : {ChildKind}
         visit 0:
            local maptolocal  : _
            local gathRules   : _
            local chnt        : _
            local inh         : _
            local syn         : _
-}
-- cata
sem_Child :: Child ->
             T_Child
sem_Child (Child _name _tp _kind) =
    (sem_Child_Child _name _tp _kind)
-- semantic domain
newtype T_Child = T_Child (([(Identifier,Type,ChildKind)]) ->
                           ([Identifier]) ->
                           ([(Identifier,Identifier)]) ->
                           Identifier ->
                           Attributes ->
                           (Map Identifier Attributes) ->
                           (Map Identifier (Identifier,[Identifier])) ->
                           Identifier ->
                           Bool ->
                           Attributes ->
                           (Map Identifier Attributes) ->
                           ( ([(Identifier,Attributes,Attributes)]),(Map Identifier Attributes ),(Map Identifier Attributes ),(Seq Error),((Identifier,Type,ChildKind)),([AltAttr]),(Seq CRule),(Seq (Identifier,Attributes)),(Seq (Identifier,NontermIdent)),([CRule]),([Identifier])))
data Inh_Child = Inh_Child {allfields_Inh_Child :: !(([(Identifier,Type,ChildKind)])),allnts_Inh_Child :: !(([Identifier])),attrs_Inh_Child :: !(([(Identifier,Identifier)])),con_Inh_Child :: !(Identifier),inh_Inh_Child :: !(Attributes),inhMap_Inh_Child :: !((Map Identifier Attributes)),mergeMap_Inh_Child :: !((Map Identifier (Identifier,[Identifier]))),nt_Inh_Child :: !(Identifier),o_unbox_Inh_Child :: !(Bool),syn_Inh_Child :: !(Attributes),synMap_Inh_Child :: !((Map Identifier Attributes))}
data Syn_Child = Syn_Child {attributes_Syn_Child :: !(([(Identifier,Attributes,Attributes)])),collectChildrenInhs_Syn_Child :: !((Map Identifier Attributes )),collectChildrenSyns_Syn_Child :: !((Map Identifier Attributes )),errors_Syn_Child :: !((Seq Error)),field_Syn_Child :: !(((Identifier,Type,ChildKind))),gathAltAttrs_Syn_Child :: !(([AltAttr])),gathRules_Syn_Child :: !((Seq CRule)),inhs_Syn_Child :: !((Seq (Identifier,Attributes))),nts_Syn_Child :: !((Seq (Identifier,NontermIdent))),singlevisits_Syn_Child :: !(([CRule])),terminals_Syn_Child :: !(([Identifier]))}
wrap_Child :: T_Child ->
              Inh_Child ->
              Syn_Child
wrap_Child (T_Child sem) (Inh_Child _lhsIallfields _lhsIallnts _lhsIattrs _lhsIcon _lhsIinh _lhsIinhMap _lhsImergeMap _lhsInt _lhsIo_unbox _lhsIsyn _lhsIsynMap) =
    (let ( _lhsOattributes,_lhsOcollectChildrenInhs,_lhsOcollectChildrenSyns,_lhsOerrors,_lhsOfield,_lhsOgathAltAttrs,_lhsOgathRules,_lhsOinhs,_lhsOnts,_lhsOsinglevisits,_lhsOterminals) = sem _lhsIallfields _lhsIallnts _lhsIattrs _lhsIcon _lhsIinh _lhsIinhMap _lhsImergeMap _lhsInt _lhsIo_unbox _lhsIsyn _lhsIsynMap
     in  (Syn_Child _lhsOattributes _lhsOcollectChildrenInhs _lhsOcollectChildrenSyns _lhsOerrors _lhsOfield _lhsOgathAltAttrs _lhsOgathRules _lhsOinhs _lhsOnts _lhsOsinglevisits _lhsOterminals))
sem_Child_Child :: Identifier ->
                   Type ->
                   ChildKind ->
                   T_Child
sem_Child_Child name_ tp_ kind_ =
    (T_Child (\ _lhsIallfields
                _lhsIallnts
                _lhsIattrs
                _lhsIcon
                _lhsIinh
                _lhsIinhMap
                _lhsImergeMap
                _lhsInt
                _lhsIo_unbox
                _lhsIsyn
                _lhsIsynMap ->
                  (let _lhsOgathAltAttrs :: ([AltAttr])
                       _lhsOnts :: (Seq (Identifier,NontermIdent))
                       _lhsOinhs :: (Seq (Identifier,Attributes))
                       _lhsOcollectChildrenSyns :: (Map Identifier Attributes )
                       _lhsOcollectChildrenInhs :: (Map Identifier Attributes )
                       _lhsOsinglevisits :: ([CRule])
                       _lhsOterminals :: ([Identifier])
                       _lhsOattributes :: ([(Identifier,Attributes,Attributes)])
                       _lhsOfield :: ((Identifier,Type,ChildKind))
                       _lhsOerrors :: (Seq Error)
                       _lhsOgathRules :: (Seq CRule)
                       -- "src-ag/Order.ag"(line 178, column 13)
                       _maptolocal =
                           ({-# LINE 178 "src-ag/Order.ag" #-}
                            case tp_ of
                              NT nt _ _ -> Map.null _syn
                              _         -> True
                            {-# LINE 327 "dist/build/Order" #-}
                            )
                       -- "src-ag/Order.ag"(line 181, column 13)
                       _lhsOgathAltAttrs =
                           ({-# LINE 181 "src-ag/Order.ag" #-}
                            if  _maptolocal
                                then [ AltAttr _LOC name_ True ]
                                else [ AltAttr name_ syn True | syn <- Map.keys _syn     ]
                            {-# LINE 335 "dist/build/Order" #-}
                            )
                       -- "src-ag/Order.ag"(line 196, column 13)
                       _lhsOnts =
                           ({-# LINE 196 "src-ag/Order.ag" #-}
                            Seq.singleton (name_,getNtName tp_)
                            {-# LINE 341 "dist/build/Order" #-}
                            )
                       -- "src-ag/Order.ag"(line 197, column 13)
                       _lhsOinhs =
                           ({-# LINE 197 "src-ag/Order.ag" #-}
                            Seq.singleton (name_,_inh    )
                            {-# LINE 347 "dist/build/Order" #-}
                            )
                       -- "src-ag/Order.ag"(line 213, column 13)
                       _gathRules =
                           ({-# LINE 213 "src-ag/Order.ag" #-}
                            if  _maptolocal
                                then Seq.singleton (cRuleTerminal name_ _lhsInt _lhsIcon tp_)
                                else Seq.fromList [ cRuleRhsSyn syn _lhsInt _lhsIcon tp name_ (getNtName tp_) | (syn,tp) <- Map.assocs _syn    ]
                            {-# LINE 355 "dist/build/Order" #-}
                            )
                       -- "src-ag/Order.ag"(line 345, column 12)
                       _lhsOcollectChildrenSyns =
                           ({-# LINE 345 "src-ag/Order.ag" #-}
                            Map.singleton name_ _syn
                            {-# LINE 361 "dist/build/Order" #-}
                            )
                       -- "src-ag/Order.ag"(line 346, column 12)
                       _lhsOcollectChildrenInhs =
                           ({-# LINE 346 "src-ag/Order.ag" #-}
                            Map.singleton name_ _inh
                            {-# LINE 367 "dist/build/Order" #-}
                            )
                       -- "src-ag/Order.ag"(line 614, column 11)
                       _lhsOsinglevisits =
                           ({-# LINE 614 "src-ag/Order.ag" #-}
                            if  _maptolocal
                                then []
                                else [CChildVisit name_ (getNtName tp_) 0 _inh     _syn     True]
                            {-# LINE 375 "dist/build/Order" #-}
                            )
                       -- "src-ag/Order.ag"(line 639, column 11)
                       _lhsOterminals =
                           ({-# LINE 639 "src-ag/Order.ag" #-}
                            if _maptolocal
                            then [name_]
                            else []
                            {-# LINE 383 "dist/build/Order" #-}
                            )
                       -- "src-ag/Order.ag"(line 668, column 11)
                       _lhsOattributes =
                           ({-# LINE 668 "src-ag/Order.ag" #-}
                            [(name_, _inh    , _syn    )]
                            {-# LINE 389 "dist/build/Order" #-}
                            )
                       -- "src-ag/Order.ag"(line 672, column 11)
                       _lhsOfield =
                           ({-# LINE 672 "src-ag/Order.ag" #-}
                            (name_, tp_, kind_)
                            {-# LINE 395 "dist/build/Order" #-}
                            )
                       -- "src-ag/DistChildAttr.ag"(line 19, column 11)
                       _chnt =
                           ({-# LINE 19 "src-ag/DistChildAttr.ag" #-}
                            case tp_ of
                              NT nt _ _ -> nt
                              Self      -> error ("The type of child " ++ show name_ ++ " should not be a Self type.")
                              Haskell t -> identifier ""
                            {-# LINE 404 "dist/build/Order" #-}
                            )
                       -- "src-ag/DistChildAttr.ag"(line 23, column 11)
                       _inh =
                           ({-# LINE 23 "src-ag/DistChildAttr.ag" #-}
                            Map.findWithDefault Map.empty _chnt     _lhsIinhMap
                            {-# LINE 410 "dist/build/Order" #-}
                            )
                       -- "src-ag/DistChildAttr.ag"(line 24, column 11)
                       _syn =
                           ({-# LINE 24 "src-ag/DistChildAttr.ag" #-}
                            Map.findWithDefault Map.empty _chnt     _lhsIsynMap
                            {-# LINE 416 "dist/build/Order" #-}
                            )
                       -- use rule "src-ag/Order.ag"(line 85, column 70)
                       _lhsOerrors =
                           ({-# LINE 85 "src-ag/Order.ag" #-}
                            Seq.empty
                            {-# LINE 422 "dist/build/Order" #-}
                            )
                       -- use rule "src-ag/Order.ag"(line 207, column 23)
                       _lhsOgathRules =
                           ({-# LINE 207 "src-ag/Order.ag" #-}
                            _gathRules
                            {-# LINE 428 "dist/build/Order" #-}
                            )
                   in  ( _lhsOattributes,_lhsOcollectChildrenInhs,_lhsOcollectChildrenSyns,_lhsOerrors,_lhsOfield,_lhsOgathAltAttrs,_lhsOgathRules,_lhsOinhs,_lhsOnts,_lhsOsinglevisits,_lhsOterminals))))
-- Children ----------------------------------------------------
{-
   visit 0:
      inherited attributes:
         allfields            : [(Identifier,Type,ChildKind)]
         allnts               : [Identifier]
         attrs                : [(Identifier,Identifier)]
         con                  : Identifier
         inh                  : Attributes
         inhMap               : Map Identifier Attributes
         mergeMap             : Map Identifier (Identifier,[Identifier])
         nt                   : Identifier
         o_unbox              : Bool
         syn                  : Attributes
         synMap               : Map Identifier Attributes
      synthesized attributes:
         attributes           : [(Identifier,Attributes,Attributes)]
         collectChildrenInhs  : Map Identifier Attributes 
         collectChildrenSyns  : Map Identifier Attributes 
         errors               : Seq Error
         fields               : [(Identifier,Type,ChildKind)]
         gathAltAttrs         : [AltAttr]
         gathRules            : Seq CRule
         inhs                 : Seq (Identifier,Attributes)
         nts                  : Seq (Identifier,NontermIdent)
         singlevisits         : [CRule]
         terminals            : [Identifier]
   alternatives:
      alternative Cons:
         child hd             : Child 
         child tl             : Children 
      alternative Nil:
-}
-- cata
sem_Children :: Children ->
                T_Children
sem_Children list =
    (Prelude.foldr sem_Children_Cons sem_Children_Nil (Prelude.map sem_Child list))
-- semantic domain
newtype T_Children = T_Children (([(Identifier,Type,ChildKind)]) ->
                                 ([Identifier]) ->
                                 ([(Identifier,Identifier)]) ->
                                 Identifier ->
                                 Attributes ->
                                 (Map Identifier Attributes) ->
                                 (Map Identifier (Identifier,[Identifier])) ->
                                 Identifier ->
                                 Bool ->
                                 Attributes ->
                                 (Map Identifier Attributes) ->
                                 ( ([(Identifier,Attributes,Attributes)]),(Map Identifier Attributes ),(Map Identifier Attributes ),(Seq Error),([(Identifier,Type,ChildKind)]),([AltAttr]),(Seq CRule),(Seq (Identifier,Attributes)),(Seq (Identifier,NontermIdent)),([CRule]),([Identifier])))
data Inh_Children = Inh_Children {allfields_Inh_Children :: !(([(Identifier,Type,ChildKind)])),allnts_Inh_Children :: !(([Identifier])),attrs_Inh_Children :: !(([(Identifier,Identifier)])),con_Inh_Children :: !(Identifier),inh_Inh_Children :: !(Attributes),inhMap_Inh_Children :: !((Map Identifier Attributes)),mergeMap_Inh_Children :: !((Map Identifier (Identifier,[Identifier]))),nt_Inh_Children :: !(Identifier),o_unbox_Inh_Children :: !(Bool),syn_Inh_Children :: !(Attributes),synMap_Inh_Children :: !((Map Identifier Attributes))}
data Syn_Children = Syn_Children {attributes_Syn_Children :: !(([(Identifier,Attributes,Attributes)])),collectChildrenInhs_Syn_Children :: !((Map Identifier Attributes )),collectChildrenSyns_Syn_Children :: !((Map Identifier Attributes )),errors_Syn_Children :: !((Seq Error)),fields_Syn_Children :: !(([(Identifier,Type,ChildKind)])),gathAltAttrs_Syn_Children :: !(([AltAttr])),gathRules_Syn_Children :: !((Seq CRule)),inhs_Syn_Children :: !((Seq (Identifier,Attributes))),nts_Syn_Children :: !((Seq (Identifier,NontermIdent))),singlevisits_Syn_Children :: !(([CRule])),terminals_Syn_Children :: !(([Identifier]))}
wrap_Children :: T_Children ->
                 Inh_Children ->
                 Syn_Children
wrap_Children (T_Children sem) (Inh_Children _lhsIallfields _lhsIallnts _lhsIattrs _lhsIcon _lhsIinh _lhsIinhMap _lhsImergeMap _lhsInt _lhsIo_unbox _lhsIsyn _lhsIsynMap) =
    (let ( _lhsOattributes,_lhsOcollectChildrenInhs,_lhsOcollectChildrenSyns,_lhsOerrors,_lhsOfields,_lhsOgathAltAttrs,_lhsOgathRules,_lhsOinhs,_lhsOnts,_lhsOsinglevisits,_lhsOterminals) = sem _lhsIallfields _lhsIallnts _lhsIattrs _lhsIcon _lhsIinh _lhsIinhMap _lhsImergeMap _lhsInt _lhsIo_unbox _lhsIsyn _lhsIsynMap
     in  (Syn_Children _lhsOattributes _lhsOcollectChildrenInhs _lhsOcollectChildrenSyns _lhsOerrors _lhsOfields _lhsOgathAltAttrs _lhsOgathRules _lhsOinhs _lhsOnts _lhsOsinglevisits _lhsOterminals))
sem_Children_Cons :: T_Child ->
                     T_Children ->
                     T_Children
sem_Children_Cons (T_Child hd_) (T_Children tl_) =
    (T_Children (\ _lhsIallfields
                   _lhsIallnts
                   _lhsIattrs
                   _lhsIcon
                   _lhsIinh
                   _lhsIinhMap
                   _lhsImergeMap
                   _lhsInt
                   _lhsIo_unbox
                   _lhsIsyn
                   _lhsIsynMap ->
                     (let _lhsOfields :: ([(Identifier,Type,ChildKind)])
                          _lhsOattributes :: ([(Identifier,Attributes,Attributes)])
                          _lhsOcollectChildrenInhs :: (Map Identifier Attributes )
                          _lhsOcollectChildrenSyns :: (Map Identifier Attributes )
                          _lhsOerrors :: (Seq Error)
                          _lhsOgathAltAttrs :: ([AltAttr])
                          _lhsOgathRules :: (Seq CRule)
                          _lhsOinhs :: (Seq (Identifier,Attributes))
                          _lhsOnts :: (Seq (Identifier,NontermIdent))
                          _lhsOsinglevisits :: ([CRule])
                          _lhsOterminals :: ([Identifier])
                          _hdOallfields :: ([(Identifier,Type,ChildKind)])
                          _hdOallnts :: ([Identifier])
                          _hdOattrs :: ([(Identifier,Identifier)])
                          _hdOcon :: Identifier
                          _hdOinh :: Attributes
                          _hdOinhMap :: (Map Identifier Attributes)
                          _hdOmergeMap :: (Map Identifier (Identifier,[Identifier]))
                          _hdOnt :: Identifier
                          _hdOo_unbox :: Bool
                          _hdOsyn :: Attributes
                          _hdOsynMap :: (Map Identifier Attributes)
                          _tlOallfields :: ([(Identifier,Type,ChildKind)])
                          _tlOallnts :: ([Identifier])
                          _tlOattrs :: ([(Identifier,Identifier)])
                          _tlOcon :: Identifier
                          _tlOinh :: Attributes
                          _tlOinhMap :: (Map Identifier Attributes)
                          _tlOmergeMap :: (Map Identifier (Identifier,[Identifier]))
                          _tlOnt :: Identifier
                          _tlOo_unbox :: Bool
                          _tlOsyn :: Attributes
                          _tlOsynMap :: (Map Identifier Attributes)
                          _hdIattributes :: ([(Identifier,Attributes,Attributes)])
                          _hdIcollectChildrenInhs :: (Map Identifier Attributes )
                          _hdIcollectChildrenSyns :: (Map Identifier Attributes )
                          _hdIerrors :: (Seq Error)
                          _hdIfield :: ((Identifier,Type,ChildKind))
                          _hdIgathAltAttrs :: ([AltAttr])
                          _hdIgathRules :: (Seq CRule)
                          _hdIinhs :: (Seq (Identifier,Attributes))
                          _hdInts :: (Seq (Identifier,NontermIdent))
                          _hdIsinglevisits :: ([CRule])
                          _hdIterminals :: ([Identifier])
                          _tlIattributes :: ([(Identifier,Attributes,Attributes)])
                          _tlIcollectChildrenInhs :: (Map Identifier Attributes )
                          _tlIcollectChildrenSyns :: (Map Identifier Attributes )
                          _tlIerrors :: (Seq Error)
                          _tlIfields :: ([(Identifier,Type,ChildKind)])
                          _tlIgathAltAttrs :: ([AltAttr])
                          _tlIgathRules :: (Seq CRule)
                          _tlIinhs :: (Seq (Identifier,Attributes))
                          _tlInts :: (Seq (Identifier,NontermIdent))
                          _tlIsinglevisits :: ([CRule])
                          _tlIterminals :: ([Identifier])
                          -- "src-ag/Order.ag"(line 675, column 11)
                          _lhsOfields =
                              ({-# LINE 675 "src-ag/Order.ag" #-}
                               _hdIfield : _tlIfields
                               {-# LINE 564 "dist/build/Order" #-}
                               )
                          -- use rule "src-ag/Order.ag"(line 666, column 32)
                          _lhsOattributes =
                              ({-# LINE 666 "src-ag/Order.ag" #-}
                               _hdIattributes ++ _tlIattributes
                               {-# LINE 570 "dist/build/Order" #-}
                               )
                          -- use rule "src-ag/Order.ag"(line 343, column 68)
                          _lhsOcollectChildrenInhs =
                              ({-# LINE 343 "src-ag/Order.ag" #-}
                               _hdIcollectChildrenInhs `Map.union` _tlIcollectChildrenInhs
                               {-# LINE 576 "dist/build/Order" #-}
                               )
                          -- use rule "src-ag/Order.ag"(line 343, column 68)
                          _lhsOcollectChildrenSyns =
                              ({-# LINE 343 "src-ag/Order.ag" #-}
                               _hdIcollectChildrenSyns `Map.union` _tlIcollectChildrenSyns
                               {-# LINE 582 "dist/build/Order" #-}
                               )
                          -- use rule "src-ag/Order.ag"(line 85, column 70)
                          _lhsOerrors =
                              ({-# LINE 85 "src-ag/Order.ag" #-}
                               _hdIerrors Seq.>< _tlIerrors
                               {-# LINE 588 "dist/build/Order" #-}
                               )
                          -- use rule "src-ag/Order.ag"(line 171, column 68)
                          _lhsOgathAltAttrs =
                              ({-# LINE 171 "src-ag/Order.ag" #-}
                               _hdIgathAltAttrs ++ _tlIgathAltAttrs
                               {-# LINE 594 "dist/build/Order" #-}
                               )
                          -- use rule "src-ag/Order.ag"(line 207, column 23)
                          _lhsOgathRules =
                              ({-# LINE 207 "src-ag/Order.ag" #-}
                               _hdIgathRules Seq.>< _tlIgathRules
                               {-# LINE 600 "dist/build/Order" #-}
                               )
                          -- use rule "src-ag/Order.ag"(line 194, column 20)
                          _lhsOinhs =
                              ({-# LINE 194 "src-ag/Order.ag" #-}
                               _hdIinhs Seq.>< _tlIinhs
                               {-# LINE 606 "dist/build/Order" #-}
                               )
                          -- use rule "src-ag/Order.ag"(line 193, column 19)
                          _lhsOnts =
                              ({-# LINE 193 "src-ag/Order.ag" #-}
                               _hdInts Seq.>< _tlInts
                               {-# LINE 612 "dist/build/Order" #-}
                               )
                          -- use rule "src-ag/Order.ag"(line 612, column 40)
                          _lhsOsinglevisits =
                              ({-# LINE 612 "src-ag/Order.ag" #-}
                               _hdIsinglevisits ++ _tlIsinglevisits
                               {-# LINE 618 "dist/build/Order" #-}
                               )
                          -- use rule "src-ag/Order.ag"(line 637, column 38)
                          _lhsOterminals =
                              ({-# LINE 637 "src-ag/Order.ag" #-}
                               _hdIterminals ++ _tlIterminals
                               {-# LINE 624 "dist/build/Order" #-}
                               )
                          -- copy rule (down)
                          _hdOallfields =
                              ({-# LINE 655 "src-ag/Order.ag" #-}
                               _lhsIallfields
                               {-# LINE 630 "dist/build/Order" #-}
                               )
                          -- copy rule (down)
                          _hdOallnts =
                              ({-# LINE 648 "src-ag/Order.ag" #-}
                               _lhsIallnts
                               {-# LINE 636 "dist/build/Order" #-}
                               )
                          -- copy rule (down)
                          _hdOattrs =
                              ({-# LINE 655 "src-ag/Order.ag" #-}
                               _lhsIattrs
                               {-# LINE 642 "dist/build/Order" #-}
                               )
                          -- copy rule (down)
                          _hdOcon =
                              ({-# LINE 91 "src-ag/Order.ag" #-}
                               _lhsIcon
                               {-# LINE 648 "dist/build/Order" #-}
                               )
                          -- copy rule (down)
                          _hdOinh =
                              ({-# LINE 90 "src-ag/Order.ag" #-}
                               _lhsIinh
                               {-# LINE 654 "dist/build/Order" #-}
                               )
                          -- copy rule (down)
                          _hdOinhMap =
                              ({-# LINE 12 "src-ag/DistChildAttr.ag" #-}
                               _lhsIinhMap
                               {-# LINE 660 "dist/build/Order" #-}
                               )
                          -- copy rule (down)
                          _hdOmergeMap =
                              ({-# LINE 361 "src-ag/Order.ag" #-}
                               _lhsImergeMap
                               {-# LINE 666 "dist/build/Order" #-}
                               )
                          -- copy rule (down)
                          _hdOnt =
                              ({-# LINE 90 "src-ag/Order.ag" #-}
                               _lhsInt
                               {-# LINE 672 "dist/build/Order" #-}
                               )
                          -- copy rule (down)
                          _hdOo_unbox =
                              ({-# LINE 120 "src-ag/Order.ag" #-}
                               _lhsIo_unbox
                               {-# LINE 678 "dist/build/Order" #-}
                               )
                          -- copy rule (down)
                          _hdOsyn =
                              ({-# LINE 90 "src-ag/Order.ag" #-}
                               _lhsIsyn
                               {-# LINE 684 "dist/build/Order" #-}
                               )
                          -- copy rule (down)
                          _hdOsynMap =
                              ({-# LINE 12 "src-ag/DistChildAttr.ag" #-}
                               _lhsIsynMap
                               {-# LINE 690 "dist/build/Order" #-}
                               )
                          -- copy rule (down)
                          _tlOallfields =
                              ({-# LINE 655 "src-ag/Order.ag" #-}
                               _lhsIallfields
                               {-# LINE 696 "dist/build/Order" #-}
                               )
                          -- copy rule (down)
                          _tlOallnts =
                              ({-# LINE 648 "src-ag/Order.ag" #-}
                               _lhsIallnts
                               {-# LINE 702 "dist/build/Order" #-}
                               )
                          -- copy rule (down)
                          _tlOattrs =
                              ({-# LINE 655 "src-ag/Order.ag" #-}
                               _lhsIattrs
                               {-# LINE 708 "dist/build/Order" #-}
                               )
                          -- copy rule (down)
                          _tlOcon =
                              ({-# LINE 91 "src-ag/Order.ag" #-}
                               _lhsIcon
                               {-# LINE 714 "dist/build/Order" #-}
                               )
                          -- copy rule (down)
                          _tlOinh =
                              ({-# LINE 90 "src-ag/Order.ag" #-}
                               _lhsIinh
                               {-# LINE 720 "dist/build/Order" #-}
                               )
                          -- copy rule (down)
                          _tlOinhMap =
                              ({-# LINE 12 "src-ag/DistChildAttr.ag" #-}
                               _lhsIinhMap
                               {-# LINE 726 "dist/build/Order" #-}
                               )
                          -- copy rule (down)
                          _tlOmergeMap =
                              ({-# LINE 361 "src-ag/Order.ag" #-}
                               _lhsImergeMap
                               {-# LINE 732 "dist/build/Order" #-}
                               )
                          -- copy rule (down)
                          _tlOnt =
                              ({-# LINE 90 "src-ag/Order.ag" #-}
                               _lhsInt
                               {-# LINE 738 "dist/build/Order" #-}
                               )
                          -- copy rule (down)
                          _tlOo_unbox =
                              ({-# LINE 120 "src-ag/Order.ag" #-}
                               _lhsIo_unbox
                               {-# LINE 744 "dist/build/Order" #-}
                               )
                          -- copy rule (down)
                          _tlOsyn =
                              ({-# LINE 90 "src-ag/Order.ag" #-}
                               _lhsIsyn
                               {-# LINE 750 "dist/build/Order" #-}
                               )
                          -- copy rule (down)
                          _tlOsynMap =
                              ({-# LINE 12 "src-ag/DistChildAttr.ag" #-}
                               _lhsIsynMap
                               {-# LINE 756 "dist/build/Order" #-}
                               )
                          ( _hdIattributes,_hdIcollectChildrenInhs,_hdIcollectChildrenSyns,_hdIerrors,_hdIfield,_hdIgathAltAttrs,_hdIgathRules,_hdIinhs,_hdInts,_hdIsinglevisits,_hdIterminals) =
                              hd_ _hdOallfields _hdOallnts _hdOattrs _hdOcon _hdOinh _hdOinhMap _hdOmergeMap _hdOnt _hdOo_unbox _hdOsyn _hdOsynMap
                          ( _tlIattributes,_tlIcollectChildrenInhs,_tlIcollectChildrenSyns,_tlIerrors,_tlIfields,_tlIgathAltAttrs,_tlIgathRules,_tlIinhs,_tlInts,_tlIsinglevisits,_tlIterminals) =
                              tl_ _tlOallfields _tlOallnts _tlOattrs _tlOcon _tlOinh _tlOinhMap _tlOmergeMap _tlOnt _tlOo_unbox _tlOsyn _tlOsynMap
                      in  ( _lhsOattributes,_lhsOcollectChildrenInhs,_lhsOcollectChildrenSyns,_lhsOerrors,_lhsOfields,_lhsOgathAltAttrs,_lhsOgathRules,_lhsOinhs,_lhsOnts,_lhsOsinglevisits,_lhsOterminals))))
sem_Children_Nil :: T_Children
sem_Children_Nil =
    (T_Children (\ _lhsIallfields
                   _lhsIallnts
                   _lhsIattrs
                   _lhsIcon
                   _lhsIinh
                   _lhsIinhMap
                   _lhsImergeMap
                   _lhsInt
                   _lhsIo_unbox
                   _lhsIsyn
                   _lhsIsynMap ->
                     (let _lhsOfields :: ([(Identifier,Type,ChildKind)])
                          _lhsOattributes :: ([(Identifier,Attributes,Attributes)])
                          _lhsOcollectChildrenInhs :: (Map Identifier Attributes )
                          _lhsOcollectChildrenSyns :: (Map Identifier Attributes )
                          _lhsOerrors :: (Seq Error)
                          _lhsOgathAltAttrs :: ([AltAttr])
                          _lhsOgathRules :: (Seq CRule)
                          _lhsOinhs :: (Seq (Identifier,Attributes))
                          _lhsOnts :: (Seq (Identifier,NontermIdent))
                          _lhsOsinglevisits :: ([CRule])
                          _lhsOterminals :: ([Identifier])
                          -- "src-ag/Order.ag"(line 676, column 11)
                          _lhsOfields =
                              ({-# LINE 676 "src-ag/Order.ag" #-}
                               []
                               {-# LINE 791 "dist/build/Order" #-}
                               )
                          -- use rule "src-ag/Order.ag"(line 666, column 32)
                          _lhsOattributes =
                              ({-# LINE 666 "src-ag/Order.ag" #-}
                               []
                               {-# LINE 797 "dist/build/Order" #-}
                               )
                          -- use rule "src-ag/Order.ag"(line 343, column 68)
                          _lhsOcollectChildrenInhs =
                              ({-# LINE 343 "src-ag/Order.ag" #-}
                               Map.empty
                               {-# LINE 803 "dist/build/Order" #-}
                               )
                          -- use rule "src-ag/Order.ag"(line 343, column 68)
                          _lhsOcollectChildrenSyns =
                              ({-# LINE 343 "src-ag/Order.ag" #-}
                               Map.empty
                               {-# LINE 809 "dist/build/Order" #-}
                               )
                          -- use rule "src-ag/Order.ag"(line 85, column 70)
                          _lhsOerrors =
                              ({-# LINE 85 "src-ag/Order.ag" #-}
                               Seq.empty
                               {-# LINE 815 "dist/build/Order" #-}
                               )
                          -- use rule "src-ag/Order.ag"(line 171, column 68)
                          _lhsOgathAltAttrs =
                              ({-# LINE 171 "src-ag/Order.ag" #-}
                               []
                               {-# LINE 821 "dist/build/Order" #-}
                               )
                          -- use rule "src-ag/Order.ag"(line 207, column 23)
                          _lhsOgathRules =
                              ({-# LINE 207 "src-ag/Order.ag" #-}
                               Seq.empty
                               {-# LINE 827 "dist/build/Order" #-}
                               )
                          -- use rule "src-ag/Order.ag"(line 194, column 20)
                          _lhsOinhs =
                              ({-# LINE 194 "src-ag/Order.ag" #-}
                               Seq.empty
                               {-# LINE 833 "dist/build/Order" #-}
                               )
                          -- use rule "src-ag/Order.ag"(line 193, column 19)
                          _lhsOnts =
                              ({-# LINE 193 "src-ag/Order.ag" #-}
                               Seq.empty
                               {-# LINE 839 "dist/build/Order" #-}
                               )
                          -- use rule "src-ag/Order.ag"(line 612, column 40)
                          _lhsOsinglevisits =
                              ({-# LINE 612 "src-ag/Order.ag" #-}
                               []
                               {-# LINE 845 "dist/build/Order" #-}
                               )
                          -- use rule "src-ag/Order.ag"(line 637, column 38)
                          _lhsOterminals =
                              ({-# LINE 637 "src-ag/Order.ag" #-}
                               []
                               {-# LINE 851 "dist/build/Order" #-}
                               )
                      in  ( _lhsOattributes,_lhsOcollectChildrenInhs,_lhsOcollectChildrenSyns,_lhsOerrors,_lhsOfields,_lhsOgathAltAttrs,_lhsOgathRules,_lhsOinhs,_lhsOnts,_lhsOsinglevisits,_lhsOterminals))))
-- Expression --------------------------------------------------
{-
   visit 0:
      inherited attributes:
         allfields            : [(Identifier,Type,ChildKind)]
         allnts               : [Identifier]
         attrs                : [(Identifier,Identifier)]
         con                  : Identifier
         mergeMap             : Map Identifier (Identifier,[Identifier])
         nt                   : Identifier
      synthesized attributes:
         allRhsVars           : Set (Identifier,Identifier)
         copy                 : Expression 
         errors               : Seq Error
         textLines            : [String]
         usedAttrs            : [(Identifier,Identifier)]
         usedFields           : [Identifier]
         usedLocals           : [Identifier]
   alternatives:
      alternative Expression:
         child pos            : {Pos}
         child tks            : {[HsToken]}
         visit 0:
            local textLines   : _
            local usedAttrs   : _
            local usedLocals  : _
            local usedFields  : _
            local copy        : _
-}
-- cata
sem_Expression :: Expression ->
                  T_Expression
sem_Expression (Expression _pos _tks) =
    (sem_Expression_Expression _pos _tks)
-- semantic domain
newtype T_Expression = T_Expression (([(Identifier,Type,ChildKind)]) ->
                                     ([Identifier]) ->
                                     ([(Identifier,Identifier)]) ->
                                     Identifier ->
                                     (Map Identifier (Identifier,[Identifier])) ->
                                     Identifier ->
                                     ( (Set (Identifier,Identifier)),Expression,(Seq Error),([String]),([(Identifier,Identifier)]),([Identifier]),([Identifier])))
data Inh_Expression = Inh_Expression {allfields_Inh_Expression :: !(([(Identifier,Type,ChildKind)])),allnts_Inh_Expression :: !(([Identifier])),attrs_Inh_Expression :: !(([(Identifier,Identifier)])),con_Inh_Expression :: !(Identifier),mergeMap_Inh_Expression :: !((Map Identifier (Identifier,[Identifier]))),nt_Inh_Expression :: !(Identifier)}
data Syn_Expression = Syn_Expression {allRhsVars_Syn_Expression :: !((Set (Identifier,Identifier))),copy_Syn_Expression :: !(Expression),errors_Syn_Expression :: !((Seq Error)),textLines_Syn_Expression :: !(([String])),usedAttrs_Syn_Expression :: !(([(Identifier,Identifier)])),usedFields_Syn_Expression :: !(([Identifier])),usedLocals_Syn_Expression :: !(([Identifier]))}
wrap_Expression :: T_Expression ->
                   Inh_Expression ->
                   Syn_Expression
wrap_Expression (T_Expression sem) (Inh_Expression _lhsIallfields _lhsIallnts _lhsIattrs _lhsIcon _lhsImergeMap _lhsInt) =
    (let ( _lhsOallRhsVars,_lhsOcopy,_lhsOerrors,_lhsOtextLines,_lhsOusedAttrs,_lhsOusedFields,_lhsOusedLocals) = sem _lhsIallfields _lhsIallnts _lhsIattrs _lhsIcon _lhsImergeMap _lhsInt
     in  (Syn_Expression _lhsOallRhsVars _lhsOcopy _lhsOerrors _lhsOtextLines _lhsOusedAttrs _lhsOusedFields _lhsOusedLocals))
sem_Expression_Expression :: Pos ->
                             ([HsToken]) ->
                             T_Expression
sem_Expression_Expression pos_ tks_ =
    (T_Expression (\ _lhsIallfields
                     _lhsIallnts
                     _lhsIattrs
                     _lhsIcon
                     _lhsImergeMap
                     _lhsInt ->
                       (let _lhsOerrors :: (Seq Error)
                            _lhsOallRhsVars :: (Set (Identifier,Identifier))
                            _lhsOcopy :: Expression
                            _lhsOtextLines :: ([String])
                            _lhsOusedAttrs :: ([(Identifier,Identifier)])
                            _lhsOusedFields :: ([Identifier])
                            _lhsOusedLocals :: ([Identifier])
                            -- "src-ag/Order.ag"(line 465, column 21)
                            (_textLines,_usedAttrs,_usedLocals,_usedFields) =
                                ({-# LINE 465 "src-ag/Order.ag" #-}
                                 let mergedChildren = [ x | (_,xs) <- Map.elems _lhsImergeMap, x <- xs ]
                                     attrsIn = filter (\(fld,_) -> not (fld `elem` mergedChildren)) _lhsIattrs
                                     inherited = Inh_HsTokensRoot
                                                 { attrs_Inh_HsTokensRoot      = attrsIn
                                                 , con_Inh_HsTokensRoot        = _lhsIcon
                                                 , allfields_Inh_HsTokensRoot  = _lhsIallfields
                                                 , allnts_Inh_HsTokensRoot     = _lhsIallnts
                                                 , nt_Inh_HsTokensRoot         = _lhsInt
                                                 }
                                     synthesized = wrap_HsTokensRoot (sem_HsTokensRoot (HsTokensRoot tks_)) inherited
                                 in case synthesized of
                                      Syn_HsTokensRoot
                                       { textLines_Syn_HsTokensRoot  = textLines
                                       , usedAttrs_Syn_HsTokensRoot  = usedAttrs
                                       , usedLocals_Syn_HsTokensRoot = usedLocals
                                       , usedFields_Syn_HsTokensRoot = usedFields
                                       }  -> let extraAttrs = [ (src,attr)
                                                              | (fld,attr) <- usedAttrs, let mbMerged = Map.lookup fld _lhsImergeMap, isJust mbMerged
                                                              , let (Just (_, srcs)) = mbMerged, src <- srcs ]
                                                 usedAttrs' = usedAttrs ++ extraAttrs
                                             in (textLines,usedAttrs',usedLocals,usedFields)
                                 {-# LINE 945 "dist/build/Order" #-}
                                 )
                            -- "src-ag/Order.ag"(line 488, column 17)
                            _lhsOerrors =
                                ({-# LINE 488 "src-ag/Order.ag" #-}
                                 Seq.empty
                                 {-# LINE 951 "dist/build/Order" #-}
                                 )
                            -- "src-ag/Order.ag"(line 489, column 17)
                            _lhsOallRhsVars =
                                ({-# LINE 489 "src-ag/Order.ag" #-}
                                 Set.fromList _usedAttrs
                                 `Set.union`
                                 Set.fromList [ (_LOC, l) | l <- _usedLocals    ]
                                 `Set.union`
                                 Set.fromList [ (_FIELD, fld) | fld <- _usedFields    ]
                                 {-# LINE 961 "dist/build/Order" #-}
                                 )
                            -- self rule
                            _copy =
                                ({-# LINE 456 "src-ag/Order.ag" #-}
                                 Expression pos_ tks_
                                 {-# LINE 967 "dist/build/Order" #-}
                                 )
                            -- self rule
                            _lhsOcopy =
                                ({-# LINE 456 "src-ag/Order.ag" #-}
                                 _copy
                                 {-# LINE 973 "dist/build/Order" #-}
                                 )
                            -- copy rule (from local)
                            _lhsOtextLines =
                                ({-# LINE 455 "src-ag/Order.ag" #-}
                                 _textLines
                                 {-# LINE 979 "dist/build/Order" #-}
                                 )
                            -- copy rule (from local)
                            _lhsOusedAttrs =
                                ({-# LINE 453 "src-ag/Order.ag" #-}
                                 _usedAttrs
                                 {-# LINE 985 "dist/build/Order" #-}
                                 )
                            -- copy rule (from local)
                            _lhsOusedFields =
                                ({-# LINE 454 "src-ag/Order.ag" #-}
                                 _usedFields
                                 {-# LINE 991 "dist/build/Order" #-}
                                 )
                            -- copy rule (from local)
                            _lhsOusedLocals =
                                ({-# LINE 452 "src-ag/Order.ag" #-}
                                 _usedLocals
                                 {-# LINE 997 "dist/build/Order" #-}
                                 )
                        in  ( _lhsOallRhsVars,_lhsOcopy,_lhsOerrors,_lhsOtextLines,_lhsOusedAttrs,_lhsOusedFields,_lhsOusedLocals))))
-- Grammar -----------------------------------------------------
{-
   visit 0:
      inherited attribute:
         options              : Options
      synthesized attributes:
         errors               : Seq Error
         nAutoRules           : Int
         nExplicitRules       : Int
         output               : CGrammar
   alternatives:
      alternative Grammar:
         child typeSyns       : {TypeSyns}
         child useMap         : {UseMap}
         child derivings      : {Derivings}
         child wrappers       : {Set NontermIdent}
         child nonts          : Nonterminals 
         child pragmas        : {PragmaMap}
         child manualAttrOrderMap : {AttrOrderMap}
         child paramMap       : {ParamMap}
         child contextMap     : {ContextMap}
         child quantMap       : {QuantMap}
         child uniqueMap      : {UniqueMap}
         child augmentsMap    : {Map NontermIdent (Map ConstructorIdent (Map Identifier [Expression]))}
         child aroundsMap     : {Map NontermIdent (Map ConstructorIdent (Map Identifier [Expression]))}
         child mergeMap       : {Map NontermIdent (Map ConstructorIdent (Map Identifier (Identifier, [Identifier], Expression)))}
         visit 0:
            local o_dovisit   : _
            local ruleTable   : _
            local attrTable   : _
            local attrVertex  : _
            local tdpToTds    : _
            local tdsToTdp    : _
            local directDep   : _
            local instDep     : _
            local aroundDep   : _
            local mergeDep    : _
            local info        : _
            local cInterfaceMap : _
            local cVisitsMap  : _
            local cyclesErrors : _
            local aroundMap   : _
            local mergeMap    : _
-}
-- cata
sem_Grammar :: Grammar ->
               T_Grammar
sem_Grammar (Grammar _typeSyns _useMap _derivings _wrappers _nonts _pragmas _manualAttrOrderMap _paramMap _contextMap _quantMap _uniqueMap _augmentsMap _aroundsMap _mergeMap) =
    (sem_Grammar_Grammar _typeSyns _useMap _derivings _wrappers (sem_Nonterminals _nonts) _pragmas _manualAttrOrderMap _paramMap _contextMap _quantMap _uniqueMap _augmentsMap _aroundsMap _mergeMap)
-- semantic domain
newtype T_Grammar = T_Grammar (Options ->
                               ( (Seq Error),Int,Int,CGrammar))
data Inh_Grammar = Inh_Grammar {options_Inh_Grammar :: !(Options)}
data Syn_Grammar = Syn_Grammar {errors_Syn_Grammar :: !((Seq Error)),nAutoRules_Syn_Grammar :: !(Int),nExplicitRules_Syn_Grammar :: !(Int),output_Syn_Grammar :: !(CGrammar)}
wrap_Grammar :: T_Grammar ->
                Inh_Grammar ->
                Syn_Grammar
wrap_Grammar (T_Grammar sem) (Inh_Grammar _lhsIoptions) =
    (let ( _lhsOerrors,_lhsOnAutoRules,_lhsOnExplicitRules,_lhsOoutput) = sem _lhsIoptions
     in  (Syn_Grammar _lhsOerrors _lhsOnAutoRules _lhsOnExplicitRules _lhsOoutput))
sem_Grammar_Grammar :: TypeSyns ->
                       UseMap ->
                       Derivings ->
                       (Set NontermIdent) ->
                       T_Nonterminals ->
                       PragmaMap ->
                       AttrOrderMap ->
                       ParamMap ->
                       ContextMap ->
                       QuantMap ->
                       UniqueMap ->
                       (Map NontermIdent (Map ConstructorIdent (Map Identifier [Expression]))) ->
                       (Map NontermIdent (Map ConstructorIdent (Map Identifier [Expression]))) ->
                       (Map NontermIdent (Map ConstructorIdent (Map Identifier (Identifier, [Identifier], Expression)))) ->
                       T_Grammar
sem_Grammar_Grammar typeSyns_ useMap_ derivings_ wrappers_ (T_Nonterminals nonts_) pragmas_ manualAttrOrderMap_ paramMap_ contextMap_ quantMap_ uniqueMap_ augmentsMap_ aroundsMap_ mergeMap_ =
    (T_Grammar (\ _lhsIoptions ->
                    (let _nontsOo_cata :: Bool
                         _nontsOo_data :: Bool
                         _nontsOo_sig :: Bool
                         _nontsOo_sem :: Bool
                         _nontsOo_rename :: Bool
                         _nontsOo_newtypes :: Bool
                         _nontsOo_wantvisit :: Bool
                         _nontsOo_unbox :: Bool
                         _nontsOo_case :: Bool
                         _nontsOprefix :: String
                         _nontsOvcount :: Int
                         _nontsOmanualAttrDepMap :: AttrOrderMap
                         _nontsOaroundMap :: (Map NontermIdent (Map ConstructorIdent (Map Identifier [Expression])))
                         _nontsOacount :: Int
                         _lhsOerrors :: (Seq Error)
                         _lhsOoutput :: CGrammar
                         _nontsOallnts :: ([Identifier])
                         _nontsOinhMap :: (Map Identifier Attributes)
                         _nontsOsynMap :: (Map Identifier Attributes)
                         _lhsOnAutoRules :: Int
                         _lhsOnExplicitRules :: Int
                         _nontsOcInterfaceMap :: CInterfaceMap
                         _nontsOcVisitsMap :: CVisitsMap
                         _nontsOmergeMap :: (Map NontermIdent (Map ConstructorIdent (Map Identifier (Identifier,[Identifier]))))
                         _nontsOo_dovisit :: Bool
                         _nontsIacount :: Int
                         _nontsIadditionalDep :: (Seq Edge)
                         _nontsIaranges :: (Seq (Int,Int,Int))
                         _nontsIaroundDep :: (Seq Edge)
                         _nontsIcNonterminals :: CNonterminals
                         _nontsIdirectDep :: (Seq Edge)
                         _nontsIerrors :: (Seq Error)
                         _nontsIinhMap' :: (Map Identifier Attributes)
                         _nontsIinstDep :: (Seq Edge)
                         _nontsImergeDep :: (Seq Edge)
                         _nontsInAutoRules :: Int
                         _nontsInExplicitRules :: Int
                         _nontsInonts :: ([(NontermIdent,[ConstructorIdent])])
                         _nontsIntattrs :: (Seq (Vertex,NTAttr))
                         _nontsIrules :: (Seq (Vertex,CRule))
                         _nontsIsynMap' :: (Map Identifier Attributes)
                         _nontsIvcount :: Int
                         -- "src-ag/Order.ag"(line 124, column 17)
                         _o_dovisit =
                             ({-# LINE 124 "src-ag/Order.ag" #-}
                              visit     _lhsIoptions && null _cyclesErrors
                              {-# LINE 1123 "dist/build/Order" #-}
                              )
                         -- "src-ag/Order.ag"(line 125, column 17)
                         _nontsOo_cata =
                             ({-# LINE 125 "src-ag/Order.ag" #-}
                              folds     _lhsIoptions
                              {-# LINE 1129 "dist/build/Order" #-}
                              )
                         -- "src-ag/Order.ag"(line 125, column 17)
                         _nontsOo_data =
                             ({-# LINE 126 "src-ag/Order.ag" #-}
                              dataTypes _lhsIoptions
                              {-# LINE 1135 "dist/build/Order" #-}
                              )
                         -- "src-ag/Order.ag"(line 125, column 17)
                         _nontsOo_sig =
                             ({-# LINE 127 "src-ag/Order.ag" #-}
                              typeSigs  _lhsIoptions
                              {-# LINE 1141 "dist/build/Order" #-}
                              )
                         -- "src-ag/Order.ag"(line 125, column 17)
                         _nontsOo_sem =
                             ({-# LINE 128 "src-ag/Order.ag" #-}
                              semfuns   _lhsIoptions
                              {-# LINE 1147 "dist/build/Order" #-}
                              )
                         -- "src-ag/Order.ag"(line 125, column 17)
                         _nontsOo_rename =
                             ({-# LINE 129 "src-ag/Order.ag" #-}
                              rename    _lhsIoptions
                              {-# LINE 1153 "dist/build/Order" #-}
                              )
                         -- "src-ag/Order.ag"(line 125, column 17)
                         _nontsOo_newtypes =
                             ({-# LINE 130 "src-ag/Order.ag" #-}
                              newtypes  _lhsIoptions
                              {-# LINE 1159 "dist/build/Order" #-}
                              )
                         -- "src-ag/Order.ag"(line 125, column 17)
                         _nontsOo_wantvisit =
                             ({-# LINE 131 "src-ag/Order.ag" #-}
                              visit   _lhsIoptions
                              {-# LINE 1165 "dist/build/Order" #-}
                              )
                         -- "src-ag/Order.ag"(line 125, column 17)
                         _nontsOo_unbox =
                             ({-# LINE 132 "src-ag/Order.ag" #-}
                              unbox     _lhsIoptions
                              {-# LINE 1171 "dist/build/Order" #-}
                              )
                         -- "src-ag/Order.ag"(line 125, column 17)
                         _nontsOo_case =
                             ({-# LINE 133 "src-ag/Order.ag" #-}
                              cases     _lhsIoptions
                              {-# LINE 1177 "dist/build/Order" #-}
                              )
                         -- "src-ag/Order.ag"(line 125, column 17)
                         _nontsOprefix =
                             ({-# LINE 134 "src-ag/Order.ag" #-}
                              prefix    _lhsIoptions
                              {-# LINE 1183 "dist/build/Order" #-}
                              )
                         -- "src-ag/Order.ag"(line 260, column 15)
                         _nontsOvcount =
                             ({-# LINE 260 "src-ag/Order.ag" #-}
                              0
                              {-# LINE 1189 "dist/build/Order" #-}
                              )
                         -- "src-ag/Order.ag"(line 286, column 7)
                         _nontsOmanualAttrDepMap =
                             ({-# LINE 286 "src-ag/Order.ag" #-}
                              manualAttrOrderMap_
                              {-# LINE 1195 "dist/build/Order" #-}
                              )
                         -- "src-ag/Order.ag"(line 415, column 14)
                         _nontsOaroundMap =
                             ({-# LINE 415 "src-ag/Order.ag" #-}
                              aroundsMap_
                              {-# LINE 1201 "dist/build/Order" #-}
                              )
                         -- "src-ag/Order.ag"(line 504, column 13)
                         _nontsOacount =
                             ({-# LINE 504 "src-ag/Order.ag" #-}
                              0
                              {-# LINE 1207 "dist/build/Order" #-}
                              )
                         -- "src-ag/Order.ag"(line 542, column 13)
                         _ruleTable =
                             ({-# LINE 542 "src-ag/Order.ag" #-}
                              Array.array (0,_nontsIvcount-1) (toList _nontsIrules)
                              {-# LINE 1213 "dist/build/Order" #-}
                              )
                         -- "src-ag/Order.ag"(line 543, column 13)
                         _attrTable =
                             ({-# LINE 543 "src-ag/Order.ag" #-}
                              Array.array (0,_nontsIacount-1) (toList _nontsIntattrs)
                              {-# LINE 1219 "dist/build/Order" #-}
                              )
                         -- "src-ag/Order.ag"(line 544, column 13)
                         _attrVertex =
                             ({-# LINE 544 "src-ag/Order.ag" #-}
                              Map.fromList (map swap (toList _nontsIntattrs))
                              {-# LINE 1225 "dist/build/Order" #-}
                              )
                         -- "src-ag/Order.ag"(line 545, column 13)
                         _tdpToTds =
                             ({-# LINE 545 "src-ag/Order.ag" #-}
                              [ (s, maybe (-1) (\v -> findWithErr1 "Grammar.tdpToTds" v _attrVertex) (ntattr cr))
                              | (s,cr) <- toList _nontsIrules]
                              {-# LINE 1232 "dist/build/Order" #-}
                              )
                         -- "src-ag/Order.ag"(line 547, column 13)
                         _tdsToTdp =
                             ({-# LINE 547 "src-ag/Order.ag" #-}
                              let  eq (_,v) (_,v') = v == v'
                                   conv ((s,v):svs)  | v == -1 = Nothing
                                                     | otherwise = Just (v,s:map fst svs)
                              in mapMaybe conv (eqClasses eq _tdpToTds)
                              {-# LINE 1241 "dist/build/Order" #-}
                              )
                         -- "src-ag/Order.ag"(line 551, column 13)
                         _directDep =
                             ({-# LINE 551 "src-ag/Order.ag" #-}
                              toList (_nontsIdirectDep Seq.>< _nontsIadditionalDep)
                              {-# LINE 1247 "dist/build/Order" #-}
                              )
                         -- "src-ag/Order.ag"(line 552, column 13)
                         _instDep =
                             ({-# LINE 552 "src-ag/Order.ag" #-}
                              toList _nontsIinstDep
                              {-# LINE 1253 "dist/build/Order" #-}
                              )
                         -- "src-ag/Order.ag"(line 553, column 13)
                         _aroundDep =
                             ({-# LINE 553 "src-ag/Order.ag" #-}
                              toList _nontsIaroundDep
                              {-# LINE 1259 "dist/build/Order" #-}
                              )
                         -- "src-ag/Order.ag"(line 554, column 13)
                         _mergeDep =
                             ({-# LINE 554 "src-ag/Order.ag" #-}
                              toList _nontsImergeDep
                              {-# LINE 1265 "dist/build/Order" #-}
                              )
                         -- "src-ag/Order.ag"(line 555, column 13)
                         _info =
                             ({-# LINE 555 "src-ag/Order.ag" #-}
                              let def [] = -1
                                  def (v:vs) = v
                               in Info { tdsToTdp   = Array.array (0,_nontsIacount-1) _tdsToTdp
                                       , tdpToTds   = Array.array (0,_nontsIvcount-1) _tdpToTds
                                       , attrTable  = _attrTable
                                       , ruleTable  = _ruleTable
                                       , lmh        = toList _nontsIaranges
                                       , nonts      = _nontsInonts
                                       , wraps      = wrappers_
                                       }
                              {-# LINE 1280 "dist/build/Order" #-}
                              )
                         -- "src-ag/Order.ag"(line 566, column 17)
                         (_cInterfaceMap,_cVisitsMap,_cyclesErrors) =
                             ({-# LINE 566 "src-ag/Order.ag" #-}
                              case computeSequential _info _directDep (_instDep ++ _aroundDep ++ _mergeDep    ) of
                                           CycleFree    cim cvm   -> ( cim
                                                                     , cvm
                                                                     , []
                                                                     )
                                           LocalCycle   errs      -> ( error "No interfaces for AG with local cycles"
                                                                     , error "No visit sub-sequences for AG with local cycles"
                                                                     , map (localCycleErr _ruleTable (visit _lhsIoptions)) errs
                                                                     )
                                           InstCycle    errs      -> ( error "No interfaces for AG with cycles through insts"
                                                                     , error "No visit sub-sequences for AG with cycles through insts"
                                                                     , map (instCycleErr _ruleTable (visit _lhsIoptions)) errs
                                                                     )
                                           DirectCycle  errs      -> ( error "No interfaces for AG with direct cycles"
                                                                     , error "No visit sub-sequences for AG with direct cycles"
                                                                     , directCycleErrs _attrTable _ruleTable (visit _lhsIoptions) errs
                                                                     )
                                           InducedCycle cim errs ->  ( cim
                                                                     , error "No visit sub-sequences for AG with induced cycles"
                                                                     , inducedCycleErrs _attrTable _ruleTable cim errs
                                                                     )
                              {-# LINE 1306 "dist/build/Order" #-}
                              )
                         -- "src-ag/Order.ag"(line 588, column 13)
                         _lhsOerrors =
                             ({-# LINE 588 "src-ag/Order.ag" #-}
                              (if withCycle _lhsIoptions then Seq.fromList _cyclesErrors else Seq.empty)
                               Seq.>< _nontsIerrors
                              {-# LINE 1313 "dist/build/Order" #-}
                              )
                         -- "src-ag/Order.ag"(line 620, column 15)
                         _lhsOoutput =
                             ({-# LINE 620 "src-ag/Order.ag" #-}
                              CGrammar typeSyns_ derivings_ wrappers_ _nontsIcNonterminals pragmas_ paramMap_ contextMap_ quantMap_ _aroundMap     _mergeMap     _o_dovisit
                              {-# LINE 1319 "dist/build/Order" #-}
                              )
                         -- "src-ag/Order.ag"(line 633, column 14)
                         _aroundMap =
                             ({-# LINE 633 "src-ag/Order.ag" #-}
                              Map.map (Map.map Map.keysSet) aroundsMap_
                              {-# LINE 1325 "dist/build/Order" #-}
                              )
                         -- "src-ag/Order.ag"(line 634, column 14)
                         _mergeMap =
                             ({-# LINE 634 "src-ag/Order.ag" #-}
                              Map.map (Map.map (Map.map (\(nt,srcs,_) -> (nt,srcs)))) mergeMap_
                              {-# LINE 1331 "dist/build/Order" #-}
                              )
                         -- "src-ag/Order.ag"(line 651, column 13)
                         _nontsOallnts =
                             ({-# LINE 651 "src-ag/Order.ag" #-}
                              map fst (_nontsInonts)
                              {-# LINE 1337 "dist/build/Order" #-}
                              )
                         -- "src-ag/DistChildAttr.ag"(line 15, column 13)
                         _nontsOinhMap =
                             ({-# LINE 15 "src-ag/DistChildAttr.ag" #-}
                              _nontsIinhMap'
                              {-# LINE 1343 "dist/build/Order" #-}
                              )
                         -- "src-ag/DistChildAttr.ag"(line 16, column 13)
                         _nontsOsynMap =
                             ({-# LINE 16 "src-ag/DistChildAttr.ag" #-}
                              _nontsIsynMap'
                              {-# LINE 1349 "dist/build/Order" #-}
                              )
                         -- use rule "src-ag/Order.ag"(line 62, column 105)
                         _lhsOnAutoRules =
                             ({-# LINE 62 "src-ag/Order.ag" #-}
                              _nontsInAutoRules
                              {-# LINE 1355 "dist/build/Order" #-}
                              )
                         -- use rule "src-ag/Order.ag"(line 62, column 105)
                         _lhsOnExplicitRules =
                             ({-# LINE 62 "src-ag/Order.ag" #-}
                              _nontsInExplicitRules
                              {-# LINE 1361 "dist/build/Order" #-}
                              )
                         -- copy rule (from local)
                         _nontsOcInterfaceMap =
                             ({-# LINE 595 "src-ag/Order.ag" #-}
                              _cInterfaceMap
                              {-# LINE 1367 "dist/build/Order" #-}
                              )
                         -- copy rule (from local)
                         _nontsOcVisitsMap =
                             ({-# LINE 602 "src-ag/Order.ag" #-}
                              _cVisitsMap
                              {-# LINE 1373 "dist/build/Order" #-}
                              )
                         -- copy rule (from local)
                         _nontsOmergeMap =
                             ({-# LINE 353 "src-ag/Order.ag" #-}
                              _mergeMap
                              {-# LINE 1379 "dist/build/Order" #-}
                              )
                         -- copy rule (from local)
                         _nontsOo_dovisit =
                             ({-# LINE 117 "src-ag/Order.ag" #-}
                              _o_dovisit
                              {-# LINE 1385 "dist/build/Order" #-}
                              )
                         ( _nontsIacount,_nontsIadditionalDep,_nontsIaranges,_nontsIaroundDep,_nontsIcNonterminals,_nontsIdirectDep,_nontsIerrors,_nontsIinhMap',_nontsIinstDep,_nontsImergeDep,_nontsInAutoRules,_nontsInExplicitRules,_nontsInonts,_nontsIntattrs,_nontsIrules,_nontsIsynMap',_nontsIvcount) =
                             nonts_ _nontsOacount _nontsOallnts _nontsOaroundMap _nontsOcInterfaceMap _nontsOcVisitsMap _nontsOinhMap _nontsOmanualAttrDepMap _nontsOmergeMap _nontsOo_case _nontsOo_cata _nontsOo_data _nontsOo_dovisit _nontsOo_newtypes _nontsOo_rename _nontsOo_sem _nontsOo_sig _nontsOo_unbox _nontsOo_wantvisit _nontsOprefix _nontsOsynMap _nontsOvcount
                     in  ( _lhsOerrors,_lhsOnAutoRules,_lhsOnExplicitRules,_lhsOoutput))))
-- Nonterminal -------------------------------------------------
{-
   visit 0:
      inherited attributes:
         allnts               : [Identifier]
         aroundMap            : Map NontermIdent (Map ConstructorIdent (Map Identifier [Expression]))
         cInterfaceMap        : CInterfaceMap
         cVisitsMap           : CVisitsMap
         inhMap               : Map Identifier Attributes
         manualAttrDepMap     : AttrOrderMap
         mergeMap             : Map NontermIdent (Map ConstructorIdent (Map Identifier (Identifier,[Identifier])))
         o_case               : Bool
         o_cata               : Bool
         o_data               : Bool
         o_dovisit            : Bool
         o_newtypes           : Bool
         o_rename             : Bool
         o_sem                : Bool
         o_sig                : Bool
         o_unbox              : Bool
         o_wantvisit          : Bool
         prefix               : String
         synMap               : Map Identifier Attributes
      chained attributes:
         acount               : Int
         vcount               : Int
      synthesized attributes:
         additionalDep        : Seq Edge
         aranges              : Seq (Int,Int,Int)
         aroundDep            : Seq Edge
         cNonterminal         : CNonterminal
         directDep            : Seq Edge
         errors               : Seq Error
         inhMap'              : Map Identifier Attributes
         instDep              : Seq Edge
         mergeDep             : Seq Edge
         nAutoRules           : Int
         nExplicitRules       : Int
         nonts                : [(NontermIdent,[ConstructorIdent])]
         ntattrs              : Seq (Vertex,NTAttr)
         rules                : Seq (Vertex,CRule)
         synMap'              : Map Identifier Attributes
   alternatives:
      alternative Nonterminal:
         child nt             : {NontermIdent}
         child params         : {[Identifier]}
         child inh            : {Attributes}
         child syn            : {Attributes}
         child prods          : Productions 
         visit 0:
            local mergeMap    : _
            local aroundMap   : _
            local ntattrs     : _
            local cInter      : _
-}
-- cata
sem_Nonterminal :: Nonterminal ->
                   T_Nonterminal
sem_Nonterminal (Nonterminal _nt _params _inh _syn _prods) =
    (sem_Nonterminal_Nonterminal _nt _params _inh _syn (sem_Productions _prods))
-- semantic domain
newtype T_Nonterminal = T_Nonterminal (Int ->
                                       ([Identifier]) ->
                                       (Map NontermIdent (Map ConstructorIdent (Map Identifier [Expression]))) ->
                                       CInterfaceMap ->
                                       CVisitsMap ->
                                       (Map Identifier Attributes) ->
                                       AttrOrderMap ->
                                       (Map NontermIdent (Map ConstructorIdent (Map Identifier (Identifier,[Identifier])))) ->
                                       Bool ->
                                       Bool ->
                                       Bool ->
                                       Bool ->
                                       Bool ->
                                       Bool ->
                                       Bool ->
                                       Bool ->
                                       Bool ->
                                       Bool ->
                                       String ->
                                       (Map Identifier Attributes) ->
                                       Int ->
                                       ( Int,(Seq Edge),(Seq (Int,Int,Int)),(Seq Edge),CNonterminal,(Seq Edge),(Seq Error),(Map Identifier Attributes),(Seq Edge),(Seq Edge),Int,Int,([(NontermIdent,[ConstructorIdent])]),(Seq (Vertex,NTAttr)),(Seq (Vertex,CRule)),(Map Identifier Attributes),Int))
data Inh_Nonterminal = Inh_Nonterminal {acount_Inh_Nonterminal :: !(Int),allnts_Inh_Nonterminal :: !(([Identifier])),aroundMap_Inh_Nonterminal :: !((Map NontermIdent (Map ConstructorIdent (Map Identifier [Expression])))),cInterfaceMap_Inh_Nonterminal :: !(CInterfaceMap),cVisitsMap_Inh_Nonterminal :: !(CVisitsMap),inhMap_Inh_Nonterminal :: !((Map Identifier Attributes)),manualAttrDepMap_Inh_Nonterminal :: !(AttrOrderMap),mergeMap_Inh_Nonterminal :: !((Map NontermIdent (Map ConstructorIdent (Map Identifier (Identifier,[Identifier]))))),o_case_Inh_Nonterminal :: !(Bool),o_cata_Inh_Nonterminal :: !(Bool),o_data_Inh_Nonterminal :: !(Bool),o_dovisit_Inh_Nonterminal :: !(Bool),o_newtypes_Inh_Nonterminal :: !(Bool),o_rename_Inh_Nonterminal :: !(Bool),o_sem_Inh_Nonterminal :: !(Bool),o_sig_Inh_Nonterminal :: !(Bool),o_unbox_Inh_Nonterminal :: !(Bool),o_wantvisit_Inh_Nonterminal :: !(Bool),prefix_Inh_Nonterminal :: !(String),synMap_Inh_Nonterminal :: !((Map Identifier Attributes)),vcount_Inh_Nonterminal :: !(Int)}
data Syn_Nonterminal = Syn_Nonterminal {acount_Syn_Nonterminal :: !(Int),additionalDep_Syn_Nonterminal :: !((Seq Edge)),aranges_Syn_Nonterminal :: !((Seq (Int,Int,Int))),aroundDep_Syn_Nonterminal :: !((Seq Edge)),cNonterminal_Syn_Nonterminal :: !(CNonterminal),directDep_Syn_Nonterminal :: !((Seq Edge)),errors_Syn_Nonterminal :: !((Seq Error)),inhMap'_Syn_Nonterminal :: !((Map Identifier Attributes)),instDep_Syn_Nonterminal :: !((Seq Edge)),mergeDep_Syn_Nonterminal :: !((Seq Edge)),nAutoRules_Syn_Nonterminal :: !(Int),nExplicitRules_Syn_Nonterminal :: !(Int),nonts_Syn_Nonterminal :: !(([(NontermIdent,[ConstructorIdent])])),ntattrs_Syn_Nonterminal :: !((Seq (Vertex,NTAttr))),rules_Syn_Nonterminal :: !((Seq (Vertex,CRule))),synMap'_Syn_Nonterminal :: !((Map Identifier Attributes)),vcount_Syn_Nonterminal :: !(Int)}
wrap_Nonterminal :: T_Nonterminal ->
                    Inh_Nonterminal ->
                    Syn_Nonterminal
wrap_Nonterminal (T_Nonterminal sem) (Inh_Nonterminal _lhsIacount _lhsIallnts _lhsIaroundMap _lhsIcInterfaceMap _lhsIcVisitsMap _lhsIinhMap _lhsImanualAttrDepMap _lhsImergeMap _lhsIo_case _lhsIo_cata _lhsIo_data _lhsIo_dovisit _lhsIo_newtypes _lhsIo_rename _lhsIo_sem _lhsIo_sig _lhsIo_unbox _lhsIo_wantvisit _lhsIprefix _lhsIsynMap _lhsIvcount) =
    (let ( _lhsOacount,_lhsOadditionalDep,_lhsOaranges,_lhsOaroundDep,_lhsOcNonterminal,_lhsOdirectDep,_lhsOerrors,_lhsOinhMap',_lhsOinstDep,_lhsOmergeDep,_lhsOnAutoRules,_lhsOnExplicitRules,_lhsOnonts,_lhsOntattrs,_lhsOrules,_lhsOsynMap',_lhsOvcount) = sem _lhsIacount _lhsIallnts _lhsIaroundMap _lhsIcInterfaceMap _lhsIcVisitsMap _lhsIinhMap _lhsImanualAttrDepMap _lhsImergeMap _lhsIo_case _lhsIo_cata _lhsIo_data _lhsIo_dovisit _lhsIo_newtypes _lhsIo_rename _lhsIo_sem _lhsIo_sig _lhsIo_unbox _lhsIo_wantvisit _lhsIprefix _lhsIsynMap _lhsIvcount
     in  (Syn_Nonterminal _lhsOacount _lhsOadditionalDep _lhsOaranges _lhsOaroundDep _lhsOcNonterminal _lhsOdirectDep _lhsOerrors _lhsOinhMap' _lhsOinstDep _lhsOmergeDep _lhsOnAutoRules _lhsOnExplicitRules _lhsOnonts _lhsOntattrs _lhsOrules _lhsOsynMap' _lhsOvcount))
sem_Nonterminal_Nonterminal :: NontermIdent ->
                               ([Identifier]) ->
                               Attributes ->
                               Attributes ->
                               T_Productions ->
                               T_Nonterminal
sem_Nonterminal_Nonterminal nt_ params_ inh_ syn_ (T_Productions prods_) =
    (T_Nonterminal (\ _lhsIacount
                      _lhsIallnts
                      _lhsIaroundMap
                      _lhsIcInterfaceMap
                      _lhsIcVisitsMap
                      _lhsIinhMap
                      _lhsImanualAttrDepMap
                      _lhsImergeMap
                      _lhsIo_case
                      _lhsIo_cata
                      _lhsIo_data
                      _lhsIo_dovisit
                      _lhsIo_newtypes
                      _lhsIo_rename
                      _lhsIo_sem
                      _lhsIo_sig
                      _lhsIo_unbox
                      _lhsIo_wantvisit
                      _lhsIprefix
                      _lhsIsynMap
                      _lhsIvcount ->
                        (let _prodsOnt :: Identifier
                             _prodsOinh :: Attributes
                             _prodsOsyn :: Attributes
                             _lhsOntattrs :: (Seq (Vertex,NTAttr))
                             _lhsOacount :: Int
                             _lhsOaranges :: (Seq (Int,Int,Int))
                             _lhsOnonts :: ([(NontermIdent,[ConstructorIdent])])
                             _lhsOcNonterminal :: CNonterminal
                             _lhsOinhMap' :: (Map Identifier Attributes)
                             _lhsOsynMap' :: (Map Identifier Attributes)
                             _lhsOadditionalDep :: (Seq Edge)
                             _lhsOaroundDep :: (Seq Edge)
                             _lhsOdirectDep :: (Seq Edge)
                             _lhsOerrors :: (Seq Error)
                             _lhsOinstDep :: (Seq Edge)
                             _lhsOmergeDep :: (Seq Edge)
                             _lhsOnAutoRules :: Int
                             _lhsOnExplicitRules :: Int
                             _lhsOrules :: (Seq (Vertex,CRule))
                             _lhsOvcount :: Int
                             _prodsOallnts :: ([Identifier])
                             _prodsOaroundMap :: (Map ConstructorIdent (Map Identifier [Expression]))
                             _prodsOcVisitsMap :: CVisitsMap
                             _prodsOinhMap :: (Map Identifier Attributes)
                             _prodsOmanualAttrDepMap :: AttrOrderMap
                             _prodsOmergeMap :: (Map ConstructorIdent (Map Identifier (Identifier,[Identifier])))
                             _prodsOo_case :: Bool
                             _prodsOo_cata :: Bool
                             _prodsOo_dovisit :: Bool
                             _prodsOo_newtypes :: Bool
                             _prodsOo_rename :: Bool
                             _prodsOo_sem :: Bool
                             _prodsOo_sig :: Bool
                             _prodsOo_unbox :: Bool
                             _prodsOo_wantvisit :: Bool
                             _prodsOprefix :: String
                             _prodsOsynMap :: (Map Identifier Attributes)
                             _prodsOvcount :: Int
                             _prodsIadditionalDep :: (Seq Edge)
                             _prodsIaroundDep :: (Seq Edge)
                             _prodsIcProductions :: CProductions
                             _prodsIcons :: ([ConstructorIdent])
                             _prodsIdirectDep :: (Seq Edge)
                             _prodsIerrors :: (Seq Error)
                             _prodsIinstDep :: (Seq Edge)
                             _prodsImergeDep :: (Seq Edge)
                             _prodsInAutoRules :: Int
                             _prodsInExplicitRules :: Int
                             _prodsIrules :: (Seq (Vertex,CRule))
                             _prodsIvcount :: Int
                             -- "src-ag/Order.ag"(line 98, column 17)
                             _prodsOnt =
                                 ({-# LINE 98 "src-ag/Order.ag" #-}
                                  nt_
                                  {-# LINE 1563 "dist/build/Order" #-}
                                  )
                             -- "src-ag/Order.ag"(line 101, column 17)
                             _prodsOinh =
                                 ({-# LINE 101 "src-ag/Order.ag" #-}
                                  inh_
                                  {-# LINE 1569 "dist/build/Order" #-}
                                  )
                             -- "src-ag/Order.ag"(line 102, column 17)
                             _prodsOsyn =
                                 ({-# LINE 102 "src-ag/Order.ag" #-}
                                  syn_
                                  {-# LINE 1575 "dist/build/Order" #-}
                                  )
                             -- "src-ag/Order.ag"(line 358, column 32)
                             _mergeMap =
                                 ({-# LINE 358 "src-ag/Order.ag" #-}
                                  Map.findWithDefault Map.empty nt_ _lhsImergeMap
                                  {-# LINE 1581 "dist/build/Order" #-}
                                  )
                             -- "src-ag/Order.ag"(line 411, column 32)
                             _aroundMap =
                                 ({-# LINE 411 "src-ag/Order.ag" #-}
                                  Map.findWithDefault Map.empty nt_ _lhsIaroundMap
                                  {-# LINE 1587 "dist/build/Order" #-}
                                  )
                             -- "src-ag/Order.ag"(line 507, column 17)
                             _ntattrs =
                                 ({-# LINE 507 "src-ag/Order.ag" #-}
                                  [ NTAInh nt_ inh tp | (inh,tp) <- Map.assocs inh_ ]
                                  ++ [NTASyn nt_ syn tp | (syn,tp) <- Map.assocs syn_ ]
                                  {-# LINE 1594 "dist/build/Order" #-}
                                  )
                             -- "src-ag/Order.ag"(line 509, column 17)
                             _lhsOntattrs =
                                 ({-# LINE 509 "src-ag/Order.ag" #-}
                                  Seq.fromList (zip [_lhsIacount ..] _ntattrs)
                                  {-# LINE 1600 "dist/build/Order" #-}
                                  )
                             -- "src-ag/Order.ag"(line 510, column 17)
                             _lhsOacount =
                                 ({-# LINE 510 "src-ag/Order.ag" #-}
                                  _lhsIacount + Map.size inh_ + Map.size syn_
                                  {-# LINE 1606 "dist/build/Order" #-}
                                  )
                             -- "src-ag/Order.ag"(line 511, column 17)
                             _lhsOaranges =
                                 ({-# LINE 511 "src-ag/Order.ag" #-}
                                  Seq.singleton
                                   (_lhsIacount
                                   ,_lhsIacount + Map.size inh_
                                   ,_lhsIacount + Map.size syn_ + Map.size inh_ - 1)
                                  {-# LINE 1615 "dist/build/Order" #-}
                                  )
                             -- "src-ag/Order.ag"(line 520, column 19)
                             _lhsOnonts =
                                 ({-# LINE 520 "src-ag/Order.ag" #-}
                                  [(nt_,_prodsIcons)]
                                  {-# LINE 1621 "dist/build/Order" #-}
                                  )
                             -- "src-ag/Order.ag"(line 597, column 19)
                             _cInter =
                                 ({-# LINE 597 "src-ag/Order.ag" #-}
                                  if  _lhsIo_dovisit
                                         then findWithErr1 "Nonterminal.cInter" nt_ _lhsIcInterfaceMap
                                         else CInterface [CSegment inh_ syn_]
                                  {-# LINE 1629 "dist/build/Order" #-}
                                  )
                             -- "src-ag/Order.ag"(line 625, column 19)
                             _lhsOcNonterminal =
                                 ({-# LINE 625 "src-ag/Order.ag" #-}
                                  CNonterminal nt_ params_ inh_ syn_ _prodsIcProductions _cInter
                                  {-# LINE 1635 "dist/build/Order" #-}
                                  )
                             -- "src-ag/DistChildAttr.ag"(line 7, column 18)
                             _lhsOinhMap' =
                                 ({-# LINE 7 "src-ag/DistChildAttr.ag" #-}
                                  Map.singleton nt_ inh_
                                  {-# LINE 1641 "dist/build/Order" #-}
                                  )
                             -- "src-ag/DistChildAttr.ag"(line 8, column 18)
                             _lhsOsynMap' =
                                 ({-# LINE 8 "src-ag/DistChildAttr.ag" #-}
                                  Map.singleton nt_ syn_
                                  {-# LINE 1647 "dist/build/Order" #-}
                                  )
                             -- use rule "src-ag/Order.ag"(line 282, column 60)
                             _lhsOadditionalDep =
                                 ({-# LINE 282 "src-ag/Order.ag" #-}
                                  _prodsIadditionalDep
                                  {-# LINE 1653 "dist/build/Order" #-}
                                  )
                             -- use rule "src-ag/Order.ag"(line 403, column 24)
                             _lhsOaroundDep =
                                 ({-# LINE 403 "src-ag/Order.ag" #-}
                                  _prodsIaroundDep
                                  {-# LINE 1659 "dist/build/Order" #-}
                                  )
                             -- use rule "src-ag/Order.ag"(line 268, column 33)
                             _lhsOdirectDep =
                                 ({-# LINE 268 "src-ag/Order.ag" #-}
                                  _prodsIdirectDep
                                  {-# LINE 1665 "dist/build/Order" #-}
                                  )
                             -- use rule "src-ag/Order.ag"(line 85, column 70)
                             _lhsOerrors =
                                 ({-# LINE 85 "src-ag/Order.ag" #-}
                                  _prodsIerrors
                                  {-# LINE 1671 "dist/build/Order" #-}
                                  )
                             -- use rule "src-ag/Order.ag"(line 311, column 31)
                             _lhsOinstDep =
                                 ({-# LINE 311 "src-ag/Order.ag" #-}
                                  _prodsIinstDep
                                  {-# LINE 1677 "dist/build/Order" #-}
                                  )
                             -- use rule "src-ag/Order.ag"(line 366, column 18)
                             _lhsOmergeDep =
                                 ({-# LINE 366 "src-ag/Order.ag" #-}
                                  _prodsImergeDep
                                  {-# LINE 1683 "dist/build/Order" #-}
                                  )
                             -- use rule "src-ag/Order.ag"(line 62, column 105)
                             _lhsOnAutoRules =
                                 ({-# LINE 62 "src-ag/Order.ag" #-}
                                  _prodsInAutoRules
                                  {-# LINE 1689 "dist/build/Order" #-}
                                  )
                             -- use rule "src-ag/Order.ag"(line 62, column 105)
                             _lhsOnExplicitRules =
                                 ({-# LINE 62 "src-ag/Order.ag" #-}
                                  _prodsInExplicitRules
                                  {-# LINE 1695 "dist/build/Order" #-}
                                  )
                             -- use rule "src-ag/Order.ag"(line 258, column 18)
                             _lhsOrules =
                                 ({-# LINE 258 "src-ag/Order.ag" #-}
                                  _prodsIrules
                                  {-# LINE 1701 "dist/build/Order" #-}
                                  )
                             -- copy rule (up)
                             _lhsOvcount =
                                 ({-# LINE 257 "src-ag/Order.ag" #-}
                                  _prodsIvcount
                                  {-# LINE 1707 "dist/build/Order" #-}
                                  )
                             -- copy rule (down)
                             _prodsOallnts =
                                 ({-# LINE 648 "src-ag/Order.ag" #-}
                                  _lhsIallnts
                                  {-# LINE 1713 "dist/build/Order" #-}
                                  )
                             -- copy rule (from local)
                             _prodsOaroundMap =
                                 ({-# LINE 409 "src-ag/Order.ag" #-}
                                  _aroundMap
                                  {-# LINE 1719 "dist/build/Order" #-}
                                  )
                             -- copy rule (down)
                             _prodsOcVisitsMap =
                                 ({-# LINE 602 "src-ag/Order.ag" #-}
                                  _lhsIcVisitsMap
                                  {-# LINE 1725 "dist/build/Order" #-}
                                  )
                             -- copy rule (down)
                             _prodsOinhMap =
                                 ({-# LINE 12 "src-ag/DistChildAttr.ag" #-}
                                  _lhsIinhMap
                                  {-# LINE 1731 "dist/build/Order" #-}
                                  )
                             -- copy rule (down)
                             _prodsOmanualAttrDepMap =
                                 ({-# LINE 282 "src-ag/Order.ag" #-}
                                  _lhsImanualAttrDepMap
                                  {-# LINE 1737 "dist/build/Order" #-}
                                  )
                             -- copy rule (from local)
                             _prodsOmergeMap =
                                 ({-# LINE 356 "src-ag/Order.ag" #-}
                                  _mergeMap
                                  {-# LINE 1743 "dist/build/Order" #-}
                                  )
                             -- copy rule (down)
                             _prodsOo_case =
                                 ({-# LINE 118 "src-ag/Order.ag" #-}
                                  _lhsIo_case
                                  {-# LINE 1749 "dist/build/Order" #-}
                                  )
                             -- copy rule (down)
                             _prodsOo_cata =
                                 ({-# LINE 112 "src-ag/Order.ag" #-}
                                  _lhsIo_cata
                                  {-# LINE 1755 "dist/build/Order" #-}
                                  )
                             -- copy rule (down)
                             _prodsOo_dovisit =
                                 ({-# LINE 117 "src-ag/Order.ag" #-}
                                  _lhsIo_dovisit
                                  {-# LINE 1761 "dist/build/Order" #-}
                                  )
                             -- copy rule (down)
                             _prodsOo_newtypes =
                                 ({-# LINE 111 "src-ag/Order.ag" #-}
                                  _lhsIo_newtypes
                                  {-# LINE 1767 "dist/build/Order" #-}
                                  )
                             -- copy rule (down)
                             _prodsOo_rename =
                                 ({-# LINE 115 "src-ag/Order.ag" #-}
                                  _lhsIo_rename
                                  {-# LINE 1773 "dist/build/Order" #-}
                                  )
                             -- copy rule (down)
                             _prodsOo_sem =
                                 ({-# LINE 114 "src-ag/Order.ag" #-}
                                  _lhsIo_sem
                                  {-# LINE 1779 "dist/build/Order" #-}
                                  )
                             -- copy rule (down)
                             _prodsOo_sig =
                                 ({-# LINE 113 "src-ag/Order.ag" #-}
                                  _lhsIo_sig
                                  {-# LINE 1785 "dist/build/Order" #-}
                                  )
                             -- copy rule (down)
                             _prodsOo_unbox =
                                 ({-# LINE 120 "src-ag/Order.ag" #-}
                                  _lhsIo_unbox
                                  {-# LINE 1791 "dist/build/Order" #-}
                                  )
                             -- copy rule (down)
                             _prodsOo_wantvisit =
                                 ({-# LINE 116 "src-ag/Order.ag" #-}
                                  _lhsIo_wantvisit
                                  {-# LINE 1797 "dist/build/Order" #-}
                                  )
                             -- copy rule (down)
                             _prodsOprefix =
                                 ({-# LINE 119 "src-ag/Order.ag" #-}
                                  _lhsIprefix
                                  {-# LINE 1803 "dist/build/Order" #-}
                                  )
                             -- copy rule (down)
                             _prodsOsynMap =
                                 ({-# LINE 12 "src-ag/DistChildAttr.ag" #-}
                                  _lhsIsynMap
                                  {-# LINE 1809 "dist/build/Order" #-}
                                  )
                             -- copy rule (down)
                             _prodsOvcount =
                                 ({-# LINE 257 "src-ag/Order.ag" #-}
                                  _lhsIvcount
                                  {-# LINE 1815 "dist/build/Order" #-}
                                  )
                             ( _prodsIadditionalDep,_prodsIaroundDep,_prodsIcProductions,_prodsIcons,_prodsIdirectDep,_prodsIerrors,_prodsIinstDep,_prodsImergeDep,_prodsInAutoRules,_prodsInExplicitRules,_prodsIrules,_prodsIvcount) =
                                 prods_ _prodsOallnts _prodsOaroundMap _prodsOcVisitsMap _prodsOinh _prodsOinhMap _prodsOmanualAttrDepMap _prodsOmergeMap _prodsOnt _prodsOo_case _prodsOo_cata _prodsOo_dovisit _prodsOo_newtypes _prodsOo_rename _prodsOo_sem _prodsOo_sig _prodsOo_unbox _prodsOo_wantvisit _prodsOprefix _prodsOsyn _prodsOsynMap _prodsOvcount
                         in  ( _lhsOacount,_lhsOadditionalDep,_lhsOaranges,_lhsOaroundDep,_lhsOcNonterminal,_lhsOdirectDep,_lhsOerrors,_lhsOinhMap',_lhsOinstDep,_lhsOmergeDep,_lhsOnAutoRules,_lhsOnExplicitRules,_lhsOnonts,_lhsOntattrs,_lhsOrules,_lhsOsynMap',_lhsOvcount))))
-- Nonterminals ------------------------------------------------
{-
   visit 0:
      inherited attributes:
         allnts               : [Identifier]
         aroundMap            : Map NontermIdent (Map ConstructorIdent (Map Identifier [Expression]))
         cInterfaceMap        : CInterfaceMap
         cVisitsMap           : CVisitsMap
         inhMap               : Map Identifier Attributes
         manualAttrDepMap     : AttrOrderMap
         mergeMap             : Map NontermIdent (Map ConstructorIdent (Map Identifier (Identifier,[Identifier])))
         o_case               : Bool
         o_cata               : Bool
         o_data               : Bool
         o_dovisit            : Bool
         o_newtypes           : Bool
         o_rename             : Bool
         o_sem                : Bool
         o_sig                : Bool
         o_unbox              : Bool
         o_wantvisit          : Bool
         prefix               : String
         synMap               : Map Identifier Attributes
      chained attributes:
         acount               : Int
         vcount               : Int
      synthesized attributes:
         additionalDep        : Seq Edge
         aranges              : Seq (Int,Int,Int)
         aroundDep            : Seq Edge
         cNonterminals        : CNonterminals
         directDep            : Seq Edge
         errors               : Seq Error
         inhMap'              : Map Identifier Attributes
         instDep              : Seq Edge
         mergeDep             : Seq Edge
         nAutoRules           : Int
         nExplicitRules       : Int
         nonts                : [(NontermIdent,[ConstructorIdent])]
         ntattrs              : Seq (Vertex,NTAttr)
         rules                : Seq (Vertex,CRule)
         synMap'              : Map Identifier Attributes
   alternatives:
      alternative Cons:
         child hd             : Nonterminal 
         child tl             : Nonterminals 
      alternative Nil:
-}
-- cata
sem_Nonterminals :: Nonterminals ->
                    T_Nonterminals
sem_Nonterminals list =
    (Prelude.foldr sem_Nonterminals_Cons sem_Nonterminals_Nil (Prelude.map sem_Nonterminal list))
-- semantic domain
newtype T_Nonterminals = T_Nonterminals (Int ->
                                         ([Identifier]) ->
                                         (Map NontermIdent (Map ConstructorIdent (Map Identifier [Expression]))) ->
                                         CInterfaceMap ->
                                         CVisitsMap ->
                                         (Map Identifier Attributes) ->
                                         AttrOrderMap ->
                                         (Map NontermIdent (Map ConstructorIdent (Map Identifier (Identifier,[Identifier])))) ->
                                         Bool ->
                                         Bool ->
                                         Bool ->
                                         Bool ->
                                         Bool ->
                                         Bool ->
                                         Bool ->
                                         Bool ->
                                         Bool ->
                                         Bool ->
                                         String ->
                                         (Map Identifier Attributes) ->
                                         Int ->
                                         ( Int,(Seq Edge),(Seq (Int,Int,Int)),(Seq Edge),CNonterminals,(Seq Edge),(Seq Error),(Map Identifier Attributes),(Seq Edge),(Seq Edge),Int,Int,([(NontermIdent,[ConstructorIdent])]),(Seq (Vertex,NTAttr)),(Seq (Vertex,CRule)),(Map Identifier Attributes),Int))
data Inh_Nonterminals = Inh_Nonterminals {acount_Inh_Nonterminals :: !(Int),allnts_Inh_Nonterminals :: !(([Identifier])),aroundMap_Inh_Nonterminals :: !((Map NontermIdent (Map ConstructorIdent (Map Identifier [Expression])))),cInterfaceMap_Inh_Nonterminals :: !(CInterfaceMap),cVisitsMap_Inh_Nonterminals :: !(CVisitsMap),inhMap_Inh_Nonterminals :: !((Map Identifier Attributes)),manualAttrDepMap_Inh_Nonterminals :: !(AttrOrderMap),mergeMap_Inh_Nonterminals :: !((Map NontermIdent (Map ConstructorIdent (Map Identifier (Identifier,[Identifier]))))),o_case_Inh_Nonterminals :: !(Bool),o_cata_Inh_Nonterminals :: !(Bool),o_data_Inh_Nonterminals :: !(Bool),o_dovisit_Inh_Nonterminals :: !(Bool),o_newtypes_Inh_Nonterminals :: !(Bool),o_rename_Inh_Nonterminals :: !(Bool),o_sem_Inh_Nonterminals :: !(Bool),o_sig_Inh_Nonterminals :: !(Bool),o_unbox_Inh_Nonterminals :: !(Bool),o_wantvisit_Inh_Nonterminals :: !(Bool),prefix_Inh_Nonterminals :: !(String),synMap_Inh_Nonterminals :: !((Map Identifier Attributes)),vcount_Inh_Nonterminals :: !(Int)}
data Syn_Nonterminals = Syn_Nonterminals {acount_Syn_Nonterminals :: !(Int),additionalDep_Syn_Nonterminals :: !((Seq Edge)),aranges_Syn_Nonterminals :: !((Seq (Int,Int,Int))),aroundDep_Syn_Nonterminals :: !((Seq Edge)),cNonterminals_Syn_Nonterminals :: !(CNonterminals),directDep_Syn_Nonterminals :: !((Seq Edge)),errors_Syn_Nonterminals :: !((Seq Error)),inhMap'_Syn_Nonterminals :: !((Map Identifier Attributes)),instDep_Syn_Nonterminals :: !((Seq Edge)),mergeDep_Syn_Nonterminals :: !((Seq Edge)),nAutoRules_Syn_Nonterminals :: !(Int),nExplicitRules_Syn_Nonterminals :: !(Int),nonts_Syn_Nonterminals :: !(([(NontermIdent,[ConstructorIdent])])),ntattrs_Syn_Nonterminals :: !((Seq (Vertex,NTAttr))),rules_Syn_Nonterminals :: !((Seq (Vertex,CRule))),synMap'_Syn_Nonterminals :: !((Map Identifier Attributes)),vcount_Syn_Nonterminals :: !(Int)}
wrap_Nonterminals :: T_Nonterminals ->
                     Inh_Nonterminals ->
                     Syn_Nonterminals
wrap_Nonterminals (T_Nonterminals sem) (Inh_Nonterminals _lhsIacount _lhsIallnts _lhsIaroundMap _lhsIcInterfaceMap _lhsIcVisitsMap _lhsIinhMap _lhsImanualAttrDepMap _lhsImergeMap _lhsIo_case _lhsIo_cata _lhsIo_data _lhsIo_dovisit _lhsIo_newtypes _lhsIo_rename _lhsIo_sem _lhsIo_sig _lhsIo_unbox _lhsIo_wantvisit _lhsIprefix _lhsIsynMap _lhsIvcount) =
    (let ( _lhsOacount,_lhsOadditionalDep,_lhsOaranges,_lhsOaroundDep,_lhsOcNonterminals,_lhsOdirectDep,_lhsOerrors,_lhsOinhMap',_lhsOinstDep,_lhsOmergeDep,_lhsOnAutoRules,_lhsOnExplicitRules,_lhsOnonts,_lhsOntattrs,_lhsOrules,_lhsOsynMap',_lhsOvcount) = sem _lhsIacount _lhsIallnts _lhsIaroundMap _lhsIcInterfaceMap _lhsIcVisitsMap _lhsIinhMap _lhsImanualAttrDepMap _lhsImergeMap _lhsIo_case _lhsIo_cata _lhsIo_data _lhsIo_dovisit _lhsIo_newtypes _lhsIo_rename _lhsIo_sem _lhsIo_sig _lhsIo_unbox _lhsIo_wantvisit _lhsIprefix _lhsIsynMap _lhsIvcount
     in  (Syn_Nonterminals _lhsOacount _lhsOadditionalDep _lhsOaranges _lhsOaroundDep _lhsOcNonterminals _lhsOdirectDep _lhsOerrors _lhsOinhMap' _lhsOinstDep _lhsOmergeDep _lhsOnAutoRules _lhsOnExplicitRules _lhsOnonts _lhsOntattrs _lhsOrules _lhsOsynMap' _lhsOvcount))
sem_Nonterminals_Cons :: T_Nonterminal ->
                         T_Nonterminals ->
                         T_Nonterminals
sem_Nonterminals_Cons (T_Nonterminal hd_) (T_Nonterminals tl_) =
    (T_Nonterminals (\ _lhsIacount
                       _lhsIallnts
                       _lhsIaroundMap
                       _lhsIcInterfaceMap
                       _lhsIcVisitsMap
                       _lhsIinhMap
                       _lhsImanualAttrDepMap
                       _lhsImergeMap
                       _lhsIo_case
                       _lhsIo_cata
                       _lhsIo_data
                       _lhsIo_dovisit
                       _lhsIo_newtypes
                       _lhsIo_rename
                       _lhsIo_sem
                       _lhsIo_sig
                       _lhsIo_unbox
                       _lhsIo_wantvisit
                       _lhsIprefix
                       _lhsIsynMap
                       _lhsIvcount ->
                         (let _lhsOcNonterminals :: CNonterminals
                              _lhsOadditionalDep :: (Seq Edge)
                              _lhsOaranges :: (Seq (Int,Int,Int))
                              _lhsOaroundDep :: (Seq Edge)
                              _lhsOdirectDep :: (Seq Edge)
                              _lhsOerrors :: (Seq Error)
                              _lhsOinhMap' :: (Map Identifier Attributes)
                              _lhsOinstDep :: (Seq Edge)
                              _lhsOmergeDep :: (Seq Edge)
                              _lhsOnAutoRules :: Int
                              _lhsOnExplicitRules :: Int
                              _lhsOnonts :: ([(NontermIdent,[ConstructorIdent])])
                              _lhsOntattrs :: (Seq (Vertex,NTAttr))
                              _lhsOrules :: (Seq (Vertex,CRule))
                              _lhsOsynMap' :: (Map Identifier Attributes)
                              _lhsOacount :: Int
                              _lhsOvcount :: Int
                              _hdOacount :: Int
                              _hdOallnts :: ([Identifier])
                              _hdOaroundMap :: (Map NontermIdent (Map ConstructorIdent (Map Identifier [Expression])))
                              _hdOcInterfaceMap :: CInterfaceMap
                              _hdOcVisitsMap :: CVisitsMap
                              _hdOinhMap :: (Map Identifier Attributes)
                              _hdOmanualAttrDepMap :: AttrOrderMap
                              _hdOmergeMap :: (Map NontermIdent (Map ConstructorIdent (Map Identifier (Identifier,[Identifier]))))
                              _hdOo_case :: Bool
                              _hdOo_cata :: Bool
                              _hdOo_data :: Bool
                              _hdOo_dovisit :: Bool
                              _hdOo_newtypes :: Bool
                              _hdOo_rename :: Bool
                              _hdOo_sem :: Bool
                              _hdOo_sig :: Bool
                              _hdOo_unbox :: Bool
                              _hdOo_wantvisit :: Bool
                              _hdOprefix :: String
                              _hdOsynMap :: (Map Identifier Attributes)
                              _hdOvcount :: Int
                              _tlOacount :: Int
                              _tlOallnts :: ([Identifier])
                              _tlOaroundMap :: (Map NontermIdent (Map ConstructorIdent (Map Identifier [Expression])))
                              _tlOcInterfaceMap :: CInterfaceMap
                              _tlOcVisitsMap :: CVisitsMap
                              _tlOinhMap :: (Map Identifier Attributes)
                              _tlOmanualAttrDepMap :: AttrOrderMap
                              _tlOmergeMap :: (Map NontermIdent (Map ConstructorIdent (Map Identifier (Identifier,[Identifier]))))
                              _tlOo_case :: Bool
                              _tlOo_cata :: Bool
                              _tlOo_data :: Bool
                              _tlOo_dovisit :: Bool
                              _tlOo_newtypes :: Bool
                              _tlOo_rename :: Bool
                              _tlOo_sem :: Bool
                              _tlOo_sig :: Bool
                              _tlOo_unbox :: Bool
                              _tlOo_wantvisit :: Bool
                              _tlOprefix :: String
                              _tlOsynMap :: (Map Identifier Attributes)
                              _tlOvcount :: Int
                              _hdIacount :: Int
                              _hdIadditionalDep :: (Seq Edge)
                              _hdIaranges :: (Seq (Int,Int,Int))
                              _hdIaroundDep :: (Seq Edge)
                              _hdIcNonterminal :: CNonterminal
                              _hdIdirectDep :: (Seq Edge)
                              _hdIerrors :: (Seq Error)
                              _hdIinhMap' :: (Map Identifier Attributes)
                              _hdIinstDep :: (Seq Edge)
                              _hdImergeDep :: (Seq Edge)
                              _hdInAutoRules :: Int
                              _hdInExplicitRules :: Int
                              _hdInonts :: ([(NontermIdent,[ConstructorIdent])])
                              _hdIntattrs :: (Seq (Vertex,NTAttr))
                              _hdIrules :: (Seq (Vertex,CRule))
                              _hdIsynMap' :: (Map Identifier Attributes)
                              _hdIvcount :: Int
                              _tlIacount :: Int
                              _tlIadditionalDep :: (Seq Edge)
                              _tlIaranges :: (Seq (Int,Int,Int))
                              _tlIaroundDep :: (Seq Edge)
                              _tlIcNonterminals :: CNonterminals
                              _tlIdirectDep :: (Seq Edge)
                              _tlIerrors :: (Seq Error)
                              _tlIinhMap' :: (Map Identifier Attributes)
                              _tlIinstDep :: (Seq Edge)
                              _tlImergeDep :: (Seq Edge)
                              _tlInAutoRules :: Int
                              _tlInExplicitRules :: Int
                              _tlInonts :: ([(NontermIdent,[ConstructorIdent])])
                              _tlIntattrs :: (Seq (Vertex,NTAttr))
                              _tlIrules :: (Seq (Vertex,CRule))
                              _tlIsynMap' :: (Map Identifier Attributes)
                              _tlIvcount :: Int
                              -- "src-ag/Order.ag"(line 622, column 12)
                              _lhsOcNonterminals =
                                  ({-# LINE 622 "src-ag/Order.ag" #-}
                                   _hdIcNonterminal : _tlIcNonterminals
                                   {-# LINE 2026 "dist/build/Order" #-}
                                   )
                              -- use rule "src-ag/Order.ag"(line 282, column 60)
                              _lhsOadditionalDep =
                                  ({-# LINE 282 "src-ag/Order.ag" #-}
                                   _hdIadditionalDep Seq.>< _tlIadditionalDep
                                   {-# LINE 2032 "dist/build/Order" #-}
                                   )
                              -- use rule "src-ag/Order.ag"(line 501, column 36)
                              _lhsOaranges =
                                  ({-# LINE 501 "src-ag/Order.ag" #-}
                                   _hdIaranges Seq.>< _tlIaranges
                                   {-# LINE 2038 "dist/build/Order" #-}
                                   )
                              -- use rule "src-ag/Order.ag"(line 403, column 24)
                              _lhsOaroundDep =
                                  ({-# LINE 403 "src-ag/Order.ag" #-}
                                   _hdIaroundDep Seq.>< _tlIaroundDep
                                   {-# LINE 2044 "dist/build/Order" #-}
                                   )
                              -- use rule "src-ag/Order.ag"(line 268, column 33)
                              _lhsOdirectDep =
                                  ({-# LINE 268 "src-ag/Order.ag" #-}
                                   _hdIdirectDep Seq.>< _tlIdirectDep
                                   {-# LINE 2050 "dist/build/Order" #-}
                                   )
                              -- use rule "src-ag/Order.ag"(line 85, column 70)
                              _lhsOerrors =
                                  ({-# LINE 85 "src-ag/Order.ag" #-}
                                   _hdIerrors Seq.>< _tlIerrors
                                   {-# LINE 2056 "dist/build/Order" #-}
                                   )
                              -- use rule "src-ag/DistChildAttr.ag"(line 4, column 53)
                              _lhsOinhMap' =
                                  ({-# LINE 4 "src-ag/DistChildAttr.ag" #-}
                                   _hdIinhMap' `Map.union` _tlIinhMap'
                                   {-# LINE 2062 "dist/build/Order" #-}
                                   )
                              -- use rule "src-ag/Order.ag"(line 311, column 31)
                              _lhsOinstDep =
                                  ({-# LINE 311 "src-ag/Order.ag" #-}
                                   _hdIinstDep Seq.>< _tlIinstDep
                                   {-# LINE 2068 "dist/build/Order" #-}
                                   )
                              -- use rule "src-ag/Order.ag"(line 366, column 18)
                              _lhsOmergeDep =
                                  ({-# LINE 366 "src-ag/Order.ag" #-}
                                   _hdImergeDep Seq.>< _tlImergeDep
                                   {-# LINE 2074 "dist/build/Order" #-}
                                   )
                              -- use rule "src-ag/Order.ag"(line 62, column 105)
                              _lhsOnAutoRules =
                                  ({-# LINE 62 "src-ag/Order.ag" #-}
                                   _hdInAutoRules + _tlInAutoRules
                                   {-# LINE 2080 "dist/build/Order" #-}
                                   )
                              -- use rule "src-ag/Order.ag"(line 62, column 105)
                              _lhsOnExplicitRules =
                                  ({-# LINE 62 "src-ag/Order.ag" #-}
                                   _hdInExplicitRules + _tlInExplicitRules
                                   {-# LINE 2086 "dist/build/Order" #-}
                                   )
                              -- use rule "src-ag/Order.ag"(line 518, column 43)
                              _lhsOnonts =
                                  ({-# LINE 518 "src-ag/Order.ag" #-}
                                   _hdInonts ++ _tlInonts
                                   {-# LINE 2092 "dist/build/Order" #-}
                                   )
                              -- use rule "src-ag/Order.ag"(line 500, column 35)
                              _lhsOntattrs =
                                  ({-# LINE 500 "src-ag/Order.ag" #-}
                                   _hdIntattrs Seq.>< _tlIntattrs
                                   {-# LINE 2098 "dist/build/Order" #-}
                                   )
                              -- use rule "src-ag/Order.ag"(line 258, column 18)
                              _lhsOrules =
                                  ({-# LINE 258 "src-ag/Order.ag" #-}
                                   _hdIrules Seq.>< _tlIrules
                                   {-# LINE 2104 "dist/build/Order" #-}
                                   )
                              -- use rule "src-ag/DistChildAttr.ag"(line 4, column 53)
                              _lhsOsynMap' =
                                  ({-# LINE 4 "src-ag/DistChildAttr.ag" #-}
                                   _hdIsynMap' `Map.union` _tlIsynMap'
                                   {-# LINE 2110 "dist/build/Order" #-}
                                   )
                              -- copy rule (up)
                              _lhsOacount =
                                  ({-# LINE 500 "src-ag/Order.ag" #-}
                                   _tlIacount
                                   {-# LINE 2116 "dist/build/Order" #-}
                                   )
                              -- copy rule (up)
                              _lhsOvcount =
                                  ({-# LINE 257 "src-ag/Order.ag" #-}
                                   _tlIvcount
                                   {-# LINE 2122 "dist/build/Order" #-}
                                   )
                              -- copy rule (down)
                              _hdOacount =
                                  ({-# LINE 500 "src-ag/Order.ag" #-}
                                   _lhsIacount
                                   {-# LINE 2128 "dist/build/Order" #-}
                                   )
                              -- copy rule (down)
                              _hdOallnts =
                                  ({-# LINE 648 "src-ag/Order.ag" #-}
                                   _lhsIallnts
                                   {-# LINE 2134 "dist/build/Order" #-}
                                   )
                              -- copy rule (down)
                              _hdOaroundMap =
                                  ({-# LINE 406 "src-ag/Order.ag" #-}
                                   _lhsIaroundMap
                                   {-# LINE 2140 "dist/build/Order" #-}
                                   )
                              -- copy rule (down)
                              _hdOcInterfaceMap =
                                  ({-# LINE 595 "src-ag/Order.ag" #-}
                                   _lhsIcInterfaceMap
                                   {-# LINE 2146 "dist/build/Order" #-}
                                   )
                              -- copy rule (down)
                              _hdOcVisitsMap =
                                  ({-# LINE 602 "src-ag/Order.ag" #-}
                                   _lhsIcVisitsMap
                                   {-# LINE 2152 "dist/build/Order" #-}
                                   )
                              -- copy rule (down)
                              _hdOinhMap =
                                  ({-# LINE 12 "src-ag/DistChildAttr.ag" #-}
                                   _lhsIinhMap
                                   {-# LINE 2158 "dist/build/Order" #-}
                                   )
                              -- copy rule (down)
                              _hdOmanualAttrDepMap =
                                  ({-# LINE 282 "src-ag/Order.ag" #-}
                                   _lhsImanualAttrDepMap
                                   {-# LINE 2164 "dist/build/Order" #-}
                                   )
                              -- copy rule (down)
                              _hdOmergeMap =
                                  ({-# LINE 353 "src-ag/Order.ag" #-}
                                   _lhsImergeMap
                                   {-# LINE 2170 "dist/build/Order" #-}
                                   )
                              -- copy rule (down)
                              _hdOo_case =
                                  ({-# LINE 118 "src-ag/Order.ag" #-}
                                   _lhsIo_case
                                   {-# LINE 2176 "dist/build/Order" #-}
                                   )
                              -- copy rule (down)
                              _hdOo_cata =
                                  ({-# LINE 112 "src-ag/Order.ag" #-}
                                   _lhsIo_cata
                                   {-# LINE 2182 "dist/build/Order" #-}
                                   )
                              -- copy rule (down)
                              _hdOo_data =
                                  ({-# LINE 121 "src-ag/Order.ag" #-}
                                   _lhsIo_data
                                   {-# LINE 2188 "dist/build/Order" #-}
                                   )
                              -- copy rule (down)
                              _hdOo_dovisit =
                                  ({-# LINE 117 "src-ag/Order.ag" #-}
                                   _lhsIo_dovisit
                                   {-# LINE 2194 "dist/build/Order" #-}
                                   )
                              -- copy rule (down)
                              _hdOo_newtypes =
                                  ({-# LINE 111 "src-ag/Order.ag" #-}
                                   _lhsIo_newtypes
                                   {-# LINE 2200 "dist/build/Order" #-}
                                   )
                              -- copy rule (down)
                              _hdOo_rename =
                                  ({-# LINE 115 "src-ag/Order.ag" #-}
                                   _lhsIo_rename
                                   {-# LINE 2206 "dist/build/Order" #-}
                                   )
                              -- copy rule (down)
                              _hdOo_sem =
                                  ({-# LINE 114 "src-ag/Order.ag" #-}
                                   _lhsIo_sem
                                   {-# LINE 2212 "dist/build/Order" #-}
                                   )
                              -- copy rule (down)
                              _hdOo_sig =
                                  ({-# LINE 113 "src-ag/Order.ag" #-}
                                   _lhsIo_sig
                                   {-# LINE 2218 "dist/build/Order" #-}
                                   )
                              -- copy rule (down)
                              _hdOo_unbox =
                                  ({-# LINE 120 "src-ag/Order.ag" #-}
                                   _lhsIo_unbox
                                   {-# LINE 2224 "dist/build/Order" #-}
                                   )
                              -- copy rule (down)
                              _hdOo_wantvisit =
                                  ({-# LINE 116 "src-ag/Order.ag" #-}
                                   _lhsIo_wantvisit
                                   {-# LINE 2230 "dist/build/Order" #-}
                                   )
                              -- copy rule (down)
                              _hdOprefix =
                                  ({-# LINE 119 "src-ag/Order.ag" #-}
                                   _lhsIprefix
                                   {-# LINE 2236 "dist/build/Order" #-}
                                   )
                              -- copy rule (down)
                              _hdOsynMap =
                                  ({-# LINE 12 "src-ag/DistChildAttr.ag" #-}
                                   _lhsIsynMap
                                   {-# LINE 2242 "dist/build/Order" #-}
                                   )
                              -- copy rule (down)
                              _hdOvcount =
                                  ({-# LINE 257 "src-ag/Order.ag" #-}
                                   _lhsIvcount
                                   {-# LINE 2248 "dist/build/Order" #-}
                                   )
                              -- copy rule (chain)
                              _tlOacount =
                                  ({-# LINE 500 "src-ag/Order.ag" #-}
                                   _hdIacount
                                   {-# LINE 2254 "dist/build/Order" #-}
                                   )
                              -- copy rule (down)
                              _tlOallnts =
                                  ({-# LINE 648 "src-ag/Order.ag" #-}
                                   _lhsIallnts
                                   {-# LINE 2260 "dist/build/Order" #-}
                                   )
                              -- copy rule (down)
                              _tlOaroundMap =
                                  ({-# LINE 406 "src-ag/Order.ag" #-}
                                   _lhsIaroundMap
                                   {-# LINE 2266 "dist/build/Order" #-}
                                   )
                              -- copy rule (down)
                              _tlOcInterfaceMap =
                                  ({-# LINE 595 "src-ag/Order.ag" #-}
                                   _lhsIcInterfaceMap
                                   {-# LINE 2272 "dist/build/Order" #-}
                                   )
                              -- copy rule (down)
                              _tlOcVisitsMap =
                                  ({-# LINE 602 "src-ag/Order.ag" #-}
                                   _lhsIcVisitsMap
                                   {-# LINE 2278 "dist/build/Order" #-}
                                   )
                              -- copy rule (down)
                              _tlOinhMap =
                                  ({-# LINE 12 "src-ag/DistChildAttr.ag" #-}
                                   _lhsIinhMap
                                   {-# LINE 2284 "dist/build/Order" #-}
                                   )
                              -- copy rule (down)
                              _tlOmanualAttrDepMap =
                                  ({-# LINE 282 "src-ag/Order.ag" #-}
                                   _lhsImanualAttrDepMap
                                   {-# LINE 2290 "dist/build/Order" #-}
                                   )
                              -- copy rule (down)
                              _tlOmergeMap =
                                  ({-# LINE 353 "src-ag/Order.ag" #-}
                                   _lhsImergeMap
                                   {-# LINE 2296 "dist/build/Order" #-}
                                   )
                              -- copy rule (down)
                              _tlOo_case =
                                  ({-# LINE 118 "src-ag/Order.ag" #-}
                                   _lhsIo_case
                                   {-# LINE 2302 "dist/build/Order" #-}
                                   )
                              -- copy rule (down)
                              _tlOo_cata =
                                  ({-# LINE 112 "src-ag/Order.ag" #-}
                                   _lhsIo_cata
                                   {-# LINE 2308 "dist/build/Order" #-}
                                   )
                              -- copy rule (down)
                              _tlOo_data =
                                  ({-# LINE 121 "src-ag/Order.ag" #-}
                                   _lhsIo_data
                                   {-# LINE 2314 "dist/build/Order" #-}
                                   )
                              -- copy rule (down)
                              _tlOo_dovisit =
                                  ({-# LINE 117 "src-ag/Order.ag" #-}
                                   _lhsIo_dovisit
                                   {-# LINE 2320 "dist/build/Order" #-}
                                   )
                              -- copy rule (down)
                              _tlOo_newtypes =
                                  ({-# LINE 111 "src-ag/Order.ag" #-}
                                   _lhsIo_newtypes
                                   {-# LINE 2326 "dist/build/Order" #-}
                                   )
                              -- copy rule (down)
                              _tlOo_rename =
                                  ({-# LINE 115 "src-ag/Order.ag" #-}
                                   _lhsIo_rename
                                   {-# LINE 2332 "dist/build/Order" #-}
                                   )
                              -- copy rule (down)
                              _tlOo_sem =
                                  ({-# LINE 114 "src-ag/Order.ag" #-}
                                   _lhsIo_sem
                                   {-# LINE 2338 "dist/build/Order" #-}
                                   )
                              -- copy rule (down)
                              _tlOo_sig =
                                  ({-# LINE 113 "src-ag/Order.ag" #-}
                                   _lhsIo_sig
                                   {-# LINE 2344 "dist/build/Order" #-}
                                   )
                              -- copy rule (down)
                              _tlOo_unbox =
                                  ({-# LINE 120 "src-ag/Order.ag" #-}
                                   _lhsIo_unbox
                                   {-# LINE 2350 "dist/build/Order" #-}
                                   )
                              -- copy rule (down)
                              _tlOo_wantvisit =
                                  ({-# LINE 116 "src-ag/Order.ag" #-}
                                   _lhsIo_wantvisit
                                   {-# LINE 2356 "dist/build/Order" #-}
                                   )
                              -- copy rule (down)
                              _tlOprefix =
                                  ({-# LINE 119 "src-ag/Order.ag" #-}
                                   _lhsIprefix
                                   {-# LINE 2362 "dist/build/Order" #-}
                                   )
                              -- copy rule (down)
                              _tlOsynMap =
                                  ({-# LINE 12 "src-ag/DistChildAttr.ag" #-}
                                   _lhsIsynMap
                                   {-# LINE 2368 "dist/build/Order" #-}
                                   )
                              -- copy rule (chain)
                              _tlOvcount =
                                  ({-# LINE 257 "src-ag/Order.ag" #-}
                                   _hdIvcount
                                   {-# LINE 2374 "dist/build/Order" #-}
                                   )
                              ( _hdIacount,_hdIadditionalDep,_hdIaranges,_hdIaroundDep,_hdIcNonterminal,_hdIdirectDep,_hdIerrors,_hdIinhMap',_hdIinstDep,_hdImergeDep,_hdInAutoRules,_hdInExplicitRules,_hdInonts,_hdIntattrs,_hdIrules,_hdIsynMap',_hdIvcount) =
                                  hd_ _hdOacount _hdOallnts _hdOaroundMap _hdOcInterfaceMap _hdOcVisitsMap _hdOinhMap _hdOmanualAttrDepMap _hdOmergeMap _hdOo_case _hdOo_cata _hdOo_data _hdOo_dovisit _hdOo_newtypes _hdOo_rename _hdOo_sem _hdOo_sig _hdOo_unbox _hdOo_wantvisit _hdOprefix _hdOsynMap _hdOvcount
                              ( _tlIacount,_tlIadditionalDep,_tlIaranges,_tlIaroundDep,_tlIcNonterminals,_tlIdirectDep,_tlIerrors,_tlIinhMap',_tlIinstDep,_tlImergeDep,_tlInAutoRules,_tlInExplicitRules,_tlInonts,_tlIntattrs,_tlIrules,_tlIsynMap',_tlIvcount) =
                                  tl_ _tlOacount _tlOallnts _tlOaroundMap _tlOcInterfaceMap _tlOcVisitsMap _tlOinhMap _tlOmanualAttrDepMap _tlOmergeMap _tlOo_case _tlOo_cata _tlOo_data _tlOo_dovisit _tlOo_newtypes _tlOo_rename _tlOo_sem _tlOo_sig _tlOo_unbox _tlOo_wantvisit _tlOprefix _tlOsynMap _tlOvcount
                          in  ( _lhsOacount,_lhsOadditionalDep,_lhsOaranges,_lhsOaroundDep,_lhsOcNonterminals,_lhsOdirectDep,_lhsOerrors,_lhsOinhMap',_lhsOinstDep,_lhsOmergeDep,_lhsOnAutoRules,_lhsOnExplicitRules,_lhsOnonts,_lhsOntattrs,_lhsOrules,_lhsOsynMap',_lhsOvcount))))
sem_Nonterminals_Nil :: T_Nonterminals
sem_Nonterminals_Nil =
    (T_Nonterminals (\ _lhsIacount
                       _lhsIallnts
                       _lhsIaroundMap
                       _lhsIcInterfaceMap
                       _lhsIcVisitsMap
                       _lhsIinhMap
                       _lhsImanualAttrDepMap
                       _lhsImergeMap
                       _lhsIo_case
                       _lhsIo_cata
                       _lhsIo_data
                       _lhsIo_dovisit
                       _lhsIo_newtypes
                       _lhsIo_rename
                       _lhsIo_sem
                       _lhsIo_sig
                       _lhsIo_unbox
                       _lhsIo_wantvisit
                       _lhsIprefix
                       _lhsIsynMap
                       _lhsIvcount ->
                         (let _lhsOcNonterminals :: CNonterminals
                              _lhsOadditionalDep :: (Seq Edge)
                              _lhsOaranges :: (Seq (Int,Int,Int))
                              _lhsOaroundDep :: (Seq Edge)
                              _lhsOdirectDep :: (Seq Edge)
                              _lhsOerrors :: (Seq Error)
                              _lhsOinhMap' :: (Map Identifier Attributes)
                              _lhsOinstDep :: (Seq Edge)
                              _lhsOmergeDep :: (Seq Edge)
                              _lhsOnAutoRules :: Int
                              _lhsOnExplicitRules :: Int
                              _lhsOnonts :: ([(NontermIdent,[ConstructorIdent])])
                              _lhsOntattrs :: (Seq (Vertex,NTAttr))
                              _lhsOrules :: (Seq (Vertex,CRule))
                              _lhsOsynMap' :: (Map Identifier Attributes)
                              _lhsOacount :: Int
                              _lhsOvcount :: Int
                              -- "src-ag/Order.ag"(line 623, column 12)
                              _lhsOcNonterminals =
                                  ({-# LINE 623 "src-ag/Order.ag" #-}
                                   []
                                   {-# LINE 2425 "dist/build/Order" #-}
                                   )
                              -- use rule "src-ag/Order.ag"(line 282, column 60)
                              _lhsOadditionalDep =
                                  ({-# LINE 282 "src-ag/Order.ag" #-}
                                   Seq.empty
                                   {-# LINE 2431 "dist/build/Order" #-}
                                   )
                              -- use rule "src-ag/Order.ag"(line 501, column 36)
                              _lhsOaranges =
                                  ({-# LINE 501 "src-ag/Order.ag" #-}
                                   Seq.empty
                                   {-# LINE 2437 "dist/build/Order" #-}
                                   )
                              -- use rule "src-ag/Order.ag"(line 403, column 24)
                              _lhsOaroundDep =
                                  ({-# LINE 403 "src-ag/Order.ag" #-}
                                   Seq.empty
                                   {-# LINE 2443 "dist/build/Order" #-}
                                   )
                              -- use rule "src-ag/Order.ag"(line 268, column 33)
                              _lhsOdirectDep =
                                  ({-# LINE 268 "src-ag/Order.ag" #-}
                                   Seq.empty
                                   {-# LINE 2449 "dist/build/Order" #-}
                                   )
                              -- use rule "src-ag/Order.ag"(line 85, column 70)
                              _lhsOerrors =
                                  ({-# LINE 85 "src-ag/Order.ag" #-}
                                   Seq.empty
                                   {-# LINE 2455 "dist/build/Order" #-}
                                   )
                              -- use rule "src-ag/DistChildAttr.ag"(line 4, column 53)
                              _lhsOinhMap' =
                                  ({-# LINE 4 "src-ag/DistChildAttr.ag" #-}
                                   Map.empty
                                   {-# LINE 2461 "dist/build/Order" #-}
                                   )
                              -- use rule "src-ag/Order.ag"(line 311, column 31)
                              _lhsOinstDep =
                                  ({-# LINE 311 "src-ag/Order.ag" #-}
                                   Seq.empty
                                   {-# LINE 2467 "dist/build/Order" #-}
                                   )
                              -- use rule "src-ag/Order.ag"(line 366, column 18)
                              _lhsOmergeDep =
                                  ({-# LINE 366 "src-ag/Order.ag" #-}
                                   Seq.empty
                                   {-# LINE 2473 "dist/build/Order" #-}
                                   )
                              -- use rule "src-ag/Order.ag"(line 62, column 105)
                              _lhsOnAutoRules =
                                  ({-# LINE 62 "src-ag/Order.ag" #-}
                                   0
                                   {-# LINE 2479 "dist/build/Order" #-}
                                   )
                              -- use rule "src-ag/Order.ag"(line 62, column 105)
                              _lhsOnExplicitRules =
                                  ({-# LINE 62 "src-ag/Order.ag" #-}
                                   0
                                   {-# LINE 2485 "dist/build/Order" #-}
                                   )
                              -- use rule "src-ag/Order.ag"(line 518, column 43)
                              _lhsOnonts =
                                  ({-# LINE 518 "src-ag/Order.ag" #-}
                                   []
                                   {-# LINE 2491 "dist/build/Order" #-}
                                   )
                              -- use rule "src-ag/Order.ag"(line 500, column 35)
                              _lhsOntattrs =
                                  ({-# LINE 500 "src-ag/Order.ag" #-}
                                   Seq.empty
                                   {-# LINE 2497 "dist/build/Order" #-}
                                   )
                              -- use rule "src-ag/Order.ag"(line 258, column 18)
                              _lhsOrules =
                                  ({-# LINE 258 "src-ag/Order.ag" #-}
                                   Seq.empty
                                   {-# LINE 2503 "dist/build/Order" #-}
                                   )
                              -- use rule "src-ag/DistChildAttr.ag"(line 4, column 53)
                              _lhsOsynMap' =
                                  ({-# LINE 4 "src-ag/DistChildAttr.ag" #-}
                                   Map.empty
                                   {-# LINE 2509 "dist/build/Order" #-}
                                   )
                              -- copy rule (chain)
                              _lhsOacount =
                                  ({-# LINE 500 "src-ag/Order.ag" #-}
                                   _lhsIacount
                                   {-# LINE 2515 "dist/build/Order" #-}
                                   )
                              -- copy rule (chain)
                              _lhsOvcount =
                                  ({-# LINE 257 "src-ag/Order.ag" #-}
                                   _lhsIvcount
                                   {-# LINE 2521 "dist/build/Order" #-}
                                   )
                          in  ( _lhsOacount,_lhsOadditionalDep,_lhsOaranges,_lhsOaroundDep,_lhsOcNonterminals,_lhsOdirectDep,_lhsOerrors,_lhsOinhMap',_lhsOinstDep,_lhsOmergeDep,_lhsOnAutoRules,_lhsOnExplicitRules,_lhsOnonts,_lhsOntattrs,_lhsOrules,_lhsOsynMap',_lhsOvcount))))
-- Pattern -----------------------------------------------------
{-
   visit 0:
      inherited attributes:
         allTypeSigs          : Map Identifier Type
         altAttrs             : Map AltAttr Vertex
         con                  : Identifier
         inh                  : Attributes
         nt                   : Identifier
         syn                  : Attributes
      synthesized attributes:
         copy                 : Pattern 
         errors               : Seq Error
         gathAltAttrs         : [AltAttr]
         instVars             : [Identifier]
         locVars              : [Identifier]
         patternAttrs         : [(Identifier,Identifier,Bool)]
   alternatives:
      alternative Alias:
         child field          : {Identifier}
         child attr           : {Identifier}
         child pat            : Pattern 
         visit 0:
            local copy        : _
      alternative Constr:
         child name           : {ConstructorIdent}
         child pats           : Patterns 
         visit 0:
            local copy        : _
      alternative Irrefutable:
         child pat            : Pattern 
         visit 0:
            local copy        : _
      alternative Product:
         child pos            : {Pos}
         child pats           : Patterns 
         visit 0:
            local copy        : _
      alternative Underscore:
         child pos            : {Pos}
         visit 0:
            local copy        : _
-}
-- cata
sem_Pattern :: Pattern ->
               T_Pattern
sem_Pattern (Alias _field _attr _pat) =
    (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 ((Map Identifier Type) ->
                               (Map AltAttr Vertex) ->
                               Identifier ->
                               Attributes ->
                               Identifier ->
                               Attributes ->
                               ( Pattern,(Seq Error),([AltAttr]),([Identifier]),([Identifier]),([(Identifier,Identifier,Bool)])))
data Inh_Pattern = Inh_Pattern {allTypeSigs_Inh_Pattern :: !((Map Identifier Type)),altAttrs_Inh_Pattern :: !((Map AltAttr Vertex)),con_Inh_Pattern :: !(Identifier),inh_Inh_Pattern :: !(Attributes),nt_Inh_Pattern :: !(Identifier),syn_Inh_Pattern :: !(Attributes)}
data Syn_Pattern = Syn_Pattern {copy_Syn_Pattern :: !(Pattern),errors_Syn_Pattern :: !((Seq Error)),gathAltAttrs_Syn_Pattern :: !(([AltAttr])),instVars_Syn_Pattern :: !(([Identifier])),locVars_Syn_Pattern :: !(([Identifier])),patternAttrs_Syn_Pattern :: !(([(Identifier,Identifier,Bool)]))}
wrap_Pattern :: T_Pattern ->
                Inh_Pattern ->
                Syn_Pattern
wrap_Pattern (T_Pattern sem) (Inh_Pattern _lhsIallTypeSigs _lhsIaltAttrs _lhsIcon _lhsIinh _lhsInt _lhsIsyn) =
    (let ( _lhsOcopy,_lhsOerrors,_lhsOgathAltAttrs,_lhsOinstVars,_lhsOlocVars,_lhsOpatternAttrs) = sem _lhsIallTypeSigs _lhsIaltAttrs _lhsIcon _lhsIinh _lhsInt _lhsIsyn
     in  (Syn_Pattern _lhsOcopy _lhsOerrors _lhsOgathAltAttrs _lhsOinstVars _lhsOlocVars _lhsOpatternAttrs))
sem_Pattern_Alias :: Identifier ->
                     Identifier ->
                     T_Pattern ->
                     T_Pattern
sem_Pattern_Alias field_ attr_ (T_Pattern pat_) =
    (T_Pattern (\ _lhsIallTypeSigs
                  _lhsIaltAttrs
                  _lhsIcon
                  _lhsIinh
                  _lhsInt
                  _lhsIsyn ->
                    (let _lhsOgathAltAttrs :: ([AltAttr])
                         _lhsOpatternAttrs :: ([(Identifier,Identifier,Bool)])
                         _lhsOlocVars :: ([Identifier])
                         _lhsOinstVars :: ([Identifier])
                         _lhsOerrors :: (Seq Error)
                         _lhsOcopy :: Pattern
                         _patOallTypeSigs :: (Map Identifier Type)
                         _patOaltAttrs :: (Map AltAttr Vertex)
                         _patOcon :: Identifier
                         _patOinh :: Attributes
                         _patOnt :: Identifier
                         _patOsyn :: Attributes
                         _patIcopy :: Pattern
                         _patIerrors :: (Seq Error)
                         _patIgathAltAttrs :: ([AltAttr])
                         _patIinstVars :: ([Identifier])
                         _patIlocVars :: ([Identifier])
                         _patIpatternAttrs :: ([(Identifier,Identifier,Bool)])
                         -- "src-ag/Order.ag"(line 185, column 12)
                         _lhsOgathAltAttrs =
                             ({-# LINE 185 "src-ag/Order.ag" #-}
                              [AltAttr field_ attr_ (field_ == _LOC || field_ == _INST)]
                              {-# LINE 2629 "dist/build/Order" #-}
                              )
                         -- "src-ag/Order.ag"(line 251, column 12)
                         _lhsOpatternAttrs =
                             ({-# LINE 251 "src-ag/Order.ag" #-}
                              [(field_,attr_,(field_ == _LOC || field_ == _INST))]
                              {-# LINE 2635 "dist/build/Order" #-}
                              )
                         -- "src-ag/Order.ag"(line 681, column 14)
                         _lhsOlocVars =
                             ({-# LINE 681 "src-ag/Order.ag" #-}
                              if field_ == _LOC
                                 then [attr_]
                                 else []
                              {-# LINE 2643 "dist/build/Order" #-}
                              )
                         -- "src-ag/Order.ag"(line 684, column 14)
                         _lhsOinstVars =
                             ({-# LINE 684 "src-ag/Order.ag" #-}
                              if field_ == _INST
                                 then [attr_]
                                 else []
                              {-# LINE 2651 "dist/build/Order" #-}
                              )
                         -- use rule "src-ag/Order.ag"(line 85, column 70)
                         _lhsOerrors =
                             ({-# LINE 85 "src-ag/Order.ag" #-}
                              _patIerrors
                              {-# LINE 2657 "dist/build/Order" #-}
                              )
                         -- self rule
                         _copy =
                             ({-# LINE 22 "src-ag/Patterns.ag" #-}
                              Alias field_ attr_ _patIcopy
                              {-# LINE 2663 "dist/build/Order" #-}
                              )
                         -- self rule
                         _lhsOcopy =
                             ({-# LINE 22 "src-ag/Patterns.ag" #-}
                              _copy
                              {-# LINE 2669 "dist/build/Order" #-}
                              )
                         -- copy rule (down)
                         _patOallTypeSigs =
                             ({-# LINE 534 "src-ag/Order.ag" #-}
                              _lhsIallTypeSigs
                              {-# LINE 2675 "dist/build/Order" #-}
                              )
                         -- copy rule (down)
                         _patOaltAttrs =
                             ({-# LINE 187 "src-ag/Order.ag" #-}
                              _lhsIaltAttrs
                              {-# LINE 2681 "dist/build/Order" #-}
                              )
                         -- copy rule (down)
                         _patOcon =
                             ({-# LINE 91 "src-ag/Order.ag" #-}
                              _lhsIcon
                              {-# LINE 2687 "dist/build/Order" #-}
                              )
                         -- copy rule (down)
                         _patOinh =
                             ({-# LINE 90 "src-ag/Order.ag" #-}
                              _lhsIinh
                              {-# LINE 2693 "dist/build/Order" #-}
                              )
                         -- copy rule (down)
                         _patOnt =
                             ({-# LINE 90 "src-ag/Order.ag" #-}
                              _lhsInt
                              {-# LINE 2699 "dist/build/Order" #-}
                              )
                         -- copy rule (down)
                         _patOsyn =
                             ({-# LINE 90 "src-ag/Order.ag" #-}
                              _lhsIsyn
                              {-# LINE 2705 "dist/build/Order" #-}
                              )
                         ( _patIcopy,_patIerrors,_patIgathAltAttrs,_patIinstVars,_patIlocVars,_patIpatternAttrs) =
                             pat_ _patOallTypeSigs _patOaltAttrs _patOcon _patOinh _patOnt _patOsyn
                     in  ( _lhsOcopy,_lhsOerrors,_lhsOgathAltAttrs,_lhsOinstVars,_lhsOlocVars,_lhsOpatternAttrs))))
sem_Pattern_Constr :: ConstructorIdent ->
                      T_Patterns ->
                      T_Pattern
sem_Pattern_Constr name_ (T_Patterns pats_) =
    (T_Pattern (\ _lhsIallTypeSigs
                  _lhsIaltAttrs
                  _lhsIcon
                  _lhsIinh
                  _lhsInt
                  _lhsIsyn ->
                    (let _lhsOerrors :: (Seq Error)
                         _lhsOgathAltAttrs :: ([AltAttr])
                         _lhsOinstVars :: ([Identifier])
                         _lhsOlocVars :: ([Identifier])
                         _lhsOpatternAttrs :: ([(Identifier,Identifier,Bool)])
                         _lhsOcopy :: Pattern
                         _patsOallTypeSigs :: (Map Identifier Type)
                         _patsOaltAttrs :: (Map AltAttr Vertex)
                         _patsOcon :: Identifier
                         _patsOinh :: Attributes
                         _patsOnt :: Identifier
                         _patsOsyn :: Attributes
                         _patsIcopy :: Patterns
                         _patsIerrors :: (Seq Error)
                         _patsIgathAltAttrs :: ([AltAttr])
                         _patsIinstVars :: ([Identifier])
                         _patsIlocVars :: ([Identifier])
                         _patsIpatternAttrs :: ([(Identifier,Identifier,Bool)])
                         -- use rule "src-ag/Order.ag"(line 85, column 70)
                         _lhsOerrors =
                             ({-# LINE 85 "src-ag/Order.ag" #-}
                              _patsIerrors
                              {-# LINE 2742 "dist/build/Order" #-}
                              )
                         -- use rule "src-ag/Order.ag"(line 171, column 68)
                         _lhsOgathAltAttrs =
                             ({-# LINE 171 "src-ag/Order.ag" #-}
                              _patsIgathAltAttrs
                              {-# LINE 2748 "dist/build/Order" #-}
                              )
                         -- use rule "src-ag/Order.ag"(line 678, column 86)
                         _lhsOinstVars =
                             ({-# LINE 678 "src-ag/Order.ag" #-}
                              _patsIinstVars
                              {-# LINE 2754 "dist/build/Order" #-}
                              )
                         -- use rule "src-ag/Order.ag"(line 678, column 48)
                         _lhsOlocVars =
                             ({-# LINE 678 "src-ag/Order.ag" #-}
                              _patsIlocVars
                              {-# LINE 2760 "dist/build/Order" #-}
                              )
                         -- use rule "src-ag/Order.ag"(line 248, column 42)
                         _lhsOpatternAttrs =
                             ({-# LINE 248 "src-ag/Order.ag" #-}
                              _patsIpatternAttrs
                              {-# LINE 2766 "dist/build/Order" #-}
                              )
                         -- self rule
                         _copy =
                             ({-# LINE 22 "src-ag/Patterns.ag" #-}
                              Constr name_ _patsIcopy
                              {-# LINE 2772 "dist/build/Order" #-}
                              )
                         -- self rule
                         _lhsOcopy =
                             ({-# LINE 22 "src-ag/Patterns.ag" #-}
                              _copy
                              {-# LINE 2778 "dist/build/Order" #-}
                              )
                         -- copy rule (down)
                         _patsOallTypeSigs =
                             ({-# LINE 534 "src-ag/Order.ag" #-}
                              _lhsIallTypeSigs
                              {-# LINE 2784 "dist/build/Order" #-}
                              )
                         -- copy rule (down)
                         _patsOaltAttrs =
                             ({-# LINE 187 "src-ag/Order.ag" #-}
                              _lhsIaltAttrs
                              {-# LINE 2790 "dist/build/Order" #-}
                              )
                         -- copy rule (down)
                         _patsOcon =
                             ({-# LINE 91 "src-ag/Order.ag" #-}
                              _lhsIcon
                              {-# LINE 2796 "dist/build/Order" #-}
                              )
                         -- copy rule (down)
                         _patsOinh =
                             ({-# LINE 90 "src-ag/Order.ag" #-}
                              _lhsIinh
                              {-# LINE 2802 "dist/build/Order" #-}
                              )
                         -- copy rule (down)
                         _patsOnt =
                             ({-# LINE 90 "src-ag/Order.ag" #-}
                              _lhsInt
                              {-# LINE 2808 "dist/build/Order" #-}
                              )
                         -- copy rule (down)
                         _patsOsyn =
                             ({-# LINE 90 "src-ag/Order.ag" #-}
                              _lhsIsyn
                              {-# LINE 2814 "dist/build/Order" #-}
                              )
                         ( _patsIcopy,_patsIerrors,_patsIgathAltAttrs,_patsIinstVars,_patsIlocVars,_patsIpatternAttrs) =
                             pats_ _patsOallTypeSigs _patsOaltAttrs _patsOcon _patsOinh _patsOnt _patsOsyn
                     in  ( _lhsOcopy,_lhsOerrors,_lhsOgathAltAttrs,_lhsOinstVars,_lhsOlocVars,_lhsOpatternAttrs))))
sem_Pattern_Irrefutable :: T_Pattern ->
                           T_Pattern
sem_Pattern_Irrefutable (T_Pattern pat_) =
    (T_Pattern (\ _lhsIallTypeSigs
                  _lhsIaltAttrs
                  _lhsIcon
                  _lhsIinh
                  _lhsInt
                  _lhsIsyn ->
                    (let _lhsOerrors :: (Seq Error)
                         _lhsOgathAltAttrs :: ([AltAttr])
                         _lhsOinstVars :: ([Identifier])
                         _lhsOlocVars :: ([Identifier])
                         _lhsOpatternAttrs :: ([(Identifier,Identifier,Bool)])
                         _lhsOcopy :: Pattern
                         _patOallTypeSigs :: (Map Identifier Type)
                         _patOaltAttrs :: (Map AltAttr Vertex)
                         _patOcon :: Identifier
                         _patOinh :: Attributes
                         _patOnt :: Identifier
                         _patOsyn :: Attributes
                         _patIcopy :: Pattern
                         _patIerrors :: (Seq Error)
                         _patIgathAltAttrs :: ([AltAttr])
                         _patIinstVars :: ([Identifier])
                         _patIlocVars :: ([Identifier])
                         _patIpatternAttrs :: ([(Identifier,Identifier,Bool)])
                         -- use rule "src-ag/Order.ag"(line 85, column 70)
                         _lhsOerrors =
                             ({-# LINE 85 "src-ag/Order.ag" #-}
                              _patIerrors
                              {-# LINE 2850 "dist/build/Order" #-}
                              )
                         -- use rule "src-ag/Order.ag"(line 171, column 68)
                         _lhsOgathAltAttrs =
                             ({-# LINE 171 "src-ag/Order.ag" #-}
                              _patIgathAltAttrs
                              {-# LINE 2856 "dist/build/Order" #-}
                              )
                         -- use rule "src-ag/Order.ag"(line 678, column 86)
                         _lhsOinstVars =
                             ({-# LINE 678 "src-ag/Order.ag" #-}
                              _patIinstVars
                              {-# LINE 2862 "dist/build/Order" #-}
                              )
                         -- use rule "src-ag/Order.ag"(line 678, column 48)
                         _lhsOlocVars =
                             ({-# LINE 678 "src-ag/Order.ag" #-}
                              _patIlocVars
                              {-# LINE 2868 "dist/build/Order" #-}
                              )
                         -- use rule "src-ag/Order.ag"(line 248, column 42)
                         _lhsOpatternAttrs =
                             ({-# LINE 248 "src-ag/Order.ag" #-}
                              _patIpatternAttrs
                              {-# LINE 2874 "dist/build/Order" #-}
                              )
                         -- self rule
                         _copy =
                             ({-# LINE 22 "src-ag/Patterns.ag" #-}
                              Irrefutable _patIcopy
                              {-# LINE 2880 "dist/build/Order" #-}
                              )
                         -- self rule
                         _lhsOcopy =
                             ({-# LINE 22 "src-ag/Patterns.ag" #-}
                              _copy
                              {-# LINE 2886 "dist/build/Order" #-}
                              )
                         -- copy rule (down)
                         _patOallTypeSigs =
                             ({-# LINE 534 "src-ag/Order.ag" #-}
                              _lhsIallTypeSigs
                              {-# LINE 2892 "dist/build/Order" #-}
                              )
                         -- copy rule (down)
                         _patOaltAttrs =
                             ({-# LINE 187 "src-ag/Order.ag" #-}
                              _lhsIaltAttrs
                              {-# LINE 2898 "dist/build/Order" #-}
                              )
                         -- copy rule (down)
                         _patOcon =
                             ({-# LINE 91 "src-ag/Order.ag" #-}
                              _lhsIcon
                              {-# LINE 2904 "dist/build/Order" #-}
                              )
                         -- copy rule (down)
                         _patOinh =
                             ({-# LINE 90 "src-ag/Order.ag" #-}
                              _lhsIinh
                              {-# LINE 2910 "dist/build/Order" #-}
                              )
                         -- copy rule (down)
                         _patOnt =
                             ({-# LINE 90 "src-ag/Order.ag" #-}
                              _lhsInt
                              {-# LINE 2916 "dist/build/Order" #-}
                              )
                         -- copy rule (down)
                         _patOsyn =
                             ({-# LINE 90 "src-ag/Order.ag" #-}
                              _lhsIsyn
                              {-# LINE 2922 "dist/build/Order" #-}
                              )
                         ( _patIcopy,_patIerrors,_patIgathAltAttrs,_patIinstVars,_patIlocVars,_patIpatternAttrs) =
                             pat_ _patOallTypeSigs _patOaltAttrs _patOcon _patOinh _patOnt _patOsyn
                     in  ( _lhsOcopy,_lhsOerrors,_lhsOgathAltAttrs,_lhsOinstVars,_lhsOlocVars,_lhsOpatternAttrs))))
sem_Pattern_Product :: Pos ->
                       T_Patterns ->
                       T_Pattern
sem_Pattern_Product pos_ (T_Patterns pats_) =
    (T_Pattern (\ _lhsIallTypeSigs
                  _lhsIaltAttrs
                  _lhsIcon
                  _lhsIinh
                  _lhsInt
                  _lhsIsyn ->
                    (let _lhsOerrors :: (Seq Error)
                         _lhsOgathAltAttrs :: ([AltAttr])
                         _lhsOinstVars :: ([Identifier])
                         _lhsOlocVars :: ([Identifier])
                         _lhsOpatternAttrs :: ([(Identifier,Identifier,Bool)])
                         _lhsOcopy :: Pattern
                         _patsOallTypeSigs :: (Map Identifier Type)
                         _patsOaltAttrs :: (Map AltAttr Vertex)
                         _patsOcon :: Identifier
                         _patsOinh :: Attributes
                         _patsOnt :: Identifier
                         _patsOsyn :: Attributes
                         _patsIcopy :: Patterns
                         _patsIerrors :: (Seq Error)
                         _patsIgathAltAttrs :: ([AltAttr])
                         _patsIinstVars :: ([Identifier])
                         _patsIlocVars :: ([Identifier])
                         _patsIpatternAttrs :: ([(Identifier,Identifier,Bool)])
                         -- use rule "src-ag/Order.ag"(line 85, column 70)
                         _lhsOerrors =
                             ({-# LINE 85 "src-ag/Order.ag" #-}
                              _patsIerrors
                              {-# LINE 2959 "dist/build/Order" #-}
                              )
                         -- use rule "src-ag/Order.ag"(line 171, column 68)
                         _lhsOgathAltAttrs =
                             ({-# LINE 171 "src-ag/Order.ag" #-}
                              _patsIgathAltAttrs
                              {-# LINE 2965 "dist/build/Order" #-}
                              )
                         -- use rule "src-ag/Order.ag"(line 678, column 86)
                         _lhsOinstVars =
                             ({-# LINE 678 "src-ag/Order.ag" #-}
                              _patsIinstVars
                              {-# LINE 2971 "dist/build/Order" #-}
                              )
                         -- use rule "src-ag/Order.ag"(line 678, column 48)
                         _lhsOlocVars =
                             ({-# LINE 678 "src-ag/Order.ag" #-}
                              _patsIlocVars
                              {-# LINE 2977 "dist/build/Order" #-}
                              )
                         -- use rule "src-ag/Order.ag"(line 248, column 42)
                         _lhsOpatternAttrs =
                             ({-# LINE 248 "src-ag/Order.ag" #-}
                              _patsIpatternAttrs
                              {-# LINE 2983 "dist/build/Order" #-}
                              )
                         -- self rule
                         _copy =
                             ({-# LINE 22 "src-ag/Patterns.ag" #-}
                              Product pos_ _patsIcopy
                              {-# LINE 2989 "dist/build/Order" #-}
                              )
                         -- self rule
                         _lhsOcopy =
                             ({-# LINE 22 "src-ag/Patterns.ag" #-}
                              _copy
                              {-# LINE 2995 "dist/build/Order" #-}
                              )
                         -- copy rule (down)
                         _patsOallTypeSigs =
                             ({-# LINE 534 "src-ag/Order.ag" #-}
                              _lhsIallTypeSigs
                              {-# LINE 3001 "dist/build/Order" #-}
                              )
                         -- copy rule (down)
                         _patsOaltAttrs =
                             ({-# LINE 187 "src-ag/Order.ag" #-}
                              _lhsIaltAttrs
                              {-# LINE 3007 "dist/build/Order" #-}
                              )
                         -- copy rule (down)
                         _patsOcon =
                             ({-# LINE 91 "src-ag/Order.ag" #-}
                              _lhsIcon
                              {-# LINE 3013 "dist/build/Order" #-}
                              )
                         -- copy rule (down)
                         _patsOinh =
                             ({-# LINE 90 "src-ag/Order.ag" #-}
                              _lhsIinh
                              {-# LINE 3019 "dist/build/Order" #-}
                              )
                         -- copy rule (down)
                         _patsOnt =
                             ({-# LINE 90 "src-ag/Order.ag" #-}
                              _lhsInt
                              {-# LINE 3025 "dist/build/Order" #-}
                              )
                         -- copy rule (down)
                         _patsOsyn =
                             ({-# LINE 90 "src-ag/Order.ag" #-}
                              _lhsIsyn
                              {-# LINE 3031 "dist/build/Order" #-}
                              )
                         ( _patsIcopy,_patsIerrors,_patsIgathAltAttrs,_patsIinstVars,_patsIlocVars,_patsIpatternAttrs) =
                             pats_ _patsOallTypeSigs _patsOaltAttrs _patsOcon _patsOinh _patsOnt _patsOsyn
                     in  ( _lhsOcopy,_lhsOerrors,_lhsOgathAltAttrs,_lhsOinstVars,_lhsOlocVars,_lhsOpatternAttrs))))
sem_Pattern_Underscore :: Pos ->
                          T_Pattern
sem_Pattern_Underscore pos_ =
    (T_Pattern (\ _lhsIallTypeSigs
                  _lhsIaltAttrs
                  _lhsIcon
                  _lhsIinh
                  _lhsInt
                  _lhsIsyn ->
                    (let _lhsOerrors :: (Seq Error)
                         _lhsOgathAltAttrs :: ([AltAttr])
                         _lhsOinstVars :: ([Identifier])
                         _lhsOlocVars :: ([Identifier])
                         _lhsOpatternAttrs :: ([(Identifier,Identifier,Bool)])
                         _lhsOcopy :: Pattern
                         -- use rule "src-ag/Order.ag"(line 85, column 70)
                         _lhsOerrors =
                             ({-# LINE 85 "src-ag/Order.ag" #-}
                              Seq.empty
                              {-# LINE 3055 "dist/build/Order" #-}
                              )
                         -- use rule "src-ag/Order.ag"(line 171, column 68)
                         _lhsOgathAltAttrs =
                             ({-# LINE 171 "src-ag/Order.ag" #-}
                              []
                              {-# LINE 3061 "dist/build/Order" #-}
                              )
                         -- use rule "src-ag/Order.ag"(line 678, column 86)
                         _lhsOinstVars =
                             ({-# LINE 678 "src-ag/Order.ag" #-}
                              []
                              {-# LINE 3067 "dist/build/Order" #-}
                              )
                         -- use rule "src-ag/Order.ag"(line 678, column 48)
                         _lhsOlocVars =
                             ({-# LINE 678 "src-ag/Order.ag" #-}
                              []
                              {-# LINE 3073 "dist/build/Order" #-}
                              )
                         -- use rule "src-ag/Order.ag"(line 248, column 42)
                         _lhsOpatternAttrs =
                             ({-# LINE 248 "src-ag/Order.ag" #-}
                              []
                              {-# LINE 3079 "dist/build/Order" #-}
                              )
                         -- self rule
                         _copy =
                             ({-# LINE 22 "src-ag/Patterns.ag" #-}
                              Underscore pos_
                              {-# LINE 3085 "dist/build/Order" #-}
                              )
                         -- self rule
                         _lhsOcopy =
                             ({-# LINE 22 "src-ag/Patterns.ag" #-}
                              _copy
                              {-# LINE 3091 "dist/build/Order" #-}
                              )
                     in  ( _lhsOcopy,_lhsOerrors,_lhsOgathAltAttrs,_lhsOinstVars,_lhsOlocVars,_lhsOpatternAttrs))))
-- Patterns ----------------------------------------------------
{-
   visit 0:
      inherited attributes:
         allTypeSigs          : Map Identifier Type
         altAttrs             : Map AltAttr Vertex
         con                  : Identifier
         inh                  : Attributes
         nt                   : Identifier
         syn                  : Attributes
      synthesized attributes:
         copy                 : Patterns 
         errors               : Seq Error
         gathAltAttrs         : [AltAttr]
         instVars             : [Identifier]
         locVars              : [Identifier]
         patternAttrs         : [(Identifier,Identifier,Bool)]
   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 ((Map Identifier Type) ->
                                 (Map AltAttr Vertex) ->
                                 Identifier ->
                                 Attributes ->
                                 Identifier ->
                                 Attributes ->
                                 ( Patterns,(Seq Error),([AltAttr]),([Identifier]),([Identifier]),([(Identifier,Identifier,Bool)])))
data Inh_Patterns = Inh_Patterns {allTypeSigs_Inh_Patterns :: !((Map Identifier Type)),altAttrs_Inh_Patterns :: !((Map AltAttr Vertex)),con_Inh_Patterns :: !(Identifier),inh_Inh_Patterns :: !(Attributes),nt_Inh_Patterns :: !(Identifier),syn_Inh_Patterns :: !(Attributes)}
data Syn_Patterns = Syn_Patterns {copy_Syn_Patterns :: !(Patterns),errors_Syn_Patterns :: !((Seq Error)),gathAltAttrs_Syn_Patterns :: !(([AltAttr])),instVars_Syn_Patterns :: !(([Identifier])),locVars_Syn_Patterns :: !(([Identifier])),patternAttrs_Syn_Patterns :: !(([(Identifier,Identifier,Bool)]))}
wrap_Patterns :: T_Patterns ->
                 Inh_Patterns ->
                 Syn_Patterns
wrap_Patterns (T_Patterns sem) (Inh_Patterns _lhsIallTypeSigs _lhsIaltAttrs _lhsIcon _lhsIinh _lhsInt _lhsIsyn) =
    (let ( _lhsOcopy,_lhsOerrors,_lhsOgathAltAttrs,_lhsOinstVars,_lhsOlocVars,_lhsOpatternAttrs) = sem _lhsIallTypeSigs _lhsIaltAttrs _lhsIcon _lhsIinh _lhsInt _lhsIsyn
     in  (Syn_Patterns _lhsOcopy _lhsOerrors _lhsOgathAltAttrs _lhsOinstVars _lhsOlocVars _lhsOpatternAttrs))
sem_Patterns_Cons :: T_Pattern ->
                     T_Patterns ->
                     T_Patterns
sem_Patterns_Cons (T_Pattern hd_) (T_Patterns tl_) =
    (T_Patterns (\ _lhsIallTypeSigs
                   _lhsIaltAttrs
                   _lhsIcon
                   _lhsIinh
                   _lhsInt
                   _lhsIsyn ->
                     (let _lhsOerrors :: (Seq Error)
                          _lhsOgathAltAttrs :: ([AltAttr])
                          _lhsOinstVars :: ([Identifier])
                          _lhsOlocVars :: ([Identifier])
                          _lhsOpatternAttrs :: ([(Identifier,Identifier,Bool)])
                          _lhsOcopy :: Patterns
                          _hdOallTypeSigs :: (Map Identifier Type)
                          _hdOaltAttrs :: (Map AltAttr Vertex)
                          _hdOcon :: Identifier
                          _hdOinh :: Attributes
                          _hdOnt :: Identifier
                          _hdOsyn :: Attributes
                          _tlOallTypeSigs :: (Map Identifier Type)
                          _tlOaltAttrs :: (Map AltAttr Vertex)
                          _tlOcon :: Identifier
                          _tlOinh :: Attributes
                          _tlOnt :: Identifier
                          _tlOsyn :: Attributes
                          _hdIcopy :: Pattern
                          _hdIerrors :: (Seq Error)
                          _hdIgathAltAttrs :: ([AltAttr])
                          _hdIinstVars :: ([Identifier])
                          _hdIlocVars :: ([Identifier])
                          _hdIpatternAttrs :: ([(Identifier,Identifier,Bool)])
                          _tlIcopy :: Patterns
                          _tlIerrors :: (Seq Error)
                          _tlIgathAltAttrs :: ([AltAttr])
                          _tlIinstVars :: ([Identifier])
                          _tlIlocVars :: ([Identifier])
                          _tlIpatternAttrs :: ([(Identifier,Identifier,Bool)])
                          -- use rule "src-ag/Order.ag"(line 85, column 70)
                          _lhsOerrors =
                              ({-# LINE 85 "src-ag/Order.ag" #-}
                               _hdIerrors Seq.>< _tlIerrors
                               {-# LINE 3186 "dist/build/Order" #-}
                               )
                          -- use rule "src-ag/Order.ag"(line 171, column 68)
                          _lhsOgathAltAttrs =
                              ({-# LINE 171 "src-ag/Order.ag" #-}
                               _hdIgathAltAttrs ++ _tlIgathAltAttrs
                               {-# LINE 3192 "dist/build/Order" #-}
                               )
                          -- use rule "src-ag/Order.ag"(line 678, column 86)
                          _lhsOinstVars =
                              ({-# LINE 678 "src-ag/Order.ag" #-}
                               _hdIinstVars ++ _tlIinstVars
                               {-# LINE 3198 "dist/build/Order" #-}
                               )
                          -- use rule "src-ag/Order.ag"(line 678, column 48)
                          _lhsOlocVars =
                              ({-# LINE 678 "src-ag/Order.ag" #-}
                               _hdIlocVars ++ _tlIlocVars
                               {-# LINE 3204 "dist/build/Order" #-}
                               )
                          -- use rule "src-ag/Order.ag"(line 248, column 42)
                          _lhsOpatternAttrs =
                              ({-# LINE 248 "src-ag/Order.ag" #-}
                               _hdIpatternAttrs ++ _tlIpatternAttrs
                               {-# LINE 3210 "dist/build/Order" #-}
                               )
                          -- self rule
                          _copy =
                              ({-# LINE 22 "src-ag/Patterns.ag" #-}
                               (:) _hdIcopy _tlIcopy
                               {-# LINE 3216 "dist/build/Order" #-}
                               )
                          -- self rule
                          _lhsOcopy =
                              ({-# LINE 22 "src-ag/Patterns.ag" #-}
                               _copy
                               {-# LINE 3222 "dist/build/Order" #-}
                               )
                          -- copy rule (down)
                          _hdOallTypeSigs =
                              ({-# LINE 534 "src-ag/Order.ag" #-}
                               _lhsIallTypeSigs
                               {-# LINE 3228 "dist/build/Order" #-}
                               )
                          -- copy rule (down)
                          _hdOaltAttrs =
                              ({-# LINE 187 "src-ag/Order.ag" #-}
                               _lhsIaltAttrs
                               {-# LINE 3234 "dist/build/Order" #-}
                               )
                          -- copy rule (down)
                          _hdOcon =
                              ({-# LINE 91 "src-ag/Order.ag" #-}
                               _lhsIcon
                               {-# LINE 3240 "dist/build/Order" #-}
                               )
                          -- copy rule (down)
                          _hdOinh =
                              ({-# LINE 90 "src-ag/Order.ag" #-}
                               _lhsIinh
                               {-# LINE 3246 "dist/build/Order" #-}
                               )
                          -- copy rule (down)
                          _hdOnt =
                              ({-# LINE 90 "src-ag/Order.ag" #-}
                               _lhsInt
                               {-# LINE 3252 "dist/build/Order" #-}
                               )
                          -- copy rule (down)
                          _hdOsyn =
                              ({-# LINE 90 "src-ag/Order.ag" #-}
                               _lhsIsyn
                               {-# LINE 3258 "dist/build/Order" #-}
                               )
                          -- copy rule (down)
                          _tlOallTypeSigs =
                              ({-# LINE 534 "src-ag/Order.ag" #-}
                               _lhsIallTypeSigs
                               {-# LINE 3264 "dist/build/Order" #-}
                               )
                          -- copy rule (down)
                          _tlOaltAttrs =
                              ({-# LINE 187 "src-ag/Order.ag" #-}
                               _lhsIaltAttrs
                               {-# LINE 3270 "dist/build/Order" #-}
                               )
                          -- copy rule (down)
                          _tlOcon =
                              ({-# LINE 91 "src-ag/Order.ag" #-}
                               _lhsIcon
                               {-# LINE 3276 "dist/build/Order" #-}
                               )
                          -- copy rule (down)
                          _tlOinh =
                              ({-# LINE 90 "src-ag/Order.ag" #-}
                               _lhsIinh
                               {-# LINE 3282 "dist/build/Order" #-}
                               )
                          -- copy rule (down)
                          _tlOnt =
                              ({-# LINE 90 "src-ag/Order.ag" #-}
                               _lhsInt
                               {-# LINE 3288 "dist/build/Order" #-}
                               )
                          -- copy rule (down)
                          _tlOsyn =
                              ({-# LINE 90 "src-ag/Order.ag" #-}
                               _lhsIsyn
                               {-# LINE 3294 "dist/build/Order" #-}
                               )
                          ( _hdIcopy,_hdIerrors,_hdIgathAltAttrs,_hdIinstVars,_hdIlocVars,_hdIpatternAttrs) =
                              hd_ _hdOallTypeSigs _hdOaltAttrs _hdOcon _hdOinh _hdOnt _hdOsyn
                          ( _tlIcopy,_tlIerrors,_tlIgathAltAttrs,_tlIinstVars,_tlIlocVars,_tlIpatternAttrs) =
                              tl_ _tlOallTypeSigs _tlOaltAttrs _tlOcon _tlOinh _tlOnt _tlOsyn
                      in  ( _lhsOcopy,_lhsOerrors,_lhsOgathAltAttrs,_lhsOinstVars,_lhsOlocVars,_lhsOpatternAttrs))))
sem_Patterns_Nil :: T_Patterns
sem_Patterns_Nil =
    (T_Patterns (\ _lhsIallTypeSigs
                   _lhsIaltAttrs
                   _lhsIcon
                   _lhsIinh
                   _lhsInt
                   _lhsIsyn ->
                     (let _lhsOerrors :: (Seq Error)
                          _lhsOgathAltAttrs :: ([AltAttr])
                          _lhsOinstVars :: ([Identifier])
                          _lhsOlocVars :: ([Identifier])
                          _lhsOpatternAttrs :: ([(Identifier,Identifier,Bool)])
                          _lhsOcopy :: Patterns
                          -- use rule "src-ag/Order.ag"(line 85, column 70)
                          _lhsOerrors =
                              ({-# LINE 85 "src-ag/Order.ag" #-}
                               Seq.empty
                               {-# LINE 3319 "dist/build/Order" #-}
                               )
                          -- use rule "src-ag/Order.ag"(line 171, column 68)
                          _lhsOgathAltAttrs =
                              ({-# LINE 171 "src-ag/Order.ag" #-}
                               []
                               {-# LINE 3325 "dist/build/Order" #-}
                               )
                          -- use rule "src-ag/Order.ag"(line 678, column 86)
                          _lhsOinstVars =
                              ({-# LINE 678 "src-ag/Order.ag" #-}
                               []
                               {-# LINE 3331 "dist/build/Order" #-}
                               )
                          -- use rule "src-ag/Order.ag"(line 678, column 48)
                          _lhsOlocVars =
                              ({-# LINE 678 "src-ag/Order.ag" #-}
                               []
                               {-# LINE 3337 "dist/build/Order" #-}
                               )
                          -- use rule "src-ag/Order.ag"(line 248, column 42)
                          _lhsOpatternAttrs =
                              ({-# LINE 248 "src-ag/Order.ag" #-}
                               []
                               {-# LINE 3343 "dist/build/Order" #-}
                               )
                          -- self rule
                          _copy =
                              ({-# LINE 22 "src-ag/Patterns.ag" #-}
                               []
                               {-# LINE 3349 "dist/build/Order" #-}
                               )
                          -- self rule
                          _lhsOcopy =
                              ({-# LINE 22 "src-ag/Patterns.ag" #-}
                               _copy
                               {-# LINE 3355 "dist/build/Order" #-}
                               )
                      in  ( _lhsOcopy,_lhsOerrors,_lhsOgathAltAttrs,_lhsOinstVars,_lhsOlocVars,_lhsOpatternAttrs))))
-- Production --------------------------------------------------
{-
   visit 0:
      inherited attributes:
         allnts               : [Identifier]
         aroundMap            : Map ConstructorIdent (Map Identifier [Expression])
         cVisitsMap           : CVisitsMap
         inh                  : Attributes
         inhMap               : Map Identifier Attributes
         manualAttrDepMap     : AttrOrderMap
         mergeMap             : Map ConstructorIdent (Map Identifier (Identifier,[Identifier]))
         nt                   : Identifier
         o_case               : Bool
         o_cata               : Bool
         o_dovisit            : Bool
         o_newtypes           : Bool
         o_rename             : Bool
         o_sem                : Bool
         o_sig                : Bool
         o_unbox              : Bool
         o_wantvisit          : Bool
         prefix               : String
         syn                  : Attributes
         synMap               : Map Identifier Attributes
      chained attribute:
         vcount               : Int
      synthesized attributes:
         additionalDep        : Seq Edge
         aroundDep            : Seq Edge
         cProduction          : CProduction
         cons                 : [ConstructorIdent]
         directDep            : Seq Edge
         errors               : Seq Error
         instDep              : Seq Edge
         mergeDep             : Seq Edge
         nAutoRules           : Int
         nExplicitRules       : Int
         rules                : Seq (Vertex,CRule)
   alternatives:
      alternative Production:
         child con            : {ConstructorIdent}
         child params         : {[Identifier]}
         child constraints    : {[Type]}
         child children       : Children 
         child rules          : Rules 
         child typeSigs       : TypeSigs 
         child macro          : {MaybeMacro}
         visit 0:
            local gathAltAttrs : _
            local altAttrs    : _
            local inhRules    : _
            local gathRules   : _
            local manualDeps  : _
            local mergeMap    : _
            local mergeDep1   : _
            local mergeDep2   : _
            local aroundMap   : _
            local aroundDep1  : _
            local aroundDep2  : _
            local cVisits     : _
            local allfields   : _
            local attrs       : _
            local inhnames    : _
            local synnames    : _
-}
-- cata
sem_Production :: Production ->
                  T_Production
sem_Production (Production _con _params _constraints _children _rules _typeSigs _macro) =
    (sem_Production_Production _con _params _constraints (sem_Children _children) (sem_Rules _rules) (sem_TypeSigs _typeSigs) _macro)
-- semantic domain
newtype T_Production = T_Production (([Identifier]) ->
                                     (Map ConstructorIdent (Map Identifier [Expression])) ->
                                     CVisitsMap ->
                                     Attributes ->
                                     (Map Identifier Attributes) ->
                                     AttrOrderMap ->
                                     (Map ConstructorIdent (Map Identifier (Identifier,[Identifier]))) ->
                                     Identifier ->
                                     Bool ->
                                     Bool ->
                                     Bool ->
                                     Bool ->
                                     Bool ->
                                     Bool ->
                                     Bool ->
                                     Bool ->
                                     Bool ->
                                     String ->
                                     Attributes ->
                                     (Map Identifier Attributes) ->
                                     Int ->
                                     ( (Seq Edge),(Seq Edge),CProduction,([ConstructorIdent]),(Seq Edge),(Seq Error),(Seq Edge),(Seq Edge),Int,Int,(Seq (Vertex,CRule)),Int))
data Inh_Production = Inh_Production {allnts_Inh_Production :: !(([Identifier])),aroundMap_Inh_Production :: !((Map ConstructorIdent (Map Identifier [Expression]))),cVisitsMap_Inh_Production :: !(CVisitsMap),inh_Inh_Production :: !(Attributes),inhMap_Inh_Production :: !((Map Identifier Attributes)),manualAttrDepMap_Inh_Production :: !(AttrOrderMap),mergeMap_Inh_Production :: !((Map ConstructorIdent (Map Identifier (Identifier,[Identifier])))),nt_Inh_Production :: !(Identifier),o_case_Inh_Production :: !(Bool),o_cata_Inh_Production :: !(Bool),o_dovisit_Inh_Production :: !(Bool),o_newtypes_Inh_Production :: !(Bool),o_rename_Inh_Production :: !(Bool),o_sem_Inh_Production :: !(Bool),o_sig_Inh_Production :: !(Bool),o_unbox_Inh_Production :: !(Bool),o_wantvisit_Inh_Production :: !(Bool),prefix_Inh_Production :: !(String),syn_Inh_Production :: !(Attributes),synMap_Inh_Production :: !((Map Identifier Attributes)),vcount_Inh_Production :: !(Int)}
data Syn_Production = Syn_Production {additionalDep_Syn_Production :: !((Seq Edge)),aroundDep_Syn_Production :: !((Seq Edge)),cProduction_Syn_Production :: !(CProduction),cons_Syn_Production :: !(([ConstructorIdent])),directDep_Syn_Production :: !((Seq Edge)),errors_Syn_Production :: !((Seq Error)),instDep_Syn_Production :: !((Seq Edge)),mergeDep_Syn_Production :: !((Seq Edge)),nAutoRules_Syn_Production :: !(Int),nExplicitRules_Syn_Production :: !(Int),rules_Syn_Production :: !((Seq (Vertex,CRule))),vcount_Syn_Production :: !(Int)}
wrap_Production :: T_Production ->
                   Inh_Production ->
                   Syn_Production
wrap_Production (T_Production sem) (Inh_Production _lhsIallnts _lhsIaroundMap _lhsIcVisitsMap _lhsIinh _lhsIinhMap _lhsImanualAttrDepMap _lhsImergeMap _lhsInt _lhsIo_case _lhsIo_cata _lhsIo_dovisit _lhsIo_newtypes _lhsIo_rename _lhsIo_sem _lhsIo_sig _lhsIo_unbox _lhsIo_wantvisit _lhsIprefix _lhsIsyn _lhsIsynMap _lhsIvcount) =
    (let ( _lhsOadditionalDep,_lhsOaroundDep,_lhsOcProduction,_lhsOcons,_lhsOdirectDep,_lhsOerrors,_lhsOinstDep,_lhsOmergeDep,_lhsOnAutoRules,_lhsOnExplicitRules,_lhsOrules,_lhsOvcount) = sem _lhsIallnts _lhsIaroundMap _lhsIcVisitsMap _lhsIinh _lhsIinhMap _lhsImanualAttrDepMap _lhsImergeMap _lhsInt _lhsIo_case _lhsIo_cata _lhsIo_dovisit _lhsIo_newtypes _lhsIo_rename _lhsIo_sem _lhsIo_sig _lhsIo_unbox _lhsIo_wantvisit _lhsIprefix _lhsIsyn _lhsIsynMap _lhsIvcount
     in  (Syn_Production _lhsOadditionalDep _lhsOaroundDep _lhsOcProduction _lhsOcons _lhsOdirectDep _lhsOerrors _lhsOinstDep _lhsOmergeDep _lhsOnAutoRules _lhsOnExplicitRules _lhsOrules _lhsOvcount))
sem_Production_Production :: ConstructorIdent ->
                             ([Identifier]) ->
                             ([Type]) ->
                             T_Children ->
                             T_Rules ->
                             T_TypeSigs ->
                             MaybeMacro ->
                             T_Production
sem_Production_Production con_ params_ constraints_ (T_Children children_) (T_Rules rules_) (T_TypeSigs typeSigs_) macro_ =
    (T_Production (\ _lhsIallnts
                     _lhsIaroundMap
                     _lhsIcVisitsMap
                     _lhsIinh
                     _lhsIinhMap
                     _lhsImanualAttrDepMap
                     _lhsImergeMap
                     _lhsInt
                     _lhsIo_case
                     _lhsIo_cata
                     _lhsIo_dovisit
                     _lhsIo_newtypes
                     _lhsIo_rename
                     _lhsIo_sem
                     _lhsIo_sig
                     _lhsIo_unbox
                     _lhsIo_wantvisit
                     _lhsIprefix
                     _lhsIsyn
                     _lhsIsynMap
                     _lhsIvcount ->
                       (let _childrenOcon :: Identifier
                            _rulesOcon :: Identifier
                            _rulesOchildNts :: (Map Identifier NontermIdent)
                            _rulesOchildInhs :: (Map Identifier Attributes)
                            _lhsOrules :: (Seq (Vertex,CRule))
                            _lhsOvcount :: Int
                            _lhsOadditionalDep :: (Seq Edge)
                            _rulesOsynsOfChildren :: (Map Identifier Attributes)
                            _rulesOinhsOfChildren :: (Map Identifier Attributes)
                            _lhsOmergeDep :: (Seq Edge)
                            _lhsOaroundDep :: (Seq Edge)
                            _lhsOcons :: ([ConstructorIdent])
                            _typeSigsOtypeSigs :: (Map Identifier Type)
                            _rulesOallTypeSigs :: (Map Identifier Type)
                            _lhsOcProduction :: CProduction
                            _lhsOdirectDep :: (Seq Edge)
                            _lhsOerrors :: (Seq Error)
                            _lhsOinstDep :: (Seq Edge)
                            _lhsOnAutoRules :: Int
                            _lhsOnExplicitRules :: Int
                            _childrenOallfields :: ([(Identifier,Type,ChildKind)])
                            _childrenOallnts :: ([Identifier])
                            _childrenOattrs :: ([(Identifier,Identifier)])
                            _childrenOinh :: Attributes
                            _childrenOinhMap :: (Map Identifier Attributes)
                            _childrenOmergeMap :: (Map Identifier (Identifier,[Identifier]))
                            _childrenOnt :: Identifier
                            _childrenOo_unbox :: Bool
                            _childrenOsyn :: Attributes
                            _childrenOsynMap :: (Map Identifier Attributes)
                            _rulesOallfields :: ([(Identifier,Type,ChildKind)])
                            _rulesOallnts :: ([Identifier])
                            _rulesOaltAttrs :: (Map AltAttr Vertex)
                            _rulesOattrs :: ([(Identifier,Identifier)])
                            _rulesOinh :: Attributes
                            _rulesOmergeMap :: (Map Identifier (Identifier,[Identifier]))
                            _rulesOnt :: Identifier
                            _rulesOo_case :: Bool
                            _rulesOo_cata :: Bool
                            _rulesOo_dovisit :: Bool
                            _rulesOo_newtypes :: Bool
                            _rulesOo_rename :: Bool
                            _rulesOo_sem :: Bool
                            _rulesOo_sig :: Bool
                            _rulesOo_wantvisit :: Bool
                            _rulesOprefix :: String
                            _rulesOsyn :: Attributes
                            _childrenIattributes :: ([(Identifier,Attributes,Attributes)])
                            _childrenIcollectChildrenInhs :: (Map Identifier Attributes )
                            _childrenIcollectChildrenSyns :: (Map Identifier Attributes )
                            _childrenIerrors :: (Seq Error)
                            _childrenIfields :: ([(Identifier,Type,ChildKind)])
                            _childrenIgathAltAttrs :: ([AltAttr])
                            _childrenIgathRules :: (Seq CRule)
                            _childrenIinhs :: (Seq (Identifier,Attributes))
                            _childrenInts :: (Seq (Identifier,NontermIdent))
                            _childrenIsinglevisits :: ([CRule])
                            _childrenIterminals :: ([Identifier])
                            _rulesIdirectDep :: (Seq Edge)
                            _rulesIerrors :: (Seq Error)
                            _rulesIgathAltAttrs :: ([AltAttr])
                            _rulesIgathRules :: (Seq CRule)
                            _rulesIinstDep :: (Seq Edge)
                            _rulesIinstVars :: ([Identifier])
                            _rulesIlocVars :: ([Identifier])
                            _rulesInAutoRules :: Int
                            _rulesInExplicitRules :: Int
                            _typeSigsItypeSigs :: (Map Identifier Type)
                            -- "src-ag/Order.ag"(line 94, column 16)
                            _childrenOcon =
                                ({-# LINE 94 "src-ag/Order.ag" #-}
                                 con_
                                 {-# LINE 3561 "dist/build/Order" #-}
                                 )
                            -- "src-ag/Order.ag"(line 96, column 16)
                            _rulesOcon =
                                ({-# LINE 96 "src-ag/Order.ag" #-}
                                 con_
                                 {-# LINE 3567 "dist/build/Order" #-}
                                 )
                            -- "src-ag/Order.ag"(line 173, column 18)
                            _gathAltAttrs =
                                ({-# LINE 173 "src-ag/Order.ag" #-}
                                 [ AltAttr _LHS inh True | inh <- Map.keys _lhsIinh ]
                                  ++ _childrenIgathAltAttrs
                                  ++ _rulesIgathAltAttrs
                                 {-# LINE 3575 "dist/build/Order" #-}
                                 )
                            -- "src-ag/Order.ag"(line 189, column 17)
                            _altAttrs =
                                ({-# LINE 189 "src-ag/Order.ag" #-}
                                 Map.fromList (zip _gathAltAttrs [_lhsIvcount..])
                                 {-# LINE 3581 "dist/build/Order" #-}
                                 )
                            -- "src-ag/Order.ag"(line 202, column 18)
                            _rulesOchildNts =
                                ({-# LINE 202 "src-ag/Order.ag" #-}
                                 Map.fromList (toList _childrenInts)
                                 {-# LINE 3587 "dist/build/Order" #-}
                                 )
                            -- "src-ag/Order.ag"(line 203, column 19)
                            _rulesOchildInhs =
                                ({-# LINE 203 "src-ag/Order.ag" #-}
                                 Map.fromList (toList _childrenIinhs)
                                 {-# LINE 3593 "dist/build/Order" #-}
                                 )
                            -- "src-ag/Order.ag"(line 209, column 18)
                            _inhRules =
                                ({-# LINE 209 "src-ag/Order.ag" #-}
                                 [ cRuleLhsInh inh _lhsInt con_ tp | (inh,tp) <- Map.assocs _lhsIinh ]
                                 {-# LINE 3599 "dist/build/Order" #-}
                                 )
                            -- "src-ag/Order.ag"(line 210, column 19)
                            _gathRules =
                                ({-# LINE 210 "src-ag/Order.ag" #-}
                                 _inhRules ++ toList (_childrenIgathRules Seq.>< _rulesIgathRules)
                                 {-# LINE 3605 "dist/build/Order" #-}
                                 )
                            -- "src-ag/Order.ag"(line 262, column 18)
                            _lhsOrules =
                                ({-# LINE 262 "src-ag/Order.ag" #-}
                                 Seq.fromList (zip [_lhsIvcount..] _gathRules)
                                 {-# LINE 3611 "dist/build/Order" #-}
                                 )
                            -- "src-ag/Order.ag"(line 263, column 19)
                            _lhsOvcount =
                                ({-# LINE 263 "src-ag/Order.ag" #-}
                                 _lhsIvcount + length _gathRules
                                 {-# LINE 3617 "dist/build/Order" #-}
                                 )
                            -- "src-ag/Order.ag"(line 290, column 7)
                            _manualDeps =
                                ({-# LINE 290 "src-ag/Order.ag" #-}
                                 Set.toList $ Map.findWithDefault Set.empty con_ $ Map.findWithDefault Map.empty _lhsInt _lhsImanualAttrDepMap
                                 {-# LINE 3623 "dist/build/Order" #-}
                                 )
                            -- "src-ag/Order.ag"(line 293, column 7)
                            _lhsOadditionalDep =
                                ({-# LINE 293 "src-ag/Order.ag" #-}
                                 Seq.fromList [ (vertex True occA, vertex False occB)
                                              | Dependency occA occB <- _manualDeps
                                              , let vertex inout (OccAttr child nm)
                                                      | child == _LOC = findWithErr2 (AltAttr _LOC nm True) _altAttrs
                                                      | otherwise     = findWithErr2 (AltAttr child nm inout) _altAttrs
                                                    vertex _ (OccRule nm)
                                                      = findWithErr2 (AltAttr _LOC (Ident ("_rule_" ++ show nm) (getPos nm)) True) _altAttrs
                                              ]
                                 {-# LINE 3636 "dist/build/Order" #-}
                                 )
                            -- "src-ag/Order.ag"(line 340, column 17)
                            _rulesOsynsOfChildren =
                                ({-# LINE 340 "src-ag/Order.ag" #-}
                                 _childrenIcollectChildrenSyns
                                 {-# LINE 3642 "dist/build/Order" #-}
                                 )
                            -- "src-ag/Order.ag"(line 341, column 17)
                            _rulesOinhsOfChildren =
                                ({-# LINE 341 "src-ag/Order.ag" #-}
                                 _childrenIcollectChildrenInhs
                                 {-# LINE 3648 "dist/build/Order" #-}
                                 )
                            -- "src-ag/Order.ag"(line 359, column 32)
                            _mergeMap =
                                ({-# LINE 359 "src-ag/Order.ag" #-}
                                 Map.findWithDefault Map.empty con_ _lhsImergeMap
                                 {-# LINE 3654 "dist/build/Order" #-}
                                 )
                            -- "src-ag/Order.ag"(line 370, column 7)
                            _lhsOmergeDep =
                                ({-# LINE 370 "src-ag/Order.ag" #-}
                                 _mergeDep1     Seq.>< _mergeDep2
                                 {-# LINE 3660 "dist/build/Order" #-}
                                 )
                            -- "src-ag/Order.ag"(line 371, column 7)
                            _mergeDep1 =
                                ({-# LINE 371 "src-ag/Order.ag" #-}
                                 Seq.fromList $
                                    [ (childVert, synVert)
                                    | childNm <- Map.keys _mergeMap
                                    , synNm <- Map.keys (findWithErr2 childNm _childrenIcollectChildrenSyns)
                                    , let childNm' = Ident (show childNm ++ "_merge") (getPos childNm)
                                          childAttr = AltAttr _LOC childNm' True
                                          synAttr  = AltAttr childNm synNm True
                                          childVert = findWithErr2 childAttr _altAttrs
                                          synVert  = findWithErr2 synAttr _altAttrs
                                    ]
                                 {-# LINE 3675 "dist/build/Order" #-}
                                 )
                            -- "src-ag/Order.ag"(line 382, column 7)
                            _mergeDep2 =
                                ({-# LINE 382 "src-ag/Order.ag" #-}
                                 Seq.fromList $
                                    [ (mergedVert, sourceVert)
                                    | (childNm, (_,cs)) <- Map.assocs _mergeMap
                                    , c <- cs
                                    , synNm <- Map.keys (findWithErr2 childNm _childrenIcollectChildrenSyns)
                                    , let sourceAttr = AltAttr childNm synNm True
                                          mergedAttr = AltAttr c synNm True
                                          sourceVert = findWithErr2 sourceAttr _altAttrs
                                          mergedVert = findWithErr2 mergedAttr _altAttrs
                                    ]
                                 {-# LINE 3690 "dist/build/Order" #-}
                                 )
                            -- "src-ag/Order.ag"(line 412, column 32)
                            _aroundMap =
                                ({-# LINE 412 "src-ag/Order.ag" #-}
                                 Map.findWithDefault Map.empty con_ _lhsIaroundMap
                                 {-# LINE 3696 "dist/build/Order" #-}
                                 )
                            -- "src-ag/Order.ag"(line 419, column 6)
                            _aroundDep1 =
                                ({-# LINE 419 "src-ag/Order.ag" #-}
                                 Seq.fromList $
                                   [ (childVert, synVert)
                                   | childNm <- Map.keys _aroundMap
                                   , synNm <- Map.keys (findWithErr2 childNm _childrenIcollectChildrenSyns)
                                   , let childNm' = Ident (show childNm ++ "_around") (getPos childNm)
                                         childAttr = AltAttr _LOC childNm' True
                                         synAttr  = AltAttr childNm synNm True
                                         childVert = findWithErr2 childAttr _altAttrs
                                         synVert  = findWithErr2 synAttr _altAttrs
                                   ]
                                 {-# LINE 3711 "dist/build/Order" #-}
                                 )
                            -- "src-ag/Order.ag"(line 430, column 6)
                            _aroundDep2 =
                                ({-# LINE 430 "src-ag/Order.ag" #-}
                                 Seq.fromList $
                                   [ (childVert, inhVert)
                                   | childNm <- Map.keys _aroundMap
                                   , inhNm <- Map.keys (findWithErr2 childNm _childrenIcollectChildrenInhs)
                                   , let childNm'  = Ident (show childNm ++ "_around") (getPos childNm)
                                         childAttr = AltAttr _LOC childNm' True
                                         inhAttr   = AltAttr childNm inhNm False
                                         childVert = findWithErr2 childAttr _altAttrs
                                         inhVert   = findWithErr2 inhAttr _altAttrs
                                   ]
                                 {-# LINE 3726 "dist/build/Order" #-}
                                 )
                            -- "src-ag/Order.ag"(line 441, column 6)
                            _lhsOaroundDep =
                                ({-# LINE 441 "src-ag/Order.ag" #-}
                                 _aroundDep1     Seq.>< _aroundDep2
                                 {-# LINE 3732 "dist/build/Order" #-}
                                 )
                            -- "src-ag/Order.ag"(line 523, column 18)
                            _lhsOcons =
                                ({-# LINE 523 "src-ag/Order.ag" #-}
                                 [con_]
                                 {-# LINE 3738 "dist/build/Order" #-}
                                 )
                            -- "src-ag/Order.ag"(line 530, column 16)
                            _typeSigsOtypeSigs =
                                ({-# LINE 530 "src-ag/Order.ag" #-}
                                 Map.empty
                                 {-# LINE 3744 "dist/build/Order" #-}
                                 )
                            -- "src-ag/Order.ag"(line 536, column 17)
                            _rulesOallTypeSigs =
                                ({-# LINE 536 "src-ag/Order.ag" #-}
                                 _typeSigsItypeSigs
                                 {-# LINE 3750 "dist/build/Order" #-}
                                 )
                            -- "src-ag/Order.ag"(line 604, column 17)
                            _cVisits =
                                ({-# LINE 604 "src-ag/Order.ag" #-}
                                 if  _lhsIo_dovisit
                                      then let prodsVisitsMap = findWithErr1 "Production.cVisits.nt" _lhsInt _lhsIcVisitsMap
                                               visits = findWithErr1 "Production.cVisits.con" con_ prodsVisitsMap
                                            in visits
                                      else  let  vss = nubBy eqCRuleDefines _gathRules ++ _childrenIsinglevisits
                                            in  [CVisit _lhsIinh _lhsIsyn vss [] False]
                                 {-# LINE 3761 "dist/build/Order" #-}
                                 )
                            -- "src-ag/Order.ag"(line 630, column 18)
                            _lhsOcProduction =
                                ({-# LINE 630 "src-ag/Order.ag" #-}
                                 CProduction con_ _cVisits _childrenIfields _childrenIterminals
                                 {-# LINE 3767 "dist/build/Order" #-}
                                 )
                            -- "src-ag/Order.ag"(line 658, column 16)
                            _allfields =
                                ({-# LINE 658 "src-ag/Order.ag" #-}
                                 _childrenIfields
                                 {-# LINE 3773 "dist/build/Order" #-}
                                 )
                            -- "src-ag/Order.ag"(line 658, column 16)
                            _attrs =
                                ({-# LINE 659 "src-ag/Order.ag" #-}
                                 map ((,) _LOC)  _rulesIlocVars ++
                                 map ((,) _INST) _rulesIinstVars ++
                                 map ((,) _LHS)  _inhnames ++
                                 concat [map ((,) nm) (Map.keys as) | (nm,_,as) <- _childrenIattributes]
                                 {-# LINE 3782 "dist/build/Order" #-}
                                 )
                            -- "src-ag/Order.ag"(line 658, column 16)
                            _inhnames =
                                ({-# LINE 663 "src-ag/Order.ag" #-}
                                 Map.keys _lhsIinh
                                 {-# LINE 3788 "dist/build/Order" #-}
                                 )
                            -- "src-ag/Order.ag"(line 658, column 16)
                            _synnames =
                                ({-# LINE 664 "src-ag/Order.ag" #-}
                                 Map.keys _lhsIsyn
                                 {-# LINE 3794 "dist/build/Order" #-}
                                 )
                            -- use rule "src-ag/Order.ag"(line 268, column 33)
                            _lhsOdirectDep =
                                ({-# LINE 268 "src-ag/Order.ag" #-}
                                 _rulesIdirectDep
                                 {-# LINE 3800 "dist/build/Order" #-}
                                 )
                            -- use rule "src-ag/Order.ag"(line 85, column 70)
                            _lhsOerrors =
                                ({-# LINE 85 "src-ag/Order.ag" #-}
                                 _childrenIerrors Seq.>< _rulesIerrors
                                 {-# LINE 3806 "dist/build/Order" #-}
                                 )
                            -- use rule "src-ag/Order.ag"(line 311, column 31)
                            _lhsOinstDep =
                                ({-# LINE 311 "src-ag/Order.ag" #-}
                                 _rulesIinstDep
                                 {-# LINE 3812 "dist/build/Order" #-}
                                 )
                            -- use rule "src-ag/Order.ag"(line 62, column 105)
                            _lhsOnAutoRules =
                                ({-# LINE 62 "src-ag/Order.ag" #-}
                                 _rulesInAutoRules
                                 {-# LINE 3818 "dist/build/Order" #-}
                                 )
                            -- use rule "src-ag/Order.ag"(line 62, column 105)
                            _lhsOnExplicitRules =
                                ({-# LINE 62 "src-ag/Order.ag" #-}
                                 _rulesInExplicitRules
                                 {-# LINE 3824 "dist/build/Order" #-}
                                 )
                            -- copy rule (from local)
                            _childrenOallfields =
                                ({-# LINE 655 "src-ag/Order.ag" #-}
                                 _allfields
                                 {-# LINE 3830 "dist/build/Order" #-}
                                 )
                            -- copy rule (down)
                            _childrenOallnts =
                                ({-# LINE 648 "src-ag/Order.ag" #-}
                                 _lhsIallnts
                                 {-# LINE 3836 "dist/build/Order" #-}
                                 )
                            -- copy rule (from local)
                            _childrenOattrs =
                                ({-# LINE 655 "src-ag/Order.ag" #-}
                                 _attrs
                                 {-# LINE 3842 "dist/build/Order" #-}
                                 )
                            -- copy rule (down)
                            _childrenOinh =
                                ({-# LINE 90 "src-ag/Order.ag" #-}
                                 _lhsIinh
                                 {-# LINE 3848 "dist/build/Order" #-}
                                 )
                            -- copy rule (down)
                            _childrenOinhMap =
                                ({-# LINE 12 "src-ag/DistChildAttr.ag" #-}
                                 _lhsIinhMap
                                 {-# LINE 3854 "dist/build/Order" #-}
                                 )
                            -- copy rule (from local)
                            _childrenOmergeMap =
                                ({-# LINE 361 "src-ag/Order.ag" #-}
                                 _mergeMap
                                 {-# LINE 3860 "dist/build/Order" #-}
                                 )
                            -- copy rule (down)
                            _childrenOnt =
                                ({-# LINE 90 "src-ag/Order.ag" #-}
                                 _lhsInt
                                 {-# LINE 3866 "dist/build/Order" #-}
                                 )
                            -- copy rule (down)
                            _childrenOo_unbox =
                                ({-# LINE 120 "src-ag/Order.ag" #-}
                                 _lhsIo_unbox
                                 {-# LINE 3872 "dist/build/Order" #-}
                                 )
                            -- copy rule (down)
                            _childrenOsyn =
                                ({-# LINE 90 "src-ag/Order.ag" #-}
                                 _lhsIsyn
                                 {-# LINE 3878 "dist/build/Order" #-}
                                 )
                            -- copy rule (down)
                            _childrenOsynMap =
                                ({-# LINE 12 "src-ag/DistChildAttr.ag" #-}
                                 _lhsIsynMap
                                 {-# LINE 3884 "dist/build/Order" #-}
                                 )
                            -- copy rule (from local)
                            _rulesOallfields =
                                ({-# LINE 655 "src-ag/Order.ag" #-}
                                 _allfields
                                 {-# LINE 3890 "dist/build/Order" #-}
                                 )
                            -- copy rule (down)
                            _rulesOallnts =
                                ({-# LINE 648 "src-ag/Order.ag" #-}
                                 _lhsIallnts
                                 {-# LINE 3896 "dist/build/Order" #-}
                                 )
                            -- copy rule (from local)
                            _rulesOaltAttrs =
                                ({-# LINE 187 "src-ag/Order.ag" #-}
                                 _altAttrs
                                 {-# LINE 3902 "dist/build/Order" #-}
                                 )
                            -- copy rule (from local)
                            _rulesOattrs =
                                ({-# LINE 655 "src-ag/Order.ag" #-}
                                 _attrs
                                 {-# LINE 3908 "dist/build/Order" #-}
                                 )
                            -- copy rule (down)
                            _rulesOinh =
                                ({-# LINE 90 "src-ag/Order.ag" #-}
                                 _lhsIinh
                                 {-# LINE 3914 "dist/build/Order" #-}
                                 )
                            -- copy rule (from local)
                            _rulesOmergeMap =
                                ({-# LINE 361 "src-ag/Order.ag" #-}
                                 _mergeMap
                                 {-# LINE 3920 "dist/build/Order" #-}
                                 )
                            -- copy rule (down)
                            _rulesOnt =
                                ({-# LINE 90 "src-ag/Order.ag" #-}
                                 _lhsInt
                                 {-# LINE 3926 "dist/build/Order" #-}
                                 )
                            -- copy rule (down)
                            _rulesOo_case =
                                ({-# LINE 118 "src-ag/Order.ag" #-}
                                 _lhsIo_case
                                 {-# LINE 3932 "dist/build/Order" #-}
                                 )
                            -- copy rule (down)
                            _rulesOo_cata =
                                ({-# LINE 112 "src-ag/Order.ag" #-}
                                 _lhsIo_cata
                                 {-# LINE 3938 "dist/build/Order" #-}
                                 )
                            -- copy rule (down)
                            _rulesOo_dovisit =
                                ({-# LINE 117 "src-ag/Order.ag" #-}
                                 _lhsIo_dovisit
                                 {-# LINE 3944 "dist/build/Order" #-}
                                 )
                            -- copy rule (down)
                            _rulesOo_newtypes =
                                ({-# LINE 111 "src-ag/Order.ag" #-}
                                 _lhsIo_newtypes
                                 {-# LINE 3950 "dist/build/Order" #-}
                                 )
                            -- copy rule (down)
                            _rulesOo_rename =
                                ({-# LINE 115 "src-ag/Order.ag" #-}
                                 _lhsIo_rename
                                 {-# LINE 3956 "dist/build/Order" #-}
                                 )
                            -- copy rule (down)
                            _rulesOo_sem =
                                ({-# LINE 114 "src-ag/Order.ag" #-}
                                 _lhsIo_sem
                                 {-# LINE 3962 "dist/build/Order" #-}
                                 )
                            -- copy rule (down)
                            _rulesOo_sig =
                                ({-# LINE 113 "src-ag/Order.ag" #-}
                                 _lhsIo_sig
                                 {-# LINE 3968 "dist/build/Order" #-}
                                 )
                            -- copy rule (down)
                            _rulesOo_wantvisit =
                                ({-# LINE 116 "src-ag/Order.ag" #-}
                                 _lhsIo_wantvisit
                                 {-# LINE 3974 "dist/build/Order" #-}
                                 )
                            -- copy rule (down)
                            _rulesOprefix =
                                ({-# LINE 119 "src-ag/Order.ag" #-}
                                 _lhsIprefix
                                 {-# LINE 3980 "dist/build/Order" #-}
                                 )
                            -- copy rule (down)
                            _rulesOsyn =
                                ({-# LINE 90 "src-ag/Order.ag" #-}
                                 _lhsIsyn
                                 {-# LINE 3986 "dist/build/Order" #-}
                                 )
                            ( _childrenIattributes,_childrenIcollectChildrenInhs,_childrenIcollectChildrenSyns,_childrenIerrors,_childrenIfields,_childrenIgathAltAttrs,_childrenIgathRules,_childrenIinhs,_childrenInts,_childrenIsinglevisits,_childrenIterminals) =
                                children_ _childrenOallfields _childrenOallnts _childrenOattrs _childrenOcon _childrenOinh _childrenOinhMap _childrenOmergeMap _childrenOnt _childrenOo_unbox _childrenOsyn _childrenOsynMap
                            ( _rulesIdirectDep,_rulesIerrors,_rulesIgathAltAttrs,_rulesIgathRules,_rulesIinstDep,_rulesIinstVars,_rulesIlocVars,_rulesInAutoRules,_rulesInExplicitRules) =
                                rules_ _rulesOallTypeSigs _rulesOallfields _rulesOallnts _rulesOaltAttrs _rulesOattrs _rulesOchildInhs _rulesOchildNts _rulesOcon _rulesOinh _rulesOinhsOfChildren _rulesOmergeMap _rulesOnt _rulesOo_case _rulesOo_cata _rulesOo_dovisit _rulesOo_newtypes _rulesOo_rename _rulesOo_sem _rulesOo_sig _rulesOo_wantvisit _rulesOprefix _rulesOsyn _rulesOsynsOfChildren
                            ( _typeSigsItypeSigs) =
                                typeSigs_ _typeSigsOtypeSigs
                        in  ( _lhsOadditionalDep,_lhsOaroundDep,_lhsOcProduction,_lhsOcons,_lhsOdirectDep,_lhsOerrors,_lhsOinstDep,_lhsOmergeDep,_lhsOnAutoRules,_lhsOnExplicitRules,_lhsOrules,_lhsOvcount))))
-- Productions -------------------------------------------------
{-
   visit 0:
      inherited attributes:
         allnts               : [Identifier]
         aroundMap            : Map ConstructorIdent (Map Identifier [Expression])
         cVisitsMap           : CVisitsMap
         inh                  : Attributes
         inhMap               : Map Identifier Attributes
         manualAttrDepMap     : AttrOrderMap
         mergeMap             : Map ConstructorIdent (Map Identifier (Identifier,[Identifier]))
         nt                   : Identifier
         o_case               : Bool
         o_cata               : Bool
         o_dovisit            : Bool
         o_newtypes           : Bool
         o_rename             : Bool
         o_sem                : Bool
         o_sig                : Bool
         o_unbox              : Bool
         o_wantvisit          : Bool
         prefix               : String
         syn                  : Attributes
         synMap               : Map Identifier Attributes
      chained attribute:
         vcount               : Int
      synthesized attributes:
         additionalDep        : Seq Edge
         aroundDep            : Seq Edge
         cProductions         : CProductions
         cons                 : [ConstructorIdent]
         directDep            : Seq Edge
         errors               : Seq Error
         instDep              : Seq Edge
         mergeDep             : Seq Edge
         nAutoRules           : Int
         nExplicitRules       : Int
         rules                : Seq (Vertex,CRule)
   alternatives:
      alternative Cons:
         child hd             : Production 
         child tl             : Productions 
      alternative Nil:
-}
-- cata
sem_Productions :: Productions ->
                   T_Productions
sem_Productions list =
    (Prelude.foldr sem_Productions_Cons sem_Productions_Nil (Prelude.map sem_Production list))
-- semantic domain
newtype T_Productions = T_Productions (([Identifier]) ->
                                       (Map ConstructorIdent (Map Identifier [Expression])) ->
                                       CVisitsMap ->
                                       Attributes ->
                                       (Map Identifier Attributes) ->
                                       AttrOrderMap ->
                                       (Map ConstructorIdent (Map Identifier (Identifier,[Identifier]))) ->
                                       Identifier ->
                                       Bool ->
                                       Bool ->
                                       Bool ->
                                       Bool ->
                                       Bool ->
                                       Bool ->
                                       Bool ->
                                       Bool ->
                                       Bool ->
                                       String ->
                                       Attributes ->
                                       (Map Identifier Attributes) ->
                                       Int ->
                                       ( (Seq Edge),(Seq Edge),CProductions,([ConstructorIdent]),(Seq Edge),(Seq Error),(Seq Edge),(Seq Edge),Int,Int,(Seq (Vertex,CRule)),Int))
data Inh_Productions = Inh_Productions {allnts_Inh_Productions :: !(([Identifier])),aroundMap_Inh_Productions :: !((Map ConstructorIdent (Map Identifier [Expression]))),cVisitsMap_Inh_Productions :: !(CVisitsMap),inh_Inh_Productions :: !(Attributes),inhMap_Inh_Productions :: !((Map Identifier Attributes)),manualAttrDepMap_Inh_Productions :: !(AttrOrderMap),mergeMap_Inh_Productions :: !((Map ConstructorIdent (Map Identifier (Identifier,[Identifier])))),nt_Inh_Productions :: !(Identifier),o_case_Inh_Productions :: !(Bool),o_cata_Inh_Productions :: !(Bool),o_dovisit_Inh_Productions :: !(Bool),o_newtypes_Inh_Productions :: !(Bool),o_rename_Inh_Productions :: !(Bool),o_sem_Inh_Productions :: !(Bool),o_sig_Inh_Productions :: !(Bool),o_unbox_Inh_Productions :: !(Bool),o_wantvisit_Inh_Productions :: !(Bool),prefix_Inh_Productions :: !(String),syn_Inh_Productions :: !(Attributes),synMap_Inh_Productions :: !((Map Identifier Attributes)),vcount_Inh_Productions :: !(Int)}
data Syn_Productions = Syn_Productions {additionalDep_Syn_Productions :: !((Seq Edge)),aroundDep_Syn_Productions :: !((Seq Edge)),cProductions_Syn_Productions :: !(CProductions),cons_Syn_Productions :: !(([ConstructorIdent])),directDep_Syn_Productions :: !((Seq Edge)),errors_Syn_Productions :: !((Seq Error)),instDep_Syn_Productions :: !((Seq Edge)),mergeDep_Syn_Productions :: !((Seq Edge)),nAutoRules_Syn_Productions :: !(Int),nExplicitRules_Syn_Productions :: !(Int),rules_Syn_Productions :: !((Seq (Vertex,CRule))),vcount_Syn_Productions :: !(Int)}
wrap_Productions :: T_Productions ->
                    Inh_Productions ->
                    Syn_Productions
wrap_Productions (T_Productions sem) (Inh_Productions _lhsIallnts _lhsIaroundMap _lhsIcVisitsMap _lhsIinh _lhsIinhMap _lhsImanualAttrDepMap _lhsImergeMap _lhsInt _lhsIo_case _lhsIo_cata _lhsIo_dovisit _lhsIo_newtypes _lhsIo_rename _lhsIo_sem _lhsIo_sig _lhsIo_unbox _lhsIo_wantvisit _lhsIprefix _lhsIsyn _lhsIsynMap _lhsIvcount) =
    (let ( _lhsOadditionalDep,_lhsOaroundDep,_lhsOcProductions,_lhsOcons,_lhsOdirectDep,_lhsOerrors,_lhsOinstDep,_lhsOmergeDep,_lhsOnAutoRules,_lhsOnExplicitRules,_lhsOrules,_lhsOvcount) = sem _lhsIallnts _lhsIaroundMap _lhsIcVisitsMap _lhsIinh _lhsIinhMap _lhsImanualAttrDepMap _lhsImergeMap _lhsInt _lhsIo_case _lhsIo_cata _lhsIo_dovisit _lhsIo_newtypes _lhsIo_rename _lhsIo_sem _lhsIo_sig _lhsIo_unbox _lhsIo_wantvisit _lhsIprefix _lhsIsyn _lhsIsynMap _lhsIvcount
     in  (Syn_Productions _lhsOadditionalDep _lhsOaroundDep _lhsOcProductions _lhsOcons _lhsOdirectDep _lhsOerrors _lhsOinstDep _lhsOmergeDep _lhsOnAutoRules _lhsOnExplicitRules _lhsOrules _lhsOvcount))
sem_Productions_Cons :: T_Production ->
                        T_Productions ->
                        T_Productions
sem_Productions_Cons (T_Production hd_) (T_Productions tl_) =
    (T_Productions (\ _lhsIallnts
                      _lhsIaroundMap
                      _lhsIcVisitsMap
                      _lhsIinh
                      _lhsIinhMap
                      _lhsImanualAttrDepMap
                      _lhsImergeMap
                      _lhsInt
                      _lhsIo_case
                      _lhsIo_cata
                      _lhsIo_dovisit
                      _lhsIo_newtypes
                      _lhsIo_rename
                      _lhsIo_sem
                      _lhsIo_sig
                      _lhsIo_unbox
                      _lhsIo_wantvisit
                      _lhsIprefix
                      _lhsIsyn
                      _lhsIsynMap
                      _lhsIvcount ->
                        (let _lhsOcProductions :: CProductions
                             _lhsOadditionalDep :: (Seq Edge)
                             _lhsOaroundDep :: (Seq Edge)
                             _lhsOcons :: ([ConstructorIdent])
                             _lhsOdirectDep :: (Seq Edge)
                             _lhsOerrors :: (Seq Error)
                             _lhsOinstDep :: (Seq Edge)
                             _lhsOmergeDep :: (Seq Edge)
                             _lhsOnAutoRules :: Int
                             _lhsOnExplicitRules :: Int
                             _lhsOrules :: (Seq (Vertex,CRule))
                             _lhsOvcount :: Int
                             _hdOallnts :: ([Identifier])
                             _hdOaroundMap :: (Map ConstructorIdent (Map Identifier [Expression]))
                             _hdOcVisitsMap :: CVisitsMap
                             _hdOinh :: Attributes
                             _hdOinhMap :: (Map Identifier Attributes)
                             _hdOmanualAttrDepMap :: AttrOrderMap
                             _hdOmergeMap :: (Map ConstructorIdent (Map Identifier (Identifier,[Identifier])))
                             _hdOnt :: Identifier
                             _hdOo_case :: Bool
                             _hdOo_cata :: Bool
                             _hdOo_dovisit :: Bool
                             _hdOo_newtypes :: Bool
                             _hdOo_rename :: Bool
                             _hdOo_sem :: Bool
                             _hdOo_sig :: Bool
                             _hdOo_unbox :: Bool
                             _hdOo_wantvisit :: Bool
                             _hdOprefix :: String
                             _hdOsyn :: Attributes
                             _hdOsynMap :: (Map Identifier Attributes)
                             _hdOvcount :: Int
                             _tlOallnts :: ([Identifier])
                             _tlOaroundMap :: (Map ConstructorIdent (Map Identifier [Expression]))
                             _tlOcVisitsMap :: CVisitsMap
                             _tlOinh :: Attributes
                             _tlOinhMap :: (Map Identifier Attributes)
                             _tlOmanualAttrDepMap :: AttrOrderMap
                             _tlOmergeMap :: (Map ConstructorIdent (Map Identifier (Identifier,[Identifier])))
                             _tlOnt :: Identifier
                             _tlOo_case :: Bool
                             _tlOo_cata :: Bool
                             _tlOo_dovisit :: Bool
                             _tlOo_newtypes :: Bool
                             _tlOo_rename :: Bool
                             _tlOo_sem :: Bool
                             _tlOo_sig :: Bool
                             _tlOo_unbox :: Bool
                             _tlOo_wantvisit :: Bool
                             _tlOprefix :: String
                             _tlOsyn :: Attributes
                             _tlOsynMap :: (Map Identifier Attributes)
                             _tlOvcount :: Int
                             _hdIadditionalDep :: (Seq Edge)
                             _hdIaroundDep :: (Seq Edge)
                             _hdIcProduction :: CProduction
                             _hdIcons :: ([ConstructorIdent])
                             _hdIdirectDep :: (Seq Edge)
                             _hdIerrors :: (Seq Error)
                             _hdIinstDep :: (Seq Edge)
                             _hdImergeDep :: (Seq Edge)
                             _hdInAutoRules :: Int
                             _hdInExplicitRules :: Int
                             _hdIrules :: (Seq (Vertex,CRule))
                             _hdIvcount :: Int
                             _tlIadditionalDep :: (Seq Edge)
                             _tlIaroundDep :: (Seq Edge)
                             _tlIcProductions :: CProductions
                             _tlIcons :: ([ConstructorIdent])
                             _tlIdirectDep :: (Seq Edge)
                             _tlIerrors :: (Seq Error)
                             _tlIinstDep :: (Seq Edge)
                             _tlImergeDep :: (Seq Edge)
                             _tlInAutoRules :: Int
                             _tlInExplicitRules :: Int
                             _tlIrules :: (Seq (Vertex,CRule))
                             _tlIvcount :: Int
                             -- "src-ag/Order.ag"(line 627, column 12)
                             _lhsOcProductions =
                                 ({-# LINE 627 "src-ag/Order.ag" #-}
                                  _hdIcProduction : _tlIcProductions
                                  {-# LINE 4182 "dist/build/Order" #-}
                                  )
                             -- use rule "src-ag/Order.ag"(line 282, column 60)
                             _lhsOadditionalDep =
                                 ({-# LINE 282 "src-ag/Order.ag" #-}
                                  _hdIadditionalDep Seq.>< _tlIadditionalDep
                                  {-# LINE 4188 "dist/build/Order" #-}
                                  )
                             -- use rule "src-ag/Order.ag"(line 403, column 24)
                             _lhsOaroundDep =
                                 ({-# LINE 403 "src-ag/Order.ag" #-}
                                  _hdIaroundDep Seq.>< _tlIaroundDep
                                  {-# LINE 4194 "dist/build/Order" #-}
                                  )
                             -- use rule "src-ag/Order.ag"(line 521, column 40)
                             _lhsOcons =
                                 ({-# LINE 521 "src-ag/Order.ag" #-}
                                  _hdIcons ++ _tlIcons
                                  {-# LINE 4200 "dist/build/Order" #-}
                                  )
                             -- use rule "src-ag/Order.ag"(line 268, column 33)
                             _lhsOdirectDep =
                                 ({-# LINE 268 "src-ag/Order.ag" #-}
                                  _hdIdirectDep Seq.>< _tlIdirectDep
                                  {-# LINE 4206 "dist/build/Order" #-}
                                  )
                             -- use rule "src-ag/Order.ag"(line 85, column 70)
                             _lhsOerrors =
                                 ({-# LINE 85 "src-ag/Order.ag" #-}
                                  _hdIerrors Seq.>< _tlIerrors
                                  {-# LINE 4212 "dist/build/Order" #-}
                                  )
                             -- use rule "src-ag/Order.ag"(line 311, column 31)
                             _lhsOinstDep =
                                 ({-# LINE 311 "src-ag/Order.ag" #-}
                                  _hdIinstDep Seq.>< _tlIinstDep
                                  {-# LINE 4218 "dist/build/Order" #-}
                                  )
                             -- use rule "src-ag/Order.ag"(line 366, column 18)
                             _lhsOmergeDep =
                                 ({-# LINE 366 "src-ag/Order.ag" #-}
                                  _hdImergeDep Seq.>< _tlImergeDep
                                  {-# LINE 4224 "dist/build/Order" #-}
                                  )
                             -- use rule "src-ag/Order.ag"(line 62, column 105)
                             _lhsOnAutoRules =
                                 ({-# LINE 62 "src-ag/Order.ag" #-}
                                  _hdInAutoRules + _tlInAutoRules
                                  {-# LINE 4230 "dist/build/Order" #-}
                                  )
                             -- use rule "src-ag/Order.ag"(line 62, column 105)
                             _lhsOnExplicitRules =
                                 ({-# LINE 62 "src-ag/Order.ag" #-}
                                  _hdInExplicitRules + _tlInExplicitRules
                                  {-# LINE 4236 "dist/build/Order" #-}
                                  )
                             -- use rule "src-ag/Order.ag"(line 258, column 18)
                             _lhsOrules =
                                 ({-# LINE 258 "src-ag/Order.ag" #-}
                                  _hdIrules Seq.>< _tlIrules
                                  {-# LINE 4242 "dist/build/Order" #-}
                                  )
                             -- copy rule (up)
                             _lhsOvcount =
                                 ({-# LINE 257 "src-ag/Order.ag" #-}
                                  _tlIvcount
                                  {-# LINE 4248 "dist/build/Order" #-}
                                  )
                             -- copy rule (down)
                             _hdOallnts =
                                 ({-# LINE 648 "src-ag/Order.ag" #-}
                                  _lhsIallnts
                                  {-# LINE 4254 "dist/build/Order" #-}
                                  )
                             -- copy rule (down)
                             _hdOaroundMap =
                                 ({-# LINE 409 "src-ag/Order.ag" #-}
                                  _lhsIaroundMap
                                  {-# LINE 4260 "dist/build/Order" #-}
                                  )
                             -- copy rule (down)
                             _hdOcVisitsMap =
                                 ({-# LINE 602 "src-ag/Order.ag" #-}
                                  _lhsIcVisitsMap
                                  {-# LINE 4266 "dist/build/Order" #-}
                                  )
                             -- copy rule (down)
                             _hdOinh =
                                 ({-# LINE 90 "src-ag/Order.ag" #-}
                                  _lhsIinh
                                  {-# LINE 4272 "dist/build/Order" #-}
                                  )
                             -- copy rule (down)
                             _hdOinhMap =
                                 ({-# LINE 12 "src-ag/DistChildAttr.ag" #-}
                                  _lhsIinhMap
                                  {-# LINE 4278 "dist/build/Order" #-}
                                  )
                             -- copy rule (down)
                             _hdOmanualAttrDepMap =
                                 ({-# LINE 282 "src-ag/Order.ag" #-}
                                  _lhsImanualAttrDepMap
                                  {-# LINE 4284 "dist/build/Order" #-}
                                  )
                             -- copy rule (down)
                             _hdOmergeMap =
                                 ({-# LINE 356 "src-ag/Order.ag" #-}
                                  _lhsImergeMap
                                  {-# LINE 4290 "dist/build/Order" #-}
                                  )
                             -- copy rule (down)
                             _hdOnt =
                                 ({-# LINE 90 "src-ag/Order.ag" #-}
                                  _lhsInt
                                  {-# LINE 4296 "dist/build/Order" #-}
                                  )
                             -- copy rule (down)
                             _hdOo_case =
                                 ({-# LINE 118 "src-ag/Order.ag" #-}
                                  _lhsIo_case
                                  {-# LINE 4302 "dist/build/Order" #-}
                                  )
                             -- copy rule (down)
                             _hdOo_cata =
                                 ({-# LINE 112 "src-ag/Order.ag" #-}
                                  _lhsIo_cata
                                  {-# LINE 4308 "dist/build/Order" #-}
                                  )
                             -- copy rule (down)
                             _hdOo_dovisit =
                                 ({-# LINE 117 "src-ag/Order.ag" #-}
                                  _lhsIo_dovisit
                                  {-# LINE 4314 "dist/build/Order" #-}
                                  )
                             -- copy rule (down)
                             _hdOo_newtypes =
                                 ({-# LINE 111 "src-ag/Order.ag" #-}
                                  _lhsIo_newtypes
                                  {-# LINE 4320 "dist/build/Order" #-}
                                  )
                             -- copy rule (down)
                             _hdOo_rename =
                                 ({-# LINE 115 "src-ag/Order.ag" #-}
                                  _lhsIo_rename
                                  {-# LINE 4326 "dist/build/Order" #-}
                                  )
                             -- copy rule (down)
                             _hdOo_sem =
                                 ({-# LINE 114 "src-ag/Order.ag" #-}
                                  _lhsIo_sem
                                  {-# LINE 4332 "dist/build/Order" #-}
                                  )
                             -- copy rule (down)
                             _hdOo_sig =
                                 ({-# LINE 113 "src-ag/Order.ag" #-}
                                  _lhsIo_sig
                                  {-# LINE 4338 "dist/build/Order" #-}
                                  )
                             -- copy rule (down)
                             _hdOo_unbox =
                                 ({-# LINE 120 "src-ag/Order.ag" #-}
                                  _lhsIo_unbox
                                  {-# LINE 4344 "dist/build/Order" #-}
                                  )
                             -- copy rule (down)
                             _hdOo_wantvisit =
                                 ({-# LINE 116 "src-ag/Order.ag" #-}
                                  _lhsIo_wantvisit
                                  {-# LINE 4350 "dist/build/Order" #-}
                                  )
                             -- copy rule (down)
                             _hdOprefix =
                                 ({-# LINE 119 "src-ag/Order.ag" #-}
                                  _lhsIprefix
                                  {-# LINE 4356 "dist/build/Order" #-}
                                  )
                             -- copy rule (down)
                             _hdOsyn =
                                 ({-# LINE 90 "src-ag/Order.ag" #-}
                                  _lhsIsyn
                                  {-# LINE 4362 "dist/build/Order" #-}
                                  )
                             -- copy rule (down)
                             _hdOsynMap =
                                 ({-# LINE 12 "src-ag/DistChildAttr.ag" #-}
                                  _lhsIsynMap
                                  {-# LINE 4368 "dist/build/Order" #-}
                                  )
                             -- copy rule (down)
                             _hdOvcount =
                                 ({-# LINE 257 "src-ag/Order.ag" #-}
                                  _lhsIvcount
                                  {-# LINE 4374 "dist/build/Order" #-}
                                  )
                             -- copy rule (down)
                             _tlOallnts =
                                 ({-# LINE 648 "src-ag/Order.ag" #-}
                                  _lhsIallnts
                                  {-# LINE 4380 "dist/build/Order" #-}
                                  )
                             -- copy rule (down)
                             _tlOaroundMap =
                                 ({-# LINE 409 "src-ag/Order.ag" #-}
                                  _lhsIaroundMap
                                  {-# LINE 4386 "dist/build/Order" #-}
                                  )
                             -- copy rule (down)
                             _tlOcVisitsMap =
                                 ({-# LINE 602 "src-ag/Order.ag" #-}
                                  _lhsIcVisitsMap
                                  {-# LINE 4392 "dist/build/Order" #-}
                                  )
                             -- copy rule (down)
                             _tlOinh =
                                 ({-# LINE 90 "src-ag/Order.ag" #-}
                                  _lhsIinh
                                  {-# LINE 4398 "dist/build/Order" #-}
                                  )
                             -- copy rule (down)
                             _tlOinhMap =
                                 ({-# LINE 12 "src-ag/DistChildAttr.ag" #-}
                                  _lhsIinhMap
                                  {-# LINE 4404 "dist/build/Order" #-}
                                  )
                             -- copy rule (down)
                             _tlOmanualAttrDepMap =
                                 ({-# LINE 282 "src-ag/Order.ag" #-}
                                  _lhsImanualAttrDepMap
                                  {-# LINE 4410 "dist/build/Order" #-}
                                  )
                             -- copy rule (down)
                             _tlOmergeMap =
                                 ({-# LINE 356 "src-ag/Order.ag" #-}
                                  _lhsImergeMap
                                  {-# LINE 4416 "dist/build/Order" #-}
                                  )
                             -- copy rule (down)
                             _tlOnt =
                                 ({-# LINE 90 "src-ag/Order.ag" #-}
                                  _lhsInt
                                  {-# LINE 4422 "dist/build/Order" #-}
                                  )
                             -- copy rule (down)
                             _tlOo_case =
                                 ({-# LINE 118 "src-ag/Order.ag" #-}
                                  _lhsIo_case
                                  {-# LINE 4428 "dist/build/Order" #-}
                                  )
                             -- copy rule (down)
                             _tlOo_cata =
                                 ({-# LINE 112 "src-ag/Order.ag" #-}
                                  _lhsIo_cata
                                  {-# LINE 4434 "dist/build/Order" #-}
                                  )
                             -- copy rule (down)
                             _tlOo_dovisit =
                                 ({-# LINE 117 "src-ag/Order.ag" #-}
                                  _lhsIo_dovisit
                                  {-# LINE 4440 "dist/build/Order" #-}
                                  )
                             -- copy rule (down)
                             _tlOo_newtypes =
                                 ({-# LINE 111 "src-ag/Order.ag" #-}
                                  _lhsIo_newtypes
                                  {-# LINE 4446 "dist/build/Order" #-}
                                  )
                             -- copy rule (down)
                             _tlOo_rename =
                                 ({-# LINE 115 "src-ag/Order.ag" #-}
                                  _lhsIo_rename
                                  {-# LINE 4452 "dist/build/Order" #-}
                                  )
                             -- copy rule (down)
                             _tlOo_sem =
                                 ({-# LINE 114 "src-ag/Order.ag" #-}
                                  _lhsIo_sem
                                  {-# LINE 4458 "dist/build/Order" #-}
                                  )
                             -- copy rule (down)
                             _tlOo_sig =
                                 ({-# LINE 113 "src-ag/Order.ag" #-}
                                  _lhsIo_sig
                                  {-# LINE 4464 "dist/build/Order" #-}
                                  )
                             -- copy rule (down)
                             _tlOo_unbox =
                                 ({-# LINE 120 "src-ag/Order.ag" #-}
                                  _lhsIo_unbox
                                  {-# LINE 4470 "dist/build/Order" #-}
                                  )
                             -- copy rule (down)
                             _tlOo_wantvisit =
                                 ({-# LINE 116 "src-ag/Order.ag" #-}
                                  _lhsIo_wantvisit
                                  {-# LINE 4476 "dist/build/Order" #-}
                                  )
                             -- copy rule (down)
                             _tlOprefix =
                                 ({-# LINE 119 "src-ag/Order.ag" #-}
                                  _lhsIprefix
                                  {-# LINE 4482 "dist/build/Order" #-}
                                  )
                             -- copy rule (down)
                             _tlOsyn =
                                 ({-# LINE 90 "src-ag/Order.ag" #-}
                                  _lhsIsyn
                                  {-# LINE 4488 "dist/build/Order" #-}
                                  )
                             -- copy rule (down)
                             _tlOsynMap =
                                 ({-# LINE 12 "src-ag/DistChildAttr.ag" #-}
                                  _lhsIsynMap
                                  {-# LINE 4494 "dist/build/Order" #-}
                                  )
                             -- copy rule (chain)
                             _tlOvcount =
                                 ({-# LINE 257 "src-ag/Order.ag" #-}
                                  _hdIvcount
                                  {-# LINE 4500 "dist/build/Order" #-}
                                  )
                             ( _hdIadditionalDep,_hdIaroundDep,_hdIcProduction,_hdIcons,_hdIdirectDep,_hdIerrors,_hdIinstDep,_hdImergeDep,_hdInAutoRules,_hdInExplicitRules,_hdIrules,_hdIvcount) =
                                 hd_ _hdOallnts _hdOaroundMap _hdOcVisitsMap _hdOinh _hdOinhMap _hdOmanualAttrDepMap _hdOmergeMap _hdOnt _hdOo_case _hdOo_cata _hdOo_dovisit _hdOo_newtypes _hdOo_rename _hdOo_sem _hdOo_sig _hdOo_unbox _hdOo_wantvisit _hdOprefix _hdOsyn _hdOsynMap _hdOvcount
                             ( _tlIadditionalDep,_tlIaroundDep,_tlIcProductions,_tlIcons,_tlIdirectDep,_tlIerrors,_tlIinstDep,_tlImergeDep,_tlInAutoRules,_tlInExplicitRules,_tlIrules,_tlIvcount) =
                                 tl_ _tlOallnts _tlOaroundMap _tlOcVisitsMap _tlOinh _tlOinhMap _tlOmanualAttrDepMap _tlOmergeMap _tlOnt _tlOo_case _tlOo_cata _tlOo_dovisit _tlOo_newtypes _tlOo_rename _tlOo_sem _tlOo_sig _tlOo_unbox _tlOo_wantvisit _tlOprefix _tlOsyn _tlOsynMap _tlOvcount
                         in  ( _lhsOadditionalDep,_lhsOaroundDep,_lhsOcProductions,_lhsOcons,_lhsOdirectDep,_lhsOerrors,_lhsOinstDep,_lhsOmergeDep,_lhsOnAutoRules,_lhsOnExplicitRules,_lhsOrules,_lhsOvcount))))
sem_Productions_Nil :: T_Productions
sem_Productions_Nil =
    (T_Productions (\ _lhsIallnts
                      _lhsIaroundMap
                      _lhsIcVisitsMap
                      _lhsIinh
                      _lhsIinhMap
                      _lhsImanualAttrDepMap
                      _lhsImergeMap
                      _lhsInt
                      _lhsIo_case
                      _lhsIo_cata
                      _lhsIo_dovisit
                      _lhsIo_newtypes
                      _lhsIo_rename
                      _lhsIo_sem
                      _lhsIo_sig
                      _lhsIo_unbox
                      _lhsIo_wantvisit
                      _lhsIprefix
                      _lhsIsyn
                      _lhsIsynMap
                      _lhsIvcount ->
                        (let _lhsOcProductions :: CProductions
                             _lhsOadditionalDep :: (Seq Edge)
                             _lhsOaroundDep :: (Seq Edge)
                             _lhsOcons :: ([ConstructorIdent])
                             _lhsOdirectDep :: (Seq Edge)
                             _lhsOerrors :: (Seq Error)
                             _lhsOinstDep :: (Seq Edge)
                             _lhsOmergeDep :: (Seq Edge)
                             _lhsOnAutoRules :: Int
                             _lhsOnExplicitRules :: Int
                             _lhsOrules :: (Seq (Vertex,CRule))
                             _lhsOvcount :: Int
                             -- "src-ag/Order.ag"(line 628, column 12)
                             _lhsOcProductions =
                                 ({-# LINE 628 "src-ag/Order.ag" #-}
                                  []
                                  {-# LINE 4546 "dist/build/Order" #-}
                                  )
                             -- use rule "src-ag/Order.ag"(line 282, column 60)
                             _lhsOadditionalDep =
                                 ({-# LINE 282 "src-ag/Order.ag" #-}
                                  Seq.empty
                                  {-# LINE 4552 "dist/build/Order" #-}
                                  )
                             -- use rule "src-ag/Order.ag"(line 403, column 24)
                             _lhsOaroundDep =
                                 ({-# LINE 403 "src-ag/Order.ag" #-}
                                  Seq.empty
                                  {-# LINE 4558 "dist/build/Order" #-}
                                  )
                             -- use rule "src-ag/Order.ag"(line 521, column 40)
                             _lhsOcons =
                                 ({-# LINE 521 "src-ag/Order.ag" #-}
                                  []
                                  {-# LINE 4564 "dist/build/Order" #-}
                                  )
                             -- use rule "src-ag/Order.ag"(line 268, column 33)
                             _lhsOdirectDep =
                                 ({-# LINE 268 "src-ag/Order.ag" #-}
                                  Seq.empty
                                  {-# LINE 4570 "dist/build/Order" #-}
                                  )
                             -- use rule "src-ag/Order.ag"(line 85, column 70)
                             _lhsOerrors =
                                 ({-# LINE 85 "src-ag/Order.ag" #-}
                                  Seq.empty
                                  {-# LINE 4576 "dist/build/Order" #-}
                                  )
                             -- use rule "src-ag/Order.ag"(line 311, column 31)
                             _lhsOinstDep =
                                 ({-# LINE 311 "src-ag/Order.ag" #-}
                                  Seq.empty
                                  {-# LINE 4582 "dist/build/Order" #-}
                                  )
                             -- use rule "src-ag/Order.ag"(line 366, column 18)
                             _lhsOmergeDep =
                                 ({-# LINE 366 "src-ag/Order.ag" #-}
                                  Seq.empty
                                  {-# LINE 4588 "dist/build/Order" #-}
                                  )
                             -- use rule "src-ag/Order.ag"(line 62, column 105)
                             _lhsOnAutoRules =
                                 ({-# LINE 62 "src-ag/Order.ag" #-}
                                  0
                                  {-# LINE 4594 "dist/build/Order" #-}
                                  )
                             -- use rule "src-ag/Order.ag"(line 62, column 105)
                             _lhsOnExplicitRules =
                                 ({-# LINE 62 "src-ag/Order.ag" #-}
                                  0
                                  {-# LINE 4600 "dist/build/Order" #-}
                                  )
                             -- use rule "src-ag/Order.ag"(line 258, column 18)
                             _lhsOrules =
                                 ({-# LINE 258 "src-ag/Order.ag" #-}
                                  Seq.empty
                                  {-# LINE 4606 "dist/build/Order" #-}
                                  )
                             -- copy rule (chain)
                             _lhsOvcount =
                                 ({-# LINE 257 "src-ag/Order.ag" #-}
                                  _lhsIvcount
                                  {-# LINE 4612 "dist/build/Order" #-}
                                  )
                         in  ( _lhsOadditionalDep,_lhsOaroundDep,_lhsOcProductions,_lhsOcons,_lhsOdirectDep,_lhsOerrors,_lhsOinstDep,_lhsOmergeDep,_lhsOnAutoRules,_lhsOnExplicitRules,_lhsOrules,_lhsOvcount))))
-- Rule --------------------------------------------------------
{-
   visit 0:
      inherited attributes:
         allTypeSigs          : Map Identifier Type
         allfields            : [(Identifier,Type,ChildKind)]
         allnts               : [Identifier]
         altAttrs             : Map AltAttr Vertex
         attrs                : [(Identifier,Identifier)]
         childInhs            : Map Identifier Attributes
         childNts             : Map Identifier NontermIdent
         con                  : Identifier
         inh                  : Attributes
         inhsOfChildren       : Map Identifier Attributes
         mergeMap             : Map Identifier (Identifier,[Identifier])
         nt                   : Identifier
         o_case               : Bool
         o_cata               : Bool
         o_dovisit            : Bool
         o_newtypes           : Bool
         o_rename             : Bool
         o_sem                : Bool
         o_sig                : Bool
         o_wantvisit          : Bool
         prefix               : String
         syn                  : Attributes
         synsOfChildren       : Map Identifier Attributes
      synthesized attributes:
         directDep            : Seq Edge
         errors               : Seq Error
         gathAltAttrs         : [AltAttr]
         gathRules            : Seq CRule
         instDep              : Seq Edge
         instVars             : [Identifier]
         locVars              : [Identifier]
         nAutoRules           : Int
         nExplicitRules       : Int
   alternatives:
      alternative Rule:
         child mbName         : {Maybe Identifier}
         child pattern        : Pattern 
         child rhs            : Expression 
         child owrt           : {Bool}
         child origin         : {String}
         child explicit       : {Bool}
         child pure           : {Bool}
         child identity       : {Bool}
         child mbError        : {Maybe Error}
         child eager          : {Bool}
         visit 0:
            local defines     : _
            local gathRules   : _
            local instDep1    : _
            local instDep2    : _
-}
-- cata
sem_Rule :: Rule ->
            T_Rule
sem_Rule (Rule _mbName _pattern _rhs _owrt _origin _explicit _pure _identity _mbError _eager) =
    (sem_Rule_Rule _mbName (sem_Pattern _pattern) (sem_Expression _rhs) _owrt _origin _explicit _pure _identity _mbError _eager)
-- semantic domain
newtype T_Rule = T_Rule ((Map Identifier Type) ->
                         ([(Identifier,Type,ChildKind)]) ->
                         ([Identifier]) ->
                         (Map AltAttr Vertex) ->
                         ([(Identifier,Identifier)]) ->
                         (Map Identifier Attributes) ->
                         (Map Identifier NontermIdent) ->
                         Identifier ->
                         Attributes ->
                         (Map Identifier Attributes) ->
                         (Map Identifier (Identifier,[Identifier])) ->
                         Identifier ->
                         Bool ->
                         Bool ->
                         Bool ->
                         Bool ->
                         Bool ->
                         Bool ->
                         Bool ->
                         Bool ->
                         String ->
                         Attributes ->
                         (Map Identifier Attributes) ->
                         ( (Seq Edge),(Seq Error),([AltAttr]),(Seq CRule),(Seq Edge),([Identifier]),([Identifier]),Int,Int))
data Inh_Rule = Inh_Rule {allTypeSigs_Inh_Rule :: !((Map Identifier Type)),allfields_Inh_Rule :: !(([(Identifier,Type,ChildKind)])),allnts_Inh_Rule :: !(([Identifier])),altAttrs_Inh_Rule :: !((Map AltAttr Vertex)),attrs_Inh_Rule :: !(([(Identifier,Identifier)])),childInhs_Inh_Rule :: !((Map Identifier Attributes)),childNts_Inh_Rule :: !((Map Identifier NontermIdent)),con_Inh_Rule :: !(Identifier),inh_Inh_Rule :: !(Attributes),inhsOfChildren_Inh_Rule :: !((Map Identifier Attributes)),mergeMap_Inh_Rule :: !((Map Identifier (Identifier,[Identifier]))),nt_Inh_Rule :: !(Identifier),o_case_Inh_Rule :: !(Bool),o_cata_Inh_Rule :: !(Bool),o_dovisit_Inh_Rule :: !(Bool),o_newtypes_Inh_Rule :: !(Bool),o_rename_Inh_Rule :: !(Bool),o_sem_Inh_Rule :: !(Bool),o_sig_Inh_Rule :: !(Bool),o_wantvisit_Inh_Rule :: !(Bool),prefix_Inh_Rule :: !(String),syn_Inh_Rule :: !(Attributes),synsOfChildren_Inh_Rule :: !((Map Identifier Attributes))}
data Syn_Rule = Syn_Rule {directDep_Syn_Rule :: !((Seq Edge)),errors_Syn_Rule :: !((Seq Error)),gathAltAttrs_Syn_Rule :: !(([AltAttr])),gathRules_Syn_Rule :: !((Seq CRule)),instDep_Syn_Rule :: !((Seq Edge)),instVars_Syn_Rule :: !(([Identifier])),locVars_Syn_Rule :: !(([Identifier])),nAutoRules_Syn_Rule :: !(Int),nExplicitRules_Syn_Rule :: !(Int)}
wrap_Rule :: T_Rule ->
             Inh_Rule ->
             Syn_Rule
wrap_Rule (T_Rule sem) (Inh_Rule _lhsIallTypeSigs _lhsIallfields _lhsIallnts _lhsIaltAttrs _lhsIattrs _lhsIchildInhs _lhsIchildNts _lhsIcon _lhsIinh _lhsIinhsOfChildren _lhsImergeMap _lhsInt _lhsIo_case _lhsIo_cata _lhsIo_dovisit _lhsIo_newtypes _lhsIo_rename _lhsIo_sem _lhsIo_sig _lhsIo_wantvisit _lhsIprefix _lhsIsyn _lhsIsynsOfChildren) =
    (let ( _lhsOdirectDep,_lhsOerrors,_lhsOgathAltAttrs,_lhsOgathRules,_lhsOinstDep,_lhsOinstVars,_lhsOlocVars,_lhsOnAutoRules,_lhsOnExplicitRules) = sem _lhsIallTypeSigs _lhsIallfields _lhsIallnts _lhsIaltAttrs _lhsIattrs _lhsIchildInhs _lhsIchildNts _lhsIcon _lhsIinh _lhsIinhsOfChildren _lhsImergeMap _lhsInt _lhsIo_case _lhsIo_cata _lhsIo_dovisit _lhsIo_newtypes _lhsIo_rename _lhsIo_sem _lhsIo_sig _lhsIo_wantvisit _lhsIprefix _lhsIsyn _lhsIsynsOfChildren
     in  (Syn_Rule _lhsOdirectDep _lhsOerrors _lhsOgathAltAttrs _lhsOgathRules _lhsOinstDep _lhsOinstVars _lhsOlocVars _lhsOnAutoRules _lhsOnExplicitRules))
sem_Rule_Rule :: (Maybe Identifier) ->
                 T_Pattern ->
                 T_Expression ->
                 Bool ->
                 String ->
                 Bool ->
                 Bool ->
                 Bool ->
                 (Maybe Error) ->
                 Bool ->
                 T_Rule
sem_Rule_Rule mbName_ (T_Pattern pattern_) (T_Expression rhs_) owrt_ origin_ explicit_ pure_ identity_ mbError_ eager_ =
    (T_Rule (\ _lhsIallTypeSigs
               _lhsIallfields
               _lhsIallnts
               _lhsIaltAttrs
               _lhsIattrs
               _lhsIchildInhs
               _lhsIchildNts
               _lhsIcon
               _lhsIinh
               _lhsIinhsOfChildren
               _lhsImergeMap
               _lhsInt
               _lhsIo_case
               _lhsIo_cata
               _lhsIo_dovisit
               _lhsIo_newtypes
               _lhsIo_rename
               _lhsIo_sem
               _lhsIo_sig
               _lhsIo_wantvisit
               _lhsIprefix
               _lhsIsyn
               _lhsIsynsOfChildren ->
                 (let _lhsOnExplicitRules :: Int
                      _lhsOnAutoRules :: Int
                      _lhsOdirectDep :: (Seq Edge)
                      _lhsOinstDep :: (Seq Edge)
                      _lhsOerrors :: (Seq Error)
                      _lhsOgathAltAttrs :: ([AltAttr])
                      _lhsOgathRules :: (Seq CRule)
                      _lhsOinstVars :: ([Identifier])
                      _lhsOlocVars :: ([Identifier])
                      _patternOallTypeSigs :: (Map Identifier Type)
                      _patternOaltAttrs :: (Map AltAttr Vertex)
                      _patternOcon :: Identifier
                      _patternOinh :: Attributes
                      _patternOnt :: Identifier
                      _patternOsyn :: Attributes
                      _rhsOallfields :: ([(Identifier,Type,ChildKind)])
                      _rhsOallnts :: ([Identifier])
                      _rhsOattrs :: ([(Identifier,Identifier)])
                      _rhsOcon :: Identifier
                      _rhsOmergeMap :: (Map Identifier (Identifier,[Identifier]))
                      _rhsOnt :: Identifier
                      _patternIcopy :: Pattern
                      _patternIerrors :: (Seq Error)
                      _patternIgathAltAttrs :: ([AltAttr])
                      _patternIinstVars :: ([Identifier])
                      _patternIlocVars :: ([Identifier])
                      _patternIpatternAttrs :: ([(Identifier,Identifier,Bool)])
                      _rhsIallRhsVars :: (Set (Identifier,Identifier))
                      _rhsIcopy :: Expression
                      _rhsIerrors :: (Seq Error)
                      _rhsItextLines :: ([String])
                      _rhsIusedAttrs :: ([(Identifier,Identifier)])
                      _rhsIusedFields :: ([Identifier])
                      _rhsIusedLocals :: ([Identifier])
                      -- "src-ag/Order.ag"(line 65, column 11)
                      _lhsOnExplicitRules =
                          ({-# LINE 65 "src-ag/Order.ag" #-}
                           if explicit_
                           then 1
                           else 0
                           {-# LINE 4783 "dist/build/Order" #-}
                           )
                      -- "src-ag/Order.ag"(line 68, column 11)
                      _lhsOnAutoRules =
                          ({-# LINE 68 "src-ag/Order.ag" #-}
                           if startsWith "use rule" origin_ || startsWith "copy rule" origin_
                           then 1
                           else 0
                           {-# LINE 4791 "dist/build/Order" #-}
                           )
                      -- "src-ag/Order.ag"(line 218, column 12)
                      _defines =
                          ({-# LINE 218 "src-ag/Order.ag" #-}
                           let  tp field attr      | field == _LOC || field == _INST
                                                                    = Map.lookup attr _lhsIallTypeSigs
                                                    | field == _LHS = Map.lookup attr _lhsIsyn
                                                    | otherwise     = Map.lookup attr (findWithErr1 "Rule.defines.tp" field _lhsIchildInhs)
                                typ :: Pattern -> Maybe Type
                                typ (Alias field attr _)       = tp field attr
                                typ (Underscore _)             = Nothing
                                typ _                          = Nothing
                           in Map.fromList  [ (findWithErr1 "Rule.defines" aa _lhsIaltAttrs, (field,attr,(tp field attr)))
                                            | (field,attr,isLocalOrInst) <- _patternIpatternAttrs
                                            , let aa = AltAttr field attr isLocalOrInst
                                            ]
                           {-# LINE 4808 "dist/build/Order" #-}
                           )
                      -- "src-ag/Order.ag"(line 232, column 12)
                      _gathRules =
                          ({-# LINE 232 "src-ag/Order.ag" #-}
                           let childnt field = Map.lookup field _lhsIchildNts
                           in Seq.fromList [ CRule attr False True _lhsInt _lhsIcon field (childnt field) tp _patternIcopy _rhsItextLines _defines owrt_ origin_ _rhsIallRhsVars explicit_ mbName_
                                           | (field,attr,tp) <- Map.elems _defines
                                           ]
                           {-# LINE 4817 "dist/build/Order" #-}
                           )
                      -- "src-ag/Order.ag"(line 270, column 12)
                      _lhsOdirectDep =
                          ({-# LINE 270 "src-ag/Order.ag" #-}
                           let  defined = Map.keys _defines
                                used =  [ Map.lookup (AltAttr field attr True) _lhsIaltAttrs | (field,attr) <- _rhsIusedAttrs]
                                        ++ [ Map.lookup (AltAttr _LOC attr True) _lhsIaltAttrs | attr <- _rhsIusedLocals ++ _rhsIusedFields ]
                           in Seq.fromList [ (x,y) | Just x <- used, y <- defined ]
                           {-# LINE 4826 "dist/build/Order" #-}
                           )
                      -- "src-ag/Order.ag"(line 314, column 6)
                      _instDep1 =
                          ({-# LINE 314 "src-ag/Order.ag" #-}
                           Seq.fromList $
                             [ (instVert, synVert)
                             | (field,instNm,_) <- Map.elems _defines
                             , field == _INST
                             , synNm <- Map.keys (findWithErr2 instNm _lhsIsynsOfChildren)
                             , let instAttr = AltAttr _INST instNm True
                                   synAttr  = AltAttr instNm synNm True
                                   instVert = findWithErr2 instAttr _lhsIaltAttrs
                                   synVert  = findWithErr2 synAttr _lhsIaltAttrs
                             ]
                           {-# LINE 4841 "dist/build/Order" #-}
                           )
                      -- "src-ag/Order.ag"(line 325, column 6)
                      _instDep2 =
                          ({-# LINE 325 "src-ag/Order.ag" #-}
                           Seq.fromList $
                             [ (instVert, inhVert)
                             | (field,instNm,_) <- Map.elems _defines
                             , field == _INST
                             , inhNm <- Map.keys (findWithErr2 instNm _lhsIinhsOfChildren)
                             , let instAttr = AltAttr _INST instNm True
                                   inhAttr  = AltAttr instNm inhNm False
                                   instVert = findWithErr2 instAttr _lhsIaltAttrs
                                   inhVert  = findWithErr2 inhAttr _lhsIaltAttrs
                             ]
                           {-# LINE 4856 "dist/build/Order" #-}
                           )
                      -- "src-ag/Order.ag"(line 336, column 6)
                      _lhsOinstDep =
                          ({-# LINE 336 "src-ag/Order.ag" #-}
                           _instDep1     Seq.>< _instDep2
                           {-# LINE 4862 "dist/build/Order" #-}
                           )
                      -- use rule "src-ag/Order.ag"(line 85, column 70)
                      _lhsOerrors =
                          ({-# LINE 85 "src-ag/Order.ag" #-}
                           _patternIerrors Seq.>< _rhsIerrors
                           {-# LINE 4868 "dist/build/Order" #-}
                           )
                      -- use rule "src-ag/Order.ag"(line 171, column 68)
                      _lhsOgathAltAttrs =
                          ({-# LINE 171 "src-ag/Order.ag" #-}
                           _patternIgathAltAttrs
                           {-# LINE 4874 "dist/build/Order" #-}
                           )
                      -- use rule "src-ag/Order.ag"(line 207, column 23)
                      _lhsOgathRules =
                          ({-# LINE 207 "src-ag/Order.ag" #-}
                           _gathRules
                           {-# LINE 4880 "dist/build/Order" #-}
                           )
                      -- use rule "src-ag/Order.ag"(line 678, column 86)
                      _lhsOinstVars =
                          ({-# LINE 678 "src-ag/Order.ag" #-}
                           _patternIinstVars
                           {-# LINE 4886 "dist/build/Order" #-}
                           )
                      -- use rule "src-ag/Order.ag"(line 678, column 48)
                      _lhsOlocVars =
                          ({-# LINE 678 "src-ag/Order.ag" #-}
                           _patternIlocVars
                           {-# LINE 4892 "dist/build/Order" #-}
                           )
                      -- copy rule (down)
                      _patternOallTypeSigs =
                          ({-# LINE 534 "src-ag/Order.ag" #-}
                           _lhsIallTypeSigs
                           {-# LINE 4898 "dist/build/Order" #-}
                           )
                      -- copy rule (down)
                      _patternOaltAttrs =
                          ({-# LINE 187 "src-ag/Order.ag" #-}
                           _lhsIaltAttrs
                           {-# LINE 4904 "dist/build/Order" #-}
                           )
                      -- copy rule (down)
                      _patternOcon =
                          ({-# LINE 91 "src-ag/Order.ag" #-}
                           _lhsIcon
                           {-# LINE 4910 "dist/build/Order" #-}
                           )
                      -- copy rule (down)
                      _patternOinh =
                          ({-# LINE 90 "src-ag/Order.ag" #-}
                           _lhsIinh
                           {-# LINE 4916 "dist/build/Order" #-}
                           )
                      -- copy rule (down)
                      _patternOnt =
                          ({-# LINE 90 "src-ag/Order.ag" #-}
                           _lhsInt
                           {-# LINE 4922 "dist/build/Order" #-}
                           )
                      -- copy rule (down)
                      _patternOsyn =
                          ({-# LINE 90 "src-ag/Order.ag" #-}
                           _lhsIsyn
                           {-# LINE 4928 "dist/build/Order" #-}
                           )
                      -- copy rule (down)
                      _rhsOallfields =
                          ({-# LINE 447 "src-ag/Order.ag" #-}
                           _lhsIallfields
                           {-# LINE 4934 "dist/build/Order" #-}
                           )
                      -- copy rule (down)
                      _rhsOallnts =
                          ({-# LINE 448 "src-ag/Order.ag" #-}
                           _lhsIallnts
                           {-# LINE 4940 "dist/build/Order" #-}
                           )
                      -- copy rule (down)
                      _rhsOattrs =
                          ({-# LINE 449 "src-ag/Order.ag" #-}
                           _lhsIattrs
                           {-# LINE 4946 "dist/build/Order" #-}
                           )
                      -- copy rule (down)
                      _rhsOcon =
                          ({-# LINE 446 "src-ag/Order.ag" #-}
                           _lhsIcon
                           {-# LINE 4952 "dist/build/Order" #-}
                           )
                      -- copy rule (down)
                      _rhsOmergeMap =
                          ({-# LINE 361 "src-ag/Order.ag" #-}
                           _lhsImergeMap
                           {-# LINE 4958 "dist/build/Order" #-}
                           )
                      -- copy rule (down)
                      _rhsOnt =
                          ({-# LINE 446 "src-ag/Order.ag" #-}
                           _lhsInt
                           {-# LINE 4964 "dist/build/Order" #-}
                           )
                      ( _patternIcopy,_patternIerrors,_patternIgathAltAttrs,_patternIinstVars,_patternIlocVars,_patternIpatternAttrs) =
                          pattern_ _patternOallTypeSigs _patternOaltAttrs _patternOcon _patternOinh _patternOnt _patternOsyn
                      ( _rhsIallRhsVars,_rhsIcopy,_rhsIerrors,_rhsItextLines,_rhsIusedAttrs,_rhsIusedFields,_rhsIusedLocals) =
                          rhs_ _rhsOallfields _rhsOallnts _rhsOattrs _rhsOcon _rhsOmergeMap _rhsOnt
                  in  ( _lhsOdirectDep,_lhsOerrors,_lhsOgathAltAttrs,_lhsOgathRules,_lhsOinstDep,_lhsOinstVars,_lhsOlocVars,_lhsOnAutoRules,_lhsOnExplicitRules))))
-- Rules -------------------------------------------------------
{-
   visit 0:
      inherited attributes:
         allTypeSigs          : Map Identifier Type
         allfields            : [(Identifier,Type,ChildKind)]
         allnts               : [Identifier]
         altAttrs             : Map AltAttr Vertex
         attrs                : [(Identifier,Identifier)]
         childInhs            : Map Identifier Attributes
         childNts             : Map Identifier NontermIdent
         con                  : Identifier
         inh                  : Attributes
         inhsOfChildren       : Map Identifier Attributes
         mergeMap             : Map Identifier (Identifier,[Identifier])
         nt                   : Identifier
         o_case               : Bool
         o_cata               : Bool
         o_dovisit            : Bool
         o_newtypes           : Bool
         o_rename             : Bool
         o_sem                : Bool
         o_sig                : Bool
         o_wantvisit          : Bool
         prefix               : String
         syn                  : Attributes
         synsOfChildren       : Map Identifier Attributes
      synthesized attributes:
         directDep            : Seq Edge
         errors               : Seq Error
         gathAltAttrs         : [AltAttr]
         gathRules            : Seq CRule
         instDep              : Seq Edge
         instVars             : [Identifier]
         locVars              : [Identifier]
         nAutoRules           : Int
         nExplicitRules       : Int
   alternatives:
      alternative Cons:
         child hd             : Rule 
         child tl             : Rules 
      alternative Nil:
-}
-- cata
sem_Rules :: Rules ->
             T_Rules
sem_Rules list =
    (Prelude.foldr sem_Rules_Cons sem_Rules_Nil (Prelude.map sem_Rule list))
-- semantic domain
newtype T_Rules = T_Rules ((Map Identifier Type) ->
                           ([(Identifier,Type,ChildKind)]) ->
                           ([Identifier]) ->
                           (Map AltAttr Vertex) ->
                           ([(Identifier,Identifier)]) ->
                           (Map Identifier Attributes) ->
                           (Map Identifier NontermIdent) ->
                           Identifier ->
                           Attributes ->
                           (Map Identifier Attributes) ->
                           (Map Identifier (Identifier,[Identifier])) ->
                           Identifier ->
                           Bool ->
                           Bool ->
                           Bool ->
                           Bool ->
                           Bool ->
                           Bool ->
                           Bool ->
                           Bool ->
                           String ->
                           Attributes ->
                           (Map Identifier Attributes) ->
                           ( (Seq Edge),(Seq Error),([AltAttr]),(Seq CRule),(Seq Edge),([Identifier]),([Identifier]),Int,Int))
data Inh_Rules = Inh_Rules {allTypeSigs_Inh_Rules :: !((Map Identifier Type)),allfields_Inh_Rules :: !(([(Identifier,Type,ChildKind)])),allnts_Inh_Rules :: !(([Identifier])),altAttrs_Inh_Rules :: !((Map AltAttr Vertex)),attrs_Inh_Rules :: !(([(Identifier,Identifier)])),childInhs_Inh_Rules :: !((Map Identifier Attributes)),childNts_Inh_Rules :: !((Map Identifier NontermIdent)),con_Inh_Rules :: !(Identifier),inh_Inh_Rules :: !(Attributes),inhsOfChildren_Inh_Rules :: !((Map Identifier Attributes)),mergeMap_Inh_Rules :: !((Map Identifier (Identifier,[Identifier]))),nt_Inh_Rules :: !(Identifier),o_case_Inh_Rules :: !(Bool),o_cata_Inh_Rules :: !(Bool),o_dovisit_Inh_Rules :: !(Bool),o_newtypes_Inh_Rules :: !(Bool),o_rename_Inh_Rules :: !(Bool),o_sem_Inh_Rules :: !(Bool),o_sig_Inh_Rules :: !(Bool),o_wantvisit_Inh_Rules :: !(Bool),prefix_Inh_Rules :: !(String),syn_Inh_Rules :: !(Attributes),synsOfChildren_Inh_Rules :: !((Map Identifier Attributes))}
data Syn_Rules = Syn_Rules {directDep_Syn_Rules :: !((Seq Edge)),errors_Syn_Rules :: !((Seq Error)),gathAltAttrs_Syn_Rules :: !(([AltAttr])),gathRules_Syn_Rules :: !((Seq CRule)),instDep_Syn_Rules :: !((Seq Edge)),instVars_Syn_Rules :: !(([Identifier])),locVars_Syn_Rules :: !(([Identifier])),nAutoRules_Syn_Rules :: !(Int),nExplicitRules_Syn_Rules :: !(Int)}
wrap_Rules :: T_Rules ->
              Inh_Rules ->
              Syn_Rules
wrap_Rules (T_Rules sem) (Inh_Rules _lhsIallTypeSigs _lhsIallfields _lhsIallnts _lhsIaltAttrs _lhsIattrs _lhsIchildInhs _lhsIchildNts _lhsIcon _lhsIinh _lhsIinhsOfChildren _lhsImergeMap _lhsInt _lhsIo_case _lhsIo_cata _lhsIo_dovisit _lhsIo_newtypes _lhsIo_rename _lhsIo_sem _lhsIo_sig _lhsIo_wantvisit _lhsIprefix _lhsIsyn _lhsIsynsOfChildren) =
    (let ( _lhsOdirectDep,_lhsOerrors,_lhsOgathAltAttrs,_lhsOgathRules,_lhsOinstDep,_lhsOinstVars,_lhsOlocVars,_lhsOnAutoRules,_lhsOnExplicitRules) = sem _lhsIallTypeSigs _lhsIallfields _lhsIallnts _lhsIaltAttrs _lhsIattrs _lhsIchildInhs _lhsIchildNts _lhsIcon _lhsIinh _lhsIinhsOfChildren _lhsImergeMap _lhsInt _lhsIo_case _lhsIo_cata _lhsIo_dovisit _lhsIo_newtypes _lhsIo_rename _lhsIo_sem _lhsIo_sig _lhsIo_wantvisit _lhsIprefix _lhsIsyn _lhsIsynsOfChildren
     in  (Syn_Rules _lhsOdirectDep _lhsOerrors _lhsOgathAltAttrs _lhsOgathRules _lhsOinstDep _lhsOinstVars _lhsOlocVars _lhsOnAutoRules _lhsOnExplicitRules))
sem_Rules_Cons :: T_Rule ->
                  T_Rules ->
                  T_Rules
sem_Rules_Cons (T_Rule hd_) (T_Rules tl_) =
    (T_Rules (\ _lhsIallTypeSigs
                _lhsIallfields
                _lhsIallnts
                _lhsIaltAttrs
                _lhsIattrs
                _lhsIchildInhs
                _lhsIchildNts
                _lhsIcon
                _lhsIinh
                _lhsIinhsOfChildren
                _lhsImergeMap
                _lhsInt
                _lhsIo_case
                _lhsIo_cata
                _lhsIo_dovisit
                _lhsIo_newtypes
                _lhsIo_rename
                _lhsIo_sem
                _lhsIo_sig
                _lhsIo_wantvisit
                _lhsIprefix
                _lhsIsyn
                _lhsIsynsOfChildren ->
                  (let _lhsOdirectDep :: (Seq Edge)
                       _lhsOerrors :: (Seq Error)
                       _lhsOgathAltAttrs :: ([AltAttr])
                       _lhsOgathRules :: (Seq CRule)
                       _lhsOinstDep :: (Seq Edge)
                       _lhsOinstVars :: ([Identifier])
                       _lhsOlocVars :: ([Identifier])
                       _lhsOnAutoRules :: Int
                       _lhsOnExplicitRules :: Int
                       _hdOallTypeSigs :: (Map Identifier Type)
                       _hdOallfields :: ([(Identifier,Type,ChildKind)])
                       _hdOallnts :: ([Identifier])
                       _hdOaltAttrs :: (Map AltAttr Vertex)
                       _hdOattrs :: ([(Identifier,Identifier)])
                       _hdOchildInhs :: (Map Identifier Attributes)
                       _hdOchildNts :: (Map Identifier NontermIdent)
                       _hdOcon :: Identifier
                       _hdOinh :: Attributes
                       _hdOinhsOfChildren :: (Map Identifier Attributes)
                       _hdOmergeMap :: (Map Identifier (Identifier,[Identifier]))
                       _hdOnt :: Identifier
                       _hdOo_case :: Bool
                       _hdOo_cata :: Bool
                       _hdOo_dovisit :: Bool
                       _hdOo_newtypes :: Bool
                       _hdOo_rename :: Bool
                       _hdOo_sem :: Bool
                       _hdOo_sig :: Bool
                       _hdOo_wantvisit :: Bool
                       _hdOprefix :: String
                       _hdOsyn :: Attributes
                       _hdOsynsOfChildren :: (Map Identifier Attributes)
                       _tlOallTypeSigs :: (Map Identifier Type)
                       _tlOallfields :: ([(Identifier,Type,ChildKind)])
                       _tlOallnts :: ([Identifier])
                       _tlOaltAttrs :: (Map AltAttr Vertex)
                       _tlOattrs :: ([(Identifier,Identifier)])
                       _tlOchildInhs :: (Map Identifier Attributes)
                       _tlOchildNts :: (Map Identifier NontermIdent)
                       _tlOcon :: Identifier
                       _tlOinh :: Attributes
                       _tlOinhsOfChildren :: (Map Identifier Attributes)
                       _tlOmergeMap :: (Map Identifier (Identifier,[Identifier]))
                       _tlOnt :: Identifier
                       _tlOo_case :: Bool
                       _tlOo_cata :: Bool
                       _tlOo_dovisit :: Bool
                       _tlOo_newtypes :: Bool
                       _tlOo_rename :: Bool
                       _tlOo_sem :: Bool
                       _tlOo_sig :: Bool
                       _tlOo_wantvisit :: Bool
                       _tlOprefix :: String
                       _tlOsyn :: Attributes
                       _tlOsynsOfChildren :: (Map Identifier Attributes)
                       _hdIdirectDep :: (Seq Edge)
                       _hdIerrors :: (Seq Error)
                       _hdIgathAltAttrs :: ([AltAttr])
                       _hdIgathRules :: (Seq CRule)
                       _hdIinstDep :: (Seq Edge)
                       _hdIinstVars :: ([Identifier])
                       _hdIlocVars :: ([Identifier])
                       _hdInAutoRules :: Int
                       _hdInExplicitRules :: Int
                       _tlIdirectDep :: (Seq Edge)
                       _tlIerrors :: (Seq Error)
                       _tlIgathAltAttrs :: ([AltAttr])
                       _tlIgathRules :: (Seq CRule)
                       _tlIinstDep :: (Seq Edge)
                       _tlIinstVars :: ([Identifier])
                       _tlIlocVars :: ([Identifier])
                       _tlInAutoRules :: Int
                       _tlInExplicitRules :: Int
                       -- use rule "src-ag/Order.ag"(line 268, column 33)
                       _lhsOdirectDep =
                           ({-# LINE 268 "src-ag/Order.ag" #-}
                            _hdIdirectDep Seq.>< _tlIdirectDep
                            {-# LINE 5156 "dist/build/Order" #-}
                            )
                       -- use rule "src-ag/Order.ag"(line 85, column 70)
                       _lhsOerrors =
                           ({-# LINE 85 "src-ag/Order.ag" #-}
                            _hdIerrors Seq.>< _tlIerrors
                            {-# LINE 5162 "dist/build/Order" #-}
                            )
                       -- use rule "src-ag/Order.ag"(line 171, column 68)
                       _lhsOgathAltAttrs =
                           ({-# LINE 171 "src-ag/Order.ag" #-}
                            _hdIgathAltAttrs ++ _tlIgathAltAttrs
                            {-# LINE 5168 "dist/build/Order" #-}
                            )
                       -- use rule "src-ag/Order.ag"(line 207, column 23)
                       _lhsOgathRules =
                           ({-# LINE 207 "src-ag/Order.ag" #-}
                            _hdIgathRules Seq.>< _tlIgathRules
                            {-# LINE 5174 "dist/build/Order" #-}
                            )
                       -- use rule "src-ag/Order.ag"(line 311, column 31)
                       _lhsOinstDep =
                           ({-# LINE 311 "src-ag/Order.ag" #-}
                            _hdIinstDep Seq.>< _tlIinstDep
                            {-# LINE 5180 "dist/build/Order" #-}
                            )
                       -- use rule "src-ag/Order.ag"(line 678, column 86)
                       _lhsOinstVars =
                           ({-# LINE 678 "src-ag/Order.ag" #-}
                            _hdIinstVars ++ _tlIinstVars
                            {-# LINE 5186 "dist/build/Order" #-}
                            )
                       -- use rule "src-ag/Order.ag"(line 678, column 48)
                       _lhsOlocVars =
                           ({-# LINE 678 "src-ag/Order.ag" #-}
                            _hdIlocVars ++ _tlIlocVars
                            {-# LINE 5192 "dist/build/Order" #-}
                            )
                       -- use rule "src-ag/Order.ag"(line 62, column 105)
                       _lhsOnAutoRules =
                           ({-# LINE 62 "src-ag/Order.ag" #-}
                            _hdInAutoRules + _tlInAutoRules
                            {-# LINE 5198 "dist/build/Order" #-}
                            )
                       -- use rule "src-ag/Order.ag"(line 62, column 105)
                       _lhsOnExplicitRules =
                           ({-# LINE 62 "src-ag/Order.ag" #-}
                            _hdInExplicitRules + _tlInExplicitRules
                            {-# LINE 5204 "dist/build/Order" #-}
                            )
                       -- copy rule (down)
                       _hdOallTypeSigs =
                           ({-# LINE 534 "src-ag/Order.ag" #-}
                            _lhsIallTypeSigs
                            {-# LINE 5210 "dist/build/Order" #-}
                            )
                       -- copy rule (down)
                       _hdOallfields =
                           ({-# LINE 655 "src-ag/Order.ag" #-}
                            _lhsIallfields
                            {-# LINE 5216 "dist/build/Order" #-}
                            )
                       -- copy rule (down)
                       _hdOallnts =
                           ({-# LINE 648 "src-ag/Order.ag" #-}
                            _lhsIallnts
                            {-# LINE 5222 "dist/build/Order" #-}
                            )
                       -- copy rule (down)
                       _hdOaltAttrs =
                           ({-# LINE 187 "src-ag/Order.ag" #-}
                            _lhsIaltAttrs
                            {-# LINE 5228 "dist/build/Order" #-}
                            )
                       -- copy rule (down)
                       _hdOattrs =
                           ({-# LINE 655 "src-ag/Order.ag" #-}
                            _lhsIattrs
                            {-# LINE 5234 "dist/build/Order" #-}
                            )
                       -- copy rule (down)
                       _hdOchildInhs =
                           ({-# LINE 200 "src-ag/Order.ag" #-}
                            _lhsIchildInhs
                            {-# LINE 5240 "dist/build/Order" #-}
                            )
                       -- copy rule (down)
                       _hdOchildNts =
                           ({-# LINE 199 "src-ag/Order.ag" #-}
                            _lhsIchildNts
                            {-# LINE 5246 "dist/build/Order" #-}
                            )
                       -- copy rule (down)
                       _hdOcon =
                           ({-# LINE 91 "src-ag/Order.ag" #-}
                            _lhsIcon
                            {-# LINE 5252 "dist/build/Order" #-}
                            )
                       -- copy rule (down)
                       _hdOinh =
                           ({-# LINE 90 "src-ag/Order.ag" #-}
                            _lhsIinh
                            {-# LINE 5258 "dist/build/Order" #-}
                            )
                       -- copy rule (down)
                       _hdOinhsOfChildren =
                           ({-# LINE 338 "src-ag/Order.ag" #-}
                            _lhsIinhsOfChildren
                            {-# LINE 5264 "dist/build/Order" #-}
                            )
                       -- copy rule (down)
                       _hdOmergeMap =
                           ({-# LINE 361 "src-ag/Order.ag" #-}
                            _lhsImergeMap
                            {-# LINE 5270 "dist/build/Order" #-}
                            )
                       -- copy rule (down)
                       _hdOnt =
                           ({-# LINE 90 "src-ag/Order.ag" #-}
                            _lhsInt
                            {-# LINE 5276 "dist/build/Order" #-}
                            )
                       -- copy rule (down)
                       _hdOo_case =
                           ({-# LINE 118 "src-ag/Order.ag" #-}
                            _lhsIo_case
                            {-# LINE 5282 "dist/build/Order" #-}
                            )
                       -- copy rule (down)
                       _hdOo_cata =
                           ({-# LINE 112 "src-ag/Order.ag" #-}
                            _lhsIo_cata
                            {-# LINE 5288 "dist/build/Order" #-}
                            )
                       -- copy rule (down)
                       _hdOo_dovisit =
                           ({-# LINE 117 "src-ag/Order.ag" #-}
                            _lhsIo_dovisit
                            {-# LINE 5294 "dist/build/Order" #-}
                            )
                       -- copy rule (down)
                       _hdOo_newtypes =
                           ({-# LINE 111 "src-ag/Order.ag" #-}
                            _lhsIo_newtypes
                            {-# LINE 5300 "dist/build/Order" #-}
                            )
                       -- copy rule (down)
                       _hdOo_rename =
                           ({-# LINE 115 "src-ag/Order.ag" #-}
                            _lhsIo_rename
                            {-# LINE 5306 "dist/build/Order" #-}
                            )
                       -- copy rule (down)
                       _hdOo_sem =
                           ({-# LINE 114 "src-ag/Order.ag" #-}
                            _lhsIo_sem
                            {-# LINE 5312 "dist/build/Order" #-}
                            )
                       -- copy rule (down)
                       _hdOo_sig =
                           ({-# LINE 113 "src-ag/Order.ag" #-}
                            _lhsIo_sig
                            {-# LINE 5318 "dist/build/Order" #-}
                            )
                       -- copy rule (down)
                       _hdOo_wantvisit =
                           ({-# LINE 116 "src-ag/Order.ag" #-}
                            _lhsIo_wantvisit
                            {-# LINE 5324 "dist/build/Order" #-}
                            )
                       -- copy rule (down)
                       _hdOprefix =
                           ({-# LINE 119 "src-ag/Order.ag" #-}
                            _lhsIprefix
                            {-# LINE 5330 "dist/build/Order" #-}
                            )
                       -- copy rule (down)
                       _hdOsyn =
                           ({-# LINE 90 "src-ag/Order.ag" #-}
                            _lhsIsyn
                            {-# LINE 5336 "dist/build/Order" #-}
                            )
                       -- copy rule (down)
                       _hdOsynsOfChildren =
                           ({-# LINE 338 "src-ag/Order.ag" #-}
                            _lhsIsynsOfChildren
                            {-# LINE 5342 "dist/build/Order" #-}
                            )
                       -- copy rule (down)
                       _tlOallTypeSigs =
                           ({-# LINE 534 "src-ag/Order.ag" #-}
                            _lhsIallTypeSigs
                            {-# LINE 5348 "dist/build/Order" #-}
                            )
                       -- copy rule (down)
                       _tlOallfields =
                           ({-# LINE 655 "src-ag/Order.ag" #-}
                            _lhsIallfields
                            {-# LINE 5354 "dist/build/Order" #-}
                            )
                       -- copy rule (down)
                       _tlOallnts =
                           ({-# LINE 648 "src-ag/Order.ag" #-}
                            _lhsIallnts
                            {-# LINE 5360 "dist/build/Order" #-}
                            )
                       -- copy rule (down)
                       _tlOaltAttrs =
                           ({-# LINE 187 "src-ag/Order.ag" #-}
                            _lhsIaltAttrs
                            {-# LINE 5366 "dist/build/Order" #-}
                            )
                       -- copy rule (down)
                       _tlOattrs =
                           ({-# LINE 655 "src-ag/Order.ag" #-}
                            _lhsIattrs
                            {-# LINE 5372 "dist/build/Order" #-}
                            )
                       -- copy rule (down)
                       _tlOchildInhs =
                           ({-# LINE 200 "src-ag/Order.ag" #-}
                            _lhsIchildInhs
                            {-# LINE 5378 "dist/build/Order" #-}
                            )
                       -- copy rule (down)
                       _tlOchildNts =
                           ({-# LINE 199 "src-ag/Order.ag" #-}
                            _lhsIchildNts
                            {-# LINE 5384 "dist/build/Order" #-}
                            )
                       -- copy rule (down)
                       _tlOcon =
                           ({-# LINE 91 "src-ag/Order.ag" #-}
                            _lhsIcon
                            {-# LINE 5390 "dist/build/Order" #-}
                            )
                       -- copy rule (down)
                       _tlOinh =
                           ({-# LINE 90 "src-ag/Order.ag" #-}
                            _lhsIinh
                            {-# LINE 5396 "dist/build/Order" #-}
                            )
                       -- copy rule (down)
                       _tlOinhsOfChildren =
                           ({-# LINE 338 "src-ag/Order.ag" #-}
                            _lhsIinhsOfChildren
                            {-# LINE 5402 "dist/build/Order" #-}
                            )
                       -- copy rule (down)
                       _tlOmergeMap =
                           ({-# LINE 361 "src-ag/Order.ag" #-}
                            _lhsImergeMap
                            {-# LINE 5408 "dist/build/Order" #-}
                            )
                       -- copy rule (down)
                       _tlOnt =
                           ({-# LINE 90 "src-ag/Order.ag" #-}
                            _lhsInt
                            {-# LINE 5414 "dist/build/Order" #-}
                            )
                       -- copy rule (down)
                       _tlOo_case =
                           ({-# LINE 118 "src-ag/Order.ag" #-}
                            _lhsIo_case
                            {-# LINE 5420 "dist/build/Order" #-}
                            )
                       -- copy rule (down)
                       _tlOo_cata =
                           ({-# LINE 112 "src-ag/Order.ag" #-}
                            _lhsIo_cata
                            {-# LINE 5426 "dist/build/Order" #-}
                            )
                       -- copy rule (down)
                       _tlOo_dovisit =
                           ({-# LINE 117 "src-ag/Order.ag" #-}
                            _lhsIo_dovisit
                            {-# LINE 5432 "dist/build/Order" #-}
                            )
                       -- copy rule (down)
                       _tlOo_newtypes =
                           ({-# LINE 111 "src-ag/Order.ag" #-}
                            _lhsIo_newtypes
                            {-# LINE 5438 "dist/build/Order" #-}
                            )
                       -- copy rule (down)
                       _tlOo_rename =
                           ({-# LINE 115 "src-ag/Order.ag" #-}
                            _lhsIo_rename
                            {-# LINE 5444 "dist/build/Order" #-}
                            )
                       -- copy rule (down)
                       _tlOo_sem =
                           ({-# LINE 114 "src-ag/Order.ag" #-}
                            _lhsIo_sem
                            {-# LINE 5450 "dist/build/Order" #-}
                            )
                       -- copy rule (down)
                       _tlOo_sig =
                           ({-# LINE 113 "src-ag/Order.ag" #-}
                            _lhsIo_sig
                            {-# LINE 5456 "dist/build/Order" #-}
                            )
                       -- copy rule (down)
                       _tlOo_wantvisit =
                           ({-# LINE 116 "src-ag/Order.ag" #-}
                            _lhsIo_wantvisit
                            {-# LINE 5462 "dist/build/Order" #-}
                            )
                       -- copy rule (down)
                       _tlOprefix =
                           ({-# LINE 119 "src-ag/Order.ag" #-}
                            _lhsIprefix
                            {-# LINE 5468 "dist/build/Order" #-}
                            )
                       -- copy rule (down)
                       _tlOsyn =
                           ({-# LINE 90 "src-ag/Order.ag" #-}
                            _lhsIsyn
                            {-# LINE 5474 "dist/build/Order" #-}
                            )
                       -- copy rule (down)
                       _tlOsynsOfChildren =
                           ({-# LINE 338 "src-ag/Order.ag" #-}
                            _lhsIsynsOfChildren
                            {-# LINE 5480 "dist/build/Order" #-}
                            )
                       ( _hdIdirectDep,_hdIerrors,_hdIgathAltAttrs,_hdIgathRules,_hdIinstDep,_hdIinstVars,_hdIlocVars,_hdInAutoRules,_hdInExplicitRules) =
                           hd_ _hdOallTypeSigs _hdOallfields _hdOallnts _hdOaltAttrs _hdOattrs _hdOchildInhs _hdOchildNts _hdOcon _hdOinh _hdOinhsOfChildren _hdOmergeMap _hdOnt _hdOo_case _hdOo_cata _hdOo_dovisit _hdOo_newtypes _hdOo_rename _hdOo_sem _hdOo_sig _hdOo_wantvisit _hdOprefix _hdOsyn _hdOsynsOfChildren
                       ( _tlIdirectDep,_tlIerrors,_tlIgathAltAttrs,_tlIgathRules,_tlIinstDep,_tlIinstVars,_tlIlocVars,_tlInAutoRules,_tlInExplicitRules) =
                           tl_ _tlOallTypeSigs _tlOallfields _tlOallnts _tlOaltAttrs _tlOattrs _tlOchildInhs _tlOchildNts _tlOcon _tlOinh _tlOinhsOfChildren _tlOmergeMap _tlOnt _tlOo_case _tlOo_cata _tlOo_dovisit _tlOo_newtypes _tlOo_rename _tlOo_sem _tlOo_sig _tlOo_wantvisit _tlOprefix _tlOsyn _tlOsynsOfChildren
                   in  ( _lhsOdirectDep,_lhsOerrors,_lhsOgathAltAttrs,_lhsOgathRules,_lhsOinstDep,_lhsOinstVars,_lhsOlocVars,_lhsOnAutoRules,_lhsOnExplicitRules))))
sem_Rules_Nil :: T_Rules
sem_Rules_Nil =
    (T_Rules (\ _lhsIallTypeSigs
                _lhsIallfields
                _lhsIallnts
                _lhsIaltAttrs
                _lhsIattrs
                _lhsIchildInhs
                _lhsIchildNts
                _lhsIcon
                _lhsIinh
                _lhsIinhsOfChildren
                _lhsImergeMap
                _lhsInt
                _lhsIo_case
                _lhsIo_cata
                _lhsIo_dovisit
                _lhsIo_newtypes
                _lhsIo_rename
                _lhsIo_sem
                _lhsIo_sig
                _lhsIo_wantvisit
                _lhsIprefix
                _lhsIsyn
                _lhsIsynsOfChildren ->
                  (let _lhsOdirectDep :: (Seq Edge)
                       _lhsOerrors :: (Seq Error)
                       _lhsOgathAltAttrs :: ([AltAttr])
                       _lhsOgathRules :: (Seq CRule)
                       _lhsOinstDep :: (Seq Edge)
                       _lhsOinstVars :: ([Identifier])
                       _lhsOlocVars :: ([Identifier])
                       _lhsOnAutoRules :: Int
                       _lhsOnExplicitRules :: Int
                       -- use rule "src-ag/Order.ag"(line 268, column 33)
                       _lhsOdirectDep =
                           ({-# LINE 268 "src-ag/Order.ag" #-}
                            Seq.empty
                            {-# LINE 5525 "dist/build/Order" #-}
                            )
                       -- use rule "src-ag/Order.ag"(line 85, column 70)
                       _lhsOerrors =
                           ({-# LINE 85 "src-ag/Order.ag" #-}
                            Seq.empty
                            {-# LINE 5531 "dist/build/Order" #-}
                            )
                       -- use rule "src-ag/Order.ag"(line 171, column 68)
                       _lhsOgathAltAttrs =
                           ({-# LINE 171 "src-ag/Order.ag" #-}
                            []
                            {-# LINE 5537 "dist/build/Order" #-}
                            )
                       -- use rule "src-ag/Order.ag"(line 207, column 23)
                       _lhsOgathRules =
                           ({-# LINE 207 "src-ag/Order.ag" #-}
                            Seq.empty
                            {-# LINE 5543 "dist/build/Order" #-}
                            )
                       -- use rule "src-ag/Order.ag"(line 311, column 31)
                       _lhsOinstDep =
                           ({-# LINE 311 "src-ag/Order.ag" #-}
                            Seq.empty
                            {-# LINE 5549 "dist/build/Order" #-}
                            )
                       -- use rule "src-ag/Order.ag"(line 678, column 86)
                       _lhsOinstVars =
                           ({-# LINE 678 "src-ag/Order.ag" #-}
                            []
                            {-# LINE 5555 "dist/build/Order" #-}
                            )
                       -- use rule "src-ag/Order.ag"(line 678, column 48)
                       _lhsOlocVars =
                           ({-# LINE 678 "src-ag/Order.ag" #-}
                            []
                            {-# LINE 5561 "dist/build/Order" #-}
                            )
                       -- use rule "src-ag/Order.ag"(line 62, column 105)
                       _lhsOnAutoRules =
                           ({-# LINE 62 "src-ag/Order.ag" #-}
                            0
                            {-# LINE 5567 "dist/build/Order" #-}
                            )
                       -- use rule "src-ag/Order.ag"(line 62, column 105)
                       _lhsOnExplicitRules =
                           ({-# LINE 62 "src-ag/Order.ag" #-}
                            0
                            {-# LINE 5573 "dist/build/Order" #-}
                            )
                   in  ( _lhsOdirectDep,_lhsOerrors,_lhsOgathAltAttrs,_lhsOgathRules,_lhsOinstDep,_lhsOinstVars,_lhsOlocVars,_lhsOnAutoRules,_lhsOnExplicitRules))))
-- TypeSig -----------------------------------------------------
{-
   visit 0:
      chained attribute:
         typeSigs             : Map Identifier Type
   alternatives:
      alternative TypeSig:
         child name           : {Identifier}
         child tp             : {Type}
-}
-- cata
sem_TypeSig :: TypeSig ->
               T_TypeSig
sem_TypeSig (TypeSig _name _tp) =
    (sem_TypeSig_TypeSig _name _tp)
-- semantic domain
newtype T_TypeSig = T_TypeSig ((Map Identifier Type) ->
                               ( (Map Identifier Type)))
data Inh_TypeSig = Inh_TypeSig {typeSigs_Inh_TypeSig :: !((Map Identifier Type))}
data Syn_TypeSig = Syn_TypeSig {typeSigs_Syn_TypeSig :: !((Map Identifier Type))}
wrap_TypeSig :: T_TypeSig ->
                Inh_TypeSig ->
                Syn_TypeSig
wrap_TypeSig (T_TypeSig sem) (Inh_TypeSig _lhsItypeSigs) =
    (let ( _lhsOtypeSigs) = sem _lhsItypeSigs
     in  (Syn_TypeSig _lhsOtypeSigs))
sem_TypeSig_TypeSig :: Identifier ->
                       Type ->
                       T_TypeSig
sem_TypeSig_TypeSig name_ tp_ =
    (T_TypeSig (\ _lhsItypeSigs ->
                    (let _lhsOtypeSigs :: (Map Identifier Type)
                         -- "src-ag/Order.ag"(line 532, column 13)
                         _lhsOtypeSigs =
                             ({-# LINE 532 "src-ag/Order.ag" #-}
                              Map.insert name_ tp_ _lhsItypeSigs
                              {-# LINE 5612 "dist/build/Order" #-}
                              )
                     in  ( _lhsOtypeSigs))))
-- TypeSigs ----------------------------------------------------
{-
   visit 0:
      chained attribute:
         typeSigs             : Map Identifier Type
   alternatives:
      alternative Cons:
         child hd             : TypeSig 
         child tl             : TypeSigs 
      alternative Nil:
-}
-- cata
sem_TypeSigs :: TypeSigs ->
                T_TypeSigs
sem_TypeSigs list =
    (Prelude.foldr sem_TypeSigs_Cons sem_TypeSigs_Nil (Prelude.map sem_TypeSig list))
-- semantic domain
newtype T_TypeSigs = T_TypeSigs ((Map Identifier Type) ->
                                 ( (Map Identifier Type)))
data Inh_TypeSigs = Inh_TypeSigs {typeSigs_Inh_TypeSigs :: !((Map Identifier Type))}
data Syn_TypeSigs = Syn_TypeSigs {typeSigs_Syn_TypeSigs :: !((Map Identifier Type))}
wrap_TypeSigs :: T_TypeSigs ->
                 Inh_TypeSigs ->
                 Syn_TypeSigs
wrap_TypeSigs (T_TypeSigs sem) (Inh_TypeSigs _lhsItypeSigs) =
    (let ( _lhsOtypeSigs) = sem _lhsItypeSigs
     in  (Syn_TypeSigs _lhsOtypeSigs))
sem_TypeSigs_Cons :: T_TypeSig ->
                     T_TypeSigs ->
                     T_TypeSigs
sem_TypeSigs_Cons (T_TypeSig hd_) (T_TypeSigs tl_) =
    (T_TypeSigs (\ _lhsItypeSigs ->
                     (let _lhsOtypeSigs :: (Map Identifier Type)
                          _hdOtypeSigs :: (Map Identifier Type)
                          _tlOtypeSigs :: (Map Identifier Type)
                          _hdItypeSigs :: (Map Identifier Type)
                          _tlItypeSigs :: (Map Identifier Type)
                          -- copy rule (up)
                          _lhsOtypeSigs =
                              ({-# LINE 528 "src-ag/Order.ag" #-}
                               _tlItypeSigs
                               {-# LINE 5656 "dist/build/Order" #-}
                               )
                          -- copy rule (down)
                          _hdOtypeSigs =
                              ({-# LINE 528 "src-ag/Order.ag" #-}
                               _lhsItypeSigs
                               {-# LINE 5662 "dist/build/Order" #-}
                               )
                          -- copy rule (chain)
                          _tlOtypeSigs =
                              ({-# LINE 528 "src-ag/Order.ag" #-}
                               _hdItypeSigs
                               {-# LINE 5668 "dist/build/Order" #-}
                               )
                          ( _hdItypeSigs) =
                              hd_ _hdOtypeSigs
                          ( _tlItypeSigs) =
                              tl_ _tlOtypeSigs
                      in  ( _lhsOtypeSigs))))
sem_TypeSigs_Nil :: T_TypeSigs
sem_TypeSigs_Nil =
    (T_TypeSigs (\ _lhsItypeSigs ->
                     (let _lhsOtypeSigs :: (Map Identifier Type)
                          -- copy rule (chain)
                          _lhsOtypeSigs =
                              ({-# LINE 528 "src-ag/Order.ag" #-}
                               _lhsItypeSigs
                               {-# LINE 5683 "dist/build/Order" #-}
                               )
                      in  ( _lhsOtypeSigs))))