1
0
mirror of https://github.com/git/git.git synced 2025-04-04 22:08:48 +00:00
Jeff King 9dd330e6ca rerere: release lockfile in non-writing functions
There's a bug in builtin/am.c in which we take a lock on
MERGE_RR recursively. But rather than fix am.c, this patch
fixes the confusing interface from rerere.c that caused the
bug. Read on for the gory details.

The setup_rerere() function both reads the existing MERGE_RR
file, and takes MERGE_RR.lock. In the rerere() and
rerere_forget() functions, we end up in write_rr(), which
will then commit the lock file.

But for functions like rerere_clear() that do not write to
MERGE_RR, we expect the caller to have handled
setup_rerere(). That caller would then need to release the
lockfile, but it can't; the lock struct is local to
rerere.c.

For builtin/rerere.c, this is OK. We run a single rerere
operation and then exit immediately, which has the side
effect of rolling back the lockfile.

But in builtin/am.c, this is actively wrong. If we run "git
am -3 --skip", we call setup-rerere twice without releasing
the lock:

  1. The "--skip" causes us to call am_rerere_clear(), which
     calls setup_rerere(), but never drops the lock.

  2. We then proceed to the next patch.

  3. The "--3way" may cause us to call rerere() to handle
     conflicts in that patch, but we are already holding the
     lock. The lockfile code dies with:

     BUG: prepare_tempfile_object called for active object

We could fix this by having rerere_clear() call
rollback_lock_file(). But it feels a bit odd for it to roll
back a lockfile that it did not itself take. So let's
simplify the interface further, and handle setup_rerere in
the function itself, taking away the question from the
caller over whether they need to do so.

We can give rerere_gc() the same treatment, as well (even
though it doesn't have any callers besides builtin/rerere.c
at this point). Note that these functions don't take flags
from their callers to pass along to setup_rerere; that's OK,
because the flags would not be meaningful for what they are
doing.

Both of those functions need to hold the lock because even
though they do not write to MERGE_RR, they are still writing
and should be protected from a simultaneous "rerere" run.
But rerere_remaining(), "rerere diff", and "rerere status"
are all read-only operations. They want to setup_rerere(),
but do not care about taking the lock in the first place.
Since our update of MERGE_RR is the usual atomic rename done
by commit_lock_file, they can just do a lockless read. For
that, we teach setup_rerere a READONLY flag to avoid the
lock.

As a bonus, this pushes builtin/rerere.c's setup_rerere call
closer to the functions that use it. Which means that "git
rerere totally-bogus-command" will no longer silently
exit(0) in a repository without rerere enabled.

