[project @ 2000-04-28 15:06:04 by panne]
[ghc-hetmet.git] / glafp-utils / lndir / lndir.c
index 0d77a49..27ae80e 100644 (file)
@@ -82,6 +82,8 @@ int ignore_links = 0;         /* -ignorelinks */
 char *rcurdir;
 char *curdir;
 
+int force=0;
+
 void
 quit (
 #if NeedVarargsPrototypes
@@ -284,15 +286,22 @@ int rel;                  /* if true, prepend "../" to fn before using */
        }
 
        if (symlen >= 0) {
-           /* Link exists in new tree.  Print message if it doesn't match. */
-           if (!equivalent (basesymlen>=0 ? basesym : buf, symbuf))
-               msg ("%s: %s", dp->d_name, symbuf);
-       } else {
-           if (symlink (basesymlen>=0 ? basesym : buf, dp->d_name) < 0)
+         if (!equivalent (basesymlen>=0 ? basesym : buf, symbuf)) {
+           if (force) {
+             unlink(dp->d_name);
+             if (symlink (basesymlen>=0 ? basesym : buf, dp->d_name) < 0)
                mperror (dp->d_name);
+           } else {
+             /* Link exists in new tree.  Print message if it doesn't match. */
+             msg ("%s: %s", dp->d_name, symbuf);
+           }
+         }
+       } else {
+         if (symlink (basesymlen>=0 ? basesym : buf, dp->d_name) < 0)
+           mperror (dp->d_name);
        }
     }
-
+    
     closedir (df);
     return 0;
 }
@@ -309,6 +318,8 @@ char **av;
     while (++av, --ac) {
        if (strcmp(*av, "-silent") == 0)
            silent = 1;
+       if (strcmp(*av, "-f") == 0)
+           force = 1;
        else if (strcmp(*av, "-ignorelinks") == 0)
            ignore_links = 1;
        else if (strcmp(*av, "--") == 0) {
@@ -320,7 +331,7 @@ char **av;
     }
 
     if (ac < 1 || ac > 2)
-       quit (1, "usage: %s [-silent] [-ignorelinks] fromdir [todir]",
+       quit (1, "usage: %s [-f] [-silent] [-ignorelinks] fromdir [todir]",
              prog_name);
 
     fn = av[0];
@@ -330,14 +341,20 @@ char **av;
        tn = ".";
 
     /* to directory */
-    if (stat (tn, &ts) < 0)
+    if (stat (tn, &ts) < 0) {
+      if (force && (tn[0] != '.' || tn[1] != '\0') ) {
+         mkdir(tn, S_IRWXU | S_IRWXG | S_IROTH | S_IXOTH );
+      } 
+      else {
        quiterr (1, tn);
 #ifdef S_ISDIR
-    if (!(S_ISDIR(ts.st_mode)))
+        if (!(S_ISDIR(ts.st_mode)))
 #else
-    if (!(ts.st_mode & S_IFDIR))
+        if (!(ts.st_mode & S_IFDIR))
 #endif
-       quit (2, "%s: Not a directory", tn);
+          quit (2, "%s: Not a directory", tn);
+      }
+    }
     if (chdir (tn) < 0)
        quiterr (1, tn);