package mirage
Install
Dune Dependency
Authors
Maintainers
Sources
sha256=0c07d59eb52dc3d1506eb4121c4953104a12df79d08a0f0923c9b71e7474a026
sha512=666bf9ee20c9f9de058441f252f4f40ceec6a9ffd00e5cd3b7bfa9532fd65000aeb8a83f9e55586be98d0a86ea72f2dda94e924608135e3d63441359505de58a
doc/mirage.functoria/Functoria/Package/index.html
Module Functoria.Package
Source
Representation of opam packages.
The scope of package installation:
- Switch: installed with opam.
- Monorepo: locally fetched along unikernel sources.
The type for opam packages.
val v :
?scope:scope ->
?build:bool ->
?sublibs:string list ->
?libs:string list ->
?min:string ->
?max:string ->
?pin:string ->
?pin_version:string ->
string ->
t
v ~scope ~build ~sublibs ~libs ~min ~max ~pin opam
is a package
. Build
indicates a build-time dependency only, defaults to false
. The library name is by default the same as opam
, you can specify ~sublibs
to add sublibraries (e.g. ~sublibs:["mirage"] "foo"
will result in the library name ["foo.mirage"]
, and ~sublibs:[""; "mirage"] "foo"
will result in the library names ["foo";"foo.mirage"]
). In case the library name is disjoint (or empty), use ~libs
. Specifying both ~libs
and ~sublibs
leads to an invalid argument. Version constraints are given as min
(inclusive) and max
(exclusive). If pin
is provided, a pin-depends is generated, pin_version
is "dev"
by default. ~scope
specifies the installation location of the package.
with_scope t
returns t with chosen installation location.
pin t
is Some (name_version, r)
iff t
is pinned to the repository r
.
libraries t
is the set of libraries (and sub-libraries) used in the package t
. For most packages, it will only contain one library whose name is name t
.
max_versions
is the set of maximum versions of t
which are required.
min_versions
is the set minimum versions of t
which are required.
merge x y
is merges the information of x
and y
. The result is None
if name x != name y
.