blob: c671dae8d1740ca0209d879d2c7d7725f9d695b0 [file] [log] [blame]
/*
* Copyright 2013 Google Inc.
*
* Use of this source code is governed by a BSD-style license that can be
* found in the LICENSE file.
*/
#ifndef SkStreamPriv_DEFINED
#define SkStreamPriv_DEFINED
#include "include/core/SkRefCnt.h"
#include "include/core/SkStream.h"
#include "src/base/SkEndian.h"
#include <cstdint>
class SkData;
namespace SkStreamPriv {
/**
* Copy the provided stream to an SkData variable.
*
* Note: Assumes the stream is at the beginning. If it has a length,
* but is not at the beginning, this call will fail (return NULL).
*
* @param stream SkStream to be copied into data.
* @return The resulting SkData after the copy, nullptr on failure.
*/
sk_sp<SkData> CopyStreamToData(SkStream* stream);
/**
* Copies the input stream from the current position to the end.
* Does not rewind the input stream.
*/
bool Copy(SkWStream* out, SkStream* input);
/** A SkWStream that writes all output to SkDebugf, for debugging purposes. */
class DebugfStream final : public SkWStream {
public:
bool write(const void* buffer, size_t size) override;
size_t bytesWritten() const override;
private:
size_t fBytesWritten = 0;
};
/**
* Helper functions to read and write big-endian values to a stream.
*/
inline bool WriteU16BE(SkWStream* s, uint16_t value) {
value = SkEndian_SwapBE16(value);
return s->write(&value, sizeof(value));
}
inline bool WriteU32BE(SkWStream* s, uint32_t value) {
value = SkEndian_SwapBE32(value);
return s->write(&value, sizeof(value));
}
inline bool WriteS32BE(SkWStream* s, int32_t value) {
value = SkEndian_SwapBE32(value);
return s->write(&value, sizeof(value));
}
inline bool ReadU16BE(SkStream* s, uint16_t* value) {
if (!s->readU16(value)) {
return false;
}
*value = SkEndian_SwapBE16(*value);
return true;
}
inline bool ReadU32BE(SkStream* s, uint32_t* value) {
if (!s->readU32(value)) {
return false;
}
*value = SkEndian_SwapBE32(*value);
return true;
}
inline bool ReadS32BE(SkStream* s, int32_t* value) {
if (!s->readS32(value)) {
return false;
}
*value = SkEndian_SwapBE32(*value);
return true;
}
// If the stream supports identifying the current position and total length, this returns
// true if there are not enough bytes in the stream to fulfill a read of the given length.
// Otherwise, it returns false.
// False does *not* mean a read will succeed of the given length, but true means we are
// certain it will fail.
bool RemainingLengthIsBelow(SkStream* stream, size_t len);
} // namespace SkStreamPriv
#endif // SkStreamPriv_DEFINED