//===- 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 { /// Adapter to write values to a stream in a particular byte order. template <endianness endian> struct Writer { raw_ostream &OS; Writer(raw_ostream &OS) : OS(OS) {} template <typename value_type> void write(ArrayRef<value_type> Vals) { for (value_type V : Vals) write(V); } template <typename value_type> void write(value_type Val) { Val = byte_swap<value_type, endian>(Val); OS.write((const char *)&Val, sizeof(value_type)); } }; template <> template <> inline void Writer<little>::write<float>(float Val) { write(FloatToBits(Val)); } template <> template <> inline void Writer<little>::write<double>(double Val) { write(DoubleToBits(Val)); } template <> template <> inline void Writer<big>::write<float>(float Val) { write(FloatToBits(Val)); } template <> template <> inline void Writer<big>::write<double>(double Val) { write(DoubleToBits(Val)); } } // end namespace endian } // end namespace support } // end namespace llvm #endif