summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authortv <tv@pkgsrc.org>2005-11-04 20:11:47 +0000
committertv <tv@pkgsrc.org>2005-11-04 20:11:47 +0000
commit0f8b64736d796b9d8d4c414d652b38087d47e2db (patch)
tree138ec25488a743a332ce7ce1cd5fb16488cb9d66
parent8ab0dedc95ebe6bd5a86021ed9fc3026665250d0 (diff)
downloadpkgsrc-0f8b64736d796b9d8d4c414d652b38087d47e2db.tar.gz
Use my_lround() on Interix too.
Add minimalist #ifndef blocks to rip out XShm support on Interix.
-rw-r--r--graphics/imlib2/distinfo7
-rw-r--r--graphics/imlib2/patches/patch-ab4
-rw-r--r--graphics/imlib2/patches/patch-ac71
-rw-r--r--graphics/imlib2/patches/patch-ad35
-rw-r--r--graphics/imlib2/patches/patch-ae45
5 files changed, 158 insertions, 4 deletions
diff --git a/graphics/imlib2/distinfo b/graphics/imlib2/distinfo
index 56cc8da0ecc..31b4f89a06d 100644
--- a/graphics/imlib2/distinfo
+++ b/graphics/imlib2/distinfo
@@ -1,10 +1,13 @@
-$NetBSD: distinfo,v 1.14 2005/11/02 00:45:02 hiramatsu Exp $
+$NetBSD: distinfo,v 1.15 2005/11/04 20:11:47 tv Exp $
SHA1 (imlib2-1.2.0.tar.gz) = 54f8ef83b0eac3f8e7f2218705e02a425fa73118
RMD160 (imlib2-1.2.0.tar.gz) = 158ed1bd7c59b8d1db2c00db98027d9c5c0abec3
Size (imlib2-1.2.0.tar.gz) = 890457 bytes
SHA1 (patch-aa) = 73e23778f6aaee5de213865aa64f9c5a4af6ba24
-SHA1 (patch-ab) = 93b6cee1242ac971926df4418699a68d999e5482
+SHA1 (patch-ab) = 191ab0083b410ef9892fbf6f4c4aede0e15dc9e2
+SHA1 (patch-ac) = da65ecd50753c37e267c2fd3de7f1dcef8dab1f1
+SHA1 (patch-ad) = adf301fe0179aa1ab05fc54bb7ab706ee97ab7a7
+SHA1 (patch-ae) = 6503e4cbc9bbb93f971ab2ae9fd7d50ddee9e0e8
SHA1 (patch-ba) = 0a3937fc4d017356ba5d33f957426f9befc94730
SHA1 (patch-bb) = 9df1e76c3023c6f9714906b226293bc3e026baca
SHA1 (patch-bc) = 29365da268d210b4eb7bb431f815a78bcf22f1e3
diff --git a/graphics/imlib2/patches/patch-ab b/graphics/imlib2/patches/patch-ab
index cd9b608b724..d843ca20e17 100644
--- a/graphics/imlib2/patches/patch-ab
+++ b/graphics/imlib2/patches/patch-ab
@@ -1,4 +1,4 @@
-$NetBSD: patch-ab,v 1.9 2005/11/02 00:45:02 hiramatsu Exp $
+$NetBSD: patch-ab,v 1.10 2005/11/04 20:11:47 tv Exp $
This patch makes imlib2 compile on systems that don't have an lround
function, which is defined in C99.
@@ -14,7 +14,7 @@ Needed at least for NetBSD-1.6.2 and NetBSD-2.0.
+#include <sys/param.h>
+#endif
+
-+#if defined(__NetBSD__) || defined(__OpenBSD__) || \
++#if defined(__NetBSD__) || defined(__OpenBSD__) || defined(__INTERIX) || \
+ (defined(__DragonFly__) && __DragonFly_version <= 130002)
+#define lround(x) my_lround(x)
+static long my_lround(double x)
diff --git a/graphics/imlib2/patches/patch-ac b/graphics/imlib2/patches/patch-ac
new file mode 100644
index 00000000000..57f8b9a9848
--- /dev/null
+++ b/graphics/imlib2/patches/patch-ac
@@ -0,0 +1,71 @@
+$NetBSD: patch-ac,v 1.4 2005/11/04 20:11:47 tv Exp $
+
+--- src/lib/grab.c.orig 2004-11-01 04:39:42.000000000 -0500
++++ src/lib/grab.c
+@@ -412,7 +412,9 @@ __imlib_GrabDrawableToRGBA(DATA32 * data
+ int i;
+ int src_x, src_y, src_w, src_h, origw, origh;
+ int width, height, clipx, clipy;
++#ifndef __INTERIX
+ XShmSegmentInfo shminfo, mshminfo;
++#endif /* !__INTERIX */
+ XImage *xim = NULL, *mxim = NULL;
+ static signed char x_does_shm = -1;
+ XColor cols[256];
+@@ -545,14 +547,17 @@ __imlib_GrabDrawableToRGBA(DATA32 * data
+ /* Create an Ximage (shared or not) */
+ if (x_does_shm < 0)
+ {
++#ifndef __INTERIX
+ if (XShmQueryExtension(d))
+ x_does_shm = 1;
+ else
++#endif /* !__INTERIX */
+ x_does_shm = 0;
+ }
+
+ prev_erh = XSetErrorHandler((XErrorHandler) Tmp_HandleXError);
+
++#ifndef __INTERIX
+ if (x_does_shm)
+ {
+ _x_err = 0;
+@@ -599,12 +604,14 @@ __imlib_GrabDrawableToRGBA(DATA32 * data
+ }
+ }
+ }
++#endif /* !__INTERIX */
+ if (!is_shm)
+ xim = XGetImage(d, p, x, y, w, h, 0xffffffff, ZPixmap);
+
+ if ((m) && (domask))
+ {
+ _x_err = 0;
++#ifndef __INTERIX
+ if (x_does_shm)
+ {
+ mxim = XShmCreateImage(d, v, 1, ZPixmap, NULL, &mshminfo, w, h);
+@@ -652,6 +659,7 @@ __imlib_GrabDrawableToRGBA(DATA32 * data
+ }
+ }
+ }
++#endif /* !__INTERIX */
+ if (!is_mshm)
+ mxim = XGetImage(d, m, 0, 0, w, h, 0xffffffff, ZPixmap);
+ }
+@@ -705,6 +713,7 @@ __imlib_GrabDrawableToRGBA(DATA32 * data
+ d, xim, mxim, v, xatt.depth, x, y, w, h, 0);
+
+ /* destroy the Ximage */
++#ifndef __INTERIX
+ if (is_shm)
+ {
+ XSync(d, False);
+@@ -718,6 +727,7 @@ __imlib_GrabDrawableToRGBA(DATA32 * data
+ shmdt(mshminfo.shmaddr);
+ shmctl(mshminfo.shmid, IPC_RMID, 0);
+ }
++#endif /* !__INTERIX */
+ XDestroyImage(xim);
+ if (created_mask)
+ XFreePixmap(d, m);
diff --git a/graphics/imlib2/patches/patch-ad b/graphics/imlib2/patches/patch-ad
new file mode 100644
index 00000000000..90b31aee863
--- /dev/null
+++ b/graphics/imlib2/patches/patch-ad
@@ -0,0 +1,35 @@
+$NetBSD: patch-ad,v 1.4 2005/11/04 20:11:47 tv Exp $
+
+--- src/lib/rend.c.orig 2004-11-01 04:39:42.000000000 -0500
++++ src/lib/rend.c
+@@ -495,24 +495,30 @@ __imlib_RenderImage(Display * d, ImlibIm
+ gcm = XCreateGC(d, m, GCGraphicsExposures, &gcv);
+ }
+ /* write the mask */
++#ifndef __INTERIX
+ if (shm)
+ /* write shm XImage */
+ XShmPutImage(d, m, gcm, mxim, 0, 0, dx, dy, dw, dh, False);
+ /* write regular XImage */
+ else
++#endif /* !__INTERIX */
+ XPutImage(d, m, gcm, mxim, 0, 0, dx, dy, dw, dh);
+ }
+ /* write the image */
++#ifndef __INTERIX
+ if (shm)
+ /* write shm XImage */
+ XShmPutImage(d, w, gc, xim, 0, 0, dx, dy, dw, dh, False);
+ /* write regular XImage */
+ else
++#endif /* !__INTERIX */
+ XPutImage(d, w, gc, xim, 0, 0, dx, dy, dw, dh);
+ /* free the XImage and put onto our free list */
+ /* wait for the write to be done */
++#ifndef __INTERIX
+ if (shm)
+ XSync(d, False);
++#endif /* !__INTERIX */
+ __imlib_ConsumeXImage(d, xim);
+ if (m)
+ __imlib_ConsumeXImage(d, mxim);
diff --git a/graphics/imlib2/patches/patch-ae b/graphics/imlib2/patches/patch-ae
new file mode 100644
index 00000000000..4604f19d628
--- /dev/null
+++ b/graphics/imlib2/patches/patch-ae
@@ -0,0 +1,45 @@
+$NetBSD: patch-ae,v 1.4 2005/11/04 20:11:47 tv Exp $
+
+--- src/lib/ximage.c.orig 2004-11-01 04:39:42.000000000 -0500
++++ src/lib/ximage.c
+@@ -81,8 +81,10 @@ __imlib_FlushXImage(Display * d)
+
+ xim = list_xim[i];
+ list_mem_use -= xim->bytes_per_line * xim->height;
++#ifndef __INTERIX
+ if (list_si[i])
+ XShmDetach(d, list_si[i]);
++#endif /* !__INTERIX */
+ XDestroyImage(xim);
+ if (list_si[i])
+ {
+@@ -163,11 +165,13 @@ __imlib_ProduceXImage(Display * d, Visua
+ /* if we havent check the shm extension before - see if its there */
+ if (x_does_shm < 0)
+ {
++#ifndef __INTERIX
+ /* if its there set dose_xhm flag */
+ if (XShmQueryExtension(d))
+ x_does_shm = 1;
+ /* clear the flag - no shm at all */
+ else
++#endif
+ x_does_shm = 0;
+ }
+ /* find a cached XImage (to avoid server to & fro) that is big enough */
+@@ -219,6 +223,7 @@ __imlib_ProduceXImage(Display * d, Visua
+
+ /* work on making a shared image */
+ xim = NULL;
++#ifndef __INTERIX
+ /* if the server does shm */
+ if (x_does_shm)
+ {
+@@ -301,6 +306,7 @@ __imlib_ProduceXImage(Display * d, Visua
+ }
+ }
+ }
++#endif /* !__INTERIX */
+ /* ok if xim == NULL it all failed - fall back to XImages */
+ if (!xim)
+ {