package ppxlib

  1. Overview
  2. Docs
Standard infrastructure for ppx rewriters

Install

Dune Dependency

Authors

Maintainers

Sources

04e050cbe2cf3e5cdb4441c480e4f472a5033941.tar.gz
sha256=f0e61123b33b2acca23a388a367226674a7bccdedbaa41b0fd62fa42344dccd9
sha512=1a192695ac3a7d587a49f3025239557a998febe72d3b469d3c69b5c32643cc91c55fb72703f8197e1395c02bfabacf17ce5f7ee2bdc367e15f9086e489082a9b

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: 16 Feb 2024

README

Non-continuous trunk-support for Ppxlib

On this branch, we provide a Ppxlib version, which can be compiled with OCaml's trunk branch. Whenever you want to compile a project that (transitively) depends on PPXs with trunk, please pin Ppxlib to this branch.

The branch is maintained manually. So each time the compiler adds a new syntax feature, first we need to bring this branch back in sync with trunk and then you'll need to re-pin your Ppxlib. Please, open an issue or a PR, if this branch doesn't compile with trunk. Also open an issue, if there's a feature/bug-fix on Ppxlib's main branch that you'd like to have here, so that we rebase.

trunk-support vs trunk-feature support

Ppxlib supporting trunk can be interpreted in two different ways.

User perspective on the difference

One notion of trunk-support is that a project depending on Ppxlib can be compiled with trunk under the assumption that the project doesn't use the new syntax features in trunk. That's what this branch provides.

The other notion of trunk-support should actually be called trunk-feature support: you can use the new trunk syntax features in a project which depends on Ppxlib and that you compile with trunk. It's not unlikely that you'll get a Ppxlib runtime error (i.e. project compile time error), if you try to use this branch in that situation.

Ppxlib behavior perspective on the difference

The Ppxlib behavior in the situation of trunk support is: The parsetree version exposed by Ppxlib is still the one from the latest stable compiler and all PPXs are defined against that one. However, Ppxlib has hold of trunk's parsetree version and knows how to migrate between that parsetree version and the parsetree version of the latest stable compiler. You can find those parsetrees and parsertree migration modules in Ppxlib's Astlib library. So, when compiling a file with trunk, the Ppxlib driver will parse the file into the trunk parsetree, migrate down to the latest stable parsetree, do the PPX expansions and migrate back to trunk's parsetree. The downward migration will error, if the parsetree contains a feature that isn't well-defined in the latest stable parsetree version.

The behavior in the case of trunk-feature support would be different. In that case, Ppxlib would have to expose the trunk parsetree, so that the PPXs would be defined against that one. So, Ppxlib would have to bump its internal parsetree to the trunk parsetree. Bumping the Ppxlib parsetree always means potentially breaking PPXs. When bumping the Ppxlib parsetree to the parsetree of an about-to-be-released stable compiler version, we create a work-space with all opam PPXs and send patch PRs to the ones we break. However, for trunk we wouldn't do such an effort.

Dependencies (6)

  1. stdlib-shims
  2. sexplib0 >= "v0.12"
  3. ppx_derivers >= "1.0"
  4. ocaml-compiler-libs >= "v0.11.0"
  5. ocaml >= "4.04.1" & < "5.3.0"
  6. dune >= "2.7"

Dev Dependencies (5)

  1. odoc with-doc
  2. cinaps with-test & >= "v0.12.1"
  3. re with-test & >= "1.9.0"
  4. ocamlfind with-test
  5. sexplib0 with-test & >= "v0.15"

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

Conflicts (4)

  1. ocaml-variants = "5.1.0~alpha1+options"
  2. ocaml-base-compiler = "5.1.0~alpha1"
  3. base-effects
  4. ocaml-migrate-parsetree < "2.0.0"
OCaml

Innovation. Community. Security.