Lisp2Perl - Lisp to perl compiler

D

David

Thomas said:
Since your system is self-hosting, that shouldn't be a problem. Do
you have something like Common Lisp's eval-when? If not, you should
read the page in the spec

http://www.lispworks.com/reference/HyperSpec/Body/s_eval_w.htm#eval-when

especially the Notes section at the bottom. In CL, forms like defun
and defmacro (when they're toplevel) cause the function to be known at
compile time by using eval-when. It also lets you write your own
forms of this type.




Actually, I think the answer is probably having a clearer concept of
time(s) in your Lisp dialect. When the compiler sees a toplevel form
that macroexpands into (eval-when (compile) ...), it should
recursively invoke itself, to deal with the eval-when, evaluate that
in the Perl interpreter, then get back to the job at hand.




It seems messy. You should be able to start Perl, load all the
functions that your macros use, compile the files defining and using
them, then quit Perl and load the resulting .pl files. Using a
CL-like concept of times (compile/macroexpand, load, and eval) would
help keep things cleaner.

(In my system, the macros are run in the hosting Common Lisp, so my
issues were different. You define Perl functions with perlisp:defun,
but they're not available at compile-time. Macros can use functions
defined with common-lisp:defun).
Hmmm. Yes, that does seem a sensible solution. Thanks for the pointers.
I think I get the general idea of (eval-when). Its _sort of_ how I've
implemented function definitions at the moment - some things macro
expand to a special form which is evaluated at compile time as well as
runtime. I might just implement something closer to the common lisp
eval-when approach (seems a bit cleaner than what I did).

My main concern with all this was how to ensure that I can handle
dependencies between lisp files. If a file of lisp code uses macros
defined in another file then clearly the macro file must be loaded into
the compiler before the first one can be compiled. I wanted to try and
make sure that the required files would be recompiled as necessary (if
they had changed) and then loaded.

Perhaps, though, the thing to do is, as you say, just to load the
required files into the running lisp/perl interpreter by hand before
attempting to compile something which uses them. I wondered how common
lisp handles these sort of things (essentially: building of projects)
and it seems that it doesn't natively. I noticed that there are lisp
libraries for handling this sort of problem, which make it possible to
write build scripts (sort of like make files I guess).

I suppose, then, that the thing to do for a complex, multi file project
is to have a lisp program whose job it is to build the thing, which it
would do by compiling (if required) and loading the lisp source code in
the required order so that macros are defined before they are used.
Then, in my case, the ultimate product of the compilation (a perl
script) would be generated by running that compilation program (with a
repl, say).

Would that be a sensible approach, or am I missing something obvious?

I can see the point of 2 namespaces by the way (particularly when it
comes to macros). I may change to that, or do something like check the
lexical scope to implement some kind of hybrid approach. I thought there
must be a reason for it.
 
P

Pascal Costanza

Pascal said:
Oh dear. This is just another one of those bad examples of unbreakable
abstractions. Unbreakability sucks.

I stand corrected on the approach taken in that paper. Sorry for
misrepresenting it.


Pascal
 
T

Thomas F. Burdick

David said:
My main concern with all this was how to ensure that I can handle
dependencies between lisp files. If a file of lisp code uses macros
defined in another file then clearly the macro file must be loaded into
the compiler before the first one can be compiled. I wanted to try and
make sure that the required files would be recompiled as necessary (if
they had changed) and then loaded.

Perhaps, though, the thing to do is, as you say, just to load the
required files into the running lisp/perl interpreter by hand before
attempting to compile something which uses them. I wondered how common
lisp handles these sort of things (essentially: building of projects)
and it seems that it doesn't natively. I noticed that there are lisp
libraries for handling this sort of problem, which make it possible to
write build scripts (sort of like make files I guess).

Yeah, system construction is extra-standard in CL. It's generally
done with a defsystem facility (eg, ASDF http://www.cliki.net/asdf).
You make a file containing a defsystem form, which is a declarative
way of describing the dependencies in the system. If you want to
compile the system, you tell your defsystem to do so, and it figures
out what order things need to be compiled in, and when/if to load
files during compilation.
I suppose, then, that the thing to do for a complex, multi file project
is to have a lisp program whose job it is to build the thing, which it
would do by compiling (if required) and loading the lisp source code in
the required order so that macros are defined before they are used.
Then, in my case, the ultimate product of the compilation (a perl
script) would be generated by running that compilation program (with a
repl, say).

Would that be a sensible approach, or am I missing something obvious?

Sounds about right. Remember also, you sometimes have control the
order that the resulting files are loaded.
I can see the point of 2 namespaces by the way (particularly when it
comes to macros). I may change to that, or do something like check the
lexical scope to implement some kind of hybrid approach. I thought there
must be a reason for it.

Just like eval-when, most of the decisions made in the design of
Common Lisp are worth considering carefully; in a lot of ways, it's
the collected wisdom of an era of Lisp development. It's far from
perfect, but it is very well designed.

--
/|_ .-----------------------.
,' .\ / | No to Imperialist war |
,--' _,' | Wage class war! |
/ / `-----------------------'
( -. |
| ) |
(`-. '--.)
`. )----'
 

Ask a Question

Want to reply to this thread or ask your own question?

You'll need to choose a username for the site, which only take a couple of moments. After that, you can post your question and our members will help you out.

Ask a Question

Members online

No members online now.

Forum statistics

Threads
474,145
Messages
2,570,826
Members
47,371
Latest member
Brkaa

Latest Threads

Top