module Cudf_types:sig..end
CUDF type library
Implement core CUDF types (see CUDF spec. ยง2.2.2).
For parsing and pretty printing of CUDF types see Cudf_types_pp.
typeversion =int
typerelop =[ `Eq | `Geq | `Gt | `Leq | `Lt | `Neq ]
typeconstr =(relop * version) option
typepkgname =string
typevpkg =pkgname * constr
typevpkglist =vpkg list
typeenum_keep =[ `Keep_feature | `Keep_none | `Keep_package | `Keep_version ]
typevpkgformula =vpkg list list
CNF formula. Inner lists are OR-ed, outer AND-ed. E.g.:
[ foo ] ; [ bar ; baz ] [] typeveqpkg =pkgname * ([ `Eq ] * version) option
typeveqpkglist =veqpkg list
typetyp =[ `Bool
| `Enum of string list
| `Ident
| `Int
| `Nat
| `Pkgname
| `Posint
| `String
| `Typedecl
| `Veqpkg
| `Veqpkglist
| `Vpkg
| `Vpkgformula
| `Vpkglist ]
CUDF types
val keep_type : typ
val keep_enums : string list
typetypedecl1 =[ `Bool of bool option
| `Enum of string list * string option
| `Ident of string option
| `Int of int option
| `Nat of int option
| `Pkgname of string option
| `Posint of int option
| `String of string option
| `Typedecl of typedecl option
| `Veqpkg of veqpkg option
| `Veqpkglist of veqpkglist option
| `Vpkg of vpkg option
| `Vpkgformula of vpkgformula option
| `Vpkglist of vpkglist option ]
(Single) type declaration: each variant denotes a type, its argument the default value, None if missing
typetypedecl =(string * typedecl1) list
typetyped_value =[ `Bool of bool
| `Enum of string list * string
| `Ident of string
| `Int of int
| `Nat of int
| `Pkgname of string
| `Posint of int
| `String of string
| `Typedecl of typedecl
| `Veqpkg of veqpkg
| `Veqpkglist of veqpkglist
| `Vpkg of vpkg
| `Vpkgformula of vpkgformula
| `Vpkglist of vpkglist ]
Typed value in the value space of all CUDF types
val type_of_typedecl : typedecl1 -> typextract the type of a (single) type declaration
val typedecl_of_value : typed_value -> typedecl1Create a (single) type declaration having as default value the given typed value (i.e. apply the "Some" monad to typed values)
val value_of_typedecl : typedecl1 -> typed_value optionExtract the default value from a type declaration (or return None)
val typedecl_of_type : typ -> typedecl1Create a (single) type declaration with no default value
val type_of_value : typed_value -> typval cast : typ -> typed_value -> typed_valuecast ty v attempt a runtime cast of a given (typed) value to a different
type.
Type_error if casting is not possibleTypes used in parsing, before values are injected into the CUDF type system.
type'tystanza =(string * 'ty) list
RFC-822-like stanza, i.e. an associative list mapping property names to property values.
Values are typed according to the type variable 'ty. Usually, libCUDF
uses either string stanza (for untyped stanzas) or
Cudf_types.typed_value stanza (for typed stanzas).
exception Parse_error_822 of string * loc
Error while parsing RFC822-like syntax of CUDF documents.
arguments: error message and file range, respectively.
exception Syntax_error of string * loc
Syntax error while parsing some literal value
arguments: error message and file range, respectively
exception Type_error of typ * typed_value * loc
Type error: mismatch between typed value and expected type
arguments: expected type, found value
val is_eq_formula : vpkgformula -> boolCheck whether a formula uses only equality tests over package versions.