OLD | NEW |
---|---|
1 /* | 1 /* |
2 * Copyright 2006 The Android Open Source Project | 2 * Copyright 2006 The Android Open Source Project |
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 SkStream_DEFINED | 8 #ifndef SkStream_DEFINED |
9 #define SkStream_DEFINED | 9 #define SkStream_DEFINED |
10 | 10 |
11 #include "SkRefCnt.h" | 11 #include "SkData.h" |
bungeman-skia
2016/03/11 14:53:13
Please don't remove this. You are directly using s
|
bungeman-skia
2016/03/11 14:53:13
Was there a compiler that required this? It should
reed1
2016/03/11 19:23:34
Needed for destructor
|
12 #include "SkScalar.h" | 12 #include "SkScalar.h" |
13 | 13 |
14 class SkData; | |
15 | |
16 class SkStream; | 14 class SkStream; |
17 class SkStreamRewindable; | 15 class SkStreamRewindable; |
18 class SkStreamSeekable; | 16 class SkStreamSeekable; |
19 class SkStreamAsset; | 17 class SkStreamAsset; |
20 class SkStreamMemory; | 18 class SkStreamMemory; |
21 | 19 |
22 /** | 20 /** |
23 * SkStream -- abstraction for a source of bytes. Subclasses can be backed by | 21 * SkStream -- abstraction for a source of bytes. Subclasses can be backed by |
24 * memory, or a file, or something else. | 22 * memory, or a file, or something else. |
25 * | 23 * |
(...skipping 237 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
263 size_t getPosition() const override; | 261 size_t getPosition() const override; |
264 bool seek(size_t position) override; | 262 bool seek(size_t position) override; |
265 bool move(long offset) override; | 263 bool move(long offset) override; |
266 SkStreamAsset* fork() const override; | 264 SkStreamAsset* fork() const override; |
267 | 265 |
268 size_t getLength() const override; | 266 size_t getLength() const override; |
269 | 267 |
270 const void* getMemoryBase() override; | 268 const void* getMemoryBase() override; |
271 | 269 |
272 private: | 270 private: |
273 FILE* fFILE; | 271 FILE* fFILE; |
274 SkString fName; | 272 SkString fName; |
275 Ownership fOwnership; | 273 Ownership fOwnership; |
276 // fData is lazilly initialized when needed. | 274 // fData is lazilly initialized when needed. |
277 mutable SkAutoTUnref<SkData> fData; | 275 mutable sk_sp<SkData> fData; |
278 | 276 |
279 typedef SkStreamAsset INHERITED; | 277 typedef SkStreamAsset INHERITED; |
280 }; | 278 }; |
281 | 279 |
282 class SK_API SkMemoryStream : public SkStreamMemory { | 280 class SK_API SkMemoryStream : public SkStreamMemory { |
283 public: | 281 public: |
284 SkMemoryStream(); | 282 SkMemoryStream(); |
285 | 283 |
286 /** We allocate (and free) the memory. Write to it via getMemoryBase() */ | 284 /** We allocate (and free) the memory. Write to it via getMemoryBase() */ |
287 SkMemoryStream(size_t length); | 285 SkMemoryStream(size_t length); |
288 | 286 |
289 /** If copyData is true, the stream makes a private copy of the data. */ | 287 /** If copyData is true, the stream makes a private copy of the data. */ |
290 SkMemoryStream(const void* data, size_t length, bool copyData = false); | 288 SkMemoryStream(const void* data, size_t length, bool copyData = false); |
291 | 289 |
292 /** Use the specified data as the memory for this stream. | 290 /** Use the specified data as the memory for this stream. |
293 * The stream will call ref() on the data (assuming it is not NULL). | 291 * The stream will call ref() on the data (assuming it is not NULL). |
scroggo
2016/03/11 15:28:35
IIUC, this is not necessarily true for the sk_sp v
reed1
2016/03/11 19:23:34
Done.
| |
294 */ | 292 */ |
295 SkMemoryStream(SkData*); | 293 SkMemoryStream(SkData*); |
296 | 294 SkMemoryStream(sk_sp<SkData>); |
297 virtual ~SkMemoryStream(); | |
298 | 295 |
299 /** Resets the stream to the specified data and length, | 296 /** Resets the stream to the specified data and length, |
300 just like the constructor. | 297 just like the constructor. |
301 if copyData is true, the stream makes a private copy of the data | 298 if copyData is true, the stream makes a private copy of the data |
302 */ | 299 */ |
303 virtual void setMemory(const void* data, size_t length, | 300 virtual void setMemory(const void* data, size_t length, |
304 bool copyData = false); | 301 bool copyData = false); |
305 /** Replace any memory buffer with the specified buffer. The caller | 302 /** Replace any memory buffer with the specified buffer. The caller |
306 must have allocated data with sk_malloc or sk_realloc, since it | 303 must have allocated data with sk_malloc or sk_realloc, since it |
307 will be freed with sk_free. | 304 will be freed with sk_free. |
(...skipping 26 matching lines...) Expand all Loading... | |
334 size_t getPosition() const override; | 331 size_t getPosition() const override; |
335 bool seek(size_t position) override; | 332 bool seek(size_t position) override; |
336 bool move(long offset) override; | 333 bool move(long offset) override; |
337 SkMemoryStream* fork() const override; | 334 SkMemoryStream* fork() const override; |
338 | 335 |
339 size_t getLength() const override; | 336 size_t getLength() const override; |
340 | 337 |
341 const void* getMemoryBase() override; | 338 const void* getMemoryBase() override; |
342 | 339 |
343 private: | 340 private: |
344 SkData* fData; | 341 sk_sp<SkData> fData; |
345 size_t fOffset; | 342 size_t fOffset; |
346 | 343 |
347 typedef SkStreamMemory INHERITED; | 344 typedef SkStreamMemory INHERITED; |
348 }; | 345 }; |
349 | 346 |
350 //////////////////////////////////////////////////////////////////////////////// ///////////// | 347 //////////////////////////////////////////////////////////////////////////////// ///////////// |
351 | 348 |
352 class SK_API SkFILEWStream : public SkWStream { | 349 class SK_API SkFILEWStream : public SkWStream { |
353 public: | 350 public: |
354 SkFILEWStream(const char path[]); | 351 SkFILEWStream(const char path[]); |
355 virtual ~SkFILEWStream(); | 352 virtual ~SkFILEWStream(); |
(...skipping 54 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
410 SkStreamAsset* detachAsStream(); | 407 SkStreamAsset* detachAsStream(); |
411 | 408 |
412 /** Reset the stream to its original, empty, state. */ | 409 /** Reset the stream to its original, empty, state. */ |
413 void reset(); | 410 void reset(); |
414 void padToAlign4(); | 411 void padToAlign4(); |
415 private: | 412 private: |
416 struct Block; | 413 struct Block; |
417 Block* fHead; | 414 Block* fHead; |
418 Block* fTail; | 415 Block* fTail; |
419 size_t fBytesWritten; | 416 size_t fBytesWritten; |
420 mutable SkData* fCopy; // is invalidated if we write after it is created | 417 mutable sk_sp<SkData> fCopy; // is invalidated if we write after it is crea ted |
421 | 418 |
422 void invalidateCopy(); | 419 void invalidateCopy(); |
423 | 420 |
424 // For access to the Block type. | 421 // For access to the Block type. |
425 friend class SkBlockMemoryStream; | 422 friend class SkBlockMemoryStream; |
426 friend class SkBlockMemoryRefCnt; | 423 friend class SkBlockMemoryRefCnt; |
427 | 424 |
428 typedef SkWStream INHERITED; | 425 typedef SkWStream INHERITED; |
429 }; | 426 }; |
430 | 427 |
431 | 428 |
432 class SK_API SkDebugWStream : public SkWStream { | 429 class SK_API SkDebugWStream : public SkWStream { |
433 public: | 430 public: |
434 SkDebugWStream() : fBytesWritten(0) {} | 431 SkDebugWStream() : fBytesWritten(0) {} |
435 | 432 |
436 // overrides | 433 // overrides |
437 bool write(const void* buffer, size_t size) override; | 434 bool write(const void* buffer, size_t size) override; |
438 void newline() override; | 435 void newline() override; |
439 size_t bytesWritten() const override { return fBytesWritten; } | 436 size_t bytesWritten() const override { return fBytesWritten; } |
440 | 437 |
441 private: | 438 private: |
442 size_t fBytesWritten; | 439 size_t fBytesWritten; |
443 typedef SkWStream INHERITED; | 440 typedef SkWStream INHERITED; |
444 }; | 441 }; |
445 | 442 |
446 // for now | 443 // for now |
447 typedef SkFILEStream SkURLStream; | 444 typedef SkFILEStream SkURLStream; |
448 | 445 |
449 #endif | 446 #endif |
OLD | NEW |