[pulseaudio-discuss] [PATCH v4 39/41] module: Create pa_module_exists()
João Paulo Rechi Vita
jprvita at gmail.com
Tue Sep 24 14:46:45 PDT 2013
On Sat, Sep 21, 2013 at 12:11 PM, Tanu Kaskinen
<tanu.kaskinen at linux.intel.com> wrote:
> On Wed, 2013-09-18 at 16:17 -0500, jprvita at gmail.com wrote:
>> From: João Paulo Rechi Vita <jprvita at openbossa.org>
>>
>> This new function checks if a certain module name is available in the
>> system.
>> ---
>> src/pulsecore/module.c | 49 +++++++++++++++++++++++++++++++++++++++++++++++++
>> src/pulsecore/module.h | 2 ++
>> 2 files changed, 51 insertions(+)
>>
>> diff --git a/src/pulsecore/module.c b/src/pulsecore/module.c
>> index 16582b3..bc53f07 100644
>> --- a/src/pulsecore/module.c
>> +++ b/src/pulsecore/module.c
>> @@ -28,6 +28,7 @@
>> #include <stdlib.h>
>> #include <string.h>
>> #include <errno.h>
>> +#include <ltdl.h>
>>
>> #include <pulse/xmalloc.h>
>> #include <pulse/proplist.h>
>> @@ -47,6 +48,54 @@
>> #define PA_SYMBOL_GET_N_USED "pa__get_n_used"
>> #define PA_SYMBOL_GET_DEPRECATE "pa__get_deprecated"
>>
>> +bool pa_module_exists(const char *name) {
>> + const char *paths, *state = NULL;
>> + char *p, *pathname;
>> + bool result;
>> +
>> + pa_assert(name);
>> +
>> + if (name[0] == PA_PATH_SEP_CHAR) {
>> + result = access(name, F_OK) == 0 ? true : false;
>> + pa_log_debug("Checking for existence of '%s': %s", name, result ? "success" : "failure");
>> + if (result)
>> + return true;
>> + }
>> +
>> + if (!(paths = lt_dlgetsearchpath()))
>> + return false;
>> +
>> + /* strip .so from the end of name, if present */
>> + p = rindex(name, '.');
>> + if (p && pa_streq(p, ".so"))
>
> Use PA_SOEXT instead of hardcoding ".so".
>
There is no PA_SOEXT in the code context, just at build context. I'll
have to define it at configure time with AC_DEFINE().
--
João Paulo Rechi Vita
http://about.me/jprvita
More information about the pulseaudio-discuss
mailing list