mirror of
https://git.tartarus.org/simon/putty.git
synced 2025-01-25 01:02:24 +00:00
split_into_argv.c: tidy up large comment.
I just happened to notice that just below my huge comment explaining the two command-line splitting policies, there's a smaller one that refers to it as '(see large comment below)'. It's not below - it's above! That was because the older parts of that comment had previously been inside split_into_argv(), until I moved the explanation further up the file to the top level. Another consequence of that was that the older section of the comment was wrapped to a strangely narrow line width, because it had previously been indented further right. Folded the two comments together, and rewrapped the narrow paragraphs.
This commit is contained in:
parent
8df3ad6316
commit
18cac59b43
@ -51,6 +51,9 @@
|
|||||||
* or more backslashes precedes two or more double quotes, starting
|
* or more backslashes precedes two or more double quotes, starting
|
||||||
* inside a double-quoted string.
|
* inside a double-quoted string.
|
||||||
*
|
*
|
||||||
|
* Modern Visual Studio (as of 2021)
|
||||||
|
* ---------------------------------
|
||||||
|
*
|
||||||
* I investigated this in an ordinary CLI program, using the
|
* I investigated this in an ordinary CLI program, using the
|
||||||
* toolchain's crt0 to split a command line of the form
|
* toolchain's crt0 to split a command line of the form
|
||||||
*
|
*
|
||||||
@ -87,6 +90,9 @@
|
|||||||
* either opens or closes a quoted string, and if it closes one, it
|
* either opens or closes a quoted string, and if it closes one, it
|
||||||
* generates a literal " as a side effect.
|
* generates a literal " as a side effect.
|
||||||
*
|
*
|
||||||
|
* Older Visual Studio
|
||||||
|
* -------------------
|
||||||
|
*
|
||||||
* But here's the corresponding table from the older Visual Studio 7:
|
* But here's the corresponding table from the older Visual Studio 7:
|
||||||
*
|
*
|
||||||
* backslashes
|
* backslashes
|
||||||
@ -107,48 +113,47 @@
|
|||||||
* 10 0,3,n | 0,4,y 1,3,n 1,4,y 2,3,n
|
* 10 0,3,n | 0,4,y 1,3,n 1,4,y 2,3,n
|
||||||
* 11 0,4,n | 0,4,n 1,4,n 1,4,n 2,4,n
|
* 11 0,4,n | 0,4,n 1,4,n 1,4,n 2,4,n
|
||||||
*
|
*
|
||||||
* There is very weird mod-3 behaviour going on here in the
|
* There is very weird mod-3 behaviour going on here in the number of
|
||||||
* number of quotes, and it even applies when there aren't any
|
* quotes, and it even applies when there aren't any backslashes! How
|
||||||
* backslashes! How ghastly.
|
* ghastly.
|
||||||
*
|
*
|
||||||
* With a bit of thought, this extremely odd diagram suddenly
|
* With a bit of thought, this extremely odd diagram suddenly
|
||||||
* coalesced itself into a coherent, if still ghastly, model of
|
* coalesced itself into a coherent, if still ghastly, model of how
|
||||||
* how things work:
|
* things work:
|
||||||
*
|
*
|
||||||
* - As before, backslashes are only special when one or more
|
* - As before, backslashes are only special when one or more of them
|
||||||
* of them appear contiguously before at least one double
|
* appear contiguously before at least one double quote. In this
|
||||||
* quote. In this situation the backslashes do exactly what
|
* situation the backslashes do exactly what you'd expect: each one
|
||||||
* you'd expect: each one quotes the next thing in front of
|
* quotes the next thing in front of it, so you end up with n/2
|
||||||
* it, so you end up with n/2 literal backslashes (if n is
|
* literal backslashes (if n is even) or (n-1)/2 literal
|
||||||
* even) or (n-1)/2 literal backslashes and a literal quote
|
* backslashes and a literal quote (if n is odd). In the latter
|
||||||
* (if n is odd). In the latter case the double quote
|
* case the double quote character right after the backslashes is
|
||||||
* character right after the backslashes is used up.
|
* used up.
|
||||||
*
|
*
|
||||||
* - After that, any remaining double quotes are processed. A
|
* - After that, any remaining double quotes are processed. A string
|
||||||
* string of contiguous unescaped double quotes has a mod-3
|
* of contiguous unescaped double quotes has a mod-3 behaviour:
|
||||||
* behaviour:
|
|
||||||
*
|
*
|
||||||
* * inside a quoted segment, a quote ends the segment.
|
* * inside a quoted segment, a quote ends the segment.
|
||||||
* * _immediately_ after ending a quoted segment, a quote
|
* * _immediately_ after ending a quoted segment, a quote simply
|
||||||
* simply produces a literal quote.
|
* produces a literal quote.
|
||||||
* * otherwise, outside a quoted segment, a quote begins a
|
* * otherwise, outside a quoted segment, a quote begins a quoted
|
||||||
* quoted segment.
|
* segment.
|
||||||
*
|
*
|
||||||
* So, for example, if we started inside a quoted segment
|
* So, for example, if we started inside a quoted segment then two
|
||||||
* then two contiguous quotes would close the segment and
|
* contiguous quotes would close the segment and produce a literal
|
||||||
* produce a literal quote; three would close the segment,
|
* quote; three would close the segment, produce a literal quote,
|
||||||
* produce a literal quote, and open a new segment. If we
|
* and open a new segment. If we started outside a quoted segment,
|
||||||
* started outside a quoted segment, then two contiguous
|
* then two contiguous quotes would open and then close a segment,
|
||||||
* quotes would open and then close a segment, producing no
|
* producing no output (but potentially creating a zero-length
|
||||||
* output (but potentially creating a zero-length argument);
|
* argument); but three quotes would open and close a segment and
|
||||||
* but three quotes would open and close a segment and then
|
* then produce a literal quote.
|
||||||
* produce a literal quote.
|
*
|
||||||
*/
|
* I don't know exactly when the bug fix happened, but I know that VS7
|
||||||
|
* had the odd mod-3 behaviour. So the #if below will ensure that
|
||||||
/*
|
* modern (2015 onwards) versions of VS use the new more sensible
|
||||||
* We select between two behaviours depending on the version of Visual
|
* behaviour, and VS7 uses the old one. Things in between may be
|
||||||
* Studio (see large comment below). I don't know exactly when the bug
|
* wrong; if anyone cares, patches to change the cutoff version in
|
||||||
* fix happened, but I know that VS7 had the odd mod-3 behaviour.
|
* this #if are welcome.
|
||||||
*/
|
*/
|
||||||
#if _MSC_VER < 1400
|
#if _MSC_VER < 1400
|
||||||
#define MOD3 1
|
#define MOD3 1
|
||||||
|
Loading…
Reference in New Issue
Block a user