Re: [PATCH] prefix_path(): Unconditionally free result of prefix_path

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



On Mon, May 4, 2015 at 8:21 PM, Jeff King <peff@xxxxxxxx> wrote:
> On Mon, May 04, 2015 at 12:11:54PM -0700, Stefan Beller wrote:
>
>> prefix_path() always returns a newly allocated string since
>> d089eba (setup: sanitize absolute and funny paths in get_pathspec(),
>> 2008-01-28)
>>
>> Additionally the const is dropped from the pointers, so the call to
>> free doesn't need a cast.
>>
>> Signed-off-by: Stefan Beller <sbeller@xxxxxxxxxx>
>> ---
>>
>> Notes:
>>     Thanks for all the suggestions!
>>     They are incorporated into this version of the patch.
>>
>>  builtin/checkout-index.c | 10 ++++------
>>  builtin/update-index.c   |  5 ++---
>>  2 files changed, 6 insertions(+), 9 deletions(-)
>
> Should we also squash in these sites? I think they are adequately
> covered under the proposed log message.

That sounds good to me.

>
> Found by grepping for prefix_path calls. The only remainders are:
>
>   1. in blame, we assign the result to a const char that may also point
>      straight into to argv, but we never actually free either way
>
>   2. test-path-utils does not free at all, but we probably don't care
>      either way
>
> diff --git a/builtin/update-index.c b/builtin/update-index.c
> index a92eed2..0665b31 100644
> --- a/builtin/update-index.c
> +++ b/builtin/update-index.c
> @@ -870,14 +870,14 @@ int cmd_update_index(int argc, const char **argv, const char *prefix)
>                 case PARSE_OPT_DONE:
>                 {
>                         const char *path = ctx.argv[0];
> -                       const char *p;
> +                       char *p;
>
>                         setup_work_tree();
>                         p = prefix_path(prefix, prefix_length, path);
>                         update_one(p);
>                         if (set_executable_bit)
>                                 chmod_path(set_executable_bit, p);
> -                       free((char *)p);
> +                       free(p);
>                         ctx.argc--;
>                         ctx.argv++;
>                         break;
> @@ -908,7 +908,7 @@ int cmd_update_index(int argc, const char **argv, const char *prefix)
>
>                 setup_work_tree();
>                 while (strbuf_getline(&buf, stdin, line_termination) != EOF) {
> -                       const char *p;
> +                       char *p;
>                         if (line_termination && buf.buf[0] == '"') {
>                                 strbuf_reset(&nbuf);
>                                 if (unquote_c_style(&nbuf, buf.buf, NULL))
> @@ -919,7 +919,7 @@ int cmd_update_index(int argc, const char **argv, const char *prefix)
>                         update_one(p);
>                         if (set_executable_bit)
>                                 chmod_path(set_executable_bit, p);
> -                       free((char *)p);
> +                       free(p);
>                 }
>                 strbuf_release(&nbuf);
>                 strbuf_release(&buf);
--
To unsubscribe from this list: send the line "unsubscribe git" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at  http://vger.kernel.org/majordomo-info.html




[Index of Archives]     [Linux Kernel Development]     [Gcc Help]     [IETF Annouce]     [DCCP]     [Netdev]     [Networking]     [Security]     [V4L]     [Bugtraq]     [Yosemite]     [MIPS Linux]     [ARM Linux]     [Linux Security]     [Linux RAID]     [Linux SCSI]     [Fedora Users]