//===- EndianStream.h - Stream ops with endian specific data ----*- C++ -*-===//
//
// The LLVM Compiler Infrastructure
//
// This file is distributed under the University of Illinois Open Source
// License. See LICENSE.TXT for details.
//
//===----------------------------------------------------------------------===//
//
// This file defines utilities for operating on streams that have endian
// specific data.
//
//===----------------------------------------------------------------------===//
#ifndef LLVM_SUPPORT_ENDIANSTREAM_H
#define LLVM_SUPPORT_ENDIANSTREAM_H
#include "llvm/ADT/ArrayRef.h"
#include "llvm/Support/Endian.h"
#include "llvm/Support/raw_ostream.h"
namespace llvm {
namespace support {
namespace endian {
template <typename value_type>
inline void write(raw_ostream &os, value_type value, endianness endian) {
value = byte_swap<value_type>(value, endian);
os.write((const char *)&value, sizeof(value_type));
}
template <>
inline void write<float>(raw_ostream &os, float value, endianness endian) {
write(os, FloatToBits(value), endian);
}
template <>
inline void write<double>(raw_ostream &os, double value,
endianness endian) {
write(os, DoubleToBits(value), endian);
}
template <typename value_type>
inline void write(raw_ostream &os, ArrayRef<value_type> vals,
endianness endian) {
for (value_type v : vals)
write(os, v, endian);
}
/// Adapter to write values to a stream in a particular byte order.
struct Writer {
raw_ostream &OS;
endianness Endian;
Writer(raw_ostream &OS, endianness Endian) : OS(OS), Endian(Endian) {}
template <typename value_type> void write(ArrayRef<value_type> Val) {
endian::write(OS, Val, Endian);
}
template <typename value_type> void write(value_type Val) {
endian::write(OS, Val, Endian);
}
};
} // end namespace endian
} // end namespace support
} // end namespace llvm
#endif