package picos_std
 sectionYPositions = computeSectionYPositions($el), 10)"
  x-init="setTimeout(() => sectionYPositions = computeSectionYPositions($el), 10)"
  >
  
  
  Sample libraries for Picos
Install
    
    dune-project
 Dependency
Authors
Maintainers
Sources
  
    
      picos-0.6.0.tbz
    
    
        
    
  
  
  
    
  
  
    
  
        sha256=3f5a08199cf65c2dae2f7d68f3877178f1da8eabf5376e15114e5a8958087dfa
    
    
  sha512=ad24910c47ce614268c4268874bb918da7f8b5f03b3ad706bbf30323635262e94ddab6be24eaebbca706bfa82c0a517d4272b396459e020c185942125c9bdb7b
    
    
  doc/src/picos_std.sync/lazy.ml.html
Source file lazy.ml
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85open Picos exception Undefined = Stdlib.Lazy.Undefined type 'a state = | Fun of (unit -> 'a) | Run of { fiber : Fiber.t; triggers : Trigger.t list } | Val of 'a | Exn of { exn : exn; trace : Printexc.raw_backtrace } type 'a t = 'a state Atomic.t let from_fun th = Atomic.make (Fun th) let from_val v = Atomic.make (Val v) let rec cleanup t trigger backoff = match Atomic.get t with | Val _ | Exn _ -> () | Fun _ -> failwith "impossible" | Run r as before -> begin match List_ext.drop_first_or_not_found trigger r.triggers with | triggers -> let after = Run { r with triggers } in if not (Atomic.compare_and_set t before after) then cleanup t trigger (Backoff.once backoff) | exception Not_found -> () end let rec force t fiber backoff = match Atomic.get t with | Val v -> v | Exn r -> Printexc.raise_with_backtrace r.exn r.trace | Fun th as before -> let after = Run { fiber; triggers = [] } in if Atomic.compare_and_set t before after then begin let result = match th () with | v -> Val v | exception exn -> let trace = Printexc.get_raw_backtrace () in Exn { exn; trace } in match Atomic.exchange t result with | Val _ | Exn _ | Fun _ -> failwith "impossible" | Run r -> List.iter Trigger.signal r.triggers; force t fiber Backoff.default end else force t fiber (Backoff.once backoff) | Run r as before -> if Fiber.equal r.fiber fiber then raise Undefined else let trigger = Trigger.create () in let triggers = trigger :: r.triggers in let after = Run { r with triggers } in if Atomic.compare_and_set t before after then begin match Trigger.await trigger with | None -> force t fiber Backoff.default | Some (exn, bt) -> cleanup t trigger Backoff.default; Printexc.raise_with_backtrace exn bt end else force t fiber (Backoff.once backoff) let force t = match Atomic.get t with | Val v -> v | Exn r -> Printexc.raise_with_backtrace r.exn r.trace | Fun _ | Run _ -> let fiber = Fiber.current () in Fiber.check fiber; force t fiber Backoff.default let map f t = from_fun @@ fun () -> f (force t) let is_val t = match Atomic.get t with Val _ -> true | Fun _ | Run _ | Exn _ -> false let map_val f t = match Atomic.get t with | Val x -> from_val (f x) | Exn { exn; trace } -> Printexc.raise_with_backtrace exn trace | _ -> map f t let force_val = force
 sectionYPositions = computeSectionYPositions($el), 10)"
  x-init="setTimeout(() => sectionYPositions = computeSectionYPositions($el), 10)"
  >