author | sandman <sandman> | 2002-06-09 23:47:03 (UTC) |
---|---|---|
committer | sandman <sandman> | 2002-06-09 23:47:03 (UTC) |
commit | c479d93f2a8d7de836ef83c205f1a1789e49aa9a (patch) (side-by-side diff) | |
tree | 7fbb3e84e9e2278af99c8ed532988c72cdd9d338 | |
parent | 1c56ab829f04ea5b127c1c632cec330e47bca524 (diff) | |
download | opie-c479d93f2a8d7de836ef83c205f1a1789e49aa9a.zip opie-c479d93f2a8d7de836ef83c205f1a1789e49aa9a.tar.gz opie-c479d93f2a8d7de836ef83c205f1a1789e49aa9a.tar.bz2 |
Made resuspend timeout a command line option (-a <seconds>)
-rw-r--r-- | core/opiealarm/opiealarm.c | 36 | ||||
-rwxr-xr-x | root/etc/resume-scripts/R46opiealarm | 2 |
2 files changed, 25 insertions, 13 deletions
diff --git a/core/opiealarm/opiealarm.c b/core/opiealarm/opiealarm.c index 3a06236..ac98832 100644 --- a/core/opiealarm/opiealarm.c +++ b/core/opiealarm/opiealarm.c @@ -31,5 +31,5 @@ FILE *log; // debug only -int resume ( void ); +int resume ( int resuspend ); int suspend ( void ); int main ( int argc, char **argv ); @@ -74,5 +74,8 @@ void sig_handler ( int sig ) void usage ( void ) { - fprintf ( stderr, "Usage: opiealarm -r|-s\n" ); + fprintf ( stderr, "Usage: opiealarm -r|-s [-a]\n\n" ); + fprintf ( stderr, "\t-s\tSuspend mode: set RTC alarm\n" ); + fprintf ( stderr, "\t-r\tResume mode: kill running opiealarm\n" ); + fprintf ( stderr, "\t-a <x>\tResuspend in <x> seconds (resume mode)\n\n" ); exit ( 1 ); } @@ -140,7 +143,8 @@ int main ( int argc, char **argv ) { int mode = 0; + int ac_resusp = 0; int opt; - while (( opt = getopt ( argc, argv, "rs" )) != EOF ) { + while (( opt = getopt ( argc, argv, "a:rs" )) != EOF ) { switch ( opt ) { case 's': @@ -150,4 +154,12 @@ int main ( int argc, char **argv ) mode = 'r'; break; + case 'a': + ac_resusp = atoi ( optarg ); + if ( ac_resusp < 30 ) { + ac_resusp = 120; + + fprintf ( stderr, "Warning: resuspend timeout must be >= 30 sec. -- now set to 120 sec\n" ); + } + break; default: usage ( ); @@ -167,9 +179,9 @@ int main ( int argc, char **argv ) remove_pidfile ( ); - if ( mode == 'r' ) - return resume ( ); - else - return suspend ( ); - + switch ( mode ) { + case 'r': return resume ( ac_resusp ); + case 's': + default : return suspend ( ); + } return 0; } @@ -263,5 +275,5 @@ static int onac ( void ) } -int resume ( void ) +int resume ( int resuspend ) { FILE *fp; @@ -270,5 +282,5 @@ int resume ( void ) if ( !opiealarm_was_running ) { // opiealarm -s got it's RTC signal -> wake up by RTC - if ( onac ( )) { + if ( resuspend && onac ( )) { time_t start, now; char *argv [4]; @@ -277,10 +289,10 @@ int resume ( void ) return 4; - // sleep 120sec (not less!) + // sleep <resuspend> sec (not less!) time ( &start ); do { sleep ( 1 ); time ( &now ); - } while (( now - start ) < 120 ); + } while (( now - start ) < resuspend ); if ( onac ( )) { // still on ac diff --git a/root/etc/resume-scripts/R46opiealarm b/root/etc/resume-scripts/R46opiealarm index c258047..169dc30 100755 --- a/root/etc/resume-scripts/R46opiealarm +++ b/root/etc/resume-scripts/R46opiealarm @@ -3,3 +3,3 @@ # and wakes it up when the RTC alarm goes off. -/opt/QtPalmtop/bin/opiealarm -r +/opt/QtPalmtop/bin/opiealarm -r -a 120 |