diff -r 000000000000 -r e4d67989cc36 genericopenlibs/cppstdlib/stl/test/unit/resolve_name.cpp --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/genericopenlibs/cppstdlib/stl/test/unit/resolve_name.cpp Tue Feb 02 02:01:42 2010 +0200 @@ -0,0 +1,83 @@ +#define _STLP_DO_IMPORT_CSTD_FUNCTIONS +#include + +#if !defined (STLPORT) || defined (_STLP_USE_NAMESPACES) + +namespace NS1 { + +bool f() +{ + double d( 1.0 ); + + d = sqrt( d ); + d = ::sqrt( d ); + d = std::sqrt( d ); + return d == 1.0; +} + +} + +namespace { + +bool g() +{ + double d( 1.0 ); + + d = sqrt( d ); + d = ::sqrt( d ); + d = std::sqrt( d ); + return d == 1.0; +} + +} + +// VC6 consider call to sqrt ambiguous as soon as using namespace std has +// been invoked. +#if !defined (STLPORT) || !defined (_STLP_MSVC) || (_STLP_MSVC >= 1300) +using namespace std; +#endif + +bool h() +{ + double d( 1.0 ); + + d = sqrt( d ); + d = ::sqrt( d ); + d = std::sqrt( d ); + return d == 1.0; +} + +struct sq +{ + sq() {} + + double sqroot( double x ) { + using std::sqrt; + return sqrt(x); + } +}; + +#endif + + +#if 0 // Do nothing, this should be compiled only + +#include "cppunit/cppunit_proxy.h" + +class ResolveNameTest : public CPPUNIT_NS::TestCase +{ + CPPUNIT_TEST_SUITE(ResolveNameTest); + CPPUNIT_TEST(cstyle); + CPPUNIT_TEST_SUITE_END(); + +protected: + void cstyle(); +}; + +CPPUNIT_TEST_SUITE_REGISTRATION(ResolveNameTest); + +void ResolveNameTest::cstyle() +{ +} + +#endif