package ppxlib

  1. Overview
  2. Docs
Standard infrastructure for ppx rewriters

Install

dune-project
 Dependency

Authors

Maintainers

Sources

ppxlib-0.36.2.tbz
sha256=c8756007d8cac1379a8461146100c1d611c7df6ecc1a9a0aa9bddec0d6e4e71b
sha512=eedafd477493be365857dbfd3733abc4a50854cd94151ae8ebc150284a1ebe5252b1a11b62c756e8078e9397a1a2fd7f1946b40e225bf7084cd33bba7fba48c7

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: 02 Oct 2025

README

Ppxlib - Meta-programming for OCaml

ocaml-ci status trunk-build-status AppVeyor status

Ppxlib documentation

Overview

Ppxlib is the standard library 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 constructing 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.

For more information about ppxlib and how to use it, please consult the documentation.

What is the relation between ppxlib and other ppx libraries?

The ppx world has a long and storied history, and if you look around, you may find other projects that offer functionalities similar to ppxlib. The following blog post gives a good overview of the various libraries that have been developed over time. At this point, ppxlib is considered the de facto library for writing ppx rewriters.

History of the project

This repository was created by merging several older smaller projects that were developed at Jane Street. See the history for more details.

Dependencies (6)

  1. stdlib-shims
  2. sexplib0 >= "v0.12"
  3. ppx_derivers >= "1.0"
  4. ocaml-compiler-libs >= "v0.11.0"
  5. ocaml >= "4.08.0" & < "5.4.0"
  6. dune >= "3.8"

