package ppx_csv_conv
Install
Dune Dependency
Authors
Maintainers
Sources
sha256=bbea60f909f076dbe68440a6e01ac3bf5e9f7d12afed0c540977ffda22ab9e22
md5=e6bd8f3c49d66fd6ac2c5bb25cebd242
Description
Part of the Jane Street's PPX rewriters collection.
Published: 14 May 2018
README
ppx_csv_conv
Generate functions to read/write records in csv format.
ppx_csv_conv
generates functions to output some records as a csv file, and read the records back from a list of strings coming from a csv file or a database query.
Usage
Annotate the type: [@@deriving fields, csv]
type t = {
field : ...
....
} [@@deriving fields, csv]
Csv uses fields so fields is also required. Now the functions listed in Csvfields.Csv.Csvable
are included in the module, including conversion to and from string lists, dumping to files, and loading files.
The Csvfields.Csv
module provides the Atom
functor, which accepts a Stringable module to produce the necessary functions for recursive calls:
module Date = struct
include Date
include (Csvfields.Csv.Atom (Date) : Csvfields.Csv.Csvable with type t := t)
end
type t = {
a : float;
b : string;
c : int;
e : Date.t;
} [@@deriving fields, csv]
Generate code/functions with types:
include (Csvfields.Csv.Csvable with type t := t)
(Known) limitations:
No
option
,ref
, orlazy_t
types allowed.No variant types ... nothing other than primitive types and records. You should create your own stringable version of those types and use the
Atom
functor.The name of the type must be
t
.
Dependencies (8)
-
ppxlib
>= "0.3.0" & < "0.9.0"
-
ocaml-migrate-parsetree
>= "1.0" & < "2.0.0"
-
jbuilder
>= "1.0+beta18.1"
-
ppx_fields_conv
>= "v0.11" & < "v0.12"
-
ppx_conv_func
>= "v0.11" & < "v0.12"
-
csvfields
>= "v0.11" & < "v0.12"
-
base
>= "v0.11" & < "v0.12"
-
ocaml
>= "4.04.1"
Dev Dependencies
None
Conflicts (1)
-
jbuilder
= "1.0+beta19"