]> git.vomp.tv Git - vompserver.git/blob - mvpreceiver.h
Updates for media player after protocol change
[vompserver.git] / mvpreceiver.h
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 #ifndef MVPRECEIVER_H
22 #define MVPRECEIVER_H
23
24 #include <vdr/channels.h>
25 #include <vdr/device.h>
26 #include <vdr/receiver.h>
27
28 #include "log.h"
29 #include "thread.h"
30 #include "ringbuffer.h"
31
32 class MVPReceiver : public cReceiver
33 {
34   public:
35     static MVPReceiver* create(cChannel*, int priority);
36     virtual ~MVPReceiver();
37     int init();
38     unsigned long getBlock(unsigned char* buffer, unsigned long amount);
39     bool isVdrActivated();
40
41   private:
42     MVPReceiver(cChannel* channel, cDevice* device);
43
44     Log* logger;
45     bool vdrActivated;
46     int inittedOK;
47     Ringbuffer processed;    // A simpler deleting ringbuffer for processed data
48     pthread_mutex_t processedRingLock; // needs outside locking
49
50     // cReciever stuff
51     void Activate(bool On);
52     void Receive(UCHAR *Data, int Length);
53 };
54
55 #endif
56
57
58 /*
59     cReceiver docs from the header file
60
61     void Activate(bool On);
62       // This function is called just before the cReceiver gets attached to
63       // (On == true) or detached from (On == false) a cDevice. It can be used
64       // to do things like starting/stopping a thread.
65       // It is guaranteed that Receive() will not be called before Activate(true).
66     void Receive(uchar *Data, int Length);
67       // This function is called from the cDevice we are attached to, and
68       // delivers one TS packet from the set of PIDs the cReceiver has requested.
69       // The data packet must be accepted immediately, and the call must return
70       // as soon as possible, without any unnecessary delay. Each TS packet
71       // will be delivered only ONCE, so the cReceiver must make sure that
72       // it will be able to buffer the data if necessary.
73
74 */
75
76 /*
77
78   cDevice docs
79
80   static cDevice *GetDevice(const cChannel *Channel, int Priority = -1, bool *NeedsDetachReceivers = NULL);
81      ///< Returns a device that is able to receive the given Channel at the
82      ///< given Priority.
83      ///< See ProvidesChannel() for more information on how
84      ///< priorities are handled, and the meaning of NeedsDetachReceivers.
85
86 */