testsuite_hooks.h (__gnu_test::try_mkfifo): Declare it.

* testsuite/testsuite_hooks.h (__gnu_test::try_mkfifo): Declare it.
	* testsuite/testsuite_hooks.cc (__gnu_test::try_mkfifo): Define
	it.
	* testsuite/27_io/basic_filebuf/close/char/4879.cc: Use try_mkfifo
	and remove Cygwin XFAIL.
	* testsuite/27_io/basic_filebuf/close/char/9964.cc: Likewise.
	* testsuite/27_io/basic_filebuf/imbue/char/13171-2.cc: Likewise.
	* testsuite/27_io/basic_filebuf/open/char/9507.cc: Likewise.
	* testsuite/27_io/basic_filebuf/showmanyc/char/9533-1.cc:
	Likewise.
	* testsuite/27_io/basic_filebuf/underflow/char/10097.cc: Likewise.
	* testsuite/27_io/objects/char/7.cc: Likewise.
	* testsuite/27_io/objects/char/9661-1.cc: Likewise.
	* testsuite/27_io/objects/wchar_t/7.cc: Likewise.
	* testsuite/27_io/objects/wchar_t/9661-1.cc: Likewise.

From-SVN: r75706
This commit is contained in:
Mark Mitchell 2004-01-12 08:11:08 +00:00 committed by Mark Mitchell
parent c223cf45e5
commit ea1ea21af5
13 changed files with 55 additions and 31 deletions

View File

@ -1,3 +1,21 @@
2004-01-12 Mark Mitchell <mark@codesourcery.com>
* testsuite/testsuite_hooks.h (__gnu_test::try_mkfifo): Declare it.
* testsuite/testsuite_hooks.cc (__gnu_test::try_mkfifo): Define
it.
* testsuite/27_io/basic_filebuf/close/char/4879.cc: Use try_mkfifo
and remove Cygwin XFAIL.
* testsuite/27_io/basic_filebuf/close/char/9964.cc: Likewise.
* testsuite/27_io/basic_filebuf/imbue/char/13171-2.cc: Likewise.
* testsuite/27_io/basic_filebuf/open/char/9507.cc: Likewise.
* testsuite/27_io/basic_filebuf/showmanyc/char/9533-1.cc:
Likewise.
* testsuite/27_io/basic_filebuf/underflow/char/10097.cc: Likewise.
* testsuite/27_io/objects/char/7.cc: Likewise.
* testsuite/27_io/objects/char/9661-1.cc: Likewise.
* testsuite/27_io/objects/wchar_t/7.cc: Likewise.
* testsuite/27_io/objects/wchar_t/9661-1.cc: Likewise.
2004-01-11 Gabriel Dos Reis <gdr@integrable-solutions.net>
* include/std/std_complex.h (std::complex<>::real): Return a

View File

