diff dep/animia/src/win/x11.cc @ 214:8d35061e7505

dep/animia: win/x11: simplify getting strings
author Paper <mrpapersonic@gmail.com>
date Sun, 07 Jan 2024 11:19:28 -0500
parents 58e81b42a0d6
children 8ccf0302afb1
line wrap: on
line diff
--- a/dep/animia/src/win/x11.cc	Sun Jan 07 11:11:27 2024 -0500
+++ b/dep/animia/src/win/x11.cc	Sun Jan 07 11:19:28 2024 -0500
@@ -20,19 +20,23 @@
 typedef ::Display XDisplay;
 typedef ::Atom XAtom;
 
-/* should return UTF8_STRING or STRING */
-static bool GetWindowPropertyAsString(XDisplay* display, XWindow window, XAtom atom, std::string& result, XAtom reqtype = AnyPropertyType) {
-	if (atom == None || reqtype == None)
+/* should return UTF8_STRING or STRING. this means we are not
+ * *guaranteed* a UTF-8 string back.
+*/
+static bool GetWindowPropertyAsString(XDisplay* display, XWindow window, XAtom atom, std::string& result) {
+	if (atom == None)
 		return false;
 
+	XAtom Atom_UTF8_STRING = ::XInternAtom(display, "UTF8_STRING", False);
+
 	int format;
 	unsigned long leftover_bytes, num_of_items;
 	XAtom type;
 	unsigned char* data;
 
-	int status = ::XGetWindowProperty(display, window, atom, 0L, (~0L), False, reqtype,
+	int status = ::XGetWindowProperty(display, window, atom, 0L, (~0L), False, AnyPropertyType,
 	                                  &type, &format, &num_of_items, &leftover_bytes, &data);
-	if (status != Success || !(reqtype == AnyPropertyType || type == reqtype) || !num_of_items)
+	if (status != Success || !(type == Atom_UTF8_STRING || type == XA_STRING) || !num_of_items)
 		return false;
 
 	result = std::string((char*)data, num_of_items);
@@ -91,13 +95,10 @@
 }
 
 static bool FetchName(XDisplay* display, XWindow window, std::string& result) {
-	/* TODO: Check if XInternAtom created None or not... */
-	if (GetWindowPropertyAsString(display, window, ::XInternAtom(display, "_NET_WM_NAME", True),
-		                          result, ::XInternAtom(display, "UTF8_STRING", True)))
+	if (GetWindowPropertyAsString(display, window, ::XInternAtom(display, "_NET_WM_NAME", True), result))
 		return true;
 
-	if (GetWindowPropertyAsString(display, window, ::XInternAtom(display, "WM_NAME", True),
-		                           result, XA_STRING))
+	if (GetWindowPropertyAsString(display, window, ::XInternAtom(display, "WM_NAME", True), result))
 		return true;
 
 	/* Fallback to XGetWMName() */
@@ -147,11 +148,6 @@
 
 		if (status < Success || !num_of_items)
 			return false;
-
-		if (format != 32) {
-			::XFree(data);
-			return false;
-		}
 	}
 
 	XWindow* arr = (XWindow*)data;