blob: 718097d1cc0624d092c8f15905bfa407a5e91580 [file] [log] [blame]
scroggo@google.comdbf9f882013-08-21 15:01:48 +00001/*
2 * Copyright 2013 Google Inc.
3 *
4 * Use of this source code is governed by a BSD-style license that can be
5 * found in the LICENSE file.
6 */
7
halcanary67ec1f82014-06-27 11:36:20 -07008#ifndef SkStreamPriv_DEFINED
9#define SkStreamPriv_DEFINED
scroggo@google.comdbf9f882013-08-21 15:01:48 +000010
11class SkAutoMalloc;
12class SkStream;
halcanarye3224822014-07-14 09:12:12 -070013class SkStreamRewindable;
krajcevski99ffe242014-06-03 13:04:35 -070014class SkData;
scroggo@google.comdbf9f882013-08-21 15:01:48 +000015
16/**
17 * Copy the provided stream to memory allocated by storage.
18 * Used by SkImageDecoder_libbmp and SkImageDecoder_libico.
19 * @param storage Allocator to hold the memory. Will be reset to be large
20 * enough to hold the entire stream. Upon successful return,
21 * storage->get() will point to data holding the SkStream's entire
22 * contents.
23 * @param stream SkStream to be copied into storage.
24 * @return size_t Total number of bytes in the SkStream, which is also the
25 * number of bytes pointed to by storage->get(). Returns 0 on failure.
26 */
halcanary67ec1f82014-06-27 11:36:20 -070027size_t SkCopyStreamToStorage(SkAutoMalloc* storage, SkStream* stream);
scroggo@google.comdbf9f882013-08-21 15:01:48 +000028
krajcevski99ffe242014-06-03 13:04:35 -070029/**
halcanary67ec1f82014-06-27 11:36:20 -070030 * Copy the provided stream to an SkData variable.
krajcevski99ffe242014-06-03 13:04:35 -070031 * @param stream SkStream to be copied into data.
halcanary67ec1f82014-06-27 11:36:20 -070032 * @return SkData* The resulting SkData after the copy. This data
33 * will have a ref count of one upon return and belongs to the
34 * caller. Returns NULL on failure.
krajcevski99ffe242014-06-03 13:04:35 -070035 */
halcanary67ec1f82014-06-27 11:36:20 -070036SkData *SkCopyStreamToData(SkStream* stream);
krajcevski99ffe242014-06-03 13:04:35 -070037
halcanarye3224822014-07-14 09:12:12 -070038/**
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). The position of the
42 * input stream is left in an indeterminate state.
43 */
44SkStreamRewindable* SkStreamRewindableFromSkStream(SkStream* stream);
45
halcanary67ec1f82014-06-27 11:36:20 -070046#endif // SkStreamPriv_DEFINED