On Sun, Mar 04, 2007 at 07:08:13AM +0200, Sami Liedes wrote:
> I found it useful to allow preloading other libraries when using zzuf.
> Here's a patch for that:

Argh, shouldn't do this when tired. Here's a patch that should work.

        Sami

------------------------------------------------------------
diff -ur zzuf-0.8.1/src/zzuf.c zzuf-0.8.1.sli/src/zzuf.c
--- zzuf-0.8.1/src/zzuf.c       2007-03-02 01:51:54.000000000 +0200
+++ zzuf-0.8.1.sli/src/zzuf.c   2007-03-04 09:50:13.000000000 +0200
@@ -837,7 +837,7 @@
     char buf[64];
 #if defined HAVE_FORK
     static int const files[] = { DEBUG_FILENO, STDERR_FILENO, STDOUT_FILENO };
-    char *libpath, *tmp;
+    char *libpath, *tmp, *old_preload, *new_preload;
     int pid, j, len = strlen(opts->oldargv[0]);
 #   if defined __APPLE__
 #       define FILENAME "libzzuf.dylib"
@@ -910,10 +910,31 @@
 
     strcpy(tmp ? tmp + 1 : libpath, ".libs/" FILENAME EXTRAINFO);
     if(ret == 0)
-        setenv(PRELOAD, libpath, 1);
+    {
+       old_preload = getenv(PRELOAD);
+       if (!old_preload)
+           old_preload = "";
+       new_preload = malloc(strlen(old_preload)+strlen(libpath)+2);
+       strcpy(new_preload, old_preload);
+       strcat(new_preload, ":");
+       strcat(new_preload, libpath);
+        setenv(PRELOAD, new_preload, 1);
+    }
     else
-        setenv(PRELOAD, LIBDIR "/" FILENAME EXTRAINFO, 1);
+    {
+       old_preload = getenv(PRELOAD);
+       if (!old_preload)
+           old_preload = "";
+       new_preload =
+           malloc(strlen(old_preload)+
+                  strlen(LIBDIR "/" FILENAME EXTRAINFO)+2);
+       strcpy(new_preload, old_preload);
+       strcat(new_preload, ":");
+       strcat(new_preload, LIBDIR "/" FILENAME EXTRAINFO);
+       setenv(PRELOAD, new_preload, 1);
+    }
     free(libpath);
+    free(new_preload);
 
     if(execvp(opts->newargv[0], opts->newargv))
     {

Attachment: signature.asc
Description: Digital signature

Reply via email to