After some months, I just updated my local ikiwiki sources, and rebuilt the Hurd web pages, <http://git.savannah.gnu.org/cgit/hurd/web.git/>. I was confused, having switched to the new automatic (thanks!) --gettime mechanism, why on some pages the timestamps had changed compared to my previous use of --getctime and setting files' mtimes (using a script) according to the last Git commit. For example: community/weblogs/ArneBab/2008-08-02-gnu_hurd_and_x.html old: Last edited <span class="date">2008-09-11 18:11:53 UTC</span> <!-- Created <span class="date">2008-09-11 17:47:08 UTC</span> --> new: Last edited <span class="date">2008-09-11 18:12:22 UTC</span> <!-- Created <span class="date">2008-09-11 17:47:50 UTC</span> --> I had a look at what git.pm is doing, and began to manually replay / investigate: $ git log --pretty=fuller --name-only --relative -- community/weblogs/ArneBab/2008-08-02-gnu_hurd_and_x.mdwn commit 8f1b97bfe45b2f173e3a7d55dee226a9e289a695 Author: arnebab <arne_bab@web.de> AuthorDate: Thu Sep 11 20:11:53 2008 +0200 Commit: arnebab <arne_bab@web.de> CommitDate: Thu Sep 11 20:11:53 2008 +0200 Added a link to the X.org guide in this wiki. community/weblogs/ArneBab/2008-08-02-gnu_hurd_and_x.mdwn commit 3ef8b7d80d80572c436c4c60c71879bc74409816 Author: arnebab <arne_bab@web.de> AuthorDate: Thu Sep 11 19:47:08 2008 +0200 Commit: arnebab <arne_bab@web.de> CommitDate: Thu Sep 11 19:47:08 2008 +0200 Minor update on the enty trying to get X working -> 'watch this place for updates' community/weblogs/ArneBab/2008-08-02-gnu_hurd_and_x.mdwn OK, these are my old dates. $ git log --pretty=format:%ci --name-only --relative -- community/weblogs/ArneBab/2008-08-02-gnu_hurd_and_x.mdwn 2008-09-11 20:11:53 +0200 community/weblogs/ArneBab/2008-08-02-gnu_hurd_and_x.mdwn 2008-09-11 19:47:08 +0200 community/weblogs/ArneBab/2008-08-02-gnu_hurd_and_x.mdwn $ git log --pretty=format:%ct --name-only --relative -- community/weblogs/ArneBab/2008-08-02-gnu_hurd_and_x.mdwn 1221156713 community/weblogs/ArneBab/2008-08-02-gnu_hurd_and_x.mdwn 1221155228 community/weblogs/ArneBab/2008-08-02-gnu_hurd_and_x.mdwn $ date -d @1221156713 Thu Sep 11 18:11:53 UTC 2008 $ date -d @1221155228 Thu Sep 11 17:47:08 UTC 2008 That's all consistent. But: $ perl -le 'use Storable; my $index=Storable::retrieve("indexdb"); use Data::Dumper; print Dumper $index' [...] 'community/weblogs/ArneBab/2008-08-02-gnu_hurd_and_x.mdwn' => { 'ctime' => '1221155270', 'dest' => [ 'community/weblogs/ArneBab/2008-08-02-gnu_hurd_and_x.html' ], 'typedlinks' => { 'tag' => {} }, 'mtime' => 1221156742, 'depends_simple' => { 'sidebar' => 1 }, 'links' => [ 'community/weblogs/ArneBab/2008-08-02-gnu_hurd_and_x/discussion', 'Hurd/DebianXorg' ], 'state' => { [...] $ date -d @1221156742 Thu Sep 11 18:12:22 UTC 2008 $ date -d @1221155270 Thu Sep 11 17:47:50 UTC 2008 That's different, and it matches what the new ikiwiki writes into the HTML file. Back to Git again, this time without specifying the file: $ git log --pretty=format:%ct --name-only --relative [...] 1221255713 1221255655 unsorted/PortingIssues.mdwn 1221156742 [Thu Sep 11 18:12:22 UTC 2008] 1221156713 [Thu Sep 11 18:11:53 UTC 2008] community/weblogs/ArneBab/2008-08-02-gnu_hurd_and_x.mdwn 1221156267 1221156235 index.mdwn 1221156122 1221156091 index.mdwn 1221155942 1221155910 index.mdwn 1221155270 [Thu Sep 11 17:47:50 UTC 2008] 1221155228 [Thu Sep 11 17:47:08 UTC 2008] community/weblogs/ArneBab/2008-08-02-gnu_hurd_and_x.mdwn 1221154986 community/gsoc.mdwn community/gsoc/project_ideas.mdwn 1221147244 whatsnew.html [...] Aha! ... and some more detail: $ git log --pretty=fuller --name-only --relative [...] commit e4e89e1683012c879012522105a3471a00714613 Author: Samuel Thibault <samuel.thibault@ens-lyon.org> AuthorDate: Fri Sep 12 23:40:55 2008 +0200 Commit: Samuel Thibault <samuel.thibault@ens-lyon.org> CommitDate: Fri Sep 12 23:40:55 2008 +0200 MSG_NOSIGNAL and IPV6_PKTINFO got fixed unsorted/PortingIssues.mdwn commit c389fae98dff86527be62f895ff7272e4ab1932c Merge: 0339e3e 8f1b97b Author: GNU Hurd wiki engine <web-hurd@gnu.org> AuthorDate: Thu Sep 11 18:12:22 2008 +0000 Commit: GNU Hurd wiki engine <web-hurd@gnu.org> CommitDate: Thu Sep 11 18:12:22 2008 +0000 Merge branch 'master' of wiki@192.168.10.50:wiki commit 8f1b97bfe45b2f173e3a7d55dee226a9e289a695 Author: arnebab <arne_bab@web.de> AuthorDate: Thu Sep 11 20:11:53 2008 +0200 Commit: arnebab <arne_bab@web.de> CommitDate: Thu Sep 11 20:11:53 2008 +0200 Added a link to the X.org guide in this wiki. community/weblogs/ArneBab/2008-08-02-gnu_hurd_and_x.mdwn [...] So, merges are involved there. What (the new) ikiwiki code does, is use the timestamp when the merge was done instead of the timestamp when the commit was done. Is this intentional? Otherwise I could supply a patch. --[[tschwinge]] > In order to be nice and fast, the git backend runs git log once > and records data for all files. Rather than looking at the log for a > given file. So amoung other things, it does not follow renames. > > AFAICS, git log only shows merges modifying files if it was a conflicted > merge. As the file is then actually modified to resolve the merge > I think it makes sense to count the merge as the last modification in > that case. --[[Joey]] >> That'd be reasonable, but `git log` will also show merges that are not >> conflicting (as in my case). >>> Actually when displaying a merge, `git log --stat` only lists files that >>> were actually modified in a new way as part of the merge resolution. >>> Ie, if the merge resolution only joins together some of the parent >>> hunks, the file is not listed as having been modified. >>> >>> So, no, ikiwiki's use of git log will not show files modified in >>> non-conflicting merges. >>> --[[Joey]] >> Yet, I'm not totally disagreeing with your choice. With this `git >> log` invocation, you're not able to tell from its output whether a >> conflict was resolved or not. >> Also, it's a bit like the *should we use the **author timestamp** or >> **commit timestamp*** discussion. Your code will always use the >> latest timestamp. >> I guess I'll get my head wrapped around that, and it's fine, so this is >> [[done]]. >> --[[tschwinge]]