31 lines
1.5 KiB
OCaml
31 lines
1.5 KiB
OCaml
|
(**************************************************************************)
|
||
|
(* *)
|
||
|
(* Copyright (c) 2014 - 2016. *)
|
||
|
(* Dynamic Ledger Solutions, Inc. <contact@tezos.com> *)
|
||
|
(* *)
|
||
|
(* All rights reserved. No warranty, explicit or implicit, provided. *)
|
||
|
(* *)
|
||
|
(**************************************************************************)
|
||
|
|
||
|
type ('l, 'p) node =
|
||
|
| Int of 'l * string
|
||
|
| String of 'l * string
|
||
|
| Prim of 'l * 'p * ('l, 'p) node list * string option
|
||
|
| Seq of 'l * ('l, 'p) node list * string option
|
||
|
|
||
|
type 'p canonical
|
||
|
type canonical_location = int
|
||
|
|
||
|
val root : 'p canonical -> (canonical_location, 'p) node
|
||
|
val canonical_location_encoding : canonical_location Data_encoding.encoding
|
||
|
val canonical_encoding : 'l Data_encoding.encoding -> 'l canonical Data_encoding.encoding
|
||
|
val erased_encoding : 'l -> 'p Data_encoding.encoding -> ('l, 'p) node Data_encoding.encoding
|
||
|
val table_encoding : 'l Data_encoding.encoding -> 'p Data_encoding.encoding -> ('l, 'p) node Data_encoding.encoding
|
||
|
|
||
|
val location : ('l, 'p) node -> 'l
|
||
|
val annotation : ('l, 'p) node -> string option
|
||
|
|
||
|
val strip_locations : (_, 'p) node -> 'p canonical
|
||
|
val extract_locations : ('l, 'p) node -> 'p canonical * (canonical_location * 'l) list
|
||
|
val inject_locations : (canonical_location -> 'l) -> 'p canonical -> ('l, 'p) node
|