comp.lang.ada
 help / color / mirror / Atom feed
From: "Marin David Condic" <marin.condic.auntie.spam@pacemicro.com>
Subject: Re: Implementing C/C++ style #include...
Date: Thu, 22 Mar 2001 10:23:16 -0500
Date: 2001-03-22T15:23:31+00:00	[thread overview]
Message-ID: <99d5dj$fi4$1@nh.pace.co.uk> (raw)
In-Reply-To: tbk5cb2rf5aef0@corp.supernews.com

Dead code optimization was brought up in another sub-thread. I agree that
this is a good trick suitable for many of the things usually done by
preprocessors.

If one is willing to live with a rather primitive preprocessor, it might not
be that big a job to simply recognize some simple markers and
comment/uncomment code (or just remove it) as needed for test. Its just that
it usually isn't long before someone wants to have somewhat more
sophisticated features available.

Its like I said: How much work do you want to do? I don't think there are
enough benefits from a preprocessor to make it worth the time it would take
to develop one. I understand that your garden variety C/C++ programmer is
used to having one around and may want to lean on one for comfort while
moving into The Ada Way(tm). (Hacking C code in Ada syntax, as it were.)

I just distrust this sort of add-on to a language and I think Ada is rich
enough to get the job done without a preprocessor. If a programmer is used
to thinking in terms of lexical inclusion rather than semantic inclusion,
preprocessors behave more the way they are used to working. If you make the
mental shift into packages, generics, "with" statements, etc., you probably
won't feel the need to rely on preprocessors since you'll evolve mechanisms
to do the same job in The Ada Way.

MDC
--
Marin David Condic
Senior Software Engineer
Pace Micro Technology Americas    www.pacemicro.com
Enabling the digital revolution
e-Mail:    marin.condic@pacemicro.com
Web:      http://www.mcondic.com/


