| ; Throughout this file, where %{pre}=FOO, FileCheck prefixes are as follows to |
| ; indicate the level of FileCheck verbosity under test: |
| ; - FOO = quiet, -v, or -vv |
| ; - FOO-V = -v or -vv (-vv implies -v) |
| ; - FOO-VV = -vv |
| ; - FOO-Q = quiet only |
| ; - FOO-VQ = -v only |
| ; |
| ; Most cases use just FOO, FOO-V, and FOO-VV in a unified block of directives |
| ; that checks an input dump where some annotations are omitted at lower |
| ; verbosity levels. |
| ; |
| ; For a few cases, multiple annotations persist but *change* across verbosity |
| ; levels, usually due to modified annotation labels. Seeing multiple versions |
| ; of the same annotation in the same block of directives can be confusing. To |
| ; improve readability, it is usually best to split these into separate blocks. |
| ; For example, use FOO-Q to check only the version without -v or -vv. |
| |
| ; DEFINE: %{pre} = |
| ; DEFINE: %{opts} = |
| ; |
| ; DEFINE: %{run-fc} = \ |
| ; DEFINE: %ProtectFileCheckOutput \ |
| ; DEFINE: FileCheck -dump-input=always -input-file=%t.in %t.chk \ |
| ; DEFINE: -dump-input-label-width=15 %{opts} |
| ; |
| ; DEFINE: %{check-fc} = \ |
| ; DEFINE: FileCheck -strict-whitespace -match-full-lines %s \ |
| ; DEFINE: -allow-unused-prefixes \ |
| ; DEFINE: -implicit-check-not='remark:' -implicit-check-not='error:' |
| ; |
| ; For each case, it is usually best to run these in order of decreasing |
| ; verbosity to maximize the information for debugging when the case is broken. |
| ; |
| ; DEFINE: %{run-vv} = %{run-fc} -vv 2>&1 | \ |
| ; DEFINE: %{check-fc} -check-prefixes=%{pre},%{pre}-V,%{pre}-VV |
| ; DEFINE: %{run-v} = %{run-fc} -v 2>&1 | \ |
| ; DEFINE: %{check-fc} -check-prefixes=%{pre},%{pre}-V,%{pre}-VQ |
| ; DEFINE: %{run} = %{run-fc} 2>&1 | \ |
| ; DEFINE: %{check-fc} -check-prefixes=%{pre},%{pre}-Q |
| |
| ;-------------------------------------------------- |
| ; Label column width |
| ; |
| ; Check that the label column width is sane when we do not force a minimum. The |
| ; rest of the test file is easier to maintain if we otherwise always force it |
| ; because that avoids the possibility of it fluctuating across different |
| ; verbosity levels. |
| ;-------------------------------------------------- |
| |
| ; Check with both the annotation label and the line number fairly short. |
| ; |
| ; RUN: echo 'hello world' > %t.in |
| ; RUN: echo 'CHECK: hello world' > %t.chk |
| ; |
| ; REDEFINE: %{opts} = -dump-input-label-width=0 |
| ; REDEFINE: %{pre} = WIDTH-SHORT |
| ; RUN: %{run-v} |
| ; |
| ; WIDTH-SHORT:<<<<<< |
| ; WIDTH-SHORT-NEXT: 1: hello world |
| ; WIDTH-SHORT-NEXT:check:1 ^~~~~~~~~~~ |
| ; WIDTH-SHORT-NEXT:>>>>>> |
| ; WIDTH-SHORT-NOT:{{.}} |
| |
| ; Check that lengthening the annotation label widens the column. |
| ; |
| ; RUN: echo 'hello world' > %t.in |
| ; RUN: echo 'hello world' >> %t.in |
| ; RUN: echo 'CHECK-COUNT-2: hello world' > %t.chk |
| ; |
| ; REDEFINE: %{opts} = -dump-input-label-width=0 |
| ; REDEFINE: %{pre} = WIDTH-ANNOT |
| ; RUN: %{run-v} |
| ; |
| ; WIDTH-ANNOT:<<<<<< |
| ; WIDTH-ANNOT-NEXT: 1: hello world |
| ; WIDTH-ANNOT-NEXT:count:1'0 ^~~~~~~~~~~ |
| ; WIDTH-ANNOT-NEXT: 2: hello world |
| ; WIDTH-ANNOT-NEXT:count:1'1 ^~~~~~~~~~~ |
| ; WIDTH-ANNOT-NEXT:>>>>>> |
| ; WIDTH-ANNOT-NOT:{{.}} |
| |
| ; Check that a longer line number (6 characters) than annotation label (5 |
| ; characters) widens the column. |
| ; |
| ; RUN: %python -c 'print("x\n" * 10**5, end="")' > %t.in |
| ; RUN: echo 'the end' >> %t.in |
| ; RUN: echo 'CHECK-DAG: the end' > %t.chk |
| ; |
| ; REDEFINE: %{opts} = -dump-input-label-width=0 -dump-input-filter=annotation \ |
| ; REDEFINE: -dump-input-context=3 |
| ; REDEFINE: %{pre} = WIDTH-LINENO |
| ; RUN: %{run-v} |
| ; |
| ; WIDTH-LINENO:<<<<<< |
| ; WIDTH-LINENO-NEXT: . |
| ; WIDTH-LINENO-NEXT: . |
| ; WIDTH-LINENO-NEXT: . |
| ; WIDTH-LINENO-NEXT: 99998: x |
| ; WIDTH-LINENO-NEXT: 99999: x |
| ; WIDTH-LINENO-NEXT: 100000: x |
| ; WIDTH-LINENO-NEXT: 100001: the end |
| ; WIDTH-LINENO-NEXT:dag:1 ^~~~~~~ |
| ; WIDTH-LINENO-NEXT:>>>>>> |
| ; WIDTH-LINENO-NOT:{{.}} |
| |
| ; REDEFINE: %{opts} = |
| |
| ;-------------------------------------------------- |
| ; CHECK (also: multi-line search range, fuzzy match) |
| ;-------------------------------------------------- |
| |
| ; Good match and no match. |
| |
| ; RUN: echo 'hello' > %t.in |
| ; RUN: echo 'again' >> %t.in |
| ; RUN: echo 'whirled' >> %t.in |
| |
| ; RUN: echo 'CHECK: hello' > %t.chk |
| ; RUN: echo 'CHECK: world' >> %t.chk |
| |
| ; REDEFINE: %{pre} = CHK |
| ; RUN: not %{run-vv} |
| ; RUN: not %{run-v} |
| ; RUN: not %{run} |
| |
| ; Verbose diagnostics are suppressed but not errors. |
| ; CHK:{{.*}}error:{{.*}} |
| ; CHK:{{.*}}possible intended match here{{.*}} |
| |
| ; CHK:<<<<<< |
| ; CHK-NEXT: 1: hello |
| ; CHK-V-NEXT:check:1 ^~~~~ |
| ; CHK-NEXT:check:2'0 X error: no match found |
| ; CHK-NEXT: 2: again |
| ; CHK-NEXT:check:2'0 ~~~~~~ |
| ; CHK-NEXT: 3: whirled |
| ; CHK-NEXT:check:2'0 ~~~~~~~~ |
| ; CHK-NEXT:check:2'1 ? possible intended match |
| ; CHK-NEXT:>>>>>> |
| ; CHK-NOT:{{.}} |
| |
| ;-------------------------------------------------- |
| ; CHECK-COUNT-<num> |
| ;-------------------------------------------------- |
| |
| ; Good match and no match. |
| |
| ; RUN: echo 'pete' > %t.in |
| ; RUN: echo 'repete' >> %t.in |
| ; RUN: echo 'repeat' >> %t.in |
| |
| ; RUN: echo 'CHECK-COUNT-3: pete' > %t.chk |
| |
| ; REDEFINE: %{pre} = CNT |
| ; RUN: not %{run-vv} |
| ; RUN: not %{run-v} |
| ; RUN: not %{run} |
| |
| ; Verbose diagnostics are suppressed but not errors. |
| ; CNT:{{.*}}error:{{.*}} |
| |
| ; CNT-V:<<<<<< |
| ; CNT-V-NEXT: 1: pete |
| ; CNT-V-NEXT:count:1'0 ^~~~ |
| ; CNT-V-NEXT: 2: repete |
| ; CNT-V-NEXT:count:1'1 ^~~~ |
| ; CNT-V-NEXT:count:1'2 X error: no match found |
| ; CNT-V-NEXT: 3: repeat |
| ; CNT-V-NEXT:count:1'2 ~~~~~~~ |
| ; CNT-V-NEXT:count:1'3 ? possible intended match |
| ; CNT-V-NEXT:>>>>>> |
| ; CNT-V-NOT:{{.}} |
| |
| ; CNT-Q:<<<<<< |
| ; CNT-Q-NEXT: 1: pete |
| ; CNT-Q-NEXT: 2: repete |
| ; CNT-Q-NEXT:count:1'0 X error: no match found |
| ; CNT-Q-NEXT: 3: repeat |
| ; CNT-Q-NEXT:count:1'0 ~~~~~~~ |
| ; CNT-Q-NEXT:count:1'1 ? possible intended match |
| ; CNT-Q-NEXT:>>>>>> |
| ; CNT-Q-NOT:{{.}} |
| |
| ;-------------------------------------------------- |
| ; CHECK-NEXT (also: EOF search-range, wrong-line match) |
| ;-------------------------------------------------- |
| |
| ; Good match and no match. |
| |
| ; RUN: echo 'hello' > %t.in |
| ; RUN: echo 'again' >> %t.in |
| |
| ; RUN: echo 'CHECK: hello' > %t.chk |
| ; RUN: echo 'CHECK-NEXT: again' >> %t.chk |
| ; RUN: echo 'CHECK-NEXT: world' >> %t.chk |
| |
| ; REDEFINE: %{pre} = NXT |
| ; RUN: not %{run-vv} |
| ; RUN: not %{run-v} |
| ; RUN: not %{run} |
| |
| ; Verbose diagnostics are suppressed but not errors. |
| ; NXT:{{.*}}error:{{.*}} |
| |
| ; NXT:<<<<<< |
| ; NXT-NEXT: 1: hello |
| ; NXT-V-NEXT:check:1 ^~~~~ |
| ; NXT-NEXT: 2: again |
| ; NXT-V-NEXT:next:2 ^~~~~ |
| ; NXT-NEXT:next:3 X error: no match found |
| ; NXT-NEXT:>>>>>> |
| ; NXT-NOT:{{.}} |
| |
| ; Wrong-line match. |
| |
| ; RUN: echo 'yonder' >> %t.in |
| ; RUN: echo 'world' >> %t.in |
| |
| ; REDEFINE: %{pre} = NXT2 |
| ; RUN: not %{run-vv} |
| ; RUN: not %{run-v} |
| ; RUN: not %{run} |
| |
| ; Verbose diagnostics are suppressed but not errors. |
| ; NXT2:{{.*}}error:{{.*}} |
| |
| ; NXT2:<<<<<< |
| ; NXT2-NEXT: 1: hello |
| ; NXT2-V-NEXT:check:1 ^~~~~ |
| ; NXT2-NEXT: 2: again |
| ; NXT2-V-NEXT:next:2 ^~~~~ |
| ; NXT2-NEXT: 3: yonder |
| ; NXT2-NEXT: 4: world |
| ; NXT2-NEXT:next:3 !~~~~ error: match on wrong line |
| ; NXT2-NEXT:>>>>>> |
| ; NXT2-NOT:{{.}} |
| |
| ;-------------------------------------------------- |
| ; CHECK-SAME (also: multiple annotations per line, single-char search range, |
| ; wrong-line match) |
| ;-------------------------------------------------- |
| |
| ; Good match and no match. |
| |
| ; RUN: echo 'hello world!' > %t.in |
| |
| ; RUN: echo 'CHECK: hello' > %t.chk |
| ; RUN: echo 'CHECK-SAME: world' >> %t.chk |
| ; RUN: echo 'CHECK-SAME: again' >> %t.chk |
| |
| ; REDEFINE: %{pre} = SAM |
| ; RUN: not %{run-vv} |
| ; RUN: not %{run-v} |
| ; RUN: not %{run} |
| |
| ; Verbose diagnostics are suppressed but not errors. |
| ; SAM:{{.*}}error:{{.*}} |
| |
| ; SAM:<<<<<< |
| ; SAM-NEXT: 1: hello world! |
| ; SAM-V-NEXT:check:1 ^~~~~ |
| ; SAM-V-NEXT:same:2 ^~~~~ |
| ; SAM-NEXT:same:3 X~ error: no match found |
| ; SAM-NEXT:>>>>>> |
| ; SAM-NOT:{{.}} |
| |
| ; Wrong-line match. |
| |
| ; RUN: echo 'again' >> %t.in |
| |
| ; REDEFINE: %{pre} = SAM2 |
| ; RUN: not %{run-vv} |
| ; RUN: not %{run-v} |
| ; RUN: not %{run} |
| |
| ; Verbose diagnostics are suppressed but not errors. |
| ; SAM2:{{.*}}error:{{.*}} |
| |
| ; SAM2:<<<<<< |
| ; SAM2-NEXT: 1: hello world! |
| ; SAM2-V-NEXT:check:1 ^~~~~ |
| ; SAM2-V-NEXT:same:2 ^~~~~ |
| ; SAM2-NEXT: 2: again |
| ; SAM2-NEXT:same:3 !~~~~ error: match on wrong line |
| ; SAM2-NEXT:>>>>>> |
| ; SAM2-NOT:{{.}} |
| |
| ;-------------------------------------------------- |
| ; CHECK-EMPTY (also: search range ends at label, single-char match, wrong-line |
| ; match) |
| ;-------------------------------------------------- |
| |
| ; Good match and no match. |
| ; |
| ; CHECK-EMPTY always seems to match an empty line at EOF (illegally when it's |
| ; not the next line) unless either (1) the last line is non-empty and has no |
| ; newline or (2) there's a CHECK-LABEL to end the search range before EOF. We |
| ; choose scenario 2 to check the case of no match. |
| |
| ; RUN: echo 'hello' > %t.in |
| ; RUN: echo '' >> %t.in |
| ; RUN: echo 'world' >> %t.in |
| ; RUN: echo 'label' >> %t.in |
| |
| ; RUN: echo 'CHECK: hello' > %t.chk |
| ; RUN: echo 'CHECK-EMPTY:' >> %t.chk |
| ; RUN: echo 'CHECK-EMPTY:' >> %t.chk |
| ; RUN: echo 'CHECK-LABEL: label' >> %t.chk |
| |
| ; REDEFINE: %{pre} = EMP |
| ; RUN: not %{run-vv} |
| ; RUN: not %{run-v} |
| ; RUN: not %{run} |
| |
| ; Verbose diagnostics are suppressed but not errors. |
| ; EMP:{{.*}}error:{{.*}} |
| |
| ; EMP:<<<<<< |
| ; EMP-NEXT: 1: hello |
| ; EMP-V-NEXT:check:1 ^~~~~ |
| ; EMP-NEXT: 2: |
| ; EMP-V-NEXT:empty:2 ^ |
| ; EMP-NEXT:empty:3 X error: no match found |
| ; EMP-NEXT: 3: world |
| ; EMP-NEXT:empty:3 ~~~~~~ |
| ; EMP-NEXT: 4: label |
| ; EMP-V-NEXT:label:4 ^~~~~ |
| ; EMP-NEXT:empty:3 ~~~~~ |
| ; EMP-NEXT:>>>>>> |
| ; EMP-NOT:{{.}} |
| |
| ; Wrong-line match. |
| |
| ; RUN: echo 'hello' > %t.in |
| ; RUN: echo 'world' >> %t.in |
| |
| ; RUN: echo 'CHECK: hello' > %t.chk |
| ; RUN: echo 'CHECK-EMPTY:' >> %t.chk |
| |
| ; REDEFINE: %{pre} = EMP2 |
| ; RUN: not %{run-vv} |
| ; RUN: not %{run-v} |
| ; RUN: not %{run} |
| |
| ; Verbose diagnostics are suppressed but not errors. |
| ; EMP2:{{.*}}error:{{.*}} |
| |
| ; EMP2:<<<<<< |
| ; EMP2-NEXT: 1: hello |
| ; EMP2-V-NEXT:check:1 ^~~~~ |
| ; EMP2-NEXT: 2: world |
| ; EMP2-NEXT: 3: |
| ; EMP2-NEXT:empty:2 ! error: match on wrong line |
| ; EMP2-NEXT:>>>>>> |
| ; EMP2-NOT:{{.}} |
| |
| ;-------------------------------------------------- |
| ; CHECK-NOT (also: EOF pattern, and multiline range that ends before EOL) |
| ;-------------------------------------------------- |
| |
| ; No match (success) and unexpected match (error). |
| |
| ; RUN: echo 'hello' > %t.in |
| ; RUN: echo 'world' >> %t.in |
| ; RUN: echo 'again' >> %t.in |
| |
| ; RUN: echo 'CHECK-NOT: goodbye' > %t.chk |
| ; RUN: echo 'CHECK-NOT: world' >> %t.chk |
| |
| ; REDEFINE: %{pre} = NOT |
| ; RUN: not %{run-vv} |
| ; RUN: not %{run-v} |
| ; RUN: not %{run} |
| |
| ; Verbose diagnostics are suppressed but not errors. |
| ; NOT:{{.*}}error:{{.*}} |
| |
| ; NOT:<<<<<< |
| ; NOT-NEXT: 1: hello |
| ; NOT-VV-NEXT:not:1 X~~~~~ |
| ; NOT-NEXT: 2: world |
| ; NOT-VV-NEXT:not:1 ~~~~~~ |
| ; NOT-NEXT:not:2 !~~~~ error: no match expected |
| ; NOT-NEXT: 3: again |
| ; NOT-VV-NEXT:not:1 ~~~~~~ |
| ; NOT-VV-NEXT: 4: |
| ; NOT-VV-NEXT:eof:2 ^ |
| ; NOT-NEXT:>>>>>> |
| ; NOT-NOT:{{.}} |
| |
| ; Again, but with a CHECK instead of EOF as search range end. |
| |
| ; RUN: echo 'CHECK: ain' >> %t.chk |
| |
| ; REDEFINE: %{pre} = NOT2 |
| ; RUN: not %{run-vv} |
| ; RUN: not %{run-v} |
| ; RUN: not %{run} |
| |
| ; Verbose diagnostics are suppressed but not errors. |
| ; NOT2:{{.*}}error:{{.*}} |
| |
| ; NOT2:<<<<<< |
| ; NOT2-NEXT: 1: hello |
| ; NOT2-VV-NEXT:not:1 X~~~~~ |
| ; NOT2-NEXT: 2: world |
| ; NOT2-VV-NEXT:not:1 ~~~~~~ |
| ; NOT2-NEXT:not:2 !~~~~ error: no match expected |
| ; NOT2-NEXT: 3: again |
| ; NOT2-V-NEXT:check:3 ^~~ |
| ; NOT2-VV-NEXT:not:1 ~~ |
| ; NOT2-NEXT:>>>>>> |
| ; NOT2-NOT:{{.}} |
| |
| ;-------------------------------------------------- |
| ; CHECK-DAG (also: matches in different order than directives, discarded match) |
| ;-------------------------------------------------- |
| |
| ; Good match, discarded match plus good match, and no match. |
| |
| ; RUN: echo 'abc' > %t.in |
| ; RUN: echo 'def' >> %t.in |
| ; RUN: echo 'abc' >> %t.in |
| |
| ; RUN: echo 'CHECK-DAG: def' > %t.chk |
| ; RUN: echo 'CHECK-DAG: abc' >> %t.chk |
| ; RUN: echo 'CHECK-DAG: abc' >> %t.chk |
| ; RUN: echo 'CHECK-DAG: def' >> %t.chk |
| |
| ; REDEFINE: %{pre} = DAG |
| ; RUN: not %{run-vv} |
| ; RUN: not %{run-v} |
| ; RUN: not %{run} |
| |
| ; Verbose diagnostics are suppressed but not errors. |
| ; DAG:{{.*}}error:{{.*}} |
| |
| ; DAG-VV:<<<<<< |
| ; DAG-VV-NEXT: 1: abc |
| ; DAG-VV-NEXT:dag:2 ^~~ |
| ; DAG-VV-NEXT:dag:3'0 !~~ discard: overlaps earlier match |
| ; DAG-VV-NEXT: 2: def |
| ; DAG-VV-NEXT:dag:1 ^~~ |
| ; DAG-VV-NEXT:dag:4'0 !~~ discard: overlaps earlier match |
| ; DAG-VV-NEXT:dag:4'1 X error: no match found |
| ; DAG-VV-NEXT: 3: abc |
| ; DAG-VV-NEXT:dag:3'1 ^~~ |
| ; DAG-VV-NEXT:dag:4'1 ~~~~ |
| ; DAG-VV-NEXT:>>>>>> |
| ; DAG-VV-NOT:{{.}} |
| |
| ; DAG-VQ:<<<<<< |
| ; DAG-VQ-NEXT: 1: abc |
| ; DAG-VQ-NEXT:dag:2 ^~~ |
| ; DAG-VQ-NEXT: 2: def |
| ; DAG-VQ-NEXT:dag:1 ^~~ |
| ; DAG-VQ-NEXT:dag:4 X error: no match found |
| ; DAG-VQ-NEXT: 3: abc |
| ; DAG-VQ-NEXT:dag:3 ^~~ |
| ; DAG-VQ-NEXT:dag:4 ~~~~ |
| ; DAG-VQ-NEXT:>>>>>> |
| ; DAG-VQ-NOT:{{.}} |
| |
| ; DAG-Q:<<<<<< |
| ; DAG-Q-NEXT: 1: abc |
| ; DAG-Q-NEXT: 2: def |
| ; DAG-Q-NEXT:dag:4 X error: no match found |
| ; DAG-Q-NEXT: 3: abc |
| ; DAG-Q-NEXT:dag:4 ~~~~ |
| ; DAG-Q-NEXT:>>>>>> |
| ; DAG-Q-NOT:{{.}} |
| |
| ; Check sorting of annotations when the order of diagnostics across an input |
| ; line is different than the order of the associated directives in the check |
| ; file. Try cases when diagnostics' input ranges overlap but are not |
| ; identical to check how that affects sorting. |
| |
| ; RUN: echo 'abc def abc def' > %t.in |
| |
| ; RUN: echo 'CHECK-DAG: def' > %t.chk |
| ; RUN: echo 'CHECK-DAG: bc' >> %t.chk |
| ; RUN: echo 'CHECK-DAG: abc' >> %t.chk |
| ; RUN: echo 'CHECK-DAG: de' >> %t.chk |
| ; RUN: echo 'CHECK-DAG: def' >> %t.chk |
| |
| ; REDEFINE: %{pre} = DAG1L |
| ; RUN: not %{run-vv} |
| ; RUN: not %{run-v} |
| ; RUN: not %{run} |
| |
| ; Verbose diagnostics are suppressed but not errors. |
| ; DAG1L:{{.*}}error:{{.*}} |
| |
| ; DAG1L-VV:<<<<<< |
| ; DAG1L-VV-NEXT: 1: abc def abc def |
| ; DAG1L-VV-NEXT:dag:1 ^~~ |
| ; DAG1L-VV-NEXT:dag:2 ^~ |
| ; DAG1L-VV-NEXT:dag:3'0 !~~ discard: overlaps earlier match |
| ; DAG1L-VV-NEXT:dag:3'1 ^~~ |
| ; DAG1L-VV-NEXT:dag:4'0 !~ discard: overlaps earlier match |
| ; DAG1L-VV-NEXT:dag:4'1 ^~ |
| ; DAG1L-VV-NEXT:dag:5'0 !~~ discard: overlaps earlier match |
| ; DAG1L-VV-NEXT:dag:5'1 !~~ discard: overlaps earlier match |
| ; DAG1L-VV-NEXT:dag:5'2 X~ error: no match found |
| ; DAG1L-VV-NEXT:>>>>>> |
| ; DAG1L-VV-NOT:{{.}} |
| |
| ; DAG1L-VQ:<<<<<< |
| ; DAG1L-VQ-NEXT: 1: abc def abc def |
| ; DAG1L-VQ-NEXT:dag:1 ^~~ |
| ; DAG1L-VQ-NEXT:dag:2 ^~ |
| ; DAG1L-VQ-NEXT:dag:3 ^~~ |
| ; DAG1L-VQ-NEXT:dag:4 ^~ |
| ; DAG1L-VQ-NEXT:dag:5 X~ error: no match found |
| ; DAG1L-VQ-NEXT:>>>>>> |
| ; DAG1L-VQ-NOT:{{.}} |
| |
| ; DAG1L-Q:<<<<<< |
| ; DAG1L-Q-NEXT: 1: abc def abc def |
| ; DAG1L-Q-NEXT:dag:5 X~ error: no match found |
| ; DAG1L-Q-NEXT:>>>>>> |
| ; DAG1L-Q-NOT:{{.}} |
| |
| ;-------------------------------------------------- |
| ; CHECK-LABEL |
| ; |
| ; Each CHECK-LABEL is processed twice: once before other patterns in the |
| ; preceding section, and once afterward. |
| ; |
| ; As expected, the search range for a negative pattern preceding a CHECK-LABEL |
| ; ends at the start of the CHECK-LABEL match. not:7 and not:11 below |
| ; demonstrate this behavior. |
| ; |
| ; The search range for a positive pattern preceding a CHECK-LABEL ends at the |
| ; end of the CHECK-LABEL match. check:3 and check:5 below demonstrate this |
| ; behavior. As in the case of check:5, an effect of this behavior is that the |
| ; second CHECK-LABEL match might fail even though the first succeeded. |
| ; |
| ; FIXME: It seems like the search range for such a positive pattern should be |
| ; the same as in the case of a negative pattern. Note that -dump-input is |
| ; correct here. It's the matching behavior that's strange. |
| ;-------------------------------------------------- |
| |
| ; RUN: echo 'text' > %t.in |
| ; RUN: echo 'labelA' >> %t.in |
| ; RUN: echo 'textA' >> %t.in |
| ; RUN: echo 'labelB' >> %t.in |
| ; RUN: echo 'textB' >> %t.in |
| ; RUN: echo 'labelC' >> %t.in |
| ; RUN: echo 'textC' >> %t.in |
| ; RUN: echo 'labelD' >> %t.in |
| ; RUN: echo 'textD' >> %t.in |
| ; RUN: echo 'labelE' >> %t.in |
| ; RUN: echo 'textE' >> %t.in |
| ; RUN: echo 'labelF' >> %t.in |
| |
| ; RUN: echo 'CHECK: text' > %t.chk |
| ; RUN: echo 'CHECK-LABEL: labelA' >> %t.chk |
| ; RUN: echo 'CHECK: foobar' >> %t.chk |
| ; RUN: echo 'CHECK-LABEL: labelB' >> %t.chk |
| ; RUN: echo 'CHECK: labelC' >> %t.chk |
| ; RUN: echo 'CHECK-LABEL: labelC' >> %t.chk |
| ; RUN: echo 'CHECK-NOT: foobar' >> %t.chk |
| ; RUN: echo 'CHECK-LABEL: labelD' >> %t.chk |
| ; RUN: echo 'CHECK-NOT: textD' >> %t.chk |
| ; RUN: echo 'CHECK-LABEL: labelE' >> %t.chk |
| ; RUN: echo 'CHECK-NOT: labelF' >> %t.chk |
| ; RUN: echo 'CHECK-LABEL: labelF' >> %t.chk |
| |
| ; REDEFINE: %{pre} = LAB |
| ; RUN: not %{run-vv} |
| ; RUN: not %{run-v} |
| ; RUN: not %{run} |
| |
| ; Verbose diagnostics are suppressed but not errors. |
| ; LAB:{{.*}}.chk:3:8: error: CHECK: expected string not found in input |
| ; LAB:{{.*}}.chk:6:14: error: CHECK-LABEL: expected string not found in input |
| ; LAB:{{.*}}.chk:9:12: error: CHECK-NOT: excluded string found in input |
| |
| ; LAB-V:<<<<<< |
| ; LAB-V-NEXT: 1: text |
| ; LAB-V-NEXT:check:1 ^~~~ |
| ; LAB-V-NEXT: 2: labelA |
| ; LAB-V-NEXT:label:2'0 ^~~~~~ |
| ; LAB-V-NEXT:label:2'1 ^~~~~~ |
| ; LAB-V-NEXT:check:3 X error: no match found |
| ; LAB-V-NEXT: 3: textA |
| ; LAB-V-NEXT:check:3 ~~~~~~ |
| ; LAB-V-NEXT: 4: labelB |
| ; LAB-V-NEXT:label:4 ^~~~~~ |
| ; LAB-V-NEXT:check:3 ~~~~~~ |
| ; LAB-V-NEXT: 5: textB |
| ; LAB-V-NEXT: 6: labelC |
| ; LAB-V-NEXT:label:6'0 ^~~~~~ |
| ; LAB-V-NEXT:check:5 ^~~~~~ |
| ; LAB-V-NEXT:label:6'1 X error: no match found |
| ; LAB-VV-NEXT:not:7 X |
| ; LAB-V-NEXT: 7: textC |
| ; LAB-VV-NEXT:not:7 ~~~~~~ |
| ; LAB-V-NEXT: 8: labelD |
| ; LAB-V-NEXT:label:8'0 ^~~~~~ |
| ; LAB-V-NEXT:label:8'1 ^~~~~~ |
| ; LAB-V-NEXT: 9: textD |
| ; LAB-V-NEXT:not:9 !~~~~ error: no match expected |
| ; LAB-V-NEXT: 10: labelE |
| ; LAB-V-NEXT:label:10'0 ^~~~~~ |
| ; LAB-V-NEXT:label:10'1 ^~~~~~ |
| ; LAB-VV-NEXT:not:11 X |
| ; LAB-V-NEXT: 11: textE |
| ; LAB-VV-NEXT:not:11 ~~~~~~ |
| ; LAB-V-NEXT: 12: labelF |
| ; LAB-V-NEXT:label:12'0 ^~~~~~ |
| ; LAB-V-NEXT:label:12'1 ^~~~~~ |
| ; LAB-V-NEXT:>>>>>> |
| ; LAB-V-NOT:{{.}} |
| |
| ; LAB-Q:<<<<<< |
| ; LAB-Q-NEXT: 1: text |
| ; LAB-Q-NEXT: 2: labelA |
| ; LAB-Q-NEXT:check:3 X error: no match found |
| ; LAB-Q-NEXT: 3: textA |
| ; LAB-Q-NEXT:check:3 ~~~~~~ |
| ; LAB-Q-NEXT: 4: labelB |
| ; LAB-Q-NEXT:check:3 ~~~~~~ |
| ; LAB-Q-NEXT: 5: textB |
| ; LAB-Q-NEXT: 6: labelC |
| ; LAB-Q-NEXT:label:6 X error: no match found |
| ; LAB-Q-NEXT: 7: textC |
| ; LAB-Q-NEXT: 8: labelD |
| ; LAB-Q-NEXT: 9: textD |
| ; LAB-Q-NEXT:not:9 !~~~~ error: no match expected |
| ; LAB-Q-NEXT: 10: labelE |
| ; LAB-Q-NEXT: 11: textE |
| ; LAB-Q-NEXT: 12: labelF |
| ; LAB-Q-NEXT:>>>>>> |
| ; LAB-Q-NOT:{{.}} |
| |
| ;-------------------------------------------------- |
| ; --implicit-check-not |
| ; |
| ; The first two --implicit-check-not patterns have no match (success). The |
| ; third has an unexpected match (error). To check per-input-line annotation |
| ; sorting, all of those plus the CHECK directives have annotations on the same |
| ; input line. |
| ;-------------------------------------------------- |
| |
| ; RUN: echo 'hello world again!' > %t.in |
| |
| ; RUN: echo 'CHECK: hel' > %t.chk |
| ; RUN: echo 'CHECK: wor' >> %t.chk |
| ; RUN: echo 'CHECK: !' >> %t.chk |
| |
| ; REDEFINE: %{pre} = IMPNOT |
| ; REDEFINE: %{opts} = \ |
| ; REDEFINE: --implicit-check-not='goodbye' \ |
| ; REDEFINE: --implicit-check-not='world' \ |
| ; REDEFINE: --implicit-check-not='again' |
| ; RUN: not %{run-vv} |
| ; RUN: not %{run-v} |
| ; RUN: not %{run} |
| ; REDEFINE: %{opts} = |
| |
| ; Verbose diagnostics are suppressed but not errors. |
| ; IMPNOT:{{.*}}command line:1:22: error: IMPLICIT-CHECK-NOT: excluded string found in input |
| |
| ; IMPNOT-VV:<<<<<< |
| ; IMPNOT-VV-NEXT: 1: hello world again! |
| ; IMPNOT-VV-NEXT:check:1 ^~~ |
| ; IMPNOT-VV-NEXT:not:imp1'0 X |
| ; IMPNOT-VV-NEXT:not:imp2'0 X |
| ; IMPNOT-VV-NEXT:not:imp3'0 X |
| ; IMPNOT-VV-NEXT:check:2 ^~~ |
| ; IMPNOT-VV-NEXT:not:imp1'1 X~~ |
| ; IMPNOT-VV-NEXT:not:imp2'1 X~~ |
| ; IMPNOT-VV-NEXT:not:imp3'1 X~~ |
| ; IMPNOT-VV-NEXT:check:3 ^ |
| ; IMPNOT-VV-NEXT:not:imp1'2 X~~~~~~~ |
| ; IMPNOT-VV-NEXT:not:imp2'2 X~~~~~~~ |
| ; IMPNOT-VV-NEXT:not:imp3'2 !~~~~ error: no match expected |
| ; IMPNOT-VV-NEXT:>>>>>> |
| ; IMPNOT-VV-NOT:{{.}} |
| |
| ; IMPNOT-VQ:<<<<<< |
| ; IMPNOT-VQ-NEXT: 1: hello world again! |
| ; IMPNOT-VQ-NEXT:check:1 ^~~ |
| ; IMPNOT-VQ-NEXT:check:2 ^~~ |
| ; IMPNOT-VQ-NEXT:check:3 ^ |
| ; IMPNOT-VQ-NEXT:not:imp3 !~~~~ error: no match expected |
| ; IMPNOT-VQ-NEXT:>>>>>> |
| ; IMPNOT-VQ-NOT:{{.}} |
| |
| ; IMPNOT-Q:<<<<<< |
| ; IMPNOT-Q-NEXT: 1: hello world again! |
| ; IMPNOT-Q-NEXT:not:imp3 !~~~~ error: no match expected |
| ; IMPNOT-Q-NEXT:>>>>>> |
| ; IMPNOT-Q-NOT:{{.}} |
| |
| ;-------------------------------------------------- |
| ; Substitutions: successful and failed positive directives. |
| ;-------------------------------------------------- |
| |
| ; RUN: echo 'def-match1 def-match2' > %t.in |
| ; RUN: echo 'def-match1 def-nomatch' >> %t.in |
| |
| ; RUN: echo 'CHECK: [[DEF_MATCH1]] [[DEF_MATCH2]]' > %t.chk |
| ; RUN: echo 'CHECK: [[DEF_MATCH1]] [[UNDEF]] [[DEF_NOMATCH]]' >> %t.chk |
| |
| ; REDEFINE: %{pre} = SUBST-POS |
| ; REDEFINE: %{opts} = \ |
| ; REDEFINE: -DDEF_MATCH1=def-match1 -DDEF_MATCH2=def-match2 \ |
| ; REDEFINE: -DDEF_NOMATCH=foobar |
| ; RUN: not %{run-vv} |
| ; RUN: not %{run-v} |
| ; RUN: not %{run} |
| ; REDEFINE: %{opts} = |
| |
| ; Verbose diagnostics are suppressed but not errors. |
| ; SUBST-POS:{{.*}}error:{{.*}} |
| ; SUBST-POS:{{.*}}possible intended match here{{.*}} |
| |
| ; SUBST-POS:<<<<<< |
| ; SUBST-POS-NEXT: 1: def-match1 def-match2 |
| ; SUBST-POS-V-NEXT:check:1'0 ^~~~~~~~~~~~~~~~~~~~~ |
| ; SUBST-POS-V-NEXT:check:1'1 with "DEF_MATCH1" equal to "def-match1" |
| ; SUBST-POS-V-NEXT:check:1'2 with "DEF_MATCH2" equal to "def-match2" |
| ; SUBST-POS-NEXT:check:2'0 X error: match failed for invalid pattern |
| ; SUBST-POS-NEXT:check:2'1 undefined variable: UNDEF |
| ; SUBST-POS-NEXT:check:2'2 with "DEF_MATCH1" equal to "def-match1" |
| ; SUBST-POS-NEXT:check:2'3 with "DEF_NOMATCH" equal to "foobar" |
| ; SUBST-POS-NEXT: 2: def-match1 def-nomatch |
| ; SUBST-POS-NEXT:check:2'0 ~~~~~~~~~~~~~~~~~~~~~~~ |
| ; SUBST-POS-NEXT:check:2'4 ? possible intended match |
| ; SUBST-POS-NEXT:>>>>>> |
| |
| ;-------------------------------------------------- |
| ; Substitutions: successful and failed negative directives. |
| ;-------------------------------------------------- |
| |
| ; RUN: echo 'def-match1 def-nomatch' > %t.in |
| ; RUN: echo 'def-match1 def-match2' >> %t.in |
| ; RUN: echo 'END' >> %t.in |
| |
| ; RUN: echo 'CHECK-NOT: [[DEF_MATCH1]] [[UNDEF]] [[DEF_NOMATCH]]' > %t.chk |
| ; RUN: echo 'CHECK-NOT: [[DEF_MATCH1]] [[DEF_MATCH2]]' >> %t.chk |
| ; RUN: echo 'CHECK: END' >> %t.chk |
| |
| ; REDEFINE: %{pre} = SUBST-NEG |
| ; REDEFINE: %{opts} = \ |
| ; REDEFINE: -DDEF_MATCH1=def-match1 -DDEF_MATCH2=def-match2 \ |
| ; REDEFINE: -DDEF_NOMATCH=foobar |
| ; RUN: not %{run-vv} |
| ; RUN: not %{run-v} |
| ; RUN: not %{run} |
| ; REDEFINE: %{opts} = |
| |
| ; Verbose diagnostics are suppressed but not errors. |
| ; SUBST-NEG-COUNT-2:{{.*}}error:{{.*}} |
| |
| ; SUBST-NEG:<<<<<< |
| ; SUBST-NEG-NEXT: 1: def-match1 def-nomatch |
| ; SUBST-NEG-NEXT:not:1'0 X~~~~~~~~~~~~~~~~~~~~~~ error: match failed for invalid pattern |
| ; SUBST-NEG-NEXT:not:1'1 undefined variable: UNDEF |
| ; SUBST-NEG-NEXT:not:1'2 with "DEF_MATCH1" equal to "def-match1" |
| ; SUBST-NEG-NEXT:not:1'3 with "DEF_NOMATCH" equal to "foobar" |
| ; SUBST-NEG-NEXT: 2: def-match1 def-match2 |
| ; SUBST-NEG-NEXT:not:1'0 ~~~~~~~~~~~~~~~~~~~~~~ |
| ; SUBST-NEG-NEXT:not:2'0 !~~~~~~~~~~~~~~~~~~~~ error: no match expected |
| ; SUBST-NEG-NEXT:not:2'1 with "DEF_MATCH1" equal to "def-match1" |
| ; SUBST-NEG-NEXT:not:2'2 with "DEF_MATCH2" equal to "def-match2" |
| ; SUBST-NEG-NEXT: 3: END |
| ; SUBST-NEG-V-NEXT:check:3 ^~~ |
| ; SUBST-NEG-NEXT:>>>>>> |
| |
| ;-------------------------------------------------- |
| ; Captured variables |
| ;-------------------------------------------------- |
| |
| ; RUN: echo 'strvar: foo' > %t.in |
| ; RUN: echo 'numvar no expr: 51' >> %t.in |
| ; RUN: echo 'numvar expr: -49' >> %t.in |
| ; RUN: echo 'many: foo 100 8 bar' >> %t.in |
| ; RUN: echo 'var in neg match: foo' >> %t.in |
| ; RUN: echo 'END' >> %t.in |
| |
| ; RUN: echo 'CHECK: strvar: [[STRVAR:[a-z]+]]' > %t.chk |
| ; RUN: echo 'CHECK: numvar no expr: [[#NUMVAR_NO_EXPR:]]' >> %t.chk |
| ; RUN: echo 'CHECK: numvar expr: [[#%d,NUMVAR_EXPR:2-NUMVAR_NO_EXPR]]' >> %t.chk |
| |
| ; Capture many variables of different kinds in a different order than their |
| ; names sort alphabetically to ensure they're sorted in capture order. |
| ; RUN: echo 'CHECK: many: [[VAR1:foo]] [[#%d,VAR3:]] [[#VAR2:]] [[VAR4:bar]]' \ |
| ; RUN: >> %t.chk |
| |
| ; RUN: echo 'CHECK-NOT: var in neg match: [[VAR:foo]]' >> %t.chk |
| ; RUN: echo 'CHECK: END' >> %t.chk |
| |
| ; REDEFINE: %{pre} = CAPTURE-NEG |
| ; RUN: not %{run-vv} |
| ; RUN: not %{run-v} |
| ; RUN: not %{run} |
| |
| ; Verbose diagnostics are suppressed but not errors. |
| ; CAPTURE-NEG:{{.*}}error:{{.*}} |
| |
| ; CAPTURE-NEG:<<<<<< |
| ; CAPTURE-NEG-NEXT: 1: strvar: foo |
| ; CAPTURE-NEG-V-NEXT:check:1'0 ^~~~~~~~~~~ |
| CAPTURE-NEG-V-NEXT:check:1'1 ^~~ captured var "STRVAR" |
| ; CAPTURE-NEG-NEXT: 2: numvar no expr: 51 |
| ; CAPTURE-NEG-V-NEXT:check:2'0 ^~~~~~~~~~~~~~~~~~ |
| ; CAPTURE-NEG-V-NEXT:check:2'1 ^~ captured var "NUMVAR_NO_EXPR" |
| ; CAPTURE-NEG-NEXT: 3: numvar expr: -49 |
| ; CAPTURE-NEG-V-NEXT:check:3'0 ^~~~~~~~~~~~~~~~ |
| ; CAPTURE-NEG-V-NEXT:check:3'1 with "%d,NUMVAR_EXPR:2-NUMVAR_NO_EXPR" equal to "-49" |
| ; CAPTURE-NEG-V-NEXT:check:3'2 ^~~ captured var "NUMVAR_EXPR" |
| ; CAPTURE-NEG-NEXT: 4: many: foo 100 8 bar |
| ; CAPTURE-NEG-V-NEXT:check:4'0 ^~~~~~~~~~~~~~~~~~~ |
| ; CAPTURE-NEG-V-NEXT:check:4'1 ^~~ captured var "VAR1" |
| ; CAPTURE-NEG-V-NEXT:check:4'2 ^~~ captured var "VAR3" |
| ; CAPTURE-NEG-V-NEXT:check:4'3 ^ captured var "VAR2" |
| ; CAPTURE-NEG-V-NEXT:check:4'4 ^~~ captured var "VAR4" |
| ; CAPTURE-NEG-NEXT: 5: var in neg match: foo |
| ; CAPTURE-NEG-NEXT:not:5'0 !~~~~~~~~~~~~~~~~~~~~ error: no match expected |
| ; CAPTURE-NEG-NEXT:not:5'1 !~~ captured var "VAR" |
| ; CAPTURE-NEG-NEXT: 6: END |
| ; CAPTURE-NEG-V-NEXT:check:6 ^~~ |
| ; CAPTURE-NEG-NEXT:>>>>>> |
| |
| ;-------------------------------------------------- |
| ; CHECK-NEXT, CHECK-SAME, CHECK-DAG note fixups. |
| ; |
| ; When CHECK-NEXT or CHECK-SAME fails for the wrong line, or when a CHECK-DAG |
| ; match is discarded, the associated diagnostic type must be converted from |
| ; successful to failed or discarded. However, any note annotation must be |
| ; traversed to find that diagnostic. We check this behavior here only for |
| ; substitutions, but it's the same mechanism for all note annotations. |
| ;-------------------------------------------------- |
| |
| ;- - - - - - - - - - - - - - - - - - - - - - - - - |
| ; CHECK-NEXT. |
| ;- - - - - - - - - - - - - - - - - - - - - - - - - |
| |
| ; RUN: echo 'pre var' > %t.in |
| |
| ; RUN: echo 'CHECK: pre' > %t.chk |
| ; RUN: echo 'CHECK-NEXT: [[VAR]]' >> %t.chk |
| |
| ; REDEFINE: %{pre} = SUBST_NEXT |
| ; REDEFINE: %{opts} = -DVAR=var |
| ; RUN: not %{run-vv} |
| ; RUN: not %{run-v} |
| ; RUN: not %{run} |
| ; REDEFINE: %{opts} = |
| |
| ; Verbose diagnostics are suppressed but not errors. |
| ; SUBST_NEXT:{{.*}}error:{{.*}} |
| |
| ; SUBST_NEXT-V:<<<<<< |
| ; SUBST_NEXT-V-NEXT: 1: pre var |
| ; SUBST_NEXT-V-NEXT:check:1 ^~~ |
| ; SUBST_NEXT-V-NEXT:next:2'0 !~~ error: match on wrong line |
| ; SUBST_NEXT-V-NEXT:next:2'1 with "VAR" equal to "var" |
| ; SUBST_NEXT-V-NEXT:>>>>>> |
| |
| ; SUBST_NEXT-Q:<<<<<< |
| ; SUBST_NEXT-Q-NEXT: 1: pre var |
| ; SUBST_NEXT-Q-NEXT:next:2 !~~ error: match on wrong line |
| ; SUBST_NEXT-Q-NEXT:>>>>>> |
| |
| ;- - - - - - - - - - - - - - - - - - - - - - - - - |
| ; CHECK-SAME. |
| ;- - - - - - - - - - - - - - - - - - - - - - - - - |
| |
| ; RUN: echo 'pre' > %t.in |
| ; RUN: echo 'var' >> %t.in |
| |
| ; RUN: echo 'CHECK: pre' > %t.chk |
| ; RUN: echo 'CHECK-SAME: [[VAR]]' >> %t.chk |
| |
| ; REDEFINE: %{pre} = SUBST_SAME |
| ; REDEFINE: %{opts} = -DVAR=var |
| ; RUN: not %{run-vv} |
| ; RUN: not %{run-v} |
| ; RUN: not %{run} |
| ; REDEFINE: %{opts} = |
| |
| ; Verbose diagnostics are suppressed but not errors. |
| ; SUBST_SAME:{{.*}}error:{{.*}} |
| |
| ; SUBST_SAME-V:<<<<<< |
| ; SUBST_SAME-V-NEXT: 1: pre |
| ; SUBST_SAME-V-NEXT:check:1 ^~~ |
| ; SUBST_SAME-V-NEXT: 2: var |
| ; SUBST_SAME-V-NEXT:same:2'0 !~~ error: match on wrong line |
| ; SUBST_SAME-V-NEXT:same:2'1 with "VAR" equal to "var" |
| ; SUBST_SAME-V-NEXT:>>>>>> |
| |
| ; SUBST_SAME-Q:<<<<<< |
| ; SUBST_SAME-Q-NEXT: 1: pre |
| ; SUBST_SAME-Q-NEXT: 2: var |
| ; SUBST_SAME-Q-NEXT:same:2 !~~ error: match on wrong line |
| ; SUBST_SAME-Q-NEXT:>>>>>> |
| |
| ;- - - - - - - - - - - - - - - - - - - - - - - - - |
| ; CHECK-DAG. |
| ;- - - - - - - - - - - - - - - - - - - - - - - - - |
| |
| ; RUN: echo 'var' > %t.in |
| ; RUN: echo 'var' >> %t.in |
| ; RUN: echo 'END' >> %t.in |
| |
| ; RUN: echo 'CHECK-DAG: var' > %t.chk |
| ; RUN: echo 'CHECK-DAG: [[VAR]]' >> %t.chk |
| ; RUN: echo 'CHECK: END' >> %t.chk |
| |
| ; REDEFINE: %{pre} = SUBST_DAG |
| ; REDEFINE: %{opts} = -DVAR=var |
| ; RUN: %{run-vv} |
| ; RUN: %{run-v} |
| ; RUN: %{run} |
| ; REDEFINE: %{opts} = |
| |
| ; SUBST_DAG-VV:<<<<<< |
| ; SUBST_DAG-VV-NEXT: 1: var |
| ; SUBST_DAG-VV-NEXT:dag:1 ^~~ |
| ; SUBST_DAG-VV-NEXT:dag:2'0 !~~ discard: overlaps earlier match |
| ; SUBST_DAG-VV-NEXT:dag:2'1 with "VAR" equal to "var" |
| ; SUBST_DAG-VV-NEXT: 2: var |
| ; SUBST_DAG-VV-NEXT:dag:2'2 ^~~ |
| ; SUBST_DAG-VV-NEXT:dag:2'3 with "VAR" equal to "var" |
| ; SUBST_DAG-VV-NEXT: 3: END |
| ; SUBST_DAG-VV-NEXT:check:3 ^~~ |
| ; SUBST_DAG-VV-NEXT:>>>>>> |
| |
| ; SUBST_DAG-VQ:<<<<<< |
| ; SUBST_DAG-VQ-NEXT: 1: var |
| ; SUBST_DAG-VQ-NEXT:dag:1 ^~~ |
| ; SUBST_DAG-VQ-NEXT: 2: var |
| ; SUBST_DAG-VQ-NEXT:dag:2'0 ^~~ |
| ; SUBST_DAG-VQ-NEXT:dag:2'1 with "VAR" equal to "var" |
| ; SUBST_DAG-VQ-NEXT: 3: END |
| ; SUBST_DAG-VQ-NEXT:check:3 ^~~ |
| ; SUBST_DAG-VQ-NEXT:>>>>>> |
| |
| ; SUBST_DAG-Q:<<<<<< |
| ; SUBST_DAG-Q-NEXT: 1: var |
| ; SUBST_DAG-Q-NEXT: 2: var |
| ; SUBST_DAG-Q-NEXT: 3: END |
| ; SUBST_DAG-Q-NEXT:>>>>>> |