fix fd leak for recordings
authorFelix Domke <tmbinc@elitedvb.net>
Sun, 9 Apr 2006 21:54:13 +0000 (21:54 +0000)
committerFelix Domke <tmbinc@elitedvb.net>
Sun, 9 Apr 2006 21:54:13 +0000 (21:54 +0000)
lib/service/servicedvbrecord.cpp
lib/service/servicedvbrecord.h

index e150ae1d3428d6f73b4d48e97d5b9d0aa6ba7937..d0da074a0dfe29b7c1fb053fd9bae8522d430645 100644 (file)
@@ -12,6 +12,7 @@ eDVBServiceRecord::eDVBServiceRecord(const eServiceReferenceDVB &ref): m_ref(ref
        m_state = stateIdle;
        m_want_record = 0;
        m_tuned = 0;
+       m_target_fd = -1;
 }
 
 void eDVBServiceRecord::serviceEvent(int event)
@@ -108,6 +109,11 @@ RESULT eDVBServiceRecord::stop()
        {
                if (m_record)
                        m_record->stop();
+               if (m_target_fd >= 0)
+               {
+                       ::close(m_target_fd);
+                       m_target_fd = -1;
+               }
                m_state = statePrepared;
        }
        
@@ -170,6 +176,7 @@ int eDVBServiceRecord::doRecord()
                }
                m_record->setTargetFD(fd);
                m_record->setTargetFilename(m_filename.c_str());
+               m_target_fd = fd;
        }
        eDebug("starting recording..");
        
index 25ca3e56f024d7cca91b5ed58669ff3dc317ac84..dd00ee8f0190b63107ab74db2ae428cbcab310c7 100644 (file)
@@ -32,6 +32,7 @@ private:
        int m_recording, m_tuned;
        std::set<int> m_pids_active;
        std::string m_filename;
+       int m_target_fd;
        
        int doPrepare();
        int doRecord();