git.vger.kernel.org archive mirror
 help / color / mirror / Atom feed
* [RFD PATCH] git-fetch--tool and "insanely" long actions
@ 2007-04-20  1:05 A Large Angry SCM
  2007-04-20  1:34 ` Julian Phillips
  0 siblings, 1 reply; 4+ messages in thread
From: A Large Angry SCM @ 2007-04-20  1:05 UTC (permalink / raw)
  To: git

This fixes a problem my repository mirroring script has been having since
the git-fetch--tool was added to master in the middle of March. However,
it is not a proper fix since it causes actual errors from snprintf() to be
ignored. A proper fix is complicated by the lack of a consistent indicator
that the buffer is too small across snprintf() implementations.


 builtin-fetch--tool.c |    2 +-
 1 files changed, 1 insertions(+), 1 deletions(-)

diff --git a/builtin-fetch--tool.c b/builtin-fetch--tool.c
index e9d6764..173dd4f 100644
--- a/builtin-fetch--tool.c
+++ b/builtin-fetch--tool.c
@@ -44,7 +44,7 @@ static int update_ref(const char *action,
 		rla = "(reflog update)";
 	len = snprintf(msg, sizeof(msg), "%s: %s", rla, action);
 	if (sizeof(msg) <= len)
-		die("insanely long action");
+		msg[sizeof(msg)-1] = '\0';
 	lock = lock_any_ref_for_update(refname, oldval);
 	if (!lock)
 		return 1;

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

* Re: [RFD PATCH] git-fetch--tool and "insanely" long actions
  2007-04-20  1:05 [RFD PATCH] git-fetch--tool and "insanely" long actions A Large Angry SCM
@ 2007-04-20  1:34 ` Julian Phillips
  2007-04-20  1:53   ` A Large Angry SCM
  0 siblings, 1 reply; 4+ messages in thread
From: Julian Phillips @ 2007-04-20  1:34 UTC (permalink / raw)
  To: A Large Angry SCM; +Cc: git

On Thu, 19 Apr 2007, A Large Angry SCM wrote:

> This fixes a problem my repository mirroring script has been having since
> the git-fetch--tool was added to master in the middle of March. However,
> it is not a proper fix since it causes actual errors from snprintf() to be
> ignored. A proper fix is complicated by the lack of a consistent indicator
> that the buffer is too small across snprintf() implementations.
.
.
.
>       if (sizeof(msg) <= len)
> -             die("insanely long action");
> +             msg[sizeof(msg)-1] = '\0';

Or you could just let the whole thing through?

diff --git a/builtin-fetch--tool.c b/builtin-fetch--tool.c
index e9d6764..9b5ae9f 100644
--- a/builtin-fetch--tool.c
+++ b/builtin-fetch--tool.c
@@ -36,21 +36,26 @@ static int update_ref(const char *action,
 		      unsigned char *oldval)
 {
 	int len;
-	char msg[1024];
+	char buffer[1024];
+	int ret = 0;
+	char *msg = buffer;
 	char *rla = getenv("GIT_REFLOG_ACTION");
 	static struct ref_lock *lock;
 
 	if (!rla)
 		rla = "(reflog update)";
-	len = snprintf(msg, sizeof(msg), "%s: %s", rla, action);
-	if (sizeof(msg) <= len)
-		die("insanely long action");
+	len = strlen(rla) + strlen(action) + 3;
+	if (len > sizeof(buffer))
+		msg = xmalloc(len);
+	snprintf(msg, len, "%s: %s", rla, action);
 	lock = lock_any_ref_for_update(refname, oldval);
 	if (!lock)
-		return 1;
+		ret = 1;
 	if (write_ref_sha1(lock, sha1, msg) < 0)
-		return 1;
-	return 0;
+		ret = 1;
+	if (msg != buffer)
+		free(msg);
+	return ret;
 }
 
 static int update_local_ref(const char *name,
-- 
1.5.1.1

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

* Re: [RFD PATCH] git-fetch--tool and "insanely" long actions
  2007-04-20  1:34 ` Julian Phillips
