[erlang-questions] LFE - Lisp Flavoured Erlang released

Robert Virding rvirding@REDACTED
Sun Mar 2 23:10:12 CET 2008


OK, some points I forgot to mention:

- Of course, the interpreter does *NOT* handle recursive letrecs, binaries,
receive or try. Yet.
- The token syntax is specified in leex but I have included a copy of a
generated erlang file.
- The compiler is "sensitive" to some errors and will occasionally crash,
though it should only generate correct code.
- The line numbers used in error messages are the line of the beginning of
the form in which the error occurs. As the forms are truly raw data this was
the best way I could get line numbers in.

The answer to Roberto's question about line number 6666 is just I wanted a
big number which was guaranteed not to clash with users code. And 666 seemed
to small. :-)

- I have been thinking about a way to load a module into the shell (when it
exists) and I think I have worked out a way to do it. With a little bit of
luck it should also support macros. You might actually be able to save a
module from the shell as well but I have not thought this through properly
yet.

Please report bugs and other mis-features and I will fix them as soon as I
can. Unfortunately I am using a toy computer so sending out patches will be
difficult.

Robert

On 02/03/2008, Robert Virding <rvirding@REDACTED> wrote:
>
> I have finally released LFE, Lisp Flavoured Erlang, which is a lisp syntax
> front-end to the Erlang compiler. Code produced with it is compatible with
> "normal" Erlang code. The is an LFE-mode for Emacs and the lfe-mode.elfile is include in the distribution. Most things seem to work but some
> things have not been done yet:
>
> - The interpreter does handle recursive letrecs, binaries, receive or try.
>
> - There is no lisp shell.
> - Documentation!
>
> Yet. The system will be updated as new features are added. This is the 1st
> release so there is much left to do.
>
> I have include the existing documentation lfe_guide.txt in this mail.
> There are a number of LFE test files and a version of the LFE interpreter
> written in LFE as examples of code. There are also a number of issues which
> need to be decided for the next version and I have included a file
> lfe_issues.txt which describe them in this mail. Both files are in the
> distribution.
>
> Note that while this this lisp has been inspired by Scheme (one of the
> issues) it is a NOT Scheme, it is Erlang with a lisp syntax and many nice
> lisp features. Not for that matter is it Common Lisp. In fact features of
> the Erlang engine mean that it is actually impossible to implement full
> Scheme of CL. No, they shouldn't be changed or added.
>
> It was quite writing Erlang code in lisp and I could easily consider using
> a lisp syntax for Erlang. I suppose it depends where your preferences lye.
> It was also easy to get into the traditional lisp habit of using long names
> for everything which I personally think is not a Good Thing. Perhaps we
> should do AFE, Arc Flavoured Erlang, instead? Although I think they have
> gone too far and missed what makes programs easy to read.
>
> Macros are very nice, and it is easy to generate LFE code, which is one of
> the benefits of lisp syntax.
>
> LFE also shows that it would probably be possible to write other
> front-ends inspired by other languages, though why anyone should want to I
> don't know. Perhaps back to a real Prolog syntax again.
>
> The system can be found in the "User Contributions" section at
> trapexit.org, http://forum.trapexit.org/viewtopic.php?p=40268#40268.
>
>
>
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://erlang.org/pipermail/erlang-questions/attachments/20080302/8eb9e11e/attachment.htm>


More information about the erlang-questions mailing list