gtk+ r20894 - in trunk: . gdk gdk/tests



Author: herzi
Date: Tue Jul 22 18:50:54 2008
New Revision: 20894
URL: http://svn.gnome.org/viewvc/gtk+?rev=20894&view=rev

Log:
2008-07-22  Sven Herzberg  <sven imendio com>

	Add a test for my fixes from July 20th.

	* configure.in: create gdk/tests/Makefile
	* gdk/Makefile.am: include the tests subfolder
	* gdk/tests/Makefile.am: create and run my test
	* gdk/tests/check-gdk-cairo.c (test), (main): the test that I wrote
	(passes at least for x11 and quartz backends)



Added:
   trunk/gdk/tests/
   trunk/gdk/tests/Makefile.am
   trunk/gdk/tests/check-gdk-cairo.c
Modified:
   trunk/ChangeLog
   trunk/configure.in
   trunk/gdk/Makefile.am

Modified: trunk/configure.in
==============================================================================
--- trunk/configure.in	(original)
+++ trunk/configure.in	Tue Jul 22 18:50:54 2008
@@ -2046,6 +2046,7 @@
 gdk/win32/rc/gdk.rc
 gdk/quartz/Makefile
 gdk/directfb/Makefile
+gdk/tests/Makefile
 gtk/Makefile
 gtk/makefile.msc
 gtk/gtkversion.h

Modified: trunk/gdk/Makefile.am
==============================================================================
--- trunk/gdk/Makefile.am	(original)
+++ trunk/gdk/Makefile.am	Tue Jul 22 18:50:54 2008
@@ -1,8 +1,8 @@
 ## Makefile.am for gtk+/gdk
 include $(top_srcdir)/Makefile.decl
 
-SUBDIRS = $(gdktarget)
-DIST_SUBDIRS = win32 x11 quartz directfb
+SUBDIRS = $(gdktarget) . tests
+DIST_SUBDIRS = win32 x11 quartz directfb tests
 
 EXTRA_DIST +=			\
 	keynames.txt		\

Added: trunk/gdk/tests/Makefile.am
==============================================================================
--- (empty file)
+++ trunk/gdk/tests/Makefile.am	Tue Jul 22 18:50:54 2008
@@ -0,0 +1,20 @@
+include $(top_srcdir)/Makefile.decl
+
+NULL=
+
+check_PROGRAMS=check-gdk-cairo
+TESTS=$(check_PROGRAMS)
+
+AM_CPPFLAGS=\
+	$(GDK_DEP_CFLAGS) \
+	-I$(top_builddir)/gdk \
+	$(NULL)
+
+check_gdk_cairo_SOURCES=\
+	check-gdk-cairo.c \
+	$(NULL)
+check_gdk_cairo_LDADD=\
+	$(GDK_DEP_LIBS) \
+	$(top_builddir)/gdk-pixbuf/libgdk_pixbuf-$(GTK_API_VERSION).la \
+	$(top_builddir)/gdk/libgdk-$(gdktarget)-$(GTK_API_VERSION).la \
+	$(NULL)

