aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorrm <rm@FreeBSD.org>2012-01-01 00:27:49 +0800
committerrm <rm@FreeBSD.org>2012-01-01 00:27:49 +0800
commit37a715897b5b77bfd02b987b797a72d44b725c4e (patch)
tree7788d59b70af315f5b981d0b82299a669f3a29c2
parent662516e2299014cdd7d4b34227c4175fcc176f70 (diff)
downloadfreebsd-ports-gnome-37a715897b5b77bfd02b987b797a72d44b725c4e.tar.gz
freebsd-ports-gnome-37a715897b5b77bfd02b987b797a72d44b725c4e.tar.zst
freebsd-ports-gnome-37a715897b5b77bfd02b987b797a72d44b725c4e.zip
- add Japanese support via option (default off)
- add LICENSE (GPLv2) - remove CONFLICTS with no more existing audio/mt-daapd - fix whitespace bug and typo PR: 160579 Submitted by: Takefu <takefu at airport dot fm> Approved by: maintainer
-rw-r--r--audio/firefly/Makefile20
-rw-r--r--audio/firefly/files/extra-patch-src_scan-mp3.c138
2 files changed, 153 insertions, 5 deletions
diff --git a/audio/firefly/Makefile b/audio/firefly/Makefile
index fe173189ecec..b9979b5c92df 100644
--- a/audio/firefly/Makefile
+++ b/audio/firefly/Makefile
@@ -6,7 +6,7 @@
PORTNAME= firefly
PORTVERSION= 1696
-PORTREVISION= 5
+PORTREVISION= 6
CATEGORIES= audio
MASTER_SITES= http://nightlies.fireflymediaserver.org/nightlies/svn-${PORTVERSION}/ \
http://www.magnesium.net/~mdf/distfiles/
@@ -15,6 +15,8 @@ DISTNAME= mt-daapd-svn-${PORTVERSION}
MAINTAINER= mark@foster.cc
COMMENT= Open-source media server for the Roku SoundBridge and iTunes
+LICENSE= GPLv2
+
BUILD_DEPENDS= ${LOCALBASE}/include/vorbis/codec.h:${PORTSDIR}/audio/libvorbis \
${LOCALBASE}/include/FLAC/metadata.h:${PORTSDIR}/audio/flac
RUN_DEPENDS= oggdec:${PORTSDIR}/audio/vorbis-tools \
@@ -23,8 +25,6 @@ LIB_DEPENDS= ogg:${PORTSDIR}/audio/libogg \
sqlite3.8:${PORTSDIR}/databases/sqlite3 \
id3tag.0:${PORTSDIR}/audio/libid3tag
-CONFLICTS= mt-daapd-0.2.*
-
GNU_CONFIGURE= yes
CONFIGURE_ENV= LIBS="-L${LOCALBASE}/lib ${PTHREAD_LIBS}"
CFLAGS+= ${PTHREAD_CFLAGS}
@@ -45,15 +45,25 @@ PLIST_SUB+= DAAPD_DBDIR=${DAAPD_DBDIR}
USE_LDCONFIG= yes
+OPTIONS= JAPANESE "Japanese support in ID3 tags" off
+
+.include <bsd.port.options.mk>
+
+.if defined(WITH_JAPANESE)
+EXTRA_PATCHES= ${FILESDIR}/extra-patch-src_scan-mp3.c
+USE_ICONV= yes
+CONFIGURE_ARGS+= --enable-iconv
+.endif
+
pre-everything::
- @${ECHO_CMD} "Define vars bellow if you need:"
+ @${ECHO_CMD} "Define vars below if you need:"
@${ECHO_CMD} "DAAPD_USER=${DAAPD_USER} (default: daapd)"
@${ECHO_CMD} "DAAPD_GROUP=${DAAPD_GROUP} (default: daapd)"
@${ECHO_CMD} "DAAPD_DBDIR=${DAAPD_DBDIR} (default: ${PREFIX}/var/db/${PORTNAME})"
post-patch:
@${REINPLACE_CMD} -e 's|echo aout|echo elf|' \
- ${WRKSRC}/configure
+ ${WRKSRC}/configure
post-install:
.if !defined(NOPORTDOCS)
diff --git a/audio/firefly/files/extra-patch-src_scan-mp3.c b/audio/firefly/files/extra-patch-src_scan-mp3.c
new file mode 100644
index 000000000000..2110bea067a1
--- /dev/null
+++ b/audio/firefly/files/extra-patch-src_scan-mp3.c
@@ -0,0 +1,138 @@
+--- src/scan-mp3.c.orig 2007-09-25 16:55:23.000000000 +0900
++++ src/scan-mp3.c 2011-09-05 13:52:16.000000000 +0900
+@@ -18,6 +18,15 @@
+ * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
+ */
+
++#define USE_CP932
++
++#ifdef USE_CP932
++ #define UNKNOWN_STR "UNKNOWN"
++ #ifndef FILESYSTEM_CES
++ #define FILESYSTEM_CES "CP932"
++ #endif
++#endif
++
+ #ifdef HAVE_CONFIG_H
+ # include "config.h"
+ #endif
+@@ -34,6 +43,10 @@
+ #include <string.h>
+ #include <time.h>
+
++#ifdef USE_CP932
++ #include <iconv.h>
++#endif
++
+ #include "daapd.h"
+ #include "conf.h"
+ #include "err.h"
+@@ -289,6 +302,96 @@
+ return 1;
+ }
+
++#ifdef USE_CP932
++#define MAX_ICONV_BUF 1024
++
++typedef enum {
++ ICONV_OK,
++ ICONV_TRYNEXT,
++ ICONV_FATAL
++} iconv_result;
++
++static iconv_result do_convert(const char* to_ces, const char* from_ces,
++ char *inbuf, size_t inbytesleft,
++ char *outbuf_orig, size_t outbytesleft_orig) {
++ size_t rc;
++ iconv_result ret = ICONV_OK;
++
++ size_t outbytesleft = outbytesleft_orig - 1;
++ char* outbuf = outbuf_orig;
++
++ iconv_t cd = iconv_open(to_ces, from_ces);
++ if (cd == (iconv_t)-1) {
++ return ICONV_FATAL;
++ }
++ rc = iconv(cd, &inbuf, &inbytesleft, &outbuf, &outbytesleft);
++ if (rc == (size_t)-1) {
++ if (errno == E2BIG) {
++ ret = ICONV_FATAL;
++ } else {
++ ret = ICONV_TRYNEXT;
++ memset(outbuf_orig, '\0', outbytesleft_orig);
++ }
++ }
++ iconv_close(cd);
++
++ return ret;
++}
++
++static unsigned char* get_utf8_text(const id3_ucs4_t* native_text) {
++ unsigned char* utf8_text = NULL;
++ char * in, * in8, * iconv_buf;
++ iconv_result rc;
++
++ in = (char*)id3_ucs4_latin1duplicate(native_text);
++ if (!in) goto out;
++
++ in8 = (char*)id3_ucs4_utf8duplicate(native_text);
++ if (!in8) {
++ free(in);
++ goto out;
++ }
++
++ iconv_buf = (char*)calloc(MAX_ICONV_BUF, sizeof(char));
++ if (!iconv_buf) {
++ free(in); free(in8);
++ goto out;
++ }
++
++ /* (1) try utf8 -> cp932 */
++ rc = do_convert("CP932", "UTF-8", in8, strlen(in8), iconv_buf, MAX_ICONV_BUF);
++ if (rc == ICONV_OK) {
++ utf8_text = (unsigned char*)in8;
++ free(iconv_buf);
++ } else if (rc == ICONV_TRYNEXT) {
++ /* (2) try cp932 -> utf8 */
++ rc = do_convert("UTF-8", "CP932", in, strlen(in), iconv_buf, MAX_ICONV_BUF);
++ if (rc == ICONV_OK) {
++ utf8_text = (unsigned char*)iconv_buf;
++ } else if (rc == ICONV_TRYNEXT) {
++ /* (3) try euc-jp -> utf8 */
++ rc = do_convert("UTF-8", "EUC-JP", in, strlen(in), iconv_buf, MAX_ICONV_BUF);
++ if (rc == ICONV_OK) {
++ utf8_text = (unsigned char*)iconv_buf;
++ } else if (rc == ICONV_TRYNEXT) {
++ /* utf-8 including non-japanese char? fallback. */
++ utf8_text = (unsigned char*)id3_ucs4_utf8duplicate(native_text);
++ free(iconv_buf);
++ }
++ }
++ free(in8);
++ }
++ free(in);
++
++ out:
++ if (!utf8_text) {
++ utf8_text = (unsigned char*)strdup(UNKNOWN_STR);
++ }
++
++ return utf8_text;
++}
++#endif
++
+ int scan_mp3_get_mp3tags(char *file, MP3FILE *pmp3) {
+ struct id3_file *pid3file;
+ struct id3_tag *pid3tag;
+@@ -352,8 +455,11 @@
+ if(native_text) {
+ have_utf8=1;
+
+-
++#ifdef USE_CP932
++ utf8_text = (char *)get_utf8_text(native_text);
++#else
+ utf8_text = (char*)id3_ucs4_utf8duplicate(native_text);
++#endif
+ if(utf8_text)
+ mem_register(utf8_text,0);