Tests of module 'sys_select' in C++ mode.
authorBruno Haible <bruno@clisp.org>
Mon, 8 Mar 2010 01:50:58 +0000 (02:50 +0100)
committerBruno Haible <bruno@clisp.org>
Mon, 8 Mar 2010 02:11:20 +0000 (03:11 +0100)
ChangeLog
m4/sys_select_h.m4
modules/sys_select-tests
tests/test-sys_select-c++.cc [new file with mode: 0644]

index ed470c2..e1f17db 100644 (file)
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,5 +1,13 @@
 2010-03-07  Bruno Haible  <bruno@clisp.org>
 
+       Tests of module 'sys_select' in C++ mode.
+       * tests/test-sys_select-c++.cc: New file.
+       * modules/sys_select-tests (Files): Add it and tests/signature.h.
+       (Depends-on): Add ansi-c++-opt.
+       (Makefile.am): Arrange to compile and run test-sys_select-c++.
+       * m4/sys_select_h.m4 (gl_SYS_SELECT_MODULE_INDICATOR): Invoke
+       gl_MODULE_INDICATOR.
+
        Tests of module 'sys_ioctl' in C++ mode.
        * tests/test-sys_ioctl-c++.cc: New file.
        * modules/sys_ioctl-tests (Files): Add it and tests/signature.h.
index 590554a..b054c4c 100644 (file)
@@ -1,4 +1,4 @@
-# sys_select_h.m4 serial 11
+# sys_select_h.m4 serial 12
 dnl Copyright (C) 2006-2010 Free Software Foundation, Inc.
 dnl This file is free software; the Free Software Foundation
 dnl gives unlimited permission to copy and/or distribute it,
@@ -74,6 +74,8 @@ AC_DEFUN([gl_SYS_SELECT_MODULE_INDICATOR],
   dnl Use AC_REQUIRE here, so that the default settings are expanded once only.
   AC_REQUIRE([gl_SYS_SELECT_H_DEFAULTS])
   GNULIB_[]m4_translit([$1],[abcdefghijklmnopqrstuvwxyz./-],[ABCDEFGHIJKLMNOPQRSTUVWXYZ___])=1
+  dnl Define it also as a C macro, for the benefit of the unit tests.
+  gl_MODULE_INDICATOR([$1])
 ])
 
 AC_DEFUN([gl_SYS_SELECT_H_DEFAULTS],
index 9908e40..227bfc1 100644 (file)
@@ -1,10 +1,19 @@
 Files:
 tests/test-sys_select.c
+tests/test-sys_select-c++.cc
+tests/signature.h
 
 Depends-on:
+ansi-c++-opt
 
 configure.ac:
 
 Makefile.am:
 TESTS += test-sys_select
 check_PROGRAMS += test-sys_select
+if ANSICXX
+TESTS += test-sys_select-c++
+check_PROGRAMS += test-sys_select-c++
+test_sys_select_c___SOURCES = test-sys_select-c++.cc
+test_sys_select_c___LDADD = $(LDADD) $(LIBINTL)
+endif
diff --git a/tests/test-sys_select-c++.cc b/tests/test-sys_select-c++.cc
new file mode 100644 (file)
index 0000000..fcf867a
--- /dev/null
@@ -0,0 +1,36 @@
+/* Test of <sys/select.h> substitute in C++ mode.
+   Copyright (C) 2010 Free Software Foundation, Inc.
+
+   This program is free software: you can redistribute it and/or modify
+   it under the terms of the GNU General Public License as published by
+   the Free Software Foundation; either version 3 of the License, or
+   (at your option) any later version.
+
+   This program is distributed in the hope that it will be useful,
+   but WITHOUT ANY WARRANTY; without even the implied warranty of
+   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+   GNU General Public License for more details.
+
+   You should have received a copy of the GNU General Public License
+   along with this program.  If not, see <http://www.gnu.org/licenses/>.  */
+
+/* Written by Bruno Haible <bruno@clisp.org>, 2010.  */
+
+#define GNULIB_NAMESPACE gnulib
+#include <config.h>
+
+#include <sys/select.h>
+
+#include "signature.h"
+
+
+#if GNULIB_SELECT
+SIGNATURE_CHECK (GNULIB_NAMESPACE::select, int,
+                 (int, fd_set *, fd_set *, fd_set *, struct timeval *));
+#endif
+
+
+int
+main ()
+{
+}