Added: trunk/gdk/tests/check-gdk-cairo.c
==============================================================================
--- (empty file)
+++ trunk/gdk/tests/check-gdk-cairo.c	Tue Jul 22 18:50:54 2008
@@ -0,0 +1,139 @@
+/* This file is part of GTK+
+ *
+ * AUTHORS
+ *     Sven Herzberg
+ *
+ * Copyright (C) 2008  Sven Herzberg
+ *
+ * This work is provided "as is"; redistribution and modification
+ * in whole or in part, in any medium, physical or electronic is
+ * permitted without restriction.
+ *
+ * This work is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
+ *
+ * In no event shall the authors or contributors be liable for any
+ * direct, indirect, incidental, special, exemplary, or consequential
+ * damages (including, but not limited to, procurement of substitute
+ * goods or services; loss of use, data, or profits; or business
+ * interruption) however caused and on any theory of liability, whether
+ * in contract, strict liability, or tort (including negligence or
+ * otherwise) arising in any way out of the use of this software, even
+ * if advised of the possibility of such damage.
+ */
+
+#include <gdk/gdk.h>
+#ifndef CAIRO_HAS_QUARTZ_SURFACE
+#include <cairo-quartz.h>
+#endif
+
+static void
+test (cairo_t* cr)
+{
+	cairo_save (cr);
+	 cairo_set_source_rgb (cr, 1.0, 1.0, 1.0);
+	 cairo_paint (cr);
+	cairo_restore (cr);
+
+	cairo_move_to (cr, 10.0, 20.0);
+	cairo_line_to (cr, 10.0, 30.0);
+	cairo_stroke (cr);
+
+	cairo_set_source_rgba (cr, 0.0, 0.0, 0.0, 0.5);
+	cairo_arc (cr, 0.0, 0.0, 10.0, 0.0, G_PI/2);
+	cairo_stroke (cr);
+}
+
+int
+main (int   argc,
+      char**argv)
+{
+	GdkPixmap* pixmap;
+	GdkPixbuf* pixbuf;
+	GdkPixbuf* pbuf_platform;
+	GdkPixbuf* pbuf_imagesrf;
+	GError   * error = NULL;
+	cairo_surface_t* surface;
+	cairo_t* cr;
+	guchar* data_platform;
+	guchar* data_imagesrf;
+	guint i;
+
+	gdk_init (&argc, &argv);
+
+	/* create "platform.png" via GdkPixmap */
+	pixmap = gdk_pixmap_new (NULL /* drawable */, 100 /* w */, 80 /* h */, 24 /* d */);
+	cr = gdk_cairo_create (pixmap);
+	test (cr);
+	cairo_destroy (cr);
+
+	pixbuf = gdk_pixbuf_get_from_drawable (NULL,
+					       pixmap,
+					       gdk_rgb_get_colormap (),
+					       0, 0,
+					       0, 0,
+					       100, 80);
+	if (!gdk_pixbuf_save (pixbuf, "gdksurface.png", "png", NULL, NULL)) {
+		g_error ("Eeek! Couldn't save the file \"gdksurface.png\"");
+	}
+	g_object_unref (pixbuf);
+
+	g_object_unref (pixmap);
+
+	/* create "cairosurface.png" via pure cairo */
+#ifndef CAIRO_HAS_QUARTZ_SURFACE
+	surface = cairo_image_surface_create (CAIRO_FORMAT_RGB24, 100, 80);
+#else
+	surface = cairo_quartz_surface_create (CAIRO_FORMAT_RGB24, 100, 80);
+#endif
+	cr = cairo_create (surface);
+	test (cr);
+	cairo_destroy (cr);
+	if (CAIRO_STATUS_SUCCESS != cairo_surface_write_to_png (surface, "cairosurface.png")) {
+		g_error ("Eeek! Couldn't save the file \"cairosurface.png\"");
+	}
+	cairo_surface_destroy (surface);
+
+	/* compare the images */
+	pbuf_platform = gdk_pixbuf_new_from_file ("gdksurface.png", &error);
+	if (!pbuf_platform || error) {
+		g_error ("Eeek! Error loading \"gdksurface.png\"");
+	}
+	pbuf_imagesrf = gdk_pixbuf_new_from_file ("cairosurface.png", &error);
+	if (!pbuf_imagesrf || error) {
+		g_object_unref (pbuf_platform);
+		g_error ("Eeek! Error loading \"cairosurface.png\"");
+	}
+
+	g_return_val_if_fail (gdk_pixbuf_get_width (pbuf_platform) ==
+			      gdk_pixbuf_get_width (pbuf_imagesrf),
+			      1);
+	g_return_val_if_fail (gdk_pixbuf_get_height (pbuf_platform) ==
+			      gdk_pixbuf_get_height (pbuf_imagesrf),
+			      1);
+	g_return_val_if_fail (gdk_pixbuf_get_rowstride (pbuf_platform) ==
+			      gdk_pixbuf_get_rowstride (pbuf_imagesrf),
+			      1);
+	g_return_val_if_fail (gdk_pixbuf_get_n_channels (pbuf_platform) ==
+			      gdk_pixbuf_get_n_channels (pbuf_imagesrf),
+			      1);
+
+	data_platform = gdk_pixbuf_get_pixels (pbuf_platform);
+	data_imagesrf = gdk_pixbuf_get_pixels (pbuf_imagesrf);
+
+	for (i = 0; i < gdk_pixbuf_get_height (pbuf_platform) * gdk_pixbuf_get_rowstride (pbuf_platform); i++) {
+		if (data_platform[i] != data_imagesrf[i]) {
+			g_warning ("Eeek! Images are differing at byte %d", i);
+			g_object_unref (pbuf_platform);
+			g_object_unref (pbuf_imagesrf);
+			return 1;
+		}
+	}
+
+	g_object_unref (pbuf_platform);
+	g_object_unref (pbuf_imagesrf);
+
+	return 0;
+}
+



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