diff options
author | Klaus Schmidinger <vdr@tvdr.de> | 2003-08-16 15:27:26 +0200 |
---|---|---|
committer | Klaus Schmidinger <vdr@tvdr.de> | 2003-08-16 15:27:26 +0200 |
commit | 3a27bdfeda2a0de7e1c4b3f7f15925e4448e8f72 (patch) | |
tree | 50e4af4e166397e4949eeb3227eb6df49c9b4b54 | |
parent | 2eec57fe184ded122ebd14240aa8564881649727 (diff) | |
download | vdr-3a27bdfeda2a0de7e1c4b3f7f15925e4448e8f72.tar.gz vdr-3a27bdfeda2a0de7e1c4b3f7f15925e4448e8f72.tar.bz2 |
Fixed toggling channels with the '0' key
-rw-r--r-- | CONTRIBUTORS | 1 | ||||
-rw-r--r-- | HISTORY | 2 | ||||
-rw-r--r-- | vdr.c | 18 |
3 files changed, 11 insertions, 10 deletions
diff --git a/CONTRIBUTORS b/CONTRIBUTORS index 9b27b325..32d03857 100644 --- a/CONTRIBUTORS +++ b/CONTRIBUTORS @@ -334,6 +334,7 @@ Mirko G�nther <mi.guenther@ib-helms.de> for suggesting the SVDRP command VOLU for reporting a bug in keeping track of the current channel number when moving channels in the "Channels" menu + for reporting a bug in toggling channels with the '0' key Achim Lange <Achim_Lange@t-online.de> for replacing 'killproc' with 'killall' in 'runvdr' to make it work on Debian @@ -2307,3 +2307,5 @@ Video Disk Recorder Revision History - Fixed freezing replay if a timer starts while in Transfer Mode from the device used by the timer, and the timer needs a different transponder (thanks to Richard Robson for reporting this one). +- Fixed toggling channels with the '0' key (thanks to Mirko G�nther for reporting + this one). @@ -22,7 +22,7 @@ * * The project's page is at http://www.cadsoft.de/vdr * - * $Id: vdr.c 1.163 2003/08/16 09:15:28 kls Exp $ + * $Id: vdr.c 1.164 2003/08/16 15:21:35 kls Exp $ */ #include <getopt.h> @@ -457,8 +457,8 @@ int main(int argc, char *argv[]) cOsdObject *Temp = NULL; int LastChannel = -1; int LastTimerChannel = -1; - int PreviousChannel = cDevice::CurrentChannel(); - int LastLastChannel = PreviousChannel; + int PreviousChannel[2] = { 1, 1 }; + int PreviousChannelIndex = 0; time_t LastChannelChanged = time(NULL); time_t LastActivity = 0; int MaxLatencyTime = 0; @@ -500,10 +500,8 @@ int main(int argc, char *argv[]) LastChannel = cDevice::CurrentChannel(); LastChannelChanged = time(NULL); } - if (LastLastChannel != LastChannel && time(NULL) - LastChannelChanged >= ZAPTIMEOUT) { - PreviousChannel = LastLastChannel; - LastLastChannel = LastChannel; - } + if (time(NULL) - LastChannelChanged >= ZAPTIMEOUT && LastChannel != PreviousChannel[0] && LastChannel != PreviousChannel[1]) + PreviousChannel[PreviousChannelIndex ^= 1] = LastChannel; // Timers and Recordings: if (!Timers.BeingEdited()) { time_t Now = time(NULL); // must do both following calls with the exact same time! @@ -682,9 +680,9 @@ int main(int argc, char *argv[]) switch (key) { // Toggle channels: case k0: { - int CurrentChannel = cDevice::CurrentChannel(); - Channels.SwitchTo(PreviousChannel); - PreviousChannel = CurrentChannel; + if (PreviousChannel[PreviousChannelIndex ^ 1] == LastChannel || LastChannel != PreviousChannel[0] && LastChannel != PreviousChannel[1]) + PreviousChannelIndex ^= 1; + Channels.SwitchTo(PreviousChannel[PreviousChannelIndex ^= 1]); break; } // Direct Channel Select: |