From c689b93bce30afda8881746b4a0195452b74d8fc Mon Sep 17 00:00:00 2001 From: Michael Stapelberg Date: Tue, 28 Apr 2009 22:41:00 +0200 Subject: [PATCH] =?UTF-8?q?Bugfix:=20Don=E2=80=99t=20crash=20when=20asprin?= =?UTF-8?q?tf()=20can=E2=80=99t=20print=20the=20window=20name=20(Thanks=20?= =?UTF-8?q?ch3ka)?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Apparantly, under some conditions (using LANG=en_US.UTF-8, other locale variables unset), asprintf() says "Invalid or incomplete multibyte or wide character" when given a string in COMPOUND_TEXT encoding. For now, we properly handle asprintf-errors (this should have been before), but there might be a better solution. --- src/handlers.c | 6 +++++- 1 file changed, 5 insertions(+), 1 deletion(-) diff --git a/src/handlers.c b/src/handlers.c index d31d0f33..0102cb12 100644 --- a/src/handlers.c +++ b/src/handlers.c @@ -747,7 +747,11 @@ int handle_windowname_change_legacy(void *data, xcb_connection_t *conn, uint8_t /* Save the old pointer to make the update atomic */ char *new_name; - asprintf(&new_name, "%.*s", xcb_get_property_value_length(prop), (char*)xcb_get_property_value(prop)); + if (asprintf(&new_name, "%.*s", xcb_get_property_value_length(prop), (char*)xcb_get_property_value(prop)) == -1) { + perror("Could not get old name"); + LOG("Could not get old name\n"); + return 1; + } /* Convert it to UCS-2 here for not having to convert it later every time we want to pass it to X */ LOG("Name should change to \"%s\"\n", new_name);