<html><head><meta http-equiv="Content-Type" content="text/html charset=utf-8"></head><body style="word-wrap: break-word; -webkit-nbsp-mode: space; -webkit-line-break: after-white-space;" class=""><br class=""><div><blockquote type="cite" class=""><div class="">On Apr 24, 2017, at 7:23 AM, T.J. Usiyan via swift-evolution &lt;<a href="mailto:swift-evolution@swift.org" class="">swift-evolution@swift.org</a>&gt; wrote:</div><br class="Apple-interchange-newline"><div class=""><div dir="ltr" class="">/me Pushes implementation detail related concerns out of head<div class=""><br class=""></div><div class="">+1</div><div class=""><br class=""></div><div class=""><br class=""></div><div class="">I want this feature but I seriously doubt that it is feasible at the moment. There are so many 'more pressing' features that, even if this were accepted now, it wouldn't be implemented it in time for Swift 4.</div></div></div></blockquote><div><br class=""></div><div>Out of scope for Swift 4, certainly. It may not look like it, but this is a fairly large feature. I suggest reading up on&nbsp;<a href="https://en.wikipedia.org/wiki/Generalized_algebraic_data_type" class="">generalized algebraic data types</a>&nbsp;(GADTs), which is the more programming-language-theoretical name for what you’re describing here.</div><div><br class=""></div><span class="Apple-tab-span" style="white-space:pre">        </span>- Doug</div><div><br class=""><blockquote type="cite" class=""><div class=""><div dir="ltr" class=""><div class=""><br class=""></div><div class="">That said, I would love to be incorrect.&nbsp;</div></div><div class="gmail_extra"><br class=""><div class="gmail_quote">On Mon, Apr 24, 2017 at 9:57 AM, Joshua Alvarado via swift-evolution <span dir="ltr" class="">&lt;<a href="mailto:swift-evolution@swift.org" target="_blank" class="">swift-evolution@swift.org</a>&gt;</span> wrote:<br class=""><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div dir="ltr" class=""><div class=""><h1 style="box-sizing:border-box;margin:0px 0px 16px;line-height:1.25;padding-bottom:0.3em;border-bottom-width:1px;border-bottom-style:solid;border-bottom-color:rgb(234,236,239);color:rgb(36,41,46)" class=""><font face="arial, helvetica, sans-serif" size="2" class=""><span style="font-weight:normal" class="">Here is my pitch on adding generics to enum cases and not to the enum type itself. Let me know if you have an improvements or modifications lets open it to discussion thank you swiftys! :)</span></font></h1><h1 style="box-sizing:border-box;margin:0px 0px 16px;line-height:1.25;padding-bottom:0.3em;border-bottom-width:1px;border-bottom-style:solid;border-bottom-color:rgb(234,236,239);color:rgb(36,41,46);font-family:-apple-system,blinkmacsystemfont,'segoe ui',helvetica,arial,sans-serif,'apple color emoji','segoe ui emoji','segoe ui symbol'" class="">Enum with generic cases</h1><ul style="box-sizing:border-box;padding-left:2em;margin-top:0px;margin-bottom:16px;color:rgb(36,41,46);font-family:-apple-system,blinkmacsystemfont,'segoe ui',helvetica,arial,sans-serif,'apple color emoji','segoe ui emoji','segoe ui symbol';font-size:16px" class=""><li style="box-sizing:border-box" class="">Proposal:&nbsp;<a href="https://github.com/lostatseajoshua/swift-evolution/blob/master/NNNN-enum-generic-cases.md" style="box-sizing:border-box;background-color:transparent;color:rgb(3,102,214);text-decoration:none" target="_blank" class="">SE-NNNN</a></li><li style="box-sizing:border-box;margin-top:0.25em" class="">Authors:&nbsp;<a href="https://github.com/alvaradojoshua0" style="box-sizing:border-box;background-color:transparent;color:rgb(3,102,214);text-decoration:none" target="_blank" class="">Joshua Alvarado</a></li><li style="box-sizing:border-box;margin-top:0.25em" class="">Review Manager: TBD</li><li style="box-sizing:border-box;margin-top:0.25em" class="">Status:&nbsp;<span style="box-sizing:border-box;font-weight:600" class="">PITCH</span></li></ul><p style="box-sizing:border-box;margin-top:0px;margin-bottom:16px;color:rgb(36,41,46);font-family:-apple-system,blinkmacsystemfont,'segoe ui',helvetica,arial,sans-serif,'apple color emoji','segoe ui emoji','segoe ui symbol';font-size:16px" class=""><em style="box-sizing:border-box" class="">During the review process, add the following fields as needed:</em></p><ul style="box-sizing:border-box;padding-left:2em;margin-top:0px;margin-bottom:16px;color:rgb(36,41,46);font-family:-apple-system,blinkmacsystemfont,'segoe ui',helvetica,arial,sans-serif,'apple color emoji','segoe ui emoji','segoe ui symbol';font-size:16px" class=""><li style="box-sizing:border-box" class="">Decision Notes:&nbsp;<a href="https://lists.swift.org/pipermail/swift-evolution/" style="box-sizing:border-box;background-color:transparent;color:rgb(3,102,214);text-decoration:none" target="_blank" class="">Rationale</a>,&nbsp;<a href="https://lists.swift.org/pipermail/swift-evolution/" style="box-sizing:border-box;background-color:transparent;color:rgb(3,102,214);text-decoration:none" target="_blank" class="">Additional Commentary</a></li><li style="box-sizing:border-box;margin-top:0.25em" class="">Bugs:&nbsp;<a href="https://bugs.swift.org/browse/SR-NNNN" style="box-sizing:border-box;background-color:transparent;color:rgb(3,102,214);text-decoration:none" target="_blank" class="">SR-NNNN</a>,&nbsp;<a href="https://bugs.swift.org/browse/SR-MMMM" style="box-sizing:border-box;background-color:transparent;color:rgb(3,102,214);text-decoration:none" target="_blank" class="">SR-MMMM</a></li><li style="box-sizing:border-box;margin-top:0.25em" class="">Previous Revision:&nbsp;<a href="https://github.com/apple/swift-evolution/blob/...commit-ID.../proposals/NNNN-filename.md" style="box-sizing:border-box;background-color:transparent;color:rgb(3,102,214);text-decoration:none" target="_blank" class="">1</a></li><li style="box-sizing:border-box;margin-top:0.25em" class="">Previous Proposal:&nbsp;<a href="https://github.com/lostatseajoshua/swift-evolution/blob/master/XXXX-filename.md" style="box-sizing:border-box;background-color:transparent;color:rgb(3,102,214);text-decoration:none" target="_blank" class="">SE-XXXX</a></li></ul><h2 style="box-sizing:border-box;margin-top:24px;margin-bottom:16px;line-height:1.25;padding-bottom:0.3em;border-bottom-width:1px;border-bottom-style:solid;border-bottom-color:rgb(234,236,239);color:rgb(36,41,46);font-family:-apple-system,blinkmacsystemfont,'segoe ui',helvetica,arial,sans-serif,'apple color emoji','segoe ui emoji','segoe ui symbol'" class=""><a id="m_-2418809334444009596gmail-user-content-introduction" class="m_-2418809334444009596gmail-anchor" href="https://github.com/lostatseajoshua/swift-evolution/tree/master#introduction" style="box-sizing:border-box;background-color:transparent;color:rgb(3,102,214);text-decoration:none;float:left;padding-right:4px;line-height:1" target="_blank"></a>Introduction</h2><p style="box-sizing:border-box;margin-top:0px;margin-bottom:16px;color:rgb(36,41,46);font-family:-apple-system,blinkmacsystemfont,'segoe ui',helvetica,arial,sans-serif,'apple color emoji','segoe ui emoji','segoe ui symbol';font-size:16px" class="">This proposal adds a change to the enumeration type that allows an enum case to cast a generic on its associated value.</p><p style="box-sizing:border-box;margin-top:0px;margin-bottom:16px;color:rgb(36,41,46);font-family:-apple-system,blinkmacsystemfont,'segoe ui',helvetica,arial,sans-serif,'apple color emoji','segoe ui emoji','segoe ui symbol';font-size:16px" class="">Swift-evolution thread:&nbsp;<a href="https://lists.swift.org/pipermail/swift-evolution/" style="box-sizing:border-box;background-color:transparent;color:rgb(3,102,214);text-decoration:none" target="_blank" class="">Discussion thread topic for that proposal</a></p><h2 style="box-sizing:border-box;margin-top:24px;margin-bottom:16px;line-height:1.25;padding-bottom:0.3em;border-bottom-width:1px;border-bottom-style:solid;border-bottom-color:rgb(234,236,239);color:rgb(36,41,46);font-family:-apple-system,blinkmacsystemfont,'segoe ui',helvetica,arial,sans-serif,'apple color emoji','segoe ui emoji','segoe ui symbol'" class=""><a id="m_-2418809334444009596gmail-user-content-motivation" class="m_-2418809334444009596gmail-anchor" href="https://github.com/lostatseajoshua/swift-evolution/tree/master#motivation" style="box-sizing:border-box;background-color:transparent;color:rgb(3,102,214);text-decoration:none;float:left;padding-right:4px;line-height:1" target="_blank"></a>Motivation</h2><p style="box-sizing:border-box;margin-top:0px;margin-bottom:16px;color:rgb(36,41,46);font-family:-apple-system,blinkmacsystemfont,'segoe ui',helvetica,arial,sans-serif,'apple color emoji','segoe ui emoji','segoe ui symbol';font-size:16px" class="">Enums currently support generics, but they are added onto the type itself. This can cause adverse syntax when implementing generics for associated values to be stored along each case. The enum case holds the associated value (not the enum type itself) so should create its own value constraints.</p><h2 style="box-sizing:border-box;margin-top:24px;margin-bottom:16px;line-height:1.25;padding-bottom:0.3em;border-bottom-width:1px;border-bottom-style:solid;border-bottom-color:rgb(234,236,239);color:rgb(36,41,46);font-family:-apple-system,blinkmacsystemfont,'segoe ui',helvetica,arial,sans-serif,'apple color emoji','segoe ui emoji','segoe ui symbol'" class=""><a id="m_-2418809334444009596gmail-user-content-proposed-solution" class="m_-2418809334444009596gmail-anchor" href="https://github.com/lostatseajoshua/swift-evolution/tree/master#proposed-solution" style="box-sizing:border-box;background-color:transparent;color:rgb(3,102,214);text-decoration:none;float:left;padding-right:4px;line-height:1" target="_blank"></a>Proposed solution</h2><p style="box-sizing:border-box;margin-top:0px;margin-bottom:16px;color:rgb(36,41,46);font-family:-apple-system,blinkmacsystemfont,'segoe ui',helvetica,arial,sans-serif,'apple color emoji','segoe ui emoji','segoe ui symbol';font-size:16px" class="">The generic is to be casted on the case of the enum and not on the enum itself.</p><h2 style="box-sizing:border-box;margin-top:24px;margin-bottom:16px;line-height:1.25;padding-bottom:0.3em;border-bottom-width:1px;border-bottom-style:solid;border-bottom-color:rgb(234,236,239);color:rgb(36,41,46);font-family:-apple-system,blinkmacsystemfont,'segoe ui',helvetica,arial,sans-serif,'apple color emoji','segoe ui emoji','segoe ui symbol'" class=""><a id="m_-2418809334444009596gmail-user-content-detailed-design" class="m_-2418809334444009596gmail-anchor" href="https://github.com/lostatseajoshua/swift-evolution/tree/master#detailed-design" style="box-sizing:border-box;background-color:transparent;color:rgb(3,102,214);text-decoration:none;float:left;padding-right:4px;line-height:1" target="_blank"></a>Detailed design</h2><p style="box-sizing:border-box;margin-top:0px;margin-bottom:16px;color:rgb(36,41,46);font-family:-apple-system,blinkmacsystemfont,'segoe ui',helvetica,arial,sans-serif,'apple color emoji','segoe ui emoji','segoe ui symbol';font-size:16px" class="">Current implementation:</p><div class="m_-2418809334444009596gmail-highlight-source-swift m_-2418809334444009596gmail-highlight" style="box-sizing:border-box;margin-bottom:16px;color:rgb(36,41,46);font-family:-apple-system,blinkmacsystemfont,'segoe ui',helvetica,arial,sans-serif,'apple color emoji','segoe ui emoji','segoe ui symbol';font-size:16px"><pre style="box-sizing:border-box;font-family:sfmono-regular,consolas,'liberation mono',menlo,courier,monospace;font-size:13.600000381469727px;margin-top:0px;margin-bottom:0px;line-height:1.45;word-wrap:normal;padding:16px;overflow:auto;background-color:rgb(246,248,250);border-top-left-radius:3px;border-top-right-radius:3px;border-bottom-right-radius:3px;border-bottom-left-radius:3px;word-break:normal" class=""><span class="m_-2418809334444009596gmail-pl-c" style="box-sizing:border-box;color:rgb(150,152,150)"><span class="m_-2418809334444009596gmail-pl-c" style="box-sizing:border-box">//</span> enum with two generic types</span>
<span class="m_-2418809334444009596gmail-pl-c" style="box-sizing:border-box;color:rgb(150,152,150)"></span><span class="m_-2418809334444009596gmail-pl-k" style="box-sizing:border-box;color:rgb(167,29,93)">enum</span> <span class="m_-2418809334444009596gmail-pl-en" style="box-sizing:border-box;color:rgb(121,93,163)">Foo</span>&lt;<span class="m_-2418809334444009596gmail-pl-c1" style="box-sizing:border-box;color:rgb(0,134,179)">T</span>: <span class="m_-2418809334444009596gmail-pl-e" style="box-sizing:border-box;color:rgb(121,93,163)"><span class="m_-2418809334444009596gmail-pl-c1" style="box-sizing:border-box;color:rgb(0,134,179)">Hashable</span></span>, <span class="m_-2418809334444009596gmail-pl-c1" style="box-sizing:border-box;color:rgb(0,134,179)">U</span>: <span class="m_-2418809334444009596gmail-pl-e" style="box-sizing:border-box;color:rgb(121,93,163)"><span class="m_-2418809334444009596gmail-pl-c1" style="box-sizing:border-box;color:rgb(0,134,179)">Collection</span></span>&gt; {
    <span class="m_-2418809334444009596gmail-pl-k" style="box-sizing:border-box;color:rgb(167,29,93)">case</span> <span class="m_-2418809334444009596gmail-pl-c1" style="box-sizing:border-box;color:rgb(0,134,179)">bar</span>(<span class="m_-2418809334444009596gmail-pl-en" style="box-sizing:border-box;color:rgb(121,93,163)"><span class="m_-2418809334444009596gmail-pl-smi" style="box-sizing:border-box;color:rgb(51,51,51)">obj</span></span>: T)
    <span class="m_-2418809334444009596gmail-pl-k" style="box-sizing:border-box;color:rgb(167,29,93)">case</span> <span class="m_-2418809334444009596gmail-pl-c1" style="box-sizing:border-box;color:rgb(0,134,179)">baz</span>(<span class="m_-2418809334444009596gmail-pl-en" style="box-sizing:border-box;color:rgb(121,93,163)"><span class="m_-2418809334444009596gmail-pl-smi" style="box-sizing:border-box;color:rgb(51,51,51)">obj</span></span>: U)
}