Dev Dependencies (6)

  1. odoc with-doc
  2. ocamlformat with-dev-setup & = "0.26.2"
  3. cinaps with-test & >= "v0.12.1"
  4. re with-test & >= "1.9.0"
  5. ocamlfind with-test
  6. sexplib0 with-test & >= "v0.15"

  1. arrayjit != "0.5.2"
  2. awsm-codegen
  3. bam-ppx >= "0.4"
  4. base_quickcheck >= "v0.17.1"
  5. bistro >= "0.6.0"
  6. bonsai >= "v0.16.0"
  7. bytestring
  8. clangml >= "4.7.0"
  9. cmdlang-to-base
  10. comby < "1.3.0"
  11. commons
  12. crs
  13. diff
  14. dune >= "3.17.2"
  15. dunolint
  16. dunolint-lib < "0.0.20251006"
  17. dunolint-lib-base
  18. ego
  19. eliom >= "8.9.0"
  20. elpi >= "3.3.1"
  21. embedded_ocaml_templates < "0.3.1" | >= "0.7"
  22. extunix >= "0.4.4"
  23. fsml
  24. fstar >= "2025.06.20"
  25. GT = "0.5.1"
  26. gen_js_api < "1.0.8" | >= "1.1.1"
  27. genprint = "0.3"
  28. goblint >= "2.5.0"
  29. hack_parallel >= "1.0.1"
  30. hardcaml >= "v0.14.1" & < "v0.17.0"
  31. html_of_jsx >= "0.0.2"
  32. http_async
  33. js_of_ocaml >= "3.8.0"
  34. js_of_ocaml-compiler >= "6.1.0"
  35. js_of_ocaml-lwt >= "3.10.0" & < "6.1.0"
  36. js_of_ocaml-ocamlbuild >= "3.10.0" & < "5.0"
  37. js_of_ocaml-ppx >= "6.1.0"
  38. js_of_ocaml-ppx_deriving_json >= "3.7.1"
  39. js_of_ocaml-toplevel >= "3.10.0"
  40. js_of_ocaml-tyxml >= "3.10.0" & < "6.1.0"
  41. lablqml >= "0.7"
  42. lascar >= "0.7.0"
  43. learn-ocaml
  44. learn-ocaml-client
  45. lens >= "1.2.5"
  46. logs-ppx
  47. lwt_ppx >= "5.9.2"
  48. MlFront_Cli >= "2.1.4~prerel2" & < "2.3.1"
  49. MlFront_Config
  50. MlFront_Manip
  51. melange-json >= "1.2.0"
  52. melange-json-native
  53. merlin >= "4.7-412"
  54. metaquot >= "0.5.0"
  55. mlt_parser = "v0.13.0" | >= "v0.14.1"
  56. mlx
  57. neural_nets_lib != "0.5.2"
  58. noCanren >= "0.3.0~alpha1"
  59. node_of_ocaml
  60. nuscr >= "2.0.0"
  61. OCanren-ppx >= "0.3.0"
  62. obus >= "1.2.5"
  63. ocaml-monadic >= "0.5"
  64. ocamlmerlin-mlx
  65. ocf_ppx
  66. ocsigen-i18n >= "4.0.0"
  67. octez-internal-libs
  68. ojs_base_ppx
  69. ometrics = "0.2.0"
  70. ortac-core
  71. ortac-qcheck-stm
  72. ortac-wrapper
  73. pancake
  74. pgocaml_ppx >= "4.3.0"
  75. pla >= "2.0"
  76. ppx-owl-opt
  77. ppx_accessor >= "v0.14.3"
  78. ppx_assert >= "v0.13.0"
  79. ppx_bap
  80. ppx_base >= "v0.13.0"
  81. ppx_bench >= "v0.17.1"
  82. ppx_bin_prot >= "v0.17.1"
  83. ppx_bitstring >= "5.0.0"
  84. ppx_blob >= "0.7.2"
  85. ppx_catch
  86. ppx_cold
  87. ppx_compare >= "v0.13.0"
  88. ppx_compose >= "0.2.1"
  89. ppx_const >= "2.0.1"
  90. ppx_conv_func >= "v0.13.0"
  91. ppx_counters
  92. ppx_css
  93. ppx_cstruct >= "6.0.0"
  94. ppx_cstubs >= "0.6.1" & < "0.7.0"
  95. ppx_csv_conv >= "v0.13.0"
  96. ppx_custom_printf >= "v0.14.1"
  97. ppx_decimal
  98. ppx_defer >= "0.5.0"
  99. ppx_demo
  100. ppx_derive_at_runtime < "v0.17.0"
  101. ppx_deriving >= "6.1.0"
  102. ppx_deriving_cad
  103. ppx_deriving_decoders < "0.2"
  104. ppx_deriving_encoding >= "0.4.2"
  105. ppx_deriving_ezjsonm >= "0.4.1"
  106. ppx_deriving_hardcaml >= "v0.13.0"
  107. ppx_deriving_hash >= "0.1.3"
  108. ppx_deriving_json_schema
  109. ppx_deriving_jsonschema
  110. ppx_deriving_madcast >= "0.2"
  111. ppx_deriving_popper
  112. ppx_deriving_protobuf >= "3.0.0"
  113. ppx_deriving_qcheck
  114. ppx_deriving_scad
  115. ppx_deriving_variant_string
  116. ppx_deriving_yaml >= "0.4.1"
  117. ppx_deriving_yojson >= "3.10.0"
  118. ppx_diff >= "v0.17.1"
  119. ppx_disable_unused_warnings
  120. ppx_dream_eml
  121. ppx_embed_file
  122. ppx_enumerate >= "v0.13.0"
  123. ppx_expect = "v0.16.2" | >= "v0.17.3"
  124. ppx_expect_nobase
  125. ppx_factory = "0.1.0" | >= "0.2.0"
  126. ppx_fail >= "v0.13.0"
  127. ppx_fields_conv >= "v0.14.2"
  128. ppx_fixed_literal
  129. ppx_format
  130. ppx_fun
  131. ppx_gen_rec >= "2.0.0"
  132. ppx_getenv >= "2.1"
  133. ppx_globalize >= "v0.17.2"
  134. ppx_hardcaml
  135. ppx_hash >= "v0.13.0"
  136. ppx_here >= "v0.13.0"
  137. ppx_ignore_instrumentation
  138. ppx_import < "1.8.0" | >= "1.11.0"
  139. ppx_inline_test >= "v0.17.1"
  140. ppx_interact >= "0.2.0"
  141. ppx_irmin >= "3.0.0"
  142. ppx_jane >= "v0.13.0"
  143. ppx_jsobject_conv = "0.8.0" | >= "0.21.1"
  144. ppx_jsonaf_conv >= "v0.15.1" & < "v0.17.0"
  145. ppx_let >= "v0.17.1"
  146. ppx_log
  147. ppx_map
  148. ppx_mica
  149. ppx_minidebug != "2.2.0" & < "2.4.0"
  150. ppx_module_timer >= "v0.13.0"
  151. ppx_monad
  152. ppx_monoid >= "0.3.3"
  153. ppx_mysql >= "1.1.3"
  154. ppx_open
  155. ppx_optcomp >= "v0.17.1"
  156. ppx_optint
  157. ppx_optional >= "v0.13.0"
  158. ppx_partial
  159. ppx_pattern_bind >= "v0.13.1" & < "v0.17.0"
  160. ppx_pipebang >= "v0.13.0"
  161. ppx_protocol_conv >= "5.2.3"
  162. ppx_pyformat
  163. ppx_python >= "v0.15.0"
  164. ppx_seq
  165. ppx_sexp_conv >= "v0.17.1"
  166. ppx_sexp_message >= "v0.14.1"
  167. ppx_sexp_value >= "v0.13.0"
  168. ppx_show >= "0.2.0"
  169. ppx_stable >= "v0.17.1"
  170. ppx_stable_witness
  171. ppx_string >= "v0.14.1"
  172. ppx_string_conv
  173. ppx_string_interpolation
  174. ppx_subliner
  175. ppx_system
  176. ppx_ts
  177. ppx_tydi >= "v0.17.1"
  178. ppx_type_directed_value
  179. ppx_typed_fields < "v0.17.0"
  180. ppx_typerep_conv >= "v0.17.1"
  181. ppx_units
  182. ppx_unreachable
  183. ppx_update
  184. ppx_variants_conv >= "v0.17.1"
  185. ppx_viewpattern >= "0.1.1"
  186. ppx_xml_conv >= "v0.13.0"
  187. ppx_yojson >= "1.3.0"
  188. ppx_yojson_conv >= "v0.15.1"
  189. ppxlib-tools >= "0.36.2"
  190. ppxlib_jane >= "v0.17.3"
  191. qcow = "0.11.0"
  192. rdf_ppx
  193. reason >= "3.16.0"
  194. reason-react-ppx >= "0.13.0" & < "0.14.1"
  195. refl >= "0.4.1"
  196. res_tailwindcss
  197. sedlex >= "3.4"
  198. serde_derive
  199. server-reason-react
  200. speed
  201. spin >= "0.8.0"
  202. stdint-literals
  203. stk_ppx
  204. streamable < "v0.17.0"
  205. styled-ppx
  206. togglelog
  207. toplevel_expect_test >= "v0.14.1"
  208. tyxml-jsx >= "4.5.0"
  209. tyxml-syntax >= "4.5.0"
  210. visitors >= "20210608"
  211. vlt >= "0.2.5"
  212. volgo < "0.0.21"
  213. volgo-base
  214. volgo-git-backend < "0.0.21"
  215. volgo-git-eio < "0.0.21"
  216. volgo-git-unix < "0.0.21"
  217. volgo-hg-backend < "0.0.21"
  218. volgo-hg-eio < "0.0.21"
  219. volgo-hg-unix < "0.0.21"
  220. volgo-vcs < "0.0.21"
  221. wasm_of_ocaml-compiler
  222. wtr < "3.0.0"
  223. wtr-ppx
  224. xtmpl_ppx

Conflicts (3)

  1. ocaml-variants = "5.1.0~alpha1+options"
  2. ocaml-base-compiler = "5.1.0~alpha1"
  3. ocaml-migrate-parsetree < "2.0.0"