# file : libbuild2/build/script/parser+diag.test.testscript # license : MIT; see accompanying LICENSE file test.options += -g : name : $* test <<EOI >>EOO echo abc EOI name: test EOO : name-deduce : $* <<EOI >>EOO echo abc EOI name: echo EOO : name-operation : $* <<EOI >>EOO a = 'b' EOI name: update EOO : preamble : { : disambiguate : $* <<EOI >>~%EOO% echo abc | set v cat abc | set v diag copy >= $> cp <- $> EOI echo abc | set v cat abc | set v %diag: copy >= .+file\{driver\.\}% EOO : name : $* <<EOI >>EOO n = foo diag copy $n cp $n $> EOI diag: copy foo EOO : quoted : $* <<EOI >'diag: foo' f = foo diag "$f" EOI : quoted-eval : $* <<EOI >'diag: foo' f = foo diag "($f)" EOI : temp_dir : { test.options += -t : no : $* <<EOI >false f = foo diag $f f = $~/f foo "$f" EOI : no-depdb : $* <<EOI >false f = $~/f depdb hash "$f" diag $f f = $~/f foo "$f" EOI : yes : $* <<EOI >true f = $~/f diag $f foo $f EOI : yes-depdb : $* <<EOI >true f = $~/f depdb hash "$f" f = $~/t diag $f f = $~/f foo "$f" EOI } } : ambiguity : { : name : $* test <<EOI 2>>EOE != 0 echo abc diag xyz EOI buildfile:12:1: error: both low-verbosity script diagnostics name and 'diag' builtin call buildfile:10: info: script name specified here EOE : diag : $* <<EOI 2>>EOE != 0 echo abc diag abc cat abc diag xyz EOI buildfile:14:1: error: multiple 'diag' builtin calls buildfile:12:1: info: previous call is here EOE : names : $* <<EOI 2>>EOE != 0 cp abc xyz cat xyz EOI buildfile:11:1: error: low-verbosity script diagnostics name is ambiguous buildfile:11:1: info: could be 'cp' buildfile:12:1: info: could be 'cat' info: consider specifying it explicitly with the 'diag' recipe attribute info: or provide custom low-verbosity diagnostics with the 'diag' builtin EOE } : inside-if : $* <<EOI 2>>EOE != 0 if true diag copy >= $> fi EOI buildfile:12:3: error: 'diag' call inside flow control construct EOE : inside-if-cond : $* <<EOI 2>>EOE != 0 if diag copy >= $> true fi EOI buildfile:11:4: error: 'diag' call inside flow control construct EOE : second-command : $* <<EOI 2>>EOE != 0 true && diag copy >= $> EOI buildfile:11:9: error: 'diag' call must be the only command EOE : via-env : $* <<EOI 2>>EOE != 0 env -- diag copy >= $> EOI buildfile:11:8: error: 'diag' call via 'env' builtin EOE : before-depdb : $* <<EOI 2>>EOE != 0 diag test depdb clear EOI buildfile:11:1: error: 'diag' builtin call before 'depdb' call buildfile:12:1: info: 'depdb' call is here EOE