diff options
author | Mattias Andrée <maandree@operamail.com> | 2013-11-03 05:16:39 +0100 |
---|---|---|
committer | Mattias Andrée <maandree@operamail.com> | 2013-11-03 05:16:39 +0100 |
commit | f784d1f73c7b1fa9b53d34b531f2737e85b6d98f (patch) | |
tree | 8da3daf890b3581805747263644134b1ef798c9b /src/cerberus.c | |
parent | derp (diff) | |
download | libpassphrase-f784d1f73c7b1fa9b53d34b531f2737e85b6d98f.tar.gz libpassphrase-f784d1f73c7b1fa9b53d34b531f2737e85b6d98f.tar.bz2 libpassphrase-f784d1f73c7b1fa9b53d34b531f2737e85b6d98f.tar.xz |
add clean quiting and timeout
Signed-off-by: Mattias Andrée <maandree@operamail.com>
Diffstat (limited to 'src/cerberus.c')
-rw-r--r-- | src/cerberus.c | 27 |
1 files changed, 26 insertions, 1 deletions
diff --git a/src/cerberus.c b/src/cerberus.c index b27b3da..f61f56a 100644 --- a/src/cerberus.c +++ b/src/cerberus.c @@ -20,8 +20,16 @@ #include <unistd.h> #include "passphrase.h" +#include "quit.h" +/* The number of seconds before the program times out */ +#ifndef TIMEOUT_SECONDS +#define TIMEOUT_SECONDS 60 +#endif + + +/* Free if declared */ #define xfree(VAR) ({ if (VAR) free(VAR); }) @@ -102,11 +110,28 @@ int main(int argc, char** argv) } - /* Get the passphrase, if -f has not been used */ + /* Print ant we want a passphrase, if -f has not been used */ if (skip_auth == 0) { printf("Passphrase: "); fflush(stdout); + } + /* Done early to make to program look like it is even faster than it is */ + + + /* Set up clean quiting and time out */ + signal(SIGALRM, timeout_quit); + signal(SIGQUIT, user_quit); + signal(SIGINT, user_quit); + siginterrupt(SIGALM, 1); + siginterrupt(SIGQUIT, 1); + siginterrupt(SIGINT, 1); + alarm(TIMEOUT_SECONDS); + + + /* Get the passphrase, if -f has not been used */ + if (skip_auth == 0) + { passphrase = get_passphrase(); printf("\n"); } |