package ppxlib

  1. Overview
  2. Docs
Standard infrastructure for ppx rewriters

Install

dune-project
 Dependency

Authors

Maintainers

Sources

ppxlib-0.38.0.tbz
sha256=89e049b3102f6670a213d34d802ea3ab0fc530a8959d2f1a1e8db830063429a3
sha512=2fbbf124fc61e1f22242d13505e9af39d4a3c7cf03def1c33ee8bd915195be9b817636667302e9c6ceddc74a9a4a54926340e21c96fd770a2bc6752400315cfd

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