git-annex/doc/bugs/softlink_atime.mdwn

50 lines
3 KiB
Text
Raw Normal View History

2011-03-14 13:47:38 +00:00
When adding files to git annex, softlinks are created with current atime (and ctime, etc). Instead, the atime of the added file should be used and added to the meta-data, restoring it everywhere an annex is cloned to. -- RichiH
2011-03-13 20:32:12 +00:00
Optionally, editing the meta-data should change the times in all annexes.
2011-03-13 21:42:07 +00:00
> Thing is, git does not preserve file timestamps much at all.
> It's not uncommon for a `git checkout` to or `git update` to
> mess up timestamps. This is why things like metastore exist (and
> metastore should work ok with git annexed files too). Trying to
> make annexed file symlinks have better timestamp handling than regular
> files in git seems pointless. --[[Joey]]
2011-03-14 13:47:38 +00:00
> > Improving an area where git is (not yet?) good at still makes sense, imo. Photos and the like need absolute timestamps more than source code which is fine with relative timestamps (local builds & updates). Maintaining global timestamps for source code could even cause a lot of unwanted effects. As it is, this issue is the only, but a major, blocker for me before I can start adapting git-annex. As I have three different use cases for it, this is a shame. Unfortunately, I don't speak any Haskell so scratching my own itch isn't do-able (without major effort and not soon, at least). Is there a realistic chance that you will tackle this nonetheless or is this WONTFIX? -- RichiH
2011-03-14 16:17:34 +00:00
>>> Not quite WONTFIX. git-annex should at least, when adding new files,
>>> preserve their timestamp in the symlink it creates.
>>>
>>> Since it doesn't have anything to do with maintaining the symlinks
>>> during an update, or a clone, etc, maintaining the permissions of them
>>> is also out of scope, and it's best to just use metastore if you need
>>> it. Otherwise, git-annex would have to reimplement metastore, and is
>>> unlikely to do it better.
2011-03-14 17:00:38 +00:00
>>>> OK, thanks for the clarification. Would it be acceptable for you to put the timestamps into the metastore with vanilla git? If such an option existed, everyone would be able to benefit and not just me. -- RichiH
>>>>> I've now committed to git changes to make git-annex add make
>>>>> symlinks that reflect the original file's mtime. (It's not possible
>>>>> to set the ctime of a symlink; nor would you want to as messing with
>>>>> ctimes can break backup software ... and atime doesn't much matter.)
>>>>>
>>>>> So all you have to do is make the pre-commit hook call
>>>>> [metastore](http://david.hardeman.nu/software.php). The hook
>>>>> would look like this: ---[[Joey]] [[!tag done]]
#!/bin/sh
git annex pre-commit .
metastore --save
git add .metadata
2011-03-15 10:49:10 +00:00
>>>>>> Thanks a lot. Doing this in a new git-annex repo from the start should at least ensure local consistency and I assume I can simply add a post-pull hook to restore the mtimes on all all other repositories? -- RichiH
2011-03-22 21:25:29 +00:00
>>>>>>> This is even better:
#!/bin/sh
git annex pre-commit .
2011-03-22 21:25:47 +00:00
which metastore || echo "$0: metastore is not installed; exiting"; exit 99
2011-03-22 21:25:29 +00:00
metastore --save
git add .metadata
>>>>>>> -- RichiH