From: Ian Lance Taylor Date: Thu, 29 Sep 1994 16:42:43 +0000 (+0000) Subject: missed this file X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=f2b38b9848d787bd675fdf02b783140f96def027;p=binutils-gdb.git missed this file --- diff --git a/ld/testsuite/ld-cdtest/cdtest-main.cc b/ld/testsuite/ld-cdtest/cdtest-main.cc new file mode 100644 index 00000000000..4b99b5c5f0f --- /dev/null +++ b/ld/testsuite/ld-cdtest/cdtest-main.cc @@ -0,0 +1,40 @@ +// main program for Class Foo + +extern "C" { +// Some implementations (e.g. SUNOS 4.1) are broken, +// in that they require . But, if gcc/g++ is installed +// correctly, you should get gcc's assert.h. +// If the compile fails, it means the wrong include files are in use! +#include +}; +#include "cdtest-foo.h" + +extern "C" void __init_start(); + +extern Foo f(void); +extern void g(void); + +/* This function should *not* be called by the environment. There is + no way in C++ to ``run something after the initializers but before main()''. + The library that depends on this (NIHCL) is broken. -- John Gilmore + We leave this here to test that future changes to the compiler + do not re-introduce this losing ``feature''. */ +void +__init_start() +{ + Foo::init_foo(); +} + +static Foo static_foo( "static_foo"); + +main() +{ + assert (Foo::nb_foos() == 2); + Foo automatic_foo( "automatic_foo"); + Foo bla_foo = f(); + assert (Foo::nb_foos() == 4); + g(); + assert (Foo::nb_foos() == 4); + // `automatic_foo' and `bla_foo' are destructed here +} + diff --git a/ld/testsuite/ld.cdtest/cdtest-main.cc b/ld/testsuite/ld.cdtest/cdtest-main.cc deleted file mode 100644 index 4b99b5c5f0f..00000000000 --- a/ld/testsuite/ld.cdtest/cdtest-main.cc +++ /dev/null @@ -1,40 +0,0 @@ -// main program for Class Foo - -extern "C" { -// Some implementations (e.g. SUNOS 4.1) are broken, -// in that they require . But, if gcc/g++ is installed -// correctly, you should get gcc's assert.h. -// If the compile fails, it means the wrong include files are in use! -#include -}; -#include "cdtest-foo.h" - -extern "C" void __init_start(); - -extern Foo f(void); -extern void g(void); - -/* This function should *not* be called by the environment. There is - no way in C++ to ``run something after the initializers but before main()''. - The library that depends on this (NIHCL) is broken. -- John Gilmore - We leave this here to test that future changes to the compiler - do not re-introduce this losing ``feature''. */ -void -__init_start() -{ - Foo::init_foo(); -} - -static Foo static_foo( "static_foo"); - -main() -{ - assert (Foo::nb_foos() == 2); - Foo automatic_foo( "automatic_foo"); - Foo bla_foo = f(); - assert (Foo::nb_foos() == 4); - g(); - assert (Foo::nb_foos() == 4); - // `automatic_foo' and `bla_foo' are destructed here -} -