package ppxlib
Install
Dune Dependency
Authors
Maintainers
Sources
sha256=f0e61123b33b2acca23a388a367226674a7bccdedbaa41b0fd62fa42344dccd9
sha512=1a192695ac3a7d587a49f3025239557a998febe72d3b469d3c69b5c32643cc91c55fb72703f8197e1395c02bfabacf17ce5f7ee2bdc367e15f9086e489082a9b
Description
Ppxlib is the standard infrastructure for ppx rewriters and other programs that manipulate the in-memory representation of OCaml programs, a.k.a the "Parsetree".
It also comes bundled with two ppx rewriters that are commonly used to
write tools that manipulate and/or generate Parsetree values;
ppxlib.metaquot
which allows to construct Parsetree values using the
OCaml syntax directly and ppxlib.traverse
which provides various
ways of automatically traversing values of a given type, in particular
allowing to inject a complex structured value into generated code.
Published: 16 Feb 2024
README
Non-continuous trunk
-support for Ppxlib
On this branch, we provide a Ppxlib version, which can be compiled with OCaml's trunk
branch. Whenever you want to compile a project that (transitively) depends on PPXs with trunk
, please pin Ppxlib to this branch.
The branch is maintained manually. So each time the compiler adds a new syntax feature, first we need to bring this branch back in sync with trunk
and then you'll need to re-pin your Ppxlib. Please, open an issue or a PR, if this branch doesn't compile with trunk
. Also open an issue, if there's a feature/bug-fix on Ppxlib's main
branch that you'd like to have here, so that we rebase.
trunk
-support vs trunk
-feature support
Ppxlib supporting trunk
can be interpreted in two different ways.
User perspective on the difference
One notion of trunk
-support is that a project depending on Ppxlib can be compiled with trunk
under the assumption that the project doesn't use the new syntax features in trunk
. That's what this branch provides.
The other notion of trunk
-support should actually be called trunk
-feature support: you can use the new trunk
syntax features in a project which depends on Ppxlib and that you compile with trunk
. It's not unlikely that you'll get a Ppxlib runtime error (i.e. project compile time error), if you try to use this branch in that situation.
Ppxlib behavior perspective on the difference
The Ppxlib behavior in the situation of trunk
support is: The parsetree version exposed by Ppxlib is still the one from the latest stable compiler and all PPXs are defined against that one. However, Ppxlib has hold of trunk
's parsetree version and knows how to migrate between that parsetree version and the parsetree version of the latest stable compiler. You can find those parsetrees and parsertree migration modules in Ppxlib's Astlib
library. So, when compiling a file with trunk
, the Ppxlib driver will parse the file into the trunk
parsetree, migrate down to the latest stable parsetree, do the PPX expansions and migrate back to trunk
's parsetree. The downward migration will error, if the parsetree contains a feature that isn't well-defined in the latest stable parsetree version.
The behavior in the case of trunk
-feature support would be different. In that case, Ppxlib would have to expose the trunk
parsetree, so that the PPXs would be defined against that one. So, Ppxlib would have to bump its internal parsetree to the trunk
parsetree. Bumping the Ppxlib parsetree always means potentially breaking PPXs. When bumping the Ppxlib parsetree to the parsetree of an about-to-be-released stable compiler version, we create a work-space with all opam PPXs and send patch PRs to the ones we break. However, for trunk
we wouldn't do such an effort.
Dependencies (6)
- stdlib-shims
-
sexplib0
>= "v0.12"
-
ppx_derivers
>= "1.0"
-
ocaml-compiler-libs
>= "v0.11.0"
-
ocaml
>= "4.04.1" & < "5.3.0"
-
dune
>= "2.7"
Dev Dependencies (5)
- arrayjit
- awsm-codegen
- bam-ppx
-
base_quickcheck
= "v0.13.0" | >= "v0.14.1"
-
bisect_ppx
>= "2.8.3"
-
bistro
>= "0.6.0"
-
bonsai
>= "v0.16.0"
- bytestring
-
clangml
>= "4.7.0"
-
comby
< "1.3.0"
- commons
- config
- diff
-
dune
>= "3.17.0"
- ego
-
eliom
>= "8.9.0"
-
elpi
>= "1.11.0" & < "1.11.3" | >= "1.13.2"
-
embedded_ocaml_templates
< "0.3.1" | >= "0.7"
-
extunix
>= "0.3.1"
-
flow_parser
= "0.229.1"
- fsml
-
GT
= "0.5.1" | >= "0.5.3"
-
gen_js_api
>= "1.0.6" & < "1.0.8" | >= "1.1.1"
-
genprint
= "0.3"
-
goblint
>= "2.5.0"
-
gospel
>= "0.2.0"
-
graphql_ppx
>= "1.2.2"
-
hack_parallel
>= "1.0.1"
-
hardcaml
>= "v0.14.1"
-
html_of_jsx
>= "0.0.2"
- http_async
-
js_of_ocaml
>= "3.8.0"
-
js_of_ocaml-compiler
>= "3.8.0"
-
js_of_ocaml-lwt
>= "3.10.0"
-
js_of_ocaml-ocamlbuild
>= "3.10.0" & < "5.0"
-
js_of_ocaml-ppx
>= "3.8.0"
-
js_of_ocaml-ppx_deriving_json
>= "3.7.1"
-
js_of_ocaml-toplevel
>= "3.10.0"
-
js_of_ocaml-tyxml
>= "3.10.0"
- jsoo-react
-
lablqml
>= "0.7"
- landmarks-ppx
-
lascar
>= "0.7.0"
-
learn-ocaml
>= "0.13.0"
-
learn-ocaml-client
>= "0.13.0"
-
lens
>= "1.2.5"
-
let-if
>= "0.2.0"
- logs-ppx
-
lwt_ppx
>= "2.0.2"
-
MlFront_Cli
>= "2.1.4~prerel2"
-
melange
>= "1.0.0"
-
melange-json
>= "1.2.0"
- melange-json-native
-
merlin
>= "4.7-412"
-
metapp
>= "0.4.4"
-
metaquot
>= "0.5.0"
-
mlt_parser
= "v0.13.0" | >= "v0.14.1"
-
mutaml
>= "0.2"
- neural_nets_lib
-
noCanren
>= "0.3.0~alpha1"
- node_of_ocaml
-
nuscr
>= "2.0.0"
-
OCanren-ppx
= "0.2.0" | >= "0.3.0"
-
obus
>= "1.2.5"
-
ocaml-monadic
>= "0.5"
-
ocamlformat
= "0.19.0~4.13preview"
- ocf_ppx
-
ocsigen-i18n
>= "4.0.0"
- ocsigen-ppx-rpc
- octez-internal-libs
- ojs_base_ppx
-
ometrics
= "0.2.0"
- ortac-core
- ortac-qcheck-stm
-
override
= "0.2.2"
- pacomb
- pancake
-
pgocaml_ppx
>= "4.3.0"
-
pla
>= "2.0"
- ppx-owl-opt
-
ppx_accessor
>= "v0.14.3"
-
ppx_assert
>= "v0.13.0"
- ppx_bap
-
ppx_base
>= "v0.13.0"
-
ppx_bench
>= "v0.15.1"
-
ppx_bin_prot
>= "v0.13.0"
-
ppx_bitstring
>= "4.1.0"
-
ppx_blob
>= "0.7.2"
- ppx_camlrack
- ppx_catch
- ppx_cold
-
ppx_compare
>= "v0.13.0"
-
ppx_compose
>= "0.2.1"
-
ppx_const
>= "2.0.1"
-
ppx_conv_func
>= "v0.13.0"
- ppx_counters
- ppx_css
-
ppx_cstruct
>= "6.0.0"
-
ppx_cstubs
>= "0.6.1"
-
ppx_csv_conv
>= "v0.13.0"
-
ppx_custom_printf
>= "v0.14.1"
- ppx_decimal
- ppx_default
-
ppx_defer
>= "0.5.0"
- ppx_demo
- ppx_derive_at_runtime
-
ppx_deriving
>= "5.2"
- ppx_deriving_cad
- ppx_deriving_decoders
-
ppx_deriving_encoding
>= "0.2"
- ppx_deriving_ezjsonm
-
ppx_deriving_hardcaml
>= "v0.13.0"
- ppx_deriving_hash
- ppx_deriving_json_schema
- ppx_deriving_jsonschema
-
ppx_deriving_jsoo
>= "0.2"
-
ppx_deriving_madcast
>= "0.2"
- ppx_deriving_popper
-
ppx_deriving_protobuf
>= "3.0.0"
- ppx_deriving_qcheck
-
ppx_deriving_rpc
>= "8.1.0"
- ppx_deriving_scad
- ppx_deriving_variant_string
- ppx_deriving_yaml
-
ppx_deriving_yojson
>= "3.7.0"
- ppx_diff
- ppx_disable_unused_warnings
-
ppx_distr_guards
>= "0.3"
- ppx_dream_eml
- ppx_embed_file
-
ppx_enumerate
>= "v0.13.0"
-
ppx_expect
>= "v0.13.0" & != "v0.14.0"
-
ppx_factory
= "0.1.0" | >= "0.2.0"
-
ppx_fail
>= "v0.13.0"
-
ppx_fields_conv
>= "v0.14.2"
- ppx_fixed_literal
-
ppx_fun
>= "0.0.9"
-
ppx_gen_rec
>= "2.0.0"
-
ppx_getenv
>= "2.1"
- ppx_globalize
-
ppx_hardcaml
>= "v0.17.0"
-
ppx_hash
>= "v0.13.0"
-
ppx_here
>= "v0.13.0"
- ppx_ignore_instrumentation
-
ppx_import
>= "1.7.0" & < "1.8.0" | >= "1.11.0"
- ppx_inline_alcotest
-
ppx_inline_test
>= "v0.15.1"
- ppx_interact
-
ppx_irmin
>= "3.0.0"
-
ppx_jane
>= "v0.13.0"
-
ppx_js_style
>= "v0.13.0"
-
ppx_jsobject_conv
= "0.8.0" | >= "0.9.3"
-
ppx_jsonaf_conv
>= "v0.15.1"
-
ppx_let
>= "v0.13.0"
- ppx_log
- ppx_lun
- ppx_make
- ppx_map
- ppx_matches
- ppx_minidebug
-
ppx_module_timer
>= "v0.13.0"
- ppx_monad
-
ppx_monoid
>= "0.3.3"
-
ppx_mysql
>= "1.1.3"
- ppx_open
-
ppx_optcomp
>= "v0.14.2"
- ppx_optint
-
ppx_optional
>= "v0.13.0"
- ppx_parser
-
ppx_pattern_bind
>= "v0.13.1"
-
ppx_pipebang
>= "v0.13.0"
-
ppx_protocol_conv
>= "5.1.3"
- ppx_pyformat
-
ppx_python
>= "v0.15.0"
- ppx_quick_test
-
ppx_rapper
< "1.0.1"
-
ppx_regexp
>= "0.5.0"
-
ppx_repr
>= "0.6.0"
- ppx_seq
-
ppx_sexp_conv
>= "v0.15.1"
-
ppx_sexp_message
>= "v0.14.1"
-
ppx_sexp_value
>= "v0.13.0"
-
ppx_show
>= "0.2.0"
-
ppx_stable
>= "v0.14.1"
- ppx_stable_witness
-
ppx_string
>= "v0.14.1"
- ppx_string_conv
- ppx_string_interpolation
- ppx_subliner
- ppx_system
- ppx_trace
- ppx_ts
- ppx_tydi
- ppx_type_directed_value
- ppx_typed_fields
-
ppx_typerep_conv
>= "v0.14.2"
- ppx_units
- ppx_update
-
ppx_variants_conv
>= "v0.14.2"
- ppx_viewpattern
-
ppx_xml_conv
>= "v0.13.0"
-
ppx_yojson
>= "1.3.0"
-
ppx_yojson_conv
>= "v0.15.1"
-
ppxlib_jane
!= "v0.17.1"
-
ppxx
>= "2.5.0"
-
qcow
>= "0.11.0"
- rdf_ppx
- reactjs-jsx-ppx
-
reason
>= "3.9.0"
-
reason-react-ppx
< "0.15.0"
-
refl
>= "0.4.1"
-
repr-fuzz
>= "0.2.1"
- res_tailwindcss
- rescript-syntax
-
scaml
!= "1.2.0"
-
sedlex
>= "2.6"
- serde_derive
- server-reason-react
- speed
-
spin
>= "0.8.0"
- spoc_ppx
- stdint-literals
- stk_ppx
- streamable
- styled-ppx
- togglelog
-
toplevel_expect_test
>= "v0.14.1"
-
tyxml-jsx
>= "4.5.0"
-
tyxml-ppx
>= "4.5.0"
-
tyxml-syntax
>= "4.5.0"
-
visitors
>= "20210608"
- vlt
-
wtr
< "3.0.0"
- wtr-ppx
- xtmpl_ppx
Conflicts (4)
-
ocaml-variants
= "5.1.0~alpha1+options"
-
ocaml-base-compiler
= "5.1.0~alpha1"
- base-effects
-
ocaml-migrate-parsetree
< "2.0.0"