[Haskell-cafe] To yi or not to yi,
is this really the question? A plea for a cooperative, ubiquitous,
distributed integrated development system.
Pasqualino 'Titto' Assini
tittoassini at gmail.com
Mon Jun 18 10:01:14 EDT 2007
Having just presented a case for the possible rationality of the irrational
decision of creating an Emacs-like IDE in Haskell, I wonder if we should not
be even more irrational and contemplate the possibility of using Haskell to
create a radically different kind of IDE.
New technologies are often used to imitate and reimplement the artefacts of
previous technologies.
In my house, I have a gas-powered fireplace that goes out of its way to
present itself as a Victorian coal-powered fireplace that in turn was just a
clone of the wood-powered fireplace of yore.
The killer application of natural gas as a home heating technology is not,
however, fake fireplaces but rather something completely new and way more
convenient: clean, reliable and affordable central heating.
Emacs was designed in a very different age, with technical limitations and
therefore design constrains quite different from the current ones:
Individual versus collective development:
In the 70/80ties, cooperative development meant having an expert spending
months writing a program in C and then distributing the source on tape to a
few hand-picked peers. These days we create whole encyclopaedias
cooperatively combining the skills of both traditional academic experts and
high school students with too much time on their hands. In the Emacs-age the
emphasis was necessarily on supporting highly-skilled individual programmers.
Now, it should be on supporting distributed, large-scale, communal
development; keeping in mind that not all potential contributors measure 1000
milliOlegs or milliSimons on the Haskell IQ scale.
Local versus ubiquitous access:
In the 70/80ties, people were lucky to have access to a computer terminal,
applications were naturally designed to be run and configured locally. These
days we tend to have multiple computing devices and we expect to be able to
access our data and software from everywhere.
Local versus distributed execution:
Application these days are often run in a distributed environment. Web
applications for example are multi-tier with often one or more servers per
tier.
Simply copying the Emacs model might therefore not do much to address the
needs of a different technological age.
So where should we look for inspiration?
Maybe not very far, the seeds of a possible revolution might have already been
sown.
LambdaBot, hpaste and hoogle as well as the Haskell Wiki and indeed even this
mailing list can all be thought as elements of a cooperative, ubiquitous,
customisable, zero-installation, distributed and integrated (that should be
enough buzzwords for anybody) development system.
What we need is to connect the dots and recognise the possibilities that might
arise from an integration of all these tools in a World-Wide Functional Web.
So, if we let our imagination loose and dream about an IDE for the Internet
age, what would it look like?
My personal dream goes a bit like this:
Simon wakes up in the morning, with an idea for a new GHC extension to
facilitate parallel computing.
He starts up his Web Browser to access the Haskell Integrated Development
Environment.
Visually, it looks pretty much like Eclipse. He can choose among a set of
customisable perspectives for development, editing, browsing, etc.
Each perspective is composed by multiple views displaying different kind of
data (Haskell modules, stack traces, etc).
Internally the IDE is based on a 'remote functional application framework': a
simple, flexible way of composing statically-typed functions in a networked
environment.
Functions (or possibly first-class modules) are made available on the Internet
as source code and/or endpoints (opaque network-accessible implementations).
Functions can take as parameters additional functions.
The IDE window manager is one such function that takes as parameters the
functions that implements the perspectives.
In turn, perspectives take as parameters the functions that implement the
views and so on recursively.
The Haskell editor, for example, take as a parameter a set of String ->
[HaskellSymbol] functions that are used to provide code completion
functionality. One such implementation is provided remotely by the Hoogle
search engine.
Simon has also configured its IDE to use two different function compositions
to compile its code, one is made of stable versions of the GHC modules
(parser, Haskell to Core-Haskell translator, code generators) , another uses
more experimental versions of the same modules.
Being a social, well-meaning guy, Simon marks his new module as 'public'. It
then immediately appears on the Haskell Code Wiki.
The code Wiki is a combination of a classic Wiki, in the sense that it allows
for unrestricted Web based editing, and a revision control system as it
supports multiple branches per page and the definition of named sets of
specific versions of multiple Wiki pages (know as “releases” in the
pre-distributed IDE age).
Oleg notices the appearance of Simon's module, as it appears in the “Current
Haskell News” view of his Haskell Browsing perspective and in a matter of a
few hours publishes on the Wiki a new implementation that demonstrates that a
compiler extension is not really required as, making use of a clever Peano
encoding of type-level delimited-continuations, he can provide the same
functionality and then some with a 40 lines library running on top of the
existing GHC compiler.
The publishing of his code causes a great commotion and induces many would-be
Haskell programmers to give up in desperation and go back to Visual Basic.
Some are so intellectually humiliated that give up programming entirely and
move into the used car sale business.
Luckily, later in the day (PhD students do not wake up early), Neil makes
available its version that has half of the functionality of Simon's, not to
mention Oleg's, but is explained in plain English, requires only Haskell 98
and compiles under YHC. As he is fond of Windows, he also makes a point of
replacing all the "/"s in the source code with "\"s.
A few days later, Titto, a perpetual Haskell beginner, takes Neil's version,
as it is the only one that he can almost make sense of, changes the "\"s back
to "/"s and compiles it in his GHC-based environment.
Titto runs a Web site that is implemented using the same remote functional
application framework used by his IDE. The Web site is made of a set of
function/modules (Web front-end, application server, persistence back end)
distributed on top of a few servers, for performance and reliability.
With a few clicks, he replaces one of the existing Web site modules with a new
implementation based on Neil's parallel library and upgrade its system
without any of his users noticing.
Up to you now, what is your dream?
Best,
titto
More information about the Haskell-Cafe
mailing list