@ 2007-04-20  1:53   ` A Large Angry SCM
  2007-04-20  7:40     ` Julian Phillips
  0 siblings, 1 reply; 4+ messages in thread
From: A Large Angry SCM @ 2007-04-20  1:53 UTC (permalink / raw)
  To: Julian Phillips; +Cc: git

Julian Phillips wrote:
> On Thu, 19 Apr 2007, A Large Angry SCM wrote:
> 
>> This fixes a problem my repository mirroring script has been having since
>> the git-fetch--tool was added to master in the middle of March. However,
>> it is not a proper fix since it causes actual errors from snprintf() to be
>> ignored. A proper fix is complicated by the lack of a consistent indicator
>> that the buffer is too small across snprintf() implementations.
> .
> .
> .
>>       if (sizeof(msg) <= len)
>> -             die("insanely long action");
>> +             msg[sizeof(msg)-1] = '\0';
> 
> Or you could just let the whole thing through?
> 
> diff --git a/builtin-fetch--tool.c b/builtin-fetch--tool.c
> index e9d6764..9b5ae9f 100644
> --- a/builtin-fetch--tool.c
> +++ b/builtin-fetch--tool.c
> @@ -36,21 +36,26 @@ static int update_ref(const char *action,
>  		      unsigned char *oldval)
>  {
>  	int len;
> -	char msg[1024];
> +	char buffer[1024];
> +	int ret = 0;
> +	char *msg = buffer;
>  	char *rla = getenv("GIT_REFLOG_ACTION");
>  	static struct ref_lock *lock;
>  
>  	if (!rla)
>  		rla = "(reflog update)";
> -	len = snprintf(msg, sizeof(msg), "%s: %s", rla, action);
> -	if (sizeof(msg) <= len)
> -		die("insanely long action");
> +	len = strlen(rla) + strlen(action) + 3;
> +	if (len > sizeof(buffer))
> +		msg = xmalloc(len);
> +	snprintf(msg, len, "%s: %s", rla, action);
>  	lock = lock_any_ref_for_update(refname, oldval);
>  	if (!lock)
> -		return 1;
> +		ret = 1;
>  	if (write_ref_sha1(lock, sha1, msg) < 0)
> -		return 1;
> -	return 0;
> +		ret = 1;
> +	if (msg != buffer)
> +		free(msg);
> +	return ret;
>  }
>  
>  static int update_local_ref(const char *name,


See the last sentence in my original message. Yours also ignores errors 
from snprintf().

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

* Re: [RFD PATCH] git-fetch--tool and "insanely" long actions
  2007-04-20  1:53   ` A Large Angry SCM
@ 2007-04-20  7:40     ` Julian Phillips
  0 siblings, 0 replies; 4+ messages in thread
From: Julian Phillips @ 2007-04-20  7:40 UTC (permalink / raw)
  To: A Large Angry SCM; +Cc: git

On Thu, 19 Apr 2007, A Large Angry SCM wrote:

> Julian Phillips wrote:
>>  On Thu, 19 Apr 2007, A Large Angry SCM wrote:
>> 
>> >  This fixes a problem my repository mirroring script has been having 
>> >  since
>> >  the git-fetch--tool was added to master in the middle of March. However,
>> >  it is not a proper fix since it causes actual errors from snprintf() to 
>> >  be
>> >  ignored. A proper fix is complicated by the lack of a consistent 
>> >  indicator
>> >  that the buffer is too small across snprintf() implementations.

>
> See the last sentence in my original message. Yours also ignores errors from 
> snprintf().
>

Well your last sentence was about the buffer being too small.  The change 
I made means it won't ever be too small.  True that it doesn't check for 
other errors.

-- 
Julian

  ---
You will be successful in your work.

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

end of thread, other threads:[~2007-04-20  7:40 UTC | newest]

Thread overview: 4+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2007-04-20  1:05 [RFD PATCH] git-fetch--tool and "insanely" long actions A Large Angry SCM
2007-04-20  1:34 ` Julian Phillips
2007-04-20  1:53   ` A Large Angry SCM
2007-04-20  7:40     ` Julian Phillips

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