<html xmlns:v="urn:schemas-microsoft-com:vml" xmlns:o="urn:schemas-microsoft-com:office:office" xmlns:w="urn:schemas-microsoft-com:office:word" xmlns:m="http://schemas.microsoft.com/office/2004/12/omml" xmlns="http://www.w3.org/TR/REC-html40">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
<meta name="Generator" content="Microsoft Word 15 (filtered medium)">
<style><!--
/* Font Definitions */
@font-face
        {font-family:"Cambria Math";
        panose-1:2 4 5 3 5 4 6 3 2 4;}
@font-face
        {font-family:Calibri;
        panose-1:2 15 5 2 2 2 4 3 2 4;}
/* Style Definitions */
p.MsoNormal, li.MsoNormal, div.MsoNormal
        {margin:0in;
        margin-bottom:.0001pt;
        font-size:11.0pt;
        font-family:"Calibri",sans-serif;}
a:link, span.MsoHyperlink
        {mso-style-priority:99;
        color:blue;
        text-decoration:underline;}
a:visited, span.MsoHyperlinkFollowed
        {mso-style-priority:99;
        color:purple;
        text-decoration:underline;}
p.MsoPlainText, li.MsoPlainText, div.MsoPlainText
        {mso-style-priority:99;
        mso-style-link:"Plain Text Char";
        margin:0in;
        margin-bottom:.0001pt;
        font-size:11.0pt;
        font-family:"Calibri",sans-serif;}
span.PlainTextChar
        {mso-style-name:"Plain Text Char";
        mso-style-priority:99;
        mso-style-link:"Plain Text";
        font-family:"Calibri",sans-serif;}
.MsoChpDefault
        {mso-style-type:export-only;
        font-family:"Calibri",sans-serif;}
@page WordSection1
        {size:8.5in 11.0in;
        margin:1.0in 1.0in 1.0in 1.0in;}
div.WordSection1
        {page:WordSection1;}