<span class="m_-2418809334444009596gmail-pl-c" style="box-sizing:border-box;color:rgb(150,152,150)"><span class="m_-2418809334444009596gmail-pl-c" style="box-sizing:border-box">//</span> U is to be casted but it is not even used</span>
<span class="m_-2418809334444009596gmail-pl-c" style="box-sizing:border-box;color:rgb(150,152,150)"></span><span class="m_-2418809334444009596gmail-pl-k" style="box-sizing:border-box;color:rgb(167,29,93)">let</span> foo<span class="m_-2418809334444009596gmail-pl-k" style="box-sizing:border-box;color:rgb(167,29,93)">:</span> Foo<span class="m_-2418809334444009596gmail-pl-k" style="box-sizing:border-box;color:rgb(167,29,93)">&lt;</span><span class="m_-2418809334444009596gmail-pl-c1" style="box-sizing:border-box;color:rgb(0,134,179)">String</span>, [<span class="m_-2418809334444009596gmail-pl-c1" style="box-sizing:border-box;color:rgb(0,134,179)">String</span>]<span class="m_-2418809334444009596gmail-pl-k" style="box-sizing:border-box;color:rgb(167,29,93)">&gt;</span> <span class="m_-2418809334444009596gmail-pl-k" style="box-sizing:border-box;color:rgb(167,29,93)">=</span> .<span class="m_-2418809334444009596gmail-pl-c1" style="box-sizing:border-box;color:rgb(0,134,179)">bar</span>(<span class="m_-2418809334444009596gmail-pl-c1" style="box-sizing:border-box;color:rgb(0,134,179)">obj</span>: <span class="m_-2418809334444009596gmail-pl-s" style="box-sizing:border-box;color:rgb(24,54,145)"><span class="m_-2418809334444009596gmail-pl-pds" style="box-sizing:border-box">"</span>hash<span class="m_-2418809334444009596gmail-pl-pds" style="box-sizing:border-box">"</span></span>)

