Caml1999I037I%Event'channel;!a@@A@A@G@B@@@)event.mliXppXp@@@@@@A@+new_channel @$unitF@@@ !a@@@@@@@[[@@-A@@%event!;!a@@A@A@A@B@@@,^  -^ @@@@>B@A@$send"@%!a@@@@@#9@@@@@@@@@@@JcKc@@\C@@'receive#@C!a@@@@@@@@@@ahbh@@sD@@&always$@!a@/@@@@@@tjuj@@E@@&choose%@$listKD!a@@@@@@@M @@@@@@noono@@F@@$wrap&@\!a@@@@@@ !b@@@l@@@@@@@@rr *@@G@@*wrap_abort'@{!a@@@@@@@@@@@@@@@@@@@@@@w  w  @@H@@%guard(@@@@@!a@@@@@@@@@@@@|  |  @@I@@$sync)@!a@@@@@@@B  B  @@J@@&select*@Ҡ!a@@@@@@@@@@H  H  @@.K@@$poll+@!a@@@@&optionL @@@@@@6L G G7L G g@@HL@@@c8-%Event0yY0%  &Stdlib0-i8Q"L{v;8CamlinternalFormatBasics0%FU(Q/Tu@@@Caml1999T0379 g!C%Event*ocaml.text&_none_@@A 2 First-class synchronous communication. This module implements synchronous inter-thread communications over channels. As in John Reppy's Concurrent ML system, the communication events are first-class values: they can be built and combined independently before being offered for communication. )event.mliP77Vln@@@@@@3@@@@@@#intA;@@#intA@@@@@;@A@$charB;@@$charA@@@@@A@A@&stringQ;@@&stringA@@@@@G@@@%bytesC;@@%bytesA@@@@@M@@@%floatD;@@%floatA@@@@@S@@@$boolE;@@%falsec@@]@$trued@@c@@@A@@@@@d@A@$unitF;@@"()e@@n@@@A@@@@@o@A@ #exnG;@@@A@@@@@s@@@#effH;@@O@A@A@@@@@@|@@@,continuationI;@@Q@@P@B,continuationA@nY@@@@@@@@@%arrayJ;@@R@A%arrayA@@@@@@@@@ $listK;@@S@A"[]f@@@"::g@@@T@@@ @@A@Y@@@@@@@@&optionL;@@V@A$Noneh@@@$Somei@@@@@A@Y@@@@@@@@)nativeintM;@@)nativeintA@@@@@@@@%int32N;@@%int32A@@@@@@@@%int64O;@@%int64A@@@@@@@@&lazy_tP;@@X@A&lazy_tA@Y@@@@@@@@ 5extension_constructorR;@@5extension_constructorA@@@@@@@@*floatarrayS;@@*floatarrayA@@@@@@@@&iarrayT;@@Y@A&iarrayA@Y@@@@@@@@ *atomic_locU;@@Z@A*atomic_locA@@@@@@ @@@ .Assert_failure`#@@@@@J@@@@@@@@[@@A!=ocaml.warn_on_literal_pattern%@&@0Division_by_zero]#@@@A+ . .@+End_of_file\#$@@@A366@'FailureY#,@'@@A<??@0Invalid_argumentX#5@0@@AE$H#H@-Match_failureV#>@@=@9@;@@a@@AV5Y4Y@)Not_foundZ#O@@@A^=a<a@-Out_of_memoryW#W@@@AfEiDi@.Stack_overflow^#_@@@AnMqLq@.Sys_blocked_io_#g@@@AvUyTy@)Sys_error[#o@j@@A^]@:Undefined_recursive_modulea#x@@w@s@u@@h@@Aon@:Continuation_already_takenb#@@@Awv@&Stdlib@AA+'channelAXpxXp@А!a@3@;@@@A@A@G@B@@@Xpp@)ocaml.doc B The type of communication channels carrying values of type ['a]. YY@@@@@@@@@@@@AXpuXpw@@BA@;%@A@A@G@B@@@@@ @@A@ڐ@@@@@@@Ұ':@+new_channel[[@б@г$unit[[@@ @@@3@Y+@A@@г]'channel[[@А!a@B@[[@@@ @@@@@@"@@%@@@[@a7 Return a new channel. \\ @@@@@@@6A@@(@q1@@@@@@>A+%eventB5^ 6^ @А!a@3<;;<<<<<@Sh4;@@@A@A@G@B@@@J^  @ C The type of communication events returning a result of type ['a]. W_X_c@@@@@@@@@pB@@A[^ \^ @@@A@;$@AA@A@B@@@@@ @@A@r@@@@@@@3jiijjjjj@-@A%9@$sendwcxc@б@г砐'channelcc@А!a@C@3@N^1@Acc@@@ @@@ @@б@А!ac c @@гq%eventcc@гT$unitcc@@ @@@(@@@@@@- @@@5@@0!@@@.@@31@@@c@ [send ch v] returns the event consisting in sending the value [v] over the channel [ch]. The result value of this event is [()]. aeeb@@@@@@@C@@-@$䐠@@@@@@R'receivehh@б@гW'channelhh@А!a@C@3@q>@Ahh@@@ @@@ @@г٠%eventhh@А!ahh@@@"@@@ @@@@@!@@@!h@r [receive ch] returns the event consisting in receiving a value from the channel [ch]. The result value of this event is the value received. .e/g@@@@@@@GD@@#@B@@@@@@@&alwaysEjFj@б@А!a@C@3NMMNNNNN@Up4@ATjUj@@г(%event]j^j@А!adjej@@@@@@ @@@!@@@@@pj@ r [always v] returns an event that is always ready for synchronization. The result value of this event is [v]. }k~l/m@@@@@@@E@@#@@@@@@@;&choosenosnoy@б@г$listnono@гt%eventnono@А!a@C@3@duH@Ano|no~@@@ @@@ @@@&@@@ #@@г%eventnono@А!a!nono@@@'@@@# @@@@@&$@@@noo@. ` [choose evl] returns the event that is the alternative of all the events in the list [evl]. op@@@@@@@F@@#@>@@@@@@E$wrapr r @б@гנ%event r  r @А!a@C@3@d>@Ar r @@@ @@@ @@б@б@А!a)r *r @@А!b@C@4r 5r @@@& @@!@@г %event@r %Ar *@А!b/Gr "Hr $@@@@@@6 @@@@@9Qr @@@8@@=;@@@Wr@ [wrap ev fn] returns the event that performs the same communications as [ev], then applies the post-processing function [fn] on the return value. ds + +eu  @@@@@@@}G@@'@x@@@@@@\*wrap_abort{w  |w  @б@гQ%eventw  w  @А!a@C@3@{>@Aw  w  @@@ @@@ @@б@б@гJ$unitw  w  @@ @@@@@гW$unitw  w  @@ @@@'@@@@@*@@г%eventw  w  @А!a=8w  w  @@@C@@@? @@@@@Bw  @@@A@@FD@@@w  @+ [wrap_abort ev fn] returns the event that performs the same communications as [ev], but if it is not selected the function [fn] is called after the synchronization. x  z x @@@@@@@H@@'@;@@@@@@e%guard|  |  @б@б@г$unit |   |  @@ @@@3        @:@A@@г堐%event|  |  @А!a@C@&|  '|  @@@ @@@@@@"@@%@@г%event7|  8|  @А!a->|  ?|  @@@#@@@4 @@@@@7H|  @@@K|  @ [guard fn] returns the event that, when synchronized, computes [fn()] and behaves as the resulting event. This enables computing events with side-effects at the time of the synchronization operation. X}  Y@  @@@@@@@qI@@$@l@@@@@@W$syncoB  pB  @б@гE%eventzB  {B  @А!a@C@3@v>@AB  B  @@@ @@@ @@А!a B  B  @@@ @@@@@B  @될 'Synchronize' on an event: offer all the communication possibilities specified in the event to the outside world, and block until one of the communications succeed. The result value of that communication is returned. C  F  @@@@@@@J@@@@@@@@@1&selectH  H  @б@г:$listH  H  @г%eventH  H  @А!a@C@3@ZuH@AH  H  @@@ @@@ @@@&@@@ #@@А!aH  H  @@@ @@@@@H  @I a 'Synchronize' on an alternative of events. [select evl] is shorthand for [sync(choose evl)]. I  J  E@@@@@@@K@@@Y@@@@@@6$pollL G KL G O@б@г%event'L G U(L G Z@А!a@C@3/../////@Uz>@A5L G R6L G T@@@ @@@ @@г&optionCL G aDL G g@А!aJL G ^KL G `@@@"@@@ @@@@@!@@@VL G G@ 1 Non-blocking version of {!Event.sync}: offer all the communication possibilities specified in the event to the outside world, and if one can take place immediately, perform it and return [Some r] where [r] is the result value of that communication. Otherwise, return [None] without blocking. cM h hdQn@@@@@@@|L@@#@w@@@@@@@@A@h@GA@@]@=@@-@ @=@@@t8@@3@[v:@A@ H************************************************************************A@@A@L@ H BMMBM@ H OCaml CC@ H DD3@ H David Nowak and Xavier Leroy, projet Cristal, INRIA Rocquencourt E44E4@ H FF@ H Copyright 1996 Institut National de Recherche en Informatique et GG@ H en Automatique. HHg@ H IhhIh@ H All rights reserved. This file is distributed under the terms of JJ@ H the GNU Lesser General Public License version 2.1, with the KKN@ H special exception on linking described in the file LICENSE. LOOLO@ H MM@ H************************************************************************NN5@ 3* First-class synchronous communication. This module implements synchronous inter-thread communications over channels. As in John Reppy's Concurrent ML system, the communication events are first-class values: they can be built and combined independently before being offered for communication. 栠 C* The type of communication channels carrying values of type ['a]. +8* Return a new channel. Ϡ D* The type of communication events returning a result of type ['a].  * [send ch v] returns the event consisting in sending the value [v] over the channel [ch]. The result value of this event is [()]. " * [receive ch] returns the event consisting in receiving a value from the channel [ch]. The result value of this event is the value received. Ǡ s* [always v] returns an event that is always ready for synchronization. The result value of this event is [v]. { a* [choose evl] returns the event that is the alternative of all the events in the list [evl].  * [wrap ev fn] returns the event that performs the same communications as [ev], then applies the post-processing function [fn] on the return value.  * [wrap_abort ev fn] returns the event that performs the same communications as [ev], but if it is not selected the function [fn] is called after the synchronization.  * [guard fn] returns the event that, when synchronized, computes [fn()] and behaves as the resulting event. This enables computing events with side-effects at the time of the synchronization operation.  * 'Synchronize' on an event: offer all the communication possibilities specified in the event to the outside world, and block until one of the communications succeed. The result value of that communication is returned. ` b* 'Synchronize' on an alternative of events. [select evl] is shorthand for [sync(choose evl)].  2* Non-blocking version of {!Event.sync}: offer all the communication possibilities specified in the event to the outside world, and if one can take place immediately, perform it and return [Some r] where [r] is the result value of that communication. Otherwise, return [None] without blocking. @;,../../ocamlc)-nostdlib"-I,../../stdlib"-I4../../otherlibs/unix"-c"-w'+33..39+-warn-error"+A"-g*-bin-annot ]/home/touraine/ci/builds/workspace/main/flambda/false/label/ocaml-arm-32/otherlibs/systhreads @@0S0ĂkIحC3      @@@8CamlinternalFormatBasics0%FU(Q/TuA0yY0%  &Stdlib0-i8Q"L{v;@0yY0%  AMC0Ӑ>@@@@ Z@@@Qmΰ@@ܰ(o@@@`@̐ @@7W@@P@@