From: Lars Hjemli Date: Sun, 11 Jan 2009 11:22:46 +0000 (+0100) Subject: Merge branch 'snapshot-fixes' X-Git-Url: https://gitweb.ps.run/ps-cgit/commitdiff_plain/aa60ae12cb3db965b3fe7239424cab92175b8343?hp=-c Merge branch 'snapshot-fixes' --- aa60ae12cb3db965b3fe7239424cab92175b8343 diff --combined tests/t0107-snapshot.sh index c42091a,5f1b862..8ab4912 --- a/tests/t0107-snapshot.sh +++ b/tests/t0107-snapshot.sh @@@ -4,36 -4,36 +4,36 @@@ prepare_tests "Verify snapshot" - run_test 'get foo/snapshot/test.tar.gz' ' - cgit_url "foo/snapshot/test.tar.gz" >trash/tmp + run_test 'get foo/snapshot/master.tar.gz' ' + cgit_url "foo/snapshot/master.tar.gz" >trash/tmp ' run_test 'check html headers' ' head -n 1 trash/tmp | - grep -e "Content-Type: application/x-tar" && + grep -e "Content-Type: application/x-gzip" && head -n 2 trash/tmp | - grep -e "Content-Disposition: inline; filename=.test.tar.gz." + grep -e "Content-Disposition: inline; filename=.master.tar.gz." ' run_test 'strip off the header lines' ' - tail -n +6 trash/tmp > trash/test.tar.gz + tail -n +6 trash/tmp > trash/master.tar.gz ' - run_test 'verify gzip format' 'gunzip --test trash/test.tar.gz' + run_test 'verify gzip format' 'gunzip --test trash/master.tar.gz' run_test 'untar' ' - rm -rf trash/foo && - tar -xf trash/test.tar.gz -C trash + rm -rf trash/master && + tar -xf trash/master.tar.gz -C trash ' run_test 'count files' ' - c=$(ls -1 trash/foo/ | wc -l) && + c=$(ls -1 trash/master/ | wc -l) && test $c = 5 ' run_test 'verify untarred file-5' ' - grep -e "^5$" trash/foo/file-5 && - test $(cat trash/foo/file-5 | wc -l) = 1 + grep -e "^5$" trash/master/file-5 && + test $(cat trash/master/file-5 | wc -l) = 1 ' tests_done diff --combined ui-snapshot.c index 5f813fc,f98f5d7..f25613e --- a/ui-snapshot.c +++ b/ui-snapshot.c @@@ -58,8 -58,8 +58,8 @@@ static int write_tar_bzip2_archive(stru const struct cgit_snapshot_format cgit_snapshot_formats[] = { { ".zip", "application/x-zip", write_zip_archive, 0x1 }, - { ".tar.gz", "application/x-tar", write_tar_gzip_archive, 0x2 }, - { ".tar.bz2", "application/x-tar", write_tar_bzip2_archive, 0x4 }, + { ".tar.gz", "application/x-gzip", write_tar_gzip_archive, 0x2 }, + { ".tar.bz2", "application/x-bzip2", write_tar_bzip2_archive, 0x4 }, { ".tar", "application/x-tar", write_tar_archive, 0x8 }, {} }; @@@ -175,10 -175,12 +175,12 @@@ void cgit_print_snapshot(const char *he if (!hex && dwim) { hex = get_ref_from_filename(ctx.repo->url, filename, f); - if (hex != NULL) { - prefix = xstrdup(filename); - prefix[strlen(filename) - strlen(f->suffix)] = '\0'; + if (hex == NULL) { + html_status(404, "Not found", 0); + return; } + prefix = xstrdup(filename); + prefix[strlen(filename) - strlen(f->suffix)] = '\0'; } if (!hex)