git.vger.kernel.org archive mirror
 help / color / mirror / Atom feed
From: Jeff King <peff@peff.net>
To: Junio C Hamano <gitster@pobox.com>
Cc: git@vger.kernel.org
Subject: [PATCH 3/8] config: teach git_config_set_multivar_in_file a default path
Date: Thu, 16 Feb 2012 03:04:05 -0500	[thread overview]
Message-ID: <20120216080405.GC11843@sigill.intra.peff.net> (raw)
In-Reply-To: <20120216080102.GA11793@sigill.intra.peff.net>

The git_config_set_multivar_in_file function takes a
filename argument to specify the file into which the values
should be written. Currently, this value must be non-NULL.
Callers which want to write to the default location must use
the regular, non-"in_file" version, which will either write
to config_exclusive_filename, or to the repo config if the
exclusive filename is NULL.

Let's migrate the "default to using repo config" logic into
the "in_file" form. That will let callers get the same
default-if-NULL behavior as one gets with
config_exclusive_filename, but without having to use the
global variable.

Signed-off-by: Jeff King <peff@peff.net>
---
 config.c |   20 +++++++-------------
 1 file changed, 7 insertions(+), 13 deletions(-)

diff --git a/config.c b/config.c
index e3fcf75..a9eec58 100644
--- a/config.c
+++ b/config.c
@@ -1300,6 +1300,7 @@ int git_config_set_multivar_in_file(const char *config_filename,
 	int fd = -1, in_fd;
 	int ret;
 	struct lock_file *lock = NULL;
+	char *filename_buf = NULL;
 
 	/* parse-key returns negative; flip the sign to feed exit(3) */
 	ret = 0 - git_config_parse_key(key, &store.key, &store.baselen);
@@ -1308,6 +1309,8 @@ int git_config_set_multivar_in_file(const char *config_filename,
 
 	store.multi_replace = multi_replace;
 
+	if (!config_filename)
+		config_filename = filename_buf = git_pathdup("config");
 
 	/*
 	 * The lock serves a purpose in addition to locking: the new
@@ -1477,6 +1480,7 @@ int git_config_set_multivar_in_file(const char *config_filename,
 out_free:
 	if (lock)
 		rollback_lock_file(lock);
+	free(filename_buf);
 	return ret;
 
 write_err_out:
@@ -1488,19 +1492,9 @@ write_err_out:
 int git_config_set_multivar(const char *key, const char *value,
 			const char *value_regex, int multi_replace)
 {
-	const char *config_filename;
-	char *buf = NULL;
-	int ret;
-
-	if (config_exclusive_filename)
-		config_filename = config_exclusive_filename;
-	else
-		config_filename = buf = git_pathdup("config");
-
-	ret = git_config_set_multivar_in_file(config_filename, key, value,
-					value_regex, multi_replace);
-	free(buf);
-	return ret;
+	return git_config_set_multivar_in_file(config_exclusive_filename,
+					       key, value, value_regex,
+					       multi_replace);
 }
 
 static int section_name_match (const char *buf, const char *name)
-- 
1.7.9.1.4.g8ffed

  parent reply	other threads:[~2012-02-16  8:04 UTC|newest]

Thread overview: 23+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2012-02-13 20:42 What's cooking in git.git (Feb 2012, #05; Mon, 13) Junio C Hamano
2012-02-14  7:22 ` An incremental update to "What's cooking" Junio C Hamano
2012-02-14 21:47 ` What's cooking in git.git (Feb 2012, #05; Mon, 13) Jeff King
2012-02-14 22:05   ` Junio C Hamano
2012-02-14 22:09     ` Jeff King
2012-02-16  8:01       ` [PATCH 0/8] config-include fixes Jeff King
2012-02-16  8:02         ` [PATCH 1/8] t1300: add missing &&-chaining Jeff King
2012-02-16  8:03         ` [PATCH 2/8] config: copy the return value of prefix_filename Jeff King
2012-02-16  8:04         ` Jeff King [this message]
2012-02-16  8:04         ` [PATCH 4/8] config: teach git_config_rename_section a file argument Jeff King
2012-02-16  8:05         ` [PATCH 5/8] config: provide a version of git_config with more options Jeff King
2012-02-16  8:07         ` [PATCH 6/8] config: stop using config_exclusive_filename Jeff King
2012-02-16  8:09         ` [PATCH 7/8] config: eliminate config_exclusive_filename Jeff King
2012-02-16  8:10         ` [PATCH 8/8] config: do not respect includes for single-file --list Jeff King
2012-02-16 20:11         ` [PATCH 0/8] config-include fixes Junio C Hamano
2012-02-17  0:14           ` Jeff King
2012-02-17  2:50             ` Junio C Hamano
2012-02-17  3:17               ` Jeff King
2012-02-17  3:23                 ` Jeff King
2012-02-17  8:17                   ` [PATCH 0/2] api-config documentation leftovers Jeff King
2012-02-17 17:04                     ` Junio C Hamano
2012-02-17  8:18                   ` [PATCH 1/2] docs/api-config: minor clarifications Jeff King
2012-02-17  8:18                   ` [PATCH 2/2] docs/api-config: describe git_config_with_options Jeff King

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=20120216080405.GC11843@sigill.intra.peff.net \
    --to=peff@peff.net \
    --cc=git@vger.kernel.org \
    --cc=gitster@pobox.com \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).