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 - 1:59 am

Giuseppe Bilotta wrote:


Nice summary.

[...]

I'm not sure if the '# dispatch' comment is correct here now that
%actions hash is moved away from actual dispatch (selecting action
to run)


I would use here pattern matching, but your code is also good and
doesn't need changing; just for completeness below there is alternate
solution:

+	$path_info =~ m,^(.*?)/,;
+	$action = $1;


[...]

You meant here

  		# we got "project.git/branch" or "project.git/action/branch"


This hunk is IMHO incorrect.  First, $refname is _either_ $hash, or
$hash_base; it cannot be both.  Second, in most cases (like the case
of 'shortlog' action, either explicit or implicit) it is simply $hash;
I think it can be $hash_base when $file_name is not set only in
singular exception case of 'tree' view for the top tree (lack of
filename is not an error, but is equivalent to $file_name='/').

[...]

I _think_ the '# dispatch' comment should be left here, and not moved
with the %actions hash.


I would _perhaps_ add here comment that multivalued parameters can come
only from CGI query string, so there is no need for something like:

+					$params{$name} = (ref($$name) ? @$name : $$name) if $$name;


This fragment is a bit of ugly code, hopefully corrected in later patch.
I think it would be better to have 'refactor parsing/validation of input
parameters' to be very fist patch in series; I am not sure but I suspect
that is a kind of bugfix for current "$project/$hash" ('shortlog' view)
and "$project/$hash_base:$file_name" ('blob_plain' and 'tree' view)
path_info.

P.S. It is a bit of pity that Mechanize test from Lea Wiemann caching
gitweb code is not in the 'master' or at least 'pu'.  Using big, single,
monolithic patch instead of patch series of small, easy reviewable
commits strikes again... ;-(

-- 
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: parse project/action/hash_base:filen ..., Jakub Narebski, (Thu Oct 2, 1:59 am)
Re: [PATCHv4] gitweb: PATH_INFO support improvements, Jakub Narebski, (Thu Oct 2, 3:16 am)
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)