Kill a bit of cruft, explain the reasonning behind the kill/traps, and

fix a potential buffering issue eating the first slider event
pull/2/merge
NiLuJe 12 years ago committed by Qingping Hou
parent 0eaf2671fd
commit 2572dd0657

@ -50,7 +50,8 @@ void slider_handler(int sig)
{ {
/* Kill lipc-wait-event properly on exit */ /* Kill lipc-wait-event properly on exit */
if(pclose_arg.pid != 0) { if(pclose_arg.pid != 0) {
kill(pclose_arg.pid, SIGTERM); // Be a little more gracious, lipc seems to handle SIGINT properly
kill(pclose_arg.pid, SIGINT);
} }
} }
@ -84,7 +85,7 @@ static int openInputDevice(lua_State *L) {
return luaL_error(L, "cannot fork() slider event listener"); return luaL_error(L, "cannot fork() slider event listener");
} }
if(childpid == 0) { if(childpid == 0) {
// Setup signal handler, to cleanup on exit // We send a SIGTERM to this child on exit, trap it to kill lipc properly.
signal(SIGTERM, slider_handler); signal(SIGTERM, slider_handler);
FILE *fp; FILE *fp;
@ -99,25 +100,21 @@ static int openInputDevice(lua_State *L) {
ev.code = key_code; ev.code = key_code;
ev.value = 1; ev.value = 1;
/* listen power slider events */ /* listen power slider events (listen for ever for multiple events) */
char *exec_file = "lipc-wait-event"; char *argv[] = {"lipc-wait-event", "-m", "-s", "0", "com.lab126.powerd", "goingToScreenSaver,outOfScreenSaver,charging,notCharging", (char *) NULL};
char *arg1 = "-m"; // Hang for ever, don't exit on the first one: we're in a dedicated child, and we'll be killed/closed on exit, so we don't care
char *arg2 = "-s";
char *arg3 = "0";
char *arg4 = "com.lab126.powerd";
char *arg5 = "goingToScreenSaver,outOfScreenSaver,charging,notCharging";
char *arg6 = (char *) NULL;
char *argv[] = {exec_file, arg1, arg2, arg3, arg4, arg5, arg6};
/* @TODO 07.06 2012 (houqp) /* @TODO 07.06 2012 (houqp)
* plugin and out event can only be watched by: * plugin and out event can only be watched by:
lipc-wait-event com.lab126.hal usbPlugOut,usbPlugIn lipc-wait-event com.lab126.hal usbPlugOut,usbPlugIn
*/ */
fp = popen_noshell(exec_file, (const char * const *)argv, "r", &pclose_arg, 0); fp = popen_noshell("lipc-wait-event", (const char * const *)argv, "r", &pclose_arg, 0);
if (!fp) { if (!fp) {
err(EXIT_FAILURE, "popen_noshell()"); err(EXIT_FAILURE, "popen_noshell()");
} }
/* Flush to get rid of buffering issues? */
fflush(fp);
while(fgets(std_out, sizeof(std_out)-1, fp)) { while(fgets(std_out, sizeof(std_out)-1, fp)) {
if(std_out[0] == 'g') { if(std_out[0] == 'g') {
ev.code = CODE_IN_SAVER; ev.code = CODE_IN_SAVER;
@ -147,13 +144,13 @@ static int openInputDevice(lua_State *L) {
if (status == -1) { if (status == -1) {
err(EXIT_FAILURE, "pclose_noshell()"); err(EXIT_FAILURE, "pclose_noshell()");
} else { } else {
printf("Power slider event listener child exited with status %d.\n", status); printf("lipc-wait-event exited with status %d.\n", status);
if WIFEXITED(status) { if WIFEXITED(status) {
printf("Child exited normally with status: %d.\n", WEXITSTATUS(status)); printf("lipc-wait-event exited normally with status: %d.\n", WEXITSTATUS(status));
} }
if WIFSIGNALED(status) { if WIFSIGNALED(status) {
printf("Child terminated by signal: %d.\n", WTERMSIG(status)); printf("lipc-wait-event terminated by signal: %d.\n", WTERMSIG(status));
} }
} }
@ -193,7 +190,7 @@ static int closeInputDevices(lua_State *L) {
} }
if(slider_pid != -1) { if(slider_pid != -1) {
/* kill and wait for child process */ /* kill and wait for child process */
kill(slider_pid, SIGTERM); kill(slider_pid, SIGTERM); // We could kill -slider_pid (note the minus) to kill the whole process group, but we trap SIGTERM to handle things nicely
waitpid(-1, NULL, 0); waitpid(-1, NULL, 0);
} }
return 0; return 0;

@ -123,15 +123,6 @@ int main(int argc, char **argv) {
} }
} }
/* Make popen_noshell & valgrind happy */
if (fflush(stdout) != 0)
err(EXIT_FAILURE, "fflush(stdout)");
if (fflush(stderr) != 0)
err(EXIT_FAILURE, "fflush(stderr)");
close(STDIN_FILENO);
close(STDOUT_FILENO);
close(STDERR_FILENO);
return 0; return 0;
} }

@ -65,16 +65,9 @@ main ( int argc, char *argv[] )
ev.value = 1; ev.value = 1;
/* listen power slider events */ /* listen power slider events */
char *exec_file = "lipc-wait-event"; char *argv[] = {"lipc-wait-event", "-m", "-s", "0", "com.lab126.powerd", "goingToScreenSaver,outOfScreenSaver", (char *) NULL};
char *arg1 = "-m";
char *arg2 = "-s"; fp = popen_noshell("lipc-wait-event", (const char * const *)chargv, "r", &pclose_arg, 0);
char *arg3 = "0";
char *arg4 = "com.lab126.powerd";
char *arg5 = "goingToScreenSaver,outOfScreenSaver";
char *arg6 = (char *) NULL;
char *chargv[] = {exec_file, arg1, arg2, arg3, arg4, arg5, arg6};
fp = popen_noshell(exec_file, (const char * const *)chargv, "r", &pclose_arg, 0);
if (!fp) { if (!fp) {
err(EXIT_FAILURE, "popen_noshell()"); err(EXIT_FAILURE, "popen_noshell()");
} }

Loading…
Cancel
Save