[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

Re: Macros Make Me Mad



I agree entirely with your premises.  Macros are language
constructs, and as such have to be held to higher standards.
I don't see how your conclusion follows from this-- that
macros will yield more problems than benefits.

What about all the stuff in Lisp that's already implemented
as macros, for example?  Are you saying it's a lose to have
these operators?  Probably not.  So why is it bad to write more?

I think the root of your mistake is saying that macros    
don't scale to larger groups.  The real truth is that
macros don't scale to stupider groups.  A group of one
idiot can easily render his code unreadable with badly
designed macros.  Whereas a group of smart programmers, 
however large, will be able to use macros in safe ways
that yield net wins.  E.g. by doing bottom-up programming.

To adapt Mike Vanier's LFSP, macros are simply an FFSP.
Macros would only be bad if there were no programmers
S enough to use them safely.   That one I can answer from
experience.  I probably know 50 Lisp hackers personally 
that I would trust to write macros.

Ergo macros are not a bad feature.  At worst they are
a high-end niche feature.  And that kind of feature is
in fact especially interesting to companies in competitive
situations, as I tried to show in Revenge of the Nerds.

--pg

--Todd Proebsting wrote:

> Despite the fact that many folks I respect swear by macros, I've yet to
> feel comfortable with them in a language.  Since LL2, I've been trying
> to figure out what my resistance is based on.
> 
> Let me say that I think that macros are beautiful and powerful and all
> those good things.  Let's not quibble about that.
> 
> Defining a macro is often an act of defining a language construct and
> implementing it.  Reasonably or not, I hold language constructs to a
> higher standard than, say, a mere function definition.  Specifically,
> * I expect language constructs to be implemented perfectly.  I must
> trust my compiler.
> * I expect language constructs to be documented precisely.  I must trust
> the documentation.
> 
> I know precious few programmers who document well at all, much less to
> the level I expect in a language definition, and I know precious few
> programmers who implement and test their own code to the level expected
> in a compiler.  Therefore, I'd expect more problems from macros than
> benefits.
> 
> Are these technical reasons?  No.  But they are practical reasons, and
> ultimately I program practically.  Macros may be great for individuals
> and small groups, but I just don't believe that they scale for these
> non-technical reasons.
> 
> Todd