Re: Complex compiler/linker tests

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

 



Ralf,

One trivial example would be a test to detect whether or not a compiler collapses static locals in inline functions occurring in both library and user program. It would require a library and a program, e.g.:

// lib.cpp
inline int foo ()
{
    static int i = 0;
    return ++i;
}

int bar ()
{
    return foo ();
}

// prog.cpp
inline int foo ()
{
    static int i = 0;
    return ++i;
}

extern int bar ();

int main ()
{
    int i = foo();
    int j = bar ();
    return !(i != j);
}

The program returns 0 is the linker correctly collapses the two "static int i".

Anyhoo, I started already looking into autoconf internal macros (e.g. _AC_COMPILE_IFELSE) and it looks pretty straightforward if I take that as a model and don't make unrealistic assumptions about what goes where.

So, the functionality I am going to need would be:
1. macro to compile and link an arbitrary number of source files into a
   library or program
2. macro to compile arbitrary number of source files and link them with
   specified libraries

Any input is appreciated as to the usefulness of this set of macros, esp. from autoconf developers.

Thank you.

Liviu

Ralf Wildenhues wrote:
Hi Liviu,

* Liviu Nicoara wrote on Tue, Jun 28, 2005 at 01:59:55AM CEST:

There are situations where a C++ comptest needs to have multiple translation units. These need to be compiled and the object files linked together, and posibbly, the resulting program needs to be run.


Could you describe an example where this is necessary?


I could not find a way of doing this in an easy way using the "public interface" of autoconf. Is it at all possible?


I'd say it's probably at least quite cumbersome.  Much of Autoconf
assumes only one source file, named `conftest.*'.  You'd either have to
munge unpublished internal variables or you'd have to give up quite a
bit of Autoconf functionality.


Would I need to roll my own macros for this?


Hmm, I'd say if it turns out to be useful to have such functionality,
then Autoconf should probably provide it.  Just my .02 cents, I'm not an
Autoconf developer.

Regards,
Ralf




_______________________________________________
Autoconf mailing list
Autoconf@xxxxxxx
http://lists.gnu.org/mailman/listinfo/autoconf

[Index of Archives]     [GCC Help]     [Kernel Discussion]     [RPM Discussion]     [Red Hat Development]     [Yosemite News]     [Linux USB]     [Samba]

  Powered by Linux