ls-remote: define die() now we do not use git-sh-setup
[gitweb.git] / hash-object.c
index 0821e543f57caa264f0cff292f4c7dbe1ed0f148..c3d05a853a5518d2800eb65a00c181f6d8ab312f 100644 (file)
@@ -21,7 +21,7 @@ static void hash_object(const char *path, const char *type, int write_object)
        printf("%s\n", sha1_to_hex(sha1));
 }
 
-static const char *hash_object_usage =
+static const char hash_object_usage[] =
 "git-hash-object [-t <type>] [-w] <file>...";
 
 int main(int argc, char **argv)
@@ -29,6 +29,8 @@ int main(int argc, char **argv)
        int i;
        const char *type = "blob";
        int write_object = 0;
+       const char *prefix;
+       int prefix_length = -1;
 
        for (i = 1 ; i < argc; i++) {
                if (!strcmp(argv[i], "-t")) {
@@ -36,10 +38,20 @@ int main(int argc, char **argv)
                                die(hash_object_usage);
                        type = argv[i];
                }
-               else if (!strcmp(argv[i], "-w"))
+               else if (!strcmp(argv[i], "-w")) {
+                       if (prefix_length < 0) {
+                               prefix = setup_git_directory();
+                               prefix_length = prefix ? strlen(prefix) : 0;
+                       }
                        write_object = 1;
-               else
-                       hash_object(argv[i], type, write_object);
+               }
+               else {
+                       char *arg = argv[i];
+                       if (0 <= prefix_length)
+                               arg = prefix_filename(prefix, prefix_length,
+                                                     arg);
+                       hash_object(arg, type, write_object);
+               }
        }
        return 0;
 }