summaryrefslogtreecommitdiff
path: root/libstdc++-v3
diff options
context:
space:
mode:
authorbstarynk <bstarynk@138bc75d-0d04-0410-961f-82ee72b054a4>2011-02-25 14:55:18 +0000
committerbstarynk <bstarynk@138bc75d-0d04-0410-961f-82ee72b054a4>2011-02-25 14:55:18 +0000
commita371787ffaccdbce41b2dd1399cea7f86ba22220 (patch)
tree4c6384f9dbef1cf8c6a9ce5a5b6ea4d2b1fe221d /libstdc++-v3
parenta73a02d4abe0f60de65430a0a424523328183dac (diff)
downloadgcc-a371787ffaccdbce41b2dd1399cea7f86ba22220.tar.gz
2011-02-25 Basile Starynkevitch <basile@starynkevitch.net>
MELT branch merged with trunk rev 170492 using svnmerge git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/branches/melt-branch@170496 138bc75d-0d04-0410-961f-82ee72b054a4
Diffstat (limited to 'libstdc++-v3')
-rw-r--r--libstdc++-v3/ChangeLog7
-rw-r--r--libstdc++-v3/testsuite/18_support/type_info/fundamental.cc79
-rw-r--r--libstdc++-v3/testsuite/Makefile.am8
-rw-r--r--libstdc++-v3/testsuite/Makefile.in4
4 files changed, 92 insertions, 6 deletions
diff --git a/libstdc++-v3/ChangeLog b/libstdc++-v3/ChangeLog
index 1d5cbcdd104..4b9b197a0da 100644
--- a/libstdc++-v3/ChangeLog
+++ b/libstdc++-v3/ChangeLog
@@ -1,3 +1,10 @@
+2011-02-24 Benjamin Kosnik <bkoz@redhat.com>
+
+ * testsuite/18_support/type_info/fundamental.cc: New.
+
+ * testsuite/Makefile.am: Make clean fixups.
+ * testsuite/Makefile.in: Regenerate.
+
2011-02-19 François Dumont <francois.cppdevs@free.fr>
* include/debug/string (basic_string::insert): Add iterator check and
diff --git a/libstdc++-v3/testsuite/18_support/type_info/fundamental.cc b/libstdc++-v3/testsuite/18_support/type_info/fundamental.cc
new file mode 100644
index 00000000000..00c64b8cfab
--- /dev/null
+++ b/libstdc++-v3/testsuite/18_support/type_info/fundamental.cc
@@ -0,0 +1,79 @@
+// { dg-options "-std=gnu++0x" }
+// { dg-require-effective-target dfp }
+
+// 2011-02-23 Benjamin Kosnik <bkoz@redhat.com>
+//
+// Copyright (C) 2011 Free Software Foundation
+//
+// This file is part of the GNU ISO C++ Library. This library 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, or (at your option)
+// any later version.
+
+// This library 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 library; see the file COPYING3. If not see
+// <http://www.gnu.org/licenses/>.
+
+#include <string>
+#include <typeinfo>
+#include <decimal/decimal>
+
+template<typename _Tp>
+ std::string
+ gen_type_info()
+ {
+ std::string s1 = typeid(_Tp).name();
+ std::string s2 = typeid(_Tp*).name();
+ std::string s3 = typeid(const _Tp*).name();
+ return std::max(std::max(s1, s2), s3);
+ }
+
+// libstdc++/43622, others
+int main()
+{
+ gen_type_info<bool>();
+ gen_type_info<char>();
+ gen_type_info<signed char>();
+ gen_type_info<unsigned char>();
+ gen_type_info<short>();
+ gen_type_info<unsigned short>();
+ gen_type_info<int>();
+ gen_type_info<unsigned int>();
+ gen_type_info<long>();
+ gen_type_info<unsigned long>();
+ gen_type_info<long long>();
+ gen_type_info<unsigned long long>();
+ gen_type_info<wchar_t>();
+ gen_type_info<char16_t>();
+ gen_type_info<char32_t>();
+
+ gen_type_info<float>();
+ gen_type_info<double>();
+ gen_type_info<long double>();
+
+ gen_type_info<void>();
+
+ gen_type_info<std::nullptr_t>();
+
+ // decimal
+ gen_type_info<std::decimal::decimal32>();
+ gen_type_info<std::decimal::decimal64>();
+ gen_type_info<std::decimal::decimal128>();
+
+ // attributes
+#if 0
+ typedef int ti_type __attribute__((__mode__(TI)));
+ gen_type_info<ti_type>();
+
+ typedef float tf_type __attribute__((__mode__(TF)));
+ gen_type_info<tf_type>();
+#endif
+
+ return 0;
+}
diff --git a/libstdc++-v3/testsuite/Makefile.am b/libstdc++-v3/testsuite/Makefile.am
index c2b8166369f..34d1ee7e904 100644
--- a/libstdc++-v3/testsuite/Makefile.am
+++ b/libstdc++-v3/testsuite/Makefile.am
@@ -1,7 +1,7 @@
## Makefile for the testsuite subdirectory of the GNU C++ Standard library.
##
-## Copyright (C) 2001, 2002, 2003, 2004, 2005, 2006, 2007, 2008, 2009, 2010
-## Free Software Foundation, Inc.
+## Copyright (C) 2001, 2002, 2003, 2004, 2005, 2006, 2007, 2008, 2009, 2010,
+## 2011 Free Software Foundation, Inc.
##
## This file is part of the libstdc++ version 3 distribution.
## Process this file with automake to produce Makefile.in.
@@ -247,8 +247,8 @@ check-profile: site.exp
# By adding these files here, automake will remove them for 'make clean'
CLEANFILES = *.txt *.tst *.exe core* filebuf_* tmp* ostream_* *.log *.sum \
testsuite_* site.exp abi_check baseline_symbols *TEST* *.dat \
- *.s *.o *.cc *.a *.so *.xml
+ *.ii *.s *.o *.cc *.x *.a *.so *.xml
# To remove directories.
clean-local:
- rm -rf debug parallel profile
+ rm -rf de fr debug parallel profile binaries
diff --git a/libstdc++-v3/testsuite/Makefile.in b/libstdc++-v3/testsuite/Makefile.in
index 86444c29169..d0967a5a6bc 100644
--- a/libstdc++-v3/testsuite/Makefile.in
+++ b/libstdc++-v3/testsuite/Makefile.in
@@ -319,7 +319,7 @@ profile_flags = "unix/-D_GLIBCXX_PROFILE"
# By adding these files here, automake will remove them for 'make clean'
CLEANFILES = *.txt *.tst *.exe core* filebuf_* tmp* ostream_* *.log *.sum \
testsuite_* site.exp abi_check baseline_symbols *TEST* *.dat \
- *.s *.o *.cc *.a *.so *.xml
+ *.ii *.s *.o *.cc *.x *.a *.so *.xml
all: all-am
@@ -652,7 +652,7 @@ check-profile: site.exp
# To remove directories.
clean-local:
- rm -rf debug parallel profile
+ rm -rf de fr debug parallel profile binaries
# Tell versions [3.59,3.63) of GNU make to not export all variables.
# Otherwise a system limit (for SysV at least) may be exceeded.