aboutsummaryrefslogtreecommitdiffstats
path: root/client.c
diff options
context:
space:
mode:
authortim2020-03-13 20:49:13 +0000
committerWynn Wolf Arbor2020-03-18 14:34:16 +0100
commit3e43b4fd232ddeab777a6ca89b6cfbb371720e21 (patch)
treefe28d07372c6538d2abd41bc62904346433f8d6d /client.c
parent1a2df9d28bc7d25475fe340e588a8102bbb4df2a (diff)
downloadcwm-3e43b4fd232ddeab777a6ca89b6cfbb371720e21.tar.gz
Plug two memory leaks. Also get rid of a variable that is no longer necessary.
OK okan@
Diffstat (limited to '')
-rw-r--r--client.c18
1 files changed, 10 insertions, 8 deletions
diff --git a/client.c b/client.c
index 08c0397..cb3f916 100644
--- a/client.c
+++ b/client.c
@@ -15,7 +15,7 @@
* ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
* OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
*
- * $OpenBSD: client.c,v 1.258 2020/02/28 13:38:35 okan Exp $
+ * $OpenBSD: client.c,v 1.259 2020/03/13 20:49:13 tim Exp $
*/
#include <sys/types.h>
@@ -668,21 +668,23 @@ void
client_set_name(struct client_ctx *cc)
{
struct winname *wn;
- char *newname;
int i = 0;
- if (!xu_get_strprop(cc->win, ewmh[_NET_WM_NAME], &newname))
- if (!xu_get_strprop(cc->win, XA_WM_NAME, &newname))
- newname = xstrdup("");
+ free(cc->name);
+ if (!xu_get_strprop(cc->win, ewmh[_NET_WM_NAME], &cc->name))
+ if (!xu_get_strprop(cc->win, XA_WM_NAME, &cc->name))
+ cc->name = xstrdup("");
TAILQ_FOREACH(wn, &cc->nameq, entry) {
- if (strcmp(wn->name, newname) == 0)
+ if (strcmp(wn->name, cc->name) == 0) {
TAILQ_REMOVE(&cc->nameq, wn, entry);
+ free(wn->name);
+ free(wn);
+ }
i++;
}
- cc->name = newname;
wn = xmalloc(sizeof(*wn));
- wn->name = xstrdup(newname);
+ wn->name = xstrdup(cc->name);
TAILQ_INSERT_TAIL(&cc->nameq, wn, entry);
/* Garbage collection. */