|
21 | 21 | #include "settings.h" |
22 | 22 | #include "standards.h" |
23 | 23 | #include "testsuite.h" |
| 24 | +#include "testutils.h" |
24 | 25 | #include "token.h" |
25 | 26 | #include "tokenize.h" |
26 | 27 | #include "tokenlist.h" |
@@ -865,6 +866,70 @@ class TestLibrary : public TestFixture { |
865 | 866 | ASSERT_EQUALS(C.size_templateArgNo, -1); |
866 | 867 | ASSERT_EQUALS(C.stdStringLike, true); |
867 | 868 | ASSERT_EQUALS(C.arrayLike_indexOp, true); |
| 869 | + |
| 870 | + { |
| 871 | + givenACodeSampleToTokenize var("std::A<int> a;"); |
| 872 | + ASSERT_EQUALS(&A, library.detectContainer(var.tokens())); |
| 873 | + ASSERT(!library.detectIterator(var.tokens())); |
| 874 | + bool isIterator; |
| 875 | + ASSERT_EQUALS(&A, library.detectContainerOrIterator(var.tokens(), &isIterator)); |
| 876 | + ASSERT(!isIterator); |
| 877 | + } |
| 878 | + |
| 879 | + { |
| 880 | + givenACodeSampleToTokenize var("std::A<int>::size_type a_s;"); |
| 881 | + ASSERT(!library.detectContainer(var.tokens())); |
| 882 | + ASSERT(!library.detectIterator(var.tokens())); |
| 883 | + ASSERT(!library.detectContainerOrIterator(var.tokens())); |
| 884 | + } |
| 885 | + |
| 886 | + { |
| 887 | + givenACodeSampleToTokenize var("std::A<int>::iterator a_it;"); |
| 888 | + ASSERT(!library.detectContainer(var.tokens())); |
| 889 | + ASSERT_EQUALS(&A, library.detectIterator(var.tokens())); |
| 890 | + bool isIterator; |
| 891 | + ASSERT_EQUALS(&A, library.detectContainerOrIterator(var.tokens(), &isIterator)); |
| 892 | + ASSERT(isIterator); |
| 893 | + } |
| 894 | + |
| 895 | + { |
| 896 | + givenACodeSampleToTokenize var("std::B<int> b;"); |
| 897 | + ASSERT_EQUALS(&B, library.detectContainer(var.tokens())); |
| 898 | + ASSERT(!library.detectIterator(var.tokens())); |
| 899 | + bool isIterator; |
| 900 | + ASSERT_EQUALS(&B, library.detectContainerOrIterator(var.tokens(), &isIterator)); |
| 901 | + ASSERT(!isIterator); |
| 902 | + } |
| 903 | + |
| 904 | + { |
| 905 | + givenACodeSampleToTokenize var("std::B<int>::size_type b_s;"); |
| 906 | + ASSERT(!library.detectContainer(var.tokens())); |
| 907 | + ASSERT(!library.detectIterator(var.tokens())); |
| 908 | + ASSERT(!library.detectContainerOrIterator(var.tokens())); |
| 909 | + } |
| 910 | + |
| 911 | + { |
| 912 | + givenACodeSampleToTokenize var("std::B<int>::iterator b_it;"); |
| 913 | + ASSERT(!library.detectContainer(var.tokens())); |
| 914 | + ASSERT_EQUALS(&B, library.detectIterator(var.tokens())); |
| 915 | + bool isIterator; |
| 916 | + ASSERT_EQUALS(&B, library.detectContainerOrIterator(var.tokens(), &isIterator)); |
| 917 | + ASSERT(isIterator); |
| 918 | + } |
| 919 | + |
| 920 | + { |
| 921 | + givenACodeSampleToTokenize var("C c;"); |
| 922 | + ASSERT(!library.detectContainer(var.tokens())); |
| 923 | + ASSERT(!library.detectIterator(var.tokens())); |
| 924 | + ASSERT(!library.detectContainerOrIterator(var.tokens())); |
| 925 | + } |
| 926 | + |
| 927 | + { |
| 928 | + givenACodeSampleToTokenize var("D d;"); |
| 929 | + ASSERT(!library.detectContainer(var.tokens())); |
| 930 | + ASSERT(!library.detectIterator(var.tokens())); |
| 931 | + ASSERT(!library.detectContainerOrIterator(var.tokens())); |
| 932 | + } |
868 | 933 | } |
869 | 934 |
|
870 | 935 | void version() const { |
|
0 commit comments