package ppxlib

  1. Overview
  2. Docs
Standard infrastructure for ppx rewriters

Install

Dune Dependency

Authors

Maintainers

Sources

ppxlib-0.36.0.tbz
sha256=5aba1bce14c53108614130110c843d004bf93bd2cf3a0778fd7086b85390a434
sha512=1e3e8fee42fe74bffc178dbcbb2db8ec38dd23e71f6fed3c4c92618cf93892f5847787e6e9abb322f5c85d29a76afde28ce840b42e10fedc14cd82ba578ad06a

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: 05 Mar 2025

README

Ppxlib - Meta-programming for OCaml

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

Innovation. Community. Security.