<div dir="ltr"><div class="markdown-here-wrapper" style=""><blockquote style="margin:1.2em 0px;border-left-width:4px;border-left-style:solid;border-left-color:rgb(221,221,221);padding:0px 1em;color:rgb(119,119,119);quotes:none">
<p style="margin:0px 0px 1.2em!important">Consider what I said above, I feel like we should tackle this:</p>
<ul style="margin:1.2em 0px;padding-left:2em">
<li style="margin:0.5em 0px">drop <code style="font-size:0.85em;font-family:Consolas,Inconsolata,Courier,monospace;margin:0px 0.15em;padding:0px 0.3em;white-space:pre-wrap;border:1px solid rgb(234,234,234);border-radius:3px;display:inline;background-color:rgb(248,248,248)">init(_ copy: Type&lt;T&gt;)</code> - to keep equality of <code style="font-size:0.85em;font-family:Consolas,Inconsolata,Courier,monospace;margin:0px 0.15em;padding:0px 0.3em;white-space:pre-wrap;border:1px solid rgb(234,234,234);border-radius:3px;display:inline;background-color:rgb(248,248,248)">Type&lt;T&gt;</code> references</li>
</ul>
</blockquote>
<p style="margin:0px 0px 1.2em!important">Agreed.</p>
<blockquote style="margin:1.2em 0px;border-left-width:4px;border-left-style:solid;border-left-color:rgb(221,221,221);padding:0px 1em;color:rgb(119,119,119);quotes:none">
<ul style="margin:1.2em 0px;padding-left:2em">
<li style="margin:0.5em 0px">make all initializer internal and as exchange make <code style="font-size:0.85em;font-family:Consolas,Inconsolata,Courier,monospace;margin:0px 0.15em;padding:0px 0.3em;white-space:pre-wrap;border:1px solid rgb(234,234,234);border-radius:3px;display:inline;background-color:rgb(248,248,248)">sharedInstance</code> public.</li>
</ul>
<p style="margin:0px 0px 1.2em!important">This would ensure that you will always get a reference from the type storage, and that there can only exist one for each (dynamic) metatype.</p>
</blockquote>
<p style="margin:0px 0px 1.2em!important">I have another idea:</p>
<pre style="font-size:0.85em;font-family:Consolas,Inconsolata,Courier,monospace;font-size:1em;line-height:1.2em;margin:1.2em 0px"><code class="hljs language-swift" style="font-size:0.85em;font-family:Consolas,Inconsolata,Courier,monospace;margin:0px 0.15em;padding:0px 0.3em;white-space:pre-wrap;border:1px solid rgb(234,234,234);border-radius:3px;display:inline;background-color:rgb(248,248,248);white-space:pre;overflow:auto;border-radius:3px;border:1px solid rgb(204,204,204);padding:0.5em 0.7em;display:block!important;display:block;overflow-x:auto;padding:0.5em;color:rgb(51,51,51);background:rgb(248,248,248)"><span class="hljs-comment" style="color:rgb(153,153,136);font-style:italic">// No uniqueness guarantee</span>
internal <span class="hljs-class"><span class="hljs-keyword" style="color:rgb(51,51,51);font-weight:bold">class</span> <span class="hljs-title" style="color:rgb(153,0,0);font-weight:bold;color:rgb(68,85,136);font-weight:bold">_Type</span>&lt;<span class="hljs-title" style="color:rgb(153,0,0);font-weight:bold;color:rgb(68,85,136);font-weight:bold">T</span>&gt; </span>{
    <span class="hljs-keyword" style="color:rgb(51,51,51);font-weight:bold">var</span> _metatype: <span class="hljs-type" style="color:rgb(68,85,136);font-weight:bold">Metatype</span>&lt;<span class="hljs-type" style="color:rgb(68,85,136);font-weight:bold">T</span>&gt;

    <span class="hljs-keyword" style="color:rgb(51,51,51);font-weight:bold">init</span>()
    <span class="hljs-keyword" style="color:rgb(51,51,51);font-weight:bold">init</span>(<span class="hljs-number" style="color:rgb(0,128,128)">_</span>: <span class="hljs-type" style="color:rgb(68,85,136);font-weight:bold">AnyMetatype</span>)
    <span class="hljs-keyword" style="color:rgb(51,51,51);font-weight:bold">init</span>?&lt;<span class="hljs-type" style="color:rgb(68,85,136);font-weight:bold">U</span>&gt;(casting: <span class="hljs-type" style="color:rgb(68,85,136);font-weight:bold">Type</span>&lt;<span class="hljs-type" style="color:rgb(68,85,136);font-weight:bold">U</span>&gt;)

    <span class="hljs-comment" style="color:rgb(153,153,136);font-style:italic">// Instead of a global dictionary</span>
    <span class="hljs-keyword" style="color:rgb(51,51,51);font-weight:bold">class</span> <span class="hljs-keyword" style="color:rgb(51,51,51);font-weight:bold">var</span> sharedInstance: _Type&lt;<span class="hljs-type" style="color:rgb(68,85,136);font-weight:bold">T</span>&gt;
}

