<div dir="ltr">Ok one last reply to myself...<div><br></div><div><span><div>public class Int16 {</div><div> public init(_ v: UInt8) {}</div><div> public init(_ v: Int8) {}</div><div> </div><div> public init?(_ v: UInt16) {...on overflow return nil...}</div><div> public init(assertValue: UInt16) {...on overflow assert...} // I think we could just drop this</div><div> public init(truncatingValue: UInt16) {...on overflow truncate, alway positive...}</div><div> </div><div> public init?(_ v: Int32) {...on overflow return nil...}</div><div> public init(assertValue: Int32) {...on overflow assert...} // I think we could just drop this</div><div> public init(truncatingValue: Int32) {...on overflow truncate, maintain sign...}</div><div> </div><div> public init?(_ v: UInt32) {...on overflow return nil...}</div><div> public init(assertValue: UInt32) {...on overflow assert...} // I think we could just drop this</div><div> public init(truncatingValue: UInt32) {...on overflow truncate, alway positive...}</div><div> </div><div> ...others...</div><div> </div><div> public init(bitPattern: UInt16) {...close your eyes and copy the bits...}</div><div>}</div><div><br></div><div><br></div><div>let unsigned32 = UInt32(UInt16.max + 50)</div><div><br></div><div>guard let foo = Int16(unsigned32) else {</div><div> throw Blah ...or... assert("BOOM")</div><div>}</div><div>...do stuff...</div><div><br></div><div>...or...</div><div><br></div><div>if let foo = Int16(unsigned32) {</div><div> ...do stuff...</div><div>}</div><div>else {</div><div> ...handle error...</div><div>}</div><div><br></div><div>...or...</div><div><br></div><div>let foo = Int16(truncatingValue: unsigned32)</div><div>...do stuff...</div><div><br></div><div>...or...</div><div><br></div><div>let foo = Int16(assertValue: unsigned32) //again I think we could just drop this</div><div>...do stuff unless I just went boom...</div></span><br></div></div><br><div class="gmail_quote"><div dir="ltr">On Tue, Feb 16, 2016 at 11:57 AM Shawn Erickson <<a href="mailto:shawnce@gmail.com">shawnce@gmail.com</a>> wrote:<br></div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div dir="ltr">Thinking a little more about this how about just adding failable constructors so it becomes easier to deal with runtime narrowing errors for those that need it? (that was my main issue I ran across when using these classes in an early project, I had to put code around things to deal with the edge case that the library was already obviously doing)<div><br></div><div><span><div>extension UInt16 {</div><div> public init(_ v: UInt8)</div><div> public init(_ v: Int8)</div><div> public init(_ v: Int16)</div><div> public init(_ v: UInt32) // runtime narrowing check, asserts BOOOM</div><div> public init?(validatingValue: UInt32) // runtime narrowing check, failable initializer</div><div> public init(truncatingBitPattern: UInt32) // narrowing "fixup" initializer</div><div> public init(_ v: Int32) // runtime narrowing check, asserts BOOOM</div><div> public init?(validatingValue: UInt32) // runtime narrowing check, failable initializer</div><div> public init(truncatingBitPattern: Int32) // narrowing "fixup" initializer</div><div> ...</div><div> public init(bitPattern: Int16) // I know what I doing! (aka live dangerously)</div><div>}</div></span></div><div><br></div><div>Ideally – to me – you would want the failable initializers to be the default ones available with the boom crash ones being something you could switch to use much like the the other special "i know what I am doing ones". Not sure of the naming to use for such an initializer however.</div></div><div dir="ltr"><div><br><div><br></div><div><span><span>-Shawn</span></span></div></div></div><div dir="ltr"><div dir="ltr"><div><div><br><br><div class="gmail_quote"><div dir="ltr">On Tue, Feb 16, 2016 at 11:28 AM Shawn Erickson <<a href="mailto:shawnce@gmail.com" target="_blank">shawnce@gmail.com</a>> wrote:<br></div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div dir="ltr">I believe you stated that you ran across at least two times that runtime checks caught a narrowing error (e.g. overflow) in your recent work. I support runtime checks however I feel in the case of operations that could have a narrowing issue using a failable constructor makes sense. It puts you control in how to deal with a narrowing error. You could assert if you so want (much like what happens now) or you could deal with the edge case. Swift makes the code to deal with a failable initializer generally trivial.<div><br></div><div>It makes you think about this very real pitfall (in some problem domains) when going between numerical types.<br><div><br></div><div>The issue of why are you using unsigned, etc. is orthogonal to this issue. If these types exist in the language folks will use them and it should be safe / consistent for them when they do.</div></div></div><div dir="ltr"><div><div><br><div><br></div><div>-Shawn</div></div></div></div><br><div class="gmail_quote"><div dir="ltr">On Tue, Feb 16, 2016 at 11:11 AM David Turnbull <<a href="mailto:dturnbull@gmail.com" target="_blank">dturnbull@gmail.com</a>> wrote:<br></div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div dir="ltr">Can you show some examples where and why you use not-Int types and this is a problem? What you're suggesting will be a burden to those of us who need bitwise optimizations or work with C APIs.<div><br></div><div>My last week was spent reading files with huffman coding. So I had no choice but to use bitwise operations. My experience is that Swift got this right (except for "<span style="font-size:13px">truncatingBitPattern" taking up 25% of an 80 column line).</span></div><div><span style="font-size:13px"><br></span></div><div>So my question is, "why are you not using Int?" There's plenty of use cases, you just haven't stated yours so we can't understand why the current system is failing you.</div></div><div dir="ltr"><div><span style="font-size:13px"><br></span></div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left-width:1px;border-left-color:rgb(204,204,204);border-left-style:solid;padding-left:1ex"><span style="font-size:13px">Safety does not mean you can easily write code that crashes once it is deployed….</span></blockquote><div><span style="font-size:13px"><br></span></div></div><div dir="ltr"><div>var a = [Int](); a[0]=99</div><div><br></div><div>That was pretty easy. I don't buy into this argument. If you don't want an out of bounds error, you either make sure you don't math your way out of bounds or you check every time before you subscript. I don't see why an integer conversion should be any different.</div></div><div dir="ltr"><div><br></div><div>-david</div></div></blockquote></div></blockquote></div></div></div></div></div></blockquote></div>