<span class="m_-2418809334444009596gmail-pl-c" style="box-sizing:border-box;color:rgb(150,152,150)"><span class="m_-2418809334444009596gmail-pl-c" style="box-sizing:border-box">//</span> Creating an optional enum, the generics have to be casted without a value set</span>
<span class="m_-2418809334444009596gmail-pl-c" style="box-sizing:border-box;color:rgb(150,152,150)"><span class="m_-2418809334444009596gmail-pl-c" style="box-sizing:border-box">//</span> The casting is really not needed as the values should be casted not the enum</span>
<span class="m_-2418809334444009596gmail-pl-c" style="box-sizing:border-box;color:rgb(150,152,150)"></span><span class="m_-2418809334444009596gmail-pl-k" style="box-sizing:border-box;color:rgb(167,29,93)">var</span> foo1<span class="m_-2418809334444009596gmail-pl-k" style="box-sizing:border-box;color:rgb(167,29,93)">:</span> Foo<span class="m_-2418809334444009596gmail-pl-k" style="box-sizing:border-box;color:rgb(167,29,93)">&lt;</span><span class="m_-2418809334444009596gmail-pl-c1" style="box-sizing:border-box;color:rgb(0,134,179)">String</span>, [<span class="m_-2418809334444009596gmail-pl-c1" style="box-sizing:border-box;color:rgb(0,134,179)">String</span>]<span class="m_-2418809334444009596gmail-pl-k" style="box-sizing:border-box;color:rgb(167,29,93)">&gt;?</span>