"Ira D. Baxter" <idbaxter@semdesigns.com> wrote in message
news:tbk5cb2rf5aef0@corp.supernews.com...
> One can take advantage of dead code optimization
> to eliminate conditionally-compiled code.  So you
> don't really need a preprocessor for that.
>
> There isn't any standard in Ada for conditional compilation
> of data declarations (or even pragmas!).  This
> is probably enough to justify a preprocessor of some kind.
>
> Building one out of conventional tools such as YACC
> is probably pretty hard.  You can certainly hack
> a simple one in PERL, if you want, by defining
> it to operate on lines that start with #, say.
>
> However, if you want one integrated with the Ada source,
> you could do that pretty easily by augmenting
> an Ada grammar with a few rules, and
> using a transformation engine such as our DMS Reengineering Toolkit
> (see http://www.semdesigns.com/Products/DMS/DMSToolkit.html).
> DMS can be obtained with an Ada grammar.
> Rewrite rules for simplifying boolean equations are pretty
> easy, as are rules that eliminate conditionals conditioned by TRUE or
FALSE.
> Such rules coupled with boolean conditions would
> give an Ada preprocessor with only small effort.
>
> --
> Ira D. Baxter, Ph.D. CTO Semantic Designs, Inc.
> http://www.semdesigns.com
>
> "Marin David Condic" <marin.condic.auntie.spam@pacemicro.com> wrote in
> message news:99alrr$itf$1@nh.pace.co.uk...
> > "bhazzard" <bhazzard@email.msn.com> wrote in message
> > news:OrZxgIisAHA.289@cpmsnbbsa09...
> > > A quick question...
> > >
> > > Is there any way to implement c/c++ style
> > > #ifdef pre-processor statements in Ada.
> > >
> > There is always a way. If you're willing to do the work yourself, you
can
> > write a program to parse your Ada code to look for preprocessor
directives
> &
> > output appropriate *new* Ada code before doing the compile. This is a
lot
> of
> > work
>
>





  reply	other threads:[~2001-03-22 15:23 UTC|newest]

Thread overview: 115+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2001-03-13 18:37 Better support for garbage collection Nick Roberts
2001-03-14  8:16 ` Florian Weimer
2001-03-14 18:52   ` Robert A Duff
2001-03-14 19:40     ` Florian Weimer
2001-03-15 13:18       ` Nick Roberts
2001-03-14 19:29 ` Robert A Duff
2001-03-14 20:59   ` Brian Rogoff
2001-03-16 16:42     ` Robert A Duff
2001-03-17  6:13       ` Lao Xiao Hai
2001-03-24  4:08       ` Brian Rogoff
2001-03-15  4:35   ` Nick Roberts
2001-03-15 21:37     ` Randy Brukardt
2001-03-15 22:36     ` Stephen Leake
2001-03-16 16:26     ` Robert A Duff
2001-03-16 16:59       ` Brian Rogoff
2001-03-16 17:31         ` Robert A Duff
2001-03-16 18:29           ` Brian Rogoff
2001-03-17  2:30           ` Nick Roberts
2001-03-17 21:59             ` Robert A Duff
2001-03-17 22:57             ` Static typing (Was Re: Better support for garbage collection) Brian Rogoff
2001-03-17 23:45               ` Robert A Duff
2001-03-18  0:58                 ` Brian Rogoff
2001-03-19 15:24                   ` Robert A Duff
2001-03-20  4:21                     ` Brian Rogoff
2001-03-21  1:32                       ` Ken Garlington
2001-03-21 13:28                         ` Robert A Duff
2001-03-22  2:08                           ` Ken Garlington
2001-03-22 16:40                             ` Robert A Duff
2001-03-25 16:21                               ` Ken Garlington
2001-03-25 16:56                                 ` Ken Garlington
2001-03-25 22:31                                 ` Robert A Duff
2001-03-27  0:24                                   ` Ken Garlington
2001-03-28 23:15                                     ` Robert A Duff
2001-03-29  5:02                                       ` Ken Garlington
2001-03-29  6:13                                         ` David Starner
2001-03-29 10:10                                           ` AG
2001-03-29 14:28                                           ` Ken Garlington
2001-03-29 23:46                                         ` Robert A Duff
2001-03-30  3:41                                           ` Ken Garlington
2001-03-30 21:21                                             ` Robert A Duff
2001-03-31 19:30                                               ` Ken Garlington
2001-04-02 15:27                                                 ` Robert A Duff
2001-04-02 23:29                                                   ` Ken Garlington
2001-03-30 21:29                                             ` Robert A Duff
2001-03-30  9:16                                           ` Dmitry Kazakov
2001-03-30  9:51                                             ` Florian Weimer
2001-04-02  8:54                                               ` Dmitry Kazakov
2001-03-30 16:13                                             ` Ken Garlington
2001-04-02 11:00                                               ` Dmitry Kazakov
2001-03-30 20:44                                             ` Robert C. Leif, Ph.D.
2001-04-02 11:29                                               ` Dmitry Kazakov
2001-04-02 13:15                                                 ` Robert A Duff
2001-04-03  8:57                                                   ` Dmitry Kazakov
2001-03-27  2:39                             ` Andrew Berg
2001-03-27  3:33                               ` Ken Garlington
2001-03-27 14:23                                 ` Robert A Duff
2001-03-27 23:36                                   ` Ken Garlington
2001-03-29 23:50                       ` Robert A Duff
2001-03-19 18:24       ` Better support for garbage collection Tucker Taft
     [not found]   ` <87bsr46kxv.fsf@deneb.enyo.de>
2001-03-15 14:18     ` Robert A Duff
2001-03-15 16:36       ` Florian Weimer
2001-03-14 22:05 ` Laurent Guerby
2001-03-16 16:47   ` Robert A Duff
2001-03-16 19:46     ` Laurent Guerby
2001-03-16 20:10       ` Robert A Duff
2001-03-17 13:14         ` Support for per allocation pool selection (was: Better support for garbage collection) Laurent Guerby
2001-03-17 17:06           ` Robert A Duff
2001-03-17 19:19           ` Florian Weimer
2001-03-17 21:10             ` Robert A Duff
2001-03-15 17:56 ` Better support for garbage collection Ray Blaak
2001-03-21 16:15 ` Implementing C/C++ style #include bhazzard
2001-03-21 16:45   ` Marin David Condic
2001-03-22 15:13     ` Ira D. Baxter
2001-03-22 15:23       ` Marin David Condic [this message]
2001-03-25 15:45         ` Anton Gibbs
2001-03-26 14:24           ` Ted Dennison
2001-03-26 15:00             ` Marin David Condic
2001-03-26 14:49           ` Marin David Condic
2001-03-26 18:19             ` Stephen Leake
2001-03-26 18:44               ` Pascal Obry
2001-03-26 21:44                 ` Robert A Duff
2001-03-27  3:02                   ` Andrew Berg
2001-03-27  3:27                     ` Phaedrus
2001-03-27 17:41                   ` Pascal Obry
2001-03-26 19:18               ` Ted Dennison
2001-03-27 18:51                 ` Anton Gibbs
2001-03-26 19:35               ` Marin David Condic
2001-03-26 23:04                 ` Mark Lundquist
2001-03-27 14:38                   ` Marin David Condic
2001-03-26 16:12           ` Florian Weimer
2001-03-26 17:34             ` David Starner
2001-03-26 22:25               ` Florian Weimer
2001-03-27  3:29                 ` David Starner
2001-03-26 18:23             ` Stephen Leake
2001-03-26 22:34               ` Florian Weimer
2001-03-27  7:34         ` Ole-Hjalmar Kristensen
2001-03-27 12:43           ` Dale Stanbrough
2001-03-27 14:40             ` Marin David Condic
2001-03-27 15:01             ` Ted Dennison
2001-03-27 13:20           ` Preben Randhol
2001-03-23 17:39       ` Wes Groleau
2001-03-21 18:07   ` Mark Lundquist
2001-03-22 12:50   ` Chris M. Moore
2001-03-22 14:30     ` Marin David Condic
2001-03-22 21:15       ` singlespeeder
2001-03-22 21:42         ` Marin David Condic
2001-03-23 14:43           ` Georg Bauhaus
2001-03-23 18:51             ` Marin David Condic
2001-03-22 15:02     ` Pat Rogers
2001-03-22 15:28       ` Marin David Condic
2001-03-22 16:32       ` Chris M. Moore
2001-03-22 16:57       ` Robert A Duff
2001-03-26 16:13   ` Martin Dowie
2001-03-26 22:55   ` Phaedrus
2001-03-27  1:36     ` tmoran
replies disabled

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox