From e2418c01b1d351c2f9939ecc4cda2b19df8d6d78 Mon Sep 17 00:00:00 2001 From: Linus Torvalds Date: Sat, 16 Jul 2005 09:57:03 -0700 Subject: [PATCH] git-convert-cache: fix up file modes in trees too git-fsck-cache complains about some of the odder ones, and is quiet about the old (S_IFREG | 664) case, but that's wrong too. Converting the kernel tree is too painful right now, but at least we know how to do it if we ever want to. --- convert-cache.c | 29 +++++++++++++++++++++++++++++ 1 file changed, 29 insertions(+) diff --git a/convert-cache.c b/convert-cache.c index 77f8bff9ac..ee599f1c02 100644 --- a/convert-cache.c +++ b/convert-cache.c @@ -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;