<span class="m_-2418809334444009596gmail-pl-c" style="box-sizing:border-box;color:rgb(150,152,150)"><span class="m_-2418809334444009596gmail-pl-c" style="box-sizing:border-box">//</span> Collections don’t look great either</span>
<span class="m_-2418809334444009596gmail-pl-c" style="box-sizing:border-box;color:rgb(150,152,150)"></span><span class="m_-2418809334444009596gmail-pl-k" style="box-sizing:border-box;color:rgb(167,29,93)">var</span> foos <span class="m_-2418809334444009596gmail-pl-k" style="box-sizing:border-box;color:rgb(167,29,93)">=</span> [Foo<span class="m_-2418809334444009596gmail-pl-k" style="box-sizing:border-box;color:rgb(167,29,93)">&lt;</span><span class="m_-2418809334444009596gmail-pl-c1" style="box-sizing:border-box;color:rgb(0,134,179)">String</span>, [<span class="m_-2418809334444009596gmail-pl-c1" style="box-sizing:border-box;color:rgb(0,134,179)">String</span>]<span class="m_-2418809334444009596gmail-pl-k" style="box-sizing:border-box;color:rgb(167,29,93)">&gt;</span>]()
foos.<span class="m_-2418809334444009596gmail-pl-c1" style="box-sizing:border-box;color:rgb(0,134,179)">append</span>(.<span class="m_-2418809334444009596gmail-pl-c1" style="box-sizing:border-box;color:rgb(0,134,179)">bar</span>(<span class="m_-2418809334444009596gmail-pl-c1" style="box-sizing:border-box;color:rgb(0,134,179)">obj</span>:<span class="m_-2418809334444009596gmail-pl-s" style="box-sizing:border-box;color:rgb(24,54,145)"><span class="m_-2418809334444009596gmail-pl-pds" style="box-sizing:border-box">"</span>hash<span class="m_-2418809334444009596gmail-pl-pds" style="box-sizing:border-box">"</span></span>))</pre></div><p style="box-sizing:border-box;margin-top:0px;margin-bottom:16px;color:rgb(36,41,46);font-family:-apple-system,blinkmacsystemfont,'segoe ui',helvetica,arial,sans-serif,'apple color emoji','segoe ui emoji','segoe ui symbol';font-size:16px" class="">Proposed solution</p><div class="m_-2418809334444009596gmail-highlight-source-swift m_-2418809334444009596gmail-highlight" style="box-sizing:border-box;margin-bottom:16px;color:rgb(36,41,46);font-family:-apple-system,blinkmacsystemfont,'segoe ui',helvetica,arial,sans-serif,'apple color emoji','segoe ui emoji','segoe ui symbol';font-size:16px"><pre style="box-sizing:border-box;font-family:sfmono-regular,consolas,'liberation mono',menlo,courier,monospace;font-size:13.600000381469727px;margin-top:0px;margin-bottom:0px;line-height:1.45;word-wrap:normal;padding:16px;overflow:auto;background-color:rgb(246,248,250);border-top-left-radius:3px;border-top-right-radius:3px;border-bottom-right-radius:3px;border-bottom-left-radius:3px;word-break:normal" class=""><span class="m_-2418809334444009596gmail-pl-k" style="box-sizing:border-box;color:rgb(167,29,93)">enum</span> <span class="m_-2418809334444009596gmail-pl-en" style="box-sizing:border-box;color:rgb(121,93,163)">Foo</span> {
    <span class="m_-2418809334444009596gmail-pl-k" style="box-sizing:border-box;color:rgb(167,29,93)">case</span> <span class="m_-2418809334444009596gmail-pl-c1" style="box-sizing:border-box;color:rgb(0,134,179)">bar</span><span class="m_-2418809334444009596gmail-pl-k" style="box-sizing:border-box;color:rgb(167,29,93)">&lt;</span>T<span class="m_-2418809334444009596gmail-pl-k" style="box-sizing:border-box;color:rgb(167,29,93)">:</span> <span class="m_-2418809334444009596gmail-pl-c1" style="box-sizing:border-box;color:rgb(0,134,179)">Hashable</span><span class="m_-2418809334444009596gmail-pl-k" style="box-sizing:border-box;color:rgb(167,29,93)">&gt;</span>(<span class="m_-2418809334444009596gmail-pl-c1" style="box-sizing:border-box;color:rgb(0,134,179)">obj</span>: T)
    <span class="m_-2418809334444009596gmail-pl-k" style="box-sizing:border-box;color:rgb(167,29,93)">case</span> <span class="m_-2418809334444009596gmail-pl-c1" style="box-sizing:border-box;color:rgb(0,134,179)">baz</span><span class="m_-2418809334444009596gmail-pl-k" style="box-sizing:border-box;color:rgb(167,29,93)">&lt;</span>U<span class="m_-2418809334444009596gmail-pl-k" style="box-sizing:border-box;color:rgb(167,29,93)">:</span> <span class="m_-2418809334444009596gmail-pl-c1" style="box-sizing:border-box;color:rgb(0,134,179)">Collection</span><span class="m_-2418809334444009596gmail-pl-k" style="box-sizing:border-box;color:rgb(167,29,93)">&gt;</span>(<span class="m_-2418809334444009596gmail-pl-c1" style="box-sizing:border-box;color:rgb(0,134,179)">obj</span>: U)
}

