summaryrefslogtreecommitdiff
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)
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)