emacs-bug-tracker
[Top][All Lists]
Advanced

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

[Emacs-bug-tracker] bug#8410: closed (make_invisible_cursor returns garb


From: GNU bug Tracking System
Subject: [Emacs-bug-tracker] bug#8410: closed (make_invisible_cursor returns garbage if XCreateBitmapFromData fails)
Date: Wed, 06 Apr 2011 05:48:02 +0000

Your message dated Tue, 05 Apr 2011 22:47:16 -0700
with message-id <address@hidden>
and subject line fix installed in trunk
has caused the GNU bug report #8410,
regarding make_invisible_cursor returns garbage if XCreateBitmapFromData fails
to be marked as done.

(If you believe you have received this mail in error, please contact
address@hidden)


-- 
8410: http://debbugs.gnu.org/cgi/bugreport.cgi?bug=8410
GNU Bug Tracking System
Contact address@hidden with problems
--- Begin Message --- Subject: make_invisible_cursor returns garbage if XCreateBitmapFromData fails Date: Fri, 01 Apr 2011 19:21:34 -0700 User-agent: Mozilla/5.0 (X11; U; Linux i686; en-US; rv:1.9.2.14) Gecko/20110223 Thunderbird/3.1.8
I found this bug via static analysis, using GCC 4.6.0's warnings.
src/xfns.c's make_invisible_cursor returns a garbage value if
XCreateBitmapFromData fails.  I plan to fix it as follows.
I don't know that returning 0 fixes the bug, so I'd like someone
who's expert in this area to look at this.  Since the patch replaces
undefined behavior with defined behavior it isn't likely to be
introducing a bug, so it shouldn't hurt to install the patch.

* xfns.c (make_invisible_cursor): Don't return garbage
if XCreateBitmapFromData fails.
=== modified file 'src/xfns.c'
--- src/xfns.c  2011-04-01 20:30:45 +0000
+++ src/xfns.c  2011-04-01 23:01:33 +0000
@@ -855,19 +855,20 @@
   static char const no_data[] = { 0 };
   Pixmap pix;
   XColor col;
-  Cursor c;
+  Cursor c = 0;

   x_catch_errors (dpy);
   pix = XCreateBitmapFromData (dpy, FRAME_X_DISPLAY_INFO (f)->root_window,
                                no_data, 1, 1);
   if (! x_had_errors_p (dpy) && pix != None)
     {
+      Cursor pixc;
       col.pixel = 0;
       col.red = col.green = col.blue = 0;
       col.flags = DoRed | DoGreen | DoBlue;
-      c = XCreatePixmapCursor (dpy, pix, pix, &col, &col, 0, 0);
-      if (x_had_errors_p (dpy) || c == None)
-        c = 0;
+      pixc = XCreatePixmapCursor (dpy, pix, pix, &col, &col, 0, 0);
+      if (! x_had_errors_p (dpy) && pixc != None)
+        c = pixc;
       XFreePixmap (dpy, pix);
     }





--- End Message ---
--- Begin Message --- Subject: fix installed in trunk Date: Tue, 05 Apr 2011 22:47:16 -0700 User-agent: Mozilla/5.0 (X11; U; Linux i686; en-US; rv:1.9.2.14) Gecko/20110223 Thunderbird/3.1.8
I committed the previously-mentioned fix
as part of the merge to the trunk in bzr 103841.


--- End Message ---

reply via email to

[Prev in Thread] Current Thread [Next in Thread]