summaryrefslogtreecommitdiff
path: root/control.c
diff options
context:
space:
mode:
authorMidas <vdrportal_midas@gmx.de>2010-06-08 12:52:10 +0200
committerMidas <vdrportal_midas@gmx.de>2010-06-08 12:52:10 +0200
commit891bfb5ba9f052f9a97ef0abedeb039236701755 (patch)
tree839838706677c12ff9f0b9a6a1ee0bdd5926fba3 /control.c
parent4753e96fbaaf0ac96ea8a8512e90819591cdc723 (diff)
downloadvdr-plugin-block-891bfb5ba9f052f9a97ef0abedeb039236701755.tar.gz
vdr-plugin-block-891bfb5ba9f052f9a97ef0abedeb039236701755.tar.bz2
This version completes the basic parental guidance
functions. I will update README soon.
Diffstat (limited to 'control.c')
-rw-r--r--control.c155
1 files changed, 85 insertions, 70 deletions
diff --git a/control.c b/control.c
index 24724a8..e4abc90 100644
--- a/control.c
+++ b/control.c
@@ -17,18 +17,18 @@ bool cControlBlock::mRequested = false;
cControlBlock::cControlBlock(const cChannel *Channel, const cEvent *Present, const cEvent *Following):
cControl(new cPlayer),
- mChannel(Channel),
- mPresent(Present),
- mFollowing(Following),
- mStart(0),
- mSwitch(true),
- mOsd(NULL),
- direction(0)
+ mChannel(Channel),
+ mPresent(Present),
+ mFollowing(Following),
+ mStart(0),
+ mSwitch(true),
+ mOsd(NULL),
+ direction(0)
{
#if APIVERSNUM >= 10500
- SetNeedsFastResponse(true);
+ SetNeedsFastResponse(true);
#else
- needsFastResponse = true;
+ needsFastResponse = true;
#endif
cRemote::Put(kBack,true); //Hide OSD new version
@@ -36,8 +36,8 @@ cControlBlock::cControlBlock(const cChannel *Channel, const cEvent *Present, con
cControlBlock::~cControlBlock()
{
- if (mOsd != NULL)
- delete mOsd;
+ if (mOsd != NULL)
+ delete mOsd;
if (mRequested)
{
#ifdef LOGGING
@@ -57,92 +57,106 @@ cControlBlock::~cControlBlock()
}
}
- if (mSwitch) {
- int lastchannel=cSetupBlock::LastChannel;
- // possibly first or last available channel, fall back to old channel
+ if (mSwitch) {
+ int lastchannel=cSetupBlock::LastChannel;
+ // possibly first or last available channel, fall back to old channel
- if (direction == 0)
- direction = 1;
- if (!cDevice::SwitchChannel(direction) && (lastchannel != 0))
- Channels.SwitchTo(lastchannel);
+ if (direction == 0)
+ direction = 1;
+ if (!cDevice::SwitchChannel(direction) && (lastchannel != 0))
+ Channels.SwitchTo(lastchannel);
- }
+ }
}
void cControlBlock::Show(void)
{
- if (mOsd == NULL)
- mOsd = Skins.Current()->DisplayChannel(true);
+ if (mOsd == NULL)
+ mOsd = Skins.Current()->DisplayChannel(true);
- mOsd->SetChannel(mChannel, 0);
- mOsd->SetEvents(mPresent, mFollowing);
- mOsd->SetMessage(mtError, tr("Channel not acceptable!"));
- mOsd->Flush();
+ mOsd->SetChannel(mChannel, 0);
+ mOsd->SetEvents(mPresent, mFollowing);
+ mOsd->SetMessage(mtError, tr("Channel not acceptable!"));
+ mOsd->Flush();
- mStart = time_ms();
+ mStart = time_ms();
}
eOSState cControlBlock::ProcessKey(eKeys Key)
{
#ifdef LOGGING
- dsyslog("plugin-block: userint cControlBlock::ProcessKey(%d) this = %p", Key, this);
+ dsyslog("plugin-block: userint cControlBlock::ProcessKey(%d) this = %p", Key, this);
#endif
switch (Key) {
- case kOk:
+ case kOk:
#ifdef LOGGING
- dsyslog("plugin-block: userint Processing 'Ok' event");
-#endif
- mRequested = true;
- mSwitch = false;
- return osEnd;
-
- case kNone:
+ dsyslog("plugin-block: userint Processing 'Ok' event");
+#endif
+ if (cSetupBlock::OkAllowed==1)
+ {
+ mRequested = true;
+ mSwitch = false;
+ return osEnd;
+ }
+ else
+ {
+ mRequested = false;
+ mSwitch = true;
+ if (mOsd != NULL)
+ {
+ mOsd->SetMessage(mtError, tr("No Permission!"));
+ mOsd->Flush();
+ }
+ }
+ return osContinue;
+
+ case kNone:
#ifdef LOGGING
dsyslog("plugin-block: userint Processing kNone (no user interaction)");
#endif
- if (mStart == 0)
- Show();
- else if (time_ms() - mStart > BlockTimeout()) {
- direction = mChannel->Number() - cSetupBlock::LastChannel;
- mSwitch = true;
- return osEnd;
- }
- return osContinue;
-
-
-
- case kUp:
- case kChanUp:
+ if (mStart == 0)
+ Show();
+ else if (time_ms() - mStart > BlockTimeout()) {
+ direction = mChannel->Number() - cSetupBlock::LastChannel;
+ mSwitch = true;
+ return osEnd;
+ }
+ return osContinue;
+
+
+
+ case kUp:
+ case kChanUp:
#ifdef LOGGING
dsyslog("plugin-block: userint Processing up event (userrequest)");
#endif
- if (mStart == 0)
- Show();
- else
- {
- mRequested=false;//TODO:necessary? as below
- direction = 1;
- mSwitch = true;
- return osEnd;
- }
- break;
- case kDown:
- case kChanDn:
+ if (mStart == 0)
+ Show();
+ else
+ {
+ mRequested=false;//TODO:necessary? as below
+ direction = 1;
+ mSwitch = true;
+ return osEnd;
+ }
+ break;
+ case kDown:
+ case kChanDn:
#ifdef LOGGING
dsyslog("plugin-block: userint Processing down event (userrequest)");
#endif
- if (mStart == 0)
- Show();
- else
- {
- mRequested=false;//TODO:necessary? as below
- direction = -1;
- mSwitch = true;
- return osEnd;
- }
- break;
+ if (mStart == 0)
+ Show();
+ else
+ {
+ mRequested=false;//TODO:necessary? as below
+ direction = -1;
+ mSwitch = true;
+ return osEnd;
+ }
+ break;
default:
@@ -150,3 +164,4 @@ dsyslog("plugin-block: userint Processing down event (userrequest)");
}
return osContinue;
}
+