diff options
author | Ben Cheng <bccheng@google.com> | 2014-03-25 22:37:19 -0700 |
---|---|---|
committer | Ben Cheng <bccheng@google.com> | 2014-03-25 22:37:19 -0700 |
commit | 1bc5aee63eb72b341f506ad058502cd0361f0d10 (patch) | |
tree | c607e8252f3405424ff15bc2d00aa38dadbb2518 /gcc-4.9/gcc/testsuite/g++.dg/tm/pr51411-2.C | |
parent | 283a0bf58fcf333c58a2a92c3ebbc41fb9eb1fdb (diff) | |
download | toolchain_gcc-1bc5aee63eb72b341f506ad058502cd0361f0d10.tar.gz toolchain_gcc-1bc5aee63eb72b341f506ad058502cd0361f0d10.tar.bz2 toolchain_gcc-1bc5aee63eb72b341f506ad058502cd0361f0d10.zip |
Initial checkin of GCC 4.9.0 from trunk (r208799).
Change-Id: I48a3c08bb98542aa215912a75f03c0890e497dba
Diffstat (limited to 'gcc-4.9/gcc/testsuite/g++.dg/tm/pr51411-2.C')
-rw-r--r-- | gcc-4.9/gcc/testsuite/g++.dg/tm/pr51411-2.C | 49 |
1 files changed, 49 insertions, 0 deletions
diff --git a/gcc-4.9/gcc/testsuite/g++.dg/tm/pr51411-2.C b/gcc-4.9/gcc/testsuite/g++.dg/tm/pr51411-2.C new file mode 100644 index 000000000..4105d66ec --- /dev/null +++ b/gcc-4.9/gcc/testsuite/g++.dg/tm/pr51411-2.C @@ -0,0 +1,49 @@ +// { dg-do compile } +// { dg-options "-fgnu-tm -O0" } + +namespace std { +template<typename _CharT> struct char_traits; + +template<typename _Tp> class allocator { +}; + +template<typename _Tp> struct less { + bool operator()(const _Tp& __x, const _Tp& __y) const { + return __x < __y; + } +}; + +template <typename _Key, typename _Compare = std::less<_Key> > class map { +public: + _Compare _M_key_compare; + bool find(const _Key& __x) { + return _M_key_compare(__x, __x); + } +}; + +template<typename _CharT, typename _Traits = char_traits<_CharT>, typename _Alloc = allocator<_CharT> > class basic_string { +public: + bool compare(const basic_string& __str) const { + return 0; + } +}; + +typedef basic_string<char> string; + +template<typename _CharT, typename _Traits> +inline bool operator<(const basic_string<_CharT, _Traits>& __lhs, const basic_string<_CharT, _Traits>& __rhs) { + return __lhs.compare(__rhs); +} + +extern template class basic_string<char>; + +} + +std::map<std::string> units; + +__attribute__((transaction_callable)) +void get(const std::string &name) { + units.find(name); +} + +// { dg-final { scan-assembler "_ZGTtNKSs7compareERKSs:" } } |