about summary refs log tree commit diff
diff options
context:
space:
mode:
authorJason A. Donenfeld <Jason@zx2c4.com>2015-02-09 12:27:44 +0100
committerJason A. Donenfeld <Jason@zx2c4.com>2015-02-09 12:29:57 +0100
commit6e498de213aeebf63523ff0f298c2ae6393f9c0f (patch)
tree689122afcac6b3e1ffa83837f4eb6dd96641d1e5
parentui-clone.c: Fix path check (diff)
downloadcgit-pink-6e498de213aeebf63523ff0f298c2ae6393f9c0f.tar.gz
cgit-pink-6e498de213aeebf63523ff0f298c2ae6393f9c0f.zip
ui-clone.c: Fix off-by-one error in pack path
Signed-off-by: Jason A. Donenfeld <Jason@zx2c4.com>
Diffstat (limited to '')
-rw-r--r--ui-clone.c16
1 files changed, 11 insertions, 5 deletions
diff --git a/ui-clone.c b/ui-clone.c
index 1e6238d..e35d3d3 100644
--- a/ui-clone.c
+++ b/ui-clone.c
@@ -32,16 +32,22 @@ static int print_ref_info(const char *refname, const unsigned char *sha1,
 static void print_pack_info(void)
 {
 	struct packed_git *pack;
-	int ofs;
+	char *offset;
 
 	ctx.page.mimetype = "text/plain";
 	ctx.page.filename = "objects/info/packs";
 	cgit_print_http_headers();
-	ofs = strlen(ctx.repo->path) + strlen("/objects/pack/");
 	prepare_packed_git();
-	for (pack = packed_git; pack; pack = pack->next)
-		if (pack->pack_local)
-			htmlf("P %s\n", pack->pack_name + ofs);
+	for (pack = packed_git; pack; pack = pack->next) {
+		if (pack->pack_local) {
+			offset = strrchr(pack->pack_name, '/');
+			if (offset && offset[1] != '\0')
+				++offset;
+			else
+				offset = pack->pack_name;
+			htmlf("P %s\n", offset);
+		}
+	}
 }
 
 static void send_file(char *path)