summaryrefslogtreecommitdiffstats
path: root/audio/streamtuner
diff options
context:
space:
mode:
authormezz <mezz@df743ca5-7f9a-e211-a948-0013205c9059>2006-07-26 08:31:24 +0800
committermezz <mezz@df743ca5-7f9a-e211-a948-0013205c9059>2006-07-26 08:31:24 +0800
commit346126b920647f361d36d935846cac75a7d0da30 (patch)
treeaea0b51733542204bd944a8a885c9ff25cc7b9c3 /audio/streamtuner
parent2a91729e22a1b3d1f7b18fb7180c3223261b0059 (diff)
downloadmarcuscom-ports-346126b920647f361d36d935846cac75a7d0da30.tar
marcuscom-ports-346126b920647f361d36d935846cac75a7d0da30.tar.gz
marcuscom-ports-346126b920647f361d36d935846cac75a7d0da30.tar.bz2
marcuscom-ports-346126b920647f361d36d935846cac75a7d0da30.tar.lz
marcuscom-ports-346126b920647f361d36d935846cac75a7d0da30.tar.xz
marcuscom-ports-346126b920647f361d36d935846cac75a7d0da30.tar.zst
marcuscom-ports-346126b920647f361d36d935846cac75a7d0da30.zip
-USE_X_PREFIX -> USE_XLIB.
-X11BASE -> LOCALBASE, gnome-icon-theme.pc lives in LOCALBASE. -Bump the PORTREVISION. git-svn-id: svn://creme-brulee.marcuscom.com/ports/trunk@6810 df743ca5-7f9a-e211-a948-0013205c9059
Diffstat (limited to 'audio/streamtuner')
-rw-r--r--audio/streamtuner/Makefile86
-rw-r--r--audio/streamtuner/distinfo3
-rw-r--r--audio/streamtuner/files/patch-src_plugins_live365_live365.c247
-rw-r--r--audio/streamtuner/files/patch-src_plugins_python_pst-main.c18
-rw-r--r--audio/streamtuner/pkg-descr8
-rw-r--r--audio/streamtuner/pkg-plist110
6 files changed, 472 insertions, 0 deletions
diff --git a/audio/streamtuner/Makefile b/audio/streamtuner/Makefile
new file mode 100644
index 000000000..4f3e990a0
--- /dev/null
+++ b/audio/streamtuner/Makefile
@@ -0,0 +1,86 @@
+# New ports collection makefile for: streamtuner
+# Date created: 02 Apr 2002
+# Whom: Jean-Yves Lefort <jylefort@brutele.be>
+#
+# $FreeBSD$
+#
+
+PORTNAME= streamtuner
+PORTVERSION= 0.99.99
+PORTREVISION= 5
+CATEGORIES= audio www
+MASTER_SITES= ${MASTER_SITE_SAVANNAH}
+MASTER_SITE_SUBDIR= ${PORTNAME}
+
+MAINTAINER= jylefort@FreeBSD.org
+COMMENT= A GTK+ stream directory browser
+
+BUILD_DEPENDS= scrollkeeper-config:${PORTSDIR}/textproc/scrollkeeper
+LIB_DEPENDS= curl:${PORTSDIR}/ftp/curl
+RUN_DEPENDS= ${LOCALBASE}/libdata/pkgconfig/gnome-icon-theme.pc:${PORTSDIR}/misc/gnome-icon-theme
+
+USE_XLIB= yes
+USE_GNOME= gtk20 gnomehack gnomeprefix
+USE_GMAKE= yes
+GNU_CONFIGURE= yes
+USE_GETOPT_LONG= yes
+CPPFLAGS= -I${LOCALBASE}/include
+LDFLAGS= -L${LOCALBASE}/lib
+CONFIGURE_ENV= CPPFLAGS="${CPPFLAGS}" LDFLAGS="${LDFLAGS}"
+
+OPTIONS= SHOUTCAST "SHOUTcast plugin" on \
+ LIVE365 "Live365 plugin" on \
+ XIPH "Xiph plugin" on \
+ LOCAL "Local plugin" on \
+ LOCAL_METADATA "metadata support for the Local plugin" on \
+ PYTHON "Python plugin" on
+
+.include <bsd.port.pre.mk>
+
+.if defined(WITHOUT_SHOUTCAST)
+CONFIGURE_ARGS+= --disable-shoutcast
+PLIST_SUB+= SHOUTCAST="@comment "
+.else
+PLIST_SUB+= SHOUTCAST=""
+.endif
+
+.if defined(WITHOUT_LIVE365)
+CONFIGURE_ARGS+= --disable-live365
+PLIST_SUB+= LIVE365="@comment "
+.else
+PLIST_SUB+= LIVE365=""
+.endif
+
+.if defined(WITHOUT_XIPH)
+CONFIGURE_ARGS+= --disable-xiph
+PLIST_SUB+= XIPH="@comment "
+.else
+PLIST_SUB+= XIPH=""
+USE_GNOME+= libxml2
+.endif
+
+.if defined(WITHOUT_LOCAL)
+CONFIGURE_ARGS+= --disable-local
+PLIST_SUB+= LOCAL="@comment "
+.else
+PLIST_SUB+= LOCAL=""
+.if defined(WITHOUT_LOCAL_METADATA)
+CONFIGURE_ARGS+= --disable-local-metadata
+.else
+LIB_DEPENDS+= tag_c:${PORTSDIR}/audio/taglib
+.endif
+.endif
+
+.if defined(WITHOUT_PYTHON)
+CONFIGURE_ARGS+= --disable-python
+PLIST_SUB+= PYTHON="@comment "
+.else
+PLIST_SUB+= PYTHON=""
+USE_PYTHON= 2.3+
+# we need to manually include this, because USE_PYTHON is defined
+# after including bsd.port.pre.mk
+.include "${PORTSDIR}/Mk/bsd.python.mk"
+USE_GNOME+= pygtk2
+.endif
+
+.include <bsd.port.post.mk>
diff --git a/audio/streamtuner/distinfo b/audio/streamtuner/distinfo
new file mode 100644
index 000000000..a07760be9
--- /dev/null
+++ b/audio/streamtuner/distinfo
@@ -0,0 +1,3 @@
+MD5 (streamtuner-0.99.99.tar.gz) = 2027b7c34e85b594524b0b4351c14362
+SHA256 (streamtuner-0.99.99.tar.gz) = 5c223a5e8dab9e504617bd221914e97bd2f0ae5f6ed8fe78b8ea8b427fee9123
+SIZE (streamtuner-0.99.99.tar.gz) = 948075
diff --git a/audio/streamtuner/files/patch-src_plugins_live365_live365.c b/audio/streamtuner/files/patch-src_plugins_live365_live365.c
new file mode 100644
index 000000000..2000c3b66
--- /dev/null
+++ b/audio/streamtuner/files/patch-src_plugins_live365_live365.c
@@ -0,0 +1,247 @@
+--- src/plugins/live365/live365.c.orig Wed May 11 03:49:30 2005
++++ src/plugins/live365/live365.c Wed May 11 03:51:11 2005
+@@ -1,5 +1,5 @@
+ /*
+- * Copyright (c) 2002, 2003, 2004 Jean-Yves Lefort
++ * Copyright (C) 2002-2005 Jean-Yves Lefort
+ * All rights reserved.
+ *
+ * Redistribution and use in source and binary forms, with or without
+@@ -59,7 +59,9 @@
+ {
+ ACCESS_ALL,
+ ACCESS_VIP,
+- ACCESS_SUBSCRIPTION
++ ACCESS_SUBSCRIPTION,
++ ACCESS_SOLD_OUT,
++ ACCESS_UNKNOWN
+ } Access;
+
+ typedef struct
+@@ -94,7 +96,8 @@
+ {
+ GList **streams;
+ Live365Stream *stream;
+- Live365Stream *finished_stream;
++ gboolean first_page;
++ gboolean looped;
+ gboolean has_next_page;
+ } ReloadStreamsInfo;
+
+@@ -263,13 +266,16 @@
+
+ case FIELD_ACCESS_STRING:
+ {
+- const char *str = NULL;
++ const char *str;
+
+ switch (stream->access)
+ {
+ case ACCESS_ALL: str = _("All"); break;
+ case ACCESS_VIP: str = _("VIP"); break;
+ case ACCESS_SUBSCRIPTION: str = _("Subscription"); break;
++ case ACCESS_SOLD_OUT: str = _("Sold out"); break;
++ case ACCESS_UNKNOWN: str = _("Unknown"); break;
++ default: str = NULL; break;
+ }
+
+ g_value_set_string(value, str);
+@@ -707,14 +713,16 @@
+ char *s1, *s2, *s3, *s4, *s5;
+
+ if ((s1 = st_strstr_span(line, "<a href=\"/cgi-bin/directory"))
+- && (s2 = st_strstr_span(s1, "&genre="))
++ && (s2 = st_strstr_span(s1, "genre="))
+ && (s3 = strchr(s2, '"'))
+ && (s4 = st_strchr_span(s3, '>'))
+ && (s5 = strstr(s4, "</a>")))
+ {
+ category = st_category_new();
+ category->name = g_strndup(s2, s3 - s2);
+- category->label = st_sgml_ref_expand_len(s4, s5 - s4);
++ category->label = ! strcmp(category->name, "Recommendations")
++ ? g_strdup(_("Recommendations"))
++ : st_sgml_ref_expand_len(s4, s5 - s4);
+ category->url_postfix = g_strconcat(DIRECTORY_PREFIX, category->name, NULL);
+ }
+ else if ((s1 = st_strstr_span(line, "<a href=\"/genres/"))
+@@ -755,6 +763,8 @@
+
+ *streams = NULL;
+ info.streams = streams;
++ info.first_page = TRUE;
++ info.looped = FALSE;
+
+ session = st_transfer_session_new();
+
+@@ -802,9 +812,11 @@
+ if (status) /* only display warning if the transfer was otherwise correct */
+ PARSE_ERROR;
+ }
++
++ info.first_page = FALSE;
+ }
+- while (status && info.has_next_page
+- && (stream_limit == -1 || received_streams < stream_limit));
++ while (status && info.has_next_page && ! info.looped
++ && (stream_limit == -1 || received_streams < stream_limit));
+
+ st_transfer_session_free(session);
+
+@@ -818,6 +830,10 @@
+ char *s1, *s2, *s3, *s4, *s5, *s6, *s7;
+ char *word1, *word2, *word3;
+
++ /* if we have detected a loop, we just ignore the page */
++ if (info->looped)
++ return;
++
+ if ((s1 = st_str_has_prefix_span(line, "<TD CLASS=\"icon\""))
+ && (s2 = st_strstr_span(s1, "DrawPlayIcon")))
+ {
+@@ -834,15 +850,18 @@
+ info->stream->access = ACCESS_VIP;
+ else if (strstr(s2, "'SUBSCRIPTION'"))
+ info->stream->access = ACCESS_SUBSCRIPTION;
++ else if (strstr(s2, "'SOLD_OUT'"))
++ info->stream->access = ACCESS_SOLD_OUT;
+ else
+- PARSE_ERROR;
+-
+- info->finished_stream = NULL;
++ {
++ PARSE_ERROR;
++ info->stream->access = ACCESS_UNKNOWN;
++ }
+ }
+ else if ((s1 = st_str_has_prefix_span(line, "<TD CLASS=\"title"))
+- && (s2 = st_strstr_span(s1, "href='"))
+- && (s3 = strstr(s2, "'>"))
+- && (s4 = strstr(s3, "</a>")))
++ && (s2 = st_strstr_span(s1, "href='"))
++ && (s3 = strstr(s2, "'>"))
++ && (s4 = strstr(s3, "</a>")))
+ {
+ if (info->stream)
+ {
+@@ -865,12 +884,19 @@
+ else
+ PARSE_ERROR;
+ }
+- else if ((s1 = st_strstr_span(line, "&station_id="))
+- && (s2 = strchr(s1, '&')))
++ else if ((s1 = st_str_has_prefix_span(line, "<TD CLASS=\"handle\""))
++ && (s2 = st_strstr_span(s1, "ReadCookie("))
++ && (s3 = st_strstr_span(s2, ", '"))
++ && (s4 = strchr(s3, '\''))
++ && (s5 = st_strstr_span(s4, "&station_id="))
++ && (s6 = strchr(s5, '&')))
+ {
+ if (info->stream)
+ {
+- word1 = g_strndup(s1, s2 - s1);
++ g_free(info->stream->broadcaster);
++ info->stream->broadcaster = st_sgml_ref_expand_len(s3, s4 - s3);
++
++ word1 = g_strndup(s5, s6 - s5);
+ if (st_str_like(word1, ST_NUMERIC))
+ info->stream->station_id = atoi(word1);
+ g_free(word1);
+@@ -878,34 +904,23 @@
+ else
+ PARSE_ERROR;
+ }
+- else if ((s1 = st_strstr_span(line, "alt=\"More broadcaster info"))
+- && (s2 = st_strchr_span(s1, '>'))
+- && (s3 = strstr(s2, "</a>")))
+- {
+- if (info->stream)
+- {
+- g_free(info->stream->broadcaster);
+- info->stream->broadcaster = st_sgml_ref_expand_len(s2, s3 - s2);
+- }
+- else
+- PARSE_ERROR;
+- }
+ else if ((s1 = st_str_has_prefix_span(line, "<TD CLASS=\"connection\""))
+ && (s2 = st_strchr_span(s1, '>'))
+- && (s3 = strstr(s2, "<br>"))
+- && ((s4 = strstr(s3, "<img src='/images/mp3pro"))
+- || (s4 = strstr(s3, "</TD>"))))
++ && (s3 = strchr(s2, '<')))
+ {
+ if (info->stream)
+ {
+ word1 = st_sgml_ref_expand_len(s2, s3 - s2);
+- s3 += 4; word2 = st_sgml_ref_expand_len(s3, s4 - s3);
+-
++
+ g_free(info->stream->audio);
+- info->stream->audio = g_strdup_printf(g_str_has_prefix(s4, "</TD>") ? "%s %s" : "%s %s, MP3Pro", word2, word1);
+
+- g_free(word1);
+- g_free(word2);
++ if (strstr(s3, "<img src='/images/mp3pro"))
++ {
++ info->stream->audio = g_strdup_printf("%s, MP3Pro", word1);
++ g_free(word1);
++ }
++ else
++ info->stream->audio = word1;
+ }
+ else
+ PARSE_ERROR;
+@@ -947,12 +962,17 @@
+ else
+ PARSE_ERROR;
+ }
+- else if (strstr(line, "TD CLASS=\"tabledesc2\""))
++ else if ((s1 = st_strstr_span(line, "<TD CLASS=\"desc\"")))
+ {
+ if (info->stream)
+ {
+ if (info->stream->station_id)
+ {
++ if ((s2 = st_strstr_span(s1, "<a class='desc-link' href='"))
++ && (s3 = st_strchr_span(s2, '>'))
++ && (s4 = strstr(s3, "<BR>")))
++ info->stream->description = st_sgml_ref_expand_len(s3, s4 - s3);
++
+ ((STStream *) info->stream)->name = g_strdup_printf("%i", info->stream->station_id);
+ *(info->streams) = g_list_append(*(info->streams), info->stream);
+ }
+@@ -962,23 +982,23 @@
+ stream_free_cb(info->stream, NULL);
+ }
+
+- info->finished_stream = info->stream;
+ info->stream = NULL;
+ }
+ else
+ PARSE_ERROR;
+ }
+- else if ((s1 = st_strstr_span(line, "<a class='desc-link' href='"))
+- && (s2 = st_strchr_span(s1, '>'))
+- && (s3 = strstr(s2, "<BR>")))
+- {
+- if (info->finished_stream)
+- {
+- info->finished_stream->description = st_sgml_ref_expand_len(s2, s3 - s2);
+- info->finished_stream = NULL;
++ else if ((s1 = st_strstr_span(line, "<TD class=\"pagination\""))
++ && (s2 = st_strstr_span(s1, ">Showing "))
++ && (s3 = strchr(s2, '-')))
++ {
++ word1 = g_strndup(s2, s3 - s2);
++ if (st_str_like(word1, ST_NUMERIC))
++ {
++ int n = atoi(word1);
++ if (n == 1 && ! info->first_page)
++ info->looped = TRUE;
+ }
+- else
+- PARSE_ERROR;
++ g_free(word1);
+ }
+ else if (strstr(line, "Next</A>"))
+ info->has_next_page = TRUE;
diff --git a/audio/streamtuner/files/patch-src_plugins_python_pst-main.c b/audio/streamtuner/files/patch-src_plugins_python_pst-main.c
new file mode 100644
index 000000000..1e5109750
--- /dev/null
+++ b/audio/streamtuner/files/patch-src_plugins_python_pst-main.c
@@ -0,0 +1,18 @@
+--- src/plugins/python/pst-main.c.orig Thu Mar 24 15:52:58 2005
++++ src/plugins/python/pst-main.c Thu Mar 24 15:53:59 2005
+@@ -94,6 +94,7 @@
+ {
+ gboolean status = FALSE;
+ PyObject *module;
++ char *argv[] = { "" };
+
+ if (! check_api_version(err))
+ return FALSE;
+@@ -109,6 +110,7 @@
+ }
+
+ Py_Initialize();
++ PySys_SetArgv(G_N_ELEMENTS(argv), argv);
+ PyEval_InitThreads();
+
+ module = PyImport_AddModule("__main__");
diff --git a/audio/streamtuner/pkg-descr b/audio/streamtuner/pkg-descr
new file mode 100644
index 000000000..331da3e96
--- /dev/null
+++ b/audio/streamtuner/pkg-descr
@@ -0,0 +1,8 @@
+streamtuner is a stream directory browser. Through the use of a plugin
+system, it offers an intuitive GTK+ 2.0 interface to Internet radio
+directories such as SHOUTcast and Live365.
+
+WWW: http://www.nongnu.org/streamtuner/
+
+- Jean-Yves Lefort
+jylefort@FreeBSD.org
diff --git a/audio/streamtuner/pkg-plist b/audio/streamtuner/pkg-plist
new file mode 100644
index 000000000..49b9461ba
--- /dev/null
+++ b/audio/streamtuner/pkg-plist
@@ -0,0 +1,110 @@
+bin/streamtuner
+include/streamtuner/st-action-api.h
+include/streamtuner/st-category-api.h
+include/streamtuner/st-dialog-api.h
+include/streamtuner/st-handler-api.h
+include/streamtuner/st-handler-field-api.h
+include/streamtuner/st-handlers-api.h
+include/streamtuner/st-m3u-api.h
+include/streamtuner/st-pls-api.h
+include/streamtuner/st-plugin-api.h
+include/streamtuner/st-programs-api.h
+include/streamtuner/st-re-api.h
+include/streamtuner/st-settings-api.h
+include/streamtuner/st-sgml-ref-api.h
+include/streamtuner/st-state-api.h
+include/streamtuner/st-stream-api.h
+include/streamtuner/st-transfer-api.h
+include/streamtuner/st-util-api.h
+include/streamtuner/st-version-api.h
+include/streamtuner/streamtuner.h
+%%LIVE365%%lib/streamtuner/plugins/live365.so
+%%LOCAL%%lib/streamtuner/plugins/local.so
+%%PYTHON%%lib/streamtuner/plugins/python.so
+%%SHOUTCAST%%lib/streamtuner/plugins/shoutcast.so
+%%XIPH%%lib/streamtuner/plugins/xiph.so
+libdata/pkgconfig/streamtuner.pc
+share/doc/streamtuner/api-reference.html
+share/doc/streamtuner/ch01s02.html
+share/doc/streamtuner/home.png
+share/doc/streamtuner/index.html
+share/doc/streamtuner/index.sgml
+share/doc/streamtuner/ix01.html
+share/doc/streamtuner/left.png
+share/doc/streamtuner/overview.html
+share/doc/streamtuner/right.png
+share/doc/streamtuner/streamtuner-STHandler.html
+share/doc/streamtuner/streamtuner-STPlugin.html
+share/doc/streamtuner/streamtuner-st-action-api.html
+share/doc/streamtuner/streamtuner-st-category-api.html
+share/doc/streamtuner/streamtuner-st-dialog-api.html
+share/doc/streamtuner/streamtuner-st-handler-field-api.html
+share/doc/streamtuner/streamtuner-st-handlers-api.html
+share/doc/streamtuner/streamtuner-st-m3u-api.html
+share/doc/streamtuner/streamtuner-st-pls-api.html
+share/doc/streamtuner/streamtuner-st-programs-api.html
+share/doc/streamtuner/streamtuner-st-re-api.html
+share/doc/streamtuner/streamtuner-st-settings-api.html
+share/doc/streamtuner/streamtuner-st-sgml-ref-api.html
+share/doc/streamtuner/streamtuner-st-state-api.html
+share/doc/streamtuner/streamtuner-st-stream-api.html
+share/doc/streamtuner/streamtuner-st-transfer-api.html
+share/doc/streamtuner/streamtuner-st-util-api.html
+share/doc/streamtuner/streamtuner-st-version-api.html
+share/doc/streamtuner/streamtuner.devhelp
+share/doc/streamtuner/up.png
+share/gnome/applications/streamtuner.desktop
+share/gnome/help/streamtuner/C/documentation-license.xml
+share/gnome/help/streamtuner/C/figures/main-window.png
+share/gnome/help/streamtuner/C/software-license.xml
+share/gnome/help/streamtuner/C/streamtuner.xml
+share/gnome/omf/streamtuner/streamtuner-C.omf
+@exec scrollkeeper-install -q %D/share/gnome/omf/streamtuner/streamtuner-C.omf 2>/dev/null || /usr/bin/true
+share/gnome/pixmaps/streamtuner.png
+share/gnome/streamtuner/ui/applications.png
+share/gnome/streamtuner/ui/bookmarks.png
+share/gnome/streamtuner/ui/browse.png
+share/gnome/streamtuner/ui/category-open-running.png
+share/gnome/streamtuner/ui/category-open.png
+share/gnome/streamtuner/ui/category-running.png
+share/gnome/streamtuner/ui/category.png
+%%LIVE365%%share/gnome/streamtuner/ui/live365.png
+%%LOCAL%%share/gnome/streamtuner/ui/local.png
+share/gnome/streamtuner/ui/logo.png
+share/gnome/streamtuner/ui/main-category-running.png
+share/gnome/streamtuner/ui/main-category.png
+share/gnome/streamtuner/ui/preselections.png
+%%PYTHON%%share/gnome/streamtuner/ui/python.png
+share/gnome/streamtuner/ui/record.png
+share/gnome/streamtuner/ui/search-category-running.png
+share/gnome/streamtuner/ui/search-category.png
+share/gnome/streamtuner/ui/search.png
+%%SHOUTCAST%%share/gnome/streamtuner/ui/shoutcast.png
+share/gnome/streamtuner/ui/streamtuner.png
+share/gnome/streamtuner/ui/tune-in.png
+%%XIPH%%share/gnome/streamtuner/ui/xiph.png
+%%PYTHON%%share/gnome/streamtuner/python/icons/basic.ch.png
+%%PYTHON%%share/gnome/streamtuner/python/icons/google-stations.png
+%%PYTHON%%share/gnome/streamtuner/python/icons/punkcast.com.png
+%%PYTHON%%share/gnome/streamtuner/python/scripts/basic.ch.py
+%%PYTHON%%share/gnome/streamtuner/python/scripts/google-stations.py
+%%PYTHON%%share/gnome/streamtuner/python/scripts/punkcast.com.py
+share/locale/de/LC_MESSAGES/streamtuner.mo
+share/locale/fr/LC_MESSAGES/streamtuner.mo
+share/locale/hu/LC_MESSAGES/streamtuner.mo
+share/locale/ja/LC_MESSAGES/streamtuner.mo
+share/locale/pt/LC_MESSAGES/streamtuner.mo
+@dirrm include/streamtuner
+@dirrm lib/streamtuner/plugins
+@dirrm lib/streamtuner
+@dirrm share/doc/streamtuner
+@dirrm share/gnome/help/streamtuner/C/figures
+@dirrm share/gnome/help/streamtuner/C
+@dirrm share/gnome/help/streamtuner
+@dirrm share/gnome/omf/streamtuner
+@unexec scrollkeeper-uninstall -q %D/share/gnome/omf/streamtuner/streamtuner-C.omf 2>/dev/null || /usr/bin/true
+@dirrm share/gnome/streamtuner/ui
+%%PYTHON%%@dirrm share/gnome/streamtuner/python/icons
+%%PYTHON%%@dirrm share/gnome/streamtuner/python/scripts
+%%PYTHON%%@dirrm share/gnome/streamtuner/python
+@dirrm share/gnome/streamtuner