chainlint: recognize multi-line quoted strings more robustly
commit22e3e0241ab5add065411d0d8d493f066764465e
authorEric Sunshine <sunshine@sunshineco.com>
Mon, 13 Aug 2018 08:47:38 +0000 (13 04:47 -0400)
committerJunio C Hamano <gitster@pobox.com>
Mon, 13 Aug 2018 19:22:12 +0000 (13 12:22 -0700)
treec0b2b77d4071eeab6b5c83bc3aff098b7159c64c
parentd93871143fdb7c11ddea81aa7f698e5eee0246e5
chainlint: recognize multi-line quoted strings more robustly

chainlint.sed recognizes multi-line quoted strings within subshells:

    echo "abc
        def" >out &&

so it can avoid incorrectly classifying lines internal to the string as
breaking the &&-chain. To identify the first line of a multi-line
string, it checks if the line contains a single quote. However, this is
fragile and can be easily fooled by a line containing multiple strings:

    echo "xyz" "abc
        def" >out &&

Make detection more robust by checking for an odd number of quotes
rather than only a single one.

(Escaped quotes are not handled, but support may be added later.)

The original multi-line string recognizer rather cavalierly threw away
all but the final quote, whereas the new one is careful to retain all
quotes, so the "expected" output of a couple existing chainlint tests is
updated to account for this new behavior.

Signed-off-by: Eric Sunshine <sunshine@sunshineco.com>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
t/chainlint.sed
t/chainlint/here-doc-multi-line-string.expect
t/chainlint/multi-line-string.expect
t/chainlint/multi-line-string.test