summaryrefslogtreecommitdiff
path: root/receiver.c
diff options
context:
space:
mode:
authorKlaus Schmidinger <kls (at) cadsoft (dot) de>2005-01-23 18:00:00 +0100
committerKlaus Schmidinger <kls (at) cadsoft (dot) de>2005-01-23 18:00:00 +0100
commite36fe18c483b8e520752f61975e44ddd0317a332 (patch)
tree83cbf9e5ec53bcf099f702028f9d6720f5fe13ce /receiver.c
parentfb5cccb2df60361a18fe3fd572b0fe18f3a4331c (diff)
downloadvdr-patch-lnbsharing-e36fe18c483b8e520752f61975e44ddd0317a332.tar.gz
vdr-patch-lnbsharing-e36fe18c483b8e520752f61975e44ddd0317a332.tar.bz2
Version 1.3.19vdr-1.3.19
- Making sure at least the default skin is available at program start in case a plugin needs to issue an error message (thanks to Achim Tuffentshammer for reporting a crash in such a case). Also checking if there is a current skin in cSkins::Message(). - Completed the Finnish OSD texts and fixed internationalization of the text for "Setup/DVB/Audio language(s)" (thanks to Rolf Ahrenberg). - Completed the Estonian OSD texts and switched to iso8859-13 character set (thanks to Arthur Konovalov). - Made cCondWait::SleepMs() sleep at least 3ms to avoid a possible busy wait. - Fixed canceling the LIRC thread (thanks to Marco Schlüßler for pointing out this one). - The "Green" button in the "Main" menu is now always "Audio", since the audio channel might be changed even if there is only one actual audio PID. - Fixed handling the '-E' option which was broken in version 1.3.18 (thanks to Christian Jacobsen for reporting this one). - Added 'channels.conf.terr' entries for Mainz (thanks to Michael Heyse). - Implemented cDolbyRepacker for better handling of Dolby Digital PES packets (thanks to Reinhard Nissl). - Fixed playing files with PES packets longer than 2048 byte through the full featured DVB card (thanks to Marco Kremer for reporting this one and providing a test sample). - Recording and Transfer Mode now handle more than 2 audio PIDs. For this the interfaces of the following functions have been changed: cTransferControl::cTransferControl() cTransfer::cTransfer() cRecorder::cRecorder() cReceiver::cReceiver() cRemux::cRemux() - Fixed a possible race condition in cDevice::Action() and cTSBuffer::Action() (thanks to Stefan Huelswitt). - Extended some buffer sizes to allow handling HDTV streams (thanks to Reinhard Nissl). - Added 'channels.conf.terr' entries for Düsseldorf and Köln (thanks to Walter Koch). - Falling back to 'stereo' when switching channels in case the user had switched to 'left' or 'right' (suggested by Rolf Groppe). - Completed the Danish OSD texts (thanks to Mogens Elneff). - Recording and Transfer Mode can now handle up to 8 Dolby Digital tracks (thanks to Marco Schlüßler for a patch that implements substream handling into cDevice::PlayPesPacket(), and Reinhard Nissl for adding substream handling to cDolbyRepacker). - Added PlayPes(NULL, 0) to cTransfer::Action() when clearing the transfer buffer to avoid overflows (thanks to Marco Schlüßler for pointing this out).
Diffstat (limited to 'receiver.c')
-rw-r--r--receiver.c37
1 files changed, 19 insertions, 18 deletions
diff --git a/receiver.c b/receiver.c
index e9efac1..2fc36c9 100644
--- a/receiver.c
+++ b/receiver.c
@@ -4,7 +4,7 @@
* See the main source file 'vdr.c' for copyright information and
* how to reach the author.
*
- * $Id: receiver.c 1.3 2002/07/28 15:14:49 kls Exp $
+ * $Id: receiver.c 1.4 2005/01/16 14:03:01 kls Exp $
*/
#include <stdarg.h>
@@ -12,25 +12,28 @@
#include "receiver.h"
#include "tools.h"
-cReceiver::cReceiver(int Ca, int Priority, int NumPids, ...)
+cReceiver::cReceiver(int Ca, int Priority, int Pid, const int *Pids1, const int *Pids2, const int *Pids3)
{
device = NULL;
ca = Ca;
priority = Priority;
- for (int i = 0; i < MAXRECEIVEPIDS; i++)
- pids[i] = 0;
- if (NumPids) {
- va_list ap;
- va_start(ap, NumPids);
- int n = 0;
- while (n < MAXRECEIVEPIDS && NumPids--) {
- if ((pids[n] = va_arg(ap, int)) != 0)
- n++;
- }
- va_end(ap);
+ numPids = 0;
+ if (Pid)
+ pids[numPids++] = Pid;
+ if (Pids1) {
+ while (*Pids1 && numPids < MAXRECEIVEPIDS)
+ pids[numPids++] = *Pids1++;
}
- else
- esyslog("ERROR: cReceiver called without a PID!");
+ if (Pids2) {
+ while (*Pids2 && numPids < MAXRECEIVEPIDS)
+ pids[numPids++] = *Pids2++;
+ }
+ if (Pids3) {
+ while (*Pids3 && numPids < MAXRECEIVEPIDS)
+ pids[numPids++] = *Pids3++;
+ }
+ if (numPids >= MAXRECEIVEPIDS)
+ dsyslog("too many PIDs in cReceiver");
}
cReceiver::~cReceiver()
@@ -41,11 +44,9 @@ cReceiver::~cReceiver()
bool cReceiver::WantsPid(int Pid)
{
if (Pid) {
- for (int i = 0; i < MAXRECEIVEPIDS; i++) {
+ for (int i = 0; i < numPids; i++) {
if (pids[i] == Pid)
return true;
- if (!pids[i])
- break;
}
}
return false;