|  | /* | 
|  | * 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 } | 
|  | } | 
|  |  | 
|  | namespace { | 
|  | SkTArray<int>* make() { | 
|  | typedef SkTArray<int> IntArray; | 
|  | return SkNEW(IntArray); | 
|  | } | 
|  |  | 
|  | template <int N> SkTArray<int>* make_s() { | 
|  | typedef SkSTArray<N, int> IntArray; | 
|  | return SkNEW(IntArray); | 
|  | } | 
|  | } | 
|  |  | 
|  | static void test_swap(skiatest::Reporter* reporter) { | 
|  | typedef SkTArray<int>* (*ArrayMaker)(); | 
|  | ArrayMaker arrayMakers[] = {make, make_s<5>, make_s<10>, make_s<20>}; | 
|  | static int kSizes[] = {0, 1, 5, 10, 15, 20, 25}; | 
|  | for (size_t arrayA = 0; arrayA < SK_ARRAY_COUNT(arrayMakers); ++arrayA) { | 
|  | for (size_t arrayB = arrayA; arrayB < SK_ARRAY_COUNT(arrayMakers); ++arrayB) { | 
|  | for (size_t dataSizeA = 0; dataSizeA < SK_ARRAY_COUNT(kSizes); ++dataSizeA) { | 
|  | for (size_t dataSizeB = 0; dataSizeB < SK_ARRAY_COUNT(kSizes); ++dataSizeB) { | 
|  | int curr = 0; | 
|  | SkTArray<int>* a = arrayMakers[arrayA](); | 
|  | SkTArray<int>* b = arrayMakers[arrayB](); | 
|  | for (int i = 0; i < kSizes[dataSizeA]; ++i) { | 
|  | a->push_back(curr++); | 
|  | } | 
|  | for (int i = 0; i < kSizes[dataSizeB]; ++i) { | 
|  | b->push_back(curr++); | 
|  | } | 
|  | a->swap(b); | 
|  | REPORTER_ASSERT(reporter, kSizes[dataSizeA] == b->count()); | 
|  | REPORTER_ASSERT(reporter, kSizes[dataSizeB] == a->count()); | 
|  | curr = 0; | 
|  | for (int i = 0; i < kSizes[dataSizeA]; ++i) { | 
|  | REPORTER_ASSERT(reporter, curr++ == (*b)[i]); | 
|  | } | 
|  | for (int i = 0; i < kSizes[dataSizeB]; ++i) { | 
|  | REPORTER_ASSERT(reporter, curr++ == (*a)[i]); | 
|  | } | 
|  | SkDELETE(b); | 
|  |  | 
|  | a->swap(a); | 
|  | curr = kSizes[dataSizeA]; | 
|  | for (int i = 0; i < kSizes[dataSizeB]; ++i) { | 
|  | REPORTER_ASSERT(reporter, curr++ == (*a)[i]); | 
|  | } | 
|  | SkDELETE(a); | 
|  | } | 
|  | } | 
|  | } | 
|  | } | 
|  | } | 
|  |  | 
|  | DEF_TEST(TArray, reporter) { | 
|  | TestTSet_basic<true>(reporter); | 
|  | TestTSet_basic<false>(reporter); | 
|  | test_swap(reporter); | 
|  | } |