[pulseaudio-discuss] [PATCH] Remove libpulse-browse and pabrowse

Maarten Bosmans mkbosmans at gmail.com
Thu Jun 23 13:21:05 PDT 2011


---
 Makefile.am           |    5 -
 configure.ac          |    1 -
 libpulse-browse.pc.in |   12 --
 man/Makefile.am       |    3 -
 man/pabrowse.1.xml.in |   47 -----
 src/.gitignore        |    1 -
 src/Makefile.am       |   22 ---
 src/map-file          |    6 -
 src/pulse/browser.c   |  464 -------------------------------------------------
 src/pulse/browser.h   |   99 -----------
 src/utils/pabrowse.c  |  156 -----------------
 11 files changed, 0 insertions(+), 816 deletions(-)

diff --git a/Makefile.am b/Makefile.am
index 5e3b627..b010701 100644
--- a/Makefile.am
+++ b/Makefile.am
@@ -46,11 +46,6 @@ vapi_DATA = \
 pkgconfigdir = $(libdir)/pkgconfig
 pkgconfig_DATA = libpulse.pc libpulse-simple.pc
 
-if HAVE_AVAHI
-pkgconfig_DATA += \
-	 libpulse-browse.pc
-endif
-
 if HAVE_GLIB20
 pkgconfig_DATA += \
 	 libpulse-mainloop-glib.pc
diff --git a/configure.ac b/configure.ac
index fbdb5d1..7517ad0 100644
--- a/configure.ac
+++ b/configure.ac
@@ -1195,7 +1195,6 @@ src/Makefile
 man/Makefile
 libpulse.pc
 libpulse-simple.pc
-libpulse-browse.pc
 libpulse-mainloop-glib.pc
 doxygen/Makefile
 doxygen/doxygen.conf
diff --git a/libpulse-browse.pc.in b/libpulse-browse.pc.in
deleted file mode 100644
index 4346168..0000000
--- a/libpulse-browse.pc.in
+++ /dev/null
@@ -1,12 +0,0 @@
-prefix=@prefix@
-exec_prefix=@exec_prefix@
-libdir=@libdir@
-includedir=@includedir@
-
-Name: libpulse-browse
-Description: PulseAudio Network Browsing Interface
-Version: @PACKAGE_VERSION@
-Libs: -L${libdir} -lpulse-browse @PTHREAD_LIBS@
-Libs.private: -lpulsecommon- at PA_MAJORMINOR@
-Cflags: -I${includedir} -D_REENTRANT
-Requires: libpulse
diff --git a/man/Makefile.am b/man/Makefile.am
index eca1fb9..8457e03 100644
--- a/man/Makefile.am
+++ b/man/Makefile.am
@@ -30,7 +30,6 @@ noinst_DATA = \
 	pactl.1.xml \
 	pasuspender.1.xml \
 	padsp.1.xml \
-	pabrowse.1.xml \
 	pulse-daemon.conf.5.xml \
 	pulse-client.conf.5.xml \
 	default.pa.5.xml
@@ -57,7 +56,6 @@ dist_man_MANS = \
 	pactl.1 \
 	pasuspender.1 \
 	padsp.1 \
-	pabrowse.1 \
 	pulse-daemon.conf.5 \
 	pulse-client.conf.5 \
 	default.pa.5
@@ -80,7 +78,6 @@ EXTRA_DIST = \
 	pactl.1.xml.in \
 	pasuspender.1.xml.in \
 	padsp.1.xml.in \
-	pabrowse.1.xml.in \
 	pulse-daemon.conf.5.xml.in \
 	pulse-client.conf.5.xml.in \
 	default.pa.5.xml.in \
