job_reader.cpp 1.0 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849
  1. #include "job_reader.h"
  2. #include <yt/cpp/mapreduce/interface/logging/yt_log.h>
  3. namespace NYT {
  4. ////////////////////////////////////////////////////////////////////////////////
  5. TJobReader::TJobReader(int fd)
  6. : TJobReader(Duplicate(fd))
  7. { }
  8. TJobReader::TJobReader(const TFile& file)
  9. : FdFile_(file)
  10. , FdInput_(FdFile_)
  11. , BufferedInput_(&FdInput_, BUFFER_SIZE)
  12. { }
  13. bool TJobReader::Retry(
  14. const TMaybe<ui32>& /*rangeIndex*/,
  15. const TMaybe<ui64>& /*rowIndex*/,
  16. const std::exception_ptr& /*error*/)
  17. {
  18. return false;
  19. }
  20. void TJobReader::ResetRetries()
  21. { }
  22. bool TJobReader::HasRangeIndices() const
  23. {
  24. return true;
  25. }
  26. size_t TJobReader::DoRead(void* buf, size_t len)
  27. {
  28. return BufferedInput_.Read(buf, len);
  29. }
  30. ////////////////////////////////////////////////////////////////////////////////
  31. TRawTableReaderPtr CreateRawJobReader(int fd)
  32. {
  33. return ::MakeIntrusive<TJobReader>(fd);
  34. }
  35. ////////////////////////////////////////////////////////////////////////////////
  36. } // namespace NYT