From 2010 to 2014 I was a member of the jury of the annual Vlaamse Programmeerwedstrijd (Flemish Programming Contest), a regional hands-on programming contest for students and professionals, inspired by ACM programming contests. I was main organizer of the 2013 edition, attracting over 500 participants. I was also involved in the organization of the Belgian Olympiad in Informatics.
I’ve been inspired the most by the following language designers:
- Mark Miller, creator of E, for showing that security and modularity are two sides of the same coin.
- Rich Hickey, creator of Clojure, for clearly articulating the differences between state and identity.
- Doug Crockford, discoverer of JSON, for showing that less can be a lot more.
- Dave Ungar and Randy Smith, creators of Self, for stressing the power of simplicity.
- Alan Kay, creator of Smalltalk, for stressing uniformity.
- Rob Pike, creator of Limbo, Plan 9 and Go, for reminding me of the power of CSP-style concurrency.
- Joe Armstrong, creator of Erlang, for showing that actors can be damned practical for building robust software.
Power to the lambda!
In its semantic structure Scheme is as closely akin to Algol 60 as to early Lisps. Algol 60, never to be an active language again, lives on in the genes of Scheme and Pascal. It would be difficult to find two languages that are the communicating coin of two more different cultures than those gathered around these two languages. Pascal is for building pyramids -- imposing, breathtaking, static structures built by armies pushing heavy blocks into place. Lisp is for building organisms -- imposing, breathtaking, dynamic structures built by squads fitting fluctuating myriads of simpler organisms into place. The organizing principles used are the same in both cases, except for one extraordinarily important difference: The discretionary exportable functionality entrusted to the individual Lisp programmer is more than an order of magnitude greater than that to be found within Pascal enterprises. Lisp programs inflate libraries with functions whose utility transcends the application that produced them. The list, Lisp's native data structure, is largely responsible for such growth of utility. The simple structure and natural applicability of lists are reflected in functions that are amazingly nonidiosyncratic. In Pascal the plethora of declarable data structures induces a specialization within functions that inhibits and penalizes casual cooperation. It is better to have 100 functions operate on one data structure than to have 10 functions operate on 10 data structures. As a result the pyramid must stand unchanged for a millennium; the organism must evolve or perish.
- Alan Perlis, from the foreword of the book Structure and Interpretation of Computer Programs by Abelson and Sussman.