diff options
author | Boris Kolpackov <boris@codesynthesis.com> | 2017-01-16 16:28:51 +0200 |
---|---|---|
committer | Boris Kolpackov <boris@codesynthesis.com> | 2017-01-16 16:28:51 +0200 |
commit | 3f78ee9a3cebec797faa9c6578350ff4ecb670d8 (patch) | |
tree | b6239aea59ab2692a8a7ccaccd03dad95a9ba79c /doc/testscript.cli | |
parent | d8f36ca9545e6489b8c6e1ec4da8cb7b2d53f8ab (diff) |
Specify shared here-document testscript feature
Diffstat (limited to 'doc/testscript.cli')
-rw-r--r-- | doc/testscript.cli | 16 |
1 files changed, 15 insertions, 1 deletions
diff --git a/doc/testscript.cli b/doc/testscript.cli index ed23727..00b2786 100644 --- a/doc/testscript.cli +++ b/doc/testscript.cli @@ -1886,7 +1886,7 @@ here-document: \ A here-document can be used to supply data to \c{stdin} or to compare output -to the expected result for \c{stdout} and \c{stderr}. Note that the order of +to the expected result for \c{stdout} and \c{stderr}. The order of here-document fragments must match the order of redirects, for example: \ @@ -1900,6 +1900,20 @@ error: no such table 'no_such_table' EOE \ +Two or more here-document redirects can use the same end marker. In this case +all the redirects must have the same modifiers, if any. Only the here-document +fragment corresponding to the first occurrence of the end marker must be +present (called \i{shared} here-document) with the subsequent redirects +reusing the same data. This mechanism is primarily useful for round-trip +testing, for example: + +\ +: xml-round-trip +$* <<EOD >>EOD +<hello>Hello, World!</hello> +EOD +\ + Here-strings can be single-quoted literals or double-quoted with expansion. This semantics is extended to here-documents as follows: If the end marker on the command line is single-quoted, then the here-document lines are |