[swift-evolution] [Review] SE-0101: Rename sizeof and related functions to comply with API Guidelines
    Hooman Mehr 
    hooman at mac.com
       
    Tue Jun 28 20:27:48 CDT 2016
    
    
  
How about we get rid of dynamicType by adding instance level properties as well:
public struct MemoryLayout<T> {
    
    public static var size: Int { return sizeof(T) }
    public static var interval: Int { return strideof(T) }
    public static var alignment: Int { return alignof(T) }
    
    public var size: Int { return sizeof(T) }
    public var interval: Int { return strideof(T) }
    public var alignment: Int { return alignof(T) }
    
    init(_ : @autoclosure () -> T) {}
}
print(MemoryLayout<Int>.size) // 8
print(MemoryLayout<Int>.interval) // 8
print(MemoryLayout<Int>.alignment) // 8
let x = 8
print(MemoryLayout(x).size) // 8
print(MemoryLayout(x).interval) // 8
print(MemoryLayout(x).alignment) // 8
> On Jun 28, 2016, at 5:08 PM, Dave Abrahams via swift-evolution <swift-evolution at swift.org> wrote:
> 
> 
> on Tue Jun 28 2016, Brandon Knope <bknope-AT-me.com> wrote:
> 
>> Isn't dynamicType possibly changing soon to a method?
> 
> A free function, I think.
> 
>> This could look much different
> 
> Yes, It will be uglier.  But this very uncommon case is not important to
> optimize for beauty.
> 
> -- 
> Dave
> _______________________________________________
> swift-evolution mailing list
> swift-evolution at swift.org
> https://lists.swift.org/mailman/listinfo/swift-evolution
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <https://lists.swift.org/pipermail/swift-evolution/attachments/20160628/ab5fb2f6/attachment.html>
    
    
More information about the swift-evolution
mailing list