package ppxlib

  1. Overview
  2. Docs
Standard infrastructure for ppx rewriters

Install

dune-project
 Dependency

Authors

Maintainers

Sources

ppxlib-0.35.0.tbz
sha256=d9d959fc9f84260487e45684dc741898a92fc5506b61a7f5cac65d21832db925
sha512=e428b1e3b89261c7efdaa18016264d1afbf067cb9b0d41124b04796c2487ac7ca8ee9a24a60d56f20d1774cb44aaa9ecf1512f17455812ba8d62d4ef93616ee7

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