Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(466)

Side by Side Diff: src/core/SkStreamPriv.h

Issue 387863005: Move SkPDFStream back to SkStream to save memory. (Closed) Base URL: https://skia.googlesource.com/skia.git@master
Patch Set: AnotherPatchSet Created 6 years, 5 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
« no previous file with comments | « src/core/SkStream.cpp ('k') | src/pdf/SkPDFStream.h » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 /* 1 /*
2 * Copyright 2013 Google Inc. 2 * Copyright 2013 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 SkStreamPriv_DEFINED 8 #ifndef SkStreamPriv_DEFINED
9 #define SkStreamPriv_DEFINED 9 #define SkStreamPriv_DEFINED
10 10
11 class SkAutoMalloc; 11 class SkAutoMalloc;
12 class SkStream; 12 class SkStream;
13 class SkStreamRewindable;
13 class SkData; 14 class SkData;
14 15
15 /** 16 /**
16 * Copy the provided stream to memory allocated by storage. 17 * Copy the provided stream to memory allocated by storage.
17 * Used by SkImageDecoder_libbmp and SkImageDecoder_libico. 18 * Used by SkImageDecoder_libbmp and SkImageDecoder_libico.
18 * @param storage Allocator to hold the memory. Will be reset to be large 19 * @param storage Allocator to hold the memory. Will be reset to be large
19 * enough to hold the entire stream. Upon successful return, 20 * enough to hold the entire stream. Upon successful return,
20 * storage->get() will point to data holding the SkStream's entire 21 * storage->get() will point to data holding the SkStream's entire
21 * contents. 22 * contents.
22 * @param stream SkStream to be copied into storage. 23 * @param stream SkStream to be copied into storage.
23 * @return size_t Total number of bytes in the SkStream, which is also the 24 * @return size_t Total number of bytes in the SkStream, which is also the
24 * number of bytes pointed to by storage->get(). Returns 0 on failure. 25 * number of bytes pointed to by storage->get(). Returns 0 on failure.
25 */ 26 */
26 size_t SkCopyStreamToStorage(SkAutoMalloc* storage, SkStream* stream); 27 size_t SkCopyStreamToStorage(SkAutoMalloc* storage, SkStream* stream);
27 28
28 /** 29 /**
29 * Copy the provided stream to an SkData variable. 30 * Copy the provided stream to an SkData variable.
30 * @param stream SkStream to be copied into data. 31 * @param stream SkStream to be copied into data.
31 * @return SkData* The resulting SkData after the copy. This data 32 * @return SkData* The resulting SkData after the copy. This data
32 * will have a ref count of one upon return and belongs to the 33 * will have a ref count of one upon return and belongs to the
33 * caller. Returns NULL on failure. 34 * caller. Returns NULL on failure.
34 */ 35 */
35 SkData *SkCopyStreamToData(SkStream* stream); 36 SkData *SkCopyStreamToData(SkStream* stream);
36 37
38 /**
39 * Attempt to convert this stream to a StreamRewindable in the
40 * cheapest possible manner (calling duplicate() if possible, and
41 * otherwise copying to memory).
reed1 2014/07/12 11:05:05 What happens with subsequent reads to the newly re
hal.canary 2014/07/14 14:34:11 Good question. Before http://crrev.com/340783013,
42 */
43 SkStreamRewindable* SkStreamRewindableFromSkStream(SkStream* stream);
44
37 #endif // SkStreamPriv_DEFINED 45 #endif // SkStreamPriv_DEFINED
OLDNEW
« no previous file with comments | « src/core/SkStream.cpp ('k') | src/pdf/SkPDFStream.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698