From 32d1bd7b040f550ab8a0c133d485ac16458a5150 Mon Sep 17 00:00:00 2001 From: electron128 Date: Sat, 4 Apr 2015 09:52:38 +0000 Subject: [PATCH] detach pqistreamer threads to allow resource cleanup or re-use git-svn-id: http://svn.code.sf.net/p/retroshare/code/trunk@8113 b45a01b8-16f6-495d-af2f-9b41ad6348cc --- libretroshare/src/pqi/pqithreadstreamer.cc | 3 +++ libretroshare/src/pqi/pqithreadstreamer.h | 8 ++++---- 2 files changed, 7 insertions(+), 4 deletions(-) diff --git a/libretroshare/src/pqi/pqithreadstreamer.cc b/libretroshare/src/pqi/pqithreadstreamer.cc index 418803fbf..f6b0630f2 100644 --- a/libretroshare/src/pqi/pqithreadstreamer.cc +++ b/libretroshare/src/pqi/pqithreadstreamer.cc @@ -73,6 +73,9 @@ void pqithreadstreamer::run() std::cerr << "pqithreadstream::run()"; std::cerr << std::endl; + // tell the OS to free the thread resources when this function exits + // it is a replacement for pthread_join() + pthread_detach(pthread_self()); while(1) { diff --git a/libretroshare/src/pqi/pqithreadstreamer.h b/libretroshare/src/pqi/pqithreadstreamer.h index 79866d04c..e17b7fc85 100644 --- a/libretroshare/src/pqi/pqithreadstreamer.h +++ b/libretroshare/src/pqi/pqithreadstreamer.h @@ -30,23 +30,23 @@ #include "pqi/pqistreamer.h" #include "util/rsthreads.h" -class pqithreadstreamer: public pqistreamer, public RsThread +class pqithreadstreamer: public pqistreamer, private RsThread { public: pqithreadstreamer(PQInterface *parent, RsSerialiser *rss, const RsPeerId& peerid, BinInterface *bio_in, int bio_flagsin); -virtual void run(); virtual void start(); virtual void shutdown(); virtual void fullstop(); -//virtual bool threadrunning(); virtual bool RecvItem(RsItem *item); virtual int tick(); protected: + // from RsThread + virtual void run(); -int data_tick(); + int data_tick(); PQInterface *mParent; uint32_t mTimeout;