<span class="hljs-comment" style="color:rgb(153,153,136);font-style:italic">// Uniqueness guarantee</span>
public <span class="hljs-class"><span class="hljs-keyword" style="color:rgb(51,51,51);font-weight:bold">struct</span> <span class="hljs-title" style="color:rgb(153,0,0);font-weight:bold;color:rgb(68,85,136);font-weight:bold">Type</span>&lt;<span class="hljs-title" style="color:rgb(153,0,0);font-weight:bold;color:rgb(68,85,136);font-weight:bold">T</span>&gt; </span>{
    internal <span class="hljs-keyword" style="color:rgb(51,51,51);font-weight:bold">var</span> impl: _Type&lt;<span class="hljs-type" style="color:rgb(68,85,136);font-weight:bold">T</span>&gt;

    public <span class="hljs-keyword" style="color:rgb(51,51,51);font-weight:bold">init</span>()
    public <span class="hljs-keyword" style="color:rgb(51,51,51);font-weight:bold">init</span>(<span class="hljs-number" style="color:rgb(0,128,128)">_</span>: <span class="hljs-type" style="color:rgb(68,85,136);font-weight:bold">AnyMetatype</span>)
    public <span class="hljs-keyword" style="color:rgb(51,51,51);font-weight:bold">init</span>?&lt;<span class="hljs-type" style="color:rgb(68,85,136);font-weight:bold">U</span>&gt;(casting: <span class="hljs-type" style="color:rgb(68,85,136);font-weight:bold">Type</span>&lt;<span class="hljs-type" style="color:rgb(68,85,136);font-weight:bold">U</span>&gt;)
}
</code></pre>
<blockquote style="margin:1.2em 0px;border-left-width:4px;border-left-style:solid;border-left-color:rgb(221,221,221);padding:0px 1em;color:rgb(119,119,119);quotes:none">
<p style="margin:0px 0px 1.2em!important">I can’t foresee the future, so I’m wondering if the type may mutate somehow when reflections are added?</p>
</blockquote>
<p style="margin:0px 0px 1.2em!important">I don’t think so. If added at all, types should only be able to be created using some kind of builder:</p>
<pre style="font-size:0.85em;font-family:Consolas,Inconsolata,Courier,monospace;font-size:1em;line-height:1.2em;margin:1.2em 0px"><code class="hljs language-swift" style="font-size:0.85em;font-family:Consolas,Inconsolata,Courier,monospace;margin:0px 0.15em;padding:0px 0.3em;white-space:pre-wrap;border:1px solid rgb(234,234,234);border-radius:3px;display:inline;background-color:rgb(248,248,248);white-space:pre;overflow:auto;border-radius:3px;border:1px solid rgb(204,204,204);padding:0.5em 0.7em;display:block!important;display:block;overflow-x:auto;padding:0.5em;color:rgb(51,51,51);background:rgb(248,248,248)"><span class="hljs-keyword" style="color:rgb(51,51,51);font-weight:bold">let</span> builder = <span class="hljs-type" style="color:rgb(68,85,136);font-weight:bold">TypeBuilder</span>(name: <span class="hljs-string" style="color:rgb(221,17,68)">&quot;Person&quot;</span>, kind: .<span class="hljs-class"><span class="hljs-keyword" style="color:rgb(51,51,51);font-weight:bold">struct</span>)
<span class="hljs-title" style="color:rgb(153,0,0);font-weight:bold;color:rgb(68,85,136);font-weight:bold">builder</span>.<span class="hljs-title" style="color:rgb(153,0,0);font-weight:bold;color:rgb(68,85,136);font-weight:bold">addField</span>(<span class="hljs-title" style="color:rgb(153,0,0);font-weight:bold;color:rgb(68,85,136);font-weight:bold">name</span>: &quot;&quot;, <span class="hljs-title" style="color:rgb(153,0,0);font-weight:bold;color:rgb(68,85,136);font-weight:bold">type</span>: <span class="hljs-title" style="color:rgb(153,0,0);font-weight:bold;color:rgb(68,85,136);font-weight:bold">Int</span>.<span class="hljs-title" style="color:rgb(153,0,0);font-weight:bold;color:rgb(68,85,136);font-weight:bold">self</span>)
//...
<span class="hljs-title" style="color:rgb(153,0,0);font-weight:bold;color:rgb(68,85,136);font-weight:bold">let</span> <span class="hljs-title" style="color:rgb(153,0,0);font-weight:bold;color:rgb(68,85,136);font-weight:bold">typeRef</span> = <span class="hljs-title" style="color:rgb(153,0,0);font-weight:bold;color:rgb(68,85,136);font-weight:bold">builder</span>.<span class="hljs-title" style="color:rgb(153,0,0);font-weight:bold;color:rgb(68,85,136);font-weight:bold">create</span>()</span>
</code></pre>
<div title="MDH:PGRpdiBjbGFzcz0iZ21haWxfZXh0cmEiPjxkaXYgY2xhc3M9ImdtYWlsX2V4dHJhIj4mZ3Q7Q29u
c2lkZXIgd2hhdCBJIHNhaWQgYWJvdmUsIEkgZmVlbCBsaWtlIHdlIHNob3VsZCB0YWNrbGUgdGhp
czo8L2Rpdj48ZGl2IGNsYXNzPSJnbWFpbF9leHRyYSI+Jmd0OzwvZGl2PjxkaXYgY2xhc3M9Imdt
YWlsX2V4dHJhIj4mZ3Q7KiBkcm9wIGBpbml0KF8gY29weTogVHlwZSZsdDtUJmd0OylgIC0gdG8g
a2VlcCBlcXVhbGl0eSBvZiBgVHlwZSZsdDtUJmd0O2AgcmVmZXJlbmNlczwvZGl2PjxkaXYgY2xh
c3M9ImdtYWlsX2V4dHJhIj48YnI+PC9kaXY+PGRpdiBjbGFzcz0iZ21haWxfZXh0cmEiPkFncmVl
ZC48L2Rpdj48ZGl2IGNsYXNzPSJnbWFpbF9leHRyYSI+PGJyPjwvZGl2PjxkaXYgY2xhc3M9Imdt
YWlsX2V4dHJhIj4mZ3Q7KiBtYWtlIGFsbCBpbml0aWFsaXplciBpbnRlcm5hbCBhbmQgYXMgZXhj
aGFuZ2UgbWFrZSBgc2hhcmVkSW5zdGFuY2VgIHB1YmxpYy48L2Rpdj48ZGl2IGNsYXNzPSJnbWFp
bF9leHRyYSI+Jmd0OzwvZGl2PjxkaXYgY2xhc3M9ImdtYWlsX2V4dHJhIj4mZ3Q7VGhpcyB3b3Vs
ZCBlbnN1cmUgdGhhdCB5b3Ugd2lsbCBhbHdheXMgZ2V0IGEgcmVmZXJlbmNlIGZyb20gdGhlIHR5
cGUgc3RvcmFnZSwgYW5kIHRoYXQgdGhlcmUgY2FuIG9ubHkgZXhpc3Qgb25lIGZvciBlYWNoIChk
eW5hbWljKSBtZXRhdHlwZS48L2Rpdj48ZGl2IGNsYXNzPSJnbWFpbF9leHRyYSI+PGJyPjwvZGl2
PjxkaXYgY2xhc3M9ImdtYWlsX2V4dHJhIj5JIGhhdmUgYW5vdGhlciBpZGVhOjwvZGl2PjxkaXYg
Y2xhc3M9ImdtYWlsX2V4dHJhIj48YnI+PC9kaXY+PGRpdiBjbGFzcz0iZ21haWxfZXh0cmEiPmBg
YHN3aWZ0PC9kaXY+PGRpdiBjbGFzcz0iZ21haWxfZXh0cmEiPi8vIE5vIHVuaXF1ZW5lc3MgZ3Vh
cmFudGVlPC9kaXY+PGRpdiBjbGFzcz0iZ21haWxfZXh0cmEiPmludGVybmFsIGNsYXNzIF9UeXBl
Jmx0O1QmZ3Q7IHs8L2Rpdj48ZGl2IGNsYXNzPSJnbWFpbF9leHRyYSI+Jm5ic3A7ICZuYnNwOyB2
YXIgX21ldGF0eXBlOiBNZXRhdHlwZSZsdDtUJmd0OzwvZGl2PjxkaXYgY2xhc3M9ImdtYWlsX2V4
dHJhIj48YnI+PC9kaXY+PGRpdiBjbGFzcz0iZ21haWxfZXh0cmEiPiZuYnNwOyAmbmJzcDsgaW5p
dCgpPC9kaXY+PGRpdiBjbGFzcz0iZ21haWxfZXh0cmEiPiZuYnNwOyAmbmJzcDsgaW5pdChfOiBB
bnlNZXRhdHlwZSk8L2Rpdj48ZGl2IGNsYXNzPSJnbWFpbF9leHRyYSI+Jm5ic3A7ICZuYnNwOyBp
bml0PyZsdDtVJmd0OyhjYXN0aW5nOiBUeXBlJmx0O1UmZ3Q7KTwvZGl2PjxkaXYgY2xhc3M9Imdt
YWlsX2V4dHJhIj48YnI+PC9kaXY+PGRpdiBjbGFzcz0iZ21haWxfZXh0cmEiPiZuYnNwOyAmbmJz
cDsgLy8gSW5zdGVhZCBvZiBhIGdsb2JhbCBkaWN0aW9uYXJ5PC9kaXY+PGRpdiBjbGFzcz0iZ21h
aWxfZXh0cmEiPiZuYnNwOyAmbmJzcDsgY2xhc3MgdmFyIHNoYXJlZEluc3RhbmNlOiBfVHlwZSZs
dDtUJmd0OzwvZGl2PjxkaXYgY2xhc3M9ImdtYWlsX2V4dHJhIj59PC9kaXY+PGRpdiBjbGFzcz0i
Z21haWxfZXh0cmEiPjxicj48L2Rpdj48ZGl2IGNsYXNzPSJnbWFpbF9leHRyYSI+PGJyPjwvZGl2
PjxkaXYgY2xhc3M9ImdtYWlsX2V4dHJhIj48YnI+PC9kaXY+PGRpdiBjbGFzcz0iZ21haWxfZXh0
cmEiPi8vIFVuaXF1ZW5lc3MgZ3VhcmFudGVlPC9kaXY+PGRpdiBjbGFzcz0iZ21haWxfZXh0cmEi
PnB1YmxpYyBzdHJ1Y3QgVHlwZSZsdDtUJmd0OyB7PC9kaXY+PGRpdiBjbGFzcz0iZ21haWxfZXh0
cmEiPiZuYnNwOyAmbmJzcDsgaW50ZXJuYWwgdmFyIGltcGw6IF9UeXBlJmx0O1QmZ3Q7PC9kaXY+
PGRpdiBjbGFzcz0iZ21haWxfZXh0cmEiPjxicj48L2Rpdj48ZGl2IGNsYXNzPSJnbWFpbF9leHRy
YSI+Jm5ic3A7ICZuYnNwOyBwdWJsaWMgaW5pdCgpPC9kaXY+PGRpdiBjbGFzcz0iZ21haWxfZXh0
cmEiPiZuYnNwOyAmbmJzcDsgcHVibGljIGluaXQoXzogQW55TWV0YXR5cGUpPC9kaXY+PGRpdiBj
bGFzcz0iZ21haWxfZXh0cmEiPiZuYnNwOyAmbmJzcDsgcHVibGljIGluaXQ/Jmx0O1UmZ3Q7KGNh
c3Rpbmc6IFR5cGUmbHQ7VSZndDspPC9kaXY+PGRpdiBjbGFzcz0iZ21haWxfZXh0cmEiPn08L2Rp
dj48ZGl2IGNsYXNzPSJnbWFpbF9leHRyYSI+YGBgPC9kaXY+PGRpdiBjbGFzcz0iZ21haWxfZXh0
cmEiPjxicj48L2Rpdj48ZGl2IGNsYXNzPSJnbWFpbF9leHRyYSI+Jmd0OyZuYnNwO0kgY2Fu4oCZ
dCBmb3Jlc2VlIHRoZSBmdXR1cmUsIHNvIEnigJltIHdvbmRlcmluZyBpZiB0aGUgdHlwZSBtYXkg
bXV0YXRlIHNvbWVob3cgd2hlbiByZWZsZWN0aW9ucyBhcmUgYWRkZWQ/PC9kaXY+PGRpdiBjbGFz
cz0iZ21haWxfZXh0cmEiPjxicj48L2Rpdj48ZGl2IGNsYXNzPSJnbWFpbF9leHRyYSI+SSBkb24n
dCB0aGluayBzby4gSWYgYWRkZWQgYXQgYWxsLCB0eXBlcyBzaG91bGQgb25seSBiZSBhYmxlIHRv
IGJlIGNyZWF0ZWQgdXNpbmcgc29tZSBraW5kIG9mIGJ1aWxkZXI6PC9kaXY+PGRpdiBjbGFzcz0i
Z21haWxfZXh0cmEiPjxicj48L2Rpdj48ZGl2IGNsYXNzPSJnbWFpbF9leHRyYSI+YGBgc3dpZnQ8
L2Rpdj48ZGl2IGNsYXNzPSJnbWFpbF9leHRyYSI+bGV0IGJ1aWxkZXIgPSBUeXBlQnVpbGRlcihu
YW1lOiAiUGVyc29uIiwga2luZDogLnN0cnVjdCk8L2Rpdj48ZGl2IGNsYXNzPSJnbWFpbF9leHRy
YSI+YnVpbGRlci5hZGRGaWVsZChuYW1lOiAiIiwgdHlwZTogSW50LnNlbGYpPC9kaXY+PGRpdiBj
bGFzcz0iZ21haWxfZXh0cmEiPi8vLi4uPC9kaXY+PGRpdiBjbGFzcz0iZ21haWxfZXh0cmEiPmxl
dCB0eXBlUmVmID0mbmJzcDtidWlsZGVyLmNyZWF0ZSgpPC9kaXY+PGRpdiBjbGFzcz0iZ21haWxf
ZXh0cmEiPmBgYDwvZGl2PjwvZGl2Pg==" style="height:0;width:0;max-height:0;max-width:0;overflow:hidden;font-size:0em;padding:0;margin:0">​</div></div></div>