job_reader.cpp 974 B

12345678910111213141516171819202122232425262728293031323334353637383940414243444546
  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(const TMaybe<ui32>& /*rangeIndex*/, const TMaybe<ui64>& /*rowIndex*/)
  14. {
  15. return false;
  16. }
  17. void TJobReader::ResetRetries()
  18. { }
  19. bool TJobReader::HasRangeIndices() const
  20. {
  21. return true;
  22. }
  23. size_t TJobReader::DoRead(void* buf, size_t len)
  24. {
  25. return BufferedInput_.Read(buf, len);
  26. }
  27. ////////////////////////////////////////////////////////////////////////////////
  28. TRawTableReaderPtr CreateRawJobReader(int fd)
  29. {
  30. return ::MakeIntrusive<TJobReader>(fd);
  31. }
  32. ////////////////////////////////////////////////////////////////////////////////
  33. } // namespace NYT