summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
Diffstat (limited to 'dev-ml/ppx_sexp_conv')
-rw-r--r--dev-ml/ppx_sexp_conv/Manifest2
-rw-r--r--dev-ml/ppx_sexp_conv/files/oc43.patch193
-rw-r--r--dev-ml/ppx_sexp_conv/ppx_sexp_conv-0.9.0.ebuild32
-rw-r--r--dev-ml/ppx_sexp_conv/ppx_sexp_conv-113.33.00.ebuild46
4 files changed, 33 insertions, 240 deletions
diff --git a/dev-ml/ppx_sexp_conv/Manifest b/dev-ml/ppx_sexp_conv/Manifest
index 25d91a6e8994..684191440502 100644
--- a/dev-ml/ppx_sexp_conv/Manifest
+++ b/dev-ml/ppx_sexp_conv/Manifest
@@ -1 +1 @@
-DIST ppx_sexp_conv-113.33.00.tar.gz 79043 SHA256 fdd6b6f1c8dc81ae969fef74724bc72346f79bf7750aebe88f1e0abf526e4710 SHA512 398e13b3689874aab627d192a05ea746c7fcd1ab38443757e9ff4be7592899f80d1d007d6330880f59d34ebf93cf4cae78da90b9418729854cc4cbe2c218b21d WHIRLPOOL 2db0bc7d8915e3fcba772e81801413e84b974533a47a128e6b12da8506a0a8ccb119a2e16fc2b231f00d8caed3e02edadaa0905160cb26a612391633cc8cc315
+DIST ppx_sexp_conv-0.9.0.tar.gz 28000 SHA256 3f79fdc1caa1a8ba8e02291c1572e5524ae057de31f62b62766d2ec06a989091 SHA512 af3d28a3cdb7c796549a2598c218f69a69d58da715ef2d16077c3adeb22823fa7bec6bc0d8cb6caaf2a0adb56dfcb39d667975959251fb310b69d6abe8302845 WHIRLPOOL 8f54bdaf830801ecbd1682aedbf1384e88d4fb85f575332150729e927d4b9a4deb4c3ed4e0473cf64502db4cc393c0025e087c92e41b306e42445c3da0a931c6
diff --git a/dev-ml/ppx_sexp_conv/files/oc43.patch b/dev-ml/ppx_sexp_conv/files/oc43.patch
deleted file mode 100644
index efb85e29306c..000000000000
--- a/dev-ml/ppx_sexp_conv/files/oc43.patch
+++ /dev/null
@@ -1,193 +0,0 @@
-diff -uNr ppx_sexp_conv-113.33.00/expander/ppx_sexp_conv_expander.ml ppx_sexp_conv-113.33.01+4.03/expander/ppx_sexp_conv_expander.ml
---- ppx_sexp_conv-113.33.00/expander/ppx_sexp_conv_expander.ml 2016-03-09 16:44:54.000000000 +0100
-+++ ppx_sexp_conv-113.33.01+4.03/expander/ppx_sexp_conv_expander.ml 2016-04-18 12:09:44.000000000 +0200
-@@ -491,30 +491,33 @@
- let lid = Located.map lident cnstr in
- let str = estring ~loc cnstr.txt in
- match cd.pcd_args with
-- | [] ->
-- ppat_construct ~loc lid None --> [%expr Sexplib.Sexp.Atom [%e str]]
-- | args ->
-- match args with
-- | [ [%type: [%t? tp] sexp_list ] ] ->
-- let cnv_expr = Fun_or_match.expr ~loc (sexp_of_type renaming tp) in
-- ppat_construct ~loc lid (Some [%pat? l]) -->
-- [%expr
-- Sexplib.Sexp.List
-- (Sexplib.Sexp.Atom [%e str] ::
-- Sexplib.Conv.list_map [%e cnv_expr] l)]
-- | _ ->
-- let sexp_of_args = List.map ~f:(sexp_of_type renaming) args in
-- let cnstr_expr = [%expr Sexplib.Sexp.Atom [%e str] ] in
-- let bindings, patts, vars = Fun_or_match.map_tmp_vars ~loc sexp_of_args in
-- let patt =
-- match patts with
-- | [patt] -> patt
-- | _ -> ppat_tuple ~loc patts
-- in
-- ppat_construct ~loc lid (Some patt) -->
-- pexp_let ~loc Nonrecursive bindings
-- [%expr Sexplib.Sexp.List [%e elist ~loc (cnstr_expr :: vars)]]
-- )
-+ | Pcstr_record _ -> failwith "Pcstr_record unsupported"
-+ | Pcstr_tuple pcd_args ->
-+ match pcd_args with
-+ | [] ->
-+ ppat_construct ~loc lid None --> [%expr Sexplib.Sexp.Atom [%e str]]
-+ | args ->
-+ match args with
-+ | [ [%type: [%t? tp] sexp_list ] ] ->
-+ let cnv_expr = Fun_or_match.expr ~loc (sexp_of_type renaming tp) in
-+ ppat_construct ~loc lid (Some [%pat? l]) -->
-+ [%expr
-+ Sexplib.Sexp.List
-+ (Sexplib.Sexp.Atom [%e str] ::
-+ Sexplib.Conv.list_map [%e cnv_expr] l)]
-+ | _ ->
-+ let sexp_of_args = List.map ~f:(sexp_of_type renaming) args in
-+ let cnstr_expr = [%expr Sexplib.Sexp.Atom [%e str] ] in
-+ let bindings, patts, vars = Fun_or_match.map_tmp_vars ~loc sexp_of_args in
-+ let patt =
-+ match patts with
-+ | [patt] -> patt
-+ | _ -> ppat_tuple ~loc patts
-+ in
-+ ppat_construct ~loc lid (Some patt) -->
-+ pexp_let ~loc Nonrecursive bindings
-+ [%expr Sexplib.Sexp.List [%e elist ~loc (cnstr_expr :: vars)]]
-+ )
-
- let sexp_of_sum tps cds = Fun_or_match.Match (branch_sum tps cds)
-
-@@ -721,7 +724,7 @@
- let sexp_of_tds ~loc ~path:_ (rec_flag, tds) =
- let rec_flag = really_recursive rec_flag tds in
- let bindings = List.map tds ~f:sexp_of_td |> List.concat in
-- [pstr_value ~loc rec_flag bindings]
-+ pstr_value_list ~loc rec_flag bindings
-
- let sexp_of_exn ~loc:_ ~path ec =
- let renaming = Renaming.identity in
-@@ -730,14 +733,14 @@
- let expr =
- match ec with
- | {pext_name = {loc; txt = cnstr};
-- pext_kind = Pext_decl ([], None); _;} ->
-+ pext_kind = Pext_decl (Pcstr_tuple [], None); _;} ->
- [%expr
- Sexplib.Exn_magic.register [%e pexp_construct ~loc
- (Located.lident ~loc cnstr) None]
- [%e estring ~loc (get_full_cnstr cnstr)]
- ]
- | {pext_name = {loc; txt = cnstr};
-- pext_kind = Pext_decl (_::_ as tps, None); _;} ->
-+ pext_kind = Pext_decl (Pcstr_tuple ((_::_) as tps), None); _;} ->
- let fps = List.map ~f:(fun tp -> sexp_of_type renaming tp) tps in
- let sexp_converters = List.map fps ~f:Fun_or_match.(expr ~loc) in
- let _, patts, vars = Fun_or_match.map_tmp_vars ~loc fps in
-@@ -761,6 +764,8 @@
- eapply ~loc partial sexp_converters
- in
- [%expr [%e call] ]
-+ | { pext_kind = Pext_decl (Pcstr_record _, _); _;} ->
-+ failwith "Pcstr_record not supported"
- | { pext_kind = Pext_decl (_, Some _); _} ->
- Location.raise_errorf ~loc "sexp_of_exn/:"
- | { pext_kind = Pext_rebind _; _} ->
-@@ -1089,13 +1094,14 @@
- (* Generate matching code for well-formed S-expressions wrt. sum types *)
- let mk_good_sum_matches (loc,cds) =
- List.map cds ~f:(function
-- | { pcd_name = cnstr; pcd_args = []; _} ->
-+ | { pcd_args = Pcstr_record _; _} -> failwith "Pcstr_record unsupported"
-+ | { pcd_name = cnstr; pcd_args = Pcstr_tuple []; _} ->
- let lcstr = pstring ~loc (String.uncapitalize cnstr.txt) in
- let str = pstring ~loc cnstr.txt in
- [%pat? Sexplib.Sexp.Atom ([%p lcstr] | [%p str])] -->
- pexp_construct ~loc (Located.lident ~loc cnstr.txt) None
-
-- | { pcd_name = cnstr; pcd_args = (_::_ as tps); _} ->
-+ | { pcd_name = cnstr; pcd_args = Pcstr_tuple (_::_ as tps); _} ->
- let lcstr = pstring ~loc (String.uncapitalize cnstr.txt) in
- let str = pstring ~loc cnstr.txt in
- [%pat? (Sexplib.Sexp.List
-@@ -1109,14 +1115,15 @@
- wrt. sum types *)
- let mk_bad_sum_matches (loc,cds) =
- List.map cds ~f:(function
-- | { pcd_name = cnstr; pcd_args = []; _} ->
-+ | { pcd_args = Pcstr_record _; _} -> failwith "Pcstr_record unsupported"
-+ | { pcd_name = cnstr; pcd_args = Pcstr_tuple []; _} ->
- let lcstr = pstring ~loc (String.uncapitalize cnstr.txt) in
- let str = pstring ~loc cnstr.txt in
- [%pat? Sexplib.Sexp.List
- (Sexplib.Sexp.Atom ([%p lcstr] | [%p str]) :: _) as sexp
- ] -->
- [%expr Sexplib.Conv_error.stag_no_args _tp_loc sexp]
-- | { pcd_name = cnstr; pcd_args = _::_; _} ->
-+ | { pcd_name = cnstr; pcd_args = Pcstr_tuple (_::_); _} ->
- let lcstr = pstring ~loc (String.uncapitalize cnstr.txt) in
- let str = pstring ~loc cnstr.txt in
- [%pat? Sexplib.Sexp.Atom ([%p lcstr] | [%p str]) as sexp] -->
-@@ -1479,13 +1486,14 @@
- internals @ externals)
- |> List.concat
- in
-- [pstr_value ~loc Recursive bindings]
-+ pstr_value_list ~loc Recursive bindings
- | Nonrecursive ->
- let bindings =
- List.map tds ~f:(fun td ->
- let internals,externals = td_of_sexp ~loc ~poly ~path td in
-- [pstr_value ~loc Nonrecursive internals;
-- pstr_value ~loc Nonrecursive externals])
-+ pstr_value_list ~loc Nonrecursive internals @
-+ pstr_value_list ~loc Nonrecursive externals
-+ )
- |> List.concat
- in
- bindings
-@@ -1496,7 +1504,7 @@
- internals @ externals)
- |> List.concat
- in
-- [pstr_value ~loc rec_flag bindings]
-+ pstr_value_list ~loc rec_flag bindings
- end
-
- let type_of_sexp ~path ctyp =
-diff -uNr ppx_sexp_conv-113.33.00/js-utils/gen_install.ml ppx_sexp_conv-113.33.01+4.03/js-utils/gen_install.ml
---- ppx_sexp_conv-113.33.00/js-utils/gen_install.ml 2016-03-09 16:44:54.000000000 +0100
-+++ ppx_sexp_conv-113.33.01+4.03/js-utils/gen_install.ml 2016-04-18 12:09:44.000000000 +0200
-@@ -31,7 +31,7 @@
- |> List.map (fun line -> Scanf.sscanf line "%[^=]=%S" (fun k v -> (k, v)))
-
- let remove_cwd =
-- let prefix = Sys.getcwd () ^ "/" in
-+ let prefix = Sys.getcwd () ^ Filename.dir_sep in
- let len_prefix = String.length prefix in
- fun fn ->
- let len = String.length fn in
-diff -uNr ppx_sexp_conv-113.33.00/_oasis ppx_sexp_conv-113.33.01+4.03/_oasis
---- ppx_sexp_conv-113.33.00/_oasis 2016-03-09 16:44:54.000000000 +0100
-+++ ppx_sexp_conv-113.33.01+4.03/_oasis 2016-04-18 12:09:44.000000000 +0200
-@@ -1,8 +1,8 @@
- OASISFormat: 0.4
--OCamlVersion: >= 4.02.3
-+OCamlVersion: >= 4.03.0
- FindlibVersion: >= 1.3.2
- Name: ppx_sexp_conv
--Version: 113.33.00
-+Version: 113.33.01+4.03
- Synopsis: Generation of S-expression conversion functions from type definitions
- Authors: Jane Street Group, LLC <opensource@janestreet.com>
- Copyrights: (C) 2015-2016 Jane Street Group LLC <opensource@janestreet.com>
-diff -uNr ppx_sexp_conv-113.33.00/opam ppx_sexp_conv-113.33.01+4.03/opam
---- ppx_sexp_conv-113.33.00/opam 2016-03-18 12:08:01.000000000 +0100
-+++ ppx_sexp_conv-113.33.01+4.03/opam 2016-04-18 12:27:13.000000000 +0200
-@@ -17,4 +17,4 @@
- "ppx_type_conv"
- "sexplib"
- ]
--available: [ ocaml-version >= "4.02.3" ]
-+available: [ ocaml-version >= "4.03.0" ]
diff --git a/dev-ml/ppx_sexp_conv/ppx_sexp_conv-0.9.0.ebuild b/dev-ml/ppx_sexp_conv/ppx_sexp_conv-0.9.0.ebuild
new file mode 100644
index 000000000000..f5d0e8d3410f
--- /dev/null
+++ b/dev-ml/ppx_sexp_conv/ppx_sexp_conv-0.9.0.ebuild
@@ -0,0 +1,32 @@
+# Copyright 1999-2017 Gentoo Foundation
+# Distributed under the terms of the GNU General Public License v2
+
+EAPI=6
+
+DESCRIPTION="Support Library for type-driven code generators"
+HOMEPAGE="https://github.com/janestreet/ppx_sexp_conv"
+SRC_URI="https://github.com/janestreet/ppx_sexp_conv/archive/v${PV}.tar.gz -> ${P}.tar.gz"
+
+LICENSE="Apache-2.0"
+SLOT="0/${PV}"
+KEYWORDS="~amd64"
+IUSE=""
+
+DEPEND="
+ dev-ml/ppx_core:=
+ dev-ml/ppx_driver:=
+ dev-ml/ppx_type_conv:=
+ dev-ml/ppx_metaquot:=
+ dev-ml/sexplib:=
+ dev-ml/ocaml-migrate-parsetree:=
+ "
+RDEPEND="${DEPEND}"
+DEPEND="${DEPEND} dev-ml/opam dev-ml/jbuilder"
+
+src_install() {
+ opam-installer -i \
+ --prefix="${ED}/usr" \
+ --libdir="${D}/$(ocamlc -where)" \
+ --docdir="${ED}/usr/share/doc/${PF}" \
+ ${PN}.install || die
+}
diff --git a/dev-ml/ppx_sexp_conv/ppx_sexp_conv-113.33.00.ebuild b/dev-ml/ppx_sexp_conv/ppx_sexp_conv-113.33.00.ebuild
deleted file mode 100644
index ea7fda7b4660..000000000000
--- a/dev-ml/ppx_sexp_conv/ppx_sexp_conv-113.33.00.ebuild
+++ /dev/null
@@ -1,46 +0,0 @@
-# Copyright 1999-2015 Gentoo Foundation
-# Distributed under the terms of the GNU General Public License v2
-
-EAPI="5"
-
-inherit oasis eutils
-
-DESCRIPTION="Support Library for type-driven code generators"
-HOMEPAGE="http://www.janestreet.com/ocaml"
-SRC_URI="http://ocaml.janestreet.com/ocaml-core/${PV%.*}/files/${P}.tar.gz"
-
-LICENSE="Apache-2.0"
-SLOT="0/${PV}"
-KEYWORDS="~amd64"
-IUSE=""
-
-DEPEND="dev-ml/ppx_tools:=
- dev-ml/ppx_core:=
- dev-ml/ppx_type_conv:=
- dev-ml/sexplib:=
- "
-
-RDEPEND="${DEPEND}"
-DEPEND="${DEPEND} dev-ml/opam"
-
-src_prepare() {
- has_version '>=dev-lang/ocaml-4.03' && epatch "${FILESDIR}/oc43.patch"
-}
-
-src_configure() {
- emake setup.exe
- OASIS_SETUP_COMMAND="./setup.exe" oasis_src_configure
-}
-
-src_compile() {
- emake
-}
-
-src_install() {
- opam-installer -i \
- --prefix="${ED}/usr" \
- --libdir="${D}/$(ocamlc -where)" \
- --docdir="${ED}/usr/share/doc/${PF}" \
- ${PN}.install || die
- dodoc CHANGES.md
-}