aboutsummaryrefslogtreecommitdiffstats
path: root/graphics
diff options
context:
space:
mode:
authormiwi <miwi@FreeBSD.org>2014-05-18 12:59:13 +0800
committermiwi <miwi@FreeBSD.org>2014-05-18 12:59:13 +0800
commit88de735bec2cb4a8384af4350c05b41275e526fc (patch)
tree63d0806b7c5c2f1af7d67384b3263b97e5d3f163 /graphics
parent7d4ec4dd182ad4f4ee409398dfb56e592bb2ac88 (diff)
downloadfreebsd-ports-gnome-88de735bec2cb4a8384af4350c05b41275e526fc.tar.gz
freebsd-ports-gnome-88de735bec2cb4a8384af4350c05b41275e526fc.tar.zst
freebsd-ports-gnome-88de735bec2cb4a8384af4350c05b41275e526fc.zip
- Fix build on i386
- Stage support PR: 188139 Submitted by: Ports Fury
Diffstat (limited to 'graphics')
-rw-r--r--graphics/grx/Makefile102
-rw-r--r--graphics/grx/files/patch-src__fdrivers__driver16.h36
-rw-r--r--graphics/grx/files/patch-src__include__arith.h11
-rw-r--r--graphics/grx/files/patch-src__include__memcopy.h11
-rw-r--r--graphics/grx/files/patch-src__include__memfill.h11
-rw-r--r--graphics/grx/files/patch-src__include__memmode.h11
-rw-r--r--graphics/grx/files/patch-src__include__mempeek.h11
-rw-r--r--graphics/grx/files/patch-src__utils__shiftscl.c20
8 files changed, 144 insertions, 69 deletions
diff --git a/graphics/grx/Makefile b/graphics/grx/Makefile
index 8903e7678b68..d3f4d3a26c05 100644
--- a/graphics/grx/Makefile
+++ b/graphics/grx/Makefile
@@ -9,20 +9,13 @@ MASTER_SITES= http://grx.gnu.de/download/
DISTNAME= ${PORTNAME}${PORTVERSION:S/.//g}
MAINTAINER= ports@FreeBSD.org
-COMMENT= A 2D graphics library
+COMMENT= 2D graphics library
LICENSE= LGPL20 MIT
LICENSE_COMB= multi
-LIB_DEPENDS= pthread-stubs:${PORTSDIR}/devel/libpthread-stubs
-
-OPTIONS_DEFINE= BGI BMP JPEG PNG PRINT TIFF ZLIB
-OPTIONS_DEFAULT= ZLIB BGI BMP PNG PRINT
-BGI_DESC= Enable BGI support
-BMP_DESC= Enable BMP support
-
-USE_XORG= x11 xau xcb xdmcp
USES= gmake
+USE_XORG= x11 xau xcb xdmcp
HAS_CONFIGURE= yes
CONFIGURE_ARGS= --prefix=${PREFIX} --with-fontpath=${DATADIR}/fonts \
--with-x11-base=${LOCALBASE}
@@ -37,59 +30,29 @@ PLIST_SUB= VERSION="${PORTVERSION}"
INFO= grx
-.include <bsd.port.options.mk>
-
-.if ${PORT_OPTIONS:MBGI}
-CONFIGURE_ARGS+=--enable-bgi
-PLIST_SUB+= BGI=""
-.else
-CONFIGURE_ARGS+=--disable-bgi
-PLIST_SUB+= BGI="@comment "
-.endif
-
-.if ${PORT_OPTIONS:MBMP}
-CONFIGURE_ARGS+=--enable-bmp
-.else
-CONFIGURE_ARGS+=--disable-bmp
-.endif
-
-.if ${PORT_OPTIONS:MJPEG}
-LIB_DEPENDS+= jpeg:${PORTSDIR}/graphics/jpeg
-CONFIGURE_ARGS+=--enable-jpeg
-.else
-CONFIGURE_ARGS+=--disable-jpeg
-.endif
+OPTIONS_DEFINE= BGI BMP JPEG PNG PRINT TIFF ZLIB
+OPTIONS_DEFAULT= BGI BMP PNG PRINT ZLIB
+OPTIONS_SUB= yes
+
+BGI_DESC= BGI image format support
+BGI_CONFIGURE_ENABLE= bgi
+BMP_DESC= BMP image format support
+BMP_CONFIGURE_ENABLE= bmp
+JPEG_LIB_DEPENDS+= libjpeg.so:${PORTSDIR}/graphics/jpeg
+JPEG_CONFIGURE_ENABLE= jpeg
+PNG_LIB_DEPENDS= libpng15.so:${PORTSDIR}/graphics/png
+PNG_CONFIGURE_ENABLE= png
+PRINT_CONFIGURE_ENABLE= print
+TIFF_LIB_DEPENDS= libtiff.so:${PORTSDIR}/graphics/tiff
+TIFF_CONFIGURE_ENABLE= tiff
+ZLIB_CONFIGURE_ENABLE= zlib
-.if ${PORT_OPTIONS:MPNG}
-LIB_DEPENDS+= png15:${PORTSDIR}/graphics/png
-CONFIGURE_ARGS+=--enable-png
-.else
-CONFIGURE_ARGS+=--disable-png
-.endif
-
-.if ${PORT_OPTIONS:MPRINT}
-CONFIGURE_ARGS+=--enable-print
-PLIST_SUB+= PRINT=""
-.else
-CONFIGURE_ARGS+=--disable-print
-PLIST_SUB+= PRINT="@comment "
-.endif
-
-.if ${PORT_OPTIONS:MTIFF}
-LIB_DEPENDS+= tiff:${PORTSDIR}/graphics/tiff
-CONFIGURE_ARGS+=--enable-tiff
-.else
-CONFIGURE_ARGS+=--disable-tiff
-.endif
+.include <bsd.port.options.mk>
-.if ${PORT_OPTIONS:MZLIB} || !empty(PORT_OPTIONS:MPNG)
-CONFIGURE_ARGS+=--enable-zlib
-.else
-CONFIGURE_ARGS+=--disable-zlib
+.if ${PORT_OPTIONS:MPNG} && empty(PORT_OPTIONS:MZLIB)
+IGNORE= PNG support requires ZLIB support
.endif
-.include <bsd.port.pre.mk>
-
.if ${ARCH} == "amd64"
CONFIGURE_ARGS+=--enable-x86_64
.endif
@@ -101,17 +64,18 @@ BROKEN= Does not compile on ia64, powerpc, or sparc64
post-patch:
@${GREP} -ERl '<(malloc|alloca)\.h>' ${WRKSRC} | ${XARGS} \
${REINPLACE_CMD} -Ee 's|<(malloc\|alloca)\.h>|<stdlib.h>|'
- @${REINPLACE_CMD} -Ee \
- 's|-m32|| ; \
+ @${REINPLACE_CMD} -e \
+ 's|^\(CC[[:blank:]]*=\).*|\1 ${CC}| ; \
+ s|^\(STRIP[[:blank:]]*=\).*|\1 ${TRUE}| ; \
+ s|^\(CCOPT[[:blank:]]*=\).*|\1 ${CPPFLAGS} ${CFLAGS}| ; \
+ s|^\(LDOPT[[:blank:]]*=\).*|\1 ${LDFLAGS}| ; \
s|-m64|| ; \
- s|^(CC[[:blank:]]*=).*|\1 ${CC}| ; \
- s|^(CCOPT =)|\1 ${CPPFLAGS} ${CFLAGS}| ; \
- s|^(LDOPT =)|\1 ${LDFLAGS}| ; \
- s|lib64|lib|' \
+ s|-m32||' \
${WRKSRC}/makedefs.grx
- @${REINPLACE_CMD} -e \
- 's|gcc|${CC}| ; \
- s|lib64|lib|' \
- ${WRKSRC}/src/makefile.[lx]*
-.include <bsd.port.post.mk>
+post-install:
+.for i in bin2c fnt2c xmodetest
+ @${STRIP_CMD} ${STAGEDIR}${PREFIX}/bin/${i}
+.endfor
+
+.include <bsd.port.mk>
diff --git a/graphics/grx/files/patch-src__fdrivers__driver16.h b/graphics/grx/files/patch-src__fdrivers__driver16.h
new file mode 100644
index 000000000000..04fe19edafa5
--- /dev/null
+++ b/graphics/grx/files/patch-src__fdrivers__driver16.h
@@ -0,0 +1,36 @@
+--- src/fdrivers/driver16.h.orig
++++ src/fdrivers/driver16.h
+@@ -46,7 +46,7 @@
+ # define repfill16_and repfill_w_f_and
+ # define repfill16 repfill_w_f
+ # define SETFARSEL(sel) setup_far_selector(sel)
+-# if defined(__GNUC__) && defined(__i386__)
++# if defined(__GNUC__) && defined(__i386__) && !defined(__clang__)
+ # define ASM_386_SEL I386_GCC_FAR_SELECTOR
+ # endif /* GCC i386 */
+ #else /* defined FAR_ACCESS */
+@@ -180,7 +180,7 @@
+ GRX_LEAVE();
+ }
+
+-#if defined(__GNUC__) && defined(__i386__)
++#if defined(__GNUC__) && defined(__i386__) && !defined(__clang__)
+ static void drawline(int x,int y,int dx,int dy,GrColor color)
+ {
+ struct {
+@@ -196,6 +196,7 @@
+
+ # ifdef __GNUC__
+ # ifdef __i386__
++# ifndef __clang__
+ # define ASM_LINE1(OPC) asm volatile("" \
+ " .align 2,0x90 \n" \
+ "0: "#OPC"w %6,"ASM_386_SEL"(%0) \n" \
+@@ -236,6 +237,7 @@
+ )
+ # endif
+ # endif
++# endif
+
+ if(dy < 0) {
+ y -= (dy = (-dy));
diff --git a/graphics/grx/files/patch-src__include__arith.h b/graphics/grx/files/patch-src__include__arith.h
new file mode 100644
index 000000000000..c9afd57b578e
--- /dev/null
+++ b/graphics/grx/files/patch-src__include__arith.h
@@ -0,0 +1,11 @@
+--- src/include/arith.h.orig
++++ src/include/arith.h
+@@ -22,7 +22,7 @@
+ #ifndef __ARITH_H_INCLUDED__
+ #define __ARITH_H_INCLUDED__
+
+-#ifdef __GNUC__
++#if defined(__GNUC__) && !defined(__clang__)
+ #include "gcc/arith.h"
+ #elif defined(__TURBOC__)
+ #include "bcc/arith.h"
diff --git a/graphics/grx/files/patch-src__include__memcopy.h b/graphics/grx/files/patch-src__include__memcopy.h
new file mode 100644
index 000000000000..1068b0f04d4a
--- /dev/null
+++ b/graphics/grx/files/patch-src__include__memcopy.h
@@ -0,0 +1,11 @@
+--- src/include/memcopy.h.orig
++++ src/include/memcopy.h
+@@ -44,7 +44,7 @@
+ #define CPSIZE_h sizeof(GR_int64)
+ #endif
+
+-#ifdef __GNUC__
++#if defined(__GNUC__) && !defined(__clang__)
+ # include "gcc/memcopy.h"
+ #elif defined(__TURBOC__)
+ # include "bcc/memcopy.h"
diff --git a/graphics/grx/files/patch-src__include__memfill.h b/graphics/grx/files/patch-src__include__memfill.h
new file mode 100644
index 000000000000..18719dc8156f
--- /dev/null
+++ b/graphics/grx/files/patch-src__include__memfill.h
@@ -0,0 +1,11 @@
+--- src/include/memfill.h.orig
++++ src/include/memfill.h
+@@ -32,7 +32,7 @@
+ #include "arith.h"
+ #endif
+
+-#ifdef __GNUC__
++#if defined(__GNUC__) && !defined(__clang__)
+ # include "gcc/memfill.h"
+ #elif defined(__TURBOC__)
+ # include "bcc/memfill.h"
diff --git a/graphics/grx/files/patch-src__include__memmode.h b/graphics/grx/files/patch-src__include__memmode.h
new file mode 100644
index 000000000000..1701b0f640a5
--- /dev/null
+++ b/graphics/grx/files/patch-src__include__memmode.h
@@ -0,0 +1,11 @@
+--- src/include/memmode.h.orig
++++ src/include/memmode.h
+@@ -19,7 +19,7 @@
+ #ifndef __MEMMODE_H_INCLUDED__
+ #define __MEMMODE_H_INCLUDED__
+
+-#ifdef __GNUC__
++#if defined(__GNUC__) && !defined(__clang__)
+ #include "gcc/memmode.h"
+ #elif defined(__TURBOC__)
+ #include "bcc/memmode.h"
diff --git a/graphics/grx/files/patch-src__include__mempeek.h b/graphics/grx/files/patch-src__include__mempeek.h
new file mode 100644
index 000000000000..23e16c9dee6d
--- /dev/null
+++ b/graphics/grx/files/patch-src__include__mempeek.h
@@ -0,0 +1,11 @@
+--- src/include/mempeek.h.orig
++++ src/include/mempeek.h
+@@ -29,7 +29,7 @@
+ #include "memmode.h"
+ #endif
+
+-#ifdef __GNUC__
++#if defined(__GNUC__) && !defined(__clang__)
+ #include "gcc/mempeek.h"
+ #elif defined(__TURBOC__)
+ #include "bcc/mempeek.h"
diff --git a/graphics/grx/files/patch-src__utils__shiftscl.c b/graphics/grx/files/patch-src__utils__shiftscl.c
new file mode 100644
index 000000000000..ee50dae96abb
--- /dev/null
+++ b/graphics/grx/files/patch-src__utils__shiftscl.c
@@ -0,0 +1,20 @@
+--- src/utils/shiftscl.c.orig
++++ src/utils/shiftscl.c
+@@ -34,7 +34,7 @@
+ for (plane = 0; plane < planes; ++plane) {
+ GR_int8u far *s = *(src++) + ws;
+ GR_int8u far *d = *(dst++) + ws;
+-# if defined(__GNUC__) && defined(__i386__)
++# if defined(__GNUC__) && defined(__i386__) && !defined(__clang__)
+ int _dummy_, w = ws;
+ /* sad but true: the x86 bytesex forces this inefficient code :( */
+ asm volatile ("\n"
+@@ -91,7 +91,7 @@
+ for (plane = 0; plane < planes; ++plane) {
+ GR_int8u far *s = *(src++);
+ GR_int8u far *d = *(dst++);
+-# if defined(__GNUC__) && defined(__i386__)
++# if defined(__GNUC__) && defined(__i386__) && !defined(__clang__)
+ int _dummy_, w = ws;
+ asm volatile ("\n"
+ " movb (%0),%%ch \n"