Go to the documentation of this file.
25 #ifndef SRC_XRDEC_XRDECSTRMWRITER_HH_
26 #define SRC_XRDEC_XRDECSTRMWRITER_HH_
127 std::unique_lock<std::mutex> lck(
mtx );
157 std::unique_lock<std::mutex> lck(
mtx );
178 std::unique_lock<std::mutex> lck(
mtx );
184 std::unique_lock<std::mutex> lck(
mtx );
209 std::unique_ptr<WrtBuff> ptr(
wrtbuff );
211 return ptr.release();
224 std::unique_ptr<WrtBuff> result( ftr.get() );
225 return std::move( result );
244 catch(
const buff_queue::wait_interrupted& ){ }
270 std::vector<std::shared_ptr<XrdCl::ZipArchive>>
dataarchs;
Definition: XrdEcObjCfg.hh:20
Handle an async response.
Definition: XrdClXRootDResponses.hh:1037
buff_queue buffers
Definition: XrdEcStrmWriter.hh:273
void issue_close(XrdCl::ResponseHandler *handler)
Definition: XrdEcStrmWriter.hh:155
const ObjCfg & objcfg
Definition: XrdEcStrmWriter.hh:268
void Open(XrdCl::ResponseHandler *handler)
Definition: XrdClZipArchive.hh:45
std::vector< char > GetMetadataBuffer()
void report_open(const XrdCl::XRootDStatus &st)
Definition: XrdEcStrmWriter.hh:147
void Write(uint32_t size, const void *buff, XrdCl::ResponseHandler *handler)
static void writer_routine(StrmWriter *me)
Definition: XrdEcStrmWriter.hh:233
void EnqueueBuff(std::unique_ptr< WrtBuff > wrtbuff)
Definition: XrdEcStrmWriter.hh:202
std::vector< std::shared_ptr< XrdCl::File > > metadataarchs
Definition: XrdEcStrmWriter.hh:271
void WriteBuff(std::unique_ptr< WrtBuff > buff)
Request status.
Definition: XrdClXRootDResponses.hh:215
std::unique_ptr< WrtBuff > DequeueBuff()
Definition: XrdEcStrmWriter.hh:221
static ThreadPool & Instance()
Singleton access.
Definition: XrdEcThreadPool.hh:150
std::vector< std::vector< char > > cdbuffs
Definition: XrdEcStrmWriter.hh:272
uint64_t bytesleft
Definition: XrdEcStrmWriter.hh:191
StrmWriter(const ObjCfg &objcfg)
Constructor.
Definition: XrdEcStrmWriter.hh:64
std::mutex mtx
Definition: XrdEcStrmWriter.hh:189
void enqueue(Element &&element)
Definition: XrdEcUtilities.hh:187
Definition: XrdEcWrtBuff.hh:133
Definition: XrdEcUtilities.hh:171
Definition: XrdEcStrmWriter.hh:111
global_status_t global_status
Definition: XrdEcStrmWriter.hh:279
void CloseImpl(XrdCl::ResponseHandler *handler)
bool IsOK() const
We're fine.
Definition: XrdClStatus.hh:120
void interrupt()
Definition: XrdEcUtilities.hh:236
virtual ~StrmWriter()
Destructor.
Definition: XrdEcStrmWriter.hh:75
void issue_write(uint64_t wrtsize)
Definition: XrdEcStrmWriter.hh:182
std::vector< std::shared_ptr< XrdCl::ZipArchive > > dataarchs
Definition: XrdEcStrmWriter.hh:270
size_t next_blknb
Definition: XrdEcStrmWriter.hh:278
void Close(XrdCl::ResponseHandler *handler)
std::thread writer_thread
Definition: XrdEcStrmWriter.hh:277
Definition: XrdEcStrmWriter.hh:53
XrdCl::ResponseHandler * closeHandler
Definition: XrdEcStrmWriter.hh:194
Element dequeue()
Definition: XrdEcUtilities.hh:198
const XrdCl::XRootDStatus & get() const
Definition: XrdEcStrmWriter.hh:176
XrdCl::XRootDStatus status
Definition: XrdEcStrmWriter.hh:193
std::atomic< bool > writer_thread_stop
Definition: XrdEcStrmWriter.hh:275
std::unique_ptr< WrtBuff > wrtbuff
Definition: XrdEcStrmWriter.hh:269
global_status_t(StrmWriter *writer)
Definition: XrdEcStrmWriter.hh:115
void report_wrt(const XrdCl::XRootDStatus &st, uint64_t wrtsize)
Definition: XrdEcStrmWriter.hh:125
sync_queue< std::future< WrtBuff * > > buff_queue
Definition: XrdEcStrmWriter.hh:57
bool stopped_writing
Definition: XrdEcStrmWriter.hh:192
StrmWriter * writer
Definition: XrdEcStrmWriter.hh:190