commit 5388a74ae0872ae2920effdb41eef96aac6a25df
parent 0710dfbec92581a81fc0052829c9081e1826dff8
Author: sewn <sewn@disroot.org>
Date:   Wed,  5 Feb 2025 16:02:54 +0300
[slstatus][patch][signals] fix nanosleep for negative intervals
fix pointed out by bakkeby in a reddit thread.
Diffstat:
1 file changed, 13 insertions(+), 14 deletions(-)
diff --git a/tools.suckless.org/slstatus/patches/signals/slstatus-signals-1.0.patch b/tools.suckless.org/slstatus/patches/signals/slstatus-signals-1.0.patch
@@ -1,12 +1,12 @@
-From 8eaf9e1d101d93c784b12902eb71d5b2985a6985 Mon Sep 17 00:00:00 2001
+From fabec4fb9f3cb749f33dc97188106c73a20ca7db Mon Sep 17 00:00:00 2001
 From: sewn <sewn@disroot.org>
-Date: Sat, 12 Oct 2024 20:45:16 +0300
+Date: Wed, 5 Feb 2025 16:00:52 +0300
 Subject: [PATCH] implement signals & turns
 
 ---
  config.def.h |  11 ++++--
- slstatus.c   | 108 ++++++++++++++++++++++++++++++++-------------------
- 2 files changed, 75 insertions(+), 44 deletions(-)
+ slstatus.c   | 107 ++++++++++++++++++++++++++++++++-------------------
+ 2 files changed, 74 insertions(+), 44 deletions(-)
 
 diff --git a/config.def.h b/config.def.h
 index d805331..a89127b 100644
@@ -36,7 +36,7 @@ index d805331..a89127b 100644
 +/* maximum output string length */
 +#define MAXLEN CMDLEN * LEN(args)
 diff --git a/slstatus.c b/slstatus.c
-index fd31313..d5efd35 100644
+index fd31313..b3dbae8 100644
 --- a/slstatus.c
 +++ b/slstatus.c
 @@ -15,20 +15,19 @@ struct arg {
@@ -178,7 +178,7 @@ index fd31313..d5efd35 100644
  
  		if (!done) {
  			if (clock_gettime(CLOCK_MONOTONIC, ¤t) < 0)
-@@ -117,10 +140,15 @@ main(int argc, char *argv[])
+@@ -117,10 +140,14 @@ main(int argc, char *argv[])
  			intspec.tv_nsec = (interval % 1000) * 1E6;
  			difftimespec(&wait, &intspec, &diff);
  
@@ -186,18 +186,17 @@ index fd31313..d5efd35 100644
 -			    nanosleep(&wait, NULL) < 0 &&
 -			    errno != EINTR)
 -					die("nanosleep:");
-+			do {
-+					if (errno == EINTR) {
-+						printstatus(0);
-+						errno = upsigno = 0;
-+					}
-+					ret = nanosleep(&wait, &wait);
-+			} while (wait.tv_sec >= 0 && ret < 0 && !done);
++			while(wait.tv_sec >= 0 &&
++			      (ret = nanosleep(&wait, &wait)) < 0 &&
++			      errno == EINTR && !done) {
++				printstatus(0);
++				errno = upsigno = 0;
++			}
 +			if (ret < 0 && errno != EINTR)
 +				die("nanosleep:");
  		}
  	} while (!done);
  
 -- 
-2.46.2
+2.47.1