186.77/167.14 MAYBE 188.86/167.78 proof of /export/starexec/sandbox/benchmark/theBenchmark.hs 188.86/167.78 # AProVE Commit ID: 48fb2092695e11cc9f56e44b17a92a5f88ffb256 marcel 20180622 unpublished dirty 188.86/167.78 188.86/167.78 188.86/167.78 H-Termination with start terms of the given HASKELL could not be shown: 188.86/167.78 188.86/167.78 (0) HASKELL 188.86/167.78 (1) LR [EQUIVALENT, 0 ms] 188.86/167.78 (2) HASKELL 188.86/167.78 (3) CR [EQUIVALENT, 0 ms] 188.86/167.78 (4) HASKELL 188.86/167.78 (5) IFR [EQUIVALENT, 0 ms] 188.86/167.78 (6) HASKELL 188.86/167.78 (7) BR [EQUIVALENT, 0 ms] 188.86/167.78 (8) HASKELL 188.86/167.78 (9) COR [EQUIVALENT, 0 ms] 188.86/167.78 (10) HASKELL 188.86/167.78 (11) LetRed [EQUIVALENT, 0 ms] 188.86/167.78 (12) HASKELL 188.86/167.78 (13) NumRed [SOUND, 7 ms] 188.86/167.78 (14) HASKELL 188.86/167.78 188.86/167.78 188.86/167.78 ---------------------------------------- 188.86/167.78 188.86/167.78 (0) 188.86/167.78 Obligation: 188.86/167.78 mainModule Main 188.86/167.78 module Main where { 188.86/167.78 import qualified Prelude; 188.86/167.78 } 188.86/167.78 188.86/167.78 ---------------------------------------- 188.86/167.78 188.86/167.78 (1) LR (EQUIVALENT) 188.86/167.78 Lambda Reductions: 188.86/167.78 The following Lambda expression 188.86/167.78 "\vu54->case vu54 of { 188.86/167.78 (ch,''' : t) -> if ch /= ''' : [] then (''' : ch ++ ''' : [],t) : [] else []; 188.86/167.78 _ -> []} 188.86/167.78 " 188.86/167.78 is transformed to 188.86/167.78 "lex0 vu54 = case vu54 of { 188.86/167.78 (ch,''' : t) -> if ch /= ''' : [] then (''' : ch ++ ''' : [],t) : [] else []; 188.86/167.78 _ -> []} 188.86/167.78 ; 188.86/167.78 " 188.86/167.78 The following Lambda expression 188.86/167.78 "\vu56->case vu56 of { 188.86/167.78 (str,u) -> (ch ++ str,u) : []; 188.86/167.78 _ -> []} 188.86/167.78 " 188.86/167.78 is transformed to 188.86/167.78 "lexString0 ch vu56 = case vu56 of { 188.86/167.78 (str,u) -> (ch ++ str,u) : []; 188.86/167.78 _ -> []} 188.86/167.78 ; 188.86/167.78 " 188.86/167.78 The following Lambda expression 188.86/167.78 "\vu57->case vu57 of { 188.86/167.78 (ch,t) -> concatMap (lexString0 ch) (lexString t); 188.86/167.78 _ -> []} 188.86/167.78 " 188.86/167.78 is transformed to 188.86/167.78 "lexString1 vu57 = case vu57 of { 188.86/167.78 (ch,t) -> concatMap (lexString0 ch) (lexString t); 188.86/167.78 _ -> []} 188.86/167.78 ; 188.86/167.78 " 188.86/167.78 The following Lambda expression 188.86/167.78 "\vu58->case vu58 of { 188.86/167.78 '\' : t -> ([],t) : []; 188.86/167.78 _ -> []} 188.86/167.78 " 188.86/167.78 is transformed to 188.86/167.78 "lexStrItem0 vu58 = case vu58 of { 188.86/167.78 '\' : t -> ([],t) : []; 188.86/167.78 _ -> []} 188.86/167.78 ; 188.86/167.78 " 188.86/167.78 The following Lambda expression 188.86/167.78 "\vu55->case vu55 of { 188.86/167.78 (str,t) -> ('"' : str,t) : []; 188.86/167.78 _ -> []} 188.86/167.78 " 188.86/167.78 is transformed to 188.86/167.78 "lex1 vu55 = case vu55 of { 188.86/167.78 (str,t) -> ('"' : str,t) : []; 188.86/167.78 _ -> []} 188.86/167.78 ; 188.86/167.78 " 188.86/167.78 The following Lambda expression 188.86/167.78 "\vu63->case vu63 of { 188.86/167.78 (e,u) -> ('.' : ds ++ e,u) : []; 188.86/167.78 _ -> []} 188.86/167.78 " 188.86/167.78 is transformed to 188.86/167.78 "lexFracExp0 ds vu63 = case vu63 of { 188.86/167.78 (e,u) -> ('.' : ds ++ e,u) : []; 188.86/167.78 _ -> []} 188.86/167.78 ; 188.86/167.78 " 188.86/167.78 The following Lambda expression 188.86/167.78 "\vu64->case vu64 of { 188.86/167.78 (ds,t) -> concatMap (lexFracExp0 ds) (lexExp t); 188.86/167.78 _ -> []} 188.86/167.78 " 188.86/167.78 is transformed to 188.86/167.78 "lexFracExp1 vu64 = case vu64 of { 188.86/167.78 (ds,t) -> concatMap (lexFracExp0 ds) (lexExp t); 188.86/167.78 _ -> []} 188.86/167.78 ; 188.86/167.78 " 188.86/167.78 The following Lambda expression 188.86/167.78 "\vu65->case vu65 of { 188.86/167.78 (ds,u) -> (e : c : ds,u) : []; 188.86/167.78 _ -> []} 188.86/167.78 " 188.86/167.78 is transformed to 188.86/167.78 "lexExp0 e c vu65 = case vu65 of { 188.86/167.78 (ds,u) -> (e : c : ds,u) : []; 188.86/167.78 _ -> []} 188.86/167.78 ; 188.86/167.78 " 188.86/167.78 The following Lambda expression 188.86/167.78 "\vu66->case vu66 of { 188.86/167.78 c : t -> if c `elem` '+' : '-' : [] then concatMap (lexExp0 e c) (lexDigits t) else []; 188.86/167.78 _ -> []} 188.86/167.78 " 188.86/167.78 is transformed to 188.86/167.78 "lexExp1 e vu66 = case vu66 of { 188.86/167.78 c : t -> if c `elem` '+' : '-' : [] then concatMap (lexExp0 e c) (lexDigits t) else []; 188.86/167.78 _ -> []} 188.86/167.78 ; 188.86/167.78 " 188.86/167.78 The following Lambda expression 188.86/167.78 "\vu67->case vu67 of { 188.86/167.78 (ds,t) -> (e : ds,t) : []; 188.86/167.78 _ -> []} 188.86/167.78 " 188.86/167.78 is transformed to 188.86/167.78 "lexExp2 e vu67 = case vu67 of { 188.86/167.78 (ds,t) -> (e : ds,t) : []; 188.86/167.78 _ -> []} 188.86/167.78 ; 188.86/167.78 " 188.86/167.78 The following Lambda expression 188.86/167.78 "\vu59->case vu59 of { 188.86/167.78 (sym,t) -> (c : sym,t) : []; 188.86/167.78 _ -> []} 188.86/167.78 " 188.86/167.78 is transformed to 188.86/167.78 "lex2 c vu59 = case vu59 of { 188.86/167.78 (sym,t) -> (c : sym,t) : []; 188.86/167.78 _ -> []} 188.86/167.78 ; 188.86/167.78 " 188.86/167.78 The following Lambda expression 188.86/167.78 "\vu60->case vu60 of { 188.86/167.78 (nam,t) -> (c : nam,t) : []; 188.86/167.78 _ -> []} 188.86/167.78 " 188.86/167.78 is transformed to 188.86/167.78 "lex3 c vu60 = case vu60 of { 188.86/167.78 (nam,t) -> (c : nam,t) : []; 188.86/167.78 _ -> []} 188.86/167.78 ; 188.86/167.78 " 188.86/167.78 The following Lambda expression 188.86/167.78 "\vu61->case vu61 of { 188.86/167.78 (fe,t) -> (c : ds ++ fe,t) : []; 188.86/167.78 _ -> []} 188.86/167.78 " 188.86/167.78 is transformed to 188.86/167.78 "lex4 c ds vu61 = case vu61 of { 188.86/167.78 (fe,t) -> (c : ds ++ fe,t) : []; 188.86/167.78 _ -> []} 188.86/167.78 ; 188.86/167.78 " 188.86/167.78 The following Lambda expression 188.86/167.78 "\vu62->case vu62 of { 188.86/167.78 (ds,s) -> concatMap (lex4 c ds) (lexFracExp s); 188.86/167.78 _ -> []} 188.86/167.78 " 188.86/167.78 is transformed to 188.86/167.78 "lex5 c vu62 = case vu62 of { 188.86/167.78 (ds,s) -> concatMap (lex4 c ds) (lexFracExp s); 188.86/167.78 _ -> []} 188.86/167.78 ; 188.86/167.78 " 188.86/167.78 The following Lambda expression 188.86/167.78 "\ab->(a,b)" 188.86/167.78 is transformed to 188.86/167.78 "zip0 a b = (a,b); 188.86/167.78 " 188.86/167.78 The following Lambda expression 188.86/167.78 "\vu68->case vu68 of { 188.86/167.78 (cs@(_ : _),t) -> (cs,t) : []; 188.86/167.78 _ -> []} 188.86/167.78 " 188.86/167.78 is transformed to 188.86/167.78 "nonnull0 vu68 = case vu68 of { 188.86/167.78 (cs@(_ : _),t) -> (cs,t) : []; 188.86/167.78 _ -> []} 188.86/167.78 ; 188.86/167.78 " 188.86/167.78 The following Lambda expression 188.86/167.78 "\vu48->case vu48 of { 188.86/167.78 (')' : [],u) -> (x,u) : []; 188.86/167.78 _ -> []} 188.86/167.78 " 188.86/167.78 is transformed to 188.86/167.78 "mandatory0 x vu48 = case vu48 of { 188.86/167.78 (')' : [],u) -> (x,u) : []; 188.86/167.78 _ -> []} 188.86/167.78 ; 188.86/167.78 " 188.86/167.78 The following Lambda expression 188.86/167.78 "\vu49->case vu49 of { 188.86/167.78 (x,t) -> concatMap (mandatory0 x) (lex t); 188.86/167.78 _ -> []} 188.86/167.78 " 188.86/167.78 is transformed to 188.86/167.78 "mandatory1 vu49 = case vu49 of { 188.86/167.78 (x,t) -> concatMap (mandatory0 x) (lex t); 188.86/167.78 _ -> []} 188.86/167.78 ; 188.86/167.78 " 188.86/167.78 The following Lambda expression 188.86/167.78 "\vu50->case vu50 of { 188.86/167.78 ('(' : [],s) -> concatMap mandatory1 (optional s); 188.86/167.78 _ -> []} 188.86/167.78 " 188.86/167.78 is transformed to 188.86/167.78 "mandatory2 vu50 = case vu50 of { 188.86/167.78 ('(' : [],s) -> concatMap mandatory1 (optional s); 188.86/167.78 _ -> []} 188.86/167.78 ; 188.86/167.78 " 188.86/167.78 The following Lambda expression 188.86/167.78 "\vu69->case vu69 of { 188.86/167.78 ([],s') -> (mne,s') : []; 188.86/167.78 _ -> []} 188.86/167.78 " 188.86/167.78 is transformed to 188.86/167.78 "lexEsc0 mne vu69 = case vu69 of { 188.86/167.78 ([],s') -> (mne,s') : []; 188.86/167.78 _ -> []} 188.86/167.78 ; 188.86/167.78 " 188.86/167.78 The following Lambda expression 188.86/167.78 "\vu70->case vu70 of { 188.86/167.78 (c,mne) -> concatMap (lexEsc0 mne) (lexmatch mne s : []); 188.86/167.78 _ -> []} 188.86/167.78 " 188.86/167.78 is transformed to 188.86/167.78 "lexEsc1 s vu70 = case vu70 of { 188.86/167.78 (c,mne) -> concatMap (lexEsc0 mne) (lexmatch mne s : []); 188.86/167.78 _ -> []} 188.86/167.78 ; 188.86/167.78 " 188.86/167.78 The following Lambda expression 188.86/167.78 "\(_,zs)->zs" 188.86/167.78 is transformed to 188.86/167.78 "zs0 (_,zs) = zs; 188.86/167.78 " 188.86/167.78 The following Lambda expression 188.86/167.78 "\(ys,_)->ys" 188.86/167.78 is transformed to 188.86/167.78 "ys0 (ys,_) = ys; 188.86/167.78 " 188.86/167.78 188.86/167.78 ---------------------------------------- 188.86/167.78 188.86/167.78 (2) 188.86/167.78 Obligation: 188.86/167.78 mainModule Main 188.86/167.78 module Main where { 188.86/167.78 import qualified Prelude; 188.86/167.78 } 188.86/167.78 188.86/167.78 ---------------------------------------- 188.86/167.78 188.86/167.78 (3) CR (EQUIVALENT) 188.86/167.78 Case Reductions: 188.86/167.78 The following Case expression 188.86/167.78 "case vu55 of { 188.86/167.78 (str,t) -> ('"' : str,t) : []; 188.86/167.78 _ -> []} 188.86/167.78 " 188.86/167.78 is transformed to 188.86/167.78 "lex10 (str,t) = ('"' : str,t) : []; 188.86/167.78 lex10 _ = []; 188.86/167.78 " 188.86/167.78 The following Case expression 188.86/167.78 "case vu57 of { 188.86/167.78 (ch,t) -> concatMap (lexString0 ch) (lexString t); 188.86/167.78 _ -> []} 188.86/167.78 " 188.86/167.78 is transformed to 188.86/167.78 "lexString10 (ch,t) = concatMap (lexString0 ch) (lexString t); 188.86/167.78 lexString10 _ = []; 188.86/167.78 " 188.86/167.78 The following Case expression 188.86/167.78 "case vu56 of { 188.86/167.78 (str,u) -> (ch ++ str,u) : []; 188.86/167.78 _ -> []} 188.86/167.78 " 188.86/167.78 is transformed to 188.86/167.78 "lexString00 ch (str,u) = (ch ++ str,u) : []; 188.86/167.78 lexString00 ch _ = []; 188.86/167.78 " 188.86/167.78 The following Case expression 188.86/167.78 "case vu58 of { 188.86/167.78 '\' : t -> ([],t) : []; 188.86/167.78 _ -> []} 188.86/167.78 " 188.86/167.78 is transformed to 188.86/167.78 "lexStrItem00 ('\' : t) = ([],t) : []; 188.86/167.78 lexStrItem00 _ = []; 188.86/167.78 " 188.86/167.78 The following Case expression 188.86/167.78 "case vu59 of { 188.86/167.78 (sym,t) -> (c : sym,t) : []; 188.86/167.78 _ -> []} 188.86/167.78 " 188.86/167.78 is transformed to 188.86/167.78 "lex20 c (sym,t) = (c : sym,t) : []; 188.86/167.78 lex20 c _ = []; 188.86/167.78 " 188.86/167.78 The following Case expression 188.86/167.78 "case vu67 of { 188.86/167.78 (ds,t) -> (e : ds,t) : []; 188.86/167.78 _ -> []} 188.86/167.78 " 188.86/167.78 is transformed to 188.86/167.78 "lexExp20 e (ds,t) = (e : ds,t) : []; 188.86/167.78 lexExp20 e _ = []; 188.86/167.78 " 188.86/167.78 The following Case expression 188.86/167.78 "case vu65 of { 188.86/167.78 (ds,u) -> (e : c : ds,u) : []; 188.86/167.78 _ -> []} 188.86/167.78 " 188.86/167.78 is transformed to 188.86/167.78 "lexExp00 e c (ds,u) = (e : c : ds,u) : []; 188.86/167.78 lexExp00 e c _ = []; 188.86/167.78 " 188.86/167.78 The following Case expression 188.86/167.78 "case vu62 of { 188.86/167.78 (ds,s) -> concatMap (lex4 c ds) (lexFracExp s); 188.86/167.78 _ -> []} 188.86/167.78 " 188.86/167.78 is transformed to 188.86/167.78 "lex50 c (ds,s) = concatMap (lex4 c ds) (lexFracExp s); 188.86/167.78 lex50 c _ = []; 188.86/167.78 " 188.86/167.78 The following Case expression 188.86/167.78 "case vu66 of { 188.86/167.78 c : t -> if c `elem` '+' : '-' : [] then concatMap (lexExp0 e c) (lexDigits t) else []; 188.86/167.78 _ -> []} 188.86/167.78 " 188.86/167.78 is transformed to 188.86/167.78 "lexExp10 e (c : t) = if c `elem` '+' : '-' : [] then concatMap (lexExp0 e c) (lexDigits t) else []; 188.86/167.78 lexExp10 e _ = []; 188.86/167.78 " 188.86/167.78 The following Case expression 188.86/167.78 "case vu60 of { 188.86/167.78 (nam,t) -> (c : nam,t) : []; 188.86/167.78 _ -> []} 188.86/167.78 " 188.86/167.78 is transformed to 188.86/167.78 "lex30 c (nam,t) = (c : nam,t) : []; 188.86/167.78 lex30 c _ = []; 188.86/167.78 " 188.86/167.78 The following Case expression 188.86/167.78 "case vu61 of { 188.86/167.78 (fe,t) -> (c : ds ++ fe,t) : []; 188.86/167.78 _ -> []} 188.86/167.78 " 188.86/167.78 is transformed to 188.86/167.78 "lex40 c ds (fe,t) = (c : ds ++ fe,t) : []; 188.86/167.78 lex40 c ds _ = []; 188.86/167.78 " 188.86/167.78 The following Case expression 188.86/167.78 "case vu63 of { 188.86/167.78 (e,u) -> ('.' : ds ++ e,u) : []; 188.86/167.78 _ -> []} 188.86/167.78 " 188.86/167.78 is transformed to 188.86/167.78 "lexFracExp00 ds (e,u) = ('.' : ds ++ e,u) : []; 188.86/167.78 lexFracExp00 ds _ = []; 188.86/167.78 " 188.86/167.78 The following Case expression 188.86/167.78 "case vu64 of { 188.86/167.78 (ds,t) -> concatMap (lexFracExp0 ds) (lexExp t); 188.86/167.78 _ -> []} 188.86/167.78 " 188.86/167.78 is transformed to 188.86/167.78 "lexFracExp10 (ds,t) = concatMap (lexFracExp0 ds) (lexExp t); 188.86/167.78 lexFracExp10 _ = []; 188.86/167.78 " 188.86/167.78 The following Case expression 188.86/167.78 "case vu54 of { 188.86/167.78 (ch,''' : t) -> if ch /= ''' : [] then (''' : ch ++ ''' : [],t) : [] else []; 188.86/167.78 _ -> []} 188.86/167.78 " 188.86/167.78 is transformed to 188.86/167.78 "lex00 (ch,''' : t) = if ch /= ''' : [] then (''' : ch ++ ''' : [],t) : [] else []; 188.86/167.78 lex00 _ = []; 188.86/167.78 " 188.86/167.78 The following Case expression 188.86/167.79 "case vu48 of { 188.86/167.79 (')' : [],u) -> (x,u) : []; 188.86/167.79 _ -> []} 188.86/167.79 " 188.86/167.79 is transformed to 188.86/167.79 "mandatory00 x (')' : [],u) = (x,u) : []; 188.86/167.79 mandatory00 x _ = []; 188.86/167.79 " 188.86/167.79 The following Case expression 188.86/167.79 "case vu49 of { 188.86/167.79 (x,t) -> concatMap (mandatory0 x) (lex t); 188.86/167.79 _ -> []} 188.86/167.79 " 188.86/167.79 is transformed to 188.86/167.79 "mandatory10 (x,t) = concatMap (mandatory0 x) (lex t); 188.86/167.79 mandatory10 _ = []; 188.86/167.79 " 188.86/167.79 The following Case expression 188.86/167.79 "case vu50 of { 188.86/167.79 ('(' : [],s) -> concatMap mandatory1 (optional s); 188.86/167.79 _ -> []} 188.86/167.79 " 188.86/167.79 is transformed to 188.86/167.79 "mandatory20 ('(' : [],s) = concatMap mandatory1 (optional s); 188.86/167.79 mandatory20 _ = []; 188.86/167.79 " 188.86/167.79 The following Case expression 188.86/167.79 "case vu68 of { 188.86/167.79 (cs@(_ : _),t) -> (cs,t) : []; 188.86/167.79 _ -> []} 188.86/167.79 " 188.86/167.79 is transformed to 188.86/167.79 "nonnull00 (cs@(_ : _),t) = (cs,t) : []; 188.86/167.79 nonnull00 _ = []; 188.86/167.79 " 188.86/167.79 The following Case expression 188.86/167.79 "case concatMap (lexEsc1 s) table of { 188.86/167.79 pr : _ -> pr : []; 188.86/167.79 [] -> []} 188.86/167.79 " 188.86/167.79 is transformed to 188.86/167.79 "lexEsc2 (pr : _) = pr : []; 188.86/167.79 lexEsc2 [] = []; 188.86/167.79 " 188.86/167.79 The following Case expression 188.86/167.79 "case vu69 of { 188.86/167.79 ([],s') -> (mne,s') : []; 188.86/167.79 _ -> []} 188.86/167.79 " 188.86/167.79 is transformed to 188.86/167.79 "lexEsc00 mne ([],s') = (mne,s') : []; 188.86/167.79 lexEsc00 mne _ = []; 188.86/167.79 " 188.86/167.79 The following Case expression 188.86/167.79 "case vu70 of { 188.86/167.79 (c,mne) -> concatMap (lexEsc0 mne) (lexmatch mne s : []); 188.86/167.79 _ -> []} 188.86/167.79 " 188.86/167.79 is transformed to 188.86/167.79 "lexEsc10 s (c,mne) = concatMap (lexEsc0 mne) (lexmatch mne s : []); 188.86/167.79 lexEsc10 s _ = []; 188.86/167.79 " 188.86/167.79 188.86/167.79 ---------------------------------------- 188.86/167.79 188.86/167.79 (4) 188.86/167.79 Obligation: 188.86/167.79 mainModule Main 188.86/167.79 module Main where { 188.86/167.79 import qualified Prelude; 188.86/167.79 } 188.86/167.79 188.86/167.79 ---------------------------------------- 188.86/167.79 188.86/167.79 (5) IFR (EQUIVALENT) 188.86/167.79 If Reductions: 188.86/167.79 The following If expression 188.86/167.79 "if c `elem` '+' : '-' : [] then concatMap (lexExp0 e c) (lexDigits t) else []" 188.86/167.79 is transformed to 188.86/167.79 "lexExp100 e c t True = concatMap (lexExp0 e c) (lexDigits t); 188.86/167.79 lexExp100 e c t False = []; 188.86/167.79 " 188.86/167.79 The following If expression 188.86/167.79 "if b then mandatory else optional" 188.86/167.79 is transformed to 188.86/167.79 "readParen0 True = mandatory; 188.86/167.79 readParen0 False = optional; 188.86/167.79 " 188.86/167.79 The following If expression 188.86/167.79 "if ch /= ''' : [] then (''' : ch ++ ''' : [],t) : [] else []" 188.86/167.79 is transformed to 188.86/167.79 "lex000 ch t True = (''' : ch ++ ''' : [],t) : []; 188.86/167.79 lex000 ch t False = []; 188.86/167.79 " 188.86/167.79 188.86/167.79 ---------------------------------------- 188.86/167.79 188.86/167.79 (6) 188.86/167.79 Obligation: 188.86/167.79 mainModule Main 188.86/167.79 module Main where { 188.86/167.79 import qualified Prelude; 188.86/167.79 } 188.86/167.79 188.86/167.79 ---------------------------------------- 188.86/167.79 188.86/167.79 (7) BR (EQUIVALENT) 188.86/167.79 Replaced joker patterns by fresh variables and removed binding patterns. 188.86/167.79 188.86/167.79 Binding Reductions: 188.86/167.79 The bind variable of the following binding Pattern 188.86/167.79 "cs@(wu : wv)" 188.86/167.79 is replaced by the following term 188.86/167.79 "wu : wv" 188.86/167.79 The bind variable of the following binding Pattern 188.86/167.79 "xs@(zz : vuu)" 188.86/167.79 is replaced by the following term 188.86/167.79 "zz : vuu" 188.86/167.79 The bind variable of the following binding Pattern 188.86/167.79 "s@(vux : vuy)" 188.86/167.79 is replaced by the following term 188.86/167.79 "vux : vuy" 188.86/167.79 The bind variable of the following binding Pattern 188.86/167.79 "xs@(vvx : vvy)" 188.86/167.79 is replaced by the following term 188.86/167.79 "vvx : vvy" 188.86/167.79 188.86/167.79 ---------------------------------------- 188.86/167.79 188.86/167.79 (8) 188.86/167.79 Obligation: 188.86/167.79 mainModule Main 188.86/167.79 module Main where { 188.86/167.79 import qualified Prelude; 188.86/167.79 } 188.86/167.79 188.86/167.79 ---------------------------------------- 188.86/167.79 188.86/167.79 (9) COR (EQUIVALENT) 188.86/167.79 Cond Reductions: 188.86/167.79 The following Function with conditions 188.86/167.79 "takeWhile p [] = []; 188.86/167.79 takeWhile p (x : xs)|p xx : takeWhile p xs|otherwise[]; 188.86/167.79 " 188.86/167.79 is transformed to 188.86/167.79 "takeWhile p [] = takeWhile3 p []; 188.86/167.79 takeWhile p (x : xs) = takeWhile2 p (x : xs); 188.86/167.79 " 188.86/167.79 "takeWhile1 p x xs True = x : takeWhile p xs; 188.86/167.79 takeWhile1 p x xs False = takeWhile0 p x xs otherwise; 188.86/167.79 " 188.86/167.79 "takeWhile0 p x xs True = []; 188.86/167.79 " 188.86/167.79 "takeWhile2 p (x : xs) = takeWhile1 p x xs (p x); 188.86/167.79 " 188.86/167.79 "takeWhile3 p [] = []; 188.86/167.79 takeWhile3 vwx vwy = takeWhile2 vwx vwy; 188.86/167.79 " 188.86/167.79 The following Function with conditions 188.86/167.79 "lexString ('"' : s) = ('"' : [],s) : []; 188.86/167.79 lexString s = concatMap lexString1 (lexStrItem s); 188.86/167.79 " 188.86/167.79 is transformed to 188.86/167.79 "lexString (vxu : s) = lexString4 (vxu : s); 188.86/167.79 lexString s = lexString2 s; 188.86/167.79 " 188.86/167.79 "lexString2 s = concatMap lexString1 (lexStrItem s); 188.86/167.79 " 188.86/167.79 "lexString3 True (vxu : s) = ('"' : [],s) : []; 188.86/167.79 lexString3 vxv vxw = lexString2 vxw; 188.86/167.79 " 188.86/167.79 "lexString4 (vxu : s) = lexString3 (vxu == '"') (vxu : s); 188.86/167.79 lexString4 vxx = lexString2 vxx; 188.86/167.79 " 188.86/167.79 The following Function with conditions 188.86/167.79 "lexStrItem ('\' : '&' : s) = ('\' : '&' : [],s) : []; 188.86/167.79 lexStrItem ('\' : c : s)|isSpace cconcatMap lexStrItem0 (dropWhile isSpace s : []); 188.86/167.79 lexStrItem s = lexLitChar s; 188.86/167.79 " 188.86/167.79 is transformed to 188.86/167.79 "lexStrItem (vzv : vzz) = lexStrItem7 (vzv : vzz); 188.86/167.79 lexStrItem (vxz : vyw) = lexStrItem4 (vxz : vyw); 188.86/167.79 lexStrItem s = lexStrItem1 s; 188.86/167.79 " 188.86/167.79 "lexStrItem1 s = lexLitChar s; 188.86/167.79 " 188.86/167.79 "lexStrItem2 vxz c s True = concatMap lexStrItem0 (dropWhile isSpace s : []); 188.86/167.79 lexStrItem2 vxz c s False = lexStrItem1 (vxz : c : s); 188.86/167.79 " 188.86/167.79 "lexStrItem3 True (vxz : c : s) = lexStrItem2 vxz c s (isSpace c); 188.86/167.79 lexStrItem3 vyx vyy = lexStrItem1 vyy; 188.86/167.79 " 188.86/167.79 "lexStrItem4 (vxz : vyw) = lexStrItem3 (vxz == '\') (vxz : vyw); 188.86/167.79 lexStrItem4 vyz = lexStrItem1 vyz; 188.86/167.79 " 188.86/167.79 "lexStrItem5 True (vzv : vzx : s) = ('\' : '&' : [],s) : []; 188.86/167.79 lexStrItem5 wuu wuv = lexStrItem4 wuv; 188.86/167.79 " 188.86/167.79 "lexStrItem6 True (vzv : vzx : s) = lexStrItem5 (vzx == '&') (vzv : vzx : s); 188.86/167.79 lexStrItem6 wuw wux = lexStrItem4 wux; 188.86/167.79 " 188.86/167.79 "lexStrItem7 (vzv : vzz) = lexStrItem6 (vzv == '\') (vzv : vzz); 188.86/167.79 lexStrItem7 wuy = lexStrItem4 wuy; 188.86/167.79 " 188.86/167.79 The following Function with conditions 188.86/167.79 "lexStrItem00 ('\' : t) = ([],t) : []; 188.86/167.79 lexStrItem00 wz = []; 188.86/167.79 " 188.86/167.79 is transformed to 188.86/167.79 "lexStrItem00 (wvu : t) = lexStrItem002 (wvu : t); 188.86/167.79 lexStrItem00 wz = lexStrItem000 wz; 188.86/167.79 " 188.86/167.79 "lexStrItem000 wz = []; 188.86/167.79 " 188.86/167.79 "lexStrItem001 True (wvu : t) = ([],t) : []; 188.86/167.79 lexStrItem001 wvv wvw = lexStrItem000 wvw; 188.86/167.79 " 188.86/167.79 "lexStrItem002 (wvu : t) = lexStrItem001 (wvu == '\') (wvu : t); 188.86/167.79 lexStrItem002 wvx = lexStrItem000 wvx; 188.86/167.79 " 188.86/167.79 The following Function with conditions 188.86/167.79 "lexExp (e : s)|e `elem` 'e' : 'E' : []concatMap (lexExp1 e) (s : []) ++ concatMap (lexExp2 e) (lexDigits s); 188.86/167.79 lexExp s = ([],s) : []; 188.86/167.79 " 188.86/167.79 is transformed to 188.86/167.79 "lexExp (e : s) = lexExp5 (e : s); 188.86/167.79 lexExp s = lexExp3 s; 188.86/167.79 " 188.86/167.79 "lexExp3 s = ([],s) : []; 188.86/167.79 " 188.86/167.79 "lexExp4 e s True = concatMap (lexExp1 e) (s : []) ++ concatMap (lexExp2 e) (lexDigits s); 188.86/167.79 lexExp4 e s False = lexExp3 (e : s); 188.86/167.79 " 188.86/167.79 "lexExp5 (e : s) = lexExp4 e s (e `elem` 'e' : 'E' : []); 188.86/167.79 lexExp5 wvz = lexExp3 wvz; 188.86/167.79 " 188.86/167.79 The following Function with conditions 188.86/167.79 "lexFracExp ('.' : c : cs)|isDigit cconcatMap lexFracExp1 (lexDigits (c : cs)); 188.86/167.79 lexFracExp s = lexExp s; 188.86/167.79 " 188.86/167.79 is transformed to 188.86/167.79 "lexFracExp (wwv : wwy) = lexFracExp5 (wwv : wwy); 188.86/167.79 lexFracExp s = lexFracExp2 s; 188.86/167.79 " 188.86/167.79 "lexFracExp2 s = lexExp s; 188.86/167.79 " 188.86/167.79 "lexFracExp3 wwv c cs True = concatMap lexFracExp1 (lexDigits (c : cs)); 188.86/167.79 lexFracExp3 wwv c cs False = lexFracExp2 (wwv : c : cs); 188.86/167.79 " 188.86/167.79 "lexFracExp4 True (wwv : c : cs) = lexFracExp3 wwv c cs (isDigit c); 188.86/167.79 lexFracExp4 wwz wxu = lexFracExp2 wxu; 188.86/167.79 " 188.86/167.79 "lexFracExp5 (wwv : wwy) = lexFracExp4 (wwv == '.') (wwv : wwy); 188.86/167.79 lexFracExp5 wxv = lexFracExp2 wxv; 188.86/167.79 " 188.86/167.79 The following Function with conditions 188.86/167.79 "lex [] = ([],[]) : []; 188.86/167.79 lex (c : s)|isSpace clex (dropWhile isSpace s); 188.86/167.79 lex (''' : s) = concatMap lex0 (lexLitChar s); 188.86/167.79 lex ('"' : s) = concatMap lex1 (lexString s) where { 188.86/167.79 lex1 vu55 = lex10 vu55; 188.86/167.79 ; 188.86/167.79 lex10 (str,t) = ('"' : str,t) : []; 188.86/167.79 lex10 xu = []; 188.86/167.79 ; 188.86/167.79 lexStrItem ('\' : '&' : s) = ('\' : '&' : [],s) : []; 188.86/167.79 lexStrItem ('\' : c : s)|isSpace cconcatMap lexStrItem0 (dropWhile isSpace s : []); 188.86/167.79 lexStrItem s = lexLitChar s; 188.86/167.79 ; 188.86/167.79 lexStrItem0 vu58 = lexStrItem00 vu58; 188.86/167.79 ; 188.86/167.79 lexStrItem00 ('\' : t) = ([],t) : []; 188.86/167.79 lexStrItem00 wz = []; 188.86/167.79 ; 188.86/167.79 lexString ('"' : s) = ('"' : [],s) : []; 188.86/167.79 lexString s = concatMap lexString1 (lexStrItem s); 188.86/167.79 ; 188.86/167.79 lexString0 ch vu56 = lexString00 ch vu56; 188.86/167.79 ; 188.86/167.79 lexString00 ch (str,u) = (ch ++ str,u) : []; 188.86/167.79 lexString00 ch wx = []; 188.86/167.79 ; 188.86/167.79 lexString1 vu57 = lexString10 vu57; 188.86/167.79 ; 188.86/167.79 lexString10 (ch,t) = concatMap (lexString0 ch) (lexString t); 188.86/167.79 lexString10 wy = []; 188.86/167.79 } 188.86/167.79 ; 188.86/167.79 lex (c : s)|isSingle c(c : [],s) : []|isSym cconcatMap (lex2 c) (span isSym s : [])|isAlpha cconcatMap (lex3 c) (span isIdChar s : [])|isDigit cconcatMap (lex5 c) (span isDigit s : [])|otherwise[] where { 188.86/167.79 isIdChar c = isAlphaNum c || c `elem` '_' : ''' : []; 188.86/167.79 ; 188.86/167.79 isSingle c = c `elem` ',' : ';' : '(' : ')' : '[' : ']' : '{' : '}' : '_' : '`' : []; 188.86/167.79 ; 188.86/167.79 isSym c = c `elem` '!' : '@' : '#' : '$' : '%' : '&' : '*' : '+' : '.' : '/' : '<' : '=' : '>' : '?' : '\' : '^' : '|' : ':' : '-' : '~' : []; 188.86/167.79 ; 188.86/167.79 lex2 c vu59 = lex20 c vu59; 188.86/167.79 ; 188.86/167.79 lex20 c (sym,t) = (c : sym,t) : []; 188.86/167.79 lex20 c yw = []; 188.86/167.79 ; 188.86/167.79 lex3 c vu60 = lex30 c vu60; 188.86/167.79 ; 188.86/167.79 lex30 c (nam,t) = (c : nam,t) : []; 188.86/167.79 lex30 c yx = []; 188.86/167.79 ; 188.86/167.79 lex4 c ds vu61 = lex40 c ds vu61; 188.86/167.79 ; 188.86/167.79 lex40 c ds (fe,t) = (c : ds ++ fe,t) : []; 188.86/167.79 lex40 c ds yu = []; 188.86/167.80 ; 188.86/167.80 lex5 c vu62 = lex50 c vu62; 188.86/167.80 ; 188.86/167.80 lex50 c (ds,s) = concatMap (lex4 c ds) (lexFracExp s); 188.86/167.80 lex50 c yv = []; 188.86/167.80 ; 188.86/167.80 lexExp (e : s)|e `elem` 'e' : 'E' : []concatMap (lexExp1 e) (s : []) ++ concatMap (lexExp2 e) (lexDigits s); 188.86/167.80 lexExp s = ([],s) : []; 188.86/167.80 ; 188.86/167.80 lexExp0 e c vu65 = lexExp00 e c vu65; 188.86/167.80 ; 188.86/167.80 lexExp00 e c (ds,u) = (e : c : ds,u) : []; 188.86/167.80 lexExp00 e c xv = []; 188.86/167.80 ; 188.86/167.80 lexExp1 e vu66 = lexExp10 e vu66; 188.86/167.80 ; 188.86/167.80 lexExp10 e (c : t) = lexExp100 e c t (c `elem` '+' : '-' : []); 188.86/167.80 lexExp10 e xx = []; 188.86/167.80 ; 188.86/167.80 lexExp100 e c t True = concatMap (lexExp0 e c) (lexDigits t); 188.86/167.80 lexExp100 e c t False = []; 188.86/167.80 ; 188.86/167.80 lexExp2 e vu67 = lexExp20 e vu67; 188.86/167.80 ; 188.86/167.80 lexExp20 e (ds,t) = (e : ds,t) : []; 188.86/167.80 lexExp20 e xw = []; 188.86/167.80 ; 188.86/167.80 lexFracExp ('.' : c : cs)|isDigit cconcatMap lexFracExp1 (lexDigits (c : cs)); 188.86/167.80 lexFracExp s = lexExp s; 188.86/167.80 ; 188.86/167.80 lexFracExp0 ds vu63 = lexFracExp00 ds vu63; 188.86/167.80 ; 188.86/167.80 lexFracExp00 ds (e,u) = ('.' : ds ++ e,u) : []; 188.86/167.80 lexFracExp00 ds xz = []; 188.86/167.80 ; 188.86/167.80 lexFracExp1 vu64 = lexFracExp10 vu64; 188.86/167.80 ; 188.86/167.80 lexFracExp10 (ds,t) = concatMap (lexFracExp0 ds) (lexExp t); 188.86/167.80 lexFracExp10 xy = []; 188.86/167.80 } 188.86/167.80 ; 188.86/167.80 " 188.86/167.80 is transformed to 188.86/167.80 "lex [] = lex19 []; 188.86/167.80 lex (c : s) = lex18 (c : s); 188.86/167.80 lex (wyx : s) = lex16 (wyx : s); 188.86/167.80 lex (wxy : s) = lex14 (wxy : s); 188.86/167.80 lex (c : s) = lex12 (c : s); 188.86/167.80 " 188.86/167.80 "lex12 (c : s) = lex11 c s (isSingle c) where { 188.86/167.80 isIdChar c = isAlphaNum c || c `elem` '_' : ''' : []; 188.86/167.80 ; 188.86/167.80 isSingle c = c `elem` ',' : ';' : '(' : ')' : '[' : ']' : '{' : '}' : '_' : '`' : []; 188.86/167.80 ; 188.86/167.80 isSym c = c `elem` '!' : '@' : '#' : '$' : '%' : '&' : '*' : '+' : '.' : '/' : '<' : '=' : '>' : '?' : '\' : '^' : '|' : ':' : '-' : '~' : []; 188.86/167.80 ; 188.86/167.80 lex11 c s True = (c : [],s) : []; 188.86/167.80 lex11 c s False = lex9 c s (isSym c); 188.86/167.80 ; 188.86/167.80 lex2 c vu59 = lex20 c vu59; 188.86/167.80 ; 188.86/167.80 lex20 c (sym,t) = (c : sym,t) : []; 188.86/167.80 lex20 c yw = []; 188.86/167.80 ; 188.86/167.80 lex3 c vu60 = lex30 c vu60; 188.86/167.80 ; 188.86/167.80 lex30 c (nam,t) = (c : nam,t) : []; 188.86/167.80 lex30 c yx = []; 188.86/167.80 ; 188.86/167.80 lex4 c ds vu61 = lex40 c ds vu61; 188.86/167.80 ; 188.86/167.80 lex40 c ds (fe,t) = (c : ds ++ fe,t) : []; 188.86/167.80 lex40 c ds yu = []; 188.86/167.80 ; 188.86/167.80 lex5 c vu62 = lex50 c vu62; 188.86/167.80 ; 188.86/167.80 lex50 c (ds,s) = concatMap (lex4 c ds) (lexFracExp s); 188.86/167.80 lex50 c yv = []; 188.86/167.80 ; 188.86/167.80 lex6 c s True = []; 188.86/167.80 ; 188.86/167.80 lex7 c s True = concatMap (lex5 c) (span isDigit s : []); 188.86/167.80 lex7 c s False = lex6 c s otherwise; 188.86/167.80 ; 188.86/167.80 lex8 c s True = concatMap (lex3 c) (span isIdChar s : []); 188.86/167.80 lex8 c s False = lex7 c s (isDigit c); 188.86/167.80 ; 188.86/167.80 lex9 c s True = concatMap (lex2 c) (span isSym s : []); 188.86/167.80 lex9 c s False = lex8 c s (isAlpha c); 188.86/167.80 ; 188.86/167.80 lexExp (e : s) = lexExp5 (e : s); 188.86/167.80 lexExp s = lexExp3 s; 188.86/167.80 ; 188.86/167.80 lexExp0 e c vu65 = lexExp00 e c vu65; 188.86/167.80 ; 188.86/167.80 lexExp00 e c (ds,u) = (e : c : ds,u) : []; 188.86/167.80 lexExp00 e c xv = []; 188.86/167.80 ; 188.86/167.80 lexExp1 e vu66 = lexExp10 e vu66; 188.86/167.80 ; 188.86/167.80 lexExp10 e (c : t) = lexExp100 e c t (c `elem` '+' : '-' : []); 188.86/167.80 lexExp10 e xx = []; 188.86/167.80 ; 188.86/167.80 lexExp100 e c t True = concatMap (lexExp0 e c) (lexDigits t); 188.86/167.80 lexExp100 e c t False = []; 188.86/167.80 ; 188.86/167.80 lexExp2 e vu67 = lexExp20 e vu67; 188.86/167.80 ; 188.86/167.80 lexExp20 e (ds,t) = (e : ds,t) : []; 188.86/167.80 lexExp20 e xw = []; 188.86/167.80 ; 188.86/167.80 lexExp3 s = ([],s) : []; 188.86/167.80 ; 188.86/167.80 lexExp4 e s True = concatMap (lexExp1 e) (s : []) ++ concatMap (lexExp2 e) (lexDigits s); 188.86/167.80 lexExp4 e s False = lexExp3 (e : s); 188.86/167.80 ; 188.86/167.80 lexExp5 (e : s) = lexExp4 e s (e `elem` 'e' : 'E' : []); 188.86/167.80 lexExp5 wvz = lexExp3 wvz; 188.86/167.80 ; 188.86/167.80 lexFracExp (wwv : wwy) = lexFracExp5 (wwv : wwy); 188.86/167.80 lexFracExp s = lexFracExp2 s; 189.19/167.80 ; 189.19/167.80 lexFracExp0 ds vu63 = lexFracExp00 ds vu63; 189.19/167.80 ; 189.19/167.80 lexFracExp00 ds (e,u) = ('.' : ds ++ e,u) : []; 189.19/167.80 lexFracExp00 ds xz = []; 189.19/167.80 ; 189.19/167.80 lexFracExp1 vu64 = lexFracExp10 vu64; 189.19/167.80 ; 189.19/167.80 lexFracExp10 (ds,t) = concatMap (lexFracExp0 ds) (lexExp t); 189.19/167.80 lexFracExp10 xy = []; 189.19/167.80 ; 189.19/167.80 lexFracExp2 s = lexExp s; 189.19/167.80 ; 189.19/167.80 lexFracExp3 wwv c cs True = concatMap lexFracExp1 (lexDigits (c : cs)); 189.19/167.80 lexFracExp3 wwv c cs False = lexFracExp2 (wwv : c : cs); 189.19/167.80 ; 189.19/167.80 lexFracExp4 True (wwv : c : cs) = lexFracExp3 wwv c cs (isDigit c); 189.19/167.80 lexFracExp4 wwz wxu = lexFracExp2 wxu; 189.19/167.80 ; 189.19/167.80 lexFracExp5 (wwv : wwy) = lexFracExp4 (wwv == '.') (wwv : wwy); 189.19/167.80 lexFracExp5 wxv = lexFracExp2 wxv; 189.19/167.80 } 189.19/167.80 ; 189.19/167.80 " 189.19/167.80 "lex13 True (wxy : s) = concatMap lex1 (lexString s) where { 189.19/167.80 lex1 vu55 = lex10 vu55; 189.19/167.80 ; 189.19/167.80 lex10 (str,t) = ('"' : str,t) : []; 189.19/167.80 lex10 xu = []; 189.19/167.80 ; 189.19/167.80 lexStrItem (vzv : vzz) = lexStrItem7 (vzv : vzz); 189.19/167.80 lexStrItem (vxz : vyw) = lexStrItem4 (vxz : vyw); 189.19/167.80 lexStrItem s = lexStrItem1 s; 189.19/167.80 ; 189.19/167.80 lexStrItem0 vu58 = lexStrItem00 vu58; 189.19/167.80 ; 189.19/167.80 lexStrItem00 (wvu : t) = lexStrItem002 (wvu : t); 189.19/167.80 lexStrItem00 wz = lexStrItem000 wz; 189.19/167.80 ; 189.19/167.80 lexStrItem000 wz = []; 189.19/167.80 ; 189.19/167.80 lexStrItem001 True (wvu : t) = ([],t) : []; 189.19/167.80 lexStrItem001 wvv wvw = lexStrItem000 wvw; 189.19/167.80 ; 189.19/167.80 lexStrItem002 (wvu : t) = lexStrItem001 (wvu == '\') (wvu : t); 189.19/167.80 lexStrItem002 wvx = lexStrItem000 wvx; 189.19/167.80 ; 189.19/167.80 lexStrItem1 s = lexLitChar s; 189.19/167.80 ; 189.19/167.80 lexStrItem2 vxz c s True = concatMap lexStrItem0 (dropWhile isSpace s : []); 189.19/167.80 lexStrItem2 vxz c s False = lexStrItem1 (vxz : c : s); 189.19/167.80 ; 189.19/167.80 lexStrItem3 True (vxz : c : s) = lexStrItem2 vxz c s (isSpace c); 189.19/167.80 lexStrItem3 vyx vyy = lexStrItem1 vyy; 189.19/167.80 ; 189.19/167.80 lexStrItem4 (vxz : vyw) = lexStrItem3 (vxz == '\') (vxz : vyw); 189.19/167.80 lexStrItem4 vyz = lexStrItem1 vyz; 189.19/167.80 ; 189.19/167.80 lexStrItem5 True (vzv : vzx : s) = ('\' : '&' : [],s) : []; 189.19/167.80 lexStrItem5 wuu wuv = lexStrItem4 wuv; 189.19/167.80 ; 189.19/167.80 lexStrItem6 True (vzv : vzx : s) = lexStrItem5 (vzx == '&') (vzv : vzx : s); 189.19/167.80 lexStrItem6 wuw wux = lexStrItem4 wux; 189.19/167.80 ; 189.19/167.80 lexStrItem7 (vzv : vzz) = lexStrItem6 (vzv == '\') (vzv : vzz); 189.19/167.80 lexStrItem7 wuy = lexStrItem4 wuy; 189.19/167.80 ; 189.19/167.80 lexString (vxu : s) = lexString4 (vxu : s); 189.19/167.80 lexString s = lexString2 s; 189.19/167.80 ; 189.19/167.80 lexString0 ch vu56 = lexString00 ch vu56; 189.19/167.80 ; 189.19/167.80 lexString00 ch (str,u) = (ch ++ str,u) : []; 189.19/167.80 lexString00 ch wx = []; 189.19/167.80 ; 189.19/167.80 lexString1 vu57 = lexString10 vu57; 189.19/167.80 ; 189.19/167.80 lexString10 (ch,t) = concatMap (lexString0 ch) (lexString t); 189.19/167.80 lexString10 wy = []; 189.19/167.80 ; 189.19/167.80 lexString2 s = concatMap lexString1 (lexStrItem s); 189.19/167.80 ; 189.19/167.80 lexString3 True (vxu : s) = ('"' : [],s) : []; 189.19/167.80 lexString3 vxv vxw = lexString2 vxw; 189.19/167.80 ; 189.19/167.80 lexString4 (vxu : s) = lexString3 (vxu == '"') (vxu : s); 189.19/167.80 lexString4 vxx = lexString2 vxx; 189.19/167.80 } 189.19/167.80 ; 189.19/167.80 lex13 wxz wyu = lex12 wyu; 189.19/167.80 " 189.19/167.80 "lex14 (wxy : s) = lex13 (wxy == '"') (wxy : s); 189.19/167.80 lex14 wyv = lex12 wyv; 189.19/167.80 " 189.19/167.80 "lex15 True (wyx : s) = concatMap lex0 (lexLitChar s); 189.19/167.80 lex15 wyy wyz = lex14 wyz; 189.19/167.80 " 189.19/167.80 "lex16 (wyx : s) = lex15 (wyx == ''') (wyx : s); 189.19/167.80 lex16 wzu = lex14 wzu; 189.19/167.80 " 189.19/167.80 "lex17 c s True = lex (dropWhile isSpace s); 189.19/167.80 lex17 c s False = lex16 (c : s); 189.19/167.80 " 189.19/167.80 "lex18 (c : s) = lex17 c s (isSpace c); 189.19/167.80 lex18 wzw = lex16 wzw; 189.19/167.80 " 189.19/167.80 "lex19 [] = ([],[]) : []; 189.19/167.80 lex19 wzy = lex18 wzy; 189.19/167.80 " 189.19/167.80 The following Function with conditions 189.19/167.80 "lexmatch (x : xs) (y : ys)|x == ylexmatch xs ys; 189.19/167.80 lexmatch xs ys = (xs,ys); 189.19/167.80 " 189.19/167.80 is transformed to 189.19/167.80 "lexmatch (x : xs) (y : ys) = lexmatch2 (x : xs) (y : ys); 189.19/167.80 lexmatch xs ys = lexmatch0 xs ys; 189.19/167.80 " 189.19/167.80 "lexmatch0 xs ys = (xs,ys); 189.19/167.80 " 189.19/167.80 "lexmatch1 x xs y ys True = lexmatch xs ys; 189.19/167.80 lexmatch1 x xs y ys False = lexmatch0 (x : xs) (y : ys); 189.19/167.80 " 189.19/167.80 "lexmatch2 (x : xs) (y : ys) = lexmatch1 x xs y ys (x == y); 189.19/167.80 lexmatch2 xuv xuw = lexmatch0 xuv xuw; 189.19/167.80 " 189.19/167.80 The following Function with conditions 189.19/167.80 "undefined |Falseundefined; 189.19/167.80 " 189.19/167.80 is transformed to 189.19/167.80 "undefined = undefined1; 189.19/167.80 " 189.19/167.80 "undefined0 True = undefined; 189.19/167.80 " 189.19/167.80 "undefined1 = undefined0 False; 189.19/167.80 " 189.19/167.80 The following Function with conditions 189.19/167.80 "mandatory20 ('(' : [],s) = concatMap mandatory1 (optional s); 189.19/167.80 mandatory20 zw = []; 189.19/167.80 " 189.19/167.80 is transformed to 189.19/167.80 "mandatory20 (xuz : xvu,s) = mandatory202 (xuz : xvu,s); 189.19/167.80 mandatory20 zw = mandatory200 zw; 189.19/167.80 " 189.19/167.80 "mandatory200 zw = []; 189.19/167.80 " 189.19/167.80 "mandatory201 True (xuz : [],s) = concatMap mandatory1 (optional s); 189.19/167.80 mandatory201 xvv xvw = mandatory200 xvw; 189.19/167.80 " 189.19/167.80 "mandatory202 (xuz : xvu,s) = mandatory201 (xuz == '(') (xuz : xvu,s); 189.19/167.80 mandatory202 xvx = mandatory200 xvx; 189.19/167.80 " 189.19/167.80 The following Function with conditions 189.19/167.80 "mandatory00 x (')' : [],u) = (x,u) : []; 189.19/167.80 mandatory00 x zx = []; 189.19/167.80 " 189.19/167.80 is transformed to 189.19/167.80 "mandatory00 x (xwu : xwv,u) = mandatory002 x (xwu : xwv,u); 189.19/167.80 mandatory00 x zx = mandatory000 x zx; 189.19/167.80 " 189.19/167.80 "mandatory000 x zx = []; 189.19/167.80 " 189.19/167.80 "mandatory001 True x (xwu : [],u) = (x,u) : []; 189.19/167.80 mandatory001 xww xwx xwy = mandatory000 xwx xwy; 189.19/167.80 " 189.19/167.80 "mandatory002 x (xwu : xwv,u) = mandatory001 (xwu == ')') x (xwu : xwv,u); 189.19/167.80 mandatory002 xwz xxu = mandatory000 xwz xxu; 189.19/167.80 " 189.19/167.80 The following Function with conditions 189.19/167.80 "dropWhile p [] = []; 189.19/167.80 dropWhile p (zz : vuu)|p zzdropWhile p vuu|otherwisezz : vuu; 189.19/167.80 " 189.19/167.80 is transformed to 189.19/167.80 "dropWhile p [] = dropWhile3 p []; 189.19/167.80 dropWhile p (zz : vuu) = dropWhile2 p (zz : vuu); 189.19/167.80 " 189.19/167.80 "dropWhile0 p zz vuu True = zz : vuu; 189.19/167.80 " 189.19/167.80 "dropWhile1 p zz vuu True = dropWhile p vuu; 189.19/167.80 dropWhile1 p zz vuu False = dropWhile0 p zz vuu otherwise; 189.19/167.80 " 189.19/167.80 "dropWhile2 p (zz : vuu) = dropWhile1 p zz vuu (p zz); 189.19/167.80 " 189.19/167.80 "dropWhile3 p [] = []; 189.19/167.80 dropWhile3 xxx xxy = dropWhile2 xxx xxy; 189.19/167.80 " 189.19/167.80 The following Function with conditions 189.19/167.80 "lex00 (ch,''' : t) = lex000 ch t (ch /= ''' : []); 189.19/167.80 lex00 vuv = []; 189.19/167.80 " 189.19/167.80 is transformed to 189.19/167.80 "lex00 (ch,xyv : t) = lex003 (ch,xyv : t); 189.19/167.80 lex00 vuv = lex001 vuv; 189.19/167.80 " 189.19/167.80 "lex001 vuv = []; 189.19/167.80 " 189.19/167.80 "lex002 True (ch,xyv : t) = lex000 ch t (ch /= ''' : []); 189.19/167.80 lex002 xyw xyx = lex001 xyx; 189.19/167.80 " 189.19/167.80 "lex003 (ch,xyv : t) = lex002 (xyv == ''') (ch,xyv : t); 189.19/167.80 lex003 xyy = lex001 xyy; 189.19/167.80 " 189.19/167.80 The following Function with conditions 189.19/167.80 "lexEsc (c : s)|c `elem` 'a' : 'b' : 'f' : 'n' : 'r' : 't' : 'v' : '\' : '"' : ''' : [](c : [],s) : []; 189.19/167.80 lexEsc ('^' : c : s)|c >= '@' && c <= '_'('^' : c : [],s) : []; 189.19/167.80 lexEsc ('o' : s) = prefix 'o' (span isOctDigit s) : []; 189.19/167.80 lexEsc ('x' : s) = prefix 'x' (span isHexDigit s) : []; 189.19/167.80 lexEsc (vux : vuy)|isDigit vuxspan isDigit (vux : vuy) : []|isUpper vuxlexEsc2 (concatMap (lexEsc1 (vux : vuy)) table); 189.19/167.80 lexEsc vuz = []; 189.19/167.80 " 189.19/167.80 is transformed to 189.19/167.80 "lexEsc (c : s) = lexEsc16 (c : s); 189.19/167.80 lexEsc (yvu : yvx) = lexEsc14 (yvu : yvx); 189.19/167.80 lexEsc (yuv : s) = lexEsc11 (yuv : s); 189.19/167.80 lexEsc (xzw : s) = lexEsc8 (xzw : s); 189.19/167.80 lexEsc (vux : vuy) = lexEsc6 (vux : vuy); 189.19/167.80 lexEsc vuz = lexEsc3 vuz; 189.19/167.80 " 189.19/167.80 "lexEsc3 vuz = []; 189.19/167.80 " 189.19/167.80 "lexEsc4 vux vuy True = lexEsc2 (concatMap (lexEsc1 (vux : vuy)) table); 189.19/167.80 lexEsc4 vux vuy False = lexEsc3 (vux : vuy); 189.19/167.80 " 189.19/167.80 "lexEsc5 vux vuy True = span isDigit (vux : vuy) : []; 189.19/167.80 lexEsc5 vux vuy False = lexEsc4 vux vuy (isUpper vux); 189.19/167.80 " 189.19/167.80 "lexEsc6 (vux : vuy) = lexEsc5 vux vuy (isDigit vux); 189.19/167.80 lexEsc6 xzu = lexEsc3 xzu; 189.19/167.80 " 189.19/167.80 "lexEsc7 True (xzw : s) = prefix 'x' (span isHexDigit s) : []; 189.19/167.80 lexEsc7 xzx xzy = lexEsc6 xzy; 189.19/167.80 " 189.19/167.80 "lexEsc8 (xzw : s) = lexEsc7 (xzw == 'x') (xzw : s); 189.19/167.80 lexEsc8 xzz = lexEsc6 xzz; 189.19/167.80 " 189.19/167.80 "lexEsc9 True (yuv : s) = prefix 'o' (span isOctDigit s) : []; 189.19/167.80 lexEsc9 yuw yux = lexEsc8 yux; 189.19/167.80 " 189.19/167.80 "lexEsc11 (yuv : s) = lexEsc9 (yuv == 'o') (yuv : s); 189.19/167.80 lexEsc11 yuy = lexEsc8 yuy; 189.19/167.80 " 189.19/167.80 "lexEsc12 yvu c s True = ('^' : c : [],s) : []; 189.19/167.80 lexEsc12 yvu c s False = lexEsc11 (yvu : c : s); 189.19/167.80 " 189.19/167.80 "lexEsc13 True (yvu : c : s) = lexEsc12 yvu c s (c >= '@' && c <= '_'); 189.19/167.80 lexEsc13 yvy yvz = lexEsc11 yvz; 189.19/167.80 " 189.19/167.80 "lexEsc14 (yvu : yvx) = lexEsc13 (yvu == '^') (yvu : yvx); 189.19/167.80 lexEsc14 ywu = lexEsc11 ywu; 189.19/167.80 " 189.19/167.80 "lexEsc15 c s True = (c : [],s) : []; 189.19/167.80 lexEsc15 c s False = lexEsc14 (c : s); 189.19/167.80 " 189.19/167.80 "lexEsc16 (c : s) = lexEsc15 c s (c `elem` 'a' : 'b' : 'f' : 'n' : 'r' : 't' : 'v' : '\' : '"' : ''' : []); 189.19/167.80 lexEsc16 yww = lexEsc14 yww; 189.19/167.80 " 189.19/167.80 The following Function with conditions 189.19/167.80 "lexLitChar [] = []; 189.19/167.80 lexLitChar (c : s)|c /= '\'(c : [],s) : []|otherwisemap (prefix '\') (lexEsc s) where { 189.19/167.80 lexEsc (c : s)|c `elem` 'a' : 'b' : 'f' : 'n' : 'r' : 't' : 'v' : '\' : '"' : ''' : [](c : [],s) : []; 189.19/167.80 lexEsc ('^' : c : s)|c >= '@' && c <= '_'('^' : c : [],s) : []; 189.19/167.80 lexEsc ('o' : s) = prefix 'o' (span isOctDigit s) : []; 189.19/167.80 lexEsc ('x' : s) = prefix 'x' (span isHexDigit s) : []; 189.19/167.80 lexEsc (vux : vuy)|isDigit vuxspan isDigit (vux : vuy) : []|isUpper vuxlexEsc2 (concatMap (lexEsc1 (vux : vuy)) table); 189.19/167.80 lexEsc vuz = []; 189.19/167.80 ; 189.19/167.80 lexEsc0 mne vu69 = lexEsc00 mne vu69; 189.19/167.80 ; 189.19/167.80 lexEsc00 mne ([],s') = (mne,s') : []; 189.19/167.80 lexEsc00 mne vvv = []; 189.19/167.80 ; 189.19/167.80 lexEsc1 s vu70 = lexEsc10 s vu70; 189.19/167.80 ; 189.19/167.80 lexEsc10 s (c,mne) = concatMap (lexEsc0 mne) (lexmatch mne s : []); 189.19/167.80 lexEsc10 s vvw = []; 189.19/167.80 ; 189.19/167.80 lexEsc2 (pr : vvu) = pr : []; 189.19/167.80 lexEsc2 [] = []; 189.19/167.80 ; 189.19/167.80 prefix c (t,s) = (c : t,s); 189.19/167.80 ; 189.19/167.80 table = ('\127','D' : 'E' : 'L' : []) : asciiTab; 189.19/167.80 } 189.19/167.80 ; 189.19/167.80 " 189.19/167.80 is transformed to 189.19/167.80 "lexLitChar [] = lexLitChar3 []; 189.19/167.80 lexLitChar (c : s) = lexLitChar2 (c : s); 189.19/167.80 " 189.19/167.80 "lexLitChar2 (c : s) = lexLitChar1 c s (c /= '\') where { 189.19/167.80 lexEsc (c : s) = lexEsc16 (c : s); 189.19/167.80 lexEsc (yvu : yvx) = lexEsc14 (yvu : yvx); 189.19/167.80 lexEsc (yuv : s) = lexEsc11 (yuv : s); 189.19/167.80 lexEsc (xzw : s) = lexEsc8 (xzw : s); 189.19/167.80 lexEsc (vux : vuy) = lexEsc6 (vux : vuy); 189.19/167.80 lexEsc vuz = lexEsc3 vuz; 189.19/167.80 ; 189.19/167.80 lexEsc0 mne vu69 = lexEsc00 mne vu69; 189.19/167.80 ; 189.19/167.80 lexEsc00 mne ([],s') = (mne,s') : []; 189.19/167.80 lexEsc00 mne vvv = []; 189.19/167.80 ; 189.19/167.80 lexEsc1 s vu70 = lexEsc10 s vu70; 189.19/167.80 ; 189.19/167.80 lexEsc10 s (c,mne) = concatMap (lexEsc0 mne) (lexmatch mne s : []); 189.19/167.80 lexEsc10 s vvw = []; 189.19/167.80 ; 189.19/167.80 lexEsc11 (yuv : s) = lexEsc9 (yuv == 'o') (yuv : s); 189.19/167.80 lexEsc11 yuy = lexEsc8 yuy; 189.19/167.80 ; 189.19/167.80 lexEsc12 yvu c s True = ('^' : c : [],s) : []; 189.19/167.80 lexEsc12 yvu c s False = lexEsc11 (yvu : c : s); 189.19/167.80 ; 189.19/167.80 lexEsc13 True (yvu : c : s) = lexEsc12 yvu c s (c >= '@' && c <= '_'); 189.19/167.80 lexEsc13 yvy yvz = lexEsc11 yvz; 189.19/167.80 ; 189.19/167.80 lexEsc14 (yvu : yvx) = lexEsc13 (yvu == '^') (yvu : yvx); 189.19/167.80 lexEsc14 ywu = lexEsc11 ywu; 189.19/167.80 ; 189.19/167.80 lexEsc15 c s True = (c : [],s) : []; 189.19/167.80 lexEsc15 c s False = lexEsc14 (c : s); 189.19/167.80 ; 189.19/167.80 lexEsc16 (c : s) = lexEsc15 c s (c `elem` 'a' : 'b' : 'f' : 'n' : 'r' : 't' : 'v' : '\' : '"' : ''' : []); 189.19/167.80 lexEsc16 yww = lexEsc14 yww; 189.19/167.80 ; 189.19/167.80 lexEsc2 (pr : vvu) = pr : []; 189.19/167.80 lexEsc2 [] = []; 189.19/167.80 ; 189.19/167.80 lexEsc3 vuz = []; 189.19/167.80 ; 189.19/167.80 lexEsc4 vux vuy True = lexEsc2 (concatMap (lexEsc1 (vux : vuy)) table); 189.19/167.80 lexEsc4 vux vuy False = lexEsc3 (vux : vuy); 189.19/167.80 ; 189.19/167.80 lexEsc5 vux vuy True = span isDigit (vux : vuy) : []; 189.19/167.80 lexEsc5 vux vuy False = lexEsc4 vux vuy (isUpper vux); 189.19/167.80 ; 189.19/167.80 lexEsc6 (vux : vuy) = lexEsc5 vux vuy (isDigit vux); 189.19/167.80 lexEsc6 xzu = lexEsc3 xzu; 189.19/167.80 ; 189.19/167.80 lexEsc7 True (xzw : s) = prefix 'x' (span isHexDigit s) : []; 189.19/167.80 lexEsc7 xzx xzy = lexEsc6 xzy; 189.19/167.80 ; 189.19/167.80 lexEsc8 (xzw : s) = lexEsc7 (xzw == 'x') (xzw : s); 189.19/167.80 lexEsc8 xzz = lexEsc6 xzz; 189.19/167.80 ; 189.19/167.80 lexEsc9 True (yuv : s) = prefix 'o' (span isOctDigit s) : []; 189.19/167.80 lexEsc9 yuw yux = lexEsc8 yux; 189.19/167.80 ; 189.19/167.80 lexLitChar0 c s True = map (prefix '\') (lexEsc s); 189.19/167.80 ; 189.19/167.80 lexLitChar1 c s True = (c : [],s) : []; 189.19/167.80 lexLitChar1 c s False = lexLitChar0 c s otherwise; 189.19/167.80 ; 189.19/167.80 prefix c (t,s) = (c : t,s); 189.19/167.80 ; 189.19/167.80 table = ('\127','D' : 'E' : 'L' : []) : asciiTab; 189.19/167.80 } 189.19/167.80 ; 189.19/167.80 " 189.19/167.80 "lexLitChar3 [] = []; 189.19/167.80 lexLitChar3 ywz = lexLitChar2 ywz; 189.19/167.80 " 189.19/167.80 The following Function with conditions 189.19/167.80 "span p [] = ([],[]); 189.19/167.80 span p (vvx : vvy)|p vvx(vvx : ys,zs)|otherwise([],vvx : vvy) where { 189.19/167.80 vu43 = span p vvy; 189.19/167.80 ; 189.19/167.80 ys = ys0 vu43; 189.19/167.80 ; 189.19/167.80 ys0 (ys,vwu) = ys; 189.19/167.80 ; 189.19/167.80 zs = zs0 vu43; 189.19/167.80 ; 189.19/167.80 zs0 (vvz,zs) = zs; 189.19/167.80 } 189.19/167.80 ; 189.19/167.80 " 189.19/167.80 is transformed to 189.19/167.80 "span p [] = span3 p []; 189.19/167.80 span p (vvx : vvy) = span2 p (vvx : vvy); 189.19/167.80 " 189.19/167.80 "span2 p (vvx : vvy) = span1 p vvx vvy (p vvx) where { 189.19/167.80 span0 p vvx vvy True = ([],vvx : vvy); 189.19/167.80 ; 189.19/167.80 span1 p vvx vvy True = (vvx : ys,zs); 189.19/167.80 span1 p vvx vvy False = span0 p vvx vvy otherwise; 189.19/167.80 ; 189.19/167.80 vu43 = span p vvy; 189.19/167.80 ; 189.19/167.80 ys = ys0 vu43; 189.19/167.80 ; 189.19/167.80 ys0 (ys,vwu) = ys; 189.19/167.80 ; 189.19/167.80 zs = zs0 vu43; 189.19/167.80 ; 189.19/167.80 zs0 (vvz,zs) = zs; 189.19/167.80 } 189.19/167.80 ; 189.19/167.80 " 189.19/167.80 "span3 p [] = ([],[]); 189.19/167.80 span3 yxw yxx = span2 yxw yxx; 189.19/167.80 " 189.19/167.80 189.19/167.80 ---------------------------------------- 189.19/167.80 189.19/167.80 (10) 189.19/167.80 Obligation: 189.19/167.80 mainModule Main 189.19/167.80 module Main where { 189.19/167.80 import qualified Prelude; 189.19/167.80 } 189.19/167.80 189.19/167.80 ---------------------------------------- 189.19/167.80 189.19/167.80 (11) LetRed (EQUIVALENT) 189.19/167.80 Let/Where Reductions: 189.19/167.80 The bindings of the following Let/Where expression 189.19/167.80 "concatMap lex1 (lexString s) where { 189.19/167.80 lex1 vu55 = lex10 vu55; 189.19/167.80 ; 189.19/167.80 lex10 (str,t) = ('"' : str,t) : []; 189.19/167.80 lex10 xu = []; 189.19/167.80 ; 189.19/167.80 lexStrItem (vzv : vzz) = lexStrItem7 (vzv : vzz); 189.19/167.80 lexStrItem (vxz : vyw) = lexStrItem4 (vxz : vyw); 189.19/167.80 lexStrItem s = lexStrItem1 s; 189.19/167.80 ; 189.19/167.80 lexStrItem0 vu58 = lexStrItem00 vu58; 189.19/167.80 ; 189.19/167.80 lexStrItem00 (wvu : t) = lexStrItem002 (wvu : t); 189.19/167.80 lexStrItem00 wz = lexStrItem000 wz; 189.19/167.80 ; 189.19/167.80 lexStrItem000 wz = []; 189.19/167.80 ; 189.19/167.80 lexStrItem001 True (wvu : t) = ([],t) : []; 189.19/167.80 lexStrItem001 wvv wvw = lexStrItem000 wvw; 189.19/167.80 ; 189.19/167.80 lexStrItem002 (wvu : t) = lexStrItem001 (wvu == '\') (wvu : t); 189.19/167.80 lexStrItem002 wvx = lexStrItem000 wvx; 189.19/167.80 ; 189.19/167.80 lexStrItem1 s = lexLitChar s; 189.19/167.80 ; 189.19/167.80 lexStrItem2 vxz c s True = concatMap lexStrItem0 (dropWhile isSpace s : []); 189.19/167.80 lexStrItem2 vxz c s False = lexStrItem1 (vxz : c : s); 189.19/167.80 ; 189.19/167.80 lexStrItem3 True (vxz : c : s) = lexStrItem2 vxz c s (isSpace c); 189.19/167.80 lexStrItem3 vyx vyy = lexStrItem1 vyy; 189.19/167.80 ; 189.19/167.80 lexStrItem4 (vxz : vyw) = lexStrItem3 (vxz == '\') (vxz : vyw); 189.19/167.80 lexStrItem4 vyz = lexStrItem1 vyz; 189.19/167.80 ; 189.19/167.80 lexStrItem5 True (vzv : vzx : s) = ('\' : '&' : [],s) : []; 189.19/167.80 lexStrItem5 wuu wuv = lexStrItem4 wuv; 189.19/167.80 ; 189.19/167.80 lexStrItem6 True (vzv : vzx : s) = lexStrItem5 (vzx == '&') (vzv : vzx : s); 189.19/167.80 lexStrItem6 wuw wux = lexStrItem4 wux; 189.19/167.80 ; 189.19/167.80 lexStrItem7 (vzv : vzz) = lexStrItem6 (vzv == '\') (vzv : vzz); 189.19/167.80 lexStrItem7 wuy = lexStrItem4 wuy; 189.19/167.80 ; 189.19/167.80 lexString (vxu : s) = lexString4 (vxu : s); 189.19/167.80 lexString s = lexString2 s; 189.19/167.80 ; 189.19/167.80 lexString0 ch vu56 = lexString00 ch vu56; 189.19/167.80 ; 189.19/167.80 lexString00 ch (str,u) = (ch ++ str,u) : []; 189.19/167.80 lexString00 ch wx = []; 189.19/167.80 ; 189.19/167.80 lexString1 vu57 = lexString10 vu57; 189.19/167.80 ; 189.19/167.80 lexString10 (ch,t) = concatMap (lexString0 ch) (lexString t); 189.19/167.80 lexString10 wy = []; 189.19/167.80 ; 189.19/167.80 lexString2 s = concatMap lexString1 (lexStrItem s); 189.19/167.80 ; 189.19/167.80 lexString3 True (vxu : s) = ('"' : [],s) : []; 189.19/167.80 lexString3 vxv vxw = lexString2 vxw; 189.19/167.80 ; 189.19/167.80 lexString4 (vxu : s) = lexString3 (vxu == '"') (vxu : s); 189.19/167.80 lexString4 vxx = lexString2 vxx; 189.19/167.80 } 189.19/167.80 " 189.19/167.80 are unpacked to the following functions on top level 189.19/167.80 "lex13LexString3 True (vxu : s) = ('"' : [],s) : []; 189.19/167.80 lex13LexString3 vxv vxw = lex13LexString2 vxw; 189.19/167.84 " 189.19/167.84 "lex13LexString0 ch vu56 = lex13LexString00 ch vu56; 189.19/167.84 " 189.19/167.84 "lex13LexStrItem00 (wvu : t) = lex13LexStrItem002 (wvu : t); 189.19/167.84 lex13LexStrItem00 wz = lex13LexStrItem000 wz; 189.19/167.84 " 189.19/167.84 "lex13LexString1 vu57 = lex13LexString10 vu57; 189.19/167.84 " 189.19/167.84 "lex13LexStrItem001 True (wvu : t) = ([],t) : []; 189.19/167.84 lex13LexStrItem001 wvv wvw = lex13LexStrItem000 wvw; 189.19/167.84 " 189.19/167.84 "lex13LexStrItem002 (wvu : t) = lex13LexStrItem001 (wvu == '\') (wvu : t); 189.19/167.84 lex13LexStrItem002 wvx = lex13LexStrItem000 wvx; 189.19/167.84 " 189.19/167.84 "lex13LexString4 (vxu : s) = lex13LexString3 (vxu == '"') (vxu : s); 189.19/167.84 lex13LexString4 vxx = lex13LexString2 vxx; 189.19/167.84 " 189.19/167.84 "lex13LexStrItem4 (vxz : vyw) = lex13LexStrItem3 (vxz == '\') (vxz : vyw); 189.19/167.84 lex13LexStrItem4 vyz = lex13LexStrItem1 vyz; 189.19/167.84 " 189.19/167.84 "lex13LexStrItem3 True (vxz : c : s) = lex13LexStrItem2 vxz c s (isSpace c); 189.19/167.84 lex13LexStrItem3 vyx vyy = lex13LexStrItem1 vyy; 189.19/167.84 " 189.19/167.84 "lex13LexString10 (ch,t) = concatMap (lex13LexString0 ch) (lex13LexString t); 189.19/167.84 lex13LexString10 wy = []; 189.19/167.84 " 189.19/167.84 "lex13LexStrItem7 (vzv : vzz) = lex13LexStrItem6 (vzv == '\') (vzv : vzz); 189.19/167.84 lex13LexStrItem7 wuy = lex13LexStrItem4 wuy; 189.19/167.84 " 189.19/167.84 "lex13LexStrItem0 vu58 = lex13LexStrItem00 vu58; 189.19/167.84 " 189.19/167.84 "lex13LexStrItem (vzv : vzz) = lex13LexStrItem7 (vzv : vzz); 189.19/167.84 lex13LexStrItem (vxz : vyw) = lex13LexStrItem4 (vxz : vyw); 189.19/167.84 lex13LexStrItem s = lex13LexStrItem1 s; 189.19/167.84 " 189.19/167.84 "lex13LexStrItem6 True (vzv : vzx : s) = lex13LexStrItem5 (vzx == '&') (vzv : vzx : s); 189.19/167.84 lex13LexStrItem6 wuw wux = lex13LexStrItem4 wux; 189.19/167.84 " 189.19/167.84 "lex13Lex10 (str,t) = ('"' : str,t) : []; 189.19/167.84 lex13Lex10 xu = []; 189.19/167.84 " 189.19/167.84 "lex13LexStrItem000 wz = []; 189.19/167.84 " 189.19/167.84 "lex13LexStrItem2 vxz c s True = concatMap lex13LexStrItem0 (dropWhile isSpace s : []); 189.19/167.84 lex13LexStrItem2 vxz c s False = lex13LexStrItem1 (vxz : c : s); 189.19/167.84 " 189.19/167.84 "lex13Lex1 vu55 = lex13Lex10 vu55; 189.19/167.84 " 189.19/167.84 "lex13LexString (vxu : s) = lex13LexString4 (vxu : s); 189.19/167.84 lex13LexString s = lex13LexString2 s; 189.19/167.84 " 189.19/167.84 "lex13LexStrItem1 s = lexLitChar s; 189.19/167.84 " 189.19/167.84 "lex13LexStrItem5 True (vzv : vzx : s) = ('\' : '&' : [],s) : []; 189.19/167.84 lex13LexStrItem5 wuu wuv = lex13LexStrItem4 wuv; 189.19/167.84 " 189.19/167.84 "lex13LexString00 ch (str,u) = (ch ++ str,u) : []; 189.19/167.84 lex13LexString00 ch wx = []; 189.19/167.84 " 189.19/167.84 "lex13LexString2 s = concatMap lex13LexString1 (lex13LexStrItem s); 189.19/167.84 " 189.19/167.84 The bindings of the following Let/Where expression 189.19/167.84 "span1 p vvx vvy (p vvx) where { 189.19/167.84 span0 p vvx vvy True = ([],vvx : vvy); 189.19/167.84 ; 189.19/167.84 span1 p vvx vvy True = (vvx : ys,zs); 189.19/167.84 span1 p vvx vvy False = span0 p vvx vvy otherwise; 189.19/167.84 ; 189.19/167.84 vu43 = span p vvy; 189.19/167.84 ; 189.19/167.84 ys = ys0 vu43; 189.19/167.84 ; 189.19/167.84 ys0 (ys,vwu) = ys; 189.19/167.84 ; 189.19/167.84 zs = zs0 vu43; 189.19/167.84 ; 189.19/167.84 zs0 (vvz,zs) = zs; 189.19/167.84 } 189.19/167.84 " 189.19/167.84 are unpacked to the following functions on top level 189.19/167.84 "span2Zs yxy yxz = span2Zs0 yxy yxz (span2Vu43 yxy yxz); 189.19/167.84 " 189.19/167.84 "span2Ys0 yxy yxz (ys,vwu) = ys; 189.19/167.84 " 189.19/167.84 "span2Vu43 yxy yxz = span yxy yxz; 189.19/167.84 " 189.19/167.84 "span2Zs0 yxy yxz (vvz,zs) = zs; 189.19/167.84 " 189.19/167.84 "span2Span1 yxy yxz p vvx vvy True = (vvx : span2Ys yxy yxz,span2Zs yxy yxz); 189.19/167.84 span2Span1 yxy yxz p vvx vvy False = span2Span0 yxy yxz p vvx vvy otherwise; 189.19/167.84 " 189.19/167.84 "span2Ys yxy yxz = span2Ys0 yxy yxz (span2Vu43 yxy yxz); 189.19/167.84 " 189.19/167.84 "span2Span0 yxy yxz p vvx vvy True = ([],vvx : vvy); 189.19/167.84 " 189.19/167.84 The bindings of the following Let/Where expression 189.19/167.84 "lex11 c s (isSingle c) where { 189.19/167.84 isIdChar c = isAlphaNum c || c `elem` '_' : ''' : []; 189.19/167.84 ; 189.19/167.84 isSingle c = c `elem` ',' : ';' : '(' : ')' : '[' : ']' : '{' : '}' : '_' : '`' : []; 189.19/167.84 ; 189.19/167.84 isSym c = c `elem` '!' : '@' : '#' : '$' : '%' : '&' : '*' : '+' : '.' : '/' : '<' : '=' : '>' : '?' : '\' : '^' : '|' : ':' : '-' : '~' : []; 189.19/167.84 ; 189.19/167.84 lex11 c s True = (c : [],s) : []; 189.19/167.84 lex11 c s False = lex9 c s (isSym c); 189.19/167.84 ; 189.19/167.84 lex2 c vu59 = lex20 c vu59; 189.19/167.84 ; 189.19/167.84 lex20 c (sym,t) = (c : sym,t) : []; 189.19/167.84 lex20 c yw = []; 189.19/167.84 ; 189.19/167.84 lex3 c vu60 = lex30 c vu60; 189.19/167.84 ; 189.19/167.84 lex30 c (nam,t) = (c : nam,t) : []; 189.19/167.84 lex30 c yx = []; 189.19/167.84 ; 189.19/167.84 lex4 c ds vu61 = lex40 c ds vu61; 189.19/167.84 ; 189.19/167.84 lex40 c ds (fe,t) = (c : ds ++ fe,t) : []; 189.19/167.84 lex40 c ds yu = []; 189.19/167.84 ; 189.19/167.84 lex5 c vu62 = lex50 c vu62; 189.19/167.84 ; 189.19/167.84 lex50 c (ds,s) = concatMap (lex4 c ds) (lexFracExp s); 189.19/167.84 lex50 c yv = []; 189.19/167.84 ; 189.19/167.84 lex6 c s True = []; 189.19/167.84 ; 189.19/167.84 lex7 c s True = concatMap (lex5 c) (span isDigit s : []); 189.19/167.84 lex7 c s False = lex6 c s otherwise; 189.19/167.84 ; 189.19/167.84 lex8 c s True = concatMap (lex3 c) (span isIdChar s : []); 189.19/167.84 lex8 c s False = lex7 c s (isDigit c); 189.19/167.84 ; 189.19/167.84 lex9 c s True = concatMap (lex2 c) (span isSym s : []); 189.19/167.84 lex9 c s False = lex8 c s (isAlpha c); 189.19/167.84 ; 189.19/167.84 lexExp (e : s) = lexExp5 (e : s); 189.19/167.84 lexExp s = lexExp3 s; 189.19/167.84 ; 189.19/167.84 lexExp0 e c vu65 = lexExp00 e c vu65; 189.19/167.84 ; 189.19/167.84 lexExp00 e c (ds,u) = (e : c : ds,u) : []; 189.19/167.84 lexExp00 e c xv = []; 189.19/167.84 ; 189.19/167.84 lexExp1 e vu66 = lexExp10 e vu66; 189.19/167.84 ; 189.19/167.84 lexExp10 e (c : t) = lexExp100 e c t (c `elem` '+' : '-' : []); 189.19/167.84 lexExp10 e xx = []; 189.19/167.84 ; 189.19/167.84 lexExp100 e c t True = concatMap (lexExp0 e c) (lexDigits t); 189.19/167.84 lexExp100 e c t False = []; 189.19/167.84 ; 189.19/167.84 lexExp2 e vu67 = lexExp20 e vu67; 189.19/167.84 ; 189.19/167.84 lexExp20 e (ds,t) = (e : ds,t) : []; 189.19/167.84 lexExp20 e xw = []; 189.19/167.84 ; 189.19/167.84 lexExp3 s = ([],s) : []; 189.19/167.84 ; 189.19/167.84 lexExp4 e s True = concatMap (lexExp1 e) (s : []) ++ concatMap (lexExp2 e) (lexDigits s); 189.19/167.84 lexExp4 e s False = lexExp3 (e : s); 189.19/167.84 ; 189.19/167.84 lexExp5 (e : s) = lexExp4 e s (e `elem` 'e' : 'E' : []); 189.19/167.84 lexExp5 wvz = lexExp3 wvz; 189.19/167.84 ; 189.19/167.84 lexFracExp (wwv : wwy) = lexFracExp5 (wwv : wwy); 189.19/167.84 lexFracExp s = lexFracExp2 s; 189.19/167.84 ; 189.19/167.84 lexFracExp0 ds vu63 = lexFracExp00 ds vu63; 189.19/167.84 ; 189.19/167.84 lexFracExp00 ds (e,u) = ('.' : ds ++ e,u) : []; 189.19/167.84 lexFracExp00 ds xz = []; 189.19/167.84 ; 189.19/167.84 lexFracExp1 vu64 = lexFracExp10 vu64; 189.19/167.84 ; 189.19/167.84 lexFracExp10 (ds,t) = concatMap (lexFracExp0 ds) (lexExp t); 189.19/167.84 lexFracExp10 xy = []; 189.19/167.84 ; 189.19/167.84 lexFracExp2 s = lexExp s; 189.19/167.84 ; 189.19/167.84 lexFracExp3 wwv c cs True = concatMap lexFracExp1 (lexDigits (c : cs)); 189.19/167.84 lexFracExp3 wwv c cs False = lexFracExp2 (wwv : c : cs); 189.19/167.84 ; 189.19/167.84 lexFracExp4 True (wwv : c : cs) = lexFracExp3 wwv c cs (isDigit c); 189.19/167.84 lexFracExp4 wwz wxu = lexFracExp2 wxu; 189.19/167.84 ; 189.19/167.84 lexFracExp5 (wwv : wwy) = lexFracExp4 (wwv == '.') (wwv : wwy); 189.19/167.84 lexFracExp5 wxv = lexFracExp2 wxv; 189.19/167.84 } 189.19/167.84 " 189.19/167.84 are unpacked to the following functions on top level 189.19/167.84 "lex12LexExp1 e vu66 = lex12LexExp10 e vu66; 189.19/167.84 " 189.19/167.84 "lex12LexExp00 e c (ds,u) = (e : c : ds,u) : []; 189.19/167.84 lex12LexExp00 e c xv = []; 189.19/167.84 " 189.19/167.84 "lex12LexExp5 (e : s) = lex12LexExp4 e s (e `elem` 'e' : 'E' : []); 189.19/167.84 lex12LexExp5 wvz = lex12LexExp3 wvz; 189.19/167.84 " 189.19/167.84 "lex12IsSingle c = c `elem` ',' : ';' : '(' : ')' : '[' : ']' : '{' : '}' : '_' : '`' : []; 189.19/167.84 " 189.19/167.84 "lex12LexFracExp (wwv : wwy) = lex12LexFracExp5 (wwv : wwy); 189.19/167.84 lex12LexFracExp s = lex12LexFracExp2 s; 189.19/167.84 " 189.19/167.84 "lex12LexExp100 e c t True = concatMap (lex12LexExp0 e c) (lexDigits t); 189.19/167.84 lex12LexExp100 e c t False = []; 189.19/167.84 " 189.19/167.84 "lex12LexFracExp3 wwv c cs True = concatMap lex12LexFracExp1 (lexDigits (c : cs)); 189.19/167.84 lex12LexFracExp3 wwv c cs False = lex12LexFracExp2 (wwv : c : cs); 189.19/167.84 " 189.19/167.84 "lex12LexFracExp2 s = lex12LexExp s; 189.19/167.84 " 189.19/167.84 "lex12Lex9 c s True = concatMap (lex12Lex2 c) (span lex12IsSym s : []); 189.19/167.84 lex12Lex9 c s False = lex12Lex8 c s (isAlpha c); 189.19/167.84 " 189.19/167.84 "lex12LexFracExp4 True (wwv : c : cs) = lex12LexFracExp3 wwv c cs (isDigit c); 189.19/167.84 lex12LexFracExp4 wwz wxu = lex12LexFracExp2 wxu; 189.19/167.84 " 189.19/167.84 "lex12LexExp (e : s) = lex12LexExp5 (e : s); 189.19/167.84 lex12LexExp s = lex12LexExp3 s; 189.19/167.84 " 189.19/167.84 "lex12LexExp0 e c vu65 = lex12LexExp00 e c vu65; 189.19/167.84 " 189.19/167.84 "lex12IsSym c = c `elem` '!' : '@' : '#' : '$' : '%' : '&' : '*' : '+' : '.' : '/' : '<' : '=' : '>' : '?' : '\' : '^' : '|' : ':' : '-' : '~' : []; 189.19/167.84 " 189.19/167.84 "lex12LexExp20 e (ds,t) = (e : ds,t) : []; 189.19/167.84 lex12LexExp20 e xw = []; 189.19/167.84 " 189.19/167.84 "lex12Lex5 c vu62 = lex12Lex50 c vu62; 189.19/167.84 " 189.19/167.84 "lex12LexFracExp1 vu64 = lex12LexFracExp10 vu64; 189.19/167.84 " 189.19/167.84 "lex12LexExp3 s = ([],s) : []; 189.19/167.84 " 189.19/167.84 "lex12LexFracExp0 ds vu63 = lex12LexFracExp00 ds vu63; 189.19/167.84 " 189.19/167.84 "lex12LexExp2 e vu67 = lex12LexExp20 e vu67; 189.19/167.84 " 189.19/167.84 "lex12LexExp10 e (c : t) = lex12LexExp100 e c t (c `elem` '+' : '-' : []); 189.19/167.84 lex12LexExp10 e xx = []; 189.19/167.84 " 189.19/167.84 "lex12Lex4 c ds vu61 = lex12Lex40 c ds vu61; 189.19/167.84 " 189.19/167.84 "lex12LexFracExp5 (wwv : wwy) = lex12LexFracExp4 (wwv == '.') (wwv : wwy); 189.19/167.84 lex12LexFracExp5 wxv = lex12LexFracExp2 wxv; 189.19/167.84 " 189.19/167.84 "lex12Lex20 c (sym,t) = (c : sym,t) : []; 189.19/167.84 lex12Lex20 c yw = []; 189.19/167.84 " 189.19/167.84 "lex12LexFracExp00 ds (e,u) = ('.' : ds ++ e,u) : []; 189.19/167.84 lex12LexFracExp00 ds xz = []; 189.19/167.84 " 189.19/167.84 "lex12LexExp4 e s True = concatMap (lex12LexExp1 e) (s : []) ++ concatMap (lex12LexExp2 e) (lexDigits s); 189.19/167.84 lex12LexExp4 e s False = lex12LexExp3 (e : s); 189.19/167.84 " 189.19/167.84 "lex12Lex30 c (nam,t) = (c : nam,t) : []; 189.19/167.84 lex12Lex30 c yx = []; 189.19/167.84 " 189.19/167.84 "lex12Lex50 c (ds,s) = concatMap (lex12Lex4 c ds) (lex12LexFracExp s); 189.19/167.84 lex12Lex50 c yv = []; 189.19/167.84 " 189.19/167.84 "lex12Lex6 c s True = []; 189.19/167.84 " 189.19/167.84 "lex12Lex7 c s True = concatMap (lex12Lex5 c) (span isDigit s : []); 189.19/167.84 lex12Lex7 c s False = lex12Lex6 c s otherwise; 189.19/167.84 " 189.19/167.84 "lex12Lex8 c s True = concatMap (lex12Lex3 c) (span lex12IsIdChar s : []); 189.19/167.84 lex12Lex8 c s False = lex12Lex7 c s (isDigit c); 189.19/167.84 " 189.19/167.84 "lex12Lex40 c ds (fe,t) = (c : ds ++ fe,t) : []; 189.19/167.84 lex12Lex40 c ds yu = []; 189.19/167.84 " 189.19/167.84 "lex12IsIdChar c = isAlphaNum c || c `elem` '_' : ''' : []; 189.19/167.86 " 189.19/167.86 "lex12Lex3 c vu60 = lex12Lex30 c vu60; 189.19/167.86 " 189.19/167.86 "lex12Lex2 c vu59 = lex12Lex20 c vu59; 189.19/167.86 " 189.19/167.86 "lex12Lex11 c s True = (c : [],s) : []; 189.19/167.86 lex12Lex11 c s False = lex12Lex9 c s (lex12IsSym c); 189.19/167.86 " 189.19/167.86 "lex12LexFracExp10 (ds,t) = concatMap (lex12LexFracExp0 ds) (lex12LexExp t); 189.19/167.86 lex12LexFracExp10 xy = []; 189.19/167.86 " 189.19/167.86 The bindings of the following Let/Where expression 189.19/167.86 "lexLitChar1 c s (c /= '\') where { 189.19/167.86 lexEsc (c : s) = lexEsc16 (c : s); 189.19/167.86 lexEsc (yvu : yvx) = lexEsc14 (yvu : yvx); 189.19/167.86 lexEsc (yuv : s) = lexEsc11 (yuv : s); 189.19/167.86 lexEsc (xzw : s) = lexEsc8 (xzw : s); 189.19/167.86 lexEsc (vux : vuy) = lexEsc6 (vux : vuy); 189.19/167.86 lexEsc vuz = lexEsc3 vuz; 189.19/167.86 ; 189.19/167.86 lexEsc0 mne vu69 = lexEsc00 mne vu69; 189.19/167.86 ; 189.19/167.86 lexEsc00 mne ([],s') = (mne,s') : []; 189.19/167.86 lexEsc00 mne vvv = []; 189.19/167.86 ; 189.19/167.86 lexEsc1 s vu70 = lexEsc10 s vu70; 189.19/167.86 ; 189.19/167.86 lexEsc10 s (c,mne) = concatMap (lexEsc0 mne) (lexmatch mne s : []); 189.19/167.86 lexEsc10 s vvw = []; 189.19/167.86 ; 189.19/167.86 lexEsc11 (yuv : s) = lexEsc9 (yuv == 'o') (yuv : s); 189.19/167.86 lexEsc11 yuy = lexEsc8 yuy; 189.19/167.86 ; 189.19/167.86 lexEsc12 yvu c s True = ('^' : c : [],s) : []; 189.19/167.86 lexEsc12 yvu c s False = lexEsc11 (yvu : c : s); 189.19/167.86 ; 189.19/167.86 lexEsc13 True (yvu : c : s) = lexEsc12 yvu c s (c >= '@' && c <= '_'); 189.19/167.86 lexEsc13 yvy yvz = lexEsc11 yvz; 189.19/167.86 ; 189.19/167.86 lexEsc14 (yvu : yvx) = lexEsc13 (yvu == '^') (yvu : yvx); 189.19/167.86 lexEsc14 ywu = lexEsc11 ywu; 189.19/167.86 ; 189.19/167.86 lexEsc15 c s True = (c : [],s) : []; 189.19/167.86 lexEsc15 c s False = lexEsc14 (c : s); 189.19/167.86 ; 189.19/167.86 lexEsc16 (c : s) = lexEsc15 c s (c `elem` 'a' : 'b' : 'f' : 'n' : 'r' : 't' : 'v' : '\' : '"' : ''' : []); 189.19/167.86 lexEsc16 yww = lexEsc14 yww; 189.19/167.86 ; 189.19/167.86 lexEsc2 (pr : vvu) = pr : []; 189.19/167.86 lexEsc2 [] = []; 189.19/167.86 ; 189.19/167.86 lexEsc3 vuz = []; 189.19/167.86 ; 189.19/167.86 lexEsc4 vux vuy True = lexEsc2 (concatMap (lexEsc1 (vux : vuy)) table); 189.19/167.86 lexEsc4 vux vuy False = lexEsc3 (vux : vuy); 189.19/167.86 ; 189.19/167.86 lexEsc5 vux vuy True = span isDigit (vux : vuy) : []; 189.19/167.86 lexEsc5 vux vuy False = lexEsc4 vux vuy (isUpper vux); 189.19/167.86 ; 189.19/167.86 lexEsc6 (vux : vuy) = lexEsc5 vux vuy (isDigit vux); 189.19/167.86 lexEsc6 xzu = lexEsc3 xzu; 189.19/167.86 ; 189.19/167.86 lexEsc7 True (xzw : s) = prefix 'x' (span isHexDigit s) : []; 189.19/167.86 lexEsc7 xzx xzy = lexEsc6 xzy; 189.19/167.86 ; 189.19/167.86 lexEsc8 (xzw : s) = lexEsc7 (xzw == 'x') (xzw : s); 189.19/167.86 lexEsc8 xzz = lexEsc6 xzz; 189.19/167.86 ; 189.19/167.86 lexEsc9 True (yuv : s) = prefix 'o' (span isOctDigit s) : []; 189.19/167.86 lexEsc9 yuw yux = lexEsc8 yux; 189.19/167.86 ; 189.19/167.86 lexLitChar0 c s True = map (prefix '\') (lexEsc s); 189.19/167.86 ; 189.19/167.86 lexLitChar1 c s True = (c : [],s) : []; 189.19/167.86 lexLitChar1 c s False = lexLitChar0 c s otherwise; 189.19/167.86 ; 189.19/167.86 prefix c (t,s) = (c : t,s); 189.19/167.86 ; 189.19/167.86 table = ('\127','D' : 'E' : 'L' : []) : asciiTab; 189.19/167.86 } 189.19/167.86 " 189.19/167.86 are unpacked to the following functions on top level 189.19/167.86 "lexLitChar2Table = ('\127','D' : 'E' : 'L' : []) : asciiTab; 189.19/167.86 " 189.19/167.86 "lexLitChar2LexEsc1 s vu70 = lexLitChar2LexEsc10 s vu70; 189.19/167.86 " 189.19/167.86 "lexLitChar2LexEsc00 mne ([],s') = (mne,s') : []; 189.19/167.86 lexLitChar2LexEsc00 mne vvv = []; 189.19/167.86 " 189.19/167.86 "lexLitChar2LexEsc6 (vux : vuy) = lexLitChar2LexEsc5 vux vuy (isDigit vux); 189.19/167.86 lexLitChar2LexEsc6 xzu = lexLitChar2LexEsc3 xzu; 189.19/167.86 " 189.19/167.86 "lexLitChar2LexEsc10 s (c,mne) = concatMap (lexLitChar2LexEsc0 mne) (lexmatch mne s : []); 189.19/167.86 lexLitChar2LexEsc10 s vvw = []; 189.19/167.86 " 189.19/167.86 "lexLitChar2LexEsc7 True (xzw : s) = lexLitChar2Prefix 'x' (span isHexDigit s) : []; 189.19/167.86 lexLitChar2LexEsc7 xzx xzy = lexLitChar2LexEsc6 xzy; 189.19/167.86 " 189.19/167.86 "lexLitChar2LexEsc (c : s) = lexLitChar2LexEsc16 (c : s); 189.19/167.86 lexLitChar2LexEsc (yvu : yvx) = lexLitChar2LexEsc14 (yvu : yvx); 189.19/167.86 lexLitChar2LexEsc (yuv : s) = lexLitChar2LexEsc11 (yuv : s); 189.19/167.86 lexLitChar2LexEsc (xzw : s) = lexLitChar2LexEsc8 (xzw : s); 189.19/167.86 lexLitChar2LexEsc (vux : vuy) = lexLitChar2LexEsc6 (vux : vuy); 189.19/167.86 lexLitChar2LexEsc vuz = lexLitChar2LexEsc3 vuz; 189.19/167.86 " 189.19/167.86 "lexLitChar2LexEsc16 (c : s) = lexLitChar2LexEsc15 c s (c `elem` 'a' : 'b' : 'f' : 'n' : 'r' : 't' : 'v' : '\' : '"' : ''' : []); 189.19/167.86 lexLitChar2LexEsc16 yww = lexLitChar2LexEsc14 yww; 189.19/167.86 " 189.19/167.86 "lexLitChar2LexEsc15 c s True = (c : [],s) : []; 189.19/167.86 lexLitChar2LexEsc15 c s False = lexLitChar2LexEsc14 (c : s); 189.19/167.86 " 189.19/167.86 "lexLitChar2LexEsc11 (yuv : s) = lexLitChar2LexEsc9 (yuv == 'o') (yuv : s); 189.19/167.86 lexLitChar2LexEsc11 yuy = lexLitChar2LexEsc8 yuy; 189.19/167.86 " 189.19/167.86 "lexLitChar2Prefix c (t,s) = (c : t,s); 189.19/167.86 " 189.19/167.86 "lexLitChar2LexEsc9 True (yuv : s) = lexLitChar2Prefix 'o' (span isOctDigit s) : []; 189.19/167.86 lexLitChar2LexEsc9 yuw yux = lexLitChar2LexEsc8 yux; 189.19/167.86 " 189.19/167.86 "lexLitChar2LexEsc4 vux vuy True = lexLitChar2LexEsc2 (concatMap (lexLitChar2LexEsc1 (vux : vuy)) lexLitChar2Table); 189.19/167.86 lexLitChar2LexEsc4 vux vuy False = lexLitChar2LexEsc3 (vux : vuy); 189.19/167.86 " 189.19/167.86 "lexLitChar2LexEsc2 (pr : vvu) = pr : []; 189.19/167.86 lexLitChar2LexEsc2 [] = []; 189.19/167.86 " 189.19/167.86 "lexLitChar2LexLitChar0 c s True = map (lexLitChar2Prefix '\') (lexLitChar2LexEsc s); 189.19/167.86 " 189.19/167.86 "lexLitChar2LexEsc13 True (yvu : c : s) = lexLitChar2LexEsc12 yvu c s (c >= '@' && c <= '_'); 189.19/167.86 lexLitChar2LexEsc13 yvy yvz = lexLitChar2LexEsc11 yvz; 189.19/167.86 " 189.19/167.86 "lexLitChar2LexEsc3 vuz = []; 189.19/167.86 " 189.19/167.86 "lexLitChar2LexEsc0 mne vu69 = lexLitChar2LexEsc00 mne vu69; 189.19/167.86 " 189.19/167.86 "lexLitChar2LexLitChar1 c s True = (c : [],s) : []; 189.19/167.86 lexLitChar2LexLitChar1 c s False = lexLitChar2LexLitChar0 c s otherwise; 189.19/167.86 " 189.19/167.86 "lexLitChar2LexEsc14 (yvu : yvx) = lexLitChar2LexEsc13 (yvu == '^') (yvu : yvx); 189.19/167.86 lexLitChar2LexEsc14 ywu = lexLitChar2LexEsc11 ywu; 189.19/167.86 " 189.19/167.86 "lexLitChar2LexEsc5 vux vuy True = span isDigit (vux : vuy) : []; 189.19/167.86 lexLitChar2LexEsc5 vux vuy False = lexLitChar2LexEsc4 vux vuy (isUpper vux); 189.19/167.86 " 189.19/167.86 "lexLitChar2LexEsc12 yvu c s True = ('^' : c : [],s) : []; 189.19/167.86 lexLitChar2LexEsc12 yvu c s False = lexLitChar2LexEsc11 (yvu : c : s); 189.19/167.86 " 189.19/167.86 "lexLitChar2LexEsc8 (xzw : s) = lexLitChar2LexEsc7 (xzw == 'x') (xzw : s); 189.19/167.86 lexLitChar2LexEsc8 xzz = lexLitChar2LexEsc6 xzz; 189.19/167.86 " 189.19/167.86 The bindings of the following Let/Where expression 189.19/167.86 "readParen0 b where { 189.19/167.86 mandatory r = concatMap mandatory2 (lex r); 189.19/167.86 ; 189.19/167.86 mandatory0 x vu48 = mandatory00 x vu48; 189.19/167.86 ; 189.19/167.86 mandatory00 x (xwu : xwv,u) = mandatory002 x (xwu : xwv,u); 189.19/167.86 mandatory00 x zx = mandatory000 x zx; 189.19/167.86 ; 189.19/167.86 mandatory000 x zx = []; 189.19/167.86 ; 189.19/167.86 mandatory001 True x (xwu : [],u) = (x,u) : []; 189.19/167.86 mandatory001 xww xwx xwy = mandatory000 xwx xwy; 189.19/167.86 ; 189.19/167.86 mandatory002 x (xwu : xwv,u) = mandatory001 (xwu == ')') x (xwu : xwv,u); 189.19/167.86 mandatory002 xwz xxu = mandatory000 xwz xxu; 189.19/167.86 ; 189.19/167.86 mandatory1 vu49 = mandatory10 vu49; 189.19/167.86 ; 189.19/167.86 mandatory10 (x,t) = concatMap (mandatory0 x) (lex t); 189.19/167.86 mandatory10 zy = []; 189.19/167.86 ; 189.19/167.86 mandatory2 vu50 = mandatory20 vu50; 189.19/167.86 ; 189.19/167.86 mandatory20 (xuz : xvu,s) = mandatory202 (xuz : xvu,s); 189.19/167.86 mandatory20 zw = mandatory200 zw; 189.19/167.86 ; 189.19/167.86 mandatory200 zw = []; 189.19/167.86 ; 189.19/167.86 mandatory201 True (xuz : [],s) = concatMap mandatory1 (optional s); 189.19/167.86 mandatory201 xvv xvw = mandatory200 xvw; 189.19/167.86 ; 189.19/167.86 mandatory202 (xuz : xvu,s) = mandatory201 (xuz == '(') (xuz : xvu,s); 189.19/167.86 mandatory202 xvx = mandatory200 xvx; 189.19/167.86 ; 189.19/167.86 optional r = g r ++ mandatory r; 189.19/167.86 ; 189.19/167.86 readParen0 True = mandatory; 189.19/167.86 readParen0 False = optional; 189.19/167.86 } 189.19/167.86 " 189.19/167.86 are unpacked to the following functions on top level 189.19/167.86 "readParenMandatory002 yyu x (xwu : xwv,u) = readParenMandatory001 yyu (xwu == ')') x (xwu : xwv,u); 189.19/167.86 readParenMandatory002 yyu xwz xxu = readParenMandatory000 yyu xwz xxu; 189.19/167.86 " 189.19/167.86 "readParenMandatory202 yyu (xuz : xvu,s) = readParenMandatory201 yyu (xuz == '(') (xuz : xvu,s); 189.19/167.86 readParenMandatory202 yyu xvx = readParenMandatory200 yyu xvx; 189.19/167.86 " 189.19/167.86 "readParenMandatory001 yyu True x (xwu : [],u) = (x,u) : []; 189.19/167.86 readParenMandatory001 yyu xww xwx xwy = readParenMandatory000 yyu xwx xwy; 189.19/167.86 " 189.19/167.86 "readParenMandatory2 yyu vu50 = readParenMandatory20 yyu vu50; 189.19/167.86 " 189.19/167.86 "readParenMandatory10 yyu (x,t) = concatMap (readParenMandatory0 yyu x) (lex t); 189.19/167.86 readParenMandatory10 yyu zy = []; 189.19/167.86 " 189.19/167.86 "readParenMandatory00 yyu x (xwu : xwv,u) = readParenMandatory002 yyu x (xwu : xwv,u); 189.19/167.86 readParenMandatory00 yyu x zx = readParenMandatory000 yyu x zx; 189.19/167.86 " 189.19/167.86 "readParenMandatory000 yyu x zx = []; 189.19/167.86 " 189.19/167.86 "readParenMandatory0 yyu x vu48 = readParenMandatory00 yyu x vu48; 189.19/167.86 " 189.19/167.86 "readParenMandatory20 yyu (xuz : xvu,s) = readParenMandatory202 yyu (xuz : xvu,s); 189.19/167.86 readParenMandatory20 yyu zw = readParenMandatory200 yyu zw; 189.19/167.86 " 189.19/167.86 "readParenReadParen0 yyu True = readParenMandatory yyu; 189.19/167.86 readParenReadParen0 yyu False = readParenOptional yyu; 189.19/167.86 " 189.19/167.86 "readParenMandatory200 yyu zw = []; 189.19/167.86 " 189.19/167.86 "readParenOptional yyu r = yyu r ++ readParenMandatory yyu r; 189.19/167.86 " 189.19/167.86 "readParenMandatory yyu r = concatMap (readParenMandatory2 yyu) (lex r); 189.19/167.86 " 189.19/167.86 "readParenMandatory201 yyu True (xuz : [],s) = concatMap (readParenMandatory1 yyu) (readParenOptional yyu s); 189.19/167.86 readParenMandatory201 yyu xvv xvw = readParenMandatory200 yyu xvw; 189.19/167.86 " 189.19/167.86 "readParenMandatory1 yyu vu49 = readParenMandatory10 yyu vu49; 189.19/167.86 " 189.19/167.86 189.19/167.86 ---------------------------------------- 189.19/167.86 189.19/167.86 (12) 189.19/167.86 Obligation: 189.19/167.86 mainModule Main 189.19/167.86 module Main where { 189.19/167.86 import qualified Prelude; 189.19/167.86 } 189.19/167.86 189.19/167.86 ---------------------------------------- 189.19/167.86 189.19/167.86 (13) NumRed (SOUND) 189.19/167.86 Num Reduction:All numbers are transformed to their corresponding representation with Succ, Pred and Zero. 189.19/167.87 ---------------------------------------- 189.19/167.87 189.19/167.87 (14) 189.19/167.87 Obligation: 189.19/167.87 mainModule Main 189.19/167.87 module Main where { 189.19/167.87 import qualified Prelude; 189.19/167.87 } 189.46/167.90 EOF