Re: Metadata and checkin file date

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



Andreas Ericsson <ae@xxxxxx> writes:
> On 04/27/2010 09:38 PM, Gerhard Wiesinger wrote:
>> On Tue, 27 Apr 2010, Andreas Ericsson wrote:
>>> On 04/27/2010 07:23 AM, Gerhard Wiesinger wrote:
>>>>
>>>> I'm new to git and I'm looking for the following features:
>>>> 1.) Metadata for
>>>> a.) directory versioning (e.g. add/rm, mv)
>>>
>>> If you're talking about empty directories, that feature doesn't
>>> exist and I can't imagine why you'd want it to. If you'd care to
>>> explain why you want it, I'm sure we can find a different way of
>>> achieving your goal.
>> 
>> Git focuses on content but I think git should also focus on metadata. 
>> For example restructuring source code moves (git mv file1.c file2.c, git 
>> mv dir1 dir2) should be documented also in the repository like e.g. 
>> subversion and commercial SCM like clearcase do. Otherwise we are on 
>> "CVS" level.

"git mv file1.c file2.c" works in practice thanks to heuristic
similarity based rename detection that git uses.  (Note that it might
not work in simplistic tests.)

"git mv dir1 dir2" works via _file_ rename detection, except for one
use case, namely when on one branch one does "git mv dir1 dir2", 
and in other branch one does "git add dir1/file.c" (new file in old
directory name).  See also below.

>> Empty directories is a special case and sometimes you need just 
>> versioned empty directies.
> 
> This has been discussed to death several times before on this mailing
> list. Browse the archives. There haven't been any new arguments the
> last 14 times it came up, so I doubt you'll be able to come up with
> a single good reason to track file renames explicitly.

There are three issues conflated here:

1. Rename tracking.  This is no go.  The only idea that have hint of
   being perhaps possibly accepted is recording resolutions of
   tree-level conflict in git-rerere2 cache.

2. Wholesame directory rename detection.  Possible, there were even
   some proof of concept patches send to git mailing list, but it
   didn't get merged in.  Would need to be resurrected, but this is
   not easy task.

3. Support for versioning empty directories.  Possible, but it would
   require extending index (the staging area one) to be able to hold
   not only files but also directories.  Not very easy.

   Current workaround: empty .gitignore / .keepme files.

-- 
Jakub Narebski
Poland
ShadeHawk on #git
--
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

[Index of Archives]     [Linux Kernel Development]     [Gcc Help]     [IETF Annouce]     [DCCP]     [Netdev]     [Networking]     [Security]     [V4L]     [Bugtraq]     [Yosemite]     [MIPS Linux]     [ARM Linux]     [Linux Security]     [Linux RAID]     [Linux SCSI]     [Fedora Users]