package ppxlib

  1. Overview
  2. Docs
Standard infrastructure for ppx rewriters

Install

dune-project
 Dependency

Authors

Maintainers

Sources

a6fadbd212f3cd7d5d8dcfefc46c884f710fedc0.tar.gz
sha256=25e81f2085ad19688f7056c6df49ca48b3df4cea8304ba3be2550e172d59bfec
sha512=cfdaa06fd32d206f72de05a5289d33ec85fa6bdf7c5be7c85874a16d9e154cdc080465453b60fe7f6c01589eb92e4296b18067413ac2d8dec47b9539f55e301e

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: 09 Mar 2026

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.6.0"
  6. dune >= "3.8"

Dev Dependencies (6)

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

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"