]> git.vomp.tv Git - vompclient.git/blob - channel.cc
OSDOpenVG: Render on demand: Fix backing out of a view render race
[vompclient.git] / channel.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, see <https://www.gnu.org/licenses/>.
18 */
19
20 #include "channel.h"
21
22 #include "vdr.h"
23 #include "log.h"
24 #include "control.h"
25
26 Channel::Channel()
27 {
28 }
29
30 Channel::~Channel()
31 {
32   if (name) delete[] name;
33   index = -1; // just in case
34 }
35
36 void Channel::loadPids()
37 {
38   // Clear the list if this is a reload
39   if (numAPids)
40   {
41     apids.clear();
42     dpids.clear();
43     spids.clear();
44     vpid = 0;
45     tpid = 0;
46     numAPids = 0;
47     numDPids = 0;
48     numSPids = 0;
49   }
50
51   VDR::getInstance()->getChannelPids(this); // FIXME sort out this system
52   if (!VDR::getInstance()->isConnected())
53   {
54     Control::getInstance()->connectionLost();
55     return;
56   }
57         
58   Log::getInstance()->log("Channel", Log::DEBUG, "C.%lu loaded, VPid=%lu, numApids=%lu, numDpids=%lu, numSpids=%lu TPid=%lu",
59       number, vpid, numAPids, numDPids, numSPids, tpid);
60   for (ULONG i = 0; i < numAPids; i++)
61   {
62     Log::getInstance()->log("Channel", Log::DEBUG, "APid %lu %s %d", apids[i].pid, apids[i].desc,apids[i].type);
63   }
64   for (ULONG i = 0; i < numDPids; i++)
65   {
66     Log::getInstance()->log("Channel", Log::DEBUG, "DPid %lu %s %d", dpids[i].pid, dpids[i].desc,dpids[i].type);
67   }
68   for (ULONG i = 0; i < numSPids; i++)
69   {
70     Log::getInstance()->log("Channel", Log::DEBUG, "SPid %lu %s %d %d %d", spids[i].pid, spids[i].desc,spids[i].type,spids[i].data1,spids[i].data2);
71   }
72 }