From: Jakub Narebski <jnareb@gmail.com>
To: Martin Koegler <mkoegler@auto.tuwien.ac.at>
Cc: git@vger.kernel.org
Subject: Re: [PATCH] gitweb: support filename prefix in git_patchset_body
Date: Tue, 27 Mar 2007 02:07:26 +0100 [thread overview]
Message-ID: <200703270307.26589.jnareb@gmail.com> (raw)
In-Reply-To: <20070326205508.GC1128@auto.tuwien.ac.at>
Martin Koegler wrote:
> On Mon, Mar 26, 2007 at 06:12:18PM +0100, Jakub Narebski wrote:
>> On Sun, Mar 25, 2007, Martin Koegler wrote:
>>
>>> git_treediff supports comparing subdirectories. As the output of
>>> git-difftree is missing the path to the compared directories,
>>> the links in the output would be wrong.
>>>
>>> The patch adds two new parameters to add the missing path prefix.
>>
>> Wouldn't it be better to concatenate the two "path prefix" patches
>> together? They are about the same thing.
>
> I thought, each patch would be more readable, I split them in logical
> separate units. Anyway, I'll combine them.
That was just a thought. If you think that separate patches would be
more readable, by all meens keep them splitted.
>>> sub git_patchset_body {
>>> - my ($fd, $difftree, $hash, $hash_parent) = @_;
>>> + my ($fd, $difftree, $hash, $hash_parent, $file_name, $file_parent) = @_;
>>>
>>> my $patch_idx = 0;
>>> my $patch_line;
>>
>> I'd rather use $from_prefix, $to_prefix here, or $basedif_name,
>> $basedir_parent, or $dir_name, $dir_parent (my preference is to
>> $from_prefix, $to_prefix variables).
>
> I'll switch to $to_prefix and $from_prefix.
>
>> + $from_prefix = !defined $from_prefix ? '' : $from_prefix.'/';
>> + $to_prefix = !defined $to_prefix ? '' : $to_prefix . '/';
>> + $to_prefix ||= $from_prefix; # to allow to pass common prefix once
>
> OK. But is not the 3 line useless, as $to_prefix is alway defined
> after the second line and you probable want $from_prefix ||=
> $to_prefix. This will cause problems, as I currently pass the root
> tree (=tree in commit object) as an missing file name parameter, as
> gitweb does not allow an empty file name.
Third line is not important, as it is you who control the calling
convention. Perhaps it should read:
+ $to_prefix = $from_prefix if (!defined $to_prefix);
And it would be fairly easy to change gitweb to allow empty file name
parameters; simply change
!validate_pathname($file_name)
to
!defined validate_pathname($file_name)
(and similarly for $file_parent).
But I'd rather not change _CGI parameter_ (URI) convention that we set
'fp' (file parent) parameter *only* if it is different from 'f' (file
name). Otherwise we would introduce backwards incompatibile change,
with respect to bookmarks and old URI-s. Cool URI-s don't change...
BTW. "git rev-parse <tree-ish>:" == "git rev-parse <tree-ish>^{tree}"
> With an propagation logic, comparing a root tree with an sub tree will only
> work in one direction.
>
> So I prefer to do not implement any automatic propagation between the
> two prefixes.
Fine by me. It is just _internal_ call convention.
>> or something like that, or just modify $from{'file'} and $to{'file'}
>>
>> $from{'file'} = (!defined $from_prefix ? '' : $from_prefix.'/') . $from{'file'};
>> $to{'file'} = (!defined $to_prefix ? '' : $to_prefix . '/') . $to{'file'};
>>
>> just after setting $from{'file'} and $to{'file'}, although the second
>> solution would additionally add prefix to the shown patch body itself.
>
> Modifing the paths before generating the links is a good idea. I'll
> look, where its useful.
Please examine consequences of this, and changes in the output if you
decide to go this way (IMHO bit simpler).
--
Jakub Narebski
Poland
next prev parent reply other threads:[~2007-03-27 1:05 UTC|newest]
Thread overview: 28+ messages / expand[flat|nested] mbox.gz Atom feed top
2007-03-25 20:34 [PATCH] gitweb: show no difference message Martin Koegler
2007-03-25 20:34 ` [PATCH] gitweb: Support comparing blobs with different names Martin Koegler
2007-03-25 20:34 ` [PATCH] gitweb: link base commit (hpb) to blobdiff output Martin Koegler
2007-03-25 20:34 ` [PATCH] gitweb: support filename prefix in git_patchset_body Martin Koegler
2007-03-25 20:34 ` [PATCH] gitweb: support filename prefix in git_difftree_body Martin Koegler
2007-03-25 20:34 ` [PATCH] gitweb: Add treediff Martin Koegler
2007-03-26 17:12 ` Jakub Narebski
2007-03-26 21:05 ` Martin Koegler
2007-03-27 1:15 ` Jakub Narebski
2007-03-26 17:12 ` [PATCH] gitweb: support filename prefix in git_patchset_body Jakub Narebski
2007-03-26 20:55 ` Martin Koegler
2007-03-27 1:07 ` Jakub Narebski [this message]
2007-03-26 17:12 ` [PATCH] gitweb: Support comparing blobs (files) with different names Jakub Narebski
2007-03-26 20:41 ` Martin Koegler
2007-03-27 0:56 ` Jakub Narebski
2007-03-27 19:56 ` Martin Koegler
2007-03-27 23:58 ` Jakub Narebski
2007-03-28 21:03 ` Martin Koegler
2007-03-30 8:48 ` Jakub Narebski
2007-03-30 23:55 ` Jakub Narebski
2007-03-31 9:18 ` Martin Koegler
2007-03-31 16:16 ` Jakub Narebski
[not found] ` <7vmz1t6oe2.fsf@assigned-by-dhcp.cox.net>
2007-04-03 14:57 ` Jakub Narebski
2007-04-04 21:27 ` Jakub Narebski
2007-04-05 10:38 ` Junio C Hamano
2007-03-31 14:52 ` [PATCH] gitweb: Fix bug in "blobdiff" view for split (e.g. file to symlink) patches Jakub Narebski
2007-03-26 17:11 ` [PATCH] gitweb: show no difference message Jakub Narebski
2007-03-26 21:01 ` Jakub Narebski
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=200703270307.26589.jnareb@gmail.com \
--to=jnareb@gmail.com \
--cc=git@vger.kernel.org \
--cc=mkoegler@auto.tuwien.ac.at \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.