This series of patches tries to improve gitweb speed somewhat. Patch 1/7 makes possible to easily enable/disable pickaxe search ('pickaxe:' operator), by making pickaxe search a feature. Patch 2/7 paginates history output, which makes "history" view for files with longer history appear much faster. Patch 7/7 fixes omission in pagination of history output. This patch is updated to newer mod_perl compatibile gitweb version, and corrected version of previous patch with the same title. Patch 3/7 makes it easy to make history output faster, if changing the output (making output backward-incompatibile), by making it easy to remove '--full-history' option and/or add '--remove-empty' option. Patches 4/7, 5/7, 6/7 tries to make gitweb faster by eliminating calls to git-rev-list, combining generating list of revision and commit parsing into one subroutine, using one call to git-rev-list. Unfortunately, git-rev-list is broken: 'git rev-list <commit> --full-history --parents -- <filename>' shows all merges in addition to what 'git rev-list <commit> --parents -- <filename>' and 'git rev-list <commit> --full-history -- <filename>' shows, see "git-rev-list --full-history --parents doesn't respect path limit and shows all merges" thread Message-ID: <edmabt$3tc$1@xxxxxxxxxxxxx> http://permalink.gmane.org/gmane.comp.version-control.git/26514 So probably those patches should be dropped or put in freezer until git-rev-list is corrected. Benchmark: First column is the patch number (0 means state before first patch), columns 2 to 4 are results of running gitweb from command line, using /usr/bin/time -f "%e %U %s", columns 5 to 8 are taken from ApacheBench 2.0.41-dev, run with -n 10 option, 5 and 6 for mod_cgi, 7 and 8 for mod_perl (probably not configured correctly, as it is slower than CGI version). # 1:gitweb/new~n 2:%e 3:%U 4:%s 5:ab-n10_cgi_time[ms] 6:[+/-sd] 7:ab-n10_perl_time[ms] 8:[+/-sd] 0 11.38 9.66 0 11350.681 96.8 11950.143 546.3 1 11.37 9.71 0 18150.842 4327.8 14535.352 3149.1 2 3.61 2.16 0 3719.344 261.9 3975.663 219.6 3 3.62 2.20 0 3576.822 41.2 3929.396 201.6 4 3.61 2.13 0 3620.246 188.3 3943.111 184.1 4 3.61 2.13 0 3622.156 172.6 3716.499 53.0 #5 0/0 0/0 0/0 0/0 0/0 0/0 0/0 6 2.60 1.56 0 2809.344 369.5 2823.286 245.9 7 2.59 1.53 0 2621.073 234.2 2742.230 96.6 Shortlog: [PATCH 1/7] gitweb: Make pickaxe search a feature [PATCH 2/7] gitweb: Paginate history output [PATCH 3/7] gitweb: Use @hist_opts as git-rev-list parameters in git_history [PATCH 4/7] gitweb: Add parse_rev_list for later use [PATCH 5/7] gitweb: Use parse_rev_list in git_shortlog and git_history [PATCH 6/7] gitweb: Assume parsed revision list in git_shortlog_body and git_history_body [PATCH 7/7] gitweb: Set page to 0 if it is not defined, in git_history Diffstat: --- gitweb/gitweb.perl | 180 +++++++++++++++++++++++++++++++++++++++++----------- 1 files changed, 141 insertions(+), 39 deletions(-)- P.S. Is putting diffstat in such a series of patches actually usefull? -- Jakub Narebski ShadeHawk on #git Poland - To unsubscribe from this list: send the line "unsubscribe git" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html