@ -23,9 +23,6 @@
// various tests for filebuf::open() and filebuf::close() including
// the non-portable functionality in the libstdc++-v3 IO library
// XXX cygwin does not support mkfifo
// { dg-do run { xfail *-*-cygwin* } }
#include <fstream>
#include <iostream>
#include <unistd.h>
@ -40,12 +37,14 @@
void
test_04()
{
using namespace __gnu_test;
bool test __attribute__((unused)) = true;
const char* name = "tmp_fifo1";
signal(SIGPIPE, SIG_IGN);
unlink(name);
if (0 != mkfifo(name, S_IRWXU))
if (0 != try_mkfifo(name, S_IRWXU))
{
std::cerr << "failed to create fifo" << std::endl;
exit(-1);

View File

@ -23,9 +23,6 @@
// various tests for filebuf::open() and filebuf::close() including
// the non-portable functionality in the libstdc++-v3 IO library
// XXX cygwin does not support mkfifo
// { dg-do run { xfail *-*-cygwin* } }
#include <fstream>
#include <unistd.h>
#include <signal.h>
@ -38,6 +35,7 @@
void test_07()
{
using namespace std;
using namespace __gnu_test;
bool test __attribute__((unused)) = true;
const char* name = "tmp_fifo3";
@ -45,7 +43,7 @@ void test_07()
signal(SIGPIPE, SIG_IGN);
unlink(name);
mkfifo(name, S_IRWXU);
try_mkfifo(name, S_IRWXU);
int child = fork();
VERIFY( child != -1 );

View File

@ -31,13 +31,14 @@ void test01()
{
bool test __attribute__((unused)) = true;
using namespace std;
using namespace __gnu_test;
locale loc_fr(__gnu_test::try_named_locale("fr_FR"));
locale loc_en(__gnu_test::try_named_locale("en_US"));
const char* name = "tmp_fifo_13171-2";
unlink(name);
mkfifo(name, S_IRWXU);
try_mkfifo(name, S_IRWXU);
int child = fork();
if (child == 0)

View File

@ -23,9 +23,6 @@
// various tests for filebuf::open() and filebuf::close() including
// the non-portable functionality in the libstdc++-v3 IO library
// XXX cygwin does not support mkfifo
// { dg-do run { xfail *-*-cygwin* } }
#include <fstream>
#include <unistd.h>
#include <signal.h>
@ -37,13 +34,14 @@
// libstdc++/9507
void test_06()
{
using namespace __gnu_test;
bool test __attribute__((unused)) = true;
const char* name = "tmp_fifo2";
signal(SIGPIPE, SIG_IGN);
unlink(name);
mkfifo(name, S_IRWXU);
try_mkfifo(name, S_IRWXU);
if (!fork())
{

View File

@ -18,9 +18,6 @@
// 27.8.1.4 Overridden virtual functions
// XXX cygwin does not support mkfifo
// { dg-do run { xfail *-*-cygwin* } }
#include <unistd.h>
#include <signal.h>
#include <fcntl.h>
@ -33,6 +30,7 @@
void test_01()
{
using namespace std;
using namespace __gnu_test;
bool test __attribute__((unused)) = true;
const char* name = "tmp_fifo1";
@ -41,7 +39,7 @@ void test_01()
signal(SIGPIPE, SIG_IGN);
unlink(name);
if (0 != mkfifo(name, S_IRWXU))
if (0 != try_mkfifo(name, S_IRWXU))
{
VERIFY( false );
}

View File

@ -20,9 +20,6 @@
// 27.8.1.4 Overridden virtual functions
// XXX cygwin does not support mkfifo
// { dg-do run { xfail *-*-cygwin* } }
#include <fstream>
#include <unistd.h>
#include <signal.h>
@ -48,6 +45,7 @@ public:
void test16()
{
using namespace std;
using namespace __gnu_test;
bool test __attribute__((unused)) = true;
const char* name = "tmp_fifo1";
@ -55,7 +53,7 @@ void test16()
signal(SIGPIPE, SIG_IGN);
unlink(name);
if (0 != mkfifo(name, S_IRWXU))
if (0 != try_mkfifo(name, S_IRWXU))
{
VERIFY( false );
}

View File

@ -20,9 +20,6 @@
// 27.3 Standard iostream objects
// XXX cygwin does not support mkfifo
// { dg-do run { xfail *-*-cygwin* } }
#include <fstream>
#include <iostream>
#include <unistd.h>
@ -36,6 +33,7 @@
void test07()
{
using namespace std;
using namespace __gnu_test;
bool test __attribute__((unused)) = true;
const char* name = "tmp_fifo4";
@ -43,7 +41,7 @@ void test07()
signal(SIGPIPE, SIG_IGN);
unlink(name);
mkfifo(name, S_IRWXU);
try_mkfifo(name, S_IRWXU);
int child = fork();
VERIFY( child != -1 );

View File

@ -18,9 +18,6 @@
// Software Foundation, 59 Temple Place - Suite 330, Boston, MA 02111-1307,
// USA.
// XXX cygwin does not support mkfifo
// { dg-do run { xfail *-*-cygwin* } }
#include <testsuite_hooks.h>
#include <cstdio>
#include <iostream>
@ -36,6 +33,7 @@
void test01()
{
using namespace std;
using namespace __gnu_test;
bool test __attribute__((unused)) = true;
@ -44,7 +42,7 @@ void test01()
signal(SIGPIPE, SIG_IGN);
unlink(name);
mkfifo(name, S_IRWXU);
try_mkfifo(name, S_IRWXU);
int child = fork();
VERIFY( child != -1 );

View File

@ -33,6 +33,7 @@
void test07()
{
using namespace std;
using namespace __gnu_test;
bool test __attribute__((unused)) = true;
const char* name = "tmp_fifo4";
@ -40,7 +41,7 @@ void test07()
signal(SIGPIPE, SIG_IGN);
unlink(name);
mkfifo(name, S_IRWXU);
try_mkfifo(name, S_IRWXU);
int child = fork();
VERIFY( child != -1 );

View File

@ -33,6 +33,7 @@
void test01()
{
using namespace std;
using namespace __gnu_test;
bool test __attribute__((unused)) = true;
@ -41,7 +42,7 @@ void test01()
signal(SIGPIPE, SIG_IGN);
unlink(name);
mkfifo(name, S_IRWXU);
try_mkfifo(name, S_IRWXU);
int child = fork();
VERIFY( child != -1 );

View File

@ -208,6 +208,17 @@ namespace __gnu_test
}
}
int
try_mkfifo (const char* filename, mode_t mode)
{
#ifdef _NEWLIB_VERSION
/* Newlib does not have mkfifo. */
exit(0);
#else
return mkfifo(filename, mode);
#endif
}
counter::size_type counter::count = 0;
unsigned int copy_constructor::count_ = 0;
unsigned int copy_constructor::throw_on_ = 0;

View File

@ -63,6 +63,9 @@
#include <cstddef>
#include <locale>
#include <ext/pod_char_traits.h>
#ifdef _GLIBCXX_HAVE_SYS_STAT_H
#include <sys/stat.h>
#endif
#ifdef _GLIBCXX_ASSERT
# include <cassert>
@ -141,6 +144,8 @@ namespace __gnu_test
std::locale
try_named_locale(const char* name);
int
try_mkfifo (const char* filename, mode_t mode);
// Test data types.
struct pod_char