aboutsummaryrefslogtreecommitdiff
path: root/src/normal.c
diff options
context:
space:
mode:
authorThiago de Arruda <tpadilha84@gmail.com>2014-04-01 08:54:31 -0300
committerThiago de Arruda <tpadilha84@gmail.com>2014-04-01 09:46:29 -0300
commit774f668c43c14c6c6593264a1c8c9a0275b19037 (patch)
tree176395e37139e68c3a40f9271b9cfa04722c0ff1 /src/normal.c
parent40879af7bdd1633f3d22f0d1da9a24992cf3e2b2 (diff)
downloadrneovim-774f668c43c14c6c6593264a1c8c9a0275b19037.tar.gz
rneovim-774f668c43c14c6c6593264a1c8c9a0275b19037.tar.bz2
rneovim-774f668c43c14c6c6593264a1c8c9a0275b19037.zip
Move signal handling to libuv event loop
This removes all signal handling code from os_unix.c to os/signal.c. Now signal handling is done like this: - Watchers for signals are registered with libuv default event loop - `event_poll` continuously calls `poll_uv_loop` to produce events until it receives user input, SIGINT or a timeout - Any signals received in `poll_uv_loop` will push events to a queue that is drained and processed by `event_poll` Signals aren't handled directly in the libuv callback to avoid recursion in the event loop(which isn't supported by libuv). The same principle will apply to other events in the future: Push to a queue from a libuv callback and drain it from `event_poll`
Diffstat (limited to 'src/normal.c')
-rw-r--r--src/normal.c3
1 files changed, 0 insertions, 3 deletions
diff --git a/src/normal.c b/src/normal.c
index 0646a62fcf..6319e19203 100644
--- a/src/normal.c
+++ b/src/normal.c
@@ -7480,9 +7480,6 @@ static void nv_open(cmdarg_T *cap)
n_opencmd(cap);
}
-
-
-
/*
* Trigger CursorHold event.
* When waiting for a character for 'updatetime' K_CURSORHOLD is put in the