From 97fe29f8e1d3a7fab58002230a398f91597f114d Mon Sep 17 00:00:00 2001 From: Tom Repetti Date: Fri, 16 Oct 2020 09:43:30 -0400 Subject: [PATCH 1/4] Enable OCaml 4.10.0 support with new mknod call signature for PPX AST manipulation. --- src/ppx_deriving_cmdliner.cppo.ml | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/src/ppx_deriving_cmdliner.cppo.ml b/src/ppx_deriving_cmdliner.cppo.ml index 117fbc4..bfa86ea 100644 --- a/src/ppx_deriving_cmdliner.cppo.ml +++ b/src/ppx_deriving_cmdliner.cppo.ml @@ -286,7 +286,7 @@ let ser_str_of_type ~options ~path ({ ptype_loc = loc } as type_decl) = let ser = ser_expr_of_typ manifest [] "" in let lid = Ppx_deriving.mangle_lid (`PrefixSuffix ("M", "cmdliner_term")) lid in let orig_mod = Mod.ident (mknoloc lid) in - ([Str.module_ (Mb.mk (mknoloc mod_name) orig_mod)], + ([Str.module_ (Mb.mk (mknoloc (Some mod_name)) orig_mod)], [Vb.mk (pvar to_cmdliner_name) (polymorphize [%expr ([%e ser] : unit -> [%t typ] Cmdliner.Term.t)])]) | Some _ -> @@ -318,7 +318,7 @@ let ser_str_of_type ~options ~path ({ ptype_loc = loc } as type_decl) = let flid = lid (Printf.sprintf "%s.f" mod_name) in let field = Exp.field (Exp.ident flid) (flid) in let mod_ = - Str.module_ (Mb.mk (mknoloc mod_name) + Str.module_ (Mb.mk (mknoloc (Some mod_name)) (Mod.structure [ Str.type_ Type_Nonrecursive [typ]; Str.value Nonrecursive [record]; @@ -448,7 +448,7 @@ let ser_sig_of_type ~options ~path type_decl = in let record = Val.mk (mknoloc "f") (Typ.constr (lid "t_cmdliner_term") []) in let mod_ = - Sig.module_ (Md.mk (mknoloc mod_name) + Sig.module_ (Md.mk (mknoloc (Some mod_name)) (Mty.signature [ Sig.type_ Type_Nonrecursive [typ]; Sig.value record; From 680167d5f496c500f59efacb7413cef0a188ecd9 Mon Sep 17 00:00:00 2001 From: Tom Repetti Date: Fri, 16 Oct 2020 10:19:46 -0400 Subject: [PATCH 2/4] Make 4.10.0 changes backwards compatible through 4.06.0. --- src/ppx_deriving_cmdliner.cppo.ml | 12 +++++++++--- 1 file changed, 9 insertions(+), 3 deletions(-) diff --git a/src/ppx_deriving_cmdliner.cppo.ml b/src/ppx_deriving_cmdliner.cppo.ml index bfa86ea..0fa25f4 100644 --- a/src/ppx_deriving_cmdliner.cppo.ml +++ b/src/ppx_deriving_cmdliner.cppo.ml @@ -6,6 +6,12 @@ #define Type_Nonrecursive Nonrecursive #endif +#if OCAML_VERSION < (4, 10, 0) +#define Mknoloc_option(x) x +#else +#define Mknoloc_option(x) (Some x) +#endif + open Longident open Location open Asttypes @@ -286,7 +292,7 @@ let ser_str_of_type ~options ~path ({ ptype_loc = loc } as type_decl) = let ser = ser_expr_of_typ manifest [] "" in let lid = Ppx_deriving.mangle_lid (`PrefixSuffix ("M", "cmdliner_term")) lid in let orig_mod = Mod.ident (mknoloc lid) in - ([Str.module_ (Mb.mk (mknoloc (Some mod_name)) orig_mod)], + ([Str.module_ (Mb.mk (mknoloc Mknoloc_option(mod_name)) orig_mod)], [Vb.mk (pvar to_cmdliner_name) (polymorphize [%expr ([%e ser] : unit -> [%t typ] Cmdliner.Term.t)])]) | Some _ -> @@ -318,7 +324,7 @@ let ser_str_of_type ~options ~path ({ ptype_loc = loc } as type_decl) = let flid = lid (Printf.sprintf "%s.f" mod_name) in let field = Exp.field (Exp.ident flid) (flid) in let mod_ = - Str.module_ (Mb.mk (mknoloc (Some mod_name)) + Str.module_ (Mb.mk (mknoloc Mknoloc_option(mod_name)) (Mod.structure [ Str.type_ Type_Nonrecursive [typ]; Str.value Nonrecursive [record]; @@ -448,7 +454,7 @@ let ser_sig_of_type ~options ~path type_decl = in let record = Val.mk (mknoloc "f") (Typ.constr (lid "t_cmdliner_term") []) in let mod_ = - Sig.module_ (Md.mk (mknoloc (Some mod_name)) + Sig.module_ (Md.mk (mknoloc Mknoloc_option(mod_name)) (Mty.signature [ Sig.type_ Type_Nonrecursive [typ]; Sig.value record; From 47546728df2b06d618c068acbf991ebdc51754d1 Mon Sep 17 00:00:00 2001 From: Tom Repetti Date: Fri, 16 Oct 2020 11:04:54 -0400 Subject: [PATCH 3/4] Add 4.11.0 and 4.11.1 support by modifying Pconst_string with optional location. --- src/ppx_deriving_cmdliner.cppo.ml | 8 +++++++- 1 file changed, 7 insertions(+), 1 deletion(-) diff --git a/src/ppx_deriving_cmdliner.cppo.ml b/src/ppx_deriving_cmdliner.cppo.ml index 0fa25f4..43a2a5c 100644 --- a/src/ppx_deriving_cmdliner.cppo.ml +++ b/src/ppx_deriving_cmdliner.cppo.ml @@ -12,6 +12,12 @@ #define Mknoloc_option(x) (Some x) #endif +#if OCAML_VERSION < (4, 11, 0) +#define Pconst_string_argument(s, l) (s, None) +#else +#define Pconst_string_argument(s, l) (s, l, None) +#endif + open Longident open Location open Asttypes @@ -307,7 +313,7 @@ let ser_str_of_type ~options ~path ({ ptype_loc = loc } as type_decl) = let ty = Typ.poly poly_vars (polymorphize_ser [%type: unit -> [%t typ] Cmdliner.Term.t]) in let default_fun = let type_path = String.concat "." (path @ [type_decl.ptype_name.txt]) in - let e_type_path = Exp.constant (Pconst_string (type_path, None)) in + let e_type_path = Exp.constant (Pconst_string Pconst_string_argument(type_path, loc)) in [%expr fun _ -> invalid_arg ("ppx_deriving_cmdliner: Maybe a [@@deriving cmdliner] is missing when extending the type "^ [%e e_type_path])] From b15cedd41a7f05aeda9591ecffd7c5b5fa758057 Mon Sep 17 00:00:00 2001 From: Tom Repetti Date: Mon, 19 Oct 2020 00:03:29 -0400 Subject: [PATCH 4/4] Add 4.7-4.11 travis targets. --- .travis.yml | 5 +++++ dune-workspace.dev | 3 +++ 2 files changed, 8 insertions(+) diff --git a/.travis.yml b/.travis.yml index 127c64e..a7899f6 100644 --- a/.travis.yml +++ b/.travis.yml @@ -9,6 +9,11 @@ env: - OCAML_VERSION=4.04 PACKAGE="ppx_deriving_cmdliner" TESTS=true - OCAML_VERSION=4.05 PACKAGE="ppx_deriving_cmdliner" TESTS=true - OCAML_VERSION=4.06 PACKAGE="ppx_deriving_cmdliner" TESTS=true + - OCAML_VERSION=4.07 PACKAGE="ppx_deriving_cmdliner" TESTS=true + - OCAML_VERSION=4.08 PACKAGE="ppx_deriving_cmdliner" TESTS=true + - OCAML_VERSION=4.09 PACKAGE="ppx_deriving_cmdliner" TESTS=true + - OCAML_VERSION=4.10 PACKAGE="ppx_deriving_cmdliner" TESTS=true + - OCAML_VERSION=4.11 PACKAGE="ppx_deriving_cmdliner" TESTS=true os: - linux - osx diff --git a/dune-workspace.dev b/dune-workspace.dev index 67e0e49..635c06f 100644 --- a/dune-workspace.dev +++ b/dune-workspace.dev @@ -5,3 +5,6 @@ (context (opam (switch 4.06.0))) (context (opam (switch 4.07.0))) (context (opam (switch 4.08.0))) +(context (opam (switch 4.09.0))) +(context (opam (switch 4.10.0))) +(context (opam (switch 4.11.0)))