]> git.vomp.tv Git - vompclient-marten.git/blob - afeed.cc
Sync changes in demuxer
[vompclient-marten.git] / afeed.cc
1 /*
2     Copyright 2004-2005 Chris Tallon
3
4     This file is part of VOMP.
5
6     VOMP is free software; you can redistribute it and/or modify
7     it under the terms of the GNU General Public License as published by
8     the Free Software Foundation; either version 2 of the License, or
9     (at your option) any later version.
10
11     VOMP is distributed in the hope that it will be useful,
12     but WITHOUT ANY WARRANTY; without even the implied warranty of
13     MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
14     GNU General Public License for more details.
15
16     You should have received a copy of the GNU General Public License
17     along with VOMP; if not, write to the Free Software
18     Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
19 */
20
21 #include "afeed.h"
22
23 AFeed::AFeed(Callback* tcb)
24 : cb(*tcb)
25 {
26   audioEnabled = 1;
27 }
28
29 #ifndef NEW_DEMUXER
30 int AFeed::init(int tfd)
31 {
32   fd = tfd;
33   return 1;
34 }
35 #else
36 int AFeed::init(DrainTarget* tdt)
37 {
38   dt = tdt;
39   return 1;
40 }
41 #endif
42
43 int AFeed::shutdown()
44 {
45   // FIXME
46   return 1;
47 }
48
49 void AFeed::disable()
50 {
51   audioEnabled = 0;
52 }
53
54 void AFeed::enable()
55 {
56   audioEnabled = 1;
57 }
58
59 int AFeed::start()
60 {
61   audioEnabled = 1;
62   return threadStart();
63 }
64
65 void AFeed::stop()
66 {
67   threadCancel();
68 }
69
70 void AFeed::threadMethod()
71 {
72   Log::getInstance()->log("AFeed", Log::DEBUG, "Started");
73
74   int alen;
75
76   while(1)
77   {
78     threadCheckExit();
79
80     if (audioEnabled)
81     {
82 #ifndef NEW_DEMUXER
83       alen = Demuxer::getInstance()->writeAudio(fd); // FIXME ?
84 #else
85       alen = Demuxer::getInstance()->writeAudio(dt); // FIXME ?
86 #endif
87
88       if (alen)
89       {
90 //        Log::getInstance()->log("AFeed", Log::DEBUG, "Written %i", alen);
91         cb.call(this);
92       }
93       else
94       {
95 //        Log::getInstance()->log("AFeed", Log::DEBUG, "No data delay");
96         MILLISLEEP(100);
97       }
98     }
99     else
100     {
101       Demuxer::getInstance()->flushAudio();
102       MILLISLEEP(100);
103     }
104   }
105 }
106