Re: [PATCH v2 4/5] replace snprintf with odb_pack_name()

2017-03-16 Thread Junio C Hamano
Jeff King  writes:

>> so that we can always use name.buf without having to do "?:" thing.
>
> See the next patch. :)

Nice ;-)  Thanks, queued the whole thing.


Re: [PATCH v2 4/5] replace snprintf with odb_pack_name()

2017-03-16 Thread Jeff King
On Thu, Mar 16, 2017 at 11:33:36AM -0700, Junio C Hamano wrote:

> Jeff King  writes:
> 
> > +   struct strbuf name = STRBUF_INIT;
> > int err;
> >  
> > if (!from_stdin) {
> > @@ -1402,14 +1402,13 @@ static void final(const char *final_pack_name, 
> > const char *curr_pack_name,
> > int keep_fd, keep_msg_len = strlen(keep_msg);
> >  
> > if (!keep_name)
> > -   snprintf(name, sizeof(name), "%s/pack/pack-%s.keep",
> > -get_object_directory(), sha1_to_hex(sha1));
> > +   odb_pack_name(&name, sha1, "keep");
> >  
> > -   keep_fd = odb_pack_keep(keep_name ? keep_name : name);
> > +   keep_fd = odb_pack_keep(keep_name ? keep_name : name.buf);
> > if (keep_fd < 0) {
> > if (errno != EEXIST)
> > die_errno(_("cannot write keep file '%s'"),
> > - keep_name ? keep_name : name);
> > + keep_name ? keep_name : name.buf);
> > } else {
> > if (keep_msg_len > 0) {
> > write_or_die(keep_fd, keep_msg, keep_msg_len);
> > @@ -1417,28 +1416,22 @@ static void final(const char *final_pack_name, 
> > const char *curr_pack_name,
> > }
> > if (close(keep_fd) != 0)
> > die_errno(_("cannot close written keep file 
> > '%s'"),
> > - keep_name ? keep_name : name);
> > + keep_name ? keep_name : name.buf);
> > report = "keep";
> > }
> > }
> 
> 
> The patch as-posted is obviously with less damage to the current
> code, but the above makes me wonder if it makes simpler to do
> 
>   if (keep_name)
>   strbuf_addstr(&name, keep_name);
>   else
>   odb_pack_name(&name, sha1, "keep");
> 
> so that we can always use name.buf without having to do "?:" thing.

See the next patch. :)

-Peff


Re: [PATCH v2 4/5] replace snprintf with odb_pack_name()

2017-03-16 Thread Junio C Hamano
Jeff King  writes:

