2026-05-27 07:11.31: New job: test ocaml-ppx/ppxlib https://github.com/ocaml-ppx/ppxlib.git#refs/heads/main (9a30587be0ece489a6b3bfd428bf5c13622cc932) (linux-x86_64:(lint-doc)) Base: ocaml/opam:debian-13-ocaml-4.11@sha256:6c34153b2b07fc0f884e792a60178e250c2d06a45050e01ed0883a67ec11440c Opam project lint documentation To reproduce locally: git clone --recursive "https://github.com/ocaml-ppx/ppxlib.git" -b "main" && cd "ppxlib" && git reset --hard 9a30587b cat > Dockerfile <<'END-OF-DOCKERFILE' FROM ocaml/opam:debian-13-ocaml-4.11@sha256:6c34153b2b07fc0f884e792a60178e250c2d06a45050e01ed0883a67ec11440c # debian-13-4.11_opam-2.5 USER 1000:1000 ENV CLICOLOR_FORCE="1" ENV OPAMCOLOR="always" WORKDIR /src RUN sudo ln -f /usr/bin/opam-2.2 /usr/bin/opam RUN cd ~/opam-repository && (git cat-file -e c180e1630960e0dbb8e30c22b3de89113eb5cc93 || git fetch origin master) && git reset -q --hard c180e1630960e0dbb8e30c22b3de89113eb5cc93 && git log --no-decorate -n1 --oneline RUN opam init --reinit -ni RUN uname -rs && opam exec -- ocaml -version && opam --version WORKDIR /src RUN sudo chown opam /src RUN opam update -u COPY --chown=1000:1000 ppxlib.opam ppxlib-tools.opam ppxlib-bench.opam ./ RUN opam pin add -yn ppxlib.dev './' && \ opam pin add -yn ppxlib-tools.dev './' && \ opam pin add -yn ppxlib-bench.dev './' RUN echo '(lang dune 3.0)' > './dune-project' ENV DEPS="base.v0.15.2 base-bigarray.base base-threads.base base-unix.base cinaps.v0.15.1 cmdliner.2.1.1 csexp.1.5.2 dune.3.23.1 dune-configurator.3.22.2 ocaml.4.11.2 ocaml-base-compiler.4.11.2 ocaml-compiler-libs.v0.12.4 ocaml-config.1 ocaml-secondary-compiler.4.14.2 ocamlfind.1.9.6 ocamlfind-secondary.1.9.6 ppx_derivers.1.2.1 re.1.11.0 seq.base sexplib0.v0.15.1 yojson.3.0.0" ENV CI="true" ENV OCAMLCI="true" RUN opam update --depexts && opam install --cli=2.2 --depext-only -y ppxlib.dev ppxlib-tools.dev ppxlib-bench.dev $DEPS RUN opam install $DEPS RUN opam install --yes dune 'odoc>=1.5.0' COPY --chown=1000:1000 . /src/ RUN ODOC_WARN_ERROR=false opam exec -- dune build @doc || (echo "dune build @doc failed"; exit 2) END-OF-DOCKERFILE docker build . END-REPRO-BLOCK 2026-05-27 07:11.31: Using cache hint "ocaml-ppx/ppxlib-ocaml/opam:debian-13-ocaml-4.11@sha256:6c34153b2b07fc0f884e792a60178e250c2d06a45050e01ed0883a67ec11440c-debian-13-4.11_opam-2.5-6a8c7249c8be50174616b22b04078d38" 2026-05-27 07:11.31: Using OBuilder spec: ((from ocaml/opam:debian-13-ocaml-4.11@sha256:6c34153b2b07fc0f884e792a60178e250c2d06a45050e01ed0883a67ec11440c) (comment debian-13-4.11_opam-2.5) (user (uid 1000) (gid 1000)) (env CLICOLOR_FORCE 1) (env OPAMCOLOR always) (workdir /src) (run (shell "sudo ln -f /usr/bin/opam-2.2 /usr/bin/opam")) (run (cache (opam-archives (target /home/opam/.opam/download-cache))) (network host) (shell "cd ~/opam-repository && (git cat-file -e c180e1630960e0dbb8e30c22b3de89113eb5cc93 || git fetch origin master) && git reset -q --hard c180e1630960e0dbb8e30c22b3de89113eb5cc93 && git log --no-decorate -n1 --oneline")) (run (shell "opam init --reinit -ni")) (run (shell "uname -rs && opam exec -- ocaml -version && opam --version")) (workdir /src) (run (shell "sudo chown opam /src")) (run (cache (opam-archives (target /home/opam/.opam/download-cache))) (network host) (shell "opam update -u")) (copy (src ppxlib.opam ppxlib-tools.opam ppxlib-bench.opam) (dst ./)) (run (network host) (shell "opam pin add -yn ppxlib.dev './' && \ \nopam pin add -yn ppxlib-tools.dev './' && \ \nopam pin add -yn ppxlib-bench.dev './'")) (run (shell "echo '(lang dune 3.0)' > './dune-project'")) (env DEPS "base.v0.15.2 base-bigarray.base base-threads.base base-unix.base cinaps.v0.15.1 cmdliner.2.1.1 csexp.1.5.2 dune.3.23.1 dune-configurator.3.22.2 ocaml.4.11.2 ocaml-base-compiler.4.11.2 ocaml-compiler-libs.v0.12.4 ocaml-config.1 ocaml-secondary-compiler.4.14.2 ocamlfind.1.9.6 ocamlfind-secondary.1.9.6 ppx_derivers.1.2.1 re.1.11.0 seq.base sexplib0.v0.15.1 yojson.3.0.0") (env CI true) (env OCAMLCI true) (run (cache (opam-archives (target /home/opam/.opam/download-cache))) (network host) (shell "opam update --depexts && opam install --cli=2.2 --depext-only -y ppxlib.dev ppxlib-tools.dev ppxlib-bench.dev $DEPS")) (run (cache (opam-archives (target /home/opam/.opam/download-cache))) (network host) (shell "opam install $DEPS")) (run (cache (opam-archives (target /home/opam/.opam/download-cache))) (network host) (shell "opam install --yes dune 'odoc>=1.5.0'")) (copy (src .) (dst /src/)) (run (shell "ODOC_WARN_ERROR=false opam exec -- dune build @doc || (echo \"dune build @doc failed\"; exit 2)")) ) 2026-05-27 07:11.31: Waiting for resource in pool OCluster 2026-05-27 07:11.31: Waiting for worker… 2026-05-27 07:11.34: Got resource from pool OCluster Building on asteria.caelum.ci.dev All commits already cached HEAD is now at 9a30587b Merge pull request #638 from patricoferris/bump-sexplib (from ocaml/opam:debian-13-ocaml-4.11@sha256:6c34153b2b07fc0f884e792a60178e250c2d06a45050e01ed0883a67ec11440c) 2026-05-27 07:11.45 ---> using "36abb6db1723167d15c41f53ef05d371444812dc64e2ea7fe109d222db988473" from cache /: (comment debian-13-4.11_opam-2.5) /: (user (uid 1000) (gid 1000)) /: (env CLICOLOR_FORCE 1) /: (env OPAMCOLOR always) /: (workdir /src) /src: (run (shell "sudo ln -f /usr/bin/opam-2.2 /usr/bin/opam")) 2026-05-27 07:11.45 ---> using "c39f4f20754d502db7263dd7936ba956bf6745180901c2936d0a5f5580e56fb1" from cache /src: (run (cache (opam-archives (target /home/opam/.opam/download-cache))) (network host) (shell "cd ~/opam-repository && (git cat-file -e c180e1630960e0dbb8e30c22b3de89113eb5cc93 || git fetch origin master) && git reset -q --hard c180e1630960e0dbb8e30c22b3de89113eb5cc93 && git log --no-decorate -n1 --oneline")) From https://github.com/ocaml/opam-repository * branch master -> FETCH_HEAD fc08333d1b..9d78ee2aea master -> origin/master c180e16309 Merge pull request #29907 from dra27/host-arch-fixes 2026-05-27 07:11.45 ---> using "2e8107e88d576e45d3df8e9f8534474972229c1fe5fad7a92e69e3caf4461de0" from cache /src: (run (shell "opam init --reinit -ni")) Configuring from /home/opam/.opamrc and then from built-in defaults. Checking for available remotes: rsync and local, git. - you won't be able to use mercurial repositories unless you install the hg command on your system. - you won't be able to use darcs repositories unless you install the darcs command on your system. This development version of opam requires an update to the layout of /home/opam/.opam from version 2.1 to version 2.2, which can't be reverted. You may want to back it up before going further. [NOTE] The 'jobs' option was reset, its value was 1 and its new value will vary according to the current number of cores on your machine. You can restore the fixed value using: opam option jobs=1 --global Continue? [y/n] y Format upgrade done. <><> Updating repositories ><><><><><><><><><><><><><><><><><><><><><><><><><><> [default] synchronised from git+file:///home/opam/opam-repository 2026-05-27 07:11.45 ---> using "70edfee66275c33407450d9576eceb0fba28d253fb261f9bbc9ad1adb2852336" from cache /src: (run (shell "uname -rs && opam exec -- ocaml -version && opam --version")) Linux 6.8.0-111-generic The OCaml toplevel, version 4.11.2 2.2.1 2026-05-27 07:11.45 ---> using "24663022223ac02e817e299781eee2d0cd2c20ceb7dbef3f08a97c4937ab571b" from cache /src: (workdir /src) /src: (run (shell "sudo chown opam /src")) 2026-05-27 07:11.45 ---> using "a61658fa21b4c6b5bcf6e0a7b9c86e01e037ab476d92a769e537eca25b089d83" from cache /src: (run (cache (opam-archives (target /home/opam/.opam/download-cache))) (network host) (shell "opam update -u")) <><> Updating package repositories ><><><><><><><><><><><><><><><><><><><><><><> [default] no changes from git+file:///home/opam/opam-repository Everything as up-to-date as possible (run with --verbose to show unavailable upgrades). The following packages are not being upgraded because the new versions conflict with other installed packages: - ocaml.5.6.0 - ocaml-config.3 However, you may "opam upgrade" these packages explicitly, which will ask permission to downgrade or uninstall the conflicting packages. Nothing to do. # Run eval $(opam env) to update the current shell environment 2026-05-27 07:11.45 ---> using "9f671a689de7e978d053aa6a6a95dd91cdec12ef6868792e0730a31313ba9417" from cache /src: (copy (src ppxlib.opam ppxlib-tools.opam ppxlib-bench.opam) (dst ./)) 2026-05-27 07:11.45 ---> using "2fa6ed05d026f8766b7e59d2016e536074b3127ef4f93c51faf04b6f0dd74f31" from cache /src: (run (network host) (shell "opam pin add -yn ppxlib.dev './' && \ \nopam pin add -yn ppxlib-tools.dev './' && \ \nopam pin add -yn ppxlib-bench.dev './'")) [ppxlib.dev] synchronised (file:///src) ppxlib is now pinned to file:///src (version dev) [ppxlib-tools.dev] synchronised (file:///src) ppxlib-tools is now pinned to file:///src (version dev) Package ppxlib-bench does not exist, create as a NEW package? [y/n] y [ppxlib-bench.dev] synchronised (file:///src) ppxlib-bench is now pinned to file:///src (version dev) 2026-05-27 07:11.45 ---> using "8d1914b3c77e912a892041c1f08bc9ef54a676a889ecb75e36643d920fe8a956" from cache /src: (run (shell "echo '(lang dune 3.0)' > './dune-project'")) 2026-05-27 07:11.45 ---> using "dbf882456f94e3fdbb5776d929ad8bd4f1585b0548c7de75629c518adbeeb85f" from cache /src: (env DEPS "base.v0.15.2 base-bigarray.base base-threads.base base-unix.base cinaps.v0.15.1 cmdliner.2.1.1 csexp.1.5.2 dune.3.23.1 dune-configurator.3.22.2 ocaml.4.11.2 ocaml-base-compiler.4.11.2 ocaml-compiler-libs.v0.12.4 ocaml-config.1 ocaml-secondary-compiler.4.14.2 ocamlfind.1.9.6 ocamlfind-secondary.1.9.6 ppx_derivers.1.2.1 re.1.11.0 seq.base sexplib0.v0.15.1 yojson.3.0.0") /src: (env CI true) /src: (env OCAMLCI true) /src: (run (cache (opam-archives (target /home/opam/.opam/download-cache))) (network host) (shell "opam update --depexts && opam install --cli=2.2 --depext-only -y ppxlib.dev ppxlib-tools.dev ppxlib-bench.dev $DEPS")) + /usr/bin/sudo "apt-get" "update" - Get:1 http://deb.debian.org/debian trixie InRelease [140 kB] - Get:2 http://deb.debian.org/debian trixie-updates InRelease [47.3 kB] - Get:3 http://deb.debian.org/debian-security trixie-security InRelease [43.4 kB] - Get:4 http://deb.debian.org/debian trixie/main amd64 Packages [9671 kB] - Get:5 http://deb.debian.org/debian-security trixie-security/main amd64 Packages [175 kB] - Fetched 10.1 MB in 20s (510 kB/s) - Reading package lists... - <><> Synchronising pinned packages ><><><><><><><><><><><><><><><><><><><><><><> [ppxlib.dev] synchronised (file:///src) [ppxlib-bench.dev] synchronised (file:///src) [ppxlib-tools.dev] synchronised (file:///src) [NOTE] Package ocaml-config is already installed (current version is 1). [NOTE] Package ocaml-base-compiler is already installed (current version is 4.11.2). [NOTE] Package ocaml is already installed (current version is 4.11.2). [NOTE] Package base-unix is already installed (current version is base). [NOTE] Package base-threads is already installed (current version is base). [NOTE] Package base-bigarray is already installed (current version is base). 2026-05-27 07:11.45 ---> using "b3c57abc0d644ef408afd1d25ae24a69742336e9c8b85931384b65ddc544c9ad" from cache /src: (run (cache (opam-archives (target /home/opam/.opam/download-cache))) (network host) (shell "opam install $DEPS")) [NOTE] Package ocaml-config is already installed (current version is 1). [NOTE] Package ocaml-base-compiler is already installed (current version is 4.11.2). [NOTE] Package ocaml is already installed (current version is 4.11.2). [NOTE] Package base-unix is already installed (current version is base). [NOTE] Package base-threads is already installed (current version is base). [NOTE] Package base-bigarray is already installed (current version is base). The following actions will be performed: === install 15 packages - install base v0.15.2 - install cinaps v0.15.1 - install cmdliner 2.1.1 - install csexp 1.5.2 - install dune 3.23.1 - install dune-configurator 3.22.2 - install ocaml-compiler-libs v0.12.4 - install ocaml-secondary-compiler 4.14.2 - install ocamlfind 1.9.6 - install ocamlfind-secondary 1.9.6 - install ppx_derivers 1.2.1 - install re 1.11.0 - install seq base - install sexplib0 v0.15.1 - install yojson 3.0.0 <><> Processing actions <><><><><><><><><><><><><><><><><><><><><><><><><><><><> -> retrieved cinaps.v0.15.1 (cached) -> retrieved csexp.1.5.2 (cached) -> retrieved base.v0.15.2 (cached) -> retrieved cmdliner.2.1.1 (cached) -> retrieved ocaml-compiler-libs.v0.12.4 (cached) -> retrieved ocaml-secondary-compiler.4.14.2 (cached) -> retrieved dune.3.23.1 (cached) -> retrieved dune-configurator.3.22.2 (cached) -> retrieved ocamlfind.1.9.6, ocamlfind-secondary.1.9.6 (cached) -> retrieved seq.base (cached) -> retrieved ppx_derivers.1.2.1 (cached) -> retrieved re.1.11.0 (cached) -> retrieved sexplib0.v0.15.1 (cached) -> retrieved yojson.3.0.0 (cached) -> installed cmdliner.2.1.1 -> installed seq.base -> installed ocamlfind.1.9.6 -> installed ocaml-secondary-compiler.4.14.2 -> installed ocamlfind-secondary.1.9.6 -> installed dune.3.23.1 -> installed ppx_derivers.1.2.1 -> installed csexp.1.5.2 -> installed ocaml-compiler-libs.v0.12.4 -> installed re.1.11.0 -> installed sexplib0.v0.15.1 -> installed yojson.3.0.0 -> installed cinaps.v0.15.1 -> installed dune-configurator.3.22.2 -> installed base.v0.15.2 Done. # Run eval $(opam env) to update the current shell environment 2026-05-27 07:11.45 ---> using "f5e91c608efdfc0e5b3ba61d0547ec10b62e931181d0a7376b2bb69a5278b8d7" from cache /src: (run (cache (opam-archives (target /home/opam/.opam/download-cache))) (network host) (shell "opam install --yes dune 'odoc>=1.5.0'")) [NOTE] Package dune is already installed (current version is 3.23.1). The following actions will be performed: === install 13 packages - install astring 0.8.5 [required by odoc] - install camlp-streams 5.0.1 [required by odoc-parser] - install cppo 1.8.0 [required by odoc] - install crunch 4.0.0 [required by odoc] - install fmt 0.11.0 [required by odoc] - install fpath 0.7.3 [required by odoc] - install ocamlbuild 0.16.1 [required by fmt, astring, fpath] - install odoc 3.2.1 - install odoc-parser 3.2.1 [required by odoc] - install ptime 1.2.0 [required by crunch] - install topkg 1.1.1 [required by fmt, astring, fpath] - install tyxml 4.6.0 [required by odoc] - install uutf 1.0.4 [required by tyxml] <><> Processing actions <><><><><><><><><><><><><><><><><><><><><><><><><><><><> -> retrieved camlp-streams.5.0.1 (cached) -> retrieved astring.0.8.5 (cached) -> retrieved cppo.1.8.0 (cached) -> retrieved crunch.4.0.0 (cached) -> retrieved fmt.0.11.0 (cached) -> retrieved fpath.0.7.3 (cached) -> retrieved ocamlbuild.0.16.1 (cached) -> retrieved ptime.1.2.0 (cached) -> retrieved topkg.1.1.1 (cached) -> retrieved tyxml.4.6.0 (cached) -> retrieved uutf.1.0.4 (cached) -> retrieved odoc.3.2.1, odoc-parser.3.2.1 (cached) -> installed camlp-streams.5.0.1 -> installed cppo.1.8.0 -> installed ocamlbuild.0.16.1 -> installed topkg.1.1.1 -> installed uutf.1.0.4 -> installed fmt.0.11.0 -> installed ptime.1.2.0 -> installed astring.0.8.5 -> installed crunch.4.0.0 -> installed fpath.0.7.3 -> installed odoc-parser.3.2.1 -> installed tyxml.4.6.0 -> installed odoc.3.2.1 Done. # Run eval $(opam env) to update the current shell environment 2026-05-27 07:11.45 ---> using "4f7d64e68ffc06e4e8c79d7d9fe975cea2572dcb22a5c7df1eca818b70707989" from cache /src: (copy (src .) (dst /src/)) 2026-05-27 07:11.45 ---> using "e767f5c0f097b90af984e9e848610c32eafeef1b76599fe2003e32a3f0e707c1" from cache /src: (run (shell "ODOC_WARN_ERROR=false opam exec -- dune build @doc || (echo \"dune build @doc failed\"; exit 2)")) (cd _build/default/_doc/_odoc/pkg/ppxlib && /home/opam/.opam/4.11/bin/odoc compile --pkg ppxlib -o page-ast-traversal.odoc ../../../../doc/ast-traversal.mld) File "ast-traversal.mld": Warning: Pages (.mld files) should start with a heading. (cd _build/default/_doc/_odoc/pkg/ppxlib && /home/opam/.opam/4.11/bin/odoc compile --pkg ppxlib -o page-compatibility.odoc ../../../../doc/compatibility.mld) File "compatibility.mld": Warning: Pages (.mld files) should start with a heading. (cd _build/default/_doc/_odoc/pkg/ppxlib && /home/opam/.opam/4.11/bin/odoc compile --pkg ppxlib -o page-driver.odoc ../../../../doc/driver.mld) File "driver.mld": Warning: Pages (.mld files) should start with a heading. (cd _build/default/_doc/_odoc/pkg/ppxlib && /home/opam/.opam/4.11/bin/odoc compile --pkg ppxlib -o page-examples.odoc ../../../../doc/examples.mld) File "../../../../doc/examples.mld", line 126, characters 2-5: Warning: Paragraph should begin on its own line. File "examples.mld": Warning: Pages (.mld files) should start with a heading. (cd _build/default/_doc/_odoc/pkg/ppxlib && /home/opam/.opam/4.11/bin/odoc compile --pkg ppxlib -o page-generating-code.odoc ../../../../doc/generating-code.mld) File "generating-code.mld": Warning: Pages (.mld files) should start with a heading. (cd _build/default/_doc/_odoc/pkg/ppxlib && /home/opam/.opam/4.11/bin/odoc compile --pkg ppxlib -o page-good-practices.odoc ../../../../doc/good-practices.mld) File "good-practices.mld": Warning: Pages (.mld files) should start with a heading. (cd _build/default/_doc/_odoc/pkg/ppxlib && /home/opam/.opam/4.11/bin/odoc compile --pkg ppxlib -o page-matching-code.odoc ../../../../doc/matching-code.mld) File "matching-code.mld": Warning: Pages (.mld files) should start with a heading. File "../../../../doc/matching-code.mld", line 422, character 2 to line 437, character 2: Warning: Code blocks should be indented at the opening `{`. File "../../../../doc/matching-code.mld", line 472, character 2 to line 481, character 2: Warning: Code blocks should be indented at the opening `{`. File "../../../../doc/matching-code.mld", line 485, character 2 to line 502, character 2: Warning: Code blocks should be indented at the opening `{`. (cd _build/default/_doc/_odoc/pkg/ppxlib && /home/opam/.opam/4.11/bin/odoc compile --pkg ppxlib -o page-quick_intro.odoc ../../../../doc/quick_intro.mld) File "quick_intro.mld": Warning: Pages (.mld files) should start with a heading. (cd _build/default/_doc/_odoc/pkg/ppxlib && /home/opam/.opam/4.11/bin/odoc compile --pkg ppxlib -o page-writing-ppxs.odoc ../../../../doc/writing-ppxs.mld) File "writing-ppxs.mld": Warning: Pages (.mld files) should start with a heading. (cd _build/default/astlib/.astlib.objs/byte && /home/opam/.opam/4.11/bin/odoc compile -I . -I ../../../_doc/_odoc/pkg/ppxlib --pkg ppxlib -o astlib__Ast_503.odoc astlib__Ast_503.cmt) File "astlib/ast_503.ml", line 676, characters 42-43: Warning: '.' is not allowed in '{ul ...}' (bulleted list). Suggestion: move '.' into a list item, '{li ...}' or '{- ...}'. (cd _build/default/astlib/.astlib.objs/byte && /home/opam/.opam/4.11/bin/odoc compile -I . -I ../../../_doc/_odoc/pkg/ppxlib --pkg ppxlib -o astlib__Ast_504.odoc astlib__Ast_504.cmt) File "astlib/ast_504.ml", line 702, characters 42-43: Warning: '.' is not allowed in '{ul ...}' (bulleted list). Suggestion: move '.' into a list item, '{li ...}' or '{- ...}'. (cd _build/default/astlib/.astlib.objs/byte && /home/opam/.opam/4.11/bin/odoc compile -I . -I ../../../_doc/_odoc/pkg/ppxlib --pkg ppxlib -o astlib__Ast_506.odoc astlib__Ast_506.cmt) File "astlib/ast_506.ml", line 709, characters 31-32: Warning: '.' is not allowed in '{ul ...}' (bulleted list). Suggestion: move '.' into a list item, '{li ...}' or '{- ...}'. (cd _build/default/astlib/.astlib.objs/byte && /home/opam/.opam/4.11/bin/odoc compile -I . -I ../../../_doc/_odoc/pkg/ppxlib --pkg ppxlib -o astlib__Ast_505.odoc astlib__Ast_505.cmt) File "astlib/ast_505.ml", line 698, characters 42-43: Warning: '.' is not allowed in '{ul ...}' (bulleted list). Suggestion: move '.' into a list item, '{li ...}' or '{- ...}'. (cd _build/default/src/.ppxlib.objs/byte && /home/opam/.opam/4.11/bin/odoc compile -I . -I ../../../_doc/_odoc/pkg/ppxlib -I ../../../ast/.ppxlib_ast.objs/byte -I ../../../astlib/.astlib.objs/byte -I ../../../print-diff/.ppxlib_print_diff.objs/byte -I ../../../stdppx/.stdppx.objs/byte -I ../../../traverse_builtins/.ppxlib_traverse_builtins.objs/byte --pkg ppxlib -o ppxlib__Pp_ast.odoc ppxlib__Pp_ast.cmti) File "src/pp_ast.mli", line 10, character 4 to line 17, character 6: Warning: Code blocks should be indented at the opening `{`. File "src/pp_ast.mli", line 21, character 4 to line 26, character 6: Warning: Code blocks should be indented at the opening `{`. (cd _build/default/_doc/_odocls/ppxlib && /home/opam/.opam/4.11/bin/odoc link -I ../../_odoc/pkg/ppxlib -I ../../../ast/.ppxlib_ast.objs/byte -I ../../../astlib/.astlib.objs/byte -I ../../../metaquot/.ppxlib_metaquot.objs/byte -I ../../../metaquot_lifters/.ppxlib_metaquot_lifters.objs/byte -I ../../../print-diff/.ppxlib_print_diff.objs/byte -I ../../../runner/.ppxlib_runner.objs/byte -I ../../../runner_as_ppx/.ppxlib_runner_as_ppx.objs/byte -I ../../../src/.ppxlib.objs/byte -I ../../../stdppx/.stdppx.objs/byte -I ../../../test/deriving/inline/foo-deriver/.ppx_foo_deriver.objs/byte -I ../../../traverse/.ppxlib_traverse.objs/byte -I ../../../traverse_builtins/.ppxlib_traverse_builtins.objs/byte -o page-compatibility.odocl ../../_odoc/pkg/ppxlib/page-compatibility.odoc) File "../../../../doc/compatibility.mld", line 71, characters 11-61: Warning: Failed to resolve reference unresolvedroot(matching-code).ast_pattern Couldn't find page "ast_pattern" (cd _build/default/_doc/_odocls/ppxlib && /home/opam/.opam/4.11/bin/odoc link -I ../../_odoc/pkg/ppxlib -I ../../../ast/.ppxlib_ast.objs/byte -I ../../../astlib/.astlib.objs/byte -I ../../../metaquot/.ppxlib_metaquot.objs/byte -I ../../../metaquot_lifters/.ppxlib_metaquot_lifters.objs/byte -I ../../../print-diff/.ppxlib_print_diff.objs/byte -I ../../../runner/.ppxlib_runner.objs/byte -I ../../../runner_as_ppx/.ppxlib_runner_as_ppx.objs/byte -I ../../../src/.ppxlib.objs/byte -I ../../../stdppx/.stdppx.objs/byte -I ../../../test/deriving/inline/foo-deriver/.ppx_foo_deriver.objs/byte -I ../../../traverse/.ppxlib_traverse.objs/byte -I ../../../traverse_builtins/.ppxlib_traverse_builtins.objs/byte -o page-ast-traversal.odocl ../../_odoc/pkg/ppxlib/page-ast-traversal.odoc) File "../../../../doc/ast-traversal.mld", line 15, characters 71-101: Warning: Failed to resolve reference unresolvedroot(Stdlib).List.map Couldn't find "Stdlib" (cd _build/default/_doc/_odocls/ppxlib && /home/opam/.opam/4.11/bin/odoc link -I ../../_odoc/pkg/ppxlib -I ../../../ast/.ppxlib_ast.objs/byte -I ../../../astlib/.astlib.objs/byte -I ../../../metaquot/.ppxlib_metaquot.objs/byte -I ../../../metaquot_lifters/.ppxlib_metaquot_lifters.objs/byte -I ../../../print-diff/.ppxlib_print_diff.objs/byte -I ../../../runner/.ppxlib_runner.objs/byte -I ../../../runner_as_ppx/.ppxlib_runner_as_ppx.objs/byte -I ../../../src/.ppxlib.objs/byte -I ../../../stdppx/.stdppx.objs/byte -I ../../../test/deriving/inline/foo-deriver/.ppx_foo_deriver.objs/byte -I ../../../traverse/.ppxlib_traverse.objs/byte -I ../../../traverse_builtins/.ppxlib_traverse_builtins.objs/byte -o astlib.odocl ../../../astlib/.astlib.objs/byte/astlib.odoc) File "astlib/clean.mli", line 10, characters 4-27: Warning: Failed to resolve reference unresolvedroot(Parsetree).signature Couldn't find "Parsetree" (cd _build/default/_doc/_odocls/ppxlib && /home/opam/.opam/4.11/bin/odoc link -I ../../_odoc/pkg/ppxlib -I ../../../ast/.ppxlib_ast.objs/byte -I ../../../astlib/.astlib.objs/byte -I ../../../metaquot/.ppxlib_metaquot.objs/byte -I ../../../metaquot_lifters/.ppxlib_metaquot_lifters.objs/byte -I ../../../print-diff/.ppxlib_print_diff.objs/byte -I ../../../runner/.ppxlib_runner.objs/byte -I ../../../runner_as_ppx/.ppxlib_runner_as_ppx.objs/byte -I ../../../src/.ppxlib.objs/byte -I ../../../stdppx/.stdppx.objs/byte -I ../../../test/deriving/inline/foo-deriver/.ppx_foo_deriver.objs/byte -I ../../../traverse/.ppxlib_traverse.objs/byte -I ../../../traverse_builtins/.ppxlib_traverse_builtins.objs/byte -o page-writing-ppxs.odocl ../../_odoc/pkg/ppxlib/page-writing-ppxs.odoc) File "../../../../doc/writing-ppxs.mld", line 428, characters 0-92: Warning: Failed to resolve reference unresolvedroot(Ppxlib).Context_free.Rule.attr_multiple_replace Couldn't find "attr_multiple_replace" (cd _build/default/_doc/_odocls/ppxlib && /home/opam/.opam/4.11/bin/odoc link -I ../../_odoc/pkg/ppxlib -I ../../../ast/.ppxlib_ast.objs/byte -I ../../../astlib/.astlib.objs/byte -I ../../../metaquot/.ppxlib_metaquot.objs/byte -I ../../../metaquot_lifters/.ppxlib_metaquot_lifters.objs/byte -I ../../../print-diff/.ppxlib_print_diff.objs/byte -I ../../../runner/.ppxlib_runner.objs/byte -I ../../../runner_as_ppx/.ppxlib_runner_as_ppx.objs/byte -I ../../../src/.ppxlib.objs/byte -I ../../../stdppx/.stdppx.objs/byte -I ../../../test/deriving/inline/foo-deriver/.ppx_foo_deriver.objs/byte -I ../../../traverse/.ppxlib_traverse.objs/byte -I ../../../traverse_builtins/.ppxlib_traverse_builtins.objs/byte -o ppxlib.odocl ../../../src/.ppxlib.objs/byte/ppxlib.odoc) File "src/context_free.mli", line 66, characters 6-18: Warning: Reference to 'extension' is ambiguous. Please specify its kind: type-extension, val-extension. File "src/ast_builder_generated.ml", line 1079, characters 88-110: Warning: While resolving the expansion of include at File "src/ast_builder.mli", line 81, character 2 While resolving the expansion of include at File "src/ast_builder_intf.ml", line 202, character 2 Failed to resolve reference unresolvedroot(Ast).'aclass_infos Couldn't find "'aclass_infos" File "src/ast_builder_generated.ml", line 1073, characters 82-106: Warning: While resolving the expansion of include at File "src/ast_builder.mli", line 81, character 2 While resolving the expansion of include at File "src/ast_builder_intf.ml", line 202, character 2 Failed to resolve reference unresolvedroot(Ast).'ainclude_infos Couldn't find "'ainclude_infos" File "src/ast_builder_generated.ml", line 1070, characters 37-58: Warning: While resolving the expansion of include at File "src/ast_builder.mli", line 81, character 2 While resolving the expansion of include at File "src/ast_builder_intf.ml", line 202, character 2 Failed to resolve reference unresolvedroot(Ast).'aopen_infos Couldn't find "'aopen_infos" File "src/ast_builder_generated.ml", line 1063, characters 16-23: Warning: While resolving the expansion of include at File "src/ast_builder.mli", line 81, character 2 While resolving the expansion of include at File "src/ast_builder_intf.ml", line 202, character 2 Reference to 'case' is ambiguous. Please specify its kind: section-case, type-case, val-case. File "src/ast_builder_generated.ml", line 1013, characters 16-34: Warning: While resolving the expansion of include at File "src/ast_builder.mli", line 81, character 2 While resolving the expansion of include at File "src/ast_builder_intf.ml", line 202, character 2 Reference to 'class_structure' is ambiguous. Please specify its kind: type-class_structure, val-class_structure. File "src/ast_builder_generated.ml", line 978, characters 12-32: Warning: While resolving the expansion of include at File "src/ast_builder.mli", line 81, character 2 While resolving the expansion of include at File "src/ast_builder_intf.ml", line 202, character 2 Reference to 'value_description' is ambiguous. Please specify its kind: type-value_description, val-value_description. File "src/ast_builder_generated.ml", line 972, characters 12-32: Warning: While resolving the expansion of include at File "src/ast_builder.mli", line 81, character 2 While resolving the expansion of include at File "src/ast_builder_intf.ml", line 202, character 2 Reference to 'label_declaration' is ambiguous. Please specify its kind: type-label_declaration, val-label_declaration. File "src/ast_builder_generated.ml", line 614, characters 16-36: Warning: While resolving the expansion of include at File "src/ast_builder.mli", line 81, character 2 While resolving the expansion of include at File "src/ast_builder_intf.ml", line 202, character 2 Reference to 'value_description' is ambiguous. Please specify its kind: type-value_description, val-value_description. File "src/ast_builder_generated.ml", line 1079, characters 88-110: Warning: While resolving the expansion of include at File "src/ast_builder.mli", line 81, character 2 While resolving the expansion of include at File "src/ast_builder_intf.ml", line 202, character 2 Failed to resolve reference unresolvedroot(Ast).'aclass_infos Couldn't find "'aclass_infos" File "src/ast_builder_generated.ml", line 1073, characters 82-106: Warning: While resolving the expansion of include at File "src/ast_builder.mli", line 81, character 2 While resolving the expansion of include at File "src/ast_builder_intf.ml", line 202, character 2 Failed to resolve reference unresolvedroot(Ast).'ainclude_infos Couldn't find "'ainclude_infos" File "src/ast_builder_generated.ml", line 1070, characters 37-58: Warning: While resolving the expansion of include at File "src/ast_builder.mli", line 81, character 2 While resolving the expansion of include at File "src/ast_builder_intf.ml", line 202, character 2 Failed to resolve reference unresolvedroot(Ast).'aopen_infos Couldn't find "'aopen_infos" File "src/ast_builder_generated.ml", line 1063, characters 16-23: Warning: While resolving the expansion of include at File "src/ast_builder.mli", line 81, character 2 While resolving the expansion of include at File "src/ast_builder_intf.ml", line 202, character 2 Reference to 'case' is ambiguous. Please specify its kind: section-case, type-case, val-case. File "src/ast_builder_generated.ml", line 1013, characters 16-34: Warning: While resolving the expansion of include at File "src/ast_builder.mli", line 81, character 2 While resolving the expansion of include at File "src/ast_builder_intf.ml", line 202, character 2 Reference to 'class_structure' is ambiguous. Please specify its kind: type-class_structure, val-class_structure. File "src/ast_builder_generated.ml", line 978, characters 12-32: Warning: While resolving the expansion of include at File "src/ast_builder.mli", line 81, character 2 While resolving the expansion of include at File "src/ast_builder_intf.ml", line 202, character 2 Reference to 'value_description' is ambiguous. Please specify its kind: type-value_description, val-value_description. File "src/ast_builder_generated.ml", line 972, characters 12-32: Warning: While resolving the expansion of include at File "src/ast_builder.mli", line 81, character 2 While resolving the expansion of include at File "src/ast_builder_intf.ml", line 202, character 2 Reference to 'label_declaration' is ambiguous. Please specify its kind: type-label_declaration, val-label_declaration. File "src/ast_builder_generated.ml", line 614, characters 16-36: Warning: While resolving the expansion of include at File "src/ast_builder.mli", line 81, character 2 While resolving the expansion of include at File "src/ast_builder_intf.ml", line 202, character 2 Reference to 'value_description' is ambiguous. Please specify its kind: type-value_description, val-value_description. File "src/ast_builder_generated.ml", line 601, characters 90-112: Warning: While resolving the expansion of include at File "src/ast_builder.mli", line 21, character 2 Failed to resolve reference unresolvedroot(Ast).'aclass_infos Couldn't find "'aclass_infos" File "src/ast_builder_generated.ml", line 594, characters 100-124: Warning: While resolving the expansion of include at File "src/ast_builder.mli", line 21, character 2 Failed to resolve reference unresolvedroot(Ast).'ainclude_infos Couldn't find "'ainclude_infos" File "src/ast_builder_generated.ml", line 591, characters 37-58: Warning: While resolving the expansion of include at File "src/ast_builder.mli", line 21, character 2 Failed to resolve reference unresolvedroot(Ast).'aopen_infos Couldn't find "'aopen_infos" File "src/ast_builder_generated.ml", line 580, characters 16-23: Warning: While resolving the expansion of include at File "src/ast_builder.mli", line 21, character 2 Reference to 'case' is ambiguous. Please specify its kind: section-case, type-case, val-case. File "src/ast_builder_generated.ml", line 517, characters 16-34: Warning: While resolving the expansion of include at File "src/ast_builder.mli", line 21, character 2 Reference to 'class_structure' is ambiguous. Please specify its kind: type-class_structure, val-class_structure. File "src/ast_builder_generated.ml", line 464, characters 12-32: Warning: While resolving the expansion of include at File "src/ast_builder.mli", line 21, character 2 Reference to 'value_description' is ambiguous. Please specify its kind: type-value_description, val-value_description. File "src/ast_builder_generated.ml", line 458, characters 12-32: Warning: While resolving the expansion of include at File "src/ast_builder.mli", line 21, character 2 Reference to 'label_declaration' is ambiguous. Please specify its kind: type-label_declaration, val-label_declaration. File "src/ast_builder_generated.ml", line 13, characters 16-36: Warning: While resolving the expansion of include at File "src/ast_builder.mli", line 21, character 2 Reference to 'value_description' is ambiguous. Please specify its kind: type-value_description, val-value_description. 2026-05-27 07:11.45 ---> using "a811b387256cca1d85b981445b67b917e5ee308a1fcb2729a3bf7d30cc6f4563" from cache Job succeeded 2026-05-27 07:11.45: Job succeeded