From 20c2a38ad0b8ac54a0eef165bc4e1b58e599a7b1 Mon Sep 17 00:00:00 2001 From: Matt Stancliff Date: Tue, 17 Jun 2014 10:12:57 -0400 Subject: [PATCH] Add SIGINT handler to cli --intrinsic-latency If we run a long latency session and want to Ctrl-C out of it, it's nice to still get the summary output at the end. --- src/redis-cli.c | 9 ++++++++- 1 file changed, 8 insertions(+), 1 deletion(-) diff --git a/src/redis-cli.c b/src/redis-cli.c index b8e17d24e..bd3b72144 100644 --- a/src/redis-cli.c +++ b/src/redis-cli.c @@ -95,6 +95,7 @@ static struct config { char *eval; } config; +static volatile sig_atomic_t force_cancel_loop = 0; static void usage(); static void slaveMode(void); char *redisGitSHA1(void); @@ -1807,11 +1808,17 @@ unsigned long compute_something_fast(void) { return output; } +static void intrinsicLatencyModeStop(int s) { + REDIS_NOTUSED(s); + force_cancel_loop = 1; +} + static void intrinsicLatencyMode(void) { long long test_end, run_time, max_latency = 0, runs = 0; run_time = config.intrinsic_latency_duration*1000000; test_end = ustime() + run_time; + signal(SIGINT, intrinsicLatencyModeStop); while(1) { long long start, end, latency; @@ -1829,7 +1836,7 @@ static void intrinsicLatencyMode(void) { printf("Max latency so far: %lld microseconds.\n", max_latency); } - if (end > test_end) { + if (force_cancel_loop || end > test_end) { printf("\n%lld total runs (avg %lld microseconds per run).\n", runs, run_time/runs); printf("Worst run took %.02fx times the average.\n",