git.vger.kernel.org archive mirror
 help / color / mirror / Atom feed
* [PATCH next] fast-import: revert die_nicely() to vsnprintf
@ 2010-06-10 19:55 Thomas Rast
  2010-06-11 13:18 ` Erik Faye-Lund
  0 siblings, 1 reply; 3+ messages in thread
From: Thomas Rast @ 2010-06-10 19:55 UTC (permalink / raw)
  To: Junio C Hamano; +Cc: git, Johannes Sixt

ebaa79f (Make report() from usage.c public as vreportf() and use it.,
2010-03-06) changed fast-import's die_nicely() to use vreportf().

This requires some more care though.  First it forgot that we also
need to reformat the message for the crash report.  Second, vreportf()
uses vsnprintf(), which does not call va_end().  This leaves the
va_list passed to it in an undefined state.  Therefore we need to make
a copy of this va_list so that we can reuse it.

Signed-off-by: Thomas Rast <trast@student.ethz.ch>
---

Another valgrind catch.  I think that'll be the last one for today.
Thanks for your attention.


 fast-import.c |    4 +++-
 1 files changed, 3 insertions(+), 1 deletions(-)

diff --git a/fast-import.c b/fast-import.c
index c0728c2..1fa5de4 100644
--- a/fast-import.c
+++ b/fast-import.c
@@ -483,12 +483,14 @@ static void dump_marks(void);
 static NORETURN void die_nicely(const char *err, va_list params)
 {
 	static int zombie;
+	va_list saved_params;
+	va_copy(saved_params, params);
 
 	vreportf("fatal: ", err, params);
 
 	if (!zombie) {
 		char message[2 * PATH_MAX];
-
+		vsnprintf(message, sizeof(message), err, saved_params);
 		zombie = 1;
 		write_crash_report(message);
 		end_packfile();
-- 
1.7.1.561.g94582

^ permalink raw reply related	[flat|nested] 3+ messages in thread

end of thread, other threads:[~2010-06-11 15:03 UTC | newest]

Thread overview: 3+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2010-06-10 19:55 [PATCH next] fast-import: revert die_nicely() to vsnprintf Thomas Rast
2010-06-11 13:18 ` Erik Faye-Lund
2010-06-11 15:02   ` [PATCH v2] fast-import: die_nicely() back to vsnprintf (reverts part of ebaa79f) Thomas Rast

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).