// Copyright (c) 2018 PaddlePaddle Authors. All Rights Reserved. // // Licensed under the Apache License, Version 2.0 (the "License"); // you may not use this file except in compliance with the License. // You may obtain a copy of the License at // // http://www.apache.org/licenses/LICENSE-2.0 // // Unless required by applicable law or agreed to in writing, software // distributed under the License is distributed on an "AS IS" BASIS, // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. // See the License for the specific language governing permissions and // limitations under the License. #include "paddle/fluid/recordio/header.h" namespace paddle { namespace recordio { Header::Header() : num_records_(0), checksum_(0), compressor_(Compressor::kNoCompress), compress_size_(0) {} Header::Header(uint32_t num, uint32_t sum, Compressor c, uint32_t cs) : num_records_(num), checksum_(sum), compressor_(c), compress_size_(cs) {} void Header::Parse(Stream* iss) { iss.Read(reinterpret_cast(&num_records_), sizeof(uint32_t)); iss.Read(reinterpret_cast(&checksum_), sizeof(uint32_t)); iss.Read(reinterpret_cast(&compressor_), sizeof(uint32_t)); iss.Read(reinterpret_cast(&compress_size_), sizeof(uint32_t)); } void Header::Write(Stream* os) { os.Write(reinterpret_cast(&num_records_), sizeof(uint32_t)); os.Write(reinterpret_cast(&checksum_), sizeof(uint32_t)); os.Write(reinterpret_cast(&compressor_), sizeof(uint32_t)); os.Write(reinterpret_cast(&compress_size_), sizeof(uint32_t)); } // std::ostream& operator << (std::ostream& os, Header h) { // os << h.num_records_ // << h.checksum_ // << static_cast(h.compressor_) // << h.compress_size_; // return os; // } std::ostream& operator<<(std::ostream& os, Header h) { os << h.NumRecords() << h.Checksum() << static_cast(h.CompressType()) << h.CompressSize(); return os; } bool operator==(Header l, Header r) { return l.NumRecords() == r.NumRecords() && l.Checksum() == r.Checksum() && l.CompressType() == r.CompressType() && l.CompressSize() == r.CompressSize(); }