diff options
author | Jeff King <peff@peff.net> | 2018-03-30 15:26:15 -0400 |
---|---|---|
committer | Junio C Hamano <gitster@pobox.com> | 2018-03-30 12:52:46 -0700 |
commit | 05e293c1ac63295fcfe1b8fd9533fcdb012d5f03 (patch) | |
tree | a5a3f5d96b8f644f0fefc32b0e2c2c71e8aaed97 /t/t3404-rebase-interactive.sh | |
parent | Prepare for 2.15.2 (diff) | |
download | tgif-05e293c1ac63295fcfe1b8fd9533fcdb012d5f03.tar.xz |
config: move flockfile() closer to unlocked functions
Commit 260d408e32 (config: use getc_unlocked when reading
from file, 2015-04-16) taught git_config_from_file() to lock
the filehandle so that we could safely use the faster
unlocked functions to access the handle.
However, it split the logic into two places:
1. The master lock/unlock happens in git_config_from_file().
2. The decision to use the unlocked functions happens in
do_config_from_file().
That means that if anybody calls the latter function, they
will accidentally use the unlocked functions without holding
the lock. And indeed, git_config_from_stdin() does so.
In practice, this hasn't been a problem since this code
isn't generally multi-threaded (and even if some Git program
happened to have another thread running, it's unlikely to be
reading from stdin). But it's a good practice to make sure
we're always holding the lock before using the unlocked
functions.
Helped-by: Johannes Schindelin <Johannes.Schindelin@gmx.de>
Signed-off-by: Jeff King <peff@peff.net>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
Diffstat (limited to 't/t3404-rebase-interactive.sh')
0 files changed, 0 insertions, 0 deletions