package picos
Pico scheduler framework
Install
Dune Dependency
Authors
Maintainers
Sources
picos-0.3.0.tbz
sha256=544804c0bde4b29764f82f04e7defed7c06bc43e5a6ce3f7fdc326cb54a7f066
sha512=4c93427e477fb52374a554a8b9c4c92836a9b5899161275d1473269ab526a1f59177209140631ed763a55be375855dea12f076e18bf4124522414986c0e257be
doc/src/picos.rc/intf.ml.html
Source file intf.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 85 86 87 88 89 90 91
module type Resource = sig (** A resource that must be explicitly {{!val-dispose} disposed}. *) type t (** Represents a disposable resource. *) val equal : t -> t -> bool (** [equal resource1 resource2] determines whether [resource1] and [resource2] are one and the same. *) val hash : t -> int (** [hash resource] computes the hash value for [resource]. *) val dispose : t -> unit (** [dispose resource] releases the resource. ⚠️ The physical [resource] value may be reused only after [dispose] has been called on it. *) end module type S = sig (** An externally reference counted resource. ℹ️ This is intended for cases where a resource needs to be safely shared between multiple independent threads of control whether they are fibers, threads, or domains. In that use case you typically need to {{!incr} increment} the reference count before handing the resource from one independent thread of control to another and the other independent thread of control then becomes responsible for {{!decr} decrementing} the reference count after being done with the resource. *) module Resource : Resource (** Resource type. *) type t (** Opaque type alias for the resource type. *) val create : ?dispose:bool -> Resource.t -> t (** [create resource] adds an entry for the resource with an initial reference count of [1] to the table for the resource and returns the resource as a value of the {{!t} opaque alias type}. The optional [dispose] argument defaults to [true]. When explicitly specified as [~dispose:false], the resource will not be {{!module-Resource.dispose} disposed} when the reference count becomes zero. This is intended for special cases where a resource is e.g. managed outside of the control of the user program. *) val unsafe_get : t -> Resource.t (** [unsafe_get opaque_resource] casts the opaque alias type back to the resource type. ⚠️ This should only be called and the resource used either after {{!create} creating} the reference counting entry or after {{!incr} incrementing} the reference count and before the matching {{!decr} decrement}. *) val incr : t -> unit (** [incr opaque_resource] tries to find the entry for the resource and increment the reference count. @raise Invalid_argument in case no entry is found for the resource or the reference count was zero or the resource was marked as closed previously by a {{!decr} decrement} operation. *) val decr : ?close:bool -> t -> unit (** [decr opaque_resource] tries to find the entry for the resource and decrement the reference count. If the reference count becomes zero, the entry for the resource will be removed and the resource will be {{!module-Resource.dispose} disposed}, unless [~dispose:false] was specified for {!create}. The optional [close] argument defaults to [false]. When explicitly specified as [~close:true] the resource will be marked as closed and attempts to {{!incr} increment} the reference will fail. @raise Invalid_argument in case no entry is found for the resource or the reference count was zero. *) type info = { resource : Resource.t; (** The resource. *) count : int; (** Reference count. This may be [0]. *) closed : bool; (** Whether the resource has been closed, see {!decr}. *) dispose : bool; (** Whether to dispose the resource, see {!create}. *) bt : Printexc.raw_backtrace; (** Backtrace captured at {!create}. *) } (** Information on a resource. *) val infos : unit -> info Seq.t (** [infos ()] returns a sequence of entries in the reference counting table at the point in time of of calling [infos ()]. *) end
sectionYPositions = computeSectionYPositions($el), 10)"
x-init="setTimeout(() => sectionYPositions = computeSectionYPositions($el), 10)"
>