| OLD | NEW |
| 1 /* | 1 /* |
| 2 * Copyright 2011 Google Inc. | 2 * Copyright 2011 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 SkData_DEFINED | 8 #ifndef SkData_DEFINED |
| 9 #define SkData_DEFINED | 9 #define SkData_DEFINED |
| 10 | 10 |
| (...skipping 53 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 64 size_t copyRange(size_t offset, size_t length, void* buffer) const; | 64 size_t copyRange(size_t offset, size_t length, void* buffer) const; |
| 65 | 65 |
| 66 /** | 66 /** |
| 67 * Returns true if these two objects have the same length and contents, | 67 * Returns true if these two objects have the same length and contents, |
| 68 * effectively returning 0 == memcmp(...) | 68 * effectively returning 0 == memcmp(...) |
| 69 */ | 69 */ |
| 70 bool equals(const SkData* other) const; | 70 bool equals(const SkData* other) const; |
| 71 | 71 |
| 72 /** | 72 /** |
| 73 * Function that, if provided, will be called when the SkData goes out | 73 * Function that, if provided, will be called when the SkData goes out |
| 74 * of scope, allowing for custom allocation/freeing of the data. | 74 * of scope, allowing for custom allocation/freeing of the data's contents. |
| 75 */ | 75 */ |
| 76 typedef void (*ReleaseProc)(const void* ptr, size_t length, void* context); | 76 typedef void (*ReleaseProc)(const void* ptr, void* context); |
| 77 | 77 |
| 78 /** | 78 /** |
| 79 * Create a new dataref by copying the specified data | 79 * Create a new dataref by copying the specified data |
| 80 */ | 80 */ |
| 81 static SkData* NewWithCopy(const void* data, size_t length); | 81 static SkData* NewWithCopy(const void* data, size_t length); |
| 82 | 82 |
| 83 /** | 83 /** |
| 84 * Create a new data with uninitialized contents. The caller should call wr
itable_data() | 84 * Create a new data with uninitialized contents. The caller should call wr
itable_data() |
| 85 * to write into the buffer, but this must be done before another ref() is
made. | 85 * to write into the buffer, but this must be done before another ref() is
made. |
| 86 */ | 86 */ |
| 87 static SkData* NewUninitialized(size_t length); | 87 static SkData* NewUninitialized(size_t length); |
| 88 | 88 |
| 89 /** | 89 /** |
| 90 * Create a new dataref by copying the specified c-string | 90 * Create a new dataref by copying the specified c-string |
| 91 * (a null-terminated array of bytes). The returned SkData will have size() | 91 * (a null-terminated array of bytes). The returned SkData will have size() |
| 92 * equal to strlen(cstr) + 1. If cstr is NULL, it will be treated the same | 92 * equal to strlen(cstr) + 1. If cstr is NULL, it will be treated the same |
| 93 * as "". | 93 * as "". |
| 94 */ | 94 */ |
| 95 static SkData* NewWithCString(const char cstr[]); | 95 static SkData* NewWithCString(const char cstr[]); |
| 96 | 96 |
| 97 /** | 97 /** |
| 98 * Create a new dataref, taking the data ptr as is, and using the | 98 * Create a new dataref, taking the ptr as is, and using the |
| 99 * releaseproc to free it. The proc may be NULL. | 99 * releaseproc to free it. The proc may be NULL. |
| 100 */ | 100 */ |
| 101 static SkData* NewWithProc(const void* data, size_t length, ReleaseProc proc
, void* context); | 101 static SkData* NewWithProc(const void* ptr, size_t length, ReleaseProc proc,
void* context); |
| 102 |
| 103 #ifdef SK_SUPPORT_LEGACY_DATARELEASEPROC_PARAMS |
| 104 // This variant is temporary. |
| 105 // Its signature is meant to match an older version of the API |
| 106 typedef void (*LegacyReleaseProc)(const void* ptr, size_t size, void* ctx); |
| 107 static SkData* NewWithProc(const void* ptr, size_t length, LegacyReleaseProc
proc, void* ctx); |
| 108 #endif |
| 102 | 109 |
| 103 /** | 110 /** |
| 104 * Call this when the data parameter is already const and will outlive the
lifetime of the | 111 * Call this when the data parameter is already const and will outlive the
lifetime of the |
| 105 * SkData. Suitable for with const globals. | 112 * SkData. Suitable for with const globals. |
| 106 */ | 113 */ |
| 107 static SkData* NewWithoutCopy(const void* data, size_t length) { | 114 static SkData* NewWithoutCopy(const void* data, size_t length) { |
| 108 return NewWithProc(data, length, NULL, NULL); | 115 return NewWithProc(data, length, DummyReleaseProc, NULL); |
| 109 } | 116 } |
| 110 | 117 |
| 111 /** | 118 /** |
| 112 * Create a new dataref from a pointer allocated by malloc. The Data object | 119 * Create a new dataref from a pointer allocated by malloc. The Data object |
| 113 * takes ownership of that allocation, and will handling calling sk_free. | 120 * takes ownership of that allocation, and will handling calling sk_free. |
| 114 */ | 121 */ |
| 115 static SkData* NewFromMalloc(const void* data, size_t length); | 122 static SkData* NewFromMalloc(const void* data, size_t length); |
| 116 | 123 |
| 117 /** | 124 /** |
| 118 * Create a new dataref the file with the specified path. | 125 * Create a new dataref the file with the specified path. |
| (...skipping 34 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 153 | 160 |
| 154 /** | 161 /** |
| 155 * Returns a new empty dataref (or a reference to a shared empty dataref). | 162 * Returns a new empty dataref (or a reference to a shared empty dataref). |
| 156 * New or shared, the caller must see that unref() is eventually called. | 163 * New or shared, the caller must see that unref() is eventually called. |
| 157 */ | 164 */ |
| 158 static SkData* NewEmpty(); | 165 static SkData* NewEmpty(); |
| 159 | 166 |
| 160 private: | 167 private: |
| 161 ReleaseProc fReleaseProc; | 168 ReleaseProc fReleaseProc; |
| 162 void* fReleaseProcContext; | 169 void* fReleaseProcContext; |
| 170 #ifdef SK_SUPPORT_LEGACY_DATARELEASEPROC_PARAMS |
| 171 LegacyReleaseProc fLegacyReleaseProc; |
| 172 #endif |
| 163 | 173 |
| 164 void* fPtr; | 174 void* fPtr; |
| 165 size_t fSize; | 175 size_t fSize; |
| 166 | 176 |
| 177 #ifdef SK_SUPPORT_LEGACY_DATARELEASEPROC_PARAMS |
| 178 SkData(const void* ptr, size_t size, ReleaseProc, void* context, LegacyRelea
seProc = NULL); |
| 179 #else |
| 167 SkData(const void* ptr, size_t size, ReleaseProc, void* context); | 180 SkData(const void* ptr, size_t size, ReleaseProc, void* context); |
| 181 #endif |
| 168 SkData(size_t size); // inplace new/delete | 182 SkData(size_t size); // inplace new/delete |
| 169 virtual ~SkData(); | 183 virtual ~SkData(); |
| 170 | 184 |
| 171 | 185 |
| 172 // Objects of this type are sometimes created in a custom fashion using sk_m
alloc_throw and | 186 // Objects of this type are sometimes created in a custom fashion using sk_m
alloc_throw and |
| 173 // therefore must be sk_freed. We overload new to also call sk_malloc_throw
so that memory | 187 // therefore must be sk_freed. We overload new to also call sk_malloc_throw
so that memory |
| 174 // can be unconditionally released using sk_free in an overloaded delete. Ov
erloading regular | 188 // can be unconditionally released using sk_free in an overloaded delete. Ov
erloading regular |
| 175 // new means we must also overload placement new. | 189 // new means we must also overload placement new. |
| 176 void* operator new(size_t size) { return sk_malloc_throw(size); } | 190 void* operator new(size_t size) { return sk_malloc_throw(size); } |
| 177 void* operator new(size_t, void* p) { return p; } | 191 void* operator new(size_t, void* p) { return p; } |
| 178 void operator delete(void* p) { sk_free(p); } | 192 void operator delete(void* p) { sk_free(p); } |
| 179 | 193 |
| 180 // Called the first time someone calls NewEmpty to initialize the singleton. | 194 // Called the first time someone calls NewEmpty to initialize the singleton. |
| 181 friend SkData* sk_new_empty_data(); | 195 friend SkData* sk_new_empty_data(); |
| 182 | 196 |
| 183 // shared internal factory | 197 // shared internal factory |
| 184 static SkData* PrivateNewWithCopy(const void* srcOrNull, size_t length); | 198 static SkData* PrivateNewWithCopy(const void* srcOrNull, size_t length); |
| 185 | 199 |
| 200 static void DummyReleaseProc(const void*, void*) {} |
| 201 |
| 186 typedef SkRefCnt INHERITED; | 202 typedef SkRefCnt INHERITED; |
| 187 }; | 203 }; |
| 188 | 204 |
| 189 /** Typedef of SkAutoTUnref<SkData> for automatically unref-ing a SkData. */ | 205 /** Typedef of SkAutoTUnref<SkData> for automatically unref-ing a SkData. */ |
| 190 typedef SkAutoTUnref<SkData> SkAutoDataUnref; | 206 typedef SkAutoTUnref<SkData> SkAutoDataUnref; |
| 191 | 207 |
| 192 #endif | 208 #endif |
| OLD | NEW |