Junxiao Shi | 8d71fdb | 2014-12-07 21:55:19 -0700 | [diff] [blame] | 1 | # -*- Mode: python; py-indent-offset: 4; indent-tabs-mode: nil; coding: utf-8; -*- |
| 2 | |
| 3 | from waflib.Configure import conf |
| 4 | |
| 5 | FRIEND_TYPENAME = ''' |
| 6 | class A; |
| 7 | |
| 8 | template<typename T> |
| 9 | class B |
| 10 | { |
| 11 | friend T; |
| 12 | }; |
| 13 | |
| 14 | B<A> g_b; |
| 15 | ''' |
| 16 | |
| 17 | FRIEND_WRAPPER = ''' |
| 18 | class A; |
| 19 | |
| 20 | template<typename T> |
| 21 | struct TypeWrapper |
| 22 | { |
| 23 | typedef T Type; |
| 24 | }; |
| 25 | |
| 26 | template<typename T> |
| 27 | class B |
| 28 | { |
| 29 | friend class TypeWrapper<T>::Type; |
| 30 | }; |
| 31 | |
| 32 | B<A> g_b; |
| 33 | ''' |
| 34 | |
| 35 | @conf |
| 36 | def check_friend_typename(self): |
| 37 | if self.check_cxx(msg='Checking for friend typename-specifier', |
| 38 | fragment=FRIEND_TYPENAME, |
| 39 | features='cxx', mandatory=False): |
| 40 | self.define('HAVE_CXX_FRIEND_TYPENAME', 1) |
| 41 | elif self.check_cxx(msg='Checking for friend typename using wrapper', |
| 42 | fragment=FRIEND_WRAPPER, |
| 43 | features='cxx', mandatory=True): |
| 44 | self.define('HAVE_CXX_FRIEND_TYPENAME_WRAPPER', 1) |
| 45 | |
Davide Pesavento | 96b96af | 2015-09-19 23:00:40 +0200 | [diff] [blame] | 46 | STD_TO_STRING = ''' |
| 47 | #include <string> |
| 48 | int |
Davide Pesavento | 7c02b47 | 2015-10-28 20:50:17 +0100 | [diff] [blame] | 49 | main() |
Davide Pesavento | 96b96af | 2015-09-19 23:00:40 +0200 | [diff] [blame] | 50 | { |
| 51 | std::string s = std::to_string(0); |
| 52 | s = std::to_string(0l); |
| 53 | s = std::to_string(0ll); |
| 54 | s = std::to_string(0u); |
| 55 | s = std::to_string(0ul); |
| 56 | s = std::to_string(0ull); |
| 57 | s = std::to_string(0.0f); |
| 58 | s = std::to_string(0.0); |
| 59 | s = std::to_string(0.0l); |
| 60 | s.clear(); |
Davide Pesavento | 96b96af | 2015-09-19 23:00:40 +0200 | [diff] [blame] | 61 | } |
| 62 | ''' |
| 63 | |
| 64 | @conf |
| 65 | def check_std_to_string(self): |
| 66 | if self.check_cxx(msg='Checking for std::to_string', |
| 67 | fragment=STD_TO_STRING, |
| 68 | features='cxx', mandatory=False): |
| 69 | self.define('HAVE_STD_TO_STRING', 1) |
| 70 | |
Joao Pereira | 7476ebf | 2015-07-07 14:54:39 -0400 | [diff] [blame] | 71 | VECTOR_INSERT_ERASE_CONST_ITERATOR = ''' |
| 72 | #include <vector> |
| 73 | int |
| 74 | main() |
| 75 | { |
| 76 | std::vector<int> v; |
| 77 | std::vector<int>::const_iterator it = v.cbegin(); |
| 78 | |
| 79 | v.insert(it, 2); |
| 80 | it = v.cend() - 1; |
| 81 | v.erase(it); |
Joao Pereira | 7476ebf | 2015-07-07 14:54:39 -0400 | [diff] [blame] | 82 | } |
| 83 | ''' |
| 84 | |
| 85 | @conf |
| 86 | def check_vector_const_iterators(self): |
Davide Pesavento | 96b96af | 2015-09-19 23:00:40 +0200 | [diff] [blame] | 87 | if self.check_cxx(msg='Checking for std::vector::insert with const_iterator', |
Joao Pereira | 7476ebf | 2015-07-07 14:54:39 -0400 | [diff] [blame] | 88 | fragment=VECTOR_INSERT_ERASE_CONST_ITERATOR, |
| 89 | features='cxx', mandatory=False): |
Davide Pesavento | 96b96af | 2015-09-19 23:00:40 +0200 | [diff] [blame] | 90 | self.define('HAVE_VECTOR_INSERT_ERASE_CONST_ITERATOR', 1) |
Joao Pereira | 7476ebf | 2015-07-07 14:54:39 -0400 | [diff] [blame] | 91 | |
Junxiao Shi | 8d71fdb | 2014-12-07 21:55:19 -0700 | [diff] [blame] | 92 | def configure(conf): |
| 93 | conf.check_friend_typename() |
Davide Pesavento | 96b96af | 2015-09-19 23:00:40 +0200 | [diff] [blame] | 94 | conf.check_std_to_string() |
Joao Pereira | 7476ebf | 2015-07-07 14:54:39 -0400 | [diff] [blame] | 95 | conf.check_vector_const_iterators() |