> + struct strbuf name = STRBUF_INIT;
>   int err;
>  
>   if (!from_stdin) {
> @@ -1402,14 +1402,13 @@ static void final(const char *final_pack_name, const 
> char *curr_pack_name,
>   int keep_fd, keep_msg_len = strlen(keep_msg);
>  
>   if (!keep_name)
> - snprintf(name, sizeof(name), "%s/pack/pack-%s.keep",
> -  get_object_directory(), sha1_to_hex(sha1));
> + odb_pack_name(&name, sha1, "keep");
>  
> - keep_fd = odb_pack_keep(keep_name ? keep_name : name);
> + keep_fd = odb_pack_keep(keep_name ? keep_name : name.buf);
>   if (keep_fd < 0) {
>   if (errno != EEXIST)
>   die_errno(_("cannot write keep file '%s'"),
> -   keep_name ? keep_name : name);
> +   keep_name ? keep_name : name.buf);
>   } else {
>   if (keep_msg_len > 0) {
>   write_or_die(keep_fd, keep_msg, keep_msg_len);
> @@ -1417,28 +1416,22 @@ static void final(const char *final_pack_name, const 
> char *curr_pack_name,
>   }
>   if (close(keep_fd) != 0)
>   die_errno(_("cannot close written keep file 
> '%s'"),
> -   keep_name ? keep_name : name);
> +   keep_name ? keep_name : name.buf);
>   report = "keep";
>   }
>   }


The patch as-posted is obviously with less damage to the current
code, but the above makes me wonder if it makes simpler to do

if (keep_name)
strbuf_addstr(&name, keep_name);
else
odb_pack_name(&name, sha1, "keep");

so that we can always use name.buf without having to do "?:" thing.


Re: [PATCH v2 4/5] replace snprintf with odb_pack_name()

2017-03-16 Thread Ramsay Jones


On 16/03/17 14:27, Jeff King wrote:
> In several places we write the name of the pack filename
> into a fixed-size buffer using snprintf(), but do not check
> the return value.  As a result, a very long object directory
> could cause us to quietly truncate the pack filename
> (potentially leading to a corrupted repository, as a newly
> written packfile could be missing its .pack extension).
> 
> We can use odb_pack_name() to do this with a strbuf (and
> shorten the code, as well).
> 
> Signed-off-by: Jeff King 
> ---
>  builtin/index-pack.c | 27 +++
>  fast-import.c| 28 +---
>  2 files changed, 24 insertions(+), 31 deletions(-)
> 
[snip]

> diff --git a/fast-import.c b/fast-import.c
> index dad697653..41a539f97 100644
> --- a/fast-import.c
> +++ b/fast-import.c
> @@ -940,43 +940,40 @@ static const char *create_index(void)
>  
>  static char *keep_pack(const char *curr_index_name)
>  {
> - static char name[PATH_MAX];
>   static const char *keep_msg = "fast-import";
> + struct strbuf name = STRBUF_INIT;
>   int keep_fd;
>  
> - snprintf(name, sizeof(name), "%s/pack/pack-%s.keep",
> -  get_object_directory(), sha1_to_hex(pack_data->sha1));
> - keep_fd = odb_pack_keep(name);
> + odb_pack_name(&name, pack_data->sha1, "keep");
> + keep_fd = odb_pack_keep(name.buf);
>   if (keep_fd < 0)
>   die_errno("cannot create keep file");
>   write_or_die(keep_fd, keep_msg, strlen(keep_msg));
>   if (close(keep_fd))
>   die_errno("failed to write keep file");
>  
> - snprintf(name, sizeof(name), "%s/pack/pack-%s.pack",
> -  get_object_directory(), sha1_to_hex(pack_data->sha1));
> - if (finalize_object_file(pack_data->pack_name, name))
> + odb_pack_name(&name, pack_data->sha1, "pack");
> + if (finalize_object_file(pack_data->pack_name, name.buf))
>   die("cannot store pack file");
>  
> - snprintf(name, sizeof(name), "%s/pack/pack-%s.idx",
> -  get_object_directory(), sha1_to_hex(pack_data->sha1));
> - if (finalize_object_file(curr_index_name, name))
> + odb_pack_name(&name, pack_data->sha1, "idx");
> + if (finalize_object_file(curr_index_name, name.buf))
>   die("cannot store index file");
>   free((void *)curr_index_name);
> - return name;
> + return strbuf_detach(&name, NULL);

Hmm, who deletes this, ...

>  }
>  
>  static void unkeep_all_packs(void)
>  {
> - static char name[PATH_MAX];
> + struct strbuf name = STRBUF_INIT;
>   int k;
>  
>   for (k = 0; k < pack_id; k++) {
>   struct packed_git *p = all_packs[k];
> - snprintf(name, sizeof(name), "%s/pack/pack-%s.keep",
> -  get_object_directory(), sha1_to_hex(p->sha1));
> - unlink_or_warn(name);
> + odb_pack_name(&name, p->sha1, "keep");
> + unlink_or_warn(name.buf);
>   }
> + strbuf_release(&name);
>  }
>  
>  static int loosen_small_pack(const struct packed_git *p)
> @@ -1035,6 +1032,7 @@ static void end_packfile(void)
>   die("core git rejected index %s", idx_name);
>   all_packs[pack_id] = new_p;
>   install_packed_git(new_p);
> + free(idx_name);

Ah, OK. Yep, no leaks here. ;-)

>  
>   /* Print the boundary */
>   if (pack_edges) {
> 

ATB,
Ramsay Jones