Mercurial > public > mercurial-scm > hg
comparison mercurial/merge.py @ 24881:51844b8b5017 stable
merge: run update hook after the last wlock release
There were 2 test failures in 3.4-rc when running test-hook.t with the
largefiles extension enabled. For context, the first is a commit hook:
@@ -618,9 +621,9 @@
$ echo 'update = hg id' >> .hg/hgrc
$ echo bb > a
$ hg ci -ma
- 223eafe2750c tip
+ d3354c4310ed+
$ hg up 0
- cb9a9f314b8b
+ 223eafe2750c+ tip
1 files updated, 0 files merged, 0 files removed, 0 files unresolved
make sure --verbose (and --quiet/--debug etc.) are propagated to the local ui
In both cases, largefiles acquires the wlock before calling into core, which
also acquires the wlock. The first case was fixed in 57f1dbc99631 by ensuring
the hook only runs after the lock has been fully released. The full release is
important, because that is what writes dirstate to the disk, allowing external
hooks to see the result of the update. This simply changes how the update hook
is called, so that it too is deferred until the lock is finally released.
There are many uses of mergemod.update(), but in terms of commands, it looks
like the following commands take wlock while calling mergemod.update(), and
therefore will now have their hook fired at a later time:
backout, fetch, histedit, qpush, rebase, shelve, transplant
Unlike the others, fetch immediately unlocks after calling update(), so for all
intents and purposes, its hook invocation is not deferred (but the external hook
still sees the proper state).
author | Matt Harbison <matt_harbison@yahoo.com> |
---|---|
date | Wed, 29 Apr 2015 15:52:31 -0400 |
parents | a8e6897dffbe |
children | 6eb4bdad198f |
comparison
equal
deleted
inserted
replaced
24880:5e111acc1170 | 24881:51844b8b5017 |
---|---|
1165 repo.dirstate.endparentchange() | 1165 repo.dirstate.endparentchange() |
1166 finally: | 1166 finally: |
1167 wlock.release() | 1167 wlock.release() |
1168 | 1168 |
1169 if not partial: | 1169 if not partial: |
1170 repo.hook('update', parent1=xp1, parent2=xp2, error=stats[3]) | 1170 def updatehook(parent1=xp1, parent2=xp2, error=stats[3]): |
1171 repo.hook('update', parent1=parent1, parent2=parent2, error=error) | |
1172 repo._afterlock(updatehook) | |
1171 return stats | 1173 return stats |
1172 | 1174 |
1173 def graft(repo, ctx, pctx, labels): | 1175 def graft(repo, ctx, pctx, labels): |
1174 """Do a graft-like merge. | 1176 """Do a graft-like merge. |
1175 | 1177 |