mirror of
https://github.com/vdr-projects/vdr.git
synced 2025-03-01 10:50:46 +00:00
Original announce message: VDR developer version 1.7.26 is now available at ftp://ftp.tvdr.de/vdr/Developer/vdr-1.7.26.tar.bz2 A 'diff' against the previous version is available at ftp://ftp.tvdr.de/vdr/Developer/vdr-1.7.25-1.7.26.diff MD5 checksums: eb57398e44935ecb0bfc532bdfead312 vdr-1.7.26.tar.bz2 62e0f39e2c53ec2b5abd3ebb0e00ce3d vdr-1.7.25-1.7.26.diff WARNING: ======== This is a developer version. Even though I use it in my productive environment. I strongly recommend that you only use it under controlled conditions and for testing and debugging. From the HISTORY file: - Now checking for NULL in cOsd::AddPixmap() (suggested by Christoph Haubrich). - Fixed the German translation of "VDR will shut down in %s minutes" (thanks to Frank Neumann). - The replay progress display is now turned on whenever a mark is toggled (not only when one is set). - Toggling a mark now restarts the timeout of the replay progress display. - Fixed a possible race condition with the SVDRP commands CLRE and PUTE, where EPG data from the transponder could be handled even though it shouldn't be handled for 10 seconds. - Added some missing member initializations in cBitmap. - Improved displaying the play mode in the ST:TNG skin. - Made the ST:TNG skin the default in case the user selected skin is not available. - Improved displaying signal strength and quality in the ST:TNG skin's channel display. - Fixed switching devices to the transponders of VPS recordings in case there are only bonded devices. The cDevice's "avoid device" mechanism has been replaced by using "occupied". - Fixed selecting devices for the EPG scan in case the primary device is bonded with an other one. - Removed the calls to EITScanner.UsesDevice(this) from dvb[hs]ddevice.c, because the code following these calls is only executed if LiveView is true, which is never the case when the EITScanner switches to a channel. - Removed the obsolete function cEITScanner::UsesDevice(). If a plugin has used this function to find out whether a call to its cStatus::ChannelSwitch() function was due to a live channel switch, it can use that function's new parameter LiveView. Any plugins that implement cStatus::ChannelSwitch() need to add the parameter 'bool LiveView' to that function. - Fixed parsing channel data in case the audio pid is 0. On channels that only broadcast Dolby Digital audio there were sometimes log entries like "changing pids of channel ... from ... to ..." with no apparent difference between the old and new set of pids. - Fixed checking pids in case a channel has only Dolby Digital audio. - The Green button in the "Edit timer" menu can now be used to toggle between single shot and repeating timers. This is the same as pressing '0' when the "Day" field is selected, but it works at any time (and is more obvious). - Revoked "If the first event in a schedule has a table id of 0x00, any incoming EIT data for that schedule from the DVB stream will be completely ignored". - Added a new plugin interface for implementing EPG handlers. + A plugin can implement an EPG handler by creating an object derived from cEpgHandler and implementing the necessary member functions. + The special handling of events with table id 0x00 has been dropped. For backwards compatibility EPG events with table ids lower than 0x4E will be treated as if they had a table id of 0x4E, and the new plugin 'epgtableid0' can be used to have them handled like in previous versions. + The default table id for a newly created cEvent has been changed to 0xFF, which is higher than any normal table id that is broadcast in the EIT data. See PLUGINS.html, section "Electronic Program Guide" for more information.
108 lines
6.4 KiB
C++
108 lines
6.4 KiB
C++
/*
|
|
* status.h: Status monitoring
|
|
*
|
|
* See the main source file 'vdr.c' for copyright information and
|
|
* how to reach the author.
|
|
*
|
|
* $Id: status.h 2.1 2012/03/07 14:16:57 kls Exp $
|
|
*/
|
|
|
|
#ifndef __STATUS_H
|
|
#define __STATUS_H
|
|
|
|
#include "config.h"
|
|
#include "device.h"
|
|
#include "player.h"
|
|
#include "tools.h"
|
|
|
|
enum eTimerChange { tcMod, tcAdd, tcDel };
|
|
|
|
class cTimer;
|
|
|
|
class cStatus : public cListObject {
|
|
private:
|
|
static cList<cStatus> statusMonitors;
|
|
protected:
|
|
// These functions can be implemented by derived classes to receive status information:
|
|
virtual void TimerChange(const cTimer *Timer, eTimerChange Change) {}
|
|
// Indicates a change in the timer settings.
|
|
// If Change is tcAdd or tcDel, Timer points to the timer that has
|
|
// been added or will be deleted, respectively. In case of tcMod,
|
|
// Timer is NULL; this indicates that some timer has been changed.
|
|
// Note that tcAdd and tcDel are always also followed by a tcMod.
|
|
virtual void ChannelSwitch(const cDevice *Device, int ChannelNumber, bool LiveView) {}
|
|
// Indicates a channel switch on the given DVB device.
|
|
// If ChannelNumber is 0, this is before the channel is being switched,
|
|
// otherwise ChannelNumber is the number of the channel that has been switched to.
|
|
// LiveView tells whether this channel switch is for live viewing.
|
|
virtual void Recording(const cDevice *Device, const char *Name, const char *FileName, bool On) {}
|
|
// The given DVB device has started (On = true) or stopped (On = false) recording Name.
|
|
// Name is the name of the recording, without any directory path. The full file name
|
|
// of the recording is given in FileName, which may be NULL in case there is no
|
|
// actual file involved. If On is false, Name may be NULL.
|
|
virtual void Replaying(const cControl *Control, const char *Name, const char *FileName, bool On) {}
|
|
// The given player control has started (On = true) or stopped (On = false) replaying Name.
|
|
// Name is the name of the recording, without any directory path. In case of a player that can't provide
|
|
// a name, Name can be a string that identifies the player type (like, e.g., "DVD").
|
|
// The full file name of the recording is given in FileName, which may be NULL in case there is no
|
|
// actual file involved. If On is false, Name may be NULL.
|
|
virtual void SetVolume(int Volume, bool Absolute) {}
|
|
// The volume has been set to the given value, either
|
|
// absolutely or relative to the current volume.
|
|
virtual void SetAudioTrack(int Index, const char * const *Tracks) {}
|
|
// The audio track has been set to the one given by Index, which
|
|
// points into the Tracks array of strings. Tracks is NULL terminated.
|
|
virtual void SetAudioChannel(int AudioChannel) {}
|
|
// The audio channel has been set to the given value.
|
|
// 0=stereo, 1=left, 2=right, -1=no information available.
|
|
virtual void SetSubtitleTrack(int Index, const char * const *Tracks) {}
|
|
// The subtitle track has been set to the one given by Index, which
|
|
// points into the Tracks array of strings. Tracks is NULL terminated.
|
|
virtual void OsdClear(void) {}
|
|
// The OSD has been cleared.
|
|
virtual void OsdTitle(const char *Title) {}
|
|
// Title has been displayed in the title line of the menu.
|
|
virtual void OsdStatusMessage(const char *Message) {}
|
|
// Message has been displayed in the status line of the menu.
|
|
// If Message is NULL, the status line has been cleared.
|
|
virtual void OsdHelpKeys(const char *Red, const char *Green, const char *Yellow, const char *Blue) {}
|
|
// The help keys have been set to the given values (may be NULL).
|
|
virtual void OsdItem(const char *Text, int Index) {}
|
|
// The OSD displays the given single line Text as menu item at Index.
|
|
virtual void OsdCurrentItem(const char *Text) {}
|
|
// The OSD displays the given single line Text as the current menu item.
|
|
virtual void OsdTextItem(const char *Text, bool Scroll) {}
|
|
// The OSD displays the given multi line text. If Text points to an
|
|
// actual string, that text shall be displayed and Scroll has no
|
|
// meaning. If Text is NULL, Scroll defines whether the previously
|
|
// received text shall be scrolled up (true) or down (false) and
|
|
// the text shall be redisplayed with the new offset.
|
|
virtual void OsdChannel(const char *Text) {}
|
|
// The OSD displays the single line Text with the current channel information.
|
|
virtual void OsdProgramme(time_t PresentTime, const char *PresentTitle, const char *PresentSubtitle, time_t FollowingTime, const char *FollowingTitle, const char *FollowingSubtitle) {}
|
|
// The OSD displays the given programme information.
|
|
public:
|
|
cStatus(void);
|
|
virtual ~cStatus();
|
|
// These functions are called whenever the related status information changes:
|
|
static void MsgTimerChange(const cTimer *Timer, eTimerChange Change);
|
|
static void MsgChannelSwitch(const cDevice *Device, int ChannelNumber, bool LiveView);
|
|
static void MsgRecording(const cDevice *Device, const char *Name, const char *FileName, bool On);
|
|
static void MsgReplaying(const cControl *Control, const char *Name, const char *FileName, bool On);
|
|
static void MsgSetVolume(int Volume, bool Absolute);
|
|
static void MsgSetAudioTrack(int Index, const char * const *Tracks);
|
|
static void MsgSetAudioChannel(int AudioChannel);
|
|
static void MsgSetSubtitleTrack(int Index, const char * const *Tracks);
|
|
static void MsgOsdClear(void);
|
|
static void MsgOsdTitle(const char *Title);
|
|
static void MsgOsdStatusMessage(const char *Message);
|
|
static void MsgOsdHelpKeys(const char *Red, const char *Green, const char *Yellow, const char *Blue);
|
|
static void MsgOsdItem(const char *Text, int Index);
|
|
static void MsgOsdCurrentItem(const char *Text);
|
|
static void MsgOsdTextItem(const char *Text, bool Scroll = false);
|
|
static void MsgOsdChannel(const char *Text);
|
|
static void MsgOsdProgramme(time_t PresentTime, const char *PresentTitle, const char *PresentSubtitle, time_t FollowingTime, const char *FollowingTitle, const char *FollowingSubtitle);
|
|
};
|
|
|
|
#endif //__STATUS_H
|