diff options
author | pgj <pgj@FreeBSD.org> | 2014-01-10 05:29:39 +0800 |
---|---|---|
committer | pgj <pgj@FreeBSD.org> | 2014-01-10 05:29:39 +0800 |
commit | 85c277ebe0c60dd6aa5be2bceb4d04e10cdf1b13 (patch) | |
tree | 576f82a7c3bb2104bf5e9aaaf018944bd9e09da9 /lang/ghc | |
parent | 6caf687af6c80829d47c1c2bece526a52e785f58 (diff) | |
download | freebsd-ports-gnome-85c277ebe0c60dd6aa5be2bceb4d04e10cdf1b13.tar.gz freebsd-ports-gnome-85c277ebe0c60dd6aa5be2bceb4d04e10cdf1b13.tar.zst freebsd-ports-gnome-85c277ebe0c60dd6aa5be2bceb4d04e10cdf1b13.zip |
- Fix a run-time problem with lang/ghc on FreeBSD 10.0 and later, caused by
the iconv changes (basically GHCi was rendered unusable)
- Fix build for x11-toolkits/hs-wxc, while here
- Bump port revision for all Haskell Cabal ports as they have to be rebuilt
PR: ports/184806
Reported by: many
Obtained from: FreeBSD Haskell
MFH: 2014Q1
Diffstat (limited to 'lang/ghc')
-rw-r--r-- | lang/ghc/Makefile | 2 | ||||
-rw-r--r-- | lang/ghc/files/patch-libraries__base__cbits__iconv.c | 51 |
2 files changed, 52 insertions, 1 deletions
diff --git a/lang/ghc/Makefile b/lang/ghc/Makefile index 2fe859d97ac6..721335016916 100644 --- a/lang/ghc/Makefile +++ b/lang/ghc/Makefile @@ -3,7 +3,7 @@ PORTNAME= ghc PORTVERSION= 7.6.3 -PORTREVISION= 1 +PORTREVISION= 2 CATEGORIES= lang haskell MASTER_SITES= http://www.haskell.org/ghc/dist/${PORTVERSION}/:source \ ${MASTER_SITE_LOCAL:S/$/:boot/} diff --git a/lang/ghc/files/patch-libraries__base__cbits__iconv.c b/lang/ghc/files/patch-libraries__base__cbits__iconv.c new file mode 100644 index 000000000000..daee90381f02 --- /dev/null +++ b/lang/ghc/files/patch-libraries__base__cbits__iconv.c @@ -0,0 +1,51 @@ +--- libraries/base/cbits/iconv.c.orig 2013-04-18 23:30:14.000000000 +0200 ++++ libraries/base/cbits/iconv.c 2013-12-15 22:08:45.995398103 +0100 +@@ -1,12 +1,28 @@ + #ifndef __MINGW32__ + ++#ifdef __FreeBSD__ ++#include <sys/param.h> ++#endif ++ + #include <stdlib.h> + #include <iconv.h> + ++#if __FreeBSD_version >= 1000502 ++iconv_t __bsd_iconv_open(const char *, const char *); ++size_t __bsd_iconv(iconv_t, const char ** __restrict, ++ size_t * __restrict, char ** __restrict, ++ size_t * __restrict); ++int __bsd_iconv_close(iconv_t); ++#endif ++ + iconv_t hs_iconv_open(const char* tocode, + const char* fromcode) + { ++#if __FreeBSD_version >= 1000502 ++ return __bsd_iconv_open(tocode, fromcode); ++#else + return iconv_open(tocode, fromcode); ++#endif + } + + size_t hs_iconv(iconv_t cd, +@@ -15,11 +31,19 @@ + { + // (void*) cast avoids a warning. Some iconvs use (const + // char**inbuf), other use (char **inbuf). ++#if __FreeBSD_version >= 1000502 ++ return __bsd_iconv(cd, (void*)inbuf, inbytesleft, outbuf, outbytesleft); ++#else + return iconv(cd, (void*)inbuf, inbytesleft, outbuf, outbytesleft); ++#endif + } + + int hs_iconv_close(iconv_t cd) { ++#if __FreeBSD_version >= 1000502 ++ return __bsd_iconv_close(cd); ++#else + return iconv_close(cd); ++#endif + } + + #endif |