OLD | NEW |
---|---|
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 allocating memory for a copy). If duplicate() succeeds, | |
42 * the input stream will be left as is; otherwise this function | |
43 * calls rewind() on the input stream before returning. | |
bungeman-skia
2014/07/14 15:05:00
There doesn't seem to be any actionable informatio
hal.canary
2014/07/14 15:08:52
Done.
| |
44 */ | |
45 SkStreamRewindable* SkStreamRewindableFromSkStream(SkStream* stream); | |
46 | |
37 #endif // SkStreamPriv_DEFINED | 47 #endif // SkStreamPriv_DEFINED |
OLD | NEW |