The current tokenize-whole-file approach has a few limitations. * Lack of state information: `maybeSplitExpr` is needed to parse expressions. It's infeasible to add new states to behave more like GNU ld. * `readInclude` may insert tokens in the middle, leading to a time complexity issue with N-nested `INCLUDE`. * line/column information for diagnostics are inaccurate, especially after an `INCLUDE`. * `getLineNumber` cannot be made more efficient without significant code complexity and memory consumption. https://reviews.llvm.org/D104137 The patch switches to a traditional lexer that generates tokens lazily. * `atEOF` behavior is modified: we need to call `peek` to determine EOF. * `peek` and `next` cannot call `setError` upon `atEOF`. * Since `consume` no longer reports an error upon `atEOF`, the idiom `while (!errorCount() && !consume(")"))` would cause a dead loop. Use `while (peek() != ")" && !atEOF()) { ... } expect(")")` instead. * An include stack is introduced to handle `readInclude`. This can be utilized to address #93947 properly. * `tokens` and `pos` are removed. * `commandString` is reimplemented. Since it is used in -Map output, `\n` needs to be replaced with space. Pull Request: https://github.com/llvm/llvm-project/pull/100493
65 lines
2.4 KiB
Plaintext
65 lines
2.4 KiB
Plaintext
## Different "echo" commands on Windows interpret quoted strings and
|
|
## wildcards in similar but different way (On Windows, ARGV tokenization
|
|
## and wildcard expansion are not done by the shell but by each command.)
|
|
## Because of that reason, this test fails on some Windows environment.
|
|
## We can't write quoted strings that are interpreted the same way
|
|
## by all echo commands. So, we don't want to run this on Windows.
|
|
|
|
# REQUIRES: shell
|
|
|
|
# RUN: mkdir -p %t.dir
|
|
|
|
## Note that we are using "cannot open no-such-file: " as a marker that the
|
|
## linker keep going when it found an error. That specific error message is not
|
|
## related to the linker script tests.
|
|
|
|
# RUN: echo foobar > %t1
|
|
# RUN: not ld.lld %t1 no-such-file 2>&1 | FileCheck -check-prefix=ERR1 %s
|
|
# ERR1: error: {{.*}}1:1: unknown directive: foobar
|
|
# ERR1: cannot open no-such-file:
|
|
|
|
# RUN: echo "foo \"bar" > %t2
|
|
# RUN: not ld.lld %t2 no-such-file 2>&1 | FileCheck -check-prefix=ERR2 %s
|
|
# ERR2: unclosed quote
|
|
# ERR2: cannot open no-such-file:
|
|
|
|
# RUN: echo "/*" > %t3
|
|
# RUN: not ld.lld %t3 no-such-file 2>&1 | FileCheck -check-prefix=ERR3 %s
|
|
# ERR3: unclosed comment
|
|
# ERR3: cannot open no-such-file:
|
|
|
|
# RUN: echo "EXTERN (" > %t4
|
|
# RUN: not ld.lld %t4 no-such-file 2>&1 | FileCheck -check-prefix=ERR4 %s
|
|
# ERR4: unexpected EOF
|
|
# ERR4: cannot open no-such-file:
|
|
|
|
# RUN: echo "EXTERN (" > %t5
|
|
# RUN: not ld.lld %t5 no-such-file 2>&1 | FileCheck -check-prefix=ERR5 %s
|
|
# ERR5: unexpected EOF
|
|
# ERR5: cannot open no-such-file:
|
|
|
|
# RUN: echo "EXTERN xyz" > %t6
|
|
# RUN: not ld.lld %t6 no-such-file 2>&1 | FileCheck -check-prefix=ERR6 %s
|
|
# ERR6: ( expected, but got xyz
|
|
# ERR6: cannot open no-such-file:
|
|
|
|
# RUN: echo "INCLUDE /no/such/file" > %t7
|
|
# RUN: not ld.lld %t7 no-such-file 2>&1 | FileCheck -check-prefix=ERR7 %s
|
|
# ERR7: cannot find linker script /no/such/file
|
|
# ERR7: cannot open no-such-file:
|
|
|
|
# RUN: echo "OUTPUT_FORMAT(x y z)" > %t8
|
|
# RUN: not ld.lld %t8 no-such-file 2>&1 | FileCheck -check-prefix=ERR8 %s
|
|
# RUN: not ld.lld -m elf_amd64 %t8 no-such-file 2>&1 | FileCheck -check-prefix=ERR8 %s
|
|
# ERR8: , expected, but got y
|
|
# ERR8: cannot open no-such-file:
|
|
|
|
# RUN: echo "OUTPUT_FORMAT(elf64-x86-64 y z)" > %t9
|
|
# RUN: not ld.lld %t9 no-such-file 2>&1 | FileCheck -check-prefix=ERR9 %s
|
|
# ERR9: , expected, but got y
|
|
# ERR9: cannot open no-such-file:
|
|
|
|
# RUN: echo 'OUTPUT_FORMAT("")' > %t10
|
|
# RUN: not ld.lld %t10 2>&1 | FileCheck -check-prefix=ERR10 %s
|
|
# ERR10: error: {{.*}}:1: unknown output format name:
|