diff --git a/src/dune_rules/preprocess.ml b/src/dune_rules/preprocess.ml index b399384fbac..ae38e43e45e 100644 --- a/src/dune_rules/preprocess.ml +++ b/src/dune_rules/preprocess.ml @@ -16,7 +16,8 @@ module Pps_and_flags = struct ( String_with_vars.is_prefix ~prefix:"-" s , String_with_vars.is_prefix ~prefix:"+" s ) with - | Yes, _ | _, Yes -> Right s + | Yes, _ -> Right s + | _, Yes when syntax_version >= (3, 18) -> Right s | (No | Unknown _), _ -> let loc = String_with_vars.loc s in (match String_with_vars.text_only s with diff --git a/test/blackbox-tests/test-cases/ppx/ppx-flags-plus.t b/test/blackbox-tests/test-cases/ppx/ppx-flags-plus.t index 35d8257e028..c57e8425aee 100644 --- a/test/blackbox-tests/test-cases/ppx/ppx-flags-plus.t +++ b/test/blackbox-tests/test-cases/ppx/ppx-flags-plus.t @@ -33,3 +33,17 @@ Create ppx1 and exe: $ touch the_exe.ml $ dune build ./the_exe.exe + File "dune", line 9, characters 30-35: + 9 | (preprocess (pps ppx --alert ++foo))) + ^^^^^ + Error: Library "++foo" not found. + -> required by _build/default/.merlin-conf/exe-the_exe + -> required by _build/default/the_exe.exe + [1] + +Works since Dune 3.18 + + $ cat > dune-project < (lang dune 3.18) + > EOF + $ dune build ./the_exe.exe