<span class="m_-2418809334444009596gmail-pl-c" style="box-sizing:border-box;color:rgb(150,152,150)"><span class="m_-2418809334444009596gmail-pl-c" style="box-sizing:border-box">//</span> generic type inferred on T</span>
<span class="m_-2418809334444009596gmail-pl-c" style="box-sizing:border-box;color:rgb(150,152,150)"></span><span class="m_-2418809334444009596gmail-pl-k" style="box-sizing:border-box;color:rgb(167,29,93)">var</span> foo<span class="m_-2418809334444009596gmail-pl-k" style="box-sizing:border-box;color:rgb(167,29,93)">:</span> Foo <span class="m_-2418809334444009596gmail-pl-k" style="box-sizing:border-box;color:rgb(167,29,93)">=</span> .<span class="m_-2418809334444009596gmail-pl-c1" style="box-sizing:border-box;color:rgb(0,134,179)">bar</span>(<span class="m_-2418809334444009596gmail-pl-c1" style="box-sizing:border-box;color:rgb(0,134,179)">obj</span>: <span class="m_-2418809334444009596gmail-pl-s" style="box-sizing:border-box;color:rgb(24,54,145)"><span class="m_-2418809334444009596gmail-pl-pds" style="box-sizing:border-box">"</span>hash<span class="m_-2418809334444009596gmail-pl-pds" style="box-sizing:border-box">"</span></span>) 

