X-Git-Url: https://git.verplant.org/?a=blobdiff_plain;f=convert-cache.c;h=ee599f1c027fc829ab98a3ba489a5c4bfd7e9977;hb=71fb3de0eed70bba1c7e28c8a0a2968efc48b9f3;hp=4d34d2d57ecda02aea70fab008fab32f5a4391b0;hpb=3c249c950649a37f2871a8b193f01a0640a20aef;p=git.git diff --git a/convert-cache.c b/convert-cache.c index 4d34d2d5..ee599f1c 100644 --- a/convert-cache.c +++ b/convert-cache.c @@ -99,7 +99,7 @@ static int write_subdirectory(void *buffer, unsigned long size, const char *base continue; } - newlen += sprintf(new + newlen, "%o %.*s", S_IFDIR, slash - path, path); + newlen += sprintf(new + newlen, "%o %.*s", S_IFDIR, (int)(slash - path), path); new[newlen++] = 0; sha1 = (unsigned char *)(new + newlen); newlen += 20; @@ -116,6 +116,34 @@ static int write_subdirectory(void *buffer, unsigned long size, const char *base return used; } +static int convert_mode(char *buffer) +{ + char *end; + unsigned short mode = strtoul(buffer, &end, 8); + unsigned short newmode; + char num[10]; + int len; + + if (*end != ' ') + die("corrupt tree object"); + switch (mode) { + case S_IFREG | 0644: + case S_IFREG | 0755: + case S_IFLNK: + case S_IFDIR: + return 0; + } + newmode = 0; + if (S_ISREG(mode)) + newmode = (mode & 0100) ? 0755 : 0644; + newmode |= mode & S_IFMT; + len = sprintf(num, "%o", newmode); + if (len != end - buffer) + return error("unable to convert tree entry mode %o to %o", mode, newmode); + memcpy(buffer, num, len); + return 0; +} + static void convert_tree(void *buffer, unsigned long size, unsigned char *result_sha1) { void *orig_buffer = buffer; @@ -124,6 +152,7 @@ static void convert_tree(void *buffer, unsigned long size, unsigned char *result while (size) { int len = 1+strlen(buffer); + convert_mode(buffer); convert_binary_sha1(buffer + len); len += 20; @@ -304,7 +333,7 @@ int main(int argc, char **argv) struct entry *entry; if (argc != 2 || get_sha1(argv[1], sha1)) - usage("convert-cache "); + usage("git-convert-cache "); entry = convert_entry(sha1); printf("new sha1: %s\n", sha1_to_hex(entry->new_sha1));