deal with failing pa_runtime_path()
authorLennart Poettering <lennart@poettering.net>
Wed, 21 May 2008 22:44:37 +0000 (22:44 +0000)
committerLennart Poettering <lennart@poettering.net>
Wed, 21 May 2008 22:44:37 +0000 (22:44 +0000)
git-svn-id: file:///home/lennart/svn/public/pulseaudio/trunk@2475 fefdeb5f-60dc-0310-8127-8f9354f1896f

src/pulse/context.c

index 0780e2f311f854c1d4db228feb9c82040e359f2c..2d92320fc669ecca648d8c85fc147a5a69c6e830 100644 (file)
@@ -103,7 +103,9 @@ static void unlock_autospawn_lock_file(pa_context *c) {
     if (c->autospawn_lock_fd >= 0) {
         char *lf;
 
-        lf = pa_runtime_path(AUTOSPAWN_LOCK);
+        if (!(lf = pa_runtime_path(AUTOSPAWN_LOCK)))
+            pa_log_warn("Cannot unlock autospawn because runtime path is no more.");
+
         pa_unlock_lockfile(lf, c->autospawn_lock_fd);
         pa_xfree(lf);
 
@@ -819,8 +821,10 @@ int pa_context_connect(
         }
 
         /* The per-user instance */
-        c->server_list = pa_strlist_prepend(c->server_list, ufn = pa_runtime_path(PA_NATIVE_DEFAULT_UNIX_SOCKET));
-        pa_xfree(ufn);
+        if ((ufn = pa_runtime_path(PA_NATIVE_DEFAULT_UNIX_SOCKET))) {
+            c->server_list = pa_strlist_prepend(c->server_list, ufn);
+            pa_xfree(ufn);
+        }
 
         /* Wrap the connection attempts in a single transaction for sane autospawn locking */
         if (!(flags & PA_CONTEXT_NOAUTOSPAWN) && c->conf->autospawn) {