Caml1999O031 T @( @(@(D C A(D C  A (D C  A (D C 86" > (D C D C 86" 86" EC> A (@(>($)*W!)TuCUz " C%C 3'G FEDC # D C + 2#GC& F EDC " +2#GC& D C " D C +[ 2#GC& E DC 4 $ E DC D85! D CF85! D C "   +  4 #4 # GD" G4# GD"GC&F EDC 85! D C "  +   4 #  4# GD"GC& D C " @ C%E DC +8 2#2# GD"GC&E DC + h2#2# GD"GC&E DC " +@4#GC& D C " + 2#GC&D C + 2#GC&D C +| 2#GC&?()* G G ! E"D?>?( G G! EDC>?(V5(c()*c]6@ YF VC VdT[TcC W[C Y C8G"ZT"8 yV Vg E8G!8$"[ C E D 8$# VC T [ +aihE@@ +3+C!>TZ( yVLF VC VTVcTTT G G EDC>?C! G F E+C>(E?()*+ 8"@ ?8G!A[ AA(C? hF#@(FU E!C&+D!%)*E DCh4"8" G ! WWC AAC% C E D C 8!   > EcT56@[GhE +CE">(D C +MG!GC" G F E D+C!>(h @l'A()*W(=eVD VT C T58!+l 4#GC&E DCA1$  " AC%)* 4"8" G%)*D C 4# 4#@G%)* 4"8"G% &)*04 43, s7!  +( )*W@ 2!8&G F EDC 3# D C 2" $D C 4" D C 2" @()* @ " @ 4# @()* 8# 3"8" @()*D C  ! VCC 8G"i F4# EhyVg G8G!8$"G GEDCE!    8  G68 !68 !A E D?? CA "G Gi F# E D  "h8 8! Dh @@  @@( c 4" @@()* 4!8&C(C8G!6 ?8&5 8|&D(C(C8G!6 ?8&5 8|&C yVE C CD VA D + + +8!!8 ! +8(!! 8!! 6? ?8- ?( D + +i +`8!!8 ! 8!! 6? ?8- ?( c(7C? &)*D C ! V.C D8!68!8"8 ! C AC 8F#?( (W&&&&&&&&&&&&&&&&&&&&&C GGV?(c()*D C >()* +8'c(D C @(VD C + 2! D"C&+C&%)*V*D C !VV!V 8" A( !@2&56@[)*,h &G(Ehz(+ + + +8(" V3D V& 8(" VD V i@( i"?( h@(h"?(8"?(c(?(V C + C&+C&)* @%)* &c(cD!hD!@(D C GUG FUF E E8$"+CCG">()* CD'c D%cD!%)*G F E+CG">((chh +F!>( @C')*8! + E"%)*! D +@(%D(!%" C?#@()*VD C + D!% &d +@()* h C')* C# C#@()*D Dn +@()* C#%)*D +@()*c()* 'd +@()* C&)* +8# !% G  EDC>%F8! +G #%)* + Fh #%)*VC D C hh>(()*!Vh@(n68#8 ! ? @?@(Wc(d()*+ +8!!85! D C ! +|8' )* G G F EiC>" F8! ???68 !G ? A! hh>()*G @ F8 !! G EDCAA()*E D C h@ !@ ?@6A()*D C !@ ?@()*D C j @@h @@(C (c]6@ + + + + +zjlq??? ++ + + A +6 +h + @ + + ++ +_ +W  +@   > + + + ++hhh +q G>+_ +Q @ +. ,S+   >  + + +     , #N+p+80! ?9z8A!,7#Tmc&_none_@@AA"??A@@@@@@@@@@,7 A"??Að@%arrayH8@@M@A@A@@@@@@K@@@$boolE8@@%false^@@U@$true_@@[@@@A@@@@@\@A@$charB8@@@A@@@@@`@A@#exnG8@@AA@@@@@d@@@5extension_constructorP8@@@A@@@@@h@@@%floatD8@@@A@@@@@l@@@*floatarrayQ8@@@A@@@@@p@@@#intA8@@@A@@@@@t@A@%int32L8@@@A@@@@@x@@@%int64M8@@@A@@@@@|@@@&lazy_tN8@@O@A@A@Y@@@@@@@@$listI8@@P@A"[]a@@@"::b@@@Q@@@ @@A@Y@@@@@@@@)nativeintK8@@@A@@@@@@@@&optionJ8@@S@A$Nonec@@@$Somed@@@@@A@Y@@@@@@@@&stringO8@@@A@@@@@@@@$unitF8@@"()`@@@@@A@@@@@@A@ .Assert_failure\ p@@@@Jm@@@@@@V@@A࠰=ocaml.warn_on_literal_pattern@@0Division_by_zeroY @@@A꠰  @+End_of_fileX !@@@A򠰠@'FailureU )@%@@A@0Invalid_argumentT 2@.@@A$#@-Match_failureR ;@:67@@\@@A21@ )Not_foundV I@@@A:9@-Out_of_memoryS Q@@@A"B%A%@.Stack_overflowZ Y@@@A*J-I-@.Sys_blocked_io[ a@@@A2R5Q5@)Sys_errorW i@e@@A;[>Z>@:Undefined_recursive_module] r@qmn@@c@@AIiLhL@ %bytesC8@@@A@@@@@P@@@&Stdlib&Lambda4tmc_call_informationXA8@@#locY@/scoped_location@@@ d-lambda/tmc.mlV9;V9P@@jC(explicitZ@$@@@ g WQSWQb@@vD@@A@@@@@UXcd@@@@zB3subterm_informationuB8@@)tmc_callsv@1@@@ %@@@ '&Z'Z@@G@@A@@@@@*Yee+[@@@AF3ambiguous_argumentswC8@@(explicitx@Q@@@ 5:];]@)ocaml.doc When [explicit = true], we have an ambiguity between arguments containing calls that have been explicitly marked [@tailcall]. Otherwise we have an ambiguity between un-annotated calls. I^Ja@@@@@@@I)argumentsy@2C@@@ 8@@@ :Zb[b@@J@@A@@@@@^\_c@@@@H%errorzD8@@?Ambiguous_constructor_arguments{A@@@ J@@pfqf @@L@@A@@@@@te@@@AK%Error|E @(Location!t@@@ C&@@@ D@@Ah""h"G@@M&offsetF8@@&Offset吠&lambda@@@j@@pp@b U In the OCaml value model, interior pointers are not allowed. To represent the "placeholder to mutate" in DPS code, we thus use a pair of the block containing the placeholder, and the offset of the placeholder within the block. In the common case, this offset is an arbitrary lambda expression, typically a constant integer or a variable. We define ['a destination] as parametrized over the offset type to represent formal destination parameters (where the offset is an Ident.t), and maybe in the future statically-known offsets (where the offset is an integer). q{ ' )@@@@@@@S@@A@@@@@p@@@AO+destinationF8&offset@ G@A#var@%Ident!t@@@`lgilgv@@.P&offset@H@cmwymw@@8Q#loc@)Debuginfo/Scoped_location!t@@@gnn@@JR@@A@Y@@@@@kJJo@@@@PN+offset_code@j@@@G@c@@@G@@@G@@} + /} + :@@fT.add_dst_params@]Q!t@@@@@@G@@h@@@G@&Lambda*value_kind@@@G@@@H@@@@G@G@@@@G@@@G@@@G@@= K O> K ]@@V,add_dst_args@@@@@@@G@@#3&lambda@@@H@ @@@G@0 G@@@@G@@@G@@@G@@lB  mB  @@Z-assign_to_dst@̠@@@|G@*@@@)G@$@+@@@FG@70@@@BG@8@@9G@%@@&G@#@E % )E % 6@@^&ConstrG@!tI8@@#tag@@@@O  O  @@N$flag@(Asttypes,mutable_flag@@@P  P  @@ O%shape@+block_shape@@@Q  Q  @@-P&before@&lambda@@@ @@@ R  R  @@?Q%after@&lambda@@@@@@S  $S  7@@QR#loc@/Scoped_location!t@@@T 8 <T 8 ^@@aS@@A@@@@@N  U _ b@ The type [Constr.t] represents a reified constructor with a single hole, which can be either directly applied to a [lambda] term, or be used to create a fresh [lambda destination] with a placeholder.  J   M  @@@@@@@@@rMA@%apply@|@@@.@-&lambda@@@/2&lambda@@@0@@1@@2@$Y  %Y  @ꐠ X [apply constr e] plugs the expression [e] in the hole of the constructor [const]. 1W d f2X  @@@@@@@T@0with_placeholder@@@@3@@@@@4@@@6`&lambda@@@7@@8e&lambda@@@9@@:@@;@W]dfX]d@ s [with_placeholder constr body] binds a placeholder for the constructor [constr] within the scope of [body]. d[  e\"c@@@@@@@U@,delay_impure(block_idg@@@<@@@@=@@@@@>&lambda@@@?@@@&lambda@@@A@@B@@C@@D@mm@S  We may want to delay the application of a constructor to a later time. This may move the constructor application below some effectful expressions (for example if we move into a context of the form [foo; bar_with_tmc_inside]), and we want to preserve the evaluation order of the other arguments of the constructor. So we bind them before proceeding, unless they are obviously side-effect free. [delay_impure ~block_id constr body] binds all inpure arguments of the constructor [constr] within the scope of [body], which is passed a pure constructor. [block_id] is a counter that is used as a suffix in the generated variable names, for readability purposes. _lW@@@@@@@V@@@I  @W#DpsJ@#dpsM8!a@(@A@A$tail@@@(#dst7@@@(@@@(O@(@@(@@(ʠY@@@@@^`^@ A term parameterized over a destination. The [tail] argument is passed by the caller to indicate whether the term will be placed in tail-position -- this allows to generate correct @tailcall annotations. j@@@@@@@@@@A@!tN8!a@(@A@A@G@B@@@@@@@PA@$make@M &lambda@@@(@@@("&lambda@@@(@@@(@@(@@@o@#run@7(&lambda@@@(@@@(v2&lambda@@@(@@@(@@(@%&@@@1delay_constructor@!t@@@(@^O&lambda@@@(@@@(hY&lambda@@@(@@@(@@)@@)@LM@@@&lambda@j&lambda@@@)s&lambda@@@)@@@)@@)@fg2@@@#map@@!a@)O@)!b@)O@)@@) @@@@) @@@) @@)@@)@353Y@@@$pair@!a@) O@)@@@)@ɠ!b@)"O@)@@@)Ԡ@@)@@@)@@)@@)@Z\Z@@ @$uniti@@@)#@@@)%@@@2@@ . The type ['a Dps.t] (destination-passing-style) represents a version of ['a] that is parametrized over a [lambda destination]. A [lambda Dps.t] is a code fragment in destination-passing-style, a [(lambda * lambda) Dps.t] represents two subterms parametrized over the same destination. +L@@@@@@@MM_1k1n@C&ChoiceIO@!tP8!a@)@A#dps@S!tR@)@@@*7n7r7n7@@c&direct@@@@@*"R@*@@* 77 77@@s)tmc_calls@&@@@* @@@* 7777@@1benefits_from_dps@>@@@*'77(77@@9explicit_tailcall_request@J@@@*377478@@@@A@_@@@@@97^7`:88 @ ? An ['a Choice.t] represents code that may be written in destination-passing style if its usage context allows it. More precisely: - If the surrounding context is already in destination-passing style, it has a destination available, we should produce the code in [dps] -- a function parametrized over the destination. - If the surrounding context is in direct style (no destination is available), we should produce the fallback code from [direct]. (Note: [direct] is also a function (on [unit]) to ensure that any effects performed during code production will only happen once we do know that we want to produce the direct-style code.) - [tmc_calls] tracks the function calls in the subterms that are in tail-modulo-cons position and get rewritten into tailcalls in the [dps] version. - [benefits_from_dps] is true when the [dps] calls strictly more TMC functions than the [direct] version. See the {!choice_makeblock} case. - [explicit_tailcall_request] is true when the user used a [@tailcall] annotation on the optimizable callsite. When one of several calls could be optimized, we expect that exactly one of them will be annotated by the user, or fail because the situation is ambiguous. F8 8G=M=R@@@@@@@@@A@&lambda@h&lambda@@@*3Q@*.{s&lambda@@@*<@@@*;Q@*/@@*0Q@*-@f=T=Zg=T=`@@@#map@@@@+,Q@*@@+Q@*@@*Q@*@@@@++Q@*Q@*@@@*Q@*@@*Q@*@@*Q@*@>>>>@@@&direct@!a@+4Q@+6@@@+R@-(@@-)R@-"@@-#R@- @[BB\BB@@@$and+@p@-Y@@@-iR@-I@o@-Z@@@-jR@-Oi @@-g@@@-fR@-P@@-QR@-J@@-KR@-H@BBBB@@@@@BtBvBB@@@&option@W!a@-R@-@@@-@@@-R@-ȠmR@-@@@-@@@-R@-@@-R@-@BBBB@@@$list@!a@.R@.3@@@.=@@@.2%LL%LL@@9&dps_id`@!t@@@>5&LL&LL@@G+direct_kinda@-function_kind@@@>8'LL'LL@@T@@A@@@@@$LL(MM@@@@X'contextJS8@@+specialized@?#Map!tB@@@6@@@6"LL "LL@@q@@A@@@@@ !LrLr #LL@@@Au%lletsb@(let_kind@@@>T@>_@@@@>T@>e@$listI%Ident!t@@@>T@>@@@>T@>@@>T@>}@@@>T@>k@@@@>T@>qT@>r@@>sT@>l@@>mT@>f@@>gT@>`@@>aT@>^@T*MMU*MM @@.find_candidatel@@@@>T@>&A)lfunction@@@>T@>@@@>T@>@@>T@>@r/MMs/MM@@/declare_bindingp@@@@?T@>@%Ident#Map#key@@@?T@>=@@@?T@>@@>T@>!T@>@@>T@>@@>T@>@3MM3MM@@ &choice@.@@@`/T@@r@V@@@CnT@@s$tail@@@^ @@@b@@@bT@^@@^T@@t@@@u@@@vU@@l@=OGOO=OGOU@@ 6(traverse@-T@@w@)T@@y@@@\T@@x@@@z@@@{U@@m@@@ J,traverse_let@AT@@|@c@@@_T@@}@DT@@~PT@@ҠT@_[/T@_\@@_ZT@`:@@@`LT@@@@@@@@@@@@@@U@@n@ !@@ v/traverse_letrec@mT@@@$listI7T@Cmu@@Cl@@@CkT@@T@@/@@@_YT@@@@@@@@@@@U@@o@56@@ 0traverse_binding@T@@@T@@@%T@@KT@@@@@@@@@@@U@@p@IJ@@ -traverse_list@T@@@<T@B@@@BT@@@@@\T@@@@@@@@U@@q@e8<f8I@@ 'rewrite&@@@@cT@c@@@cT@c@@cT@c@zw{{w@@  ޠ@'*match*S@@AH@@BF@@G@@AA@@ND@@ABCC@@"E@@L@@ABDK@@AJ@@AI@@B@@5R@@ABCM@@iP@@AN@@O@@ZQ@@ABCDE@SA,7 [`@A A  @.@A-+B)(C&%D! E@R,7  @A)Tmc.(fun)A@  @@,7 "wAA+Tmc.rewriteA@ ! @@,7< (3MN;O OEAA3Tmc.declare_bindingA@ ' &@@,7, ./MM1MM@A2Tmc.find_candidateA@ - ,@@,7 4*MM -MoMAA)Tmc.lletsA@ 3 2@@,7 :~7G7W@A*Tmc.ChoiceA@ 8 7@@,6 ?AAð 5|zQO75@@@@@fca_53  ec O@kiBg@N@@Ah@BCg@h@AcJ@@KK@@tQ@@ABCH@@IP@@AI@@Bi@yO@@AL@@M@@ABCDE@Q@,6 q FF0 LMLXAA %Tmc.Choice.find_nonambiguous_tmc_callA@ p o@@,6 w BB CICmAA1Tmc.Choice.optionA@ v u@@,6p } BtB@A1Tmc.Choice.SyntaxA@ { z@@,6` AA> 0C@O@@A@B.@-@AC*@N@@A)@B@&%BCDE@O@,6\  /BB 0BBAA6Tmc.Choice.Syntax.and+A@  @@,6L  5BB 6BBAA6Tmc.Choice.Syntax.let+A@  @@,6<  ;AA  <AA@A/Tmc.Choice.unitA@  @@,6   AA6AC BA6AQ@A5Tmc.Choice.unit.(fun)A@  @@,6  G?? HAAAA/Tmc.Choice.pairA@  @@,5  M?X?b N?~?AA.Tmc.Choice.dpsA@  @@,5  S?(?5 T?G?VAA1Tmc.Choice.directA@  @@,5  Y>> Z>>AA.Tmc.Choice.mapA@  @@,5 İ _=T=a `> >AA1Tmc.Choice.lambdaA@  @@,5 ʰ e@A'Tmc.DpsA@  @@,5x AA ±#dpsK8!a@@A@A$tail @@@#dstޠ @@@@@@M@@@@@Y@@@@@  @@@@ X!tL8!a@@A$code@'delayed  !t@@@@@@EN@@@@@@  @@ (Z1delayed_use_count@ @@@  7@@ 4[@@A@Y@@@@@  8;@  We want to optimize nested constructors, for example: {[ (x () :: y () :: tmc call) ]} which would naively generate (in a DPS context parametrized over a location dst.i): {[ let dstx = x () :: Placeholder in dst.i <- dstx; let dsty = y () :: Placeholder in dstx.1 <- dsty; tmc dsty.1 call ]} when we would rather hope for {[ let vx = x () in let dsty = y () :: Placeholder in dst.i <- vx :: dsty; tmc dsty.1 call ]} The idea is that the unoptimized version first creates a destination site [dstx], which is then used by the following code. If we keep track of the current destination: {[ (* Destination is [dst.i] *) let dstx = x () :: Placeholder in dst.i (* Destination *) <- dstx; (* Destination is [dstx.1] *) let dsty = y () :: Placeholder in dstx.1 (* Destination *) <- dsty; (* Destination is [dsty.1] *) tmc dsty.1 call ]} Instead of binding the whole newly-created destination, we can simply let-bind the non-placeholder arguments (in order to preserve execution order), and keep track of a list of blocks to be created along with the current destination. Instead of seeing a DPS fragment as writing to a destination, we see it as a term with shape [dst.i <- C .] where [C .] is a linear context consisting only of constructor applications. {[ (* Destination is [dst.i <- C .] *) let vx = x () in (* Destination is [dst.i <- C (vx :: .)] *) let vy = y () in (* Destination is [dst.i <- C (vx :: vy :: .)] *) (* Making a call: reify the destination *) let dsty = vy :: Placeholder in dst.i <- vx :: dsty; tmc dsty.1 call ]} The [delayed] argument represents the context [C] as a list of reified constructors, to allow both to build the final holey block ([vy :: Placeholder]) at the recursive call site, and the delayed constructor applications ([vx :: dsty]). In practice, it is not desirable to perform this simplification when there are multiple TMC calls (e.g. in different branches of an [if] block), because it would cause duplication of the nested constructor applications. The [delayed_use_count] field keeps track of this information, it counts the number of syntactic use sites of the delayed constructors, if any, in the generated code.  <> )Z)^@@@@@@@@@ GY,write_to_dst@r@@@ O@@@ NM@ @ˠmf@@@ N@ `@@@ oM@ #@@@@ YM@ )@@@ XM@ *@@ +M@ $@@ %M@ @@ M@ @ )`)f )`)r@@ {\&lambda@ 2&lambda@@@ M@  =&lambda@@@ @@@ M@ @@ M@ @ 0)) 1))@@ b$unit @@@!{@@@!z@ @&++ A&++@@ f#map@@!a@#M@"!b@"`M@" @@"'M@"@ȠM@"/@@@"4M@",РM@"9@@@"=M@"-@@".M@"@@"M@"@ o-++ p-++@@ g$pair@!a@$DM@#@@@#M@# @!b@$JM@#@@@#"M@#!M@#'M@#(@@#/@@@#.M@#@@#M@# @@# M@# @ 3,8,> 3,8,B@@ m#run@!a@$|M@$\@@@$bM@$YL M@$g@@@$kM@$Z@@$[M@$X@ :-'-- :-'-0@@ .s+reify_delay@_ &lambda@@@$@@@$M@$E &lambda@@@$@@@$M@$@@$M@$@ >-- >--@@ Qw.ensures_affine@\ &lambda@@@&@@@&M@&h &lambda@@@&@@@&M@&@@&M@&@ K.. K./@@ t$make@H@@@'WM@'6@@@'-- I..AA3Tmc.Dps.reify_delayA@  @@,5$  :-'-1 <-]-~AA+Tmc.Dps.runA@  @@,5  3,8,C 8-"-%AA,Tmc.Dps.pairA@  @@,5  -++ 1,3,6AA+Tmc.Dps.mapA@  @@,4  &++( +++@A,Tmc.Dps.unitA@  @@,4  '+*+5 )+`+e@A2Tmc.Dps.unit.(fun)A@  @@,4  ))  *w*zAA.Tmc.Dps.lambdaA@  @@,4  )`)s ))AA4Tmc.Dps.write_to_dstA@  @@,4  n @A*Tmc.ConstrA@  @@,4 AA !tH8@@#tag@ @@@ p p@@ 5d$flag @ %,mutable_flag@@@ʰ q q@@ Ce%shape @ +block_shape@@@Ͱ r r.@@ Pf&before@ Р &lambda@@@@@@Ұ s/3 s/G@@ bg%after@  &lambda@@@@@@װ tHL tH_@@ th#loc@ x ?x@@ j/tmc_placeholderU @@@I@@ J}MS K}Mb@@ n0with_placeholderV@+@@@I@@@  @@@@@@ ~&lambda@@@@@I@ @@@I@@@I@@@I@@ u v@@ o,delay_impure^(block_id v@@@@@@@@@@@@ &lambda@@@@@ &lambda@@@@@@@@@@  $@@v@B@F@@A@0I@@AB@iG@@_H@@ABCD@I@,4  @A=Tmc.Constr.delay_impure.(fun)A@@@,4@7Tmc.Constr.delay_impureA)bind_list_(block_id#intA@@@J@*arg_offset#intA@@@J@@ @@@J@@@@J@ @@àK@^@@@J@ @@@J@A@J@&J@'@@(J@!@@"J@@@J@@@J@@ V^ Vg@@gwbbuau@QI@@ABm@_^BCD@I@,4|p Vh AA !Tmc.Constr.delay_impure.bind_listA@on@@,4lv  AA;Tmc.Constr.with_placeholderA@ut@@,4X|  @A:Tmc.Constr.tmc_placeholderA@{z@@,4P @AA@~@@,4H ! "@A A@@@,40 &x '{)KAA0Tmc.Constr.applyA@@@,4  ,E % 7 -G  AA1Tmc.assign_to_dstA@@@,4 2B   3C  #AA0Tmc.add_dst_argsA@@@,4 8 K ^ 9@  AA2Tmc.add_dst_paramsA@@@,3 >} + ; ?} + IAA/Tmc.offset_codeA@@@,3 AA@@@,3 F} + H@@A ^ K} + + @!t @@@@ S} + C T} + D@@U@%paramA@@B@@AB@@BA,3%A"@à@ @AA,3Ͱ h@  0@A/A@@@,3Ѱ l@  @A3A@@@,3հ p@  8@A7A@@@,3ٰ t@  @A;A@@@,3x@=A z } K KE@#var @@@@  K `  K c@@W&offset ~@@@@  K e  K k@@X¶ms }@  K   K @@Y@C@@AEB@@A@@%D@@ABC@@DA,3dqAn@. @ @ @ABB,3P C  }@A|A@@@,3H C  @AA@@@,3< C  @AA@@@,34  C  @ bH@A  B  @#var @@@@ B   B  @@7[&offset @@@@ B   B  @@A\$args @ B   B  @@H]C@ A@@AC@@B@@%D@@ABC@ B@@A@E@,3(XD@A2SDA,3\A@3W@@A@B B,3b F P R@AA@_^@@,2fG  G  @AA@dc@@,2kG  G  @AA@ih@@,2p G   AAA@ml@@,2tG  @ H@{Ac E % %@#var b@@@+@"E % 8#E % ;@@_&offset G@}I@,@,E % =-E % C@@`#loc \@@@1@6E % E7E % H@@a#lam @=E % J>E % M@@b@ A@@AC@@#D@@AB@@1E@@ABC@ eB@@A@G@,2SG  RAA&A@@@,2Z@(ACEA,2/A,@C@@A@BB,2ưaz;@A:A@@@,2ʰezfz'@A?A@@@,2T @AAJoxI@&constrJ@Ntx@@k!tF@zx{x@@l*block_argsVSI@w@@@vJ@@yy@@m@C@@A!B@@A@@AB@@CA,2Pyy@AsA2@ B B ,2L y@@z@@J@lL@[@@J@h. @@J@g@J@fAKC@,24y@AA@@@,2!y@@@S!B@,2%LP@AA@"!@@,1)@ l@@I@J@A@&constrX@@@Cp$bodyY@@@@@@@@@@@@@@@Vq2k_with_placeholderZ @@@J@@7?7Q@@br/placeholder_pos[#intA@@@VJ@K@ @@qs3placeholder_pos_lam\ @@@aJ@^@@@}t)block_var]!t@@@|J@r@""#+@@u@F@@ANA@@BUB@@?C@@A4D@@'E@@ABC@B@@C@@AB@F@,1<x@A*A@@@,1@A@A/A@@@,1@1AwFA,1I.JH@A8A~@%@A$#CE ,1SB@@AAE@,1WX@AFA@@@,1\@AJA@@@,1Ű`a@AOA@@@,1ʰeT@@SAǠ=@;@;@ABC8DA,1԰op@A^AӠ&I@G@ABCC ,1xްyh@@gACA,1tTZT@AnB6Y@BRB ,1dT`T~@AwA@@@,17;|@@{@ B@,0>T@A 'Tmc.Constr.delay_impure.bind_list.(fun)A@@@,0>D@@AꐰVZ@a@ViVq@@xb@VsV}@@y'lambdasc@V~V@@z!kd@VV@@${.can_be_delayede@j@@@0K@-@@@9K@.@@/K@,@@@9|(bindingshy@@@ @@@@@K@\@@@jK@H@@@T}$argsi@@@kK@I@@@a~$body J@@#-#1@@iBd@F@@A`C@@G@@;H@@ABCkD@@I@@AVE@@B^A@@gB@@ACD@@IA,0#4#:@AA@@ABD H ,0(#)@@A H@,0,- @^D@@LK@i(A@0@A+C"E@,0< @ mW@L@m@@L@lL@L@>AE@,0O@@x@@L@N@@@L@ 0 U@@L@N@N@@L@N@@@L@N@#N@@L@N@~@@L@@L@oAGF@,0E@AA@@@,0y@@xAOE@,0u}@A 0Tmc.Constr.delay_impure.bind_list.can_be_delayedA@@@,0x@@@Y@@A}@BC|D@,0`@@Aڐ @@EgA@@A@@AB,0T @@A A,/"A@ A ,/@AA@@@,/@A!A@@@,/@A%A@@@,/ @A*A@@@,/%@,A'!ij@@@@@@3#lamkzN@@  @@<@!vl@@@P@@ZlZm@@HAC@$B@@AA@@C@@AB@CC@@AKB@@4D@@AB@CA,/]Zp@AgA;\@@@ABB ,/g @&stringO@@Q@Q@Q@{COpB@,/wCT@@ATuB@,/||7B@AA@zy@@,/l@A[| B@,/d1@?@@O@P@Ah-B@,/T+@@@l1B@,/</0@@A'binding Ӡ @@J@J@gJ@@J@J@@@J@J@@J>YK>`@@C$body[J@@S>aT>e@@D@&B@@A@@AB@@B@,/4İ_`@AA@@@,/@A4!v(@ij@@E#lam)@pq@@FԠ@C@@A @ @AD@@E@@ABC"E@,.is!@@@P+B@,. O@@@1@@I@@@I@5@@I@AI@@I@C(block_id@@@M@ @@ G&constr@@@`@ @@H$body@@@@s(@@@r@@q@@@'I"@+C@@AA@@#B@@AB@B@@A@D@,.4S @AA@10@@,.8O#@@"@<4C@,.;@@@@@J@,@@J@+@@J@)AJ@*@J@(7CT'vbefore@@@@@@@W^@@_J*arg_offset/@@@K@@bjbt@@lKg@B@@A A@@B@YB@@AwC@@eE@@ArD@@BC@C@,.tl@AkA@}|@@,.XIo@@nA6B@,.L"bw#b@Z@@L@L@M@{AC@%@A$A@,.42bf@@@IA@,. 6@AA@@@,-:@@@S&vafterP@@@R@@@Q@GH@@L@A@@A@C@@AB@@kD@@AB@A@,-Z))[))@@@@M@ M@@M@ L@M@ KAl)`)b@#dst@q)`)v@@]'delayed@w)`)wx)`)~@@^!tv@~)`))`)@@_@B@@AC@@A@@AB@B@@C@@AB@D@,-))@N@ ^C0C@,-))))@A:Tmc.Dps.write_to_dst.(fun)A@@@,-E@@@9C@,-))))@@ @@!t@))))@@`&constrN@ z@))))@@a@ A@@AB@@B@*B@@A@B@,-l')* @AA@$#@@,-d+* **U*Z@A4Tmc.Dps.lambda.(fun)A@*)@@,-L1 @@ [))%@!v@@@ @))))@@@c;@ A@@A@B@@A@A@,-4I*4*:*4*T@@@'delayed ? >@@@ @@@ @* ** *#@@\d#dst o n@@@ @@@ @* *-* *0@@jee@ C@@AA@@B@@AB@@C@@A 1B@@B@C@,-{(+W+](+W+_@@r@ y@ABC@@A@@C@,-&-++@AA@@@,-*.+++/+,@A1Tmc.Dps.map.(fun)A@@@,, @@ !f@@@"(@7-++8-++@@h!dݠ@@@"5@B-++C-++@@i@A@@AB@@B@@B@,,N/++O/+,@ M@"P@"(C)'delayed  @@@"Z@@@"Y@c.++d.++@@j$tail @@@"j@m.++n.++@@k#dst  @@@"x@@@"w@{.++|.++@@lߠ@*C@@AA@@B@@AB@OC@@AZB@@B@C@,,/++A@@d@;C@,,3,8,k@AA@@@,,4,m,x5,,@A2Tmc.Dps.pair.(fun)A@@@,,p @@ 0 ,3,8,:@"da * )@@@#@3,8,D3,8,F@@n"db $ #@@@##@3,8,P3,8,R@@o@B@@A@@AB@@B@,,\&5,,5,,@A*A@$#@@,,T+5,,5,,@ JO@#1C2'delayed % $@@@#Q@@@#P@4,m,~4,m,@@Bp$tail ]@@@#d@4,m,4,m,@@Lq#dst _ ^@@@#u@@@#t@4,m,4,m,@@ZrU@*C@@AA@@B@@AB@\B@@TC@@AB@D@,,<j5,,5,,@ xO@#pC?kC@,,$rL@s@AmC@,+t<-]-a@@@  k:-'-)@!d i h@@@$c@:-'-2 :-'-3@@t$tail @@@$w@);-G-P*;-G-T@@u#dst  @@@$@@@$@7;-G-V8;-G-Y@@v@'C@@AA@@B@@AB@@C@,+E>--@AA@@@,+I?--JG..@A9Tmc.Dps.reify_delay.(fun)A@@@,+ @@  R>--@#dps  @@@$@@@$@^>--_>--@@x @A@@A@ӐB@@ C@@AB@A@,+ӰnA-.oA-.@@%A%'delayed ʠ @@@%@@@%@~?--?--@@y$tail @@@%!@?--?--@@z#dst  @@@%0@@@%/@?--?--@@{@*C@@AA@@B@@AB@B@@ASD@@ ȐC@@AB@C@,+C.$..C.$.G@@@qp@@O@%@@O@%o@@O@%@O@%n@@O@%@O@%xAV!x @@@%H@B..B..@@6|"xs &@@@%J@@@%I@B..B.. @@D}?EC@C@AE@@D@@ABCEF@,+MC.$.KF..@AA@KJ@@,+tR@@@A)NE@,+TU@--@@@RXC@,+@YD.Z.d @AA@VU@@,+8]E.p.|E.p.@@@P@%Q@%C>'new_dst @@@%@@@%@ C.$.OC.$.V@@v~q@A@@A@ĐC@@E@@ABD@@ >B@@RF@@ABC@B@,+ &E.p..@AA@@@,+*F..+F..@@@P@%Q@&B2#A@,*B@@4%A@,*8O/V/h @ | n@@N@&N@'N@'N@&@@N@' ŐA  ^LK.. @!d \ [@@@&@@@&@XK./YK./@@@A@@A@ C@@A B@@B@A@,*ͰhO/V/\ @@ A!A@,*ѰlM/E/KmM/E/L@@ A&A@,*ְqL/ /$ @@ @*A@,*ڰuU00 @@ @  izT// @#dps g f@@@'=@T//T//@@@A@@A@ ĐB@@A@A@,*X0F0f @A A@@@,*Y0h0u\014@A?Tmc.Dps.delay_constructor.(fun)A@@@,* @ #A 3 oW0#0% +@&constr o@ 0W0#0A@@ !d l@W0#0BW0#0C@@!d  @@@'@@@'N@'@X0F0NX0F0O@@#@ B@@CA@@AB@3B@@ ߐC@@AB@CA,*5X0F0RX0F0b@A \A94@@@ABB ,*x?X0F0J f@@ e@A<B@,*dC[00[00@@@ @@N@(f@@N@(@N@( @@N@(@N@(YB['delayed K J@@@'@@@'@Y0h0{Y0h0@@h$tail @@@'@ Y0h0 Y0h0@@r#dst  @@@'@@@'@Y0h0Y0h0@@(block_id@@@'O@'@#Z00$Z00@@@D@@A8C@@B!A@@-B@@AC@B@@AC@@D@@AB@E@,*P<[00=\013@AA@@@,*4c@@AQDA,*0FZ00GZ00@AAX@!@A BC ,*PZ00@@@`C@,*T\01 @AA@@@,)X\01@@@j&constr `@@@(.@a[00b[00@@Š@ A@@A@B@@AyC@@eE@@AqD@@BC@A@,)ܰw=T={ @A A@@@,){=}=|=}=@$@@R@*G@@R@*FR@*S &A >=T=V -@!v<@@@*4@=T=b=T=c@@@ A@@A@B@@A@E@,)====@A7Tmc.Choice.lambda.(fun)A@@@,) 0@ E@A@,)====@@@# @ UA@@A@%B@@A@A@,)>>  ]@A \A@@@,)>">,>">;@Ϡ4@@R@*R@* hB !fW@ q>>@@2!sM@>>>>@@94@B@@ A@@AB@:B@@A@F@,)dD>=>J>=>e@A4Tmc.Choice.map.(fun)A@CB@@,)4J/@ @ EB@,)L>=>W>=>d@xQ@+!Q@+Q@*A,Q@ A@@A@1B@@.C@@AB@A@,) c>=>U@@@;`A@,(g?G?K @@ @!n?(?* @!clk@@@+=@?(?6?(?7@@yt@A@@A@@A@,(?~? @@ @<n!?X?Z @!clk@@@+b@@@+a@-?X?c.?X?d@@ii@3?X?r4?X?v@@bb@9?X?x:?X?{@@@C@@A A@@B@@AB@B@@A@C@,(J??@AA@@@,(N??O??@c@?@R@+@@R@+R@+B}qa??@"c1 lk@@@+@j??k??@@"c2 kj@@@+@u??v??@@٠@C@@AB@@ & A@@AB@B@@A@G@,(?@?@)@A5Tmc.Choice.pair.(fun)A@@@,(@;@A@;@\@@@R@,[@@R@,ZR@,lPB>"E@,(0S@SA@$CA,(ZAW@B@$@A"A,( ?@ ?@(@AA@ @@,( ?@ ?@@Q@,*&AT@ Z A@@A@UB@@MC@@AB@B@,'#?@?@'@Q@,;9Ag$A@,'+ @<@i&A@,'-A6ANA6AP@@@+@ tA@@A@@A@,'7BB@@@BB@!a@BB@@E!f@BBBB@@LG@B@@ A@@AB@B@@A@B@,'WBB@AA@TS@@,'[BB@@@BB@"a1@BB@@i"a2@BBBB@@pk@B@@ A@@AB@%B@@A@B@,'{C$CDC$CH@AA@yx@@,'xC$C2@@A@ BB@!c@@@-@@@-@-BB.BB@@@A@@A@B@@C@@AB@A@,'d=CICg+@A*A@@@,'XACICY/@@.A'!c@@@-@KCICTLCICU@@@B @AB@,'@UCCC@@B@:&A@,'8ADA@@@,',@F@!vR@-@`CIC^aCIC_@@Ġ@ A@@A@@A@,' T@U@Mʠ@%paramA@@A@@A@,'װr IIs II@AfA@@@,'ܰw II@@@T@1QT@1cqBFF|@'choices2@FF7@@͠-has_tmc_calls3@#@/@@@/T@/n$boolE@@@/T@/o@@/pT@/m@F:FBF:FO@@Π+is_explicit6@.=@/@@@/T@/@@@/T@/@@/T@/@FiFqFiF|@@&Р,nonambiguous93only_explicit_calls,@@@01T@/@4S@/@@@0@@@0T@/ޠ=U@/@@@0T@/@@/T@/@@/T@/@FFFF@@QҠ1tmc_call_subtermsBĠ_T@1@@@1T@1@I/I7I/IH@@`[@uA@@ApB@@YC@@ACD@@E@@ABC@rB@@A@E@,&q@AlE@,&s II IJ:@AA@qp@@,&x IJ @rS@1q@@T@1uT@1B$_oneDS@1S@1S@1S@1kS@1)W@1>@- II. II@@@F@@A9@B87C1F@,&+@*AF@,&;JJ<K?KL@A/A@@@,&@JJ@@3Aà0several_subtermsEVU@@@1F@K J;JAL J;JQ@@ܠ1explicit_subtermsFcU@1@@@1U@1@YJUJaZJUJr@@,b@H@@ABcb`@"G@@Aa@BCD`H@,&ͰhKcKoiKcK@A\A@@@,&ҰmKcK|@nS@2 @@U@2U@2!hB7$_oneGVS@1S@1X@1@KMKYKMK]@@@IW@A,B*DI@,&&@A I@,&KKL?LL@AA@@@,&KK@@AV9several_explicit_subtermsHG@@@1@KKKK@@@J@@AD@@ABCDJ@,&dJJ@@AlQHA,&`JUJuJUJ@ABsVDG ,&L JUJ]@@AzG@,&($II@@A@!EA,&$*IKIQIKI@ABG)@@@ABCD ,&5IKI]IKIw@A +Tmc.Choice.find_nonambiguous_tmc_call.(fun)A@43@@,&;I/I3@@AV8D@,&?FFII'AA 2Tmc.Choice.find_nonambiguous_tmc_call.nonambiguousA@>=@@,%EFF@@A_B@@ABC@,%LFiF}FiFAA 1Tmc.Choice.find_nonambiguous_tmc_call.is_explicitA@KJ@@,%RFiFm@@AkO@@@ABB@,%YF:FPF:FeAA 3Tmc.Choice.find_nonambiguous_tmc_call.has_tmc_callsA@XW@@,%_F:F>@@@w\@@AA@,%eF:FT @@ @s @!c5r@ F:FQ@@ql@ A@@A@@A@,%wFiF+@@*@k*/@!s8j@4FiF~@@~@ A@@A@@A@,%$IIJ@@IAhKP@d;d@.FF/FF@@Ӡ'choices<a@5FF6FF@@Ԡ%split=@ U@0@@@0U@/@ut@@@0@@@0U@/qp@@@/@@/@@/V@/@WGGXGG@@@-A@@A4B@@)C@@AB@ϐB@@AؐC@@D@@AB@C@,%hӰnGG@@@IР@BB@,%XٰtGGuGG@v@@V@0V@/ 8Tmc.Choice.find_nonambiguous_tmc_call.nonambiguous.splitB\*rev_before>E@GGGG@@@ 3AA@@A B@@B@B@@AC@@D@@AoE@@e@@@ABC@B@,%@-@"A BB,%4 HHHI@A)A@@@,%,HHHH@S@00A1!c?ܠ@@@/@H#H-H#H.@@"נ$rest@@@@/@@@/@H#H2H#H6@@1,@D@@AE@BC@@E@ACDF@,%:HHHI @@YA(8 D@,%?HHHH@A^A@=<@@,%DHHHH@n?X@0[@@W@0`W@0rkB;KD@,$R@nA=M!D@,$TH:HvH:H@W@@X@0%X@0DY@0?|AL\0D@,$cH:HGH:HV@f@@W@0W@0X@0A[k?D@,$r H:HD8@@A_oCDn,$w@>CoC?CoC@@@A@@A@B@@A@@@*C@@AB@A@,$(QCDRCD @Q*R@.@@S@.S@.S@.S@.@@S@.S@.9A7!c @@@._@pCCqCC@@"cs!A@@@.a@@@.`@CCCC@@@CD@AB@@$leftE@@ABHE@,$D DD D@AeA@@@,$ CC@@iA/@@@ABTC@,#CC @@p@k[A@,#ArA@@@,#@tA@@w#defi@+M#M@+M#MC@@~$bodyjT@>@+M#ME+M#MI@@@ A@@AC@@kB@@!D@@ABC@SB@@PC@@AB@DA,#DkAh@c@@A@BB,#,=1MMt@@sA琰A/MMx@@oA@@A@@AB,#L0MMM0MM@AA@@@,#@A$lfunn@@@>@X0MMY0MM@@@B@@A@BB@,"ǰb0MMc0MM@@A B,"A@)%A ,"|аk5N1N=l5N1N@@@As3MM@#ctxr@x3MN@@#vars@~3MN3MN@@#deft@3MN 3MN @@@ E@@AB@@BC@@9A@@D@@ABC@AB@@A@E@,"t;O O @AA@@@,"l;O O;O OC@!t@@V@?V@?@@V@?CG$lfunuL@@@?@6NANJ6NANN@@$%arityv @@@?&V@?@7NRNX7NRN]@@0&dps_idw @@@?;V@?1@8N{N8N{N@@<+direct_kindx-function_kind@@@?eV@?b@9NN9NN@@J$candy)@@@?kV@?g@:NN:NN@@WR@i@A8G@@J@@Ak@BCj@'I@@A4H@@LF@@ABomCDkJ@,"Hhg@=AScJ@,"@j:NN:NO@ABA@hg@@,"0o :NNG@@FA[l@@ABDzI@,"(w9NNO@@NAbt@@A@BCDHA,"$8N{N8N{N@AZAn@%@ABCG ,"(8N{N @ &@@W@?@1@AI@@@ABCI@, Ű`$@@8 @@W@sY@sg@@W@sscd@@W@sY@se@@W@sr@W@sqA8!J@, ?{g@:@@X@s@@X@sX@sX@sϐAI2I@, P8f@fjX@sX@sX@s@@Y@s@@Y@sY@sY@sAc LI@,  8G@@F@@Y@s[@s@@Y@s@@Y@s@@Y@s[@s@@Y@s@Y@sA #kJ@,  *8P:@A A@ ' &@@,  .@A )qI@,  0auAA-Tmc.(fun).subA@ / .@@,  6JT@@A 3*@@A)@BC&H@,  >z@09@@X@u@@X@uX@v;X@uAH 1J@, !@@w@@X@uZ@u@@X@u @@X@u@X@uA_!HK@,!)@AA@!!@@,!jl@0X@v@@Z@v\@v @@Z@vڠ@@Z@v@@Z@v\@v@@Z@v@Z@vEA!`K@,!g =U7@AJA@!d!c@@,!k@LA!fJ@,!m au #AA-Tmc.(fun).subA@!l!k@@,!s JT(@@VA!pg@@Af@BCcI@,!{ d| H">L@@$3¶ms!t@@@ag!@@@ah@@af@@@ae@">N">T@@$L&return!@@@ak@">V">\@@$V$attr!2function_attribute@@@aq@">h">l@@$b#loc!/scoped_location@@@at@#>n#>q@@$n$bodyFW@a@#~#~@@$w$r@@A'K@@O@@AB@@AC@[N@@A@$J@@AB@@AWM@@@L@@AB#"CDEO@,$p@Ak$OA,$#-~#.~@AސAr$@@@ABCEN ,$#9~@@A|$ N@,$#=/1@@A$)CBCADI@,$#E#F -@#@@U@aYV@aWW@a/B$I@,$#T#U @@@W@aA A$J@,$@ A$I@,|$Ű#`@@A$#IA,x$˰#fQd#gQ@AC$ʠ@nBClDH ,`$ְ#qQS@@!A$ HA,\$ܰ#w%#xM@A(B$۠DG ,<$#@@0A$G@,$$##@"@@@`@@@`=A1$@@A@BCE@,$#@@FA9$EA,%6AAK@$$@@A@@AB C ,% #qs#q@A3Tmc.traverse_letrecA@%%@@,%@A%#ctx @##@@%(bindingsT@`@##@@%##ctxU@`@##@@%,(bindings@@@`IU@`5@#)/#)7@@%:%5@D&A@@AC0B@@BIDA,%H#):#)m@A?B<%G@@A@B C ,%R#)J#)d@@@V@`\LBI%T D@,%[#)+R@@QAM%XCA,%a##%@AXCT%`%@B$B ,%j$a@@`@[%gB@,%n$ $ @A0Tmc.traverse_letA@%m%l@@,|%t@A%n)outer_ctx+@$"$+@@%#var /T@_@$ ,$!/@@%#def 1T@_@$(0$)3@@%)inner_ctx U@_@$06<$16E@@%(bindings :T@_@$8pv$9p~@@%%@ E@@AA@@D@@AB1C@@,B@@AC-FEA,x%$Lp$Mp@ACC@%@BC D ,d%$Vp @ALA@%%@@,X%$ZprQ@@PAL% DA,T%Ű$`6H$a6l@AWBS%Ġ@&@A#"B C ,D%ϰ$j6b @A`A@%%@@,4%Ӱ$n68e@@d@_% C@, %װ$r$s@A,Tmc.traverseA@%%@@,%ݰ$x$y@B%ܠ#ctx@$$@@%(bindingsoX!t@@@^נ#;@@@^@@^@@@^@$Zg$Zo@@&$body#F@@@^@$Zq$Zu@@&#ctxV@_;@$z$z@@&(bindingsV@_<@$z$z@@& &@;sE@@AF;D@@%C@@ABGGB@@#lamA@@ACCG@,&5^@[AS&0G@,&7$z$z@-&@@_?V@_KgB^&=@@A@BCD@,&H$zq@@pAf&EDC,&N$:@$:Y@@wAs"lk@@@^@$$@@&c"vk#@@@^@%%@@&m#var@@@^@%%@@&w#def#@@@^@%%@@&$body#@@@^@%"%#@@&#ctx~V@^@%*%+@@&(bindings4V@^@%2%3@@&$body]V@^@%:%;"@@&&@oH@@AI@@K.C@@AB%J@O^Oh%>O^On@@'@,choice_apply@7T@@$tail%U@@@$,lambda_apply@@@B-U@@%U@@@@@@@@@@@V@@@%]]%]]@@'[0choice_makeblock@RU@@$tail@U@@@$j@@@YU@V$d$a@@@Y U@V&-$[@@@YU@V@@VU@@@U@@@%@@@BU@@\U@@@@@@@@@@@@@@@@@V@@@&)hh&*hi@@'+choice_prim@T@@$tailwU@@@%)primitive@@@BU@@@U@@@&U@@U@@@@@@@@@@@@@@@@@V@@@&L9ww&M9ww@@'+choice_list@T@@$tailU@@@qT@D7@@@D6U@@@U@E@@@EU@EZ@@@EsU@@@@@@@@@@@V@@@&ty&uy@@'+choice_pair@T@@$tailU@@@U@BU@B@@BU@@ΠU@BU@B@@BW@By@@@BU@@@@@@@@@@@V@@@&&@@(-choice_option@T@@$tailU@@@&optionJ@@@D]U@@@@@EU@E[@@@EU@@@@@@@@@@@V@@@&39&3F@@(/ (*@C@@AD@@G@@ABE@@6I@@A`H@@F@@AB2B@@-A@@ACD@I@,(E&>O^O`F@@E@;(B@  BB@,(K&Ug&U@!W#@@W@]W@^~W@^h8Tmc.choice.choice_optionBW#ctxR@&3G&3J@@(cS>U@]@'3L'3P@@(k!tYU@]@' 3Q' 3R@@(t(o@C@@AA@@B@@AB@#>W@@A%U@@$V@@AB&T@@%X@@Aq@@@BCPC@@L@@A)EA,L) ;LAAK@)@@ABC,()''@!U@^U@]iU@]hU@]U@]~U@]@@W@]W@]7W@]!6Tmc.choice.choice_listB)#ctxu@'y'y@@)5vU@\@'y'y@@)=%terms|U@\@'y'y@@)F)A@C@@AB@@A@@ABLC@,)P''@@(%@X@]3-B,)RD@,)Y'G@@2@0)VC@,)]'~DZ'~Dw@A6Tmc.choice.choice_primA@)\)[@@,)c'~DL@@Af#ctx@( 9ww( 9ww@@)r U@[@(9ww(9ww@@)y$primU@[@(9ww(9ww@@)(primargsU@[@(!9ww("9ww@@)#locU@[ @()9ww(*9ww@@)(primargsX@\@(1}(2}#@@))@3E@@A@@AB(C@@F$B@@A5D@@BC,IFA,)(G}&(H}@@AOBJ)@@A@BC E ,)(R}Z@@YAS) E@,)(V=xLxo(W=xLx@A^A@))@@,)([=xLxT(\=xLx@@cA`#tag#intA@@@[+@(j<x%x7(k<x%x:@@)$flag(Asttypes,mutable_flag@@@[,@(y<x%x<(z<x%x@@@)%shape'U+block_shape@@@[-@(<x%xB(<x%xG@@))@U@A G@@U@ABT@Q@AF@@4H@@AT@BCDSH@,P)(DyFyX(DyFyk@C"l1 X@\N@(Axx(Axx@@* *@q@A F@@q@ABp^CiG@,8*(Eyoyw(Eyoy@AA@**@@,,*(DyFyN@@A*F@,(*(Cyy)(CyyB@ cT@ET@BWX@\ZŐA*!vE@,*( @A*#xE@,**(Byy(Byy@@AȠ"l1U@\Q@(Byy(Byy@@*7*2@ R"F@@A@G@@A@BCDG@,*B(Axx0@@A*?E@,*F(:ww@@@*CE@,*J8AA@*E*D@@,*L(Eyoy(Eyoy@AA@*J*I@@,*Q?@@Q"l1U@\u@(DyFyS(DyFyU@@*Z*U@ A@@A@֐B@@A@A@,*c( q#q+(s3s<@A;Tmc.choice.choice_makeblockA@*b*a@@,*i) q>qU)s&s1@%%=Y@W@@X@WX@XA{#ctx!@)hi)hi @@*m#tag@)%hi)&hi@@*n$flag@),hi)-hi@@*o%shape@)3hi)4hi#@@*p)blockargs U@V@);hi%)<hi.@@*q#locU@V@)Chi/)Dhi2@@*r'choices @W@V@@@VW@V@)Qi5i=)Ri5iD@@*s(explicit#>@@@W-@)[jj3)\jj;@@*u2ambiguous_subterms#<!U@WZ@W0@@@W8@@@W7@)mjjH)njjZ@@*v+term_choice!(@@@WY@W@@@WX@W@)pp)pp@@*w*@! J@@,K@@ABUB@@GI@@ACtE@@>L@@AkG@@$initN@@ABZA@@BCED@@AqF@@H@@4M@@ABCDEFR@,+ ) q>q^@A !Tmc.choice.choice_makeblock.(fun)A@+ + @@,x+@A+ *! @BDE MA,t+)pp) pq@AB+6- $#@@ABCDL ,\+&)pp)pp@"!ug@@X@WX@WY@W@@X@WX@WҐA+4M@,D+;) pp!@AA@+8+7@@,,+?)pp@@A+<#L@, +C)$tWt_)7ww@AA@+A+@@@,+H)2vv)2vw@ߠW@Ya@@X@YeX@YyBߠ*rev_before#.U@YU@Y.U@X}Z@WG@@@WJ@*s=sY*s=sj@@+j|&choice"E@U@\U@\U@Z?Z@WL@@@WO@*s=sl*s=sr@@+|}%after# Z@WQ@@@WT@*s=st* s=sy@@+~&constr *@@@YX@X@*+ss*,ss@@++@!!K@!L@@AB@6M@@A@O@@ABC@@A@B@PN@@ABCDS@,+*E%tat{*F+uu@AA@++@@,+l@IA[+O@,+*L#t.t6*M#t.tU@@@W@Y^X@Y\TBg+'O@,p+ y@@XAj+*O@,l+*[ss*\"t!t*@A]A@++@@,H+Ű*`ss*ass@(j@@Y@YY@Y(iA|(+͠>8@BC4DP@,0+ذ*sss@@tA+N@,+ܰ*wii*xij@AyA@++@@,+*|ii*}ij @A~A@++@@,+*ii @@Ap$args$U@WU@WU@BZ@W@@@W@*ii*ii@@+t+@@K@@AB^BCDK@,,*ivi*ivi@"$U@W@@@W A, @#"B oCD I@,,*iviz@@A,IA,,*i5iG*i5ir@AB,@3@A0B&CH ,,&*i5iP*i5ih@@@X@VƐB,(I@,p,/*i5i9@@A,,HA,T,5AA@1,1E@=@A:@BC0E ,@,=*)uu*)uu-@@@((@@Y@Y@@Y@Y+@@Y@Y@Y@Y*@@Y@Y@Y@YCA,N@A@@A@'C@@A)cB@@D@@ېE@@ABC@B@,,,f+)uu1++uu@AZA@,d,c@@,,k.@@]A,gA@,,n+ 'tt+ 'tt@U@ZBU@YU@YZ@YjA&,u'A@,,|+'tt@@oA*,y+A@,,+&tt@@s@.,}/A@,,+*u@uN@AwA@,,@@,,+#*u@uX+$*u@u@)@@Z@Z[@Z:C?'new_dst((@@@Z@@@Z@+8)uu5+9)uu<@@,,@A@@A@'dB@@@C@@AB@B@,,+H+uu+I+uu@AA@,,@@,,.@@ ,A@,,yANA@,,@@,,+Q pp+R pq @ASA@,,@@,t,@U@E$args@+Zpp+[pp@@,x,@ A@@A@rZ+r>rz@+n+m@@[@X\@@[@X[[@XnB$info@'!t+&lambda@@@X-@@@X,[@X$+@@@X4[@X%@@X&[@X#@+qq+qq@@-Lz-G@#C@@A\@BWC@,-R9@CA&-MC@,-T+qq+rrAA &Tmc.choice.choice_makeblock.(fun).infoA@-S-R@@,-Z+ quq@@M@-W@j@AeB@,-`+qq @A A@-]-\@@,-d@ @8,qq@!t63@@@X/@@@X.@,qq,qq@@-w{-r@A@@A@@A@,-},hh,hh@A7Tmc.choice.choice_applyA@-|-{@@,-,hh,hh@A=Tmc.choice.choice_apply.(fun)A@--@@,-,$hh,%hh@$iU@TU@VW@V@@W@VW@VW@VA#ctx]@,?]],@]]@@-Z^U@Q@,G]],H]]@@-[%applydU@Q@,P]],Q]]@@-\&No_tmcV ,@@@A,X]],Y]]@@-]0apply_no_bailoutu@@@VPX@V@,dff,eff@@-j-Ƞ@D@@A#A@@F@@AB5C@@#exn E@@A4B@@BCaCF@,x-߰,zhh,{hh@AbA@--@@,p-g@dAH-F@,d-,h^hf,h^h@AiA@--@@,$-@kAO+ap_tailcall+a2tailcall_attribute@@@V)Y@V@,gg,gg@@-k-@-@AF@@.@AB+*C$F@,.,h8hM,h8hR@@Ai%other@@@V"@,h8hD,h8hI@@.l. CA@B>@=@AF@@<@ABC;F@,.,gh',gh7@@A.@$7G@@AQ@Q@ABNCGG@,.%,gh,gh#@@A.# G@,.*,ff@@A.'YXCRE@,l.0,dd,fbfm@AA@...-@@,`.5,dd5,ee0@̠W@T@@X@TX@TA9explicit_tailcall_request%)@@@RW@Q@,]^,]^@@.R^!f%!t@@@RA@,^_,^_@@.__+specialized%@@@RqX@RJ@-__-__@@.k`$args$+@@@Tz@@@TyX@T@-`R``-`R`d@@.|a(tailcall@@@@TX@T@@@TX@T@@TX@T@-(bb-)bb@@.e.@@A(_nontailJ@@@0M@@ABC@XI@@AMK@@CL@@A@(N@@ABCDR@,P.-Add>q@A"A@..@@,$.-Ee2eG-FeRe@A'A@..@@,.-Jee-Kf,f:@A2A@..@@, .-Oee-Pf,f9@A7A@..@@, .@9Ax.(N@, .-Vbb-WcdAA Tmc.choice.choice_apply.tailcallA@..@@, .-\bb@@CA.2*('@BCDM@, .ɰ-dbb-ebb@@@Z@TrZ@TvRA$kind&@@@TY@T@-yaa-zaa@@.b%arity&@@@TY@T@-aa-ab@@.c  .@% Q@@A&@Bb@&@ OM@@ABC(b`@P-N@@Ac@*@ABCD)Q@, />@A51%/Q@, / -bb-bb@@A=$args,T@@@Tc@@@Tb@-bb-bb@@/d1G0;//@R@AR@@-@ABCQ)DJR@, /(-b3bE-b3b|@,p@@@T?@@@T>@@@T=CgMcLW/6GCiADbP@, l/@-b3b?5@@ApVlU`/? P@, P/F-`R`\@@A/C@z@ABwDpL@, 8/N-`)`7-`)`C@y@@Z@TZ@T A/R@L@@A@B@@ACDL@, 0/a@A/\ L@, 0/c-__-_`'@ @@Y@SZ@S[@RB+/jL@, /q. __. __@ @@[@SA5/t"M@, /{@A7/v$L@, /}._p_~.`)`D@@A</{)L@, /._!_1._!_Q@$X@RNBE/A.BCO@, /.)__^@@AL/K@, |/.-fnf..fnf@@@X@VX@VAW,@@@RD@.;fnfv.<fnf~@@/i/\@ @A@BCJ@, x/@*A/J@, /.G^^@@.Ai/ CI@, /.M^F^d.N^F^i@@5A/@%I@@A@@AB@@ACI@, /.Z^^.[^^@@@Y@R$Y@R(HA+/à@%J@ABCJ@, /@QA4/ J@, /Ӱ.n^j^.o^j^@@VA9/J@, /AXA@//@@, /ڰ.u]]]@@\@>/נ@ @A #BC@, p/.|cc&@@%Ah%*@$tailg@/.bb@@/f/@ A@@A@@A@, `/.cc.cc@@8A/ A@, T/.cc=@@<@/ A@, L/.eRe`.eRe@AyA@//@@, <0.eReg@A}A@//@@, 0.eRe.eRe@@@Z@U[@UA0 @B@@A!VA@@B@jC@@AtB@@D@@AB@D@, 0"&@@0@@AA@, 0&.dQd_.ee/@AA@0$0#@@, 0+.dQdf@AA@0(0'@@, 0/.dsd.dsd@AA@0-0,@@, 04.dd.dd@&-{@@Z@T@@Z@TZ@U B$tail,.@@@T@.ddD.ddH@@0Og#dst,0,/@@@T@@@T@.ddJ.ddM@@0]h0X@A@@AgC@@ B@@AB@-ÐB@@AC@@E@@AD@@F@@ABC@G@, 0w/de /de@@@Z@U[@U(A>0|$E@, l0]@@@0~@&@A"@B!B@, X0/#hh/$hh@AA@00@@, L0@@0@!A@@A@ӐB@@A@A@, 00/2]m]/3]m]@ j1Tmc.choice.choiceC #ctx @/@>O^Oo/A>O^Or@@0 ' U@A @/G>O^Ot/H>O^Ox@@0 !t'U@A@/O>O^Oy/P>O^Oz@@0 !x(!t@@@A@/\]S]b/]]S]c@@0W#lam.@@@A@/f]S]e/g]S]h@@0X0ʠ@1C@@D@@AB&A@@/B@@"E@@ABC_@F@, 0ݰ/x]]/y]]@AEA@00@@, 0/}]m]u@@IAG0E@, 0/]]!/]]5@ OCN#lam.-@@@A@/\]/\]@@0T#lev.j,lambda_event@@@A@/\]/\] @@1U0@5@AE@@D@@AB5@4@AC1F@, 1 /]9]A/]9]R@AuA@1 1 @@, 1/]]@@yA)1E@, 1/TRR/TRS@ C"l1.^@@@AW@/RRR/RRR@@1("l2.h@@@AX@/RRR/RRR@@12"l1'W@B0@/SRR/SRR@@1:15@l@A F#E@@D@@ABn9CiG@, |1E/USS/USS0@AA@1C1B@@, p1J/TRR@@A11GFA, l1P/SRR/SRR@AB81OBMC}E , \1Z/SRR@@A@1WE@, ,1^/XSwS/XSwS@ nǐCȠ"l1.@@@A]@0VS1SD0 VS1SF@@1q"l2.@@@A^@0VS1SH0VS1SJ@@1{"l3.@@@A_@0VS1SL0VS1SN@@1"l1(GW@Bh@0$WSSS_0%WSSSa@@11@@ G-F@@AB$E@@D@@ABCH@, 105XSwS<@AA@11@@, 109YSS0:YSS@AA@11@@,10>XSwS@@ AB1GA,10DWSSSd0EWSSSs@ABI1@@@ABCF ,10OWSSS[@@AR1 F@,10S[[0T[[@ !C!"l1/@@@A@0aZZ0bZZ@@1J"id).!t@@@A@0nZZ0oZZ@@1K"l2/@@@A@0xZZ0yZZ@@1L1ܠ@@AE@@(F@@ABD@@H@@ABCH@,t10[[0[[@ XC71@"BCG@,`10[[0[[@AaA@11@@,T10[[@@eAC1 F@,20\\0\\@ kCk"l1/J@@@A@0[\ 0[\ @@2O#idsQ@@@A()!t@@@A/@@@A@@A@@@A@@A@0[\ 0[\@@25P"l2/u@@@A@0[\0[\@@2?Q2:@q@A0E@@2 E@,21C{YY1D{YY@ C"l1/@@@A@1UuXX1VuXX@@2=%cases)?&stringO@@@A0 @@@A@@A@@@A@1nuXX1ouXX@@2>$fail 0@@@A@@@A@1|uXX1}uXX@@2?#loc@@@A@1uXX1uXX@@2@)cases_lhs!1@@@E5W@E!@@@E/W@E@1wXX1wXY@@3A)cases_rhs$0H@@@E6W@E#@@@E0W@E@1wXY1wXY @@3B"l1)W@E:@1yY<YH1yY<YJ@@3C3@)6H@@AdF@@6J@@A%I@@U@ABCQE@@KzG@@A?M@@MD@@AB](CDXM@,341zY`Yy1zY`Y@ mC34@@A @Bi4CDdL@,3@1}YY1~ZZG@AA@3>3=@@,3E1zY`Yh@@A3BKA,3K1yY<YM1yY<Y\@AB3J4*@'@A#@BJCDzJ ,3W1yY<YD@@A3T J@,3[1wXY1wXY @ra@@EW@E.ʐA3a@I@A@BCDG@,3l2wXX,@@A3iG@,3p2 oWiW2 oWiW@ VِCޠ"l10@@@A@2gVV2gVV@@3/"sw0-lambda_switch@@@A@2*gVV2+gVV@@30#loc1@@@A@24gVV25gVV@@31*consts_lhs"d @@@CW@C@@@CW@C@2GiV7VC2HiV7VM@@32*consts_rhs%`0@@@CW@C@@@CW@C@2YiV7VO2ZiV7VY@@33*blocks_lhs" @@@CW@C@@@CW@C@2ljVwV2mjVwV@@34*blocks_rhs%1@@@CW@C@@@CW@C@2~jVwV2jVwV@@35"l1*W@C@2lVV2lVV@@363@* J*G@@A8L@@'K@@AB`I@@OH@@AC-@MF@@PO@@ABxD@@E@@A9BCD4P@,42nW.WH2nW.Wh@ IyC4&E@@@ABCD@O@,42mVW 2mVW-@ UC42((S@%@ABCDLN@,4(2qWW2tXX@AA@4&4%@@,`4-2mVV@@A4*MA,\432lVV2lVV@AB42H>>i@9@ABC21DbL ,H4?2lVV@@A4< L@,44C2jVwV2jVwV@u@@CW@CA4I@\@AWVBCIHDyI@, 4U2jVwV-@@A4R I@, 4Y2iV7V\2iV7Vs@ @@CW@CȐA4_@,B]\CF@,4i3iV7V?A@@A4fF@,4m3IPQ3 IPQ)@@AԠ$prim @@@AM@3HPP3HPP@@4}(primargs* 1@@@AO@@@AN@3"HPP3#HPP@@4#loc)@@@AP@3,HPP3-HPP@@44@@AD@@)F@@AB E@@BCF@,43;eUU3<eUU@ s C (bindings+*@@@A|1@@@A}@@A{@@@Az@3UcUUUd3VcUUUl@@4*$body1@@@A~@3_cUUUn3`cUUUr@@4+#ctx+T@CZ@3gdUwU3hdUwU@@4,(bindings+?T@C[@3odUwU3pdUwU@@4-4Ӡ@*F@@AG8E@@B$D@@H@ABC I@,h43fUU3fUU@APA@44@@,\43eUU@@TAJ4H@,H43dUwU3dUwU@/(@@C^W@Cj`BU4@ @A@/@AB,C'E@,853dUwU@@jA^5 E@,53]TUTi3]TUT~@ pCr"vk2@@@Ae@3ZSS3ZSS@@5#var,!t@@@Af@3ZSS3ZSS@@5(#def2h@@@Ag@3ZSS3ZSS@@52$body2r@@@Ah@3ZSS3ZSS@@5<#def+W@B@3\T/T;3\T/T>@@5D 5?@D@@Aw@H%E@@ABx@x@A5F@@AG@@ABCxI@,5T3^TT3^TT@AA@5R5Q@@,5Y3]TUT]@@AO5VHA,5_3\T/TA3\T/TQ@AǐBV5^@@ABCG ,5j4\T/T7@@A_5g G@,5n4 aUU4 aUU/@AאC۠"lk,@@@Ao@4_TT4_TT@@5""vk2@@@Ap@4%_TT4&_TT@@5##var,@@@Aq@4/_TT40_TT@@5$#def2@@@Ar@49_TT4:_TT@@5%$body2@@@As@4C_TT4D_TT@@5&#ctx,T@B@4K`TT4L`TT@@5'(bindings,UT@B@4S`TT4T`TT@@5(5@+I@@AJ@@$D@@ABK@2E@@RH@@ABC@@AAF@@MG@@ABDL@,h5Ӱ4nbU3U;4obU3UT@A;A@55@@,L5ذ4saUU@@?Ag5K@,85ܰ4w`TT4x`TU@6/@@BW@CKCr5@&@A#CDH@,$54`TT@@TAz5H@,54NQQ4NQQ@@YAV%apply@@@AS@4MQQ4MQQ@@55@D@@A2@B/C*D@,64CPP4CPP.@@nAk!t,T@A@4BOP4BOP@@6 6 @C@A DB B=DA,64BOP4BOP@AB6 LBGC ,6$4BOO@@A6!C@,D6(4?O}OK@@@6% C@,6,Y@@$bodyU@C @4aUU4aUU@@65)60@ A@@A@E@@AŐC@@B-̐B@@D@@AC@A@,6GAA@6B6A@@,6I@@>$bodyU@B@4]TUTb4]TUTf@@6R!6M@ A@@A@D@@A@C@@MB@@AB@A@,6ayAA@6\6[@@,6c{@@$body1U@Cw@5eUU5eUU@@6l.6g@ A@@A@B@@A@A@,6u5tXXM@AA@6r6q@@,6y@A *consts_rhsU@EU@DU@DU@DU@D@Dn@5(mVW5)mVW @@67*blocks_rhs@Do@50nW.W;51nW.WE@@68-sw_failactiony@Dj@58oWiWv59oWiW@@69)sw_consts.@@@DW@D}U@D@@D@@@DW@Dy@5PqWW5QqWW@@6:)sw_blocks@@@DW@DU@D@@D@@@DW@D@5grXX5hrXX@@6;"swK@@@DW@D@5ssXDXP5tsXDXR@@6<6נ@,C@@ARD@@fE@@ABA@@H@@A3G@@BLF@@VB@@ACD@2E@@AYD@@F@@ABhC@@wB@@AC@H@,75sXDXU5sXDX@AiA@66@@,75sXDXL@@mA7,%@!@A BCGA,|75rXX5rXX@@AxB781@,@A*@BC)F ,d75rXX@@A7 FA,`7!5qWW5qWX@AB7 IB@:@AC9E ,H7+@A7&EA,$7/A@7*@L@ABA,745~ZZ#@AA@7170@@,78@A)cases_rhs@E@5zY`Ym5zY`Yv@@7CD$fail#@E@5{YY5{YY@@7KE%cases@@@EW@E@@E@@@EW@E@5}YY5}YY@@7aF7\@D@@A,C@@B%B@@A@@AC@C@@A^D@@B@@AB@DA,7y6}YY6}YZ@ABD7x@@ABC ,7C@AJ7~CA,7GA@N7@ @AA,75AA@77@@,77@A"l1]@F@6/\\60\\@@7R"l2e@F@67\\68\\@@7S7@C@@A B@@A@@AB@B@@A@CA,7YA@"7@ @A A,7AA@77@@,7@A"l1@FC@6X[[6Y[[@@7M"l2@FD@6`[[6a[[@@7N7Ġ@C@@A B@@A@@AB@ B@@A@CA,|7A>@"7Ԡ@ @A A,t7@ACA@77@@,d7B@EA"l2@6XSwS6XSwS@@7"l3@6XSwS6XSwS@@77@C@@A B@@%A@@AB@vB@@A@CA,P8bAe@ 7@ @A A,H8AjA@87@@,x8@l@"l2U@BC@6TRR6TRR@@88 @ A@@A@B@@A@A@,p8 A~A@88@@,`8@@1#lamU@F@6]]6]]@@8$V8@ A@@A@3B@@A@A@,X8-PAA@8(8'@@,H8/R@@#lamU@F@6]m]z6]m]}@@88Y83@ A@@A@B@@A@A@@b  */home/barsac/ci/builds/workspace/bootstrap 1/home/barsac/ci/builds/workspace/bootstrap/lambda@x ST(#TmcP7𠠑,Stdlib__List𠠑Tp (@A@ d0caml_fresh_oo_id &No_tmc-lambda/tmc.ml]]]]@@ %Ident &Stdlib ̠)Debuginfo (Location $&Lambda |BPHK<@.0#t.t61#t.tU@@#H@.Assert_failure\+choice_primDCyy6ECyyA@@>o.Stdlib__OptionԠ:<z}ԠWHPNLL&offsetm)Ln)R@@tl|#dsty#z&@@xgdjx,zX@K=This call could be annotated.A@@@=This call could be annotated. @@p [@tail_mod_cons]: this constructor application may be TMC-transformed in several different ways. Please disambiguate by adding an explicit [@tailcall] attribute to the call that should be made tail-recursive, or a [@tailcall false] attribute on calls that should not be transformed.;@@.Stdlib__Formatࠠ@K "This call is explicitly annotated.#A@@@ "This call is explicitly annotated. @@ 0[@tail_mod_cons]: this constructor application may be TMC-transformed in several different ways. Only one of the arguments may become a TMC call, but several arguments contain calls that are explicitly marked as tail-recursive. Please fix the conflict by reviewing and fixing the conflicting annotations.;@@ (,Ƞܠ @P@@"%t15A@@ @ d Ġ ؠ  젠@P@@"%t  A@@!!< !l9!ܠ$_dps8N{N8N{N@@!젠!"""%"\Q#T$@79GG:GG@@P@%D %Lj&m&Tp'E(xv*$y-|.@@K%blockdeA@D@@@K$_arg@D@@@@@@@@-block%d_arg%d&@@/.Stdlib__Printf//0011%blockBG@@112@EAA@23̠)Tmc.Errorh""h"G@@3Ԡ7Ġ7@(Warnings0Ӷ.5S6V%Types0AF3Ai4.Type_immediacy0Xp '0:(d)2"Y%Subst00gDQ,Wp -Stdlib__Uchar0 |K?bޣ ˠ.Stdlib__String0L%BWx:6+Stdlib__Set0PSVl8 ;+Stdlib__Seq0yt\eǟ&Q,}.Stdlib__Printf0=iW1jfSW<.Stdlib__Option04BotԞ$+Stdlib__Map0ҭfȨ؜ׇ0,Stdlib__List0E &xa.Stdlib__Lexing0zsc\ZoQ,Stdlib__Lazy0'rruSZY/Stdlib__Hashtbl0!z9ϸ@`VǠ.Stdlib__Format0=z+.m׸.Stdlib__Either0 }rCT0J){9).Stdlib__Digest0@~8x2.Stdlib__Buffer0'ON͋[h#ڗA&Stdlib0>,W:(%Shape0-#\wz5)Primitive0.>}7Fmd*ՠ$Path0"nA_8K 1)Parsetree03p雲Ҳ$+Outcometree0xHU ͧTƠ$Misc0KH(1Xk5o\)Longident0{C 3C(Location0>gc 7پI{YG)Load_path0@d0X&Lambda0A x~72~,Identifiable0g+AbڀO"q,%Ident0T;~-1ѡ#Env0T\$nd-0qbҠ)Debuginfo0[Q;k SWVӠ*Cmi_format0d S[@0CamlinternalLazy0G -Ϥ;I8CamlinternalFormatBasics0cEXy