aboutsummaryrefslogtreecommitdiff
path: root/src/os/time.c
diff options
context:
space:
mode:
Diffstat (limited to 'src/os/time.c')
-rw-r--r--src/os/time.c58
1 files changed, 58 insertions, 0 deletions
diff --git a/src/os/time.c b/src/os/time.c
new file mode 100644
index 0000000000..bb86806af3
--- /dev/null
+++ b/src/os/time.c
@@ -0,0 +1,58 @@
+#include <stdint.h>
+#include <stdbool.h>
+
+#include <uv.h>
+
+#include "vim.h"
+#include "term.h"
+
+static uv_mutex_t delay_mutex;
+static uv_cond_t delay_cond;
+
+static void delay(uint64_t ms);
+
+void time_init()
+{
+ uv_mutex_init(&delay_mutex);
+ uv_cond_init(&delay_cond);
+}
+
+void mch_delay(uint64_t ms, bool ignoreinput)
+{
+ int old_tmode;
+
+ if (ignoreinput) {
+ /* Go to cooked mode without echo, to allow SIGINT interrupting us
+ * here. But we don't want QUIT to kill us (CTRL-\ used in a
+ * shell may produce SIGQUIT). */
+ in_mch_delay = true;
+ old_tmode = curr_tmode;
+
+ if (curr_tmode == TMODE_RAW)
+ settmode(TMODE_SLEEP);
+
+ delay(ms);
+
+ settmode(old_tmode);
+ in_mch_delay = false;
+ } else {
+ delay(ms);
+ }
+}
+
+static void delay(uint64_t ms)
+{
+ uint64_t hrtime;
+ int64_t ns = ms * 1000000; /* convert to nanoseconds */
+
+ uv_mutex_lock(&delay_mutex);
+
+ while (ns > 0) {
+ hrtime = uv_hrtime();
+ if (uv_cond_timedwait(&delay_cond, &delay_mutex, ns) == UV_ETIMEDOUT)
+ break;
+ ns -= uv_hrtime() - hrtime;
+ }
+
+ uv_mutex_unlock(&delay_mutex);
+}