1*103e46e4SHarish Mahendrakar // Copyright (c) 2016 The WebM project authors. All Rights Reserved. 2*103e46e4SHarish Mahendrakar // 3*103e46e4SHarish Mahendrakar // Use of this source code is governed by a BSD-style license 4*103e46e4SHarish Mahendrakar // that can be found in the LICENSE file in the root of the source 5*103e46e4SHarish Mahendrakar // tree. An additional intellectual property rights grant can be found 6*103e46e4SHarish Mahendrakar // in the file PATENTS. All contributing project authors may 7*103e46e4SHarish Mahendrakar // be found in the AUTHORS file in the root of the source tree. 8*103e46e4SHarish Mahendrakar #ifndef SRC_DATE_PARSER_H_ 9*103e46e4SHarish Mahendrakar #define SRC_DATE_PARSER_H_ 10*103e46e4SHarish Mahendrakar 11*103e46e4SHarish Mahendrakar #include <cassert> 12*103e46e4SHarish Mahendrakar #include <cstdint> 13*103e46e4SHarish Mahendrakar 14*103e46e4SHarish Mahendrakar #include "src/element_parser.h" 15*103e46e4SHarish Mahendrakar #include "webm/callback.h" 16*103e46e4SHarish Mahendrakar #include "webm/element.h" 17*103e46e4SHarish Mahendrakar #include "webm/reader.h" 18*103e46e4SHarish Mahendrakar #include "webm/status.h" 19*103e46e4SHarish Mahendrakar 20*103e46e4SHarish Mahendrakar namespace webm { 21*103e46e4SHarish Mahendrakar 22*103e46e4SHarish Mahendrakar // Parses an EBML date from a byte stream. EBML dates are signed integer values 23*103e46e4SHarish Mahendrakar // that represent the offset, in nanoseconds, from 2001-01-01T00:00:00.00 UTC. 24*103e46e4SHarish Mahendrakar class DateParser : public ElementParser { 25*103e46e4SHarish Mahendrakar public: 26*103e46e4SHarish Mahendrakar // Constructs a new parser which will use the given default_value as the 27*103e46e4SHarish Mahendrakar // value for the element if its size is zero. Defaults to the value zero (as 28*103e46e4SHarish Mahendrakar // the EBML spec indicates). 29*103e46e4SHarish Mahendrakar explicit DateParser(std::int64_t default_value = 0); 30*103e46e4SHarish Mahendrakar 31*103e46e4SHarish Mahendrakar DateParser(DateParser&&) = default; 32*103e46e4SHarish Mahendrakar DateParser& operator=(DateParser&&) = default; 33*103e46e4SHarish Mahendrakar 34*103e46e4SHarish Mahendrakar DateParser(const DateParser&) = delete; 35*103e46e4SHarish Mahendrakar DateParser& operator=(const DateParser&) = delete; 36*103e46e4SHarish Mahendrakar 37*103e46e4SHarish Mahendrakar Status Init(const ElementMetadata& metadata, std::uint64_t max_size) override; 38*103e46e4SHarish Mahendrakar 39*103e46e4SHarish Mahendrakar Status Feed(Callback* callback, Reader* reader, 40*103e46e4SHarish Mahendrakar std::uint64_t* num_bytes_read) override; 41*103e46e4SHarish Mahendrakar 42*103e46e4SHarish Mahendrakar // Gets the parsed date. This must not be called until the parse had been 43*103e46e4SHarish Mahendrakar // successfully completed. value()44*103e46e4SHarish Mahendrakar std::int64_t value() const { 45*103e46e4SHarish Mahendrakar assert(num_bytes_remaining_ == 0); 46*103e46e4SHarish Mahendrakar return value_; 47*103e46e4SHarish Mahendrakar } 48*103e46e4SHarish Mahendrakar 49*103e46e4SHarish Mahendrakar // Gets the parsed date. This must not be called until the parse had been 50*103e46e4SHarish Mahendrakar // successfully completed. mutable_value()51*103e46e4SHarish Mahendrakar std::int64_t* mutable_value() { 52*103e46e4SHarish Mahendrakar assert(num_bytes_remaining_ == 0); 53*103e46e4SHarish Mahendrakar return &value_; 54*103e46e4SHarish Mahendrakar } 55*103e46e4SHarish Mahendrakar 56*103e46e4SHarish Mahendrakar private: 57*103e46e4SHarish Mahendrakar std::int64_t value_; 58*103e46e4SHarish Mahendrakar std::int64_t default_value_; 59*103e46e4SHarish Mahendrakar int num_bytes_remaining_ = -1; 60*103e46e4SHarish Mahendrakar }; 61*103e46e4SHarish Mahendrakar 62*103e46e4SHarish Mahendrakar } // namespace webm 63*103e46e4SHarish Mahendrakar 64*103e46e4SHarish Mahendrakar #endif // SRC_DATE_PARSER_H_ 65