2025-01-21 14:20.03: New job: test ocaml-ppx/ppxlib https://github.com/ocaml-ppx/ppxlib.git#refs/pull/541/head (6426dc0d1a28c1f36363570773aac42291cf4c41) (windows-amd64:windows-server-2022-amd64-5.3_opam-2.3)
Base: windows-server-2022-amd64-ocaml-5.3
Opam project build
To reproduce locally:
git clone --recursive "https://github.com/ocaml-ppx/ppxlib.git" && cd "ppxlib" && git fetch origin "refs/pull/541/head" && git reset --hard 6426dc0d
cat > Dockerfile <<'END-OF-DOCKERFILE'
FROM windows-server-2022-amd64-ocaml-5.3
# windows-server-2022-amd64-5.3_opam-2.3
USER 1000:1000
ENV CLICOLOR_FORCE="1"
ENV OPAMCOLOR="always"
RUN ln -f /usr/bin/opam-2.3 /usr/bin/opam
RUN opam init --reinit -ni
RUN uname -rs && opam exec -- ocaml -version && opam --version
RUN cd ~/opam-repository && (git cat-file -e b41fc63234d56d04112634b1ea9121f12caf9794 || git fetch origin master) && git reset -q --hard b41fc63234d56d04112634b1ea9121f12caf9794 && git log --no-decorate -n1 --oneline && opam update -u
COPY --chown=1000:1000 ppxlib.opam ppxlib-tools.opam ppxlib-bench.opam /Users/opam/src/./
RUN opam pin add -yn ppxlib.dev '/Users/opam/src/./' && \
opam pin add -yn ppxlib-tools.dev '/Users/opam/src/./' && \
opam pin add -yn ppxlib-bench.dev '/Users/opam/src/./'
RUN echo '(lang dune 3.0)' > '/cygdrive/c/Users/opam/src/./dune-project'
ENV DEPS="arch-x86_64.1 base.v0.17.1 base-bigarray.base base-domains.base base-effects.base base-nnp.base base-threads.base base-unix.base cinaps.v0.15.1 cmdliner.1.3.0 conf-mingw-w64-gcc-x86_64.1 csexp.1.5.2 dune.3.17.1 dune-configurator.3.17.1 flexdll.0.43 host-arch-x86_64.1 host-system-mingw.1 mingw-w64-shims.0.2.0 ocaml.5.3.0 ocaml-base-compiler.5.3.0 ocaml-compiler.5.3.0 ocaml-compiler-libs.v0.17.0 ocaml-config.3 ocaml-env-mingw64.1 ocaml-options-vanilla.1 ocaml_intrinsics_kernel.v0.17.1 ocamlfind.1.9.5 ppx_derivers.1.2.1 re.1.12.0 seq.base sexplib0.v0.17.0 stdlib-shims.0.3.0 system-mingw.1 yojson.2.2.2"
ENV CI="true"
ENV OCAMLCI="true"
RUN opam update --depexts && opam install --cli=2.3 --depext-only -y ppxlib.dev ppxlib-tools.dev ppxlib-bench.dev $DEPS
RUN opam install $DEPS
COPY --chown=1000:1000 . /Users/opam/src
RUN cd /cygdrive/c/Users/opam/src && opam exec -- dune build @install @check @runtest && rm -rf _build
END-OF-DOCKERFILE
docker build .
END-REPRO-BLOCK
2025-01-21 14:20.03: Using cache hint "ocaml-ppx/ppxlib-windows-server-2022-amd64-ocaml-5.3-windows-server-2022-amd64-5.3_opam-2.3-3ae442992ee6182bf2e930101f7322a5"
2025-01-21 14:20.03: Using OBuilder spec:
((from windows-server-2022-amd64-ocaml-5.3)
(comment windows-server-2022-amd64-5.3_opam-2.3)
(user (uid 1000) (gid 1000))
(env CLICOLOR_FORCE 1)
(env OPAMCOLOR always)
(run (shell "ln -f /usr/bin/opam-2.3 /usr/bin/opam"))
(run (shell "opam init --reinit -ni"))
(run (shell "uname -rs && opam exec -- ocaml -version && opam --version"))
(run (cache (opam-archives (target "c:\\Users\\opam\\AppData\\local\\opam\\download-cache")))
(network host)
(shell "cd ~/opam-repository && (git cat-file -e b41fc63234d56d04112634b1ea9121f12caf9794 || git fetch origin master) && git reset -q --hard b41fc63234d56d04112634b1ea9121f12caf9794 && git log --no-decorate -n1 --oneline && opam update -u"))
(copy (src ppxlib.opam ppxlib-tools.opam ppxlib-bench.opam)
(dst /Users/opam/src/./))
(run (network host)
(shell "opam pin add -yn ppxlib.dev '/Users/opam/src/./' && \
\nopam pin add -yn ppxlib-tools.dev '/Users/opam/src/./' && \
\nopam pin add -yn ppxlib-bench.dev '/Users/opam/src/./'"))
(run (network host)
(shell "echo '(lang dune 3.0)' > '/cygdrive/c/Users/opam/src/./dune-project'"))
(env DEPS "arch-x86_64.1 base.v0.17.1 base-bigarray.base base-domains.base base-effects.base base-nnp.base base-threads.base base-unix.base cinaps.v0.15.1 cmdliner.1.3.0 conf-mingw-w64-gcc-x86_64.1 csexp.1.5.2 dune.3.17.1 dune-configurator.3.17.1 flexdll.0.43 host-arch-x86_64.1 host-system-mingw.1 mingw-w64-shims.0.2.0 ocaml.5.3.0 ocaml-base-compiler.5.3.0 ocaml-compiler.5.3.0 ocaml-compiler-libs.v0.17.0 ocaml-config.3 ocaml-env-mingw64.1 ocaml-options-vanilla.1 ocaml_intrinsics_kernel.v0.17.1 ocamlfind.1.9.5 ppx_derivers.1.2.1 re.1.12.0 seq.base sexplib0.v0.17.0 stdlib-shims.0.3.0 system-mingw.1 yojson.2.2.2")
(env CI true)
(env OCAMLCI true)
(run (cache (opam-archives (target "c:\\Users\\opam\\AppData\\local\\opam\\download-cache")))
(network host)
(shell "opam update --depexts && opam install --cli=2.3 --depext-only -y ppxlib.dev ppxlib-tools.dev ppxlib-bench.dev $DEPS"))
(run (cache (opam-archives (target "c:\\Users\\opam\\AppData\\local\\opam\\download-cache")))
(network host)
(shell "opam install $DEPS"))
(copy (src .) (dst /Users/opam/src))
(run (shell "cd /cygdrive/c/Users/opam/src && opam exec -- dune build @install @check @runtest && rm -rf _build"))
)
2025-01-21 14:20.03: Waiting for resource in pool OCluster
2025-01-21 16:11.15: Waiting for worker…
2025-01-21 17:06.28: Got resource from pool OCluster
Building on odawa
All commits already cached
HEAD is now at 6426dc0d Mark deriving.end attributes as seen in -no-corrections mode
(from windows-server-2022-amd64-ocaml-5.3)
2025-01-21 17:06.28 ---> using "1d6ffeb5a52124df73b2e951323e99615c52ca4f9bdf0f65039be6146fabdaab" from cache
/: (comment windows-server-2022-amd64-5.3_opam-2.3)
/: (user (uid 1000) (gid 1000))
/: (env CLICOLOR_FORCE 1)
/: (env OPAMCOLOR always)
/: (run (shell "ln -f /usr/bin/opam-2.3 /usr/bin/opam"))
2025-01-21 17:06.28 ---> using "95d5d85ee56c2575e196f53fe7f940cc0731fb5c4485beb38b72a714de9d05bf" from cache
/: (run (shell "opam init --reinit -ni"))
No configuration file found, using built-in defaults.
<><> Unix support infrastructure ><><><><><><><><><><><><><><><><><><><><><><><>
opam and the OCaml ecosystem in general require various Unix tools in order to operate correctly. At present, this requires the installation of Cygwin to provide these tools.
How should opam obtain Unix tools?
> 1. Use tools found in PATH (Cygwin installation at C:\cygwin64)
2. Automatically create an internal Cygwin installation that will be managed by opam (recommended)
3. Use Cygwin installation found in C:\cygwin64
4. Use another existing Cygwin/MSYS2 installation
5. Abort initialisation
[1/2/3/4/5] 1
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.
<><> Updating repositories ><><><><><><><><><><><><><><><><><><><><><><><><><><>
[default] no changes from file://C:/Users/opam/opam-repository
2025-01-21 17:06.28 ---> using "53bae75d46d214e65b51daece9ef873c6c6a891e203ec3d98bbd26c30834d1e2" from cache
/: (run (shell "uname -rs && opam exec -- ocaml -version && opam --version"))
CYGWIN_NT-10.0-20348 3.5.5-1.x86_64
The OCaml toplevel, version 5.3.0
2.3.0
2025-01-21 17:06.28 ---> using "2b54922bf0d8d5ddbb1aea4afec4a959968c963bd87de7fe3038a742f957825c" from cache
/: (run (cache (opam-archives (target "c:\\Users\\opam\\AppData\\local\\opam\\download-cache")))
(network host)
(shell "cd ~/opam-repository && (git cat-file -e b41fc63234d56d04112634b1ea9121f12caf9794 || git fetch origin master) && git reset -q --hard b41fc63234d56d04112634b1ea9121f12caf9794 && git log --no-decorate -n1 --oneline && opam update -u"))
From https://github.com/ocaml/opam-repository
* branch master -> FETCH_HEAD
f93eb7cb02..b41fc63234 master -> origin/master
b41fc63234 Merge pull request #27302 from ocaml/dra27--rm-non-win32-host-pkgs
<><> Updating package repositories ><><><><><><><><><><><><><><><><><><><><><><>
[default] synchronised from file://C:/Users/opam/opam-repository
Everything as up-to-date as possible (run with --verbose to show unavailable upgrades).
However, you may "opam upgrade" these packages explicitly, which will ask permission to downgrade or uninstall the conflicting packages.
Nothing to do.
# To update the current shell environment, run: eval $(opam env)
2025-01-21 17:06.28 ---> using "f3aefeca99a577161b1c4036e8c3d43bc3e8a5e84e55f42dbc259ccc1863e902" from cache
/: (copy (src ppxlib.opam ppxlib-tools.opam ppxlib-bench.opam)
(dst /Users/opam/src/./))
2025-01-21 17:06.28 ---> using "079cea3d248e6cd30046b2d73a77d770182b69f0050c8ef045e39103e942c0d5" from cache
/: (run (network host)
(shell "opam pin add -yn ppxlib.dev '/Users/opam/src/./' && \
\nopam pin add -yn ppxlib-tools.dev '/Users/opam/src/./' && \
\nopam pin add -yn ppxlib-bench.dev '/Users/opam/src/./'"))
[ppxlib.dev] synchronised (file://C:/Users/opam/src/.)
ppxlib is now pinned to file://C:/Users/opam/src/. (version dev)
[ppxlib-tools.dev] synchronised (file://C:/Users/opam/src/.)
ppxlib-tools is now pinned to file://C:/Users/opam/src/. (version dev)
Package ppxlib-bench does not exist, create as a NEW package? [y/n] y
[ppxlib-bench.dev] synchronised (file://C:/Users/opam/src/.)
ppxlib-bench is now pinned to file://C:/Users/opam/src/. (version dev)
2025-01-21 17:06.28 ---> using "4b0064c51d74dcb8fbf9193c40b189c310cc868d626bd1abee98316cca42661b" from cache
/: (run (network host)
(shell "echo '(lang dune 3.0)' > '/cygdrive/c/Users/opam/src/./dune-project'"))
2025-01-21 17:06.28 ---> using "876a24bf637c2650cb4b32d1621eb142087ae429a73c94282a8c82c9e6fc31c0" from cache
/: (env DEPS "arch-x86_64.1 base.v0.17.1 base-bigarray.base base-domains.base base-effects.base base-nnp.base base-threads.base base-unix.base cinaps.v0.15.1 cmdliner.1.3.0 conf-mingw-w64-gcc-x86_64.1 csexp.1.5.2 dune.3.17.1 dune-configurator.3.17.1 flexdll.0.43 host-arch-x86_64.1 host-system-mingw.1 mingw-w64-shims.0.2.0 ocaml.5.3.0 ocaml-base-compiler.5.3.0 ocaml-compiler.5.3.0 ocaml-compiler-libs.v0.17.0 ocaml-config.3 ocaml-env-mingw64.1 ocaml-options-vanilla.1 ocaml_intrinsics_kernel.v0.17.1 ocamlfind.1.9.5 ppx_derivers.1.2.1 re.1.12.0 seq.base sexplib0.v0.17.0 stdlib-shims.0.3.0 system-mingw.1 yojson.2.2.2")
/: (env CI true)
/: (env OCAMLCI true)
/: (run (cache (opam-archives (target "c:\\Users\\opam\\AppData\\local\\opam\\download-cache")))
(network host)
(shell "opam update --depexts && opam install --cli=2.3 --depext-only -y ppxlib.dev ppxlib-tools.dev ppxlib-bench.dev $DEPS"))
<><> Synchronising pinned packages ><><><><><><><><><><><><><><><><><><><><><><>
[ppxlib.dev] synchronised (file://C:/Users/opam/src/.)
[ppxlib-bench.dev] synchronised (file://C:/Users/opam/src/.)
[ppxlib-tools.dev] synchronised (file://C:/Users/opam/src/.)
[NOTE] Package system-mingw is already installed (current version is 1).
[NOTE] Package ocaml-options-vanilla is already installed (current version is 1).
[NOTE] Package ocaml-env-mingw64 is already installed (current version is 1).
[NOTE] Package ocaml-config is already installed (current version is 3).
[NOTE] Package ocaml-compiler is already installed (current version is 5.3.0).
[NOTE] Package ocaml-base-compiler is already installed (current version is 5.3.0).
[NOTE] Package ocaml is already installed (current version is 5.3.0).
[NOTE] Package mingw-w64-shims is already installed (current version is 0.2.0).
[NOTE] Package host-system-mingw is already installed (current version is 1).
[NOTE] Package host-arch-x86_64 is already installed (current version is 1).
[NOTE] Package flexdll is already installed (current version is 0.43).
[NOTE] Package conf-mingw-w64-gcc-x86_64 is already installed (current version is 1).
[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-nnp is already installed (current version is base).
[NOTE] Package base-effects is already installed (current version is base).
[NOTE] Package base-domains is already installed (current version is base).
[NOTE] Package base-bigarray is already installed (current version is base).
[NOTE] Package arch-x86_64 is already installed (current version is 1).
2025-01-21 17:06.28 ---> using "421fa8e32884fc4b71ef00ee521fa380f2b531118a06b6573ed08200f29e105a" from cache
/: (run (cache (opam-archives (target "c:\\Users\\opam\\AppData\\local\\opam\\download-cache")))
(network host)
(shell "opam install $DEPS"))
[NOTE] Package system-mingw is already installed (current version is 1).
[NOTE] Package ocaml-options-vanilla is already installed (current version is 1).
[NOTE] Package ocaml-env-mingw64 is already installed (current version is 1).
[NOTE] Package ocaml-config is already installed (current version is 3).
[NOTE] Package ocaml-compiler is already installed (current version is 5.3.0).
[NOTE] Package ocaml-base-compiler is already installed (current version is 5.3.0).
[NOTE] Package ocaml is already installed (current version is 5.3.0).
[NOTE] Package mingw-w64-shims is already installed (current version is 0.2.0).
[NOTE] Package host-system-mingw is already installed (current version is 1).
[NOTE] Package host-arch-x86_64 is already installed (current version is 1).
[NOTE] Package flexdll is already installed (current version is 0.43).
[NOTE] Package conf-mingw-w64-gcc-x86_64 is already installed (current version is 1).
[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-nnp is already installed (current version is base).
[NOTE] Package base-effects is already installed (current version is base).
[NOTE] Package base-domains is already installed (current version is base).
[NOTE] Package base-bigarray is already installed (current version is base).
[NOTE] Package arch-x86_64 is already installed (current version is 1).
The following actions will be performed:
=== install 15 packages
- install base v0.17.1
- install cinaps v0.15.1
- install cmdliner 1.3.0
- install csexp 1.5.2
- install dune 3.17.1
- install dune-configurator 3.17.1
- install ocaml-compiler-libs v0.17.0
- install ocaml_intrinsics_kernel v0.17.1
- install ocamlfind 1.9.5
- install ppx_derivers 1.2.1
- install re 1.12.0
- install seq base
- install sexplib0 v0.17.0
- install stdlib-shims 0.3.0
- install yojson 2.2.2
<><> Processing actions <><><><><><><><><><><><><><><><><><><><><><><><><><><><>
-> retrieved cmdliner.1.3.0 (cached)
-> retrieved base.v0.17.1 (cached)
-> retrieved csexp.1.5.2 (cached)
-> retrieved cinaps.v0.15.1 (https://github.com/ocaml-ppx/cinaps/archive/v0.15.1.tar.gz)
-> retrieved ocaml-compiler-libs.v0.17.0 (cached)
-> retrieved ocaml_intrinsics_kernel.v0.17.1 (cached)
-> retrieved ppx_derivers.1.2.1 (cached)
-> retrieved ocamlfind.1.9.5 (cached)
-> retrieved seq.base (cached)
-> installed seq.base
-> retrieved re.1.12.0 (cached)
-> retrieved sexplib0.v0.17.0 (cached)
-> retrieved stdlib-shims.0.3.0 (cached)
-> retrieved yojson.2.2.2 (cached)
-> retrieved dune.3.17.1, dune-configurator.3.17.1 (cached)
-> installed cmdliner.1.3.0
[WARNING] .install file is missing .exe extension for src/findlib/ocamlfind
[WARNING] .install file is missing .exe extension for src/findlib/ocamlfind_opt
[WARNING] Automatically adding .exe to C:\Users\opam\AppData\Local\opam\5.3.0\.opam-switch\build\ocamlfind.1.9.5\src\findlib\ocamlfind.exe
[WARNING] Automatically adding .exe to C:\Users\opam\AppData\Local\opam\5.3.0\.opam-switch\build\ocamlfind.1.9.5\src\findlib\ocamlfind_opt.exe
[WARNING] C:\Users\opam\AppData\Local\opam\5.3.0\bin\safe_camlp4 is a script; the command won't be available
-> installed ocamlfind.1.9.5
-> installed dune.3.17.1
-> installed csexp.1.5.2
-> installed ocaml-compiler-libs.v0.17.0
-> installed ocaml_intrinsics_kernel.v0.17.1
-> installed ppx_derivers.1.2.1
-> installed re.1.12.0
-> installed sexplib0.v0.17.0
-> installed stdlib-shims.0.3.0
-> installed yojson.2.2.2
-> installed cinaps.v0.15.1
-> installed dune-configurator.3.17.1
-> installed base.v0.17.1
Done.
# To update the current shell environment, run: eval $(opam env)
2025-01-21 17:08.04 ---> saved as "e6106a3a8fc6ef49fc472e2a8138e1c26943ba1af578ccaba2da4ede028b45be"
/: (copy (src .) (dst /Users/opam/src))
2025-01-21 17:08.17 ---> saved as "4d449deb0e09d43dacad84d773f2f1c812769dce01b5680786d18d0c8478beda"
/: (run (shell "cd /cygdrive/c/Users/opam/src && opam exec -- dune build @install @check @runtest && rm -rf _build"))
File "ast/dune", lines 21-23, characters 0-60:
21 | (cinaps
22 | (files *.ml *.mli)
23 | (libraries ast_cinaps_helpers))
(cd _build/default/ast && .cinaps.5e30bf3c\cinaps.exe -diff-cmd -)
Fatal error: exception Sys_error("C:\\Users\\opam\\AppData\\Local\\Temp\\build_e0de0c_dune\\cinaps7bed0e.ml: Permission denied")
File "astlib/dune", lines 15-17, characters 0-63:
15 | (cinaps
16 | (files *.ml *.mli)
17 | (libraries astlib_cinaps_helpers))
(cd _build/default/astlib && .cinaps.d65f99e1\cinaps.exe -diff-cmd -)
Fatal error: exception Sys_error("C:\\Users\\opam\\AppData\\Local\\Temp\\build_e0de0c_dune\\cinaps41e907.ml: Permission denied")
File "src/dune", lines 23-25, characters 0-63:
23 | (cinaps
24 | (files *.ml *.mli)
25 | (libraries ppxlib_cinaps_helpers))
(cd _build/default/src && .cinaps.b043d3b4\cinaps.exe -diff-cmd -)
Fatal error: exception Sys_error("C:\\Users\\opam\\AppData\\Local\\Temp\\build_e0de0c_dune\\cinaps73699d.mli: Permission denied")
File "test/driver/error_embedding/test.t/run.t", line 1, characters 0-0:
C:\cygwin64\bin\git.exe --no-pager diff --no-index --color=always -u --ignore-cr-at-eol _build/.sandbox/2a8fa3cffbf906002b390063590640fc/default/test/driver/error_embedding/test.t/run.t _build/.sandbox/2a8fa3cffbf906002b390063590640fc/default/test/driver/error_embedding/test.t/run.t.corrected
diff --git a/_build/.sandbox/2a8fa3cffbf906002b390063590640fc/default/test/driver/error_embedding/test.t/run.t b/_build/.sandbox/2a8fa3cffbf906002b390063590640fc/default/test/driver/error_embedding/test.t/run.t.corrected
index dafee10..7170038 100644
--- a/_build/.sandbox/2a8fa3cffbf906002b390063590640fc/default/test/driver/error_embedding/test.t/run.t
+++ b/_build/.sandbox/2a8fa3cffbf906002b390063590640fc/default/test/driver/error_embedding/test.t/run.t.corrected
@@ -14,8 +14,12 @@ The same is true when using the `-as-ppx` mode (note that the error is reported
by ocaml itself)
$ ocaml -ppx '../raiser.exe -as-ppx' impl.ml
- File "./impl.ml", line 1, characters 8-16:
- Error: Raising inside the rewriter
+ '..' is not recognized as an internal or external command,
+ operable program or batch file.
+ File ".\impl.ml", line 1:
+ Error: Error while running external preprocessor
+ Command line: ../raiser.exe -as-ppx "C:\Users\opam\AppData\Local\Temp\build_e0de0c_dune\camlppx7a0d65" "C:\Users\opam\AppData\Local\Temp\build_e0de0c_dune\camlppx6762c7"
+
[2]
Also exceptions raised in a preprocessor get embedded into an AST(while the
@@ -23,9 +27,10 @@ error from the preprocessor's stderr also gets reported on the driver's stderr)
$ touch file.ml
$ ../raiser.exe -embed-errors -pp ../pp.exe file.ml | sed "s/> '.*'/> tmpfile/"
- Fatal error: exception Raising inside the preprocessor
+ '..' is not recognized as an internal or external command,
+ operable program or batch file.
[%%ocaml.error
- "Error while running external preprocessor\nCommand line: ../pp.exe 'file.ml' > tmpfile\n"]
+ "Error while running external preprocessor\nCommand line: ../pp.exe \"file.ml\" > \"C:\\Users\\opam\\AppData\\Local\\Temp\\build_e0de0c_dune\\ocamlpp9bd243\"\n"]
Also `unknown version` errors are embedded into an AST when using the
main standalone
File "test/driver/standalone_run_as_ppx/run.t", line 1, characters 0-0:
C:\cygwin64\bin\git.exe --no-pager diff --no-index --color=always -u --ignore-cr-at-eol _build/.sandbox/c5db9ba4564cebbd7e65b56f9a70129d/default/test/driver/standalone_run_as_ppx/run.t _build/.sandbox/c5db9ba4564cebbd7e65b56f9a70129d/default/test/driver/standalone_run_as_ppx/run.t.corrected
diff --git a/_build/.sandbox/c5db9ba4564cebbd7e65b56f9a70129d/default/test/driver/standalone_run_as_ppx/run.t b/_build/.sandbox/c5db9ba4564cebbd7e65b56f9a70129d/default/test/driver/standalone_run_as_ppx/run.t.corrected
index e36c4bf..b8a4aac 100644
--- a/_build/.sandbox/c5db9ba4564cebbd7e65b56f9a70129d/default/test/driver/standalone_run_as_ppx/run.t
+++ b/_build/.sandbox/c5db9ba4564cebbd7e65b56f9a70129d/default/test/driver/standalone_run_as_ppx/run.t.corrected
@@ -6,7 +6,13 @@ The rewriter gets applied when using `--as-ppx`
$ echo "let _ = [%print_hi]" > impl.ml
$ ocaml -ppx './print_stuff.exe --as-ppx' impl.ml
- hi
+ '.' is not recognized as an internal or external command,
+ operable program or batch file.
+ File ".\impl.ml", line 1:
+ Error: Error while running external preprocessor
+ Command line: ./print_stuff.exe --as-ppx "C:\Users\opam\AppData\Local\Temp\build_e0de0c_dune\camlppxd66c56" "C:\Users\opam\AppData\Local\Temp\build_e0de0c_dune\camlppx5efd56"
+
+ [2]
If a non-compatible file gets fed, the file name is reported correctly
@@ -20,18 +26,34 @@ The ocaml.ppx.context attribute gets parsed correctly; in particular, the tool n
$ echo "let _ = [%print_tool_name]" > impl.ml
$ ocaml -ppx './print_stuff.exe --as-ppx' impl.ml
- ocaml
+ '.' is not recognized as an internal or external command,
+ operable program or batch file.
+ File ".\impl.ml", line 1:
+ Error: Error while running external preprocessor
+ Command line: ./print_stuff.exe --as-ppx "C:\Users\opam\AppData\Local\Temp\build_e0de0c_dune\camlppx5ab545" "C:\Users\opam\AppData\Local\Temp\build_e0de0c_dune\camlppxd76223"
+
+ [2]
The driver's `shared_args` arguments are taken into account. For example, `-loc-filename`
$ echo "let _ = [%print_fname]" > impl.ml
$ ocaml -ppx './print_stuff.exe --as-ppx -loc-filename new_fn.ml' impl.ml
- new_fn.ml
+ '.' is not recognized as an internal or external command,
+ operable program or batch file.
+ File ".\impl.ml", line 1:
+ Error: Error while running external preprocessor
+ Command line: ./print_stuff.exe --as-ppx -loc-filename new_fn.ml "C:\Users\opam\AppData\Local\Temp\build_e0de0c_dune\camlppxff32c4" "C:\Users\opam\AppData\Local\Temp\build_e0de0c_dune\camlppx9c14ec"
+
+ [2]
or `dont-apply`
$ echo "let _ = [%print_hi]" > impl.ml
$ ocaml -ppx './print_stuff.exe --as-ppx -dont-apply test' impl.ml
- File "./impl.ml", line 1, characters 10-18:
- Error: Uninterpreted extension 'print_hi'.
+ '.' is not recognized as an internal or external command,
+ operable program or batch file.
+ File ".\impl.ml", line 1:
+ Error: Error while running external preprocessor
+ Command line: ./print_stuff.exe --as-ppx -dont-apply test "C:\Users\opam\AppData\Local\Temp\build_e0de0c_dune\camlppxf2ccdf" "C:\Users\opam\AppData\Local\Temp\build_e0de0c_dune\camlppxb99d43"
+
[2]
File "test/driver/flag_cookie/run.t", line 1, characters 0-0:
C:\cygwin64\bin\git.exe --no-pager diff --no-index --color=always -u --ignore-cr-at-eol _build/.sandbox/43ebf3910cbcba888b44b4135c9b9459/default/test/driver/flag_cookie/run.t _build/.sandbox/43ebf3910cbcba888b44b4135c9b9459/default/test/driver/flag_cookie/run.t.corrected
diff --git a/_build/.sandbox/43ebf3910cbcba888b44b4135c9b9459/default/test/driver/flag_cookie/run.t b/_build/.sandbox/43ebf3910cbcba888b44b4135c9b9459/default/test/driver/flag_cookie/run.t.corrected
index d6c3fa5..42c81cc 100644
--- a/_build/.sandbox/43ebf3910cbcba888b44b4135c9b9459/default/test/driver/flag_cookie/run.t
+++ b/_build/.sandbox/43ebf3910cbcba888b44b4135c9b9459/default/test/driver/flag_cookie/run.t.corrected
@@ -7,4 +7,10 @@ The cookie flag is taken into account, both by the main standalone
...and by the `-as-ppx` standalone
$ ocaml -ppx './print_cookie_driver.exe --as-ppx -cookie x=1' impl.ml
- Value of cookie x: 1
+ '.' is not recognized as an internal or external command,
+ operable program or batch file.
+ File ".\impl.ml", line 1:
+ Error: Error while running external preprocessor
+ Command line: ./print_cookie_driver.exe --as-ppx -cookie x=1 "C:\Users\opam\AppData\Local\Temp\build_e0de0c_dune\camlppx8dbbc3" "C:\Users\opam\AppData\Local\Temp\build_e0de0c_dune\camlppxf71e8a"
+
+ [2]
File "test/driver/no-corrections/run.t", line 1, characters 0-0:
C:\cygwin64\bin\git.exe --no-pager diff --no-index --color=always -u --ignore-cr-at-eol _build/.sandbox/5145fa4c5ac3209d9590214cea3839d5/default/test/driver/no-corrections/run.t _build/.sandbox/5145fa4c5ac3209d9590214cea3839d5/default/test/driver/no-corrections/run.t.corrected
diff --git a/_build/.sandbox/5145fa4c5ac3209d9590214cea3839d5/default/test/driver/no-corrections/run.t b/_build/.sandbox/5145fa4c5ac3209d9590214cea3839d5/default/test/driver/no-corrections/run.t.corrected
index 573fa11..adc7e63 100644
--- a/_build/.sandbox/5145fa4c5ac3209d9590214cea3839d5/default/test/driver/no-corrections/run.t
+++ b/_build/.sandbox/5145fa4c5ac3209d9590214cea3839d5/default/test/driver/no-corrections/run.t.corrected
@@ -66,10 +66,23 @@ and the last [@@@deriving.end] that comes with it.
[@@@deriving.end ]
type t3[@@gen_stuff ]
[@@@deriving.end ]
- 3a4,6
+ 1,6c1,9
+ < type t [@@deriving x]
+ < type t2
+ < [@@deriving_inline y]
+ < [@@@deriving.end]
+ < type t3 [@@gen_stuff]
+ < [@@@deriving.end]
+ ---
+ > type t [@@deriving x]
+ > type t2
+ > [@@deriving_inline y]
> let _ = fun (_ : t2) -> ()
> [%%ocaml.error
> "Ppxlib.Deriving: 'y' is not a supported type deriving generator"]
+ > [@@@deriving.end]
+ > type t3 [@@gen_stuff]
+ > [@@@deriving.end]
[1]
Now if we run it with -no-corrections, there should be no .ppx-corrected file
@@ -101,12 +114,24 @@ expected and all corrections will be correctly generated
[@@@deriving.end ]
type t3[@@gen_stuff ]
[@@@deriving.end ]
- 3a4,6
+ 1,6c1,10
+ < type t [@@deriving x]
+ < type t2
+ < [@@deriving_inline y]
+ < [@@@deriving.end]
+ < type t3 [@@gen_stuff]
+ < [@@@deriving.end]
+ ---
+ > type t [@@deriving x]
+ > type t2
+ > [@@deriving_inline y]
> let _ = fun (_ : t2) -> ()
> let y = 3
> let _ = y
- 5a9
+ > [@@@deriving.end]
+ > type t3 [@@gen_stuff]
> let stuff = 4
+ > [@@@deriving.end]
[1]
For reference and to document the behaviour of the -no-corrections flag in this
File "test/driver/run_as_ppx_rewriter/run.t", line 1, characters 0-0:
C:\cygwin64\bin\git.exe --no-pager diff --no-index --color=always -u --ignore-cr-at-eol _build/.sandbox/dbb02c697e7b293f7b62da6705ea790a/default/test/driver/run_as_ppx_rewriter/run.t _build/.sandbox/dbb02c697e7b293f7b62da6705ea790a/default/test/driver/run_as_ppx_rewriter/run.t.corrected
diff --git a/_build/.sandbox/dbb02c697e7b293f7b62da6705ea790a/default/test/driver/run_as_ppx_rewriter/run.t b/_build/.sandbox/dbb02c697e7b293f7b62da6705ea790a/default/test/driver/run_as_ppx_rewriter/run.t.corrected
index 0befcac..3c09a15 100644
--- a/_build/.sandbox/dbb02c697e7b293f7b62da6705ea790a/default/test/driver/run_as_ppx_rewriter/run.t
+++ b/_build/.sandbox/dbb02c697e7b293f7b62da6705ea790a/default/test/driver/run_as_ppx_rewriter/run.t.corrected
@@ -10,23 +10,35 @@ The registered rewriters get applied when using `run_as_ppx_rewriter` as entry p
> let () = [%print_bye]
> EOF
$ ocaml -ppx './print_greetings.exe' file.ml
- hi
- bye
+ '.' is not recognized as an internal or external command,
+ operable program or batch file.
+ File ".\file.ml", line 1:
+ Error: Error while running external preprocessor
+ Command line: ./print_greetings.exe "C:\Users\opam\AppData\Local\Temp\build_e0de0c_dune\camlppx4036a8" "C:\Users\opam\AppData\Local\Temp\build_e0de0c_dune\camlppxc9b8e9"
+
+ [2]
The driver's `shared_args` are taken into account, such as `-apply`...
$ ocaml -ppx './print_greetings.exe -apply print_hi' file.ml
- hi
- File "./file.ml", line 2, characters 11-20:
- Error: Uninterpreted extension 'print_bye'.
+ '.' is not recognized as an internal or external command,
+ operable program or batch file.
+ File ".\file.ml", line 1:
+ Error: Error while running external preprocessor
+ Command line: ./print_greetings.exe -apply print_hi "C:\Users\opam\AppData\Local\Temp\build_e0de0c_dune\camlppx072445" "C:\Users\opam\AppData\Local\Temp\build_e0de0c_dune\camlppxb3001a"
+
[2]
... and `-check`
$ echo "[@@@attr non_registered_attr]" > attribute_file.ml
$ ocaml -ppx './print_greetings.exe -check' attribute_file.ml
- File "./attribute_file.ml", line 1, characters 4-8:
- Error: Attribute `attr' was not used
+ '.' is not recognized as an internal or external command,
+ operable program or batch file.
+ File ".\attribute_file.ml", line 1:
+ Error: Error while running external preprocessor
+ Command line: ./print_greetings.exe -check "C:\Users\opam\AppData\Local\Temp\build_e0de0c_dune\camlppx6df0fa" "C:\Users\opam\AppData\Local\Temp\build_e0de0c_dune\camlppx415dfc"
+
[2]
@@ -48,7 +60,7 @@ The only possible usage is [extra_args] <infile> <outfile>...
$ touch some_output
$ ./print_greetings.exe some_input some_output -check
- ./print_greetings.exe: anonymous arguments not accepted.
+ C:\Users\opam\src\_build\.sandbox\dbb02c697e7b293f7b62da6705ea790a\default\test\driver\run_as_ppx_rewriter\print_greetings.exe: anonymous arguments not accepted.
print_greetings.exe [extra_args] <infile> <outfile>
-loc-filename <string> File name to use in locations
-reserve-namespace <string> Mark the given namespace as reserved
"cd /cygdrive/c/Users/opam/src && opam exec -- dune build @install @check @runtest && rm -rf _build" failed with exit status 1
2025-01-21 17:08.59: Job failed: Failed: Build failed