diff options
author | Owen Taylor <otaylor@redhat.com> | 2001-06-23 22:14:02 +0000 |
---|---|---|
committer | Owen Taylor <otaylor@src.gnome.org> | 2001-06-23 22:14:02 +0000 |
commit | 5a5580a8e77dda9b7746012405f8e813a0e6c87b (patch) | |
tree | e42abf38789183406222263f309c03c26e56c425 | |
parent | 92e87e40a7525cd84579865bf7404a84bde93115 (diff) | |
download | gtk+-5a5580a8e77dda9b7746012405f8e813a0e6c87b.tar.gz |
Fix tests for XShm.h.
Sat Jun 23 18:02:46 2001 Owen Taylor <otaylor@redhat.com>
* configure.in: Fix tests for XShm.h.
* gdk/x11/gdkimage-x11.c: Cleanup error handling in
gdk_image_new() by use of goto, properly use g_object_unref().
-rw-r--r-- | ChangeLog | 7 | ||||
-rw-r--r-- | ChangeLog.pre-2-0 | 7 | ||||
-rw-r--r-- | ChangeLog.pre-2-10 | 7 | ||||
-rw-r--r-- | ChangeLog.pre-2-2 | 7 | ||||
-rw-r--r-- | ChangeLog.pre-2-4 | 7 | ||||
-rw-r--r-- | ChangeLog.pre-2-6 | 7 | ||||
-rw-r--r-- | ChangeLog.pre-2-8 | 7 | ||||
-rw-r--r-- | configure.in | 27 | ||||
-rw-r--r-- | gdk/x11/gdkimage-x11.c | 131 |
9 files changed, 134 insertions, 73 deletions
@@ -1,3 +1,10 @@ +Sat Jun 23 18:02:46 2001 Owen Taylor <otaylor@redhat.com> + + * configure.in: Fix tests for XShm.h. + + * gdk/x11/gdkimage-x11.c: Cleanup error handling in + gdk_image_new() by use of goto, properly use g_object_unref(). + Sat Jun 23 22:03:20 2001 Tim Janik <timj@gtk.org> * gdk/x11/gdkimage-x11.c (gdk_image_init): disabled g_free (image) diff --git a/ChangeLog.pre-2-0 b/ChangeLog.pre-2-0 index 792da488df..4681cf051c 100644 --- a/ChangeLog.pre-2-0 +++ b/ChangeLog.pre-2-0 @@ -1,3 +1,10 @@ +Sat Jun 23 18:02:46 2001 Owen Taylor <otaylor@redhat.com> + + * configure.in: Fix tests for XShm.h. + + * gdk/x11/gdkimage-x11.c: Cleanup error handling in + gdk_image_new() by use of goto, properly use g_object_unref(). + Sat Jun 23 22:03:20 2001 Tim Janik <timj@gtk.org> * gdk/x11/gdkimage-x11.c (gdk_image_init): disabled g_free (image) diff --git a/ChangeLog.pre-2-10 b/ChangeLog.pre-2-10 index 792da488df..4681cf051c 100644 --- a/ChangeLog.pre-2-10 +++ b/ChangeLog.pre-2-10 @@ -1,3 +1,10 @@ +Sat Jun 23 18:02:46 2001 Owen Taylor <otaylor@redhat.com> + + * configure.in: Fix tests for XShm.h. + + * gdk/x11/gdkimage-x11.c: Cleanup error handling in + gdk_image_new() by use of goto, properly use g_object_unref(). + Sat Jun 23 22:03:20 2001 Tim Janik <timj@gtk.org> * gdk/x11/gdkimage-x11.c (gdk_image_init): disabled g_free (image) diff --git a/ChangeLog.pre-2-2 b/ChangeLog.pre-2-2 index 792da488df..4681cf051c 100644 --- a/ChangeLog.pre-2-2 +++ b/ChangeLog.pre-2-2 @@ -1,3 +1,10 @@ +Sat Jun 23 18:02:46 2001 Owen Taylor <otaylor@redhat.com> + + * configure.in: Fix tests for XShm.h. + + * gdk/x11/gdkimage-x11.c: Cleanup error handling in + gdk_image_new() by use of goto, properly use g_object_unref(). + Sat Jun 23 22:03:20 2001 Tim Janik <timj@gtk.org> * gdk/x11/gdkimage-x11.c (gdk_image_init): disabled g_free (image) diff --git a/ChangeLog.pre-2-4 b/ChangeLog.pre-2-4 index 792da488df..4681cf051c 100644 --- a/ChangeLog.pre-2-4 +++ b/ChangeLog.pre-2-4 @@ -1,3 +1,10 @@ +Sat Jun 23 18:02:46 2001 Owen Taylor <otaylor@redhat.com> + + * configure.in: Fix tests for XShm.h. + + * gdk/x11/gdkimage-x11.c: Cleanup error handling in + gdk_image_new() by use of goto, properly use g_object_unref(). + Sat Jun 23 22:03:20 2001 Tim Janik <timj@gtk.org> * gdk/x11/gdkimage-x11.c (gdk_image_init): disabled g_free (image) diff --git a/ChangeLog.pre-2-6 b/ChangeLog.pre-2-6 index 792da488df..4681cf051c 100644 --- a/ChangeLog.pre-2-6 +++ b/ChangeLog.pre-2-6 @@ -1,3 +1,10 @@ +Sat Jun 23 18:02:46 2001 Owen Taylor <otaylor@redhat.com> + + * configure.in: Fix tests for XShm.h. + + * gdk/x11/gdkimage-x11.c: Cleanup error handling in + gdk_image_new() by use of goto, properly use g_object_unref(). + Sat Jun 23 22:03:20 2001 Tim Janik <timj@gtk.org> * gdk/x11/gdkimage-x11.c (gdk_image_init): disabled g_free (image) diff --git a/ChangeLog.pre-2-8 b/ChangeLog.pre-2-8 index 792da488df..4681cf051c 100644 --- a/ChangeLog.pre-2-8 +++ b/ChangeLog.pre-2-8 @@ -1,3 +1,10 @@ +Sat Jun 23 18:02:46 2001 Owen Taylor <otaylor@redhat.com> + + * configure.in: Fix tests for XShm.h. + + * gdk/x11/gdkimage-x11.c: Cleanup error handling in + gdk_image_new() by use of goto, properly use g_object_unref(). + Sat Jun 23 22:03:20 2001 Tim Janik <timj@gtk.org> * gdk/x11/gdkimage-x11.c (gdk_image_init): disabled g_free (image) diff --git a/configure.in b/configure.in index f1300ea197..3b8eba5d76 100644 --- a/configure.in +++ b/configure.in @@ -775,18 +775,27 @@ if test "x$gdktarget" = "xx11"; then AC_CHECK_HEADER(sys/shm.h, AC_DEFINE(HAVE_SHM_H), no_sys_shm=yes) # Check for the X shared memory extension header file + have_xshm=no AC_MSG_CHECKING(X11/extensions/XShm.h) if test "x$no_xext_lib" = "xyes"; then - AC_MSG_RESULT(no) - no_xshm=yes + : else - if test -f "$x_includes/X11/extensions/XShm.h"; then - AC_MSG_RESULT(yes) - AC_DEFINE(HAVE_XSHM_H) - else - AC_MSG_RESULT(no) - no_xshm=yes - fi + gtk_save_CFLAGS="$CFLAGS" + CFLAGS="$CFLAGS $x_cflags" + AC_TRY_COMPILE([ +#include <stdlib.h> +#include <sys/types.h> +#include <sys/ipc.h> +#include <sys/shm.h> +#include <X11/Xlib.h> +#include <X11/Xutil.h> +#include <X11/extensions/XShm.h> +], [XShmSegmentInfo *x_shm_info;], have_xshm=yes) + CFLAGS="$gtk_save_CFLAGS" + fi + AC_MSG_RESULT($have_xshm) + if test $have_xshm = yes ; then + AC_DEFINE(HAVE_XSHM_H) fi fi diff --git a/gdk/x11/gdkimage-x11.c b/gdk/x11/gdkimage-x11.c index 008b515bc7..23d9dc7ba0 100644 --- a/gdk/x11/gdkimage-x11.c +++ b/gdk/x11/gdkimage-x11.c @@ -62,8 +62,6 @@ static void gdk_image_finalize (GObject *object); #define PRIVATE_DATA(image) ((GdkImagePrivateX11 *) GDK_IMAGE (image)->windowing_data) -#define LEAK_IMAGE(image) /* FIXME!! this should be g_object_unref */ - GType gdk_image_get_type (void) { @@ -243,16 +241,17 @@ gdk_image_new (GdkImageType type, { private->x_shm_info = g_new (XShmSegmentInfo, 1); x_shm_info = private->x_shm_info; + x_shm_info->shmid = -1; + x_shm_info->shmaddr = (char*) -1; private->ximage = XShmCreateImage (private->xdisplay, xvisual, visual->depth, ZPixmap, NULL, x_shm_info, width, height); if (private->ximage == NULL) { g_warning ("XShmCreateImage failed"); - - LEAK_IMAGE (image); - gdk_use_xshm = False; - return NULL; + gdk_use_xshm = FALSE; + + goto error; } x_shm_info->shmid = shmget (IPC_PRIVATE, @@ -269,14 +268,10 @@ gdk_image_new (GdkImageType type, if (errno != EINVAL) { g_warning ("shmget failed: error %d (%s)", errno, g_strerror (errno)); - gdk_use_xshm = False; + gdk_use_xshm = FALSE; } - XDestroyImage (private->ximage); - g_free (private->x_shm_info); - LEAK_IMAGE (image); - - return NULL; + goto error; } x_shm_info->readOnly = False; @@ -286,20 +281,12 @@ gdk_image_new (GdkImageType type, if (x_shm_info->shmaddr == (char*) -1) { g_warning ("shmat failed: error %d (%s)", errno, g_strerror (errno)); - - XDestroyImage (private->ximage); - shmctl (x_shm_info->shmid, IPC_RMID, 0); - - g_free (private->x_shm_info); - LEAK_IMAGE (image); - /* Failure in shmat is almost certainly permanent. Most likely error is * EMFILE, which would mean that we've exceeded the per-process * Shm segment limit. */ - gdk_use_xshm = False; - - return NULL; + gdk_use_xshm = FALSE; + goto error; } gdk_error_trap_push (); @@ -310,16 +297,8 @@ gdk_image_new (GdkImageType type, if (gdk_error_trap_pop ()) { /* this is the common failure case so omit warning */ - XDestroyImage (private->ximage); - shmdt (x_shm_info->shmaddr); - shmctl (x_shm_info->shmid, IPC_RMID, 0); - - g_free (private->x_shm_info); - LEAK_IMAGE (image); - - gdk_use_xshm = False; - - return NULL; + gdk_use_xshm = FALSE; + goto error; } /* We mark the segment as destroyed so that when @@ -334,15 +313,10 @@ gdk_image_new (GdkImageType type, image_list = g_list_prepend (image_list, image); } else - { - LEAK_IMAGE (image); - return NULL; - } - break; -#else /* USE_SHM */ - LEAK_IMAGE (image); - return NULL; +#else /* !USE_SHM */ + goto error; #endif /* USE_SHM */ + break; case GDK_IMAGE_NORMAL: private->ximage = XCreateImage (private->xdisplay, xvisual, visual->depth, ZPixmap, 0, 0, width, height, 32, 0); @@ -352,6 +326,8 @@ gdk_image_new (GdkImageType type, */ private->ximage->data = malloc (private->ximage->bytes_per_line * private->ximage->height); + if (!private->ximage->data) + goto error; break; case GDK_IMAGE_FASTEST: @@ -369,6 +345,30 @@ gdk_image_new (GdkImageType type, } return image; + + error: + if (private->ximage) + { + XDestroyImage (private->ximage); + private->ximage = NULL; + } +#ifdef USE_SHM + if (private->x_shm_info) + { + x_shm_info = private->x_shm_info; + + if (x_shm_info->shmaddr != (char *)-1) + shmdt (x_shm_info->shmaddr); + if (x_shm_info->shmid != -1) + shmctl (x_shm_info->shmid, IPC_RMID, 0); + + g_free (x_shm_info); + private->x_shm_info = NULL; + } +#endif /* USE_SHM */ + g_object_unref (image); + + return NULL; } GdkImage* @@ -478,34 +478,37 @@ gdk_x11_image_destroy (GdkImage *image) * time from _finalize() */ return; - - switch (image->type) - { - case GDK_IMAGE_NORMAL: - XDestroyImage (private->ximage); - break; - case GDK_IMAGE_SHARED: + if (private->ximage) /* Deal with failure of creation */ + { + switch (image->type) + { + case GDK_IMAGE_NORMAL: + XDestroyImage (private->ximage); + break; + + case GDK_IMAGE_SHARED: #ifdef USE_SHM - gdk_flush(); - - XShmDetach (private->xdisplay, private->x_shm_info); - XDestroyImage (private->ximage); - - x_shm_info = private->x_shm_info; - shmdt (x_shm_info->shmaddr); - - g_free (private->x_shm_info); - private->x_shm_info = NULL; - - image_list = g_list_remove (image_list, image); + gdk_flush(); + + XShmDetach (private->xdisplay, private->x_shm_info); + XDestroyImage (private->ximage); + + x_shm_info = private->x_shm_info; + shmdt (x_shm_info->shmaddr); + + g_free (private->x_shm_info); + private->x_shm_info = NULL; + + image_list = g_list_remove (image_list, image); #else /* USE_SHM */ - g_error ("trying to destroy shared memory image when gdk was compiled without shared memory support"); + g_error ("trying to destroy shared memory image when gdk was compiled without shared memory support"); #endif /* USE_SHM */ - break; - - case GDK_IMAGE_FASTEST: - g_assert_not_reached (); + break; + + case GDK_IMAGE_FASTEST: + g_assert_not_reached (); + } } g_free (private); |