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