1 
2 /*
3  * Copyright 2006 The Android Open Source Project
4  *
5  * Use of this source code is governed by a BSD-style license that can be
6  * found in the LICENSE file.
7  */
8 
9 
10 #include "SkTypedArray.h"
11 
SkTypedArray()12 SkTypedArray::SkTypedArray() : fType(SkType_Unknown) {
13 }
14 
SkTypedArray(SkDisplayTypes type)15 SkTypedArray::SkTypedArray(SkDisplayTypes type) : fType(type) {
16 }
17 
getIndex(int index,SkOperand * operand)18 bool SkTypedArray::getIndex(int index, SkOperand* operand) {
19     if (index >= count()) {
20         SkASSERT(0);
21         return false;
22     }
23     *operand = begin()[index];
24     return true;
25 }
26 
27 
28 #if SK_SMALLER_ARRAY_TEMPLATE_EXPERIMENT == 1
SkDS32Array()29 SkDS32Array::SkDS32Array()
30 {
31     fReserve = fCount = 0;
32     fArray = nullptr;
33 #ifdef SK_DEBUG
34     fData = nullptr;
35 #endif
36 }
37 
SkDS32Array(const SkDS32Array & src)38 SkDS32Array::SkDS32Array(const SkDS32Array& src)
39 {
40     fReserve = fCount = 0;
41     fArray = nullptr;
42 #ifdef SK_DEBUG
43     fData = nullptr;
44 #endif
45     SkDS32Array tmp(src.fArray, src.fCount);
46     this->swap(tmp);
47 }
48 
SkDS32Array(const int32_t src[],U16CPU count)49 SkDS32Array::SkDS32Array(const int32_t src[], U16CPU count)
50 {
51     SkASSERT(src || count == 0);
52 
53     fReserve = fCount = 0;
54     fArray = nullptr;
55 #ifdef SK_DEBUG
56     fData = nullptr;
57 #endif
58     if (count)
59     {
60         fArray = (int32_t*)sk_malloc_throw(count * sizeof(int32_t));
61 #ifdef SK_DEBUG
62         fData = (int32_t (*)[kDebugArraySize]) fArray;
63 #endif
64         memcpy(fArray, src, sizeof(int32_t) * count);
65         fReserve = fCount = SkToU16(count);
66     }
67 }
68 
operator =(const SkDS32Array & src)69 SkDS32Array& SkDS32Array::operator=(const SkDS32Array& src)
70 {
71     if (this != &src)
72     {
73         if (src.fCount > fReserve)
74         {
75             SkDS32Array tmp(src.fArray, src.fCount);
76             this->swap(tmp);
77         }
78         else
79         {
80             memcpy(fArray, src.fArray, sizeof(int32_t) * src.fCount);
81             fCount = src.fCount;
82         }
83     }
84     return *this;
85 }
86 
operator ==(const SkDS32Array & a,const SkDS32Array & b)87 int operator==(const SkDS32Array& a, const SkDS32Array& b)
88 {
89     return a.fCount == b.fCount &&
90             (a.fCount == 0 || !memcmp(a.fArray, b.fArray, a.fCount * sizeof(int32_t)));
91 }
92 
swap(SkDS32Array & other)93 void SkDS32Array::swap(SkDS32Array& other)
94 {
95     SkTSwap(fArray, other.fArray);
96 #ifdef SK_DEBUG
97     SkTSwap(fData, other.fData);
98 #endif
99     SkTSwap(fReserve, other.fReserve);
100     SkTSwap(fCount, other.fCount);
101 }
102 
append(U16CPU count,const int32_t * src)103 int32_t* SkDS32Array::append(U16CPU count, const int32_t* src)
104 {
105     unsigned oldCount = fCount;
106     if (count)
107     {
108         SkASSERT(src == nullptr || fArray == nullptr ||
109                 src + count <= fArray || fArray + count <= src);
110 
111         this->growBy(count);
112         if (src)
113             memcpy(fArray + oldCount, src, sizeof(int32_t) * count);
114     }
115     return fArray + oldCount;
116 }
117 
find(const int32_t & elem) const118 int SkDS32Array::find(const int32_t& elem) const
119 {
120     const int32_t* iter = fArray;
121     const int32_t* stop = fArray + fCount;
122 
123     for (; iter < stop; iter++)
124     {
125         if (*iter == elem)
126             return (int) (iter - fArray);
127     }
128     return -1;
129 }
130 
growBy(U16CPU extra)131 void SkDS32Array::growBy(U16CPU extra)
132 {
133     SkASSERT(extra);
134     SkASSERT(fCount + extra <= 0xFFFF);
135 
136     if (fCount + extra > fReserve)
137     {
138         size_t size = fCount + extra + 4;
139         size += size >> 2;
140         int32_t* array = (int32_t*)sk_malloc_throw(size * sizeof(int32_t));
141         memcpy(array, fArray, fCount * sizeof(int32_t));
142 
143         sk_free(fArray);
144         fArray = array;
145 #ifdef SK_DEBUG
146         fData = (int32_t (*)[kDebugArraySize]) fArray;
147 #endif
148         fReserve = SkToU16((U16CPU)size);
149     }
150     fCount = SkToU16(fCount + extra);
151 }
152 
insert(U16CPU index,U16CPU count,const int32_t * src)153 int32_t* SkDS32Array::insert(U16CPU index, U16CPU count, const int32_t* src)
154 {
155     SkASSERT(count);
156     int oldCount = fCount;
157     this->growBy(count);
158     int32_t* dst = fArray + index;
159     memmove(dst + count, dst, sizeof(int32_t) * (oldCount - index));
160     if (src)
161         memcpy(dst, src, sizeof(int32_t) * count);
162     return dst;
163 }
164 
165 
rfind(const int32_t & elem) const166     int SkDS32Array::rfind(const int32_t& elem) const
167     {
168         const int32_t* iter = fArray + fCount;
169         const int32_t* stop = fArray;
170 
171         while (iter > stop)
172         {
173             if (*--iter == elem)
174                 return (int) (iter - stop);
175         }
176         return -1;
177     }
178 
179 #endif
180