From ad571e7448eb53fb099ec0cb87baf97cb38d3450 Mon Sep 17 00:00:00 2001 From: NRK Date: Sun, 27 Feb 2022 16:53:45 +0600 Subject: [PATCH] always initialize window title before if exec/win-title didn't exist then window title wouldn't be set. this patch makes it so window title is always set to something. --- main.c | 38 ++++++++++++++++++++++---------------- nsxiv.h | 2 +- window.c | 8 ++++---- 3 files changed, 27 insertions(+), 21 deletions(-) diff --git a/main.c b/main.c index f485d39..d33d6ab 100644 --- a/main.c +++ b/main.c @@ -233,30 +233,36 @@ static bool check_timeouts(struct timeval *t) return tmin > 0; } -size_t get_win_title(unsigned char *buf, int len) +size_t get_win_title(unsigned char *buf, int len, bool init) { char *argv[8]; spawn_t pfd; char w[12] = "", h[12] = "", z[12] = "", fidx[12], fcnt[12]; ssize_t n = -1; - if (wintitle.f.err || buf == NULL || len <= 0) + if (buf == NULL || len <= 0) return 0; - if (mode == MODE_IMAGE) { - snprintf(w, ARRLEN(w), "%d", img.w); - snprintf(h, ARRLEN(h), "%d", img.h); - snprintf(z, ARRLEN(z), "%d", (int)(img.zoom * 100)); - } - snprintf(fidx, ARRLEN(fidx), "%d", fileidx+1); - snprintf(fcnt, ARRLEN(fcnt), "%d", filecnt); - construct_argv(argv, ARRLEN(argv), wintitle.f.cmd, files[fileidx].path, - fidx, fcnt, w, h, z, NULL); - pfd = spawn(wintitle.f.cmd, argv, X_READ); - if (pfd.readfd >= 0) { - if ((n = read(pfd.readfd, buf, len-1)) > 0) - buf[n] = '\0'; + if (init) { + n = snprintf((char *)buf, len, "%s", options->res_name != NULL ? + options->res_name : "nsxiv"); + } else if (!wintitle.f.err) { + if (mode == MODE_IMAGE) { + snprintf(w, ARRLEN(w), "%d", img.w); + snprintf(h, ARRLEN(h), "%d", img.h); + snprintf(z, ARRLEN(z), "%d", (int)(img.zoom * 100)); + } + snprintf(fidx, ARRLEN(fidx), "%d", fileidx+1); + snprintf(fcnt, ARRLEN(fcnt), "%d", filecnt); + construct_argv(argv, ARRLEN(argv), wintitle.f.cmd, files[fileidx].path, + fidx, fcnt, w, h, z, NULL); + pfd = spawn(wintitle.f.cmd, argv, X_READ); + if (pfd.readfd >= 0) { + if ((n = read(pfd.readfd, buf, len-1)) > 0) + buf[n] = '\0'; + } } + return MAX(0, n); } @@ -459,7 +465,7 @@ void redraw(void) tns_render(&tns); } update_info(); - win_set_title(&win); + win_set_title(&win, false); win_draw(&win); reset_timeout(redraw); reset_cursor(); diff --git a/nsxiv.h b/nsxiv.h index a60f028..8576d51 100644 --- a/nsxiv.h +++ b/nsxiv.h @@ -442,7 +442,7 @@ void win_toggle_bar(win_t*); void win_clear(win_t*); void win_draw(win_t*); void win_draw_rect(win_t*, int, int, int, int, bool, int, unsigned long); -void win_set_title(win_t*); +void win_set_title(win_t*, bool); void win_set_cursor(win_t*, cursor_t); void win_cursor_pos(win_t*, int*, int*); diff --git a/window.c b/window.c index 9bfc2ec..fb9c776 100644 --- a/window.c +++ b/window.c @@ -30,7 +30,7 @@ #include #include -extern size_t get_win_title(unsigned char *, int); +extern size_t get_win_title(unsigned char *, int, bool); #if HAVE_LIBFONTS #include "utf8.h" @@ -289,9 +289,9 @@ void win_open(win_t *win) } free(icon_data); - /* These two atoms won't change and thus only need to be set once. */ XStoreName(win->env.dpy, win->xwin, res_name); XSetIconName(win->env.dpy, win->xwin, res_name); + win_set_title(win, true); classhint.res_class = res_class; classhint.res_name = options->res_name != NULL ? options->res_name : res_name; @@ -503,12 +503,12 @@ void win_draw_rect(win_t *win, int x, int y, int w, int h, bool fill, int lw, XDrawRectangle(win->env.dpy, win->buf.pm, gc, x, y, w, h); } -void win_set_title(win_t *win) +void win_set_title(win_t *win, bool init) { unsigned char title[512]; size_t len; - if ((len = get_win_title(title, ARRLEN(title))) <= 0) + if ((len = get_win_title(title, ARRLEN(title), init)) <= 0) return; XChangeProperty(win->env.dpy, win->xwin, atoms[ATOM__NET_WM_NAME],