X-Git-Url: https://sigrok.org/gitweb/?p=sigrok-cli.git;a=blobdiff_plain;f=anykey.c;h=4126518e8a0801dc3700bdc3c0e86582668b47fd;hp=be16ff11a37fa6895a4385d93665f890f2cb8b4e;hb=7c6a0420448760fc138cbe38579a5c9e0a46132c;hpb=43e5747a59ed92243c217f7e36da2ac35bbcd80d diff --git a/anykey.c b/anykey.c index be16ff1..4126518 100644 --- a/anykey.c +++ b/anykey.c @@ -1,5 +1,5 @@ /* - * This file is part of the sigrok project. + * This file is part of the sigrok-cli project. * * Copyright (C) 2011 Bert Vermeulen * @@ -17,6 +17,7 @@ * along with this program. If not, see . */ +#include "sigrok-cli.h" #include #ifdef _WIN32 #include @@ -26,30 +27,29 @@ #include #include #include -#include -#include "sigrok-cli.h" #ifdef _WIN32 -HANDLE stdin_handle; -DWORD stdin_mode; +static HANDLE stdin_handle; +static DWORD stdin_mode; #else -struct termios term_orig; +static struct termios term_orig; #endif -static int received_anykey(int fd, int revents, void *user_data) +static int received_anykey(int fd, int revents, void *cb_data) { - /* Avoid compiler warnings. */ + struct sr_session *session; (void)fd; (void)revents; - (void)user_data; - sr_session_stop(); + session = cb_data; + sr_session_source_remove(session, STDIN_FILENO); + sr_session_stop(session); return TRUE; } /* Turn off buffering on stdin. */ -void add_anykey(void) +void add_anykey(struct sr_session *session) { #ifdef _WIN32 stdin_handle = GetStdHandle(STD_INPUT_HANDLE); @@ -68,9 +68,10 @@ void add_anykey(void) tcsetattr(STDIN_FILENO, TCSADRAIN, &term); #endif - sr_session_source_add(STDIN_FILENO, G_IO_IN, -1, received_anykey, NULL); + sr_session_source_add(session, STDIN_FILENO, G_IO_IN, -1, + received_anykey, session); - printf("Press any key to stop acquisition.\n"); + g_message("Press any key to stop acquisition."); } /* Restore stdin attributes. */