|  | /* | 
|  | * 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); | 
|  | } |