FileUtil: Add a WriteObject method for writing a single, POD-type object.
This commit is contained in:
parent
256bdfb579
commit
279e19732c
1 changed files with 10 additions and 0 deletions
|
@ -181,6 +181,10 @@ public:
|
|||
template <typename T>
|
||||
size_t WriteArray(const T* data, size_t length)
|
||||
{
|
||||
static_assert(std::is_standard_layout<T>::value, "Given array does not consist of standard layout objects");
|
||||
// TODO: gcc 4.8 does not support is_trivially_copyable, but we really should check for it here.
|
||||
//static_assert(std::is_trivially_copyable<T>::value, "Given array does not consist of trivially copyable objects");
|
||||
|
||||
if (!IsOpen()) {
|
||||
m_good = false;
|
||||
return -1;
|
||||
|
@ -203,6 +207,12 @@ public:
|
|||
return WriteArray(reinterpret_cast<const char*>(data), length);
|
||||
}
|
||||
|
||||
template<typename T>
|
||||
size_t WriteObject(const T& object) {
|
||||
static_assert(!std::is_pointer<T>::value, "Given object is a pointer");
|
||||
return WriteArray(&object, 1);
|
||||
}
|
||||
|
||||
bool IsOpen() { return nullptr != m_file; }
|
||||
|
||||
// m_good is set to false when a read, write or other function fails
|
||||
|
|
Loading…
Reference in a new issue