Typing Unmarshalling without Marshalling Types - Archive ouverte HAL Accéder directement au contenu
Communication Dans Un Congrès Année : 2012

Typing Unmarshalling without Marshalling Types

Grégoire Henry
  • Fonction : Auteur
Michel Mauny
  • Fonction : Auteur
Pascal Manoury
  • Fonction : Auteur

Résumé

Unmarshalling primitives in statically typed language require, in order to preserve type safety, to dynamically verify the compatibility between the incoming values and the statically expected type. In the context of programming languages based on parametric polymorphism and uniform data representation, we propose a relation of compatibility between (unmarshalled) memory graphs and types. It is defined as constraints over nodes of the memory graph. Then, we propose an algorithm to check the compatibility between a memory graph and a type. It is described as a constraint solver based on a rewriting system. We have shown that the proposed algorithm is sound and semi-complete in presence of algebraic data types, mutable data, polymorphic sharing, cycles, and functional values, however, in its general form, it may not terminate. We have implemented a prototype tailored for the OCaml compiler [17] that always terminates and still seems sufficiently complete in practice.

Dates et versions

hal-01282253 , version 1 (03-03-2016)

Identifiants

Citer

Grégoire Henry, Michel Mauny, Emmanuel Chailloux, Pascal Manoury. Typing Unmarshalling without Marshalling Types. International Conference on Functional Programming, Sep 2012, Copenhagen, Denmark. pp.287-298, ⟨10.1145/2364527.2364569⟩. ⟨hal-01282253⟩
63 Consultations
0 Téléchargements

Altmetric

Partager

Gmail Facebook X LinkedIn More