Signed-off-by: Jeff King <peff@peff.net>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
2015-09-01 15:52:54 -07:00
2015-08-31 15:40:24 -07:00
2015-04-18 18:35:48 -07:00
2015-08-31 15:38:52 -07:00
2014-07-28 10:14:33 -07:00
2015-05-05 21:00:23 -07:00
2015-08-03 11:01:27 -07:00
2015-08-25 14:57:08 -07:00
2015-08-25 14:57:08 -07:00
2015-08-11 13:48:15 -07:00
2015-05-05 21:00:23 -07:00
2015-08-31 15:39:08 -07:00
2015-08-03 11:01:21 -07:00
2015-08-03 11:01:21 -07:00
2015-08-03 11:01:27 -07:00
2015-08-31 15:39:08 -07:00
2015-06-03 09:38:19 -07:00
2015-05-20 10:19:12 -07:00
2014-12-22 12:27:20 -08:00
2014-12-12 14:31:42 -08:00
2015-06-29 11:39:10 -07:00
2014-03-31 15:29:27 -07:00
2015-06-25 10:47:46 -07:00
2015-08-31 15:38:52 -07:00
2015-08-28 12:32:15 -07:00
2015-05-26 13:24:46 -07:00
2015-08-19 14:48:56 -07:00
2015-08-03 11:01:18 -07:00
2015-06-29 11:39:10 -07:00
2014-10-29 10:09:35 -07:00
2015-02-26 20:19:21 +00:00
2015-08-28 11:19:57 -07:00
2014-09-29 12:36:11 -07:00
2014-07-07 13:56:38 -07:00
2014-07-07 13:56:38 -07:00
2015-06-24 12:21:47 -07:00
2015-03-13 22:43:11 -07:00
2015-03-27 13:02:32 -07:00
2015-08-25 14:57:09 -07:00
2015-08-03 11:01:27 -07:00
2014-10-20 12:23:48 -07:00
2015-08-31 15:38:52 -07:00
2015-03-23 11:12:58 -07:00
2014-10-19 15:28:30 -07:00
2014-07-21 12:35:39 -07:00
2014-03-31 15:29:27 -07:00
2015-08-25 14:57:09 -07:00
2014-10-10 16:02:26 -07:00
2015-08-25 14:57:09 -07:00
2015-08-25 14:57:08 -07:00
2015-08-19 14:48:13 -07:00
2015-06-05 12:17:37 -07:00
2015-05-22 09:33:08 -07:00
2015-08-12 14:09:53 -07:00
2015-08-25 14:57:08 -07:00
2015-08-25 14:57:09 -07:00
2014-06-13 11:49:40 -07:00
2015-08-03 11:01:27 -07:00
2014-12-22 12:27:30 -08:00
2014-12-22 12:27:30 -08:00
2015-08-31 15:39:03 -07:00
2014-03-31 15:29:27 -07:00
2014-09-02 13:28:44 -07:00
2015-08-19 14:48:56 -07:00
2015-06-05 12:17:37 -07:00
2015-08-11 14:29:36 -07:00

////////////////////////////////////////////////////////////////

	Git - the stupid content tracker

////////////////////////////////////////////////////////////////

"git" can mean anything, depending on your mood.

 - random three-letter combination that is pronounceable, and not
   actually used by any common UNIX command.  The fact that it is a
   mispronunciation of "get" may or may not be relevant.
 - stupid. contemptible and despicable. simple. Take your pick from the
   dictionary of slang.
 - "global information tracker": you're in a good mood, and it actually
   works for you. Angels sing, and a light suddenly fills the room.
 - "goddamn idiotic truckload of sh*t": when it breaks

Git is a fast, scalable, distributed revision control system with an
unusually rich command set that provides both high-level operations
and full access to internals.

Git is an Open Source project covered by the GNU General Public
License version 2 (some parts of it are under different licenses,
compatible with the GPLv2). It was originally written by Linus
Torvalds with help of a group of hackers around the net.

Please read the file INSTALL for installation instructions.

See Documentation/gittutorial.txt to get started, then see
Documentation/giteveryday.txt for a useful minimum set of commands, and
Documentation/git-commandname.txt for documentation of each command.
If git has been correctly installed, then the tutorial can also be
read with "man gittutorial" or "git help tutorial", and the
documentation of each command with "man git-commandname" or "git help
commandname".

CVS users may also want to read Documentation/gitcvs-migration.txt
("man gitcvs-migration" or "git help cvs-migration" if git is
installed).

Many Git online resources are accessible from http://git-scm.com/
including full documentation and Git related tools.

The user discussion and development of Git take place on the Git
mailing list -- everyone is welcome to post bug reports, feature
requests, comments and patches to git@vger.kernel.org (read
Documentation/SubmittingPatches for instructions on patch submission).
To subscribe to the list, send an email with just "subscribe git" in
the body to majordomo@vger.kernel.org. The mailing list archives are
available at http://news.gmane.org/gmane.comp.version-control.git/,
http://marc.info/?l=git and other archival sites.

The maintainer frequently sends the "What's cooking" reports that
list the current status of various development topics to the mailing
list.  The discussion following them give a good reference for
project status, development direction and remaining tasks.
Description
Git Source Code Mirror - This is a publish-only repository but pull requests can be turned into patches to the mailing list via GitGitGadget (https://gitgitgadget.github.io/). Please follow Documentation/SubmittingPatches procedure for any of your improvements.
Readme 809 MiB
Languages
C 50.1%
Shell 38.4%
Perl 5.1%
Tcl 3.2%
Python 0.8%
Other 2.1%