From 46338d109c23edaf84ca2cb4120dd5d708d8d8b5 Mon Sep 17 00:00:00 2001 From: Etienne Millon Date: Fri, 31 Aug 2018 15:04:02 +0200 Subject: [PATCH] Always display the line number in file excerpts Signed-off-by: Etienne Millon --- src/errors.ml | 15 +++++++++++---- .../test-cases/bad-alias-error/run.t | 8 ++++---- .../test-cases/dune-jbuild-var-case/run.t | 4 ++-- .../test-cases/dune-ppx-driver-system/run.t | 12 ++++++------ test/blackbox-tests/test-cases/dup-fields/run.t | 8 ++++---- .../test-cases/exclude-missing-module/run.t | 4 ++-- .../blackbox-tests/test-cases/exec-missing/run.t | 4 ++-- .../test-cases/fallback-dune/run.t | 8 ++++---- .../test-cases/findlib-error/run.t | 8 ++++---- test/blackbox-tests/test-cases/findlib/run.t | 12 ++++++------ test/blackbox-tests/test-cases/github1099/run.t | 8 ++++---- test/blackbox-tests/test-cases/github644/run.t | 4 ++-- test/blackbox-tests/test-cases/github734/run.t | 4 ++-- test/blackbox-tests/test-cases/github761/run.t | 4 ++-- test/blackbox-tests/test-cases/github784/run.t | 4 ++-- test/blackbox-tests/test-cases/github992/run.t | 8 ++++---- .../blackbox-tests/test-cases/include-loop/run.t | 4 ++-- .../blackbox-tests/test-cases/inline_tests/run.t | 8 ++++---- test/blackbox-tests/test-cases/intf-only/run.t | 12 ++++++------ .../test-cases/macro-expand-error/run.t | 4 ++-- test/blackbox-tests/test-cases/misc/run.t | 4 ++-- .../test-cases/missing-loc-run/run.t | 4 ++-- test/blackbox-tests/test-cases/multi-dir/run.t | 8 ++++---- .../test-cases/name-field-validation/run.t | 4 ++-- .../test-cases/no-name-field/run.t | 16 ++++++++-------- .../test-cases/path-variables/run.t | 12 ++++++------ .../test-cases/private-public-overlap/run.t | 8 ++++---- test/blackbox-tests/test-cases/quoting/run.t | 12 ++++++------ .../test-cases/several-packages/run.t | 4 ++-- .../test-cases/syntax-versioning/run.t | 12 ++++++------ .../test-cases/too-many-parens/run.t | 12 ++++++------ test/blackbox-tests/test-cases/variants/run.t | 4 ++-- test/blackbox-tests/test-cases/workspaces/run.t | 8 ++++---- 33 files changed, 129 insertions(+), 122 deletions(-) diff --git a/src/errors.ml b/src/errors.ml index 2a3a8061bf8..198553c307c 100644 --- a/src/errors.ml +++ b/src/errors.ml @@ -63,6 +63,9 @@ let file_lines path ~start ~stop = aux [] 1 ) +let pp_line padding_width pp (lnum, l) = + Format.fprintf pp "%*s | %s\n" padding_width lnum l + let print ppf loc = let { Loc.start; stop } = loc in let start_c = start.pos_cnum - start.pos_bol in @@ -73,11 +76,15 @@ let print ppf loc = if not whole_file then let path = Path.of_string start.pos_fname in if Path.exists path then - let line = file_line path start.pos_lnum in + let line_num = start.pos_lnum in + let line_num_str = string_of_int line_num in + let padding_width = String.length line_num_str in + let line = file_line path line_num in if stop_c <= String.length line then let len = stop_c - start_c in - Format.fprintf pp "%s\n%*s\n" line - stop_c + Format.fprintf pp "%a%*s\n" + (pp_line padding_width) (line_num_str, line) + (stop_c + padding_width + 3) (String.make len '^') else let get_padding lines = @@ -93,7 +100,7 @@ let print ppf loc = in let print_lines lines padding_width = List.iter ~f:(fun (lnum, l) -> - Format.fprintf pp "%*s | %s\n" padding_width lnum l) lines; + pp_line padding_width pp (lnum, l)) lines; in if num_lines <= max_lines_to_print_in_full then let lines = file_lines path ~start:start.pos_lnum ~stop:stop.pos_lnum in diff --git a/test/blackbox-tests/test-cases/bad-alias-error/run.t b/test/blackbox-tests/test-cases/bad-alias-error/run.t index 479fed64dac..eab87ce8b7b 100644 --- a/test/blackbox-tests/test-cases/bad-alias-error/run.t +++ b/test/blackbox-tests/test-cases/bad-alias-error/run.t @@ -1,15 +1,15 @@ $ dune runtest --root absolute-path Entering directory 'absolute-path' File "jbuild", line 3, characters 16-24: - (deps ((alias /foo/bar))))) - ^^^^^^^^ + 3 | (deps ((alias /foo/bar))))) + ^^^^^^^^ Error: Invalid alias! Tried to reference path outside build dir: "/foo/bar" [1] $ dune runtest --root outside-workspace Entering directory 'outside-workspace' File "jbuild", line 4, characters 16-39: - (deps ((alias ${ROOT}/../../../foobar))))) - ^^^^^^^^^^^^^^^^^^^^^^^ + 4 | (deps ((alias ${ROOT}/../../../foobar))))) + ^^^^^^^^^^^^^^^^^^^^^^^ Error: path outside the workspace: ./../../../foobar from default [1] diff --git a/test/blackbox-tests/test-cases/dune-jbuild-var-case/run.t b/test/blackbox-tests/test-cases/dune-jbuild-var-case/run.t index e8df058bac2..6f6a6499afc 100644 --- a/test/blackbox-tests/test-cases/dune-jbuild-var-case/run.t +++ b/test/blackbox-tests/test-cases/dune-jbuild-var-case/run.t @@ -6,8 +6,8 @@ All builtin variables are lower cased in Dune: $ dune runtest --root dune-upper Entering directory 'dune-upper' File "dune", line 3, characters 41-46: - (action (with-stdout-to %{null} (echo %{MAKE})))) - ^^^^^ + 3 | (action (with-stdout-to %{null} (echo %{MAKE})))) + ^^^^^ Error: %{MAKE} was renamed to '%{make}' in the 1.0 version of the dune language [1] diff --git a/test/blackbox-tests/test-cases/dune-ppx-driver-system/run.t b/test/blackbox-tests/test-cases/dune-ppx-driver-system/run.t index 252f732f46b..258573928f2 100644 --- a/test/blackbox-tests/test-cases/dune-ppx-driver-system/run.t +++ b/test/blackbox-tests/test-cases/dune-ppx-driver-system/run.t @@ -2,8 +2,8 @@ No ppx driver found $ dune build foo1.cma File "dune", line 6, characters 13-18: - (preprocess (pps))) - ^^^^^ + 6 | (preprocess (pps))) + ^^^^^ Error: You must specify at least one ppx rewriter. [1] @@ -11,8 +11,8 @@ Too many drivers $ dune build foo2.cma File "dune", line 13, characters 13-28: - (preprocess (pps ppx1 ppx2))) - ^^^^^^^^^^^^^^^ + 13 | (preprocess (pps ppx1 ppx2))) + ^^^^^^^^^^^^^^^ Error: Too many incompatible ppx drivers were found: foo.driver2 and foo.driver1. [1] @@ -21,8 +21,8 @@ Not compatible with Dune $ dune build foo3.cma File "dune", line 20, characters 13-28: - (preprocess (pps ppx_other))) - ^^^^^^^^^^^^^^^ + 20 | (preprocess (pps ppx_other))) + ^^^^^^^^^^^^^^^ Error: No ppx driver were found. It seems that ppx_other is not compatible with Dune. Examples of ppx rewriters that are compatible with Dune are ones using ocaml-migrate-parsetree, ppxlib or ppx_driver. diff --git a/test/blackbox-tests/test-cases/dup-fields/run.t b/test/blackbox-tests/test-cases/dup-fields/run.t index 4cb006ed1de..489639c5081 100644 --- a/test/blackbox-tests/test-cases/dup-fields/run.t +++ b/test/blackbox-tests/test-cases/dup-fields/run.t @@ -5,8 +5,8 @@ Duplicating a field in a dune file is an error: $ dune build --root dune File "dune", line 4, characters 1-20: - (action (echo bar))) - ^^^^^^^^^^^^^^^^^^^ + 4 | (action (echo bar))) + ^^^^^^^^^^^^^^^^^^^ Error: Field "action" is present too many times [1] @@ -17,8 +17,8 @@ For backward compatibility, it is only a warning in jbuild files: $ dune build --root jbuild File "jbuild", line 4, characters 2-21: - (action (echo bar)))) - ^^^^^^^^^^^^^^^^^^^ + 4 | (action (echo bar)))) + ^^^^^^^^^^^^^^^^^^^ Warning: Field "action" is present several times, previous occurrences are ignored. Entering directory 'jbuild' bar diff --git a/test/blackbox-tests/test-cases/exclude-missing-module/run.t b/test/blackbox-tests/test-cases/exclude-missing-module/run.t index a0e23431247..e884c911c79 100644 --- a/test/blackbox-tests/test-cases/exclude-missing-module/run.t +++ b/test/blackbox-tests/test-cases/exclude-missing-module/run.t @@ -1,5 +1,5 @@ $ dune build --display short File "dune", line 3, characters 22-26: - (modules :standard \ fake)) - ^^^^ + 3 | (modules :standard \ fake)) + ^^^^ Warning: Module Fake is excluded but it doesn't exist. diff --git a/test/blackbox-tests/test-cases/exec-missing/run.t b/test/blackbox-tests/test-cases/exec-missing/run.t index 5bdfe4afcef..6b26c0a40c3 100644 --- a/test/blackbox-tests/test-cases/exec-missing/run.t +++ b/test/blackbox-tests/test-cases/exec-missing/run.t @@ -2,8 +2,8 @@ When using dune exec, the external-lib-deps command refers to the executable: $ dune exec ./x.exe File "dune", line 3, characters 12-26: - (libraries does-not-exist)) - ^^^^^^^^^^^^^^ + 3 | (libraries does-not-exist)) + ^^^^^^^^^^^^^^ Error: Library "does-not-exist" not found. Hint: try: dune external-lib-deps --missing ./x.exe [1] diff --git a/test/blackbox-tests/test-cases/fallback-dune/run.t b/test/blackbox-tests/test-cases/fallback-dune/run.t index 2df5ae025bb..ecda696d324 100644 --- a/test/blackbox-tests/test-cases/fallback-dune/run.t +++ b/test/blackbox-tests/test-cases/fallback-dune/run.t @@ -2,8 +2,8 @@ fallback isn't allowed in dune $ dune build --root dune1 File "dune", line 2, characters 1-11: - (fallback) - ^^^^^^^^^^ + 2 | (fallback) + ^^^^^^^^^^ Error: 'fallback' was renamed to '(mode fallback)' in the 1.0 version of the dune language [1] @@ -11,8 +11,8 @@ fallback isn't allowed in dune $ dune build --root dune2 File "dune", line 2, characters 1-17: - (fallback false) - ^^^^^^^^^^^^^^^^ + 2 | (fallback false) + ^^^^^^^^^^^^^^^^ Error: 'fallback' was renamed to '(mode fallback)' in the 1.0 version of the dune language [1] diff --git a/test/blackbox-tests/test-cases/findlib-error/run.t b/test/blackbox-tests/test-cases/findlib-error/run.t index fff86215062..94b59a08932 100644 --- a/test/blackbox-tests/test-cases/findlib-error/run.t +++ b/test/blackbox-tests/test-cases/findlib-error/run.t @@ -3,8 +3,8 @@ We are dropping support for findlib in dune $ dune build --root in-dune target.txt Entering directory 'in-dune' File "dune", line 2, characters 25-37: - (write-file target.txt %{findlib:pkg}) - ^^^^^^^^^^^^ + 2 | (write-file target.txt %{findlib:pkg}) + ^^^^^^^^^^^^ Error: %{findlib:..} was renamed to '%{lib:..}' in the 1.0 version of the dune language [1] @@ -13,7 +13,7 @@ But it must still be available in jbuild files $ dune build --root in-jbuild target.txt Entering directory 'in-jbuild' File "jbuild", line 4, characters 23-42: - (write-file target.txt ${findlib:pkg:file}) - ^^^^^^^^^^^^^^^^^^^ + 4 | (write-file target.txt ${findlib:pkg:file}) + ^^^^^^^^^^^^^^^^^^^ Error: Public library "pkg" not found [1] diff --git a/test/blackbox-tests/test-cases/findlib/run.t b/test/blackbox-tests/test-cases/findlib/run.t index 777f0153d27..bae8d40c4d1 100644 --- a/test/blackbox-tests/test-cases/findlib/run.t +++ b/test/blackbox-tests/test-cases/findlib/run.t @@ -8,8 +8,8 @@ Reproduction case for #484. The error should point to src/jbuild $ dune build @install File "src/dune", line 4, characters 14-15: - (libraries a b c)) - ^ + 4 | (libraries a b c)) + ^ Error: Library "a" not found. Hint: try: dune external-lib-deps --missing @install [1] @@ -18,8 +18,8 @@ When passing --dev, the profile should be displayed only once (#1106): $ jbuilder build --dev @install File "src/dune", line 4, characters 14-15: - (libraries a b c)) - ^ + 4 | (libraries a b c)) + ^ Error: Library "a" not found. Hint: try: dune external-lib-deps --missing --profile dev @install [1] @@ -28,8 +28,8 @@ With dune and an explicit profile, it is the same: $ dune build --profile dev @install File "src/dune", line 4, characters 14-15: - (libraries a b c)) - ^ + 4 | (libraries a b c)) + ^ Error: Library "a" not found. Hint: try: dune external-lib-deps --missing --profile dev @install [1] diff --git a/test/blackbox-tests/test-cases/github1099/run.t b/test/blackbox-tests/test-cases/github1099/run.t index 46c72e02d58..52cec8b03ca 100644 --- a/test/blackbox-tests/test-cases/github1099/run.t +++ b/test/blackbox-tests/test-cases/github1099/run.t @@ -3,8 +3,8 @@ If the source directory does not exist, an error message is printed: $ dune build --root no-dir demo.exe Entering directory 'no-dir' File "dune", line 1, characters 13-23: - (copy_files# "no_dir/*") - ^^^^^^^^^^ + 1 | (copy_files# "no_dir/*") + ^^^^^^^^^^ Error: cannot find directory: no_dir [1] @@ -13,7 +13,7 @@ This works also is a file exists with the same name: $ dune build --root file-with-same-name demo.exe Entering directory 'file-with-same-name' File "dune", line 1, characters 13-23: - (copy_files# "no_dir/*") - ^^^^^^^^^^ + 1 | (copy_files# "no_dir/*") + ^^^^^^^^^^ Error: cannot find directory: no_dir [1] diff --git a/test/blackbox-tests/test-cases/github644/run.t b/test/blackbox-tests/test-cases/github644/run.t index 893905b3104..ebdc9f2f498 100644 --- a/test/blackbox-tests/test-cases/github644/run.t +++ b/test/blackbox-tests/test-cases/github644/run.t @@ -1,7 +1,7 @@ $ dune runtest File "jbuild", line 4, characters 20-42: - (preprocess (pps (ppx_that_doesn't_exist))))) - ^^^^^^^^^^^^^^^^^^^^^^ + 4 | (preprocess (pps (ppx_that_doesn't_exist))))) + ^^^^^^^^^^^^^^^^^^^^^^ Error: Library "ppx_that_doesn't_exist" not found. Hint: try: dune external-lib-deps --missing @runtest [1] diff --git a/test/blackbox-tests/test-cases/github734/run.t b/test/blackbox-tests/test-cases/github734/run.t index 79d246bc7c5..74fab0c6562 100644 --- a/test/blackbox-tests/test-cases/github734/run.t +++ b/test/blackbox-tests/test-cases/github734/run.t @@ -1,6 +1,6 @@ $ jbuilder build @foo File "src/dune", line 4, characters 10-17: - (c_names stubs/x)) - ^^^^^^^ + 4 | (c_names stubs/x)) + ^^^^^^^ Error: File src/stubs/x.c is not part of the current directory group. This is not allowed. [1] diff --git a/test/blackbox-tests/test-cases/github761/run.t b/test/blackbox-tests/test-cases/github761/run.t index ce087c823b2..4cf17fd888f 100644 --- a/test/blackbox-tests/test-cases/github761/run.t +++ b/test/blackbox-tests/test-cases/github761/run.t @@ -1,6 +1,6 @@ $ jbuilder build @bar File "dune", line 2, characters 7-14: - (name foo/bar) - ^^^^^^^ + 2 | (name foo/bar) + ^^^^^^^ Error: "foo/bar" is not a valid alias name [1] diff --git a/test/blackbox-tests/test-cases/github784/run.t b/test/blackbox-tests/test-cases/github784/run.t index cc1fcefdfa6..cea3dcc95c9 100644 --- a/test/blackbox-tests/test-cases/github784/run.t +++ b/test/blackbox-tests/test-cases/github784/run.t @@ -1,6 +1,6 @@ $ dune build File "dune", line 1, characters 0-28: - (rule (run %{bin:echo} foo)) - ^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + 1 | (rule (run %{bin:echo} foo)) + ^^^^^^^^^^^^^^^^^^^^^^^^^^^^ Error: Rule has no targets specified [1] diff --git a/test/blackbox-tests/test-cases/github992/run.t b/test/blackbox-tests/test-cases/github992/run.t index d59f80690cb..d8261dedd7a 100644 --- a/test/blackbox-tests/test-cases/github992/run.t +++ b/test/blackbox-tests/test-cases/github992/run.t @@ -17,13 +17,13 @@ argument of "package". $ cd package-without-pub-name && dune build -p foo File "dune", line 3, characters 1-14: - (package foo)) - ^^^^^^^^^^^^^ + 3 | (package foo)) + ^^^^^^^^^^^^^ Error: This field is useless without a (public_name ...) field. [1] $ cd package-without-pub-name-jbuild && dune build -p foo File "jbuild", line 3, characters 2-15: - (package foo))) - ^^^^^^^^^^^^^ + 3 | (package foo))) + ^^^^^^^^^^^^^ Warning: This field is useless without a (public_name ...) field. diff --git a/test/blackbox-tests/test-cases/include-loop/run.t b/test/blackbox-tests/test-cases/include-loop/run.t index 28bf251f6eb..1d2cbb829df 100644 --- a/test/blackbox-tests/test-cases/include-loop/run.t +++ b/test/blackbox-tests/test-cases/include-loop/run.t @@ -1,7 +1,7 @@ $ dune build --display short File "dune", line 1, characters 0-15: - (include a.inc) - ^^^^^^^^^^^^^^^ + 1 | (include a.inc) + ^^^^^^^^^^^^^^^ Error: Recursive inclusion of jbuild files detected: File a.inc is included from c.inc:1 --> included from b.inc:1 diff --git a/test/blackbox-tests/test-cases/inline_tests/run.t b/test/blackbox-tests/test-cases/inline_tests/run.t index 99925c5e7e6..9e4dbafd7dc 100644 --- a/test/blackbox-tests/test-cases/inline_tests/run.t +++ b/test/blackbox-tests/test-cases/inline_tests/run.t @@ -6,15 +6,15 @@ $ dune runtest missing-backend File "missing-backend/dune", line 3, characters 1-15: - (inline_tests)) - ^^^^^^^^^^^^^^ + 3 | (inline_tests)) + ^^^^^^^^^^^^^^ Error: No inline tests backend found. [1] $ dune runtest too-many-backends File "too-many-backends/dune", line 17, characters 1-15: - (inline_tests) - ^^^^^^^^^^^^^^ + 17 | (inline_tests) + ^^^^^^^^^^^^^^ Error: Too many independent inline tests backends found: - "backend_tmb1" in _build/default/too-many-backends - "backend_tmb2" in _build/default/too-many-backends diff --git a/test/blackbox-tests/test-cases/intf-only/run.t b/test/blackbox-tests/test-cases/intf-only/run.t index 7d3665c5410..7005a0e4209 100644 --- a/test/blackbox-tests/test-cases/intf-only/run.t +++ b/test/blackbox-tests/test-cases/intf-only/run.t @@ -37,8 +37,8 @@ Errors: $ dune build --display short --root b foo.cma Entering directory 'b' File "dune", line 3, characters 33-34: - (modules_without_implementation x)) - ^ + 3 | (modules_without_implementation x)) + ^ Warning: The following modules must be listed here as they don't have an implementation: - y This will become an error in the future. @@ -47,14 +47,14 @@ Errors: $ dune build --display short --root c foo.cma Entering directory 'c' File "dune", line 3, characters 33-34: - (modules_without_implementation x)) - ^ + 3 | (modules_without_implementation x)) + ^ Error: Module X doesn't exist. [1] $ dune build --display short --root d foo.cma Entering directory 'd' File "dune", line 3, characters 33-34: - (modules_without_implementation x)) - ^ + 3 | (modules_without_implementation x)) + ^ Error: Module X has an implementation, it cannot be listed here [1] diff --git a/test/blackbox-tests/test-cases/macro-expand-error/run.t b/test/blackbox-tests/test-cases/macro-expand-error/run.t index b0e7cbc886a..e98eded8923 100644 --- a/test/blackbox-tests/test-cases/macro-expand-error/run.t +++ b/test/blackbox-tests/test-cases/macro-expand-error/run.t @@ -3,7 +3,7 @@ inappropariate place: $ dune build File "dune", line 1, characters 14-21: - (copy_files %{read:x}/*) - ^^^^^^^ + 1 | (copy_files %{read:x}/*) + ^^^^^^^ Error: %{read:..} isn't allowed in this position [1] diff --git a/test/blackbox-tests/test-cases/misc/run.t b/test/blackbox-tests/test-cases/misc/run.t index 2394739443e..a98e29929da 100644 --- a/test/blackbox-tests/test-cases/misc/run.t +++ b/test/blackbox-tests/test-cases/misc/run.t @@ -1,7 +1,7 @@ $ dune runtest --display short File "dune", line 44, characters 19-42: - (deps (glob_files dir-that-doesnt-exist/*))) - ^^^^^^^^^^^^^^^^^^^^^^^ + 44 | (deps (glob_files dir-that-doesnt-exist/*))) + ^^^^^^^^^^^^^^^^^^^^^^^ Warning: Directory dir-that-doesnt-exist doesn't exist. diff alias runtest diff alias runtest diff --git a/test/blackbox-tests/test-cases/missing-loc-run/run.t b/test/blackbox-tests/test-cases/missing-loc-run/run.t index 6538a854874..cfa6cbf18fa 100644 --- a/test/blackbox-tests/test-cases/missing-loc-run/run.t +++ b/test/blackbox-tests/test-cases/missing-loc-run/run.t @@ -14,8 +14,8 @@ Path that needs to be searched: $ dune runtest --root search-path Entering directory 'search-path' File "dune", line 3, characters 14-32: - (action (run foo-does-not-exist))) - ^^^^^^^^^^^^^^^^^^ + 3 | (action (run foo-does-not-exist))) + ^^^^^^^^^^^^^^^^^^ Error: Error: Program foo-does-not-exist not found in the tree or in PATH (context: default) [1] diff --git a/test/blackbox-tests/test-cases/multi-dir/run.t b/test/blackbox-tests/test-cases/multi-dir/run.t index 5c0eab3c557..c90dc66edb1 100644 --- a/test/blackbox-tests/test-cases/multi-dir/run.t +++ b/test/blackbox-tests/test-cases/multi-dir/run.t @@ -36,16 +36,16 @@ Test some error cases $ dune build --root error2 Entering directory 'error2' File "dune", line 2, characters 0-29: - (include_subdirs unqualified) - ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + 2 | (include_subdirs unqualified) + ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ Error: The 'include_subdirs' stanza cannot appear more than once [1] $ dune build --root error3 Entering directory 'error3' File "src/gen/dune", line 1, characters 0-23: - (executable (name gen)) - ^^^^^^^^^^^^^^^^^^^^^^^ + 1 | (executable (name gen)) + ^^^^^^^^^^^^^^^^^^^^^^^ Error: This stanza is not allowed in a sub-directory of directory with (include_subdirs unqualified). Hint: add (include_subdirs no) to this file. [1] diff --git a/test/blackbox-tests/test-cases/name-field-validation/run.t b/test/blackbox-tests/test-cases/name-field-validation/run.t index 3ff02a3924a..d49159470b0 100644 --- a/test/blackbox-tests/test-cases/name-field-validation/run.t +++ b/test/blackbox-tests/test-cases/name-field-validation/run.t @@ -1,7 +1,7 @@ $ dune exec ./bar.exe File "dune", line 3, characters 7-14: - (name foo.bar) - ^^^^^^^ + 3 | (name foo.bar) + ^^^^^^^ Warning: invalid library name. Hint: library names must be non-empty and composed only of the following characters: 'A'..'Z', 'a'..'z', '_' or '0'..'9'. This is temporary allowed for libraries with (wrapped false). diff --git a/test/blackbox-tests/test-cases/no-name-field/run.t b/test/blackbox-tests/test-cases/no-name-field/run.t index 449e053d7dd..7e5984aa69b 100644 --- a/test/blackbox-tests/test-cases/no-name-field/run.t +++ b/test/blackbox-tests/test-cases/no-name-field/run.t @@ -5,8 +5,8 @@ the name field can be omitted for libraries when public_name is present this isn't possible for older syntax <= (1, 0) $ dune build --root no-name-lib-syntax-1-0 File "dune", line 1, characters 22-25: - (library (public_name foo)) - ^^^ + 1 | (library (public_name foo)) + ^^^ Error: name field cannot be omitted before version 1.1 of the dune language [1] @@ -17,8 +17,8 @@ executable(s) stanza works the same way $ dune build --root no-name-exes-syntax-1-0 File "dune", line 1, characters 0-36: - (executables (public_names foo bar)) - ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + 1 | (executables (public_names foo bar)) + ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ Error: names field may not be omitted before dune version 1.1 [1] @@ -26,8 +26,8 @@ there's only a public name but it's invalid as a name $ dune build --root public-name-invalid-name File "dune", line 1, characters 22-28: - (library (public_name c.find)) - ^^^^^^ + 1 | (library (public_name c.find)) + ^^^^^^ Error: invalid library name. Hint: library names must be non-empty and composed only of the following characters: 'A'..'Z', 'a'..'z', '_' or '0'..'9'. Public library names don't have this restriction. You can either change this public name to be a valid library name or add a "name" field with a valid library name. @@ -39,8 +39,8 @@ it's just a warning $ dune build --root public-name-invalid-wrapped-false Info: creating file dune-project with this contents: (lang dune 1.2) File "dune", line 3, characters 14-21: - (public_name foo.bar)) - ^^^^^^^ + 3 | (public_name foo.bar)) + ^^^^^^^ Error: invalid library name. Hint: library names must be non-empty and composed only of the following characters: 'A'..'Z', 'a'..'z', '_' or '0'..'9'. Public library names don't have this restriction. You can either change this public name to be a valid library name or add a "name" field with a valid library name. diff --git a/test/blackbox-tests/test-cases/path-variables/run.t b/test/blackbox-tests/test-cases/path-variables/run.t index 7ed72906e82..a84abbd3e6f 100644 --- a/test/blackbox-tests/test-cases/path-variables/run.t +++ b/test/blackbox-tests/test-cases/path-variables/run.t @@ -9,8 +9,8 @@ In expands to a file name, and registers this as a dependency. $ dune build --root dune @test-dep Entering directory 'dune' File "dune", line 13, characters 17-47: - (echo "%{path:file-that-does-not-exist}\n") - ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + 13 | (echo "%{path:file-that-does-not-exist}\n") + ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ Error: %{path:..} was renamed to '%{dep:..}' in the 1.0 version of the dune language [1] @@ -22,8 +22,8 @@ This form does not exist, but displays an hint: $ dune build --root dune-invalid @test-path-no-dep Entering directory 'dune-invalid' File "dune", line 7, characters 17-54: - (echo "%{path-no-dep:file-that-does-not-exist}\n") - ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + 7 | (echo "%{path-no-dep:file-that-does-not-exist}\n") + ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ Error: %{path-no-dep:..} was deleted in version 1.0 of the dune language [1] @@ -57,7 +57,7 @@ This form does not exist, but displays an hint: $ dune build --root jbuild-invalid @test-dep Entering directory 'jbuild-invalid' File "jbuild", line 5, characters 16-37: - (action (cat ${dep:generated-file})))) - ^^^^^^^^^^^^^^^^^^^^^ + 5 | (action (cat ${dep:generated-file})))) + ^^^^^^^^^^^^^^^^^^^^^ Error: ${dep:..} is only available since version 1.0 of the dune language [1] diff --git a/test/blackbox-tests/test-cases/private-public-overlap/run.t b/test/blackbox-tests/test-cases/private-public-overlap/run.t index 00f349637d7..626f5965f69 100644 --- a/test/blackbox-tests/test-cases/private-public-overlap/run.t +++ b/test/blackbox-tests/test-cases/private-public-overlap/run.t @@ -3,8 +3,8 @@ public libraries may not have private dependencies $ dune build --display short --root private-dep Entering directory 'private-dep' File "dune", line 8, characters 12-22: - (libraries privatelib) - ^^^^^^^^^^ + 8 | (libraries privatelib) + ^^^^^^^^^^ Error: Library "privatelib" is private, it cannot be a dependency of a public library. You need to give "privatelib" a public name. ocamldep .publiclib.objs/publiclib.ml.d @@ -29,8 +29,8 @@ Unless they introduce private runtime dependencies: $ dune build --display short --root private-runtime-deps Entering directory 'private-runtime-deps' File "jbuild", line 16, characters 20-31: - (preprocess (pps (private_ppx))) - ^^^^^^^^^^^ + 16 | (preprocess (pps (private_ppx))) + ^^^^^^^^^^^ Error: Library "private_runtime_dep" is private, it cannot be a dependency of a public library. You need to give "private_runtime_dep" a public name. ocamlc .private_ppx.objs/private_ppx.{cmi,cmo,cmt} diff --git a/test/blackbox-tests/test-cases/quoting/run.t b/test/blackbox-tests/test-cases/quoting/run.t index 4f22dd1c470..ab51996799c 100644 --- a/test/blackbox-tests/test-cases/quoting/run.t +++ b/test/blackbox-tests/test-cases/quoting/run.t @@ -4,8 +4,8 @@ that ${@} is not quoted and doesn't contain exactly 1 element $ dune build --root bad x Entering directory 'bad' File "dune", line 3, characters 27-35: - (action (with-stdout-to %{targets} (echo foo)))) - ^^^^^^^^ + 3 | (action (with-stdout-to %{targets} (echo foo)))) + ^^^^^^^^ Error: Variable %{targets} expands to 2 values, however a single value is expected here. Please quote this atom. [1] @@ -29,14 +29,14 @@ The targets should only be interpreted as a single path when quoted $ dune build @quoted --root filename-space File "dune", line 4, characters 17-18: - (action (echo %{read:foo bar.txt}))) - ^ + 4 | (action (echo %{read:foo bar.txt}))) + ^ Error: This character is not allowed inside %{...} forms [1] $ dune build @unquoted --root filename-space File "dune", line 4, characters 17-18: - (action (echo %{read:foo bar.txt}))) - ^ + 4 | (action (echo %{read:foo bar.txt}))) + ^ Error: This character is not allowed inside %{...} forms [1] diff --git a/test/blackbox-tests/test-cases/several-packages/run.t b/test/blackbox-tests/test-cases/several-packages/run.t index 1a5558a5711..6754f6485ea 100644 --- a/test/blackbox-tests/test-cases/several-packages/run.t +++ b/test/blackbox-tests/test-cases/several-packages/run.t @@ -19,8 +19,8 @@ displayed. This can happen for: $ dune build --root documentation File "dune", line 1, characters 0-15: - (documentation) - ^^^^^^^^^^^^^^^ + 1 | (documentation) + ^^^^^^^^^^^^^^^ Error: I can't determine automatically which package this stanza is for. I have the choice between these ones: - pkg1 (because of pkg1.opam) diff --git a/test/blackbox-tests/test-cases/syntax-versioning/run.t b/test/blackbox-tests/test-cases/syntax-versioning/run.t index 5d610a57f46..b720ec6369d 100644 --- a/test/blackbox-tests/test-cases/syntax-versioning/run.t +++ b/test/blackbox-tests/test-cases/syntax-versioning/run.t @@ -1,8 +1,8 @@ $ echo '(jbuild_version 1)' > dune $ dune build File "dune", line 1, characters 0-18: - (jbuild_version 1) - ^^^^^^^^^^^^^^^^^^ + 1 | (jbuild_version 1) + ^^^^^^^^^^^^^^^^^^ Error: 'jbuild_version' was deleted in version 1.0 of the dune language [1] $ rm -f dune @@ -14,8 +14,8 @@ $ echo '(executable (name x) (link_executables false))' > dune $ dune build File "dune", line 1, characters 21-45: - (executable (name x) (link_executables false)) - ^^^^^^^^^^^^^^^^^^^^^^^^ + 1 | (executable (name x) (link_executables false)) + ^^^^^^^^^^^^^^^^^^^^^^^^ Error: 'link_executables' was deleted in version 1.0 of the dune language [1] $ rm -f dune @@ -23,8 +23,8 @@ $ echo '(alias (name x) (deps x) (action (run %{<})))' > dune $ dune build File "dune", line 1, characters 40-42: - (alias (name x) (deps x) (action (run %{<}))) - ^^ + 1 | (alias (name x) (deps x) (action (run %{<}))) + ^^ Error: %{<} was deleted in version 1.0 of the dune language. Use a named dependency instead: diff --git a/test/blackbox-tests/test-cases/too-many-parens/run.t b/test/blackbox-tests/test-cases/too-many-parens/run.t index ddf1f7a3909..5c9e162ace6 100644 --- a/test/blackbox-tests/test-cases/too-many-parens/run.t +++ b/test/blackbox-tests/test-cases/too-many-parens/run.t @@ -15,8 +15,8 @@ are readable. $ dune build --root b File "dune", line 4, characters 12-17: - (libraries (lib))) - ^^^^^ + 4 | (libraries (lib))) + ^^^^^ Error: 'select' expected Hint: dune files require less parentheses than jbuild files. If you just converted this file from a jbuild file, try removing these parentheses. @@ -24,8 +24,8 @@ are readable. $ dune build --root c File "dune", line 3, characters 7-14: - (deps (x y z))) - ^^^^^^^ + 3 | (deps (x y z))) + ^^^^^^^ Error: Unknown constructor x Hint: dune files require less parentheses than jbuild files. If you just converted this file from a jbuild file, try removing these parentheses. @@ -50,8 +50,8 @@ When the inner syntax is wrong, do not warn about the parens: $ dune build --root e File "dune", line 3, characters 7-15: - (deps (glob *)) ; this form doesn't exist - ^^^^^^^^ + 3 | (deps (glob *)) ; this form doesn't exist + ^^^^^^^^ Error: Unknown constructor glob Hint: dune files require less parentheses than jbuild files. If you just converted this file from a jbuild file, try removing these parentheses. diff --git a/test/blackbox-tests/test-cases/variants/run.t b/test/blackbox-tests/test-cases/variants/run.t index 17f3376f436..ddab869341e 100644 --- a/test/blackbox-tests/test-cases/variants/run.t +++ b/test/blackbox-tests/test-cases/variants/run.t @@ -2,8 +2,8 @@ Variant feature is auto enabled when virtual_modules is used $ dune build --root variants-without-using File "dune", line 3, characters 1-25: - (virtual_modules foobar)) - ^^^^^^^^^^^^^^^^^^^^^^^^ + 3 | (virtual_modules foobar)) + ^^^^^^^^^^^^^^^^^^^^^^^^ Error: 'virtual_modules' is only available since version 0.1 of the experimental variants feature [1] diff --git a/test/blackbox-tests/test-cases/workspaces/run.t b/test/blackbox-tests/test-cases/workspaces/run.t index af9e9535855..76839264f01 100644 --- a/test/blackbox-tests/test-cases/workspaces/run.t +++ b/test/blackbox-tests/test-cases/workspaces/run.t @@ -2,8 +2,8 @@ jbuild still discovers workspaces as usual $ jbuilder build --root jbuilder-default-name File "jbuild-workspace", line 1, characters 10-24: - (context (does-not-exist)) - ^^^^^^^^^^^^^^ + 1 | (context (does-not-exist)) + ^^^^^^^^^^^^^^ Error: Unknown constructor does-not-exist [1] @@ -16,8 +16,8 @@ dune uses a versioned file. If the version is missing, then we get an error. $ dune build --root dune-no-version File "dune-workspace", line 1, characters 0-19: - (context (default)) - ^^^^^^^^^^^^^^^^^^^ + 1 | (context (default)) + ^^^^^^^^^^^^^^^^^^^ Error: Invalid first line, expected: (lang ) [1]