diff --git a/man/pabrowse.1.xml.in b/man/pabrowse.1.xml.in
deleted file mode 100644
index 33f071b..0000000
--- a/man/pabrowse.1.xml.in
+++ /dev/null
@@ -1,47 +0,0 @@
-<?xml version="1.0"?><!--*-nxml-*-->
-<!DOCTYPE manpage SYSTEM "xmltoman.dtd">
-<?xml-stylesheet type="text/xsl" href="xmltoman.xsl" ?>
-
-<!--
-This file is part of PulseAudio.
-
-PulseAudio is free software; you can redistribute it and/or modify it
-under the terms of the GNU Lesser General Public License as
-published by the Free Software Foundation; either version 2.1 of the
-License, or (at your option) any later version.
-
-PulseAudio is distributed in the hope that it will be useful, but WITHOUT
-ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
-or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser General
-Public License for more details.
-
-You should have received a copy of the GNU Lesser General Public
-License along with PulseAudio; if not, write to the Free Software
-Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307
-USA.
--->
-
-<manpage name="pabrowse" section="1" desc="List PulseAudio sound servers on the network">
-
-  <synopsis>
-    <cmd>pabrowse</cmd>
-  </synopsis>
-
-  <description>
-    <p><file>pabrowse</file> lists all PulseAudio sound servers on the
-    local network that are being announced with Zeroconf/Avahi.</p>
-
-    <p>This program takes no command line arguments.</p>
-  </description>
-
-  <section name="Authors">
-    <p>The PulseAudio Developers &lt;@PACKAGE_BUGREPORT@&gt;; PulseAudio is available from <url href="@PACKAGE_URL@"/></p>
-  </section>
-
-  <section name="See also">
-    <p>
-      <manref name="pulseaudio" section="1"/>, <manref name="avahi-daemon" section="8"/>
-    </p>
-  </section>
-
-</manpage>
diff --git a/src/.gitignore b/src/.gitignore
index 554176b..072a75c 100644
--- a/src/.gitignore
+++ b/src/.gitignore
@@ -37,7 +37,6 @@ mcalign-test
 memblock-test
 memblockq-test
 mix-test
-pabrowse
 pacat
 pacat-simple
 pacmd
diff --git a/src/Makefile.am b/src/Makefile.am
index a0e7ce3..a37e202 100644
--- a/src/Makefile.am
+++ b/src/Makefile.am
@@ -203,10 +203,6 @@ bin_PROGRAMS += pax11publish
 bin_SCRIPTS += start-pulseaudio-x11 start-pulseaudio-kde
 endif
 
-if HAVE_AVAHI
-bin_PROGRAMS += pabrowse
-endif
-
 pacat_SOURCES = utils/pacat.c
 pacat_LDADD = $(AM_LDADD) libpulse.la libpulsecommon- at PA_MAJORMINOR@.la $(LIBSNDFILE_LIBS)
 pacat_CFLAGS = $(AM_CFLAGS) $(LIBSNDFILE_CFLAGS)
@@ -232,11 +228,6 @@ pax11publish_CFLAGS = $(AM_CFLAGS) $(X11_CFLAGS)
 pax11publish_LDADD = $(AM_LDADD) libpulse.la libpulsecommon- at PA_MAJORMINOR@.la $(X11_LIBS)
 pax11publish_LDFLAGS = $(AM_LDFLAGS) $(BINLDFLAGS)
 
-pabrowse_SOURCES = utils/pabrowse.c
-pabrowse_LDADD = $(AM_LDADD) libpulse.la libpulse-browse.la libpulsecommon- at PA_MAJORMINOR@.la
-pabrowse_CFLAGS = $(AM_CFLAGS)
-pabrowse_LDFLAGS = $(AM_LDFLAGS) $(BINLDFLAGS)
-
 ###################################
 #         Test programs           #
 ###################################
@@ -716,14 +707,6 @@ lib_LTLIBRARIES += \
 		libpulse.la \
 		libpulse-simple.la
 
-if HAVE_AVAHI
-pulseinclude_HEADERS += \
-		pulse/browser.h
-
-lib_LTLIBRARIES += \
-		libpulse-browse.la
-endif
-
 if HAVE_GLIB20
 pulseinclude_HEADERS += \
 		pulse/glib-mainloop.h
@@ -777,11 +760,6 @@ libpulse_simple_la_CFLAGS = $(AM_CFLAGS)
 libpulse_simple_la_LIBADD = $(AM_LIBADD) libpulse.la libpulsecommon- at PA_MAJORMINOR@.la
 libpulse_simple_la_LDFLAGS = $(AM_LDFLAGS) $(VERSIONING_LDFLAGS) -version-info $(LIBPULSE_SIMPLE_VERSION_INFO)
 
