Re: [PATCHv4] gitweb: parse project/action/hash_base:filename PATH_INFO

Previous message: [thread] [date] [author]
Next message: [thread] [date] [author]
From: Jakub Narebski
Date: Thursday, October 2, 2008 - 5:48 pm

On Thu, 2 Oct 2008, Giuseppe Bilotta wrote:


Well, it is either checking $action and setting either $hash or
$hash_base, or setting both, with some comments on why and when it is
needed (as discussed on #git). IIUC $hash_base is needed only for
filename-taking tree actions which acts on top-tree, and therefore
don't need $file_name, like 'project/tree/branch' or related 
'project/history/branch' (the latter is practically almost equivalent
to 'project/shortlog/branch' or 'project/branch').

I'm not sure if it wouldn't be better to call validate_refname($refname)
once, either as:

  $hash_base ||= $hash ||= validate_refname($refname);
 
but that might be incorrect in the obscure case of setting $hash via 'h'
CGI query parameter, and letting gitweb to set-up $hash_base via
path_info, so perhaps ($refname is local to evaluate_path_info, IIRC)

  $refname = validate_refname($refname);
  $hash      ||= $refname;
  $hash_base ||= $refname;

But that is just nitpicking this fragment of code to death. In short:
either check which of $hash and $hash_base to set in this branch of
conditional, or explain why setting both $hash and $hash_base is needed,
and why it is acceptable, either as comments, or in commit message.


Why not cleanup first?

When implementing href(..., -replay=>1) I have forgot that some of
gitweb parameters are implicitly passed ($project, because it is needed
in most gitweb links), and some can be passed via path_info ($hash 
and/or $hash_base, $file_name). Your code adds $action to the mix, but
it doesn't change the fact that 1.) even before your code -replay case
was incorrect for some path_info links (handcrafted, as gitweb generates
only $project via path_info); 2.) code you have added is a bit ugly.

Besides using variables change a little meaning of -replay, namely
in your code gitweb always sets action, even for non-path_name links
when we started from "default action" (i.e. without action set) links.
I guess this is mainly theoretical issue, as I don't think that default
views use many -replay links.


P.S. with the idea of pushing parameters obtained not from CGI query
string to $cgi->param() via "$cgi->param($name, $value);" or in named
params form "$cgi->(-name=>$name, -value=>$value);" you would not need
to change (a bit hacky, admittedly) href(...,-replay=>1) code.
-- 
Jakub Narebski
Poland
--
To unsubscribe from this list: send the line "unsubscribe git" in
the body of a message to majordomo@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html
Previous message: [thread] [date] [author]
Next message: [thread] [date] [author]

Messages in current thread:
[PATCHv4] gitweb: PATH_INFO support improvements, Giuseppe Bilotta, (Wed Oct 1, 5:10 pm)
[PATCHv4] gitweb: refactor input parameters parse/validation, Giuseppe Bilotta, (Wed Oct 1, 5:10 pm)
[PATCHv4] gitweb: generate project/action/hash URLs, Giuseppe Bilotta, (Wed Oct 1, 5:10 pm)
[PATCHv4] gitweb: use_pathinfo filenames start with /, Giuseppe Bilotta, (Wed Oct 1, 5:10 pm)
[PATCHv4] gitweb: parse parent..current syntax from pathinfo, Giuseppe Bilotta, (Wed Oct 1, 5:10 pm)
[PATCHv4] gitweb: generate parent..current URLs, Giuseppe Bilotta, (Wed Oct 1, 5:10 pm)
Re: [PATCHv4] gitweb: PATH_INFO support improvements, Jakub Narebski, (Thu Oct 2, 1:19 am)
Re: [PATCHv4] gitweb: PATH_INFO support improvements, Giuseppe Bilotta, (Thu Oct 2, 1:49 am)
Re: [PATCHv4] gitweb: PATH_INFO support improvements, Jakub Narebski, (Thu Oct 2, 3:16 am)
Re: [PATCHv4] gitweb: parse project/action/hash_base:filen ..., Jakub Narebski, (Thu Oct 2, 5:48 pm)
Re: [PATCHv4] gitweb: generate project/action/hash URLs, Jakub Narebski, (Thu Oct 2, 6:48 pm)
Re: [PATCHv4] gitweb: use_pathinfo filenames start with /, Jakub Narebski, (Fri Oct 3, 4:28 am)
Re: [PATCHv4] gitweb: generate project/action/hash URLs, Jakub Narebski, (Fri Oct 3, 6:15 pm)
Re: [PATCHv4] gitweb: generate parent..current URLs, Jakub Narebski, (Sun Oct 5, 5:17 pm)