Generic Programming in OCAML

Abstract : We present a library for generic programming in OCAML, adapting some techniques borrowed from other functional languages. The library makes use of three recent additions to OCAML: generalised abstract datatypes are essential to reflect types, extensible variants allow this reflection to be open for new additions, and extension points provide syntactic sugar and generate boiler plate code that simplify the use of the library. The building blocks of the library can be used to support many approaches to generic programming through the concept of view. Generic traversals are implemented on top of the library and provide powerful combinators to write concise definitions of recursive functions over complex tree types. Our case study is a type-safe deserialization function that respects type abstraction.
Document type :
Preprints, Working Papers, ...
Complete list of metadatas

Cited literature [34 references]  Display  Hide  Download

https://hal.inria.fr/hal-01664286
Contributor : Michel Mauny <>
Submitted on : Thursday, December 14, 2017 - 4:41:59 PM
Last modification on : Wednesday, July 3, 2019 - 10:48:05 AM

File

generic.submitted.pdf
Files produced by the author(s)

Identifiers

  • HAL Id : hal-01664286, version 1

Citation

Florent Balestrieri, Michel Mauny. Generic Programming in OCAML. 2017. ⟨hal-01664286⟩

Share

Metrics

Record views

178

Files downloads

650