Hacker News new | past | comments | ask | show | jobs | submit login

Well, for one it's not actually new. Protocols are interfaces, sets of messages.

Hmm...that would be message-oriented programming, which is what Smalltalk for example has been all about. First equating OO with heavy use of static typing and inheritance (which wasn't the idea), noting that that doesn't actually work (surprise!) and then "inventing" POP...sigh.

https://blog.metaobject.com/2015/06/protocol-oriented-progra...




No, Smalltalk does not have "protocols", traits or interfaces. Everything is dynamically typed ala Objective C.


Last sentence first: Objective-C certainly has (optional) static types and protocols[1][2], or as Java calls them, interfaces. In fact Java interfaces were "borrowed" from Objective-C[3]. In fact, Objective-C needs the types of a message's arguments and return value in order to generate correct code in the general case, and since message names can be ambiguous it needs to know the static type of the receiver (or "close enough") in order to know those static types in the message. If all arguments and the return value are objects, then this is not necessary, this "id subset" has some nice properties.[4]

In Smalltalk, the messages an object responds to are called its protocol.[5]

"Every object in Smalltalk, even a lowly integer, has a set of messages, a protocol, that defines the explicit communication to which that object can respond."

Now that that single protocol for the entire object can be split into multiple meaningful protocols should be obvious, but Alan Kay has also explicitly talked about objects embodying "multiple algebras"[6]

The basic idea of "protocol oriented programming" is that you focus on what an object can do (its interface/protocol) rather than what it is (its class/type) and that Smalltalk certainly did. Whether you check this statically is a secondary and certainly orthogonal concern, but of course there were and are statically typed variants of Smalltalk (such as Strongtal) and type-systems for others Smalltalks.

Traits were introduced in 2003 for Squeak Smalltalk.[7]

[1] https://en.wikipedia.org/wiki/Objective-C#Protocols

[2] https://developer.apple.com/library/archive/documentation/Co...

[3] https://cs.gmu.edu/~sean/stuff/java-objc.html

[4] https://blog.metaobject.com/2014/05/the-spidy-subset-or-avoi...

[5] https://www.cs.virginia.edu/~evans/cs655/readings/smalltalk....

[6] http://www.cs.uni.edu/~wallingf/blog/archives/monthly/2014-0...

[7] http://scg.unibe.ch/archive/papers/Scha03aTraits.pdf




Guidelines | FAQ | Lists | API | Security | Legal | Apply to YC | Contact

Search: