ocaml-trace/ppxlib/_doc-dir/README.md
2024-08-26 14:16:27 +00:00

46 lines
2.1 KiB
Markdown

# Ppxlib - Meta-programming for OCaml
[![ocaml-ci status][ocaml-ci-img]][ocaml-ci] [![trunk-build-status][trunk-build-img]][trunk-build] [![AppVeyor status][appveyor-img]][appveyor]
[ocaml-ci]: https://ci.ocamllabs.io/github/ocaml-ppx/ppxlib
[ocaml-ci-img]: https://img.shields.io/endpoint?url=https%3A%2F%2Fci.ocamllabs.io%2Fbadge%2Focaml-ppx%2Fppxlib%2Fmain&logo=ocaml
[appveyor]: https://ci.appveyor.com/project/diml/ppxlib/branch/main
[appveyor-img]: https://ci.appveyor.com/api/projects/status/bogbsm33uvh083jx?svg=true
[trunk-build]: https://github.com/ocaml-ppx/ppxlib/actions/workflows/trunk-build.yml
[trunk-build-img]: https://github.com/ocaml-ppx/ppxlib/actions/workflows/trunk-build.yml/badge.svg?branch=main
[Ppxlib documentation][doc]
# 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][doc].
# 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][future-of-ppx] 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](HISTORY.md) for
more details.
[doc]: https://ocaml-ppx.github.io/ppxlib/ppxlib/index.html
[future-of-ppx]: https://discuss.ocaml.org/t/the-future-of-ppx/3766