about summary refs log tree commit
path: root/ui-clone.c
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 /ui-clone.c
parentb66b16ed026c6f57ad8ae892c821d835113e7fb2 (diff)
downloadcgit-6e498de213aeebf63523ff0f298c2ae6393f9c0f.tar.gz
ui-clone.c: Fix off-by-one error in pack path
Signed-off-by: Jason A. Donenfeld <Jason@zx2c4.com>
Diffstat (limited to 'ui-clone.c')
-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)