]> git.wh0rd.org Git - elf2flt.git/commitdiff
the attached patch is needed for the recent elf2flt
authorDavid McCullough <davidm@snapgear.com>
Tue, 15 Feb 2011 23:22:26 +0000 (23:22 +0000)
committerDavid McCullough <davidm@snapgear.com>
Tue, 15 Feb 2011 23:22:26 +0000 (23:22 +0000)
on MinGW builds. The stat() cannot cope with directories
ending with the directory separator.

Regards
Stanislav Meduna <stano@meduna.org>

ld-elf2flt.c

index e4cb0736f4ad6898a1a3f79af222d60b11877af0..6b8853e83581dfacaa555a3cee95f9a5d302a19e 100644 (file)
@@ -506,13 +506,15 @@ int main(int argc, char *argv[])
           Make bindir point to the bin dir for bin/<TARGET_ALIAS>-foo.
           Make tooldir point to the bin dir for <TARGET_ALIAS>/bin/foo.  */
        if (streqn(elf2flt_progname, TARGET_ALIAS)) {
-               tmp = concat(argv0_dir, "../" TARGET_ALIAS "/bin/", NULL);
-               if (stat(tmp, &buf) == 0 && S_ISDIR(buf.st_mode))
-                       tooldir = tmp;
+               tmp = concat(argv0_dir, "../" TARGET_ALIAS "/bin", NULL);
+               if (stat(tmp, &buf) == 0 && S_ISDIR(buf.st_mode)) {
+                       tooldir = concat(tmp, "/", NULL);
+               }
        } else {
-               tmp = concat(argv0_dir, "../../bin/", NULL);
-               if (stat(tmp, &buf) == 0 && S_ISDIR(buf.st_mode))
-                       bindir = tmp;
+               tmp = concat(argv0_dir, "../../bin", NULL);
+               if (stat(tmp, &buf) == 0 && S_ISDIR(buf.st_mode)) {
+                       bindir = concat(tmp, "/", NULL);
+               }
        }
 
        /* Typically ld-elf2flt is invoked as `ld` which means error