--></style><!--[if gte mso 9]><xml>
<o:shapedefaults v:ext="edit" spidmax="1026" />
</xml><![endif]--><!--[if gte mso 9]><xml>
<o:shapelayout v:ext="edit">
<o:idmap v:ext="edit" data="1" />
</o:shapelayout></xml><![endif]-->
</head>
<body lang="EN-US" link="blue" vlink="purple">
<div class="WordSection1">
<p class="MsoPlainText">• What is your evaluation of the proposal?<o:p></o:p></p>
<p class="MsoPlainText"><o:p>&nbsp;</o:p></p>
<p class="MsoPlainText">-1, for two reasons:<o:p></o:p></p>
<p class="MsoPlainText"><span style="color:black"><o:p>&nbsp;</o:p></span></p>
<p class="MsoPlainText"><span style="color:black">(from <a href="https://lists.swift.org/pipermail/swift-evolution/Week-of-Mon-20170403/034897.html">
https://lists.swift.org/pipermail/swift-evolution/Week-of-Mon-20170403/034897.html</a> and follow-up)<o:p></o:p></span></p>
<p class="MsoPlainText"><span style="color:black">First, having the same beginning and ending delimiter, with no continuation character, makes it very easy for a syntax highlighter or tokenizer to get &quot;inverted&quot; in what it believes is string content and what
 it believes is code.&nbsp; I have seen this happen due to a subtle bug in a Python syntax highlighter, and it's incredibly frustrating that a single misinterpretation can &quot;invert&quot; the highlighting of the rest of the file.&nbsp; It's also possible that future syntactic
 enhancements to Swift could lead to inversion in a correct highlighter for an older version of Swift reading a newer Swift file.<o:p></o:p></span></p>
<p class="MsoPlainText"><span style="color:black"><o:p>&nbsp;</o:p></span></p>
<p class="MsoPlainText"><span style="color:black">When working with an online tokenizer / highlighter while editing your code, the proposed design maximizes what needs to get re-parsed as &quot;&quot;&quot; are added and removed.&nbsp; Sure, automatic insertion of close-&quot;&quot;&quot; helps,
 but not fully.<o:p></o:p></span></p>
<p class="MsoPlainText"><span style="color:black"><o:p>&nbsp;</o:p></span></p>
<p class="MsoPlainText"><span style="color:black">Under this proposal, you might say, &quot;you can assume it's code again if the indentation decreases too much.&quot;&nbsp; There are two problems with that.&nbsp; First, the required indentation is determined by the line with
 the close &quot;&quot;&quot;, so there's no way to detect a violation until you get there.&nbsp; Second, the user might have intended that as part of the quoted text but messed up the formatting.&nbsp; In that case, if you assume resumption of code, the actual close &quot;&quot;&quot; will be interpreted
 as an open &quot;&quot;&quot; and you have inversion anyway.&nbsp; So it's not clear that you've decreased the likelihood of inversion.<o:p></o:p></span></p>
<p class="MsoPlainText"><span style="color:black"><o:p>&nbsp;</o:p></span></p>
<p class="MsoPlainText"><span style="color:black"><o:p>&nbsp;</o:p></span></p>
<p class="MsoPlainText"><span style="color:black">Second, as others have pointed out, the proposal is quite lacking in specifics.&nbsp; For example, it's not clear if characters are allowed on the same line after an open &quot;&quot;&quot;.&nbsp; If not allowed, a syntax highlighter
 could heuristically distinguish open and close &quot;&quot;&quot; based on non-whitespace on the same line (just not the case of &quot;&quot;&quot; on a line with only whitespace - perhaps that should be disallowed).&nbsp; This could be helpful for recovery in tokenization/highlighting, but
 this proposal is unclear.<o:p></o:p></span></p>
<p class="MsoPlainText"><o:p>&nbsp;</o:p></p>
<p class="MsoPlainText"><span style="color:black"><o:p>&nbsp;</o:p></span></p>
<p class="MsoPlainText">• Is the problem being addressed significant enough to warrant a change to Swift?<o:p></o:p></p>
<p class="MsoPlainText"><o:p>&nbsp;</o:p></p>
<p class="MsoPlainText">Yes. &nbsp;Especially since unused string expressions are not a compilation error, using &#43; to construct long strings spanning multiple lines is hazardous.<o:p></o:p></p>
<p class="MsoPlainText">(See <a href="https://lists.swift.org/pipermail/swift-evolution/Week-of-Mon-20170320/034472.html">
https://lists.swift.org/pipermail/swift-evolution/Week-of-Mon-20170320/034472.html</a> )<o:p></o:p></p>
<p class="MsoPlainText"><span style="color:black"><o:p>&nbsp;</o:p></span></p>
<p class="MsoPlainText"><span style="color:black"><o:p>&nbsp;</o:p></span></p>
<p class="MsoPlainText">• Does this proposal fit well with the feel and direction of Swift?<o:p></o:p></p>
<p class="MsoPlainText"><o:p>&nbsp;</o:p></p>
<p class="MsoPlainText">I'm not satisfied this proposal has sufficiently addressed issues in the language feature being mostly inherited here.<o:p></o:p></p>
<p class="MsoPlainText"><o:p>&nbsp;</o:p></p>
<p class="MsoPlainText"><span style="color:black"><o:p>&nbsp;</o:p></span></p>
<p class="MsoPlainText">• If you have used other languages or libraries with a similar feature, how do you feel that this proposal compares to those?<o:p></o:p></p>
<p class="MsoPlainText"><o:p>&nbsp;</o:p></p>
<p class="MsoPlainText">I have experience with some tools supporting Python and we had issues with syntax highlighting ending up &quot;inverted&quot; because &quot;&quot;&quot; strings have the same beginning and ending delimiter.<o:p></o:p></p>
<p class="MsoPlainText"><o:p>&nbsp;</o:p></p>
<p class="MsoPlainText"><span style="color:black"><o:p>&nbsp;</o:p></span></p>
<p class="MsoPlainText">• How much effort did you put into your review? A glance, a quick reading, or an in-depth study?<o:p></o:p></p>
<p class="MsoPlainText"><o:p>&nbsp;</o:p></p>
<p class="MsoPlainText">A quick read, and participation in the discussion.&nbsp; I don't see any evidence the proposal took into account recent discussion:<o:p></o:p></p>
<p class="MsoPlainText"><span style="color:black"><o:p>&nbsp;</o:p></span></p>
<p class="MsoPlainText"><span style="color:black"><a href="https://lists.swift.org/pipermail/swift-evolution/Week-of-Mon-20170403/034856.html">https://lists.swift.org/pipermail/swift-evolution/Week-of-Mon-20170403/034856.html</a><o:p></o:p></span></p>
<p class="MsoPlainText"><span style="color:black"><o:p>&nbsp;</o:p></span></p>
<p class="MsoNormal"><o:p></o:p></p>
<p class="MsoNormal">-- <o:p></o:p></p>
<p class="MsoNormal">Peter Dillinger, Ph.D.<o:p></o:p></p>
<p class="MsoNormal">Software Engineering Manager, Coverity Analysis, Software Integrity Group | Synopsys<o:p></o:p></p>
<p class="MsoNormal">www.synopsys.com/software<o:p></o:p></p>
<p class="MsoNormal"><o:p>&nbsp;</o:p></p>
<p class="MsoPlainText"><o:p>&nbsp;</o:p></p>
</div>
</body>
</html>