-libpulse_browse_la_SOURCES = pulse/browser.c pulse/browser.h pulsecore/avahi-wrap.c pulsecore/avahi-wrap.h
-libpulse_browse_la_CFLAGS = $(AM_CFLAGS) $(AVAHI_CFLAGS)
-libpulse_browse_la_LIBADD = $(AM_LIBADD) libpulse.la libpulsecommon- at PA_MAJORMINOR@.la $(AVAHI_LIBS)
-libpulse_browse_la_LDFLAGS = $(AM_LDFLAGS) $(VERSIONING_LDFLAGS) -version-info $(LIBPULSE_BROWSE_VERSION_INFO)
-
 libpulse_mainloop_glib_la_SOURCES = pulse/glib-mainloop.h pulse/glib-mainloop.c
 libpulse_mainloop_glib_la_CFLAGS = $(AM_CFLAGS) $(GLIB20_CFLAGS)
 libpulse_mainloop_glib_la_LIBADD = $(AM_LIBADD) libpulse.la libpulsecommon- at PA_MAJORMINOR@.la $(GLIB20_LIBS)
diff --git a/src/map-file b/src/map-file
index 31ef271..d9c3e9f 100644
--- a/src/map-file
+++ b/src/map-file
@@ -2,12 +2,6 @@ PULSE_0 {
 global:
 pa_ascii_filter;
 pa_ascii_valid;
-pa_browser_new;
-pa_browser_new_full;
-pa_browser_ref;
-pa_browser_set_callback;
-pa_browser_set_error_callback;
-pa_browser_unref;
 pa_bytes_per_second;
 pa_bytes_snprint;
 pa_bytes_to_usec;
diff --git a/src/pulse/browser.c b/src/pulse/browser.c
deleted file mode 100644
index d059228..0000000
--- a/src/pulse/browser.c
+++ /dev/null
@@ -1,464 +0,0 @@
-/***
-  This file is part of PulseAudio.
-
-  Copyright 2004-2006 Lennart Poettering
-
-  PulseAudio is free software; you can redistribute it and/or modify
-  it under the terms of the GNU Lesser General Public License as
-  published by the Free Software Foundation; either version 2.1 of the
-  License, or (at your option) any later version.
-
-  PulseAudio is distributed in the hope that it will be useful, but
-  WITHOUT ANY WARRANTY; without even the implied warranty of
-  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
-  General Public License for more details.
-
-  You should have received a copy of the GNU Lesser General Public
-  License along with PulseAudio; if not, write to the Free Software
-  Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307
-  USA.
-***/
-
-#ifdef HAVE_CONFIG_H
-#include <config.h>
-#endif
-
-#include <string.h>
-
-#include <avahi-client/lookup.h>
-#include <avahi-common/domain.h>
-#include <avahi-common/error.h>
-
-#include <pulse/xmalloc.h>
-
-#include <pulsecore/log.h>
-#include <pulsecore/core-util.h>
-#include <pulsecore/avahi-wrap.h>
-#include <pulsecore/refcnt.h>
-#include <pulsecore/macro.h>
-
-#include "browser.h"
-
-#define SERVICE_TYPE_SINK "_pulse-sink._tcp."
-#define SERVICE_TYPE_SOURCE "_pulse-source._tcp."
-#define SERVICE_TYPE_SERVER "_pulse-server._tcp."
-
-struct pa_browser {
-    PA_REFCNT_DECLARE;
-
-    pa_mainloop_api *mainloop;
-    AvahiPoll* avahi_poll;
-
-    pa_browse_cb_t callback;
-    void *userdata;
-
-    pa_browser_error_cb_t error_callback;
-    void *error_userdata;
-
-    AvahiClient *client;
-    AvahiServiceBrowser *server_browser, *sink_browser, *source_browser;
-
-};
-
-static int map_to_opcode(const char *type, int new) {
-
-    if (avahi_domain_equal(type, SERVICE_TYPE_SINK))
-        return new ? PA_BROWSE_NEW_SINK : PA_BROWSE_REMOVE_SINK;
-    else if (avahi_domain_equal(type, SERVICE_TYPE_SOURCE))
-        return new ? PA_BROWSE_NEW_SOURCE : PA_BROWSE_REMOVE_SOURCE;
-    else if (avahi_domain_equal(type, SERVICE_TYPE_SERVER))
-        return new ? PA_BROWSE_NEW_SERVER : PA_BROWSE_REMOVE_SERVER;
-
-    return -1;
-}
-
-static void resolve_callback(
-        AvahiServiceResolver *r,
-        AvahiIfIndex interface,
-        AvahiProtocol protocol,
-        AvahiResolverEvent event,
-        const char *name,
-        const char *type,
-        const char *domain,
-        const char *host_name,
-        const AvahiAddress *aa,
-        uint16_t port,
-        AvahiStringList *txt,
-        AvahiLookupResultFlags flags,
-        void *userdata) {
-
-    pa_browser *b = userdata;
-    pa_browse_info i;
-    char ip[256], a[256];
-    int opcode;
-    int device_found = 0;
-    uint32_t cookie;
-    pa_sample_spec ss;
-    int ss_valid = 0;
-    char *key = NULL, *value = NULL;
-
-    pa_assert(b);
-    pa_assert(PA_REFCNT_VALUE(b) >= 1);
-
-    memset(&i, 0, sizeof(i));
-    i.name = name;
-
-    if (event != AVAHI_RESOLVER_FOUND)
-        goto fail;
-
-    if (!b->callback)
-        goto fail;
-
-    opcode = map_to_opcode(type, 1);
-    pa_assert(opcode >= 0);
-
-    if (aa->proto == AVAHI_PROTO_INET)
-        pa_snprintf(a, sizeof(a), "tcp:%s:%u", avahi_address_snprint(ip, sizeof(ip), aa), port);
-    else {
-        pa_assert(aa->proto == AVAHI_PROTO_INET6);
-        pa_snprintf(a, sizeof(a), "tcp6:%s:%u", avahi_address_snprint(ip, sizeof(ip), aa), port);
-    }
-    i.server = a;
-
-
-    while (txt) {
-
-        if (avahi_string_list_get_pair(txt, &key, &value, NULL) < 0)
-            break;
-
-        if (!strcmp(key, "device")) {
-            device_found = 1;
-            pa_xfree((char*) i.device);
-            i.device = value;
-            value = NULL;
-        } else if (!strcmp(key, "server-version")) {
-            pa_xfree((char*) i.server_version);
-            i.server_version = value;
-            value = NULL;
-        } else if (!strcmp(key, "user-name")) {
-            pa_xfree((char*) i.user_name);
-            i.user_name = value;
-            value = NULL;
-        } else if (!strcmp(key, "fqdn")) {
-            size_t l;
-
-            pa_xfree((char*) i.fqdn);
-            i.fqdn = value;
-            value = NULL;
-
-            l = strlen(a);
-            pa_assert(l+1 <= sizeof(a));
-            strncat(a, " ", sizeof(a)-l-1);
-            strncat(a, i.fqdn, sizeof(a)-l-2);
-        } else if (!strcmp(key, "cookie")) {
-
-            if (pa_atou(value, &cookie) < 0)
-                goto fail;
-
-            i.cookie = &cookie;
-        } else if (!strcmp(key, "description")) {
-            pa_xfree((char*) i.description);
-            i.description = value;
-            value = NULL;
-        } else if (!strcmp(key, "channels")) {
-            uint32_t ch;
-
-            if (pa_atou(value, &ch) < 0 || ch <= 0 || ch > 255)
-                goto fail;
-
-            ss.channels = (uint8_t) ch;
-            ss_valid |= 1;
-
-        } else if (!strcmp(key, "rate")) {
-            if (pa_atou(value, &ss.rate) < 0)
-                goto fail;
-            ss_valid |= 2;
-        } else if (!strcmp(key, "format")) {
-
-            if ((ss.format = pa_parse_sample_format(value)) == PA_SAMPLE_INVALID)
-                goto fail;
-
-            ss_valid |= 4;
-        }
-
-        pa_xfree(key);
-        pa_xfree(value);
-        key = value = NULL;
-
-        txt = avahi_string_list_get_next(txt);
-    }
-
-    /* No device txt record was sent for a sink or source service */
-    if (opcode != PA_BROWSE_NEW_SERVER && !device_found)
-        goto fail;
-
-    if (ss_valid == 7)
-        i.sample_spec = &ss;
-
-    b->callback(b, opcode, &i, b->userdata);
-
-fail:
-    pa_xfree((void*) i.device);
-    pa_xfree((void*) i.fqdn);
-    pa_xfree((void*) i.server_version);
-    pa_xfree((void*) i.user_name);
-    pa_xfree((void*) i.description);
-
-    pa_xfree(key);
-    pa_xfree(value);
-
-    avahi_service_resolver_free(r);
-}
-
-static void handle_failure(pa_browser *b) {
-    const char *e = NULL;
-
-    pa_assert(b);
-    pa_assert(PA_REFCNT_VALUE(b) >= 1);
-
-    if (b->sink_browser)
-        avahi_service_browser_free(b->sink_browser);
-    if (b->source_browser)
-        avahi_service_browser_free(b->source_browser);
-    if (b->server_browser)
-        avahi_service_browser_free(b->server_browser);
-
-    b->sink_browser = b->source_browser = b->server_browser = NULL;
-
-    if (b->client) {
-        e = avahi_strerror(avahi_client_errno(b->client));
-        avahi_client_free(b->client);
-    }
-
-    b->client = NULL;
-
-    if (b->error_callback)
-        b->error_callback(b, e, b->error_userdata);
-}
-
-static void browse_callback(
-        AvahiServiceBrowser *sb,
-        AvahiIfIndex interface,
-        AvahiProtocol protocol,
-        AvahiBrowserEvent event,
-        const char *name,
-        const char *type,
-        const char *domain,
-        AvahiLookupResultFlags flags,
-        void *userdata) {
-
-    pa_browser *b = userdata;
-
-    pa_assert(b);
-    pa_assert(PA_REFCNT_VALUE(b) >= 1);
-
-    switch (event) {
-        case AVAHI_BROWSER_NEW: {
-
-            if (!avahi_service_resolver_new(
-                          b->client,
-                          interface,
-                          protocol,
-                          name,
-                          type,
-                          domain,
-                          AVAHI_PROTO_UNSPEC,
-                          0,
-                          resolve_callback,
-                          b))
-                handle_failure(b);
-
-            break;
-        }
-
-        case AVAHI_BROWSER_REMOVE: {
-
-            if (b->callback) {
-                pa_browse_info i;
-                int opcode;
-
-                memset(&i, 0, sizeof(i));
-                i.name = name;
-
-                opcode = map_to_opcode(type, 0);
-                pa_assert(opcode >= 0);
-
-                b->callback(b, opcode, &i, b->userdata);
-            }
-            break;
-        }
-
-        case AVAHI_BROWSER_FAILURE: {
-            handle_failure(b);
-            break;
-        }
-
-        default:
-            ;
-    }
-}
-
-static void client_callback(AvahiClient *s, AvahiClientState state, void *userdata) {
-    pa_browser *b = userdata;
-
-    pa_assert(s);
-    pa_assert(b);
-    pa_assert(PA_REFCNT_VALUE(b) >= 1);
-
-    if (state == AVAHI_CLIENT_FAILURE)
-        handle_failure(b);
-}
-
-static void browser_free(pa_browser *b);
-
-
-PA_WARN_REFERENCE(pa_browser_new, "libpulse-browse is being phased out.");
-
-pa_browser *pa_browser_new(pa_mainloop_api *mainloop) {
-    return pa_browser_new_full(mainloop, PA_BROWSE_FOR_SERVERS|PA_BROWSE_FOR_SINKS|PA_BROWSE_FOR_SOURCES, NULL);
-}
-
-PA_WARN_REFERENCE(pa_browser_new_full, "libpulse-browse is being phased out.");
-
-pa_browser *pa_browser_new_full(pa_mainloop_api *mainloop, pa_browse_flags_t flags, const char **error_string) {
-    pa_browser *b;
-    int error;
-
-    pa_assert(mainloop);
-
-    if (flags & ~(PA_BROWSE_FOR_SERVERS|PA_BROWSE_FOR_SINKS|PA_BROWSE_FOR_SOURCES) || flags == 0)
-        return NULL;
-
-    b = pa_xnew(pa_browser, 1);
-    b->mainloop = mainloop;
-    PA_REFCNT_INIT(b);
-    b->callback = NULL;
-    b->userdata = NULL;
-    b->error_callback = NULL;
-    b->error_userdata = NULL;
-    b->sink_browser = b->source_browser = b->server_browser = NULL;
-
-    b->avahi_poll = pa_avahi_poll_new(mainloop);
-
-    if (!(b->client = avahi_client_new(b->avahi_poll, 0, client_callback, b, &error))) {
-        if (error_string)
-            *error_string = avahi_strerror(error);
-        goto fail;
-    }
-
-    if ((flags & PA_BROWSE_FOR_SERVERS) &&
-        !(b->server_browser = avahi_service_browser_new(
-                  b->client,
-                  AVAHI_IF_UNSPEC,
-                  AVAHI_PROTO_INET,
-                  SERVICE_TYPE_SERVER,
-                  NULL,
-                  0,
-                  browse_callback,
-                  b))) {
-
-        if (error_string)
-            *error_string = avahi_strerror(avahi_client_errno(b->client));
-        goto fail;
-    }
-
-    if ((flags & PA_BROWSE_FOR_SINKS) &&
-        !(b->sink_browser = avahi_service_browser_new(
-                  b->client,
-                  AVAHI_IF_UNSPEC,
-                  AVAHI_PROTO_UNSPEC,
-                  SERVICE_TYPE_SINK,
-                  NULL,
-                  0,
-                  browse_callback,
-                  b))) {
-
-        if (error_string)
-            *error_string = avahi_strerror(avahi_client_errno(b->client));
-        goto fail;
-    }
-
-    if ((flags & PA_BROWSE_FOR_SOURCES) &&
-        !(b->source_browser = avahi_service_browser_new(
-                  b->client,
-                  AVAHI_IF_UNSPEC,
-                  AVAHI_PROTO_UNSPEC,
-                  SERVICE_TYPE_SOURCE,
-                  NULL,
-                  0,
-                  browse_callback,
-                  b))) {
-
-        if (error_string)
-            *error_string = avahi_strerror(avahi_client_errno(b->client));
-        goto fail;
-    }
-
-    return b;
-
-fail:
-    if (b)
-        browser_free(b);
-
-    return NULL;
-}
-
-static void browser_free(pa_browser *b) {
-    pa_assert(b);
-    pa_assert(b->mainloop);
-
-    if (b->sink_browser)
-        avahi_service_browser_free(b->sink_browser);
-    if (b->source_browser)
-        avahi_service_browser_free(b->source_browser);
-    if (b->server_browser)
-        avahi_service_browser_free(b->server_browser);
-
-    if (b->client)
-        avahi_client_free(b->client);
-
-    if (b->avahi_poll)
-        pa_avahi_poll_free(b->avahi_poll);
-
-    pa_xfree(b);
-}
-
-PA_WARN_REFERENCE(pa_browser_ref, "libpulse-browse is being phased out.");
-
-pa_browser *pa_browser_ref(pa_browser *b) {
-    pa_assert(b);
-    pa_assert(PA_REFCNT_VALUE(b) >= 1);
-
-    PA_REFCNT_INC(b);
-    return b;
-}
-
-PA_WARN_REFERENCE(pa_browser_unref, "libpulse-browse is being phased out.");
-
-void pa_browser_unref(pa_browser *b) {
-    pa_assert(b);
-    pa_assert(PA_REFCNT_VALUE(b) >= 1);
-
-    if (PA_REFCNT_DEC(b) <= 0)
-        browser_free(b);
-}
-
-PA_WARN_REFERENCE(pa_browser_set_callback, "libpulse-browse is being phased out.");
-
-void pa_browser_set_callback(pa_browser *b, pa_browse_cb_t cb, void *userdata) {
-    pa_assert(b);
-    pa_assert(PA_REFCNT_VALUE(b) >= 1);
-
-    b->callback = cb;
-    b->userdata = userdata;
-}
-
-PA_WARN_REFERENCE(pa_browser_set_error_callback, "libpulse-browse is being phased out.");
-
-void pa_browser_set_error_callback(pa_browser *b, pa_browser_error_cb_t cb, void *userdata) {
-    pa_assert(b);
-    pa_assert(PA_REFCNT_VALUE(b) >= 1);
-
-    b->error_callback = cb;
-    b->error_userdata = userdata;
-}
diff --git a/src/pulse/browser.h b/src/pulse/browser.h
deleted file mode 100644
index c843e2a..0000000
--- a/src/pulse/browser.h
+++ /dev/null
@@ -1,99 +0,0 @@
-#ifndef foobrowserhfoo
-#define foobrowserhfoo
-
-/***
-  This file is part of PulseAudio.
-
-  Copyright 2004-2006 Lennart Poettering
-
-  PulseAudio is free software; you can redistribute it and/or modify
-  it under the terms of the GNU Lesser General Public License as
-  published by the Free Software Foundation; either version 2.1 of the
-  License, or (at your option) any later version.
-
-  PulseAudio is distributed in the hope that it will be useful, but
-  WITHOUT ANY WARRANTY; without even the implied warranty of
-  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
-  General Public License for more details.
-
-  You should have received a copy of the GNU Lesser General Public
-  License along with PulseAudio; if not, write to the Free Software
-  Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307
-  USA.
-***/
-
-#include <pulse/mainloop-api.h>
-#include <pulse/sample.h>
-#include <pulse/channelmap.h>
-#include <pulse/cdecl.h>
-#include <pulse/version.h>
-
-/** \file
- * An abstract interface for Zeroconf browsing of PulseAudio servers */
-
-PA_C_DECL_BEGIN
-
-/** An opaque Zeroconf service browser object */
-typedef struct pa_browser pa_browser;
-
-/** Opcodes for pa_browser_cb_t callbacks */
-typedef enum pa_browse_opcode {
-    PA_BROWSE_NEW_SERVER = 0, /**< New server found */
-    PA_BROWSE_NEW_SINK,       /**< New sink found */
-    PA_BROWSE_NEW_SOURCE,     /**< New source found */
-    PA_BROWSE_REMOVE_SERVER,  /**< Server disappeared */
-    PA_BROWSE_REMOVE_SINK,    /**< Sink disappeared */
-    PA_BROWSE_REMOVE_SOURCE   /**< Source disappeared */
-} pa_browse_opcode_t;
-
-typedef enum pa_browse_flags {
-    PA_BROWSE_FOR_SERVERS = 1, /**< Browse for servers */
-    PA_BROWSE_FOR_SINKS = 2, /**< Browse for sinks */
-    PA_BROWSE_FOR_SOURCES = 4 /** Browse for sources */
-} pa_browse_flags_t;
-
-/** Create a new browser object on the specified main loop */
-pa_browser *pa_browser_new(pa_mainloop_api *mainloop);
-
-/** Same pa_browser_new, but pass additional flags parameter. */
-pa_browser *pa_browser_new_full(pa_mainloop_api *mainloop, pa_browse_flags_t flags, const char **error_string);
-
-/** Increase reference counter of the specified browser object */
-pa_browser *pa_browser_ref(pa_browser *z);
-
-/** Decrease reference counter of the specified browser object */
-void pa_browser_unref(pa_browser *z);
-
-/** Information about a sink/source/server found with Zeroconf */
-typedef struct pa_browse_info {
-    const char *name;  /**< Unique service name; always available */
-
-    const char *server; /**< Server name; always available */
-    const char *server_version; /**< Server version string; optional */
-    const char *user_name; /**< User name of the server process; optional */
-    const char *fqdn; /* Server version; optional */
-    const uint32_t *cookie;  /* Server cookie; optional */
-
-    const char *device; /* Device name; always available when this information is of a sink/source */
-    const char *description;  /* Device description; optional */
-    const pa_sample_spec *sample_spec;  /* Sample specification of the device; optional */
-} pa_browse_info;
-
-/** Callback prototype */
-typedef void (*pa_browse_cb_t)(pa_browser *z, pa_browse_opcode_t c, const pa_browse_info *i, void *userdata);
-
-/** Set the callback pointer for the browser object */
-void pa_browser_set_callback(pa_browser *z, pa_browse_cb_t cb, void *userdata);
-
-/** Callback prototype for errors */
-typedef void (*pa_browser_error_cb_t)(pa_browser *z, const char *error_string, void *userdata);
-
-/** Set a callback function that is called whenever the browser object
- * becomes invalid due to an error. After this function has been
- * called the browser object has become invalid and should be
- * freed. */
-void pa_browser_set_error_callback(pa_browser *z, pa_browser_error_cb_t, void *userdata);
-
-PA_C_DECL_END
-
-#endif
diff --git a/src/utils/pabrowse.c b/src/utils/pabrowse.c
deleted file mode 100644
index a00fb4d..0000000
--- a/src/utils/pabrowse.c
+++ /dev/null
@@ -1,156 +0,0 @@
-/***
-  This file is part of PulseAudio.
-
-  Copyright 2004-2006 Lennart Poettering
-
-  PulseAudio is free software; you can redistribute it and/or modify
-  it under the terms of the GNU Lesser General Public License as published
-  by the Free Software Foundation; either version 2.1 of the License,
-  or (at your option) any later version.
-
-  PulseAudio is distributed in the hope that it will be useful, but
-  WITHOUT ANY WARRANTY; without even the implied warranty of
-  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
-  General Public License for more details.
-
-  You should have received a copy of the GNU Lesser General Public License
-  along with PulseAudio; if not, write to the Free Software
-  Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307
-  USA.
-***/
-
-#ifdef HAVE_CONFIG_H
-#include <config.h>
-#endif
-
-#include <stdio.h>
-#include <assert.h>
-#include <signal.h>
-
-#include <pulse/browser.h>
-#include <pulse/pulseaudio.h>
-
-#include <pulsecore/core-util.h>
-
-static void exit_signal_callback(pa_mainloop_api*m, pa_signal_event *e, int sig, void *userdata) {
-    fprintf(stderr, "Got signal, exiting\n");
-    m->quit(m, 0);
-}
-
-static void dump_server(const pa_browse_info *i) {
-    char t[16];
-
-    if (i->cookie)
-        snprintf(t, sizeof(t), "0x%08x", *i->cookie);
-
-    printf("server: %s\n"
-           "server-version: %s\n"
-           "user-name: %s\n"
-           "fqdn: %s\n"
-           "cookie: %s\n",
-           i->server,
-           i->server_version ? i->server_version : "n/a",
-           i->user_name ? i->user_name : "n/a",
-           i->fqdn ? i->fqdn : "n/a",
-           i->cookie ? t : "n/a");
-}
-
-static void dump_device(const pa_browse_info *i) {
-    char ss[PA_SAMPLE_SPEC_SNPRINT_MAX];
-
-    if (i->sample_spec)
-        pa_sample_spec_snprint(ss, sizeof(ss), i->sample_spec);
-
-    printf("device: %s\n"
-           "description: %s\n"
-           "sample spec: %s\n",
-           i->device,
-           i->description ? i->description : "n/a",
-           i->sample_spec ? ss : "n/a");
-
-}
-
-static void browser_callback(pa_browser *b, pa_browse_opcode_t c, const pa_browse_info *i, void *userdata) {
-    assert(b && i);
-
-    switch (c) {
-
-        case PA_BROWSE_NEW_SERVER:
-            printf("\n=> new server <%s>\n", i->name);
-            dump_server(i);
-            break;
-
-        case PA_BROWSE_NEW_SINK:
-            printf("\n=> new sink <%s>\n", i->name);
-            dump_server(i);
-            dump_device(i);
-            break;
-
-        case PA_BROWSE_NEW_SOURCE:
-            printf("\n=> new source <%s>\n", i->name);
-            dump_server(i);
-            dump_device(i);
-            break;
-
-        case PA_BROWSE_REMOVE_SERVER:
-            printf("\n=> removed server <%s>\n", i->name);
-            break;
-
-        case PA_BROWSE_REMOVE_SINK:
-            printf("\n=> removed sink <%s>\n", i->name);
-            break;
-
-        case PA_BROWSE_REMOVE_SOURCE:
-            printf("\n=> removed source <%s>\n", i->name);
-            break;
-
-        default:
-            ;
-    }
-}
-
-static void error_callback(pa_browser *b, const char *s, void *userdata) {
-    pa_mainloop_api*m = userdata;
-
-    fprintf(stderr, "Failure: %s\n", s);
-    m->quit(m, 1);
-}
-
-int main(int argc, char *argv[]) {
-    pa_mainloop *mainloop = NULL;
-    pa_browser *browser = NULL;
-    int ret = 1, r;
-    const char *s;
-
-    if (!(mainloop = pa_mainloop_new()))
-        goto finish;
-
-    r = pa_signal_init(pa_mainloop_get_api(mainloop));
-    assert(r == 0);
-    pa_signal_new(SIGINT, exit_signal_callback, NULL);
-    pa_signal_new(SIGTERM, exit_signal_callback, NULL);
-    pa_disable_sigpipe();
-
-    if (!(browser = pa_browser_new_full(pa_mainloop_get_api(mainloop), PA_BROWSE_FOR_SERVERS|PA_BROWSE_FOR_SINKS|PA_BROWSE_FOR_SOURCES, &s))) {
-        fprintf(stderr, "pa_browse_new_full(): %s\n", s);
-        goto finish;
-    }
-
-    pa_browser_set_callback(browser, browser_callback, NULL);
-    pa_browser_set_error_callback(browser, error_callback, pa_mainloop_get_api(mainloop));
-
-    ret = 0;
-    pa_mainloop_run(mainloop, &ret);
-
-finish:
-
-    if (browser)
-        pa_browser_unref(browser);
-
-    if (mainloop) {
-        pa_signal_done();
-        pa_mainloop_free(mainloop);
-    }
-
-    return ret;
-}
-- 
1.7.4.1



More information about the pulseaudio-discuss mailing list