commit 59e46f178eccd10472f1a9a2a62d8efb0b3f7d15
Author: Son Phan Trung <[email protected]>
Date:   Tue Mar 12 18:44:11 2024 +0700

    dwm/patches/cool_autostart: Add updated patch
    
    As commit 712d6639ff8e863560328131bbb92b248dc9cde7 changed the way
    SIGCHLD was handled, an update is necessary

diff --git 
a/dwm.suckless.org/patches/cool_autostart/dwm-cool-autostart-20240312-9f88553.diff
 
b/dwm.suckless.org/patches/cool_autostart/dwm-cool-autostart-20240312-9f88553.diff
new file mode 100644
index 00000000..b0890d96
--- /dev/null
+++ 
b/dwm.suckless.org/patches/cool_autostart/dwm-cool-autostart-20240312-9f88553.diff
@@ -0,0 +1,133 @@
+From feeaa839d2c6c1d0e66649cb64c4added563d4e4 Mon Sep 17 00:00:00 2001
+From: Son Phan Trung <[email protected]>
+Date: Tue, 12 Mar 2024 18:37:32 +0700
+Subject: [PATCH] patches/cool-autostart: Update patch
+
+Updated for the removal of the sigchld() function.
+---
+ config.def.h |  5 +++++
+ dwm.c        | 57 +++++++++++++++++++++++++++++++++++++++++++++++++++-
+ 2 files changed, 61 insertions(+), 1 deletion(-)
+
+diff --git a/config.def.h b/config.def.h
+index 9efa774..aba210d 100644
+--- a/config.def.h
++++ b/config.def.h
+@@ -18,6 +18,11 @@ static const char *colors[][3]      = {
+       [SchemeSel]  = { col_gray4, col_cyan,  col_cyan  },
+ };
+ 
++static const char *const autostart[] = {
++      "st", NULL,
++      NULL /* terminate */
++};
++
+ /* tagging */
+ static const char *tags[] = { "1", "2", "3", "4", "5", "6", "7", "8", "9" };
+ 
+diff --git a/dwm.c b/dwm.c
+index f1d86b2..c2eb07d 100644
+--- a/dwm.c
++++ b/dwm.c
+@@ -233,6 +233,7 @@ static int xerror(Display *dpy, XErrorEvent *ee);
+ static int xerrordummy(Display *dpy, XErrorEvent *ee);
+ static int xerrorstart(Display *dpy, XErrorEvent *ee);
+ static void zoom(const Arg *arg);
++static void autostart_exec(void);
+ 
+ /* variables */
+ static const char broken[] = "broken";
+@@ -274,6 +275,34 @@ static Window root, wmcheckwin;
+ /* compile-time check if all tags fit into an unsigned int bit array. */
+ struct NumTags { char limitexceeded[LENGTH(tags) > 31 ? -1 : 1]; };
+ 
++/* dwm will keep pid's of processes from autostart array and kill them at 
quit */
++static pid_t *autostart_pids;
++static size_t autostart_len;
++
++/* execute command from autostart array */
++static void
++autostart_exec() {
++      const char *const *p;
++      size_t i = 0;
++
++      /* count entries */
++      for (p = autostart; *p; autostart_len++, p++)
++              while (*++p);
++
++      autostart_pids = malloc(autostart_len * sizeof(pid_t));
++      for (p = autostart; *p; i++, p++) {
++              if ((autostart_pids[i] = fork()) == 0) {
++                      setsid();
++                      execvp(*p, (char *const *)p);
++                      fprintf(stderr, "dwm: execvp %s
", *p);
++                      perror(" failed");
++                      _exit(EXIT_FAILURE);
++              }
++              /* skip arguments */
++              while (*++p);
++      }
++}
++
+ /* function implementations */
+ void
+ applyrules(Client *c)
+@@ -1258,6 +1287,16 @@ propertynotify(XEvent *e)
+ void
+ quit(const Arg *arg)
+ {
++      size_t i;
++
++      /* kill child processes */
++      for (i = 0; i < autostart_len; i++) {
++              if (0 < autostart_pids[i]) {
++                      kill(autostart_pids[i], SIGTERM);
++                      waitpid(autostart_pids[i], NULL, 0);
++              }
++      }
++
+       running = 0;
+ }
+ 
+@@ -1540,6 +1579,7 @@ void
+ setup(void)
+ {
+       int i;
++      pid_t pid;
+       XSetWindowAttributes wa;
+       Atom utf8string;
+       struct sigaction sa;
+@@ -1551,7 +1591,21 @@ setup(void)
+       sigaction(SIGCHLD, &sa, NULL);
+ 
+       /* clean up any zombies (inherited from .xinitrc etc) immediately */
+-      while (waitpid(-1, NULL, WNOHANG) > 0);
++      while ((pid = waitpid(-1, NULL, WNOHANG)) > 0) {
++              pid_t *p, *lim;
++
++              if (!(p = autostart_pids))
++                      continue;
++              lim = &p[autostart_len];
++
++              for (; p < lim; p++) {
++                      if (*p == pid) {
++                              *p = -1;
++                              break;
++                      }
++              }
++
++      }
+ 
+       /* init screen */
+       screen = DefaultScreen(dpy);
+@@ -2152,6 +2206,7 @@ main(int argc, char *argv[])
+       if (!(dpy = XOpenDisplay(NULL)))
+               die("dwm: cannot open display");
+       checkotherwm();
++      autostart_exec();
+       setup();
+ #ifdef __OpenBSD__
+       if (pledge("stdio rpath proc exec", NULL) == -1)
+-- 
+2.44.0
+
diff --git a/dwm.suckless.org/patches/cool_autostart/index.md 
b/dwm.suckless.org/patches/cool_autostart/index.md
index e1ea3dab..e3d6a72e 100644
--- a/dwm.suckless.org/patches/cool_autostart/index.md
+++ b/dwm.suckless.org/patches/cool_autostart/index.md
@@ -28,8 +28,10 @@ So if you need to execute shell command you need to prefix 
it with
 Download
 --------
 * [dwm-cool-autostart-6.2.diff](dwm-cool-autostart-6.2.diff)
+* 
[dwm-cool-autostart-20240312-9f88553.diff](dwm-cool-autostart-20240312-9f88553.diff)
 
 Authors
 -------
 * bit6tream <[email protected]> [bit6tream's 
gitlab](https://gitlab.com/bit9tream)
 * zsugabubus <[email protected]>
+* Son Phan Trung <[email protected]>


Reply via email to