]> Git — Sourcephile - haskell/symantic-parser.git/blob - test/Golden/Splice/G4.expected.txt
machine: fix factorize out raiseException
[haskell/symantic-parser.git] / test / Golden / Splice / G4.expected.txt
1 \(input :: inp) ->
2 let !(#
3 init,
4 readMore,
5 readNext
6 #) =
7 let _ = "cursorOf"
8 in let next
9 ( t@( Data.Text.Internal.Text
10 arr
11 off
12 unconsumed
13 )
14 ) =
15 let !( Data.Text.Unsafe.Iter
16 c
17 d
18 ) = Data.Text.Unsafe.iter t 0
19 in (#
20 c,
21 Data.Text.Internal.Text arr (off GHC.Num.+ d) (unconsumed GHC.Num.- d)
22 #)
23 more
24 ( Data.Text.Internal.Text
25 _
26 _
27 unconsumed
28 ) = unconsumed GHC.Classes.> 0
29 in (# input, more, next #)
30 finalRet = \_farInp _farExp v _inp -> Data.Either.Right v
31 finalRaise ::
32 forall b.
33 Symantic.Parser.Machine.Generate.Catcher
34 inp
35 b = \(!exn) _failInp (!farInp) (!farExp) ->
36 Data.Either.Left
37 Symantic.Parser.Machine.Generate.ParsingErrorStandard
38 { Symantic.Parser.Machine.Generate.parsingErrorOffset = Symantic.Parser.Machine.Input.offset farInp,
39 Symantic.Parser.Machine.Generate.parsingErrorException = exn,
40 Symantic.Parser.Machine.Generate.parsingErrorUnexpected =
41 if readMore farInp
42 then
43 GHC.Maybe.Just
44 ( let (#
45 c,
46 _
47 #) = readNext farInp
48 in c
49 )
50 else GHC.Maybe.Nothing,
51 Symantic.Parser.Machine.Generate.parsingErrorExpecting = farExp
52 }
53 in let inputToken = Data.Proxy.Proxy :: Data.Proxy.Proxy (Symantic.Parser.Machine.Input.InputToken inp)
54 in let name = \(!ok) (!inp) (!koByLabel) ->
55 let _ = "catch ExceptionFailure"
56 in let catchHandler (!_exn) (!failInp) (!farInp) (!farExp) =
57 let _ = "catch.ko ExceptionFailure"
58 in finalRaise Symantic.Parser.Grammar.Combinators.ExceptionFailure inp farInp farExp
59 in let readFail = catchHandler
60 in if readMore (Symantic.Parser.Machine.Input.shiftRightText 3 inp)
61 then
62 let !(#
63 c,
64 cs
65 #) = readNext inp
66 in if ('a' GHC.Classes.==) c
67 then
68 let readFail = readFail
69 in let !(#
70 c,
71 cs
72 #) = readNext cs
73 in if ('b' GHC.Classes.==) c
74 then
75 let readFail = readFail
76 in let !(#
77 c,
78 cs
79 #) = readNext cs
80 in if ('c' GHC.Classes.==) c
81 then
82 let readFail = readFail
83 in let !(#
84 c,
85 cs
86 #) = readNext cs
87 in if ('d' GHC.Classes.==) c
88 then
89 let _ = "resume"
90 in ok
91 init
92 Data.Set.Internal.empty
93 ( let _ = "resume.genCode"
94 in 'a' GHC.Types.: ('b' GHC.Types.: ('c' GHC.Types.: ('d' GHC.Types.: GHC.Types . [])))
95 )
96 cs
97 else
98 let _ = "checkToken.else"
99 in let failExp =
100 Data.Set.Internal.Bin
101 1
102 ( Symantic.Parser.Grammar.Combinators.SomeFailure
103 ( case inputToken of
104 (Data.Proxy.Proxy :: Data.Proxy.Proxy tok') -> Symantic.Parser.Grammar.Combinators.FailureToken 'd'
105 )
106 )
107 Data.Set.Internal.Tip
108 Data.Set.Internal.Tip
109 (#
110 farInp,
111 farExp
112 #) = case (GHC.Classes.compare `Data.Function.on` Symantic.Parser.Machine.Input.offset) init cs of
113 GHC.Types.LT ->
114 (#
115 cs,
116 failExp
117 #)
118 GHC.Types.EQ ->
119 (#
120 init,
121 failExp GHC.Base.<> Data.Set.Internal.empty
122 #)
123 GHC.Types.GT ->
124 (#
125 init,
126 Data.Set.Internal.empty
127 #)
128 in readFail Symantic.Parser.Grammar.Combinators.ExceptionFailure cs farInp farExp
129 else
130 let _ = "checkToken.else"
131 in let failExp =
132 Data.Set.Internal.Bin
133 1
134 ( Symantic.Parser.Grammar.Combinators.SomeFailure
135 ( case inputToken of
136 (Data.Proxy.Proxy :: Data.Proxy.Proxy tok') -> Symantic.Parser.Grammar.Combinators.FailureToken 'c'
137 )
138 )
139 Data.Set.Internal.Tip
140 Data.Set.Internal.Tip
141 (#
142 farInp,
143 farExp
144 #) = case (GHC.Classes.compare `Data.Function.on` Symantic.Parser.Machine.Input.offset) init cs of
145 GHC.Types.LT ->
146 (#
147 cs,
148 failExp
149 #)
150 GHC.Types.EQ ->
151 (#
152 init,
153 failExp GHC.Base.<> Data.Set.Internal.empty
154 #)
155 GHC.Types.GT ->
156 (#
157 init,
158 Data.Set.Internal.empty
159 #)
160 in readFail Symantic.Parser.Grammar.Combinators.ExceptionFailure cs farInp farExp
161 else
162 let _ = "checkToken.else"
163 in let failExp =
164 Data.Set.Internal.Bin
165 1
166 ( Symantic.Parser.Grammar.Combinators.SomeFailure
167 ( case inputToken of
168 (Data.Proxy.Proxy :: Data.Proxy.Proxy tok') -> Symantic.Parser.Grammar.Combinators.FailureToken 'b'
169 )
170 )
171 Data.Set.Internal.Tip
172 Data.Set.Internal.Tip
173 (#
174 farInp,
175 farExp
176 #) = case (GHC.Classes.compare `Data.Function.on` Symantic.Parser.Machine.Input.offset) init cs of
177 GHC.Types.LT ->
178 (#
179 cs,
180 failExp
181 #)
182 GHC.Types.EQ ->
183 (#
184 init,
185 failExp GHC.Base.<> Data.Set.Internal.empty
186 #)
187 GHC.Types.GT ->
188 (#
189 init,
190 Data.Set.Internal.empty
191 #)
192 in readFail Symantic.Parser.Grammar.Combinators.ExceptionFailure cs farInp farExp
193 else
194 let _ = "checkToken.else"
195 in let failExp =
196 Data.Set.Internal.Bin
197 1
198 ( Symantic.Parser.Grammar.Combinators.SomeFailure
199 ( case inputToken of
200 (Data.Proxy.Proxy :: Data.Proxy.Proxy tok') -> Symantic.Parser.Grammar.Combinators.FailureToken 'a'
201 )
202 )
203 Data.Set.Internal.Tip
204 Data.Set.Internal.Tip
205 (#
206 farInp,
207 farExp
208 #) = case (GHC.Classes.compare `Data.Function.on` Symantic.Parser.Machine.Input.offset) init inp of
209 GHC.Types.LT ->
210 (#
211 inp,
212 failExp
213 #)
214 GHC.Types.EQ ->
215 (#
216 init,
217 failExp GHC.Base.<> Data.Set.Internal.empty
218 #)
219 GHC.Types.GT ->
220 (#
221 init,
222 Data.Set.Internal.empty
223 #)
224 in readFail Symantic.Parser.Grammar.Combinators.ExceptionFailure inp farInp farExp
225 else
226 let _ = "checkHorizon.else"
227 in let failExp =
228 Data.Set.Internal.Bin
229 1
230 ( Symantic.Parser.Grammar.Combinators.SomeFailure
231 ( case inputToken of
232 (Data.Proxy.Proxy :: Data.Proxy.Proxy tok') -> Symantic.Parser.Grammar.Combinators.FailureHorizon @tok' 4
233 )
234 )
235 Data.Set.Internal.Tip
236 Data.Set.Internal.Tip
237 (#
238 farInp,
239 farExp
240 #) = case (GHC.Classes.compare `Data.Function.on` Symantic.Parser.Machine.Input.offset) init inp of
241 GHC.Types.LT ->
242 (#
243 inp,
244 failExp
245 #)
246 GHC.Types.EQ ->
247 (#
248 init,
249 failExp GHC.Base.<> Data.Set.Internal.empty
250 #)
251 GHC.Types.GT ->
252 (#
253 init,
254 Data.Set.Internal.empty
255 #)
256 in readFail Symantic.Parser.Grammar.Combinators.ExceptionFailure inp farInp farExp
257 name = \(!ok) (!inp) (!koByLabel) ->
258 let _ = "catch ExceptionFailure"
259 in let catchHandler (!_exn) (!failInp) (!farInp) (!farExp) =
260 let _ = "catch.ko ExceptionFailure"
261 in if ( \( Data.Text.Internal.Text
262 _
263 i
264 _
265 )
266 ( Data.Text.Internal.Text
267 _
268 j
269 _
270 ) -> i GHC.Classes.== j
271 )
272 inp
273 failInp
274 then
275 let _ = "choicesBranch.then"
276 in let _ = "resume"
277 in ok
278 farInp
279 farExp
280 ( let _ = "resume.genCode"
281 in \x -> x
282 )
283 failInp
284 else
285 let _ = "choicesBranch.else"
286 in finalRaise Symantic.Parser.Grammar.Combinators.ExceptionFailure failInp farInp farExp
287 in name
288 ( let _ = "suspend"
289 in \farInp farExp v (!inp) ->
290 name
291 ( let _ = "suspend"
292 in \farInp farExp v (!inp) ->
293 let _ = "resume"
294 in ok
295 farInp
296 farExp
297 ( let _ = "resume.genCode"
298 in \x -> v GHC.Types.: v x
299 )
300 inp
301 )
302 inp
303 Data.Map.Internal.Tip
304 )
305 inp
306 Data.Map.Internal.Tip
307 in name
308 ( let _ = "suspend"
309 in \farInp farExp v (!inp) ->
310 name
311 ( let _ = "suspend"
312 in \farInp farExp v (!inp) ->
313 let _ = "resume"
314 in finalRet
315 farInp
316 farExp
317 ( let _ = "resume.genCode"
318 in GHC.Show.show (v GHC.Types.: v GHC.Types . [])
319 )
320 inp
321 )
322 inp
323 Data.Map.Internal.Tip
324 )
325 init
326 Data.Map.Internal.Tip