[Haskell-cafe] What *is* a DSL?
Günther Schmidt
gue.schmidt at web.de
Wed Oct 7 11:42:16 EDT 2009
Hi Joe
Am 07.10.2009, 17:26 Uhr, schrieb Joe Fredette <jfredett at gmail.com>:
> Let me add to this, as I've used the term "DSL" without (*gasp*) fully
> understanding it before.
>
Welcome to the club then! :)
> In addition to "What is a DSL", I'd like to ask:
>
> "How is a DSL different from an API?" -- in the sense that an API is a
> set of, say, combinators to filter email + a monad in which to combine
> them. Or even the API in the more traditional sense of the set of
> exposed operations on a given type. Is an API a kind of DSL? A kind of
> Embedded DSL?
>
> Also,
>
> "What is the difference between an EDSL and a DSL?" -- I've got a vague
> intuition of the difference, but am unsure how to particularly delineate
> them.
Well that part I think I can answer.
An EDSL is when you don't start from scratch. IE. when you do not, let's
say build a compiler that parses a String and then eventually "executes"
it.
Rather you define the "Terms", ie. primitive Terms (Terminals) and
Non-Terminals with the means of the "host" language (Haskell in my case).
>
> Also, any good introductory papers/books/other resources on DSLs and how
> to design, build and use them would be _lovely_.
>
Well as a book I could recommend Paul Hudaks "School of Expression". The
way he abstracts is by means of using a DSL. He assembles objects,
Geometrics Regions, Triangles, circles, squares etc. combines them with
the help of functions and *later* evaluates them. Now he is definatly
using a DSL here, but that is by no means the only way of implementing the
abstract through a DSL. Once that has sunk in I suggest papers from Oleg
and others on the subject, but to get started SOE would be a good idea.
Günther
More information about the Haskell-Cafe
mailing list