| /* | 
 |  * Copyright 2014 Google Inc. | 
 |  * | 
 |  * Use of this source code is governed by a BSD-style license that can be | 
 |  * found in the LICENSE file. | 
 |  */ | 
 |  | 
 | #include "SkTArray.h" | 
 | #include "Test.h" | 
 |  | 
 | // Tests the SkTArray<T> class template. | 
 |  | 
 | template <bool MEM_COPY> | 
 | static void TestTSet_basic(skiatest::Reporter* reporter) { | 
 |     SkTArray<int, MEM_COPY> a; | 
 |  | 
 |     // Starts empty. | 
 |     REPORTER_ASSERT(reporter, a.empty()); | 
 |     REPORTER_ASSERT(reporter, a.count() == 0); | 
 |  | 
 |     // { }, add a default constructed element | 
 |     a.push_back() = 0; | 
 |     REPORTER_ASSERT(reporter, !a.empty()); | 
 |     REPORTER_ASSERT(reporter, a.count() == 1); | 
 |  | 
 |     // { 0 }, removeShuffle the only element. | 
 |     a.removeShuffle(0); | 
 |     REPORTER_ASSERT(reporter, a.empty()); | 
 |     REPORTER_ASSERT(reporter, a.count() == 0); | 
 |  | 
 |     // { }, add a default, add a 1, remove first | 
 |     a.push_back() = 0; | 
 |     REPORTER_ASSERT(reporter, a.push_back() = 1); | 
 |     a.removeShuffle(0); | 
 |     REPORTER_ASSERT(reporter, !a.empty()); | 
 |     REPORTER_ASSERT(reporter, a.count() == 1); | 
 |     REPORTER_ASSERT(reporter, a[0] == 1); | 
 |  | 
 |     // { 1 }, replace with new array | 
 |     int b[5] = { 0, 1, 2, 3, 4 }; | 
 |     a.reset(b, SK_ARRAY_COUNT(b)); | 
 |     REPORTER_ASSERT(reporter, a.count() == SK_ARRAY_COUNT(b)); | 
 |     REPORTER_ASSERT(reporter, a[2] == 2); | 
 |     REPORTER_ASSERT(reporter, a[4] == 4); | 
 |  | 
 |     // { 0, 1, 2, 3, 4 }, removeShuffle the last | 
 |     a.removeShuffle(4); | 
 |     REPORTER_ASSERT(reporter, a.count() == SK_ARRAY_COUNT(b) - 1); | 
 |     REPORTER_ASSERT(reporter, a[3] == 3); | 
 |  | 
 |     // { 0, 1, 2, 3 }, remove a middle, note shuffle | 
 |     a.removeShuffle(1); | 
 |     REPORTER_ASSERT(reporter, a.count() == SK_ARRAY_COUNT(b) - 2); | 
 |     REPORTER_ASSERT(reporter, a[0] == 0); | 
 |     REPORTER_ASSERT(reporter, a[1] == 3); | 
 |     REPORTER_ASSERT(reporter, a[2] == 2); | 
 |  | 
 |     // {0, 3, 2 } | 
 | } | 
 |  | 
 | template <typename T> static void test_swap(skiatest::Reporter* reporter, | 
 |                                             SkTArray<T>* (&arrays)[4], | 
 |                                             int (&sizes)[7]) | 
 | { | 
 |     for (auto a : arrays) { | 
 |     for (auto b : arrays) { | 
 |         if (a == b) { | 
 |             continue; | 
 |         } | 
 |  | 
 |         for (auto sizeA : sizes) { | 
 |         for (auto sizeB : sizes) { | 
 |             a->reset(); | 
 |             b->reset(); | 
 |  | 
 |             int curr = 0; | 
 |             for (int i = 0; i < sizeA; i++) { a->push_back(curr++); } | 
 |             for (int i = 0; i < sizeB; i++) { b->push_back(curr++); } | 
 |  | 
 |             a->swap(b); | 
 |             REPORTER_ASSERT(reporter, b->count() == sizeA); | 
 |             REPORTER_ASSERT(reporter, a->count() == sizeB); | 
 |  | 
 |             curr = 0; | 
 |             for (auto&& x : *b) { REPORTER_ASSERT(reporter, x == curr++); } | 
 |             for (auto&& x : *a) { REPORTER_ASSERT(reporter, x == curr++); } | 
 |  | 
 |             a->swap(a); | 
 |             curr = sizeA; | 
 |             for (auto&& x : *a) { REPORTER_ASSERT(reporter, x == curr++); } | 
 |         }} | 
 |     }} | 
 | } | 
 |  | 
 | static void test_swap(skiatest::Reporter* reporter) { | 
 |     int sizes[] = {0, 1, 5, 10, 15, 20, 25}; | 
 |  | 
 |     SkTArray<int> arr; | 
 |     SkSTArray< 5, int> arr5; | 
 |     SkSTArray<10, int> arr10; | 
 |     SkSTArray<20, int> arr20; | 
 |     SkTArray<int>* arrays[] = { &arr, &arr5, &arr10, &arr20 }; | 
 |     test_swap(reporter, arrays, sizes); | 
 |  | 
 |     struct MoveOnlyInt { | 
 |         MoveOnlyInt(int i) : fInt(i) {} | 
 |         MoveOnlyInt(MoveOnlyInt&& that) : fInt(that.fInt) {} | 
 |         bool operator==(int i) { return fInt == i; } | 
 |         int fInt; | 
 |     }; | 
 |  | 
 |     SkTArray<MoveOnlyInt> moi; | 
 |     SkSTArray< 5, MoveOnlyInt> moi5; | 
 |     SkSTArray<10, MoveOnlyInt> moi10; | 
 |     SkSTArray<20, MoveOnlyInt> moi20; | 
 |     SkTArray<MoveOnlyInt>* arraysMoi[] = { &moi, &moi5, &moi10, &moi20 }; | 
 |     test_swap(reporter, arraysMoi, sizes); | 
 | } | 
 |  | 
 | DEF_TEST(TArray, reporter) { | 
 |     TestTSet_basic<true>(reporter); | 
 |     TestTSet_basic<false>(reporter); | 
 |     test_swap(reporter); | 
 | } |