1
0
mirror of https://github.com/VDR4Arch/vdr.git synced 2023-10-10 13:36:52 +02:00

Providing channel number and file name to the shutdown program

This commit is contained in:
Klaus Schmidinger 2001-09-30 12:35:09 +02:00
parent 3b67f70b9d
commit 726225e083
3 changed files with 13 additions and 3 deletions

View File

@ -795,3 +795,5 @@ Video Disk Recorder Revision History
not the result of an editing process shall be written into separate files. not the result of an editing process shall be written into separate files.
- Fixed handling repeat function when using LIRC (thanks to Matthias Weingart). - Fixed handling repeat function when using LIRC (thanks to Matthias Weingart).
- Fixed the "system time seen..." message in case of overlapping timers. - Fixed the "system time seen..." message in case of overlapping timers.
- The shutdown program (defined with the '-s' option) now also gets the channel
number and recording title of the timer (see INSTALL).

View File

@ -109,7 +109,7 @@ active, the user has been inactive for at least MinUserInactivity minutes
and the next timer event is at least MinEventTimeout minutes in the future and the next timer event is at least MinEventTimeout minutes in the future
(see the Setup parameters in MANUAL). (see the Setup parameters in MANUAL).
The command given in the '-s' option will be called with two parameters. The command given in the '-s' option will be called with four parameters.
The first one is the time (in UTC) of the next timer event (as a time_t The first one is the time (in UTC) of the next timer event (as a time_t
type number), and the second one is the number of seconds from the current type number), and the second one is the number of seconds from the current
time until the next timer event. Your program can choose which one to use time until the next timer event. Your program can choose which one to use
@ -129,6 +129,12 @@ and only perform the system shutdown. A program that uses the second parameter
to set the hardware for restart must therefore also check whether the first to set the hardware for restart must therefore also check whether the first
parameter is '0'. parameter is '0'.
The third parameter contains the number of the channel that will be recorded
by the next timer (or 0 if no timer is present), and the fourth parameter
contains the file name of the recording as defined in the timer (or an empty
string if no timer is present). These can be used by the shutdown program to
show that information on some display interface etc.
If a timer is currently recording, the parameters will reflect the start If a timer is currently recording, the parameters will reflect the start
time of that timer. This means that the first parameter will be a time in time of that timer. This means that the first parameter will be a time in
the past, and the second parameter will be a negative number. This only the past, and the second parameter will be a negative number. This only

6
vdr.c
View File

@ -22,7 +22,7 @@
* *
* The project's page is at http://www.cadsoft.de/people/kls/vdr * The project's page is at http://www.cadsoft.de/people/kls/vdr
* *
* $Id: vdr.c 1.80 2001/09/30 11:42:58 kls Exp $ * $Id: vdr.c 1.81 2001/09/30 12:13:38 kls Exp $
*/ */
#define _GNU_SOURCE #define _GNU_SOURCE
@ -502,8 +502,10 @@ int main(int argc, char *argv[])
if (WatchdogTimeout > 0) if (WatchdogTimeout > 0)
signal(SIGALRM, SIG_IGN); signal(SIGALRM, SIG_IGN);
if (Interface->Confirm(tr("Press any key to cancel shutdown"), LastActivity == 1 ? 5 : SHUTDOWNWAIT, true)) { if (Interface->Confirm(tr("Press any key to cancel shutdown"), LastActivity == 1 ? 5 : SHUTDOWNWAIT, true)) {
int Channel = timer ? timer->channel : 0;
const char *File = timer ? timer->file : "";
char *cmd; char *cmd;
asprintf(&cmd, "%s %ld %ld", Shutdown, Next, Delta); asprintf(&cmd, "%s %ld %ld %d '%s'", Shutdown, Next, Delta, Channel, File);
isyslog(LOG_INFO, "executing '%s'", cmd); isyslog(LOG_INFO, "executing '%s'", cmd);
system(cmd); system(cmd);
delete cmd; delete cmd;