Skip to content

Commit

Permalink
gitweb: generate project/action/hash URLs
Browse files Browse the repository at this point in the history
When generating path info URLs, reduce the number of CGI parameters by
embedding action and hash_parent:filename or hash in the path.

Signed-off-by: Giuseppe Bilotta <giuseppe.bilotta@gmail.com>
Acked-by: Jakub Narebski <jnareb@gmail.com>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
  • Loading branch information
Giuseppe Bilotta authored and Junio C Hamano committed Oct 25, 2008
1 parent d8c2882 commit b02bd7a
Showing 1 changed file with 30 additions and 3 deletions.
33 changes: 30 additions & 3 deletions gitweb/gitweb.perl
Original file line number Diff line number Diff line change
Expand Up @@ -731,14 +731,41 @@ (%)

my ($use_pathinfo) = gitweb_check_feature('pathinfo');
if ($use_pathinfo) {
# use PATH_INFO for project name
# try to put as many parameters as possible in PATH_INFO:
# - project name
# - action
# - hash or hash_base:filename

# When the script is the root DirectoryIndex for the domain,
# $href here would be something like http://gitweb.example.com/
# Thus, we strip any trailing / from $href, to spare us double
# slashes in the final URL
$href =~ s,/$,,;

# Then add the project name, if present
$href .= "/".esc_url($params{'project'}) if defined $params{'project'};
delete $params{'project'};

# Summary just uses the project path URL
if (defined $params{'action'} && $params{'action'} eq 'summary') {
# Summary just uses the project path URL, any other action is
# added to the URL
if (defined $params{'action'}) {
$href .= "/".esc_url($params{'action'}) unless $params{'action'} eq 'summary';
delete $params{'action'};
}

# Finally, we put either hash_base:file_name or hash
if (defined $params{'hash_base'}) {
$href .= "/".esc_url($params{'hash_base'});
if (defined $params{'file_name'}) {
$href .= ":".esc_url($params{'file_name'});
delete $params{'file_name'};
}
delete $params{'hash'};
delete $params{'hash_base'};
} elsif (defined $params{'hash'}) {
$href .= "/".esc_url($params{'hash'});
delete $params{'hash'};
}
}

# now encode the parameters explicitly
Expand Down

0 comments on commit b02bd7a

Please sign in to comment.