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