package frama-c
Install
    
    dune-project
 Dependency
Authors
- 
  
    
    MMichele Alberti
- 
  
    
    TThibaud Antignac
- 
  
    
    GGergö Barany
- 
  
    
    PPatrick Baudin
- 
  
    
    TThibaut Benjamin
- 
  
    
    AAllan Blanchard
- 
  
    
    LLionel Blatter
- 
  
    
    FFrançois Bobot
- 
  
    
    RRichard Bonichon
- 
  
    
    QQuentin Bouillaguet
- 
  
    
    DDavid Bühler
- 
  
    
    ZZakaria Chihani
- 
  
    
    LLoïc Correnson
- 
  
    
    JJulien Crétin
- 
  
    
    PPascal Cuoq
- 
  
    
    ZZaynah Dargaye
- 
  
    
    BBasile Desloges
- 
  
    
    JJean-Christophe Filliâtre
- 
  
    
    PPhilippe Herrmann
- 
  
    
    MMaxime Jacquemin
- 
  
    
    FFlorent Kirchner
- 
  
    
    AAlexander Kogtenkov
- 
  
    
    TTristan Le Gall
- 
  
    
    JJean-Christophe Léchenet
- 
  
    
    MMatthieu Lemerre
- 
  
    
    DDara Ly
- 
  
    
    DDavid Maison
- 
  
    
    CClaude Marché
- 
  
    
    AAndré Maroneze
- 
  
    
    TThibault Martin
- 
  
    
    FFonenantsoa Maurica
- 
  
    
    MMelody Méaulle
- 
  
    
    BBenjamin Monate
- 
  
    
    YYannick Moy
- 
  
    
    AAnne Pacalet
- 
  
    
    VValentin Perrelle
- 
  
    
    GGuillaume Petiot
- 
  
    
    DDario Pinto
- 
  
    
    VVirgile Prevosto
- 
  
    
    AArmand Puccetti
- 
  
    
    FFélix Ridoux
- 
  
    
    VVirgile Robles
- 
  
    
    MMuriel Roger
- 
  
    
    JJulien Signoles
- 
  
    
    NNicolas Stouls
- 
  
    
    KKostyantyn Vorobyov
- 
  
    
    BBoris Yakobowski
Maintainers
Sources
sha256=25885f89daa478aeafdd1e4205452c7a30695d4b3b3ee8fc98b4a9c5f83f79c2
    
    
  doc/frama-c.kernel/Frama_c_kernel/Unmarshal/index.html
Module Frama_c_kernel.Unmarshal
Provides a function input_val, similar in functionality to the standard library function Marshal.from_channel. The main difference with Marshal.from_channel is that input_val is able to apply transformation functions on the values on the fly as they are read from the input channel.
Because it has an abstract representation of the type, input_val is able to catch some inconsistencies that Marshal.from_channel cannot. It is therefore "more" type-safe, but only if it is always used in conditions where the static type attributed to the result by the type-checker agrees with the representation of the type passed as second argument to input_val. No such verification is done by this module (this would require changes to the compiler).
The sanity checks are not the primary purpose of input_val, and it is possible for a bug where the representation of a value of the wrong type is passed to input_val to go undetected, just as this can happen with Marshal.from_channel.
Type t is used to describe the type of the data to be read and the transformations to be applied to the data.
Abstract is used to input a value without any checking or transformation (as Marshal.from_channel does). In this case, you don't need to provide a precise description of the representation of the data.
Structure a is used to provide a description of the representation of the data, along with optional transformation functions for parts of the data.
a can be:
- Array(t), indicating that the data is an array of values of the same type, each value being described by- t.
- Sum(c)for describing a non-array type where- cis an array describing the non-constant constructors of the type being described (in the order of their declarations in that type). Each element of this latter array is an array of- tthat describes (in order) the fields of the corresponding constructor.
- Dependent_pair(e,f)for instructing the unmarshaler to reconstruct the first component of a pair first, using- eas its description, and to apply function- fto this value in order to get the description of the pair's second component.
The shape of a must match the shape of the representation of the type of the data being imported, or input_val may report an error when the data doesn't match the description.
Transform (u, f) is used to specify a transformation function on the data described by u. input_val will read and rebuild the data as described by u, then call f on that data and return the result returned by f.
Return (u, f) is the same as Transform, except that the data is not rebuilt, and () is passed to f instead of the data. This is to be used when the transformation functions of u rebuild the data by side effects and the version rebuilt by input_val is irrelevant.
Dynamic f is used to build a new description on the fly when a new data of the current type is encountered.
val input_val : in_channel -> t -> 'ainput_val c t Read a value from the input channel c, applying the transformations described by t.
val null : Obj.trecursive values cannot be completely formed at the time they are passed to their transformation function. When traversing a recursive value, the transformation function must check the fields for physical equality to null (with the function ==) and avoid using any field that is equal to null.
Use this function when you don't want to change the value unmarshaled by input_val. You can also use your own identity function, but using this one is more efficient.
Convenience functions for describing transformations.
val t_unit : tval t_int : tval t_string : tval t_float : tval t_bool : tval t_int32 : tval t_int64 : tval t_nativeint : tFunctions for writing deserializers.
val register_custom : string -> (in_channel -> Obj.t) -> unitval getword : in_channel -> Int32.tval read8s : in_channel -> intval read16s : in_channel -> intval read32s : in_channel -> intval read64s : in_channel -> intval read8u : in_channel -> intval read16u : in_channel -> intval read32u : in_channel -> intval read64u : in_channel -> intval readblock : in_channel -> Obj.t -> int -> int -> unitval readblock_rev : in_channel -> Obj.t -> int -> int -> unit