| OLD | NEW | 
|---|
| 1 /* | 1 /* | 
| 2  * Copyright 2014 Google Inc. | 2  * Copyright 2014 Google Inc. | 
| 3  * | 3  * | 
| 4  * Use of this source code is governed by a BSD-style license that can be | 4  * Use of this source code is governed by a BSD-style license that can be | 
| 5  * found in the LICENSE file. | 5  * found in the LICENSE file. | 
| 6  */ | 6  */ | 
| 7 | 7 | 
| 8 #ifndef SkRecord_DEFINED | 8 #ifndef SkRecord_DEFINED | 
| 9 #define SkRecord_DEFINED | 9 #define SkRecord_DEFINED | 
| 10 | 10 | 
| (...skipping 116 matching lines...) Expand 10 before | Expand all | Expand 10 after  Loading... | 
| 127     // We store the types of each of the pointers alongside the pointer. | 127     // We store the types of each of the pointers alongside the pointer. | 
| 128     // The cost to append a T to this structure is 8 + sizeof(T) bytes. | 128     // The cost to append a T to this structure is 8 + sizeof(T) bytes. | 
| 129 | 129 | 
| 130     // A mutator that can be used with replace to destroy canvas commands. | 130     // A mutator that can be used with replace to destroy canvas commands. | 
| 131     struct Destroyer { | 131     struct Destroyer { | 
| 132         template <typename T> | 132         template <typename T> | 
| 133         void operator()(T* record) { record->~T(); } | 133         void operator()(T* record) { record->~T(); } | 
| 134     }; | 134     }; | 
| 135 | 135 | 
| 136     template <typename T> | 136     template <typename T> | 
| 137     SK_WHEN(skstd::is_empty<T>, T*) allocCommand() { | 137     SK_WHEN(skstd::is_empty<T>::value, T*) allocCommand() { | 
| 138         static T singleton = {}; | 138         static T singleton = {}; | 
| 139         return &singleton; | 139         return &singleton; | 
| 140     } | 140     } | 
| 141 | 141 | 
| 142     template <typename T> | 142     template <typename T> | 
| 143     SK_WHEN(!skstd::is_empty<T>, T*) allocCommand() { return this->alloc<T>(); } | 143     SK_WHEN(!skstd::is_empty<T>::value, T*) allocCommand() { return this->alloc<
     T>(); } | 
| 144 | 144 | 
| 145     void grow(); | 145     void grow(); | 
| 146 | 146 | 
| 147     // A typed pointer to some bytes in fAlloc.  visit() and mutate() allow poly
     morphic dispatch. | 147     // A typed pointer to some bytes in fAlloc.  visit() and mutate() allow poly
     morphic dispatch. | 
| 148     struct Record { | 148     struct Record { | 
| 149         // On 32-bit machines we store type in 4 bytes, followed by a pointer.  
     Simple. | 149         // On 32-bit machines we store type in 4 bytes, followed by a pointer.  
     Simple. | 
| 150         // On 64-bit machines we store a pointer with the type slotted into two 
     top (unused) bytes. | 150         // On 64-bit machines we store a pointer with the type slotted into two 
     top (unused) bytes. | 
| 151         // FWIW, SkRecords::Type is tiny.  It can easily fit in one byte. | 151         // FWIW, SkRecords::Type is tiny.  It can easily fit in one byte. | 
| 152         uint64_t fTypeAndPtr; | 152         uint64_t fTypeAndPtr; | 
| 153         static const int kTypeShift = sizeof(void*) == 4 ? 32 : 48; | 153         static const int kTypeShift = sizeof(void*) == 4 ? 32 : 48; | 
| (...skipping 35 matching lines...) Expand 10 before | Expand all | Expand 10 after  Loading... | 
| 189     int fCount, fReserved; | 189     int fCount, fReserved; | 
| 190     SkAutoSTMalloc<kInlineRecords, Record> fRecords; | 190     SkAutoSTMalloc<kInlineRecords, Record> fRecords; | 
| 191 | 191 | 
| 192     // fAlloc needs to be a data structure which can append variable length data
      in contiguous | 192     // fAlloc needs to be a data structure which can append variable length data
      in contiguous | 
| 193     // chunks, returning a stable handle to that data for later retrieval. | 193     // chunks, returning a stable handle to that data for later retrieval. | 
| 194     SkVarAlloc fAlloc; | 194     SkVarAlloc fAlloc; | 
| 195     char fInlineAlloc[1 << kInlineAllocLgBytes]; | 195     char fInlineAlloc[1 << kInlineAllocLgBytes]; | 
| 196 }; | 196 }; | 
| 197 | 197 | 
| 198 #endif//SkRecord_DEFINED | 198 #endif//SkRecord_DEFINED | 
| OLD | NEW | 
|---|