<span class="m_-2418809334444009596gmail-pl-c" style="box-sizing:border-box;color:rgb(150,152,150)"><span class="m_-2418809334444009596gmail-pl-c" style="box-sizing:border-box">//</span> doesn’t need to cast the generic on the optional enum</span>
<span class="m_-2418809334444009596gmail-pl-c" style="box-sizing:border-box;color:rgb(150,152,150)"><span class="m_-2418809334444009596gmail-pl-c" style="box-sizing:border-box">//</span> the associated value will hold the cast</span>
<span class="m_-2418809334444009596gmail-pl-c" style="box-sizing:border-box;color:rgb(150,152,150)"></span><span class="m_-2418809334444009596gmail-pl-k" style="box-sizing:border-box;color:rgb(167,29,93)">var</span> foo1<span class="m_-2418809334444009596gmail-pl-k" style="box-sizing:border-box;color:rgb(167,29,93)">:</span> Foo<span class="m_-2418809334444009596gmail-pl-k" style="box-sizing:border-box;color:rgb(167,29,93)">?</span> 

<span class="m_-2418809334444009596gmail-pl-c" style="box-sizing:border-box;color:rgb(150,152,150)"><span class="m_-2418809334444009596gmail-pl-c" style="box-sizing:border-box">//</span> This also gives better syntax with collections of enums with associated types</span>
<span class="m_-2418809334444009596gmail-pl-c" style="box-sizing:border-box;color:rgb(150,152,150)"></span><span class="m_-2418809334444009596gmail-pl-k" style="box-sizing:border-box;color:rgb(167,29,93)">var</span> foos <span class="m_-2418809334444009596gmail-pl-k" style="box-sizing:border-box;color:rgb(167,29,93)">=</span> [Foo]()
foos.<span class="m_-2418809334444009596gmail-pl-c1" style="box-sizing:border-box;color:rgb(0,134,179)">append</span>(.<span class="m_-2418809334444009596gmail-pl-c1" style="box-sizing:border-box;color:rgb(0,134,179)">bar</span>(<span class="m_-2418809334444009596gmail-pl-c1" style="box-sizing:border-box;color:rgb(0,134,179)">obj</span>: <span class="m_-2418809334444009596gmail-pl-s" style="box-sizing:border-box;color:rgb(24,54,145)"><span class="m_-2418809334444009596gmail-pl-pds" style="box-sizing:border-box">"</span>hey<span class="m_-2418809334444009596gmail-pl-pds" style="box-sizing:border-box">"</span></span>)</pre></div><h2 style="box-sizing:border-box;margin-top:24px;margin-bottom:16px;line-height:1.25;padding-bottom:0.3em;border-bottom-width:1px;border-bottom-style:solid;border-bottom-color:rgb(234,236,239);color:rgb(36,41,46);font-family:-apple-system,blinkmacsystemfont,'segoe ui',helvetica,arial,sans-serif,'apple color emoji','segoe ui emoji','segoe ui symbol'" class=""><a id="m_-2418809334444009596gmail-user-content-source-compatibility" class="m_-2418809334444009596gmail-anchor" href="https://github.com/lostatseajoshua/swift-evolution/tree/master#source-compatibility" style="box-sizing:border-box;background-color:transparent;color:rgb(3,102,214);text-decoration:none;float:left;padding-right:4px;line-height:1" target="_blank"></a>Source compatibility</h2><p style="box-sizing:border-box;margin-top:0px;margin-bottom:16px;color:rgb(36,41,46);font-family:-apple-system,blinkmacsystemfont,'segoe ui',helvetica,arial,sans-serif,'apple color emoji','segoe ui emoji','segoe ui symbol';font-size:16px" class="">This may cause subtle breaking changes for areas in code with generic enum cases. The compiler could help with the change by finding the associated generic and updating the case with the new syntax.</p><h2 style="box-sizing:border-box;margin-top:24px;margin-bottom:16px;line-height:1.25;padding-bottom:0.3em;border-bottom-width:1px;border-bottom-style:solid;border-bottom-color:rgb(234,236,239);color:rgb(36,41,46);font-family:-apple-system,blinkmacsystemfont,'segoe ui',helvetica,arial,sans-serif,'apple color emoji','segoe ui emoji','segoe ui symbol'" class=""><a id="m_-2418809334444009596gmail-user-content-alternatives-considered" class="m_-2418809334444009596gmail-anchor" href="https://github.com/lostatseajoshua/swift-evolution/tree/master#alternatives-considered" style="box-sizing:border-box;background-color:transparent;color:rgb(3,102,214);text-decoration:none;float:left;padding-right:4px;line-height:1" target="_blank"></a>Alternatives considered</h2><p style="box-sizing:border-box;margin-top:0px;margin-bottom:16px;color:rgb(36,41,46);font-family:-apple-system,blinkmacsystemfont,'segoe ui',helvetica,arial,sans-serif,'apple color emoji','segoe ui emoji','segoe ui symbol';font-size:16px" class="">An alternative would be to extend the&nbsp;<code style="box-sizing:border-box;font-family:sfmono-regular,consolas,'liberation mono',menlo,courier,monospace;font-size:13.600000381469727px;padding:0.2em 0px;margin:0px;background-color:rgba(27,31,35,0.0470588);border-top-left-radius:3px;border-top-right-radius:3px;border-bottom-right-radius:3px;border-bottom-left-radius:3px" class="">associatedtype</code>&nbsp;keyword to the enum type.</p><div class="m_-2418809334444009596gmail-highlight-source-swift m_-2418809334444009596gmail-highlight" style="box-sizing:border-box;margin-bottom:16px;color:rgb(36,41,46);font-family:-apple-system,blinkmacsystemfont,'segoe ui',helvetica,arial,sans-serif,'apple color emoji','segoe ui emoji','segoe ui symbol';font-size:16px"><pre style="box-sizing:border-box;font-family:sfmono-regular,consolas,'liberation mono',menlo,courier,monospace;font-size:13.600000381469727px;margin-top:0px;margin-bottom:0px;line-height:1.45;word-wrap:normal;padding:16px;overflow:auto;background-color:rgb(246,248,250);border-top-left-radius:3px;border-top-right-radius:3px;border-bottom-right-radius:3px;border-bottom-left-radius:3px;word-break:normal" class=""><span class="m_-2418809334444009596gmail-pl-k" style="box-sizing:border-box;color:rgb(167,29,93)">enum</span> <span class="m_-2418809334444009596gmail-pl-en" style="box-sizing:border-box;color:rgb(121,93,163)">Foo</span> {
    <span class="m_-2418809334444009596gmail-pl-k" style="box-sizing:border-box;color:rgb(167,29,93)">associatedtype</span> T <span class="m_-2418809334444009596gmail-pl-k" style="box-sizing:border-box;color:rgb(167,29,93)">=</span> <span class="m_-2418809334444009596gmail-pl-c1" style="box-sizing:border-box;color:rgb(0,134,179)">Hashable</span>
    <span class="m_-2418809334444009596gmail-pl-k" style="box-sizing:border-box;color:rgb(167,29,93)">case</span> <span class="m_-2418809334444009596gmail-pl-c1" style="box-sizing:border-box;color:rgb(0,134,179)">bar</span>(<span class="m_-2418809334444009596gmail-pl-en" style="box-sizing:border-box;color:rgb(121,93,163)"><span class="m_-2418809334444009596gmail-pl-smi" style="box-sizing:border-box;color:rgb(51,51,51)">obj</span></span>: T)
}</pre></div></div><div class=""><br class=""></div>Copy of proposal can be found here&nbsp;<a href="https://github.com/lostatseajoshua/swift-evolution/blob/master/NNNN-enum-generic-cases.md" target="_blank" class="">Swift proposal on github</a><span class="HOEnZb"><font color="#888888" class=""><div class=""><div class=""><br class=""></div>-- <br class=""><div class="m_-2418809334444009596gmail_signature">Joshua Alvarado<div class=""><a href="mailto:alvaradojoshua0@gmail.com" target="_blank" class="">alvaradojoshua0@gmail.com</a></div></div>
</div></font></span></div>
<br class="">______________________________<wbr class="">_________________<br class="">
swift-evolution mailing list<br class="">
<a href="mailto:swift-evolution@swift.org" class="">swift-evolution@swift.org</a><br class="">
<a href="https://lists.swift.org/mailman/listinfo/swift-evolution" rel="noreferrer" target="_blank" class="">https://lists.swift.org/<wbr class="">mailman/listinfo/swift-<wbr class="">evolution</a><br class="">
<br class=""></blockquote></div><br class=""></div>
_______________________________________________<br class="">swift-evolution mailing list<br class=""><a href="mailto:swift-evolution@swift.org" class="">swift-evolution@swift.org</a><br class="">https://lists.swift.org/mailman/listinfo/swift-evolution<br class=""></div></blockquote></div><br class=""></body></html>