* [PATCH] bugreport.c: fix a crash in `git bugreport` with `--no-suffix` option @ 2024-03-12 16:26 barroit via GitGitGadget 2024-03-13 15:59 ` Junio C Hamano 2024-03-14 4:00 ` [PATCH v2 0/2] bugreport.c: fix a crash in git bugreport with --no-suffix option barroit via GitGitGadget 0 siblings, 2 replies; 12+ messages in thread From: barroit via GitGitGadget @ 2024-03-12 16:26 UTC (permalink / raw) To: git; +Cc: barroit, Jiamu Sun From: Jiamu Sun <barroit@linux.com> executing `git bugreport --no-suffix` led to a segmentation fault due to strbuf_addftime() being called with a NULL option_suffix variable. This occurs because negating the "--[no-]suffix" option causes the parser to set option_suffix to NULL, which is not handled prior to calling strbuf_addftime(). Signed-off-by: Jiamu Sun <barroit@linux.com> --- bugreport.c: fix a crash in git bugreport with --no-suffix option executing git bugreport --no-suffix led to a segmentation fault due to strbuf_addftime() being called with a NULL option_suffix variable. This occurs because negating the "--[no-]suffix" option causes the parser to set option_suffix to NULL, which is not handled prior to calling strbuf_addftime(). Published-As: https://github.com/gitgitgadget/git/releases/tag/pr-1693%2Fbarroit%2Ffix-bugreport-v1 Fetch-It-Via: git fetch https://github.com/gitgitgadget/git pr-1693/barroit/fix-bugreport-v1 Pull-Request: https://github.com/gitgitgadget/git/pull/1693 builtin/bugreport.c | 7 +++++-- 1 file changed, 5 insertions(+), 2 deletions(-) diff --git a/builtin/bugreport.c b/builtin/bugreport.c index 3106e56a130..32281815b77 100644 --- a/builtin/bugreport.c +++ b/builtin/bugreport.c @@ -138,8 +138,11 @@ int cmd_bugreport(int argc, const char **argv, const char *prefix) strbuf_complete(&report_path, '/'); output_path_len = report_path.len; - strbuf_addstr(&report_path, "git-bugreport-"); - strbuf_addftime(&report_path, option_suffix, localtime_r(&now, &tm), 0, 0); + strbuf_addstr(&report_path, "git-bugreport"); + if (option_suffix) { + strbuf_addch(&report_path, '-'); + strbuf_addftime(&report_path, option_suffix, localtime_r(&now, &tm), 0, 0); + } strbuf_addstr(&report_path, ".txt"); switch (safe_create_leading_directories(report_path.buf)) { base-commit: 945115026aa63df4ab849ab14a04da31623abece -- gitgitgadget ^ permalink raw reply related [flat|nested] 12+ messages in thread
* Re: [PATCH] bugreport.c: fix a crash in `git bugreport` with `--no-suffix` option 2024-03-12 16:26 [PATCH] bugreport.c: fix a crash in `git bugreport` with `--no-suffix` option barroit via GitGitGadget @ 2024-03-13 15:59 ` Junio C Hamano 2024-03-13 17:42 ` Junio C Hamano 2024-03-16 1:55 ` Taylor Blau 2024-03-14 4:00 ` [PATCH v2 0/2] bugreport.c: fix a crash in git bugreport with --no-suffix option barroit via GitGitGadget 1 sibling, 2 replies; 12+ messages in thread From: Junio C Hamano @ 2024-03-13 15:59 UTC (permalink / raw) To: barroit via GitGitGadget; +Cc: git, barroit, Emily Shaffer, Taylor Blau "barroit via GitGitGadget" <gitgitgadget@gmail.com> writes: > From: Jiamu Sun <barroit@linux.com> > > executing `git bugreport --no-suffix` led to a segmentation fault > due to strbuf_addftime() being called with a NULL option_suffix > variable. This occurs because negating the "--[no-]suffix" option > causes the parser to set option_suffix to NULL, which is not > handled prior to calling strbuf_addftime(). > > Signed-off-by: Jiamu Sun <barroit@linux.com> > --- "git blame" points at 238b439d (bugreport: add tool to generate debugging info, 2020-04-16) that is the very beginning of this tool, and the bug survived 4f6460df (builtin/bugreport.c: use thread-safe localtime_r(), 2020-11-30). Apparently neither commit considered "--suffix=<string>" would invite users to say "--no-suffix" (authors of them CC'ed for their input). Perhaps we should update the documentation a bit while at it? Here is what I can find in its documentation. SYNOPSIS -------- [verse] 'git bugreport' [(-o | --output-directory) <path>] [(-s | --suffix) <format>] [--diagnose[=<mode>]] -s <format>:: --suffix <format>:: Specify an alternate suffix for the bugreport name, to create a file named 'git-bugreport-<formatted-suffix>'. This should take the form of a strftime(3) format string; the current local time will be used. The above does not say that it is possible to ask the code not to use suffix at all with "--no-suffix". If we want it to happen and behave sensibly (which I think the code with your patch does, from my cursory read), we probably should document it. At least two developers, considered to be expert Git developers and consider themselves to be expert Git users, did not even anticipate that "--no-suffix" will hit their code. Another approach (with devil's advocate hat on) is obviously to use the PARSE_OPT_NONEG bit so that people won't do what hurts them ;-), but the fix is so trivial that it may be better to formally accept "--no-suffix" in this case. An aside #leftoverbits is to find OPTION_STRING that is used without NONEG bit and make sure negating them with the "--no-" prefix will not trigger a similar issue. All uses of OPT_STRING() that use a variable that is initialized to a non-NULL string are suspect. Of course, this is #leftoverbits and must be kept outside the topic to fix this bug (i.e. this patch). > bugreport.c: fix a crash in git bugreport with --no-suffix option > > executing git bugreport --no-suffix led to a segmentation fault due to > strbuf_addftime() being called with a NULL option_suffix variable. This > occurs because negating the "--[no-]suffix" option causes the parser to > set option_suffix to NULL, which is not handled prior to calling > strbuf_addftime(). > > Published-As: https://github.com/gitgitgadget/git/releases/tag/pr-1693%2Fbarroit%2Ffix-bugreport-v1 > Fetch-It-Via: git fetch https://github.com/gitgitgadget/git pr-1693/barroit/fix-bugreport-v1 > Pull-Request: https://github.com/gitgitgadget/git/pull/1693 > > builtin/bugreport.c | 7 +++++-- > 1 file changed, 5 insertions(+), 2 deletions(-) > > diff --git a/builtin/bugreport.c b/builtin/bugreport.c > index 3106e56a130..32281815b77 100644 > --- a/builtin/bugreport.c > +++ b/builtin/bugreport.c > @@ -138,8 +138,11 @@ int cmd_bugreport(int argc, const char **argv, const char *prefix) > strbuf_complete(&report_path, '/'); > output_path_len = report_path.len; > > - strbuf_addstr(&report_path, "git-bugreport-"); > - strbuf_addftime(&report_path, option_suffix, localtime_r(&now, &tm), 0, 0); > + strbuf_addstr(&report_path, "git-bugreport"); > + if (option_suffix) { > + strbuf_addch(&report_path, '-'); > + strbuf_addftime(&report_path, option_suffix, localtime_r(&now, &tm), 0, 0); > + } > strbuf_addstr(&report_path, ".txt"); > > switch (safe_create_leading_directories(report_path.buf)) { > > base-commit: 945115026aa63df4ab849ab14a04da31623abece ^ permalink raw reply [flat|nested] 12+ messages in thread
* Re: [PATCH] bugreport.c: fix a crash in `git bugreport` with `--no-suffix` option 2024-03-13 15:59 ` Junio C Hamano @ 2024-03-13 17:42 ` Junio C Hamano 2024-03-16 1:55 ` Taylor Blau 1 sibling, 0 replies; 12+ messages in thread From: Junio C Hamano @ 2024-03-13 17:42 UTC (permalink / raw) To: barroit via GitGitGadget; +Cc: git, barroit, Emily Shaffer, Taylor Blau Junio C Hamano <gitster@pobox.com> writes: > Perhaps we should update the documentation a bit while at it? Here > is what I can find in its documentation. > ... > The above does not say that it is possible to ask the code not to > use suffix at all with "--no-suffix". If we want it to happen and > behave sensibly (which I think the code with your patch does, from > my cursory read), we probably should document it. At least two > developers, considered to be expert Git developers and consider > themselves to be expert Git users, did not even anticipate that > "--no-suffix" will hit their code. And such a documentation update may look like this. Feel free to use it in an updated version of the patch but please make sure it formats correctly (I didn't test it). Thanks. Documentation/git-bugreport.txt | 6 +++++- 1 file changed, 5 insertions(+), 1 deletion(-) diff --git c/Documentation/git-bugreport.txt w/Documentation/git-bugreport.txt index ca626f7fc6..112658b3c3 100644 --- c/Documentation/git-bugreport.txt +++ w/Documentation/git-bugreport.txt @@ -8,7 +8,8 @@ git-bugreport - Collect information for user to file a bug report SYNOPSIS -------- [verse] -'git bugreport' [(-o | --output-directory) <path>] [(-s | --suffix) <format>] +'git bugreport' [(-o | --output-directory) <path>] + [(-s | --suffix) <format> | --no-suffix] [--diagnose[=<mode>]] DESCRIPTION @@ -51,9 +52,12 @@ OPTIONS -s <format>:: --suffix <format>:: +--no-suffix:: Specify an alternate suffix for the bugreport name, to create a file named 'git-bugreport-<formatted-suffix>'. This should take the form of a strftime(3) format string; the current local time will be used. + `--no-suffix` disables the suffix and the file is just named + `git-bugreport` without any disambiguation measure. --no-diagnose:: --diagnose[=<mode>]:: ^ permalink raw reply related [flat|nested] 12+ messages in thread
* Re: [PATCH] bugreport.c: fix a crash in `git bugreport` with `--no-suffix` option 2024-03-13 15:59 ` Junio C Hamano 2024-03-13 17:42 ` Junio C Hamano @ 2024-03-16 1:55 ` Taylor Blau 1 sibling, 0 replies; 12+ messages in thread From: Taylor Blau @ 2024-03-16 1:55 UTC (permalink / raw) To: Junio C Hamano; +Cc: barroit via GitGitGadget, git, barroit, Emily Shaffer On Wed, Mar 13, 2024 at 08:59:52AM -0700, Junio C Hamano wrote: > "barroit via GitGitGadget" <gitgitgadget@gmail.com> writes: > > > From: Jiamu Sun <barroit@linux.com> > > > > executing `git bugreport --no-suffix` led to a segmentation fault > > due to strbuf_addftime() being called with a NULL option_suffix > > variable. This occurs because negating the "--[no-]suffix" option > > causes the parser to set option_suffix to NULL, which is not > > handled prior to calling strbuf_addftime(). > > > > Signed-off-by: Jiamu Sun <barroit@linux.com> > > --- > > "git blame" points at 238b439d (bugreport: add tool to generate > debugging info, 2020-04-16) that is the very beginning of this tool, > and the bug survived 4f6460df (builtin/bugreport.c: use thread-safe > localtime_r(), 2020-11-30). Apparently neither commit considered > "--suffix=<string>" would invite users to say "--no-suffix" (authors > of them CC'ed for their input). I can't speak for 238b439d, but at least in the case of 4f6460df, the conversion was purely about changing localtime() to localtime_r(), and nothing more. The commit message indicates that I was blindly grepping around for 'localtime\(_.\)\?' without looking too much at the surrounding context. Thanks, Taylor ^ permalink raw reply [flat|nested] 12+ messages in thread
* [PATCH v2 0/2] bugreport.c: fix a crash in git bugreport with --no-suffix option 2024-03-12 16:26 [PATCH] bugreport.c: fix a crash in `git bugreport` with `--no-suffix` option barroit via GitGitGadget 2024-03-13 15:59 ` Junio C Hamano @ 2024-03-14 4:00 ` barroit via GitGitGadget 2024-03-14 4:00 ` [PATCH v2 1/2] bugreport.c: fix a crash in `git bugreport` with `--no-suffix` option Jiamu Sun via GitGitGadget ` (3 more replies) 1 sibling, 4 replies; 12+ messages in thread From: barroit via GitGitGadget @ 2024-03-14 4:00 UTC (permalink / raw) To: git; +Cc: barroit executing git bugreport --no-suffix led to a segmentation fault due to strbuf_addftime() being called with a NULL option_suffix variable. This occurs because negating the "--[no-]suffix" option causes the parser to set option_suffix to NULL, which is not handled prior to calling strbuf_addftime(). Jiamu Sun (2): bugreport.c: fix a crash in `git bugreport` with `--no-suffix` option doc: update doc file and usage for git-bugreport Documentation/git-bugreport.txt | 6 +++++- builtin/bugreport.c | 10 +++++++--- 2 files changed, 12 insertions(+), 4 deletions(-) base-commit: 945115026aa63df4ab849ab14a04da31623abece Published-As: https://github.com/gitgitgadget/git/releases/tag/pr-1693%2Fbarroit%2Ffix-bugreport-v2 Fetch-It-Via: git fetch https://github.com/gitgitgadget/git pr-1693/barroit/fix-bugreport-v2 Pull-Request: https://github.com/gitgitgadget/git/pull/1693 Range-diff vs v1: 1: 9c6f3f5203a = 1: 9c6f3f5203a bugreport.c: fix a crash in `git bugreport` with `--no-suffix` option -: ----------- > 2: 868cec05ed5 doc: update doc file and usage for git-bugreport -- gitgitgadget ^ permalink raw reply [flat|nested] 12+ messages in thread
* [PATCH v2 1/2] bugreport.c: fix a crash in `git bugreport` with `--no-suffix` option 2024-03-14 4:00 ` [PATCH v2 0/2] bugreport.c: fix a crash in git bugreport with --no-suffix option barroit via GitGitGadget @ 2024-03-14 4:00 ` Jiamu Sun via GitGitGadget 2024-03-14 4:00 ` [PATCH v2 2/2] doc: update doc file and usage for git-bugreport Jiamu Sun via GitGitGadget ` (2 subsequent siblings) 3 siblings, 0 replies; 12+ messages in thread From: Jiamu Sun via GitGitGadget @ 2024-03-14 4:00 UTC (permalink / raw) To: git; +Cc: barroit, Jiamu Sun From: Jiamu Sun <barroit@linux.com> executing `git bugreport --no-suffix` led to a segmentation fault due to strbuf_addftime() being called with a NULL option_suffix variable. This occurs because negating the "--[no-]suffix" option causes the parser to set option_suffix to NULL, which is not handled prior to calling strbuf_addftime(). Signed-off-by: Jiamu Sun <barroit@linux.com> --- builtin/bugreport.c | 7 +++++-- 1 file changed, 5 insertions(+), 2 deletions(-) diff --git a/builtin/bugreport.c b/builtin/bugreport.c index 3106e56a130..32281815b77 100644 --- a/builtin/bugreport.c +++ b/builtin/bugreport.c @@ -138,8 +138,11 @@ int cmd_bugreport(int argc, const char **argv, const char *prefix) strbuf_complete(&report_path, '/'); output_path_len = report_path.len; - strbuf_addstr(&report_path, "git-bugreport-"); - strbuf_addftime(&report_path, option_suffix, localtime_r(&now, &tm), 0, 0); + strbuf_addstr(&report_path, "git-bugreport"); + if (option_suffix) { + strbuf_addch(&report_path, '-'); + strbuf_addftime(&report_path, option_suffix, localtime_r(&now, &tm), 0, 0); + } strbuf_addstr(&report_path, ".txt"); switch (safe_create_leading_directories(report_path.buf)) { -- gitgitgadget ^ permalink raw reply related [flat|nested] 12+ messages in thread
* [PATCH v2 2/2] doc: update doc file and usage for git-bugreport 2024-03-14 4:00 ` [PATCH v2 0/2] bugreport.c: fix a crash in git bugreport with --no-suffix option barroit via GitGitGadget 2024-03-14 4:00 ` [PATCH v2 1/2] bugreport.c: fix a crash in `git bugreport` with `--no-suffix` option Jiamu Sun via GitGitGadget @ 2024-03-14 4:00 ` Jiamu Sun via GitGitGadget 2024-03-14 16:27 ` [PATCH v2 0/2] bugreport.c: fix a crash in git bugreport with --no-suffix option Junio C Hamano 2024-03-14 22:34 ` [PATCH v3] bugreport.c: fix a crash in `git bugreport` with `--no-suffix` option Jiamu Sun 3 siblings, 0 replies; 12+ messages in thread From: Jiamu Sun via GitGitGadget @ 2024-03-14 4:00 UTC (permalink / raw) To: git; +Cc: barroit, Jiamu Sun From: Jiamu Sun <barroit@linux.com> Changes since v1: - Update documentation and usage string for `git bugreport` as suggested by Junio C Hamano Signed-off-by: Jiamu Sun <barroit@linux.com> --- Documentation/git-bugreport.txt | 6 +++++- builtin/bugreport.c | 3 ++- 2 files changed, 7 insertions(+), 2 deletions(-) diff --git a/Documentation/git-bugreport.txt b/Documentation/git-bugreport.txt index ca626f7fc68..112658b3c3b 100644 --- a/Documentation/git-bugreport.txt +++ b/Documentation/git-bugreport.txt @@ -8,7 +8,8 @@ git-bugreport - Collect information for user to file a bug report SYNOPSIS -------- [verse] -'git bugreport' [(-o | --output-directory) <path>] [(-s | --suffix) <format>] +'git bugreport' [(-o | --output-directory) <path>] + [(-s | --suffix) <format> | --no-suffix] [--diagnose[=<mode>]] DESCRIPTION @@ -51,9 +52,12 @@ OPTIONS -s <format>:: --suffix <format>:: +--no-suffix:: Specify an alternate suffix for the bugreport name, to create a file named 'git-bugreport-<formatted-suffix>'. This should take the form of a strftime(3) format string; the current local time will be used. + `--no-suffix` disables the suffix and the file is just named + `git-bugreport` without any disambiguation measure. --no-diagnose:: --diagnose[=<mode>]:: diff --git a/builtin/bugreport.c b/builtin/bugreport.c index 32281815b77..25f860a0d97 100644 --- a/builtin/bugreport.c +++ b/builtin/bugreport.c @@ -64,7 +64,8 @@ static void get_populated_hooks(struct strbuf *hook_info, int nongit) } static const char * const bugreport_usage[] = { - N_("git bugreport [(-o | --output-directory) <path>] [(-s | --suffix) <format>]\n" + N_("git bugreport [(-o | --output-directory) <path>]\n" + " [(-s | --suffix) <format> | --no-suffix]\n" " [--diagnose[=<mode>]]"), NULL }; -- gitgitgadget ^ permalink raw reply related [flat|nested] 12+ messages in thread
* Re: [PATCH v2 0/2] bugreport.c: fix a crash in git bugreport with --no-suffix option 2024-03-14 4:00 ` [PATCH v2 0/2] bugreport.c: fix a crash in git bugreport with --no-suffix option barroit via GitGitGadget 2024-03-14 4:00 ` [PATCH v2 1/2] bugreport.c: fix a crash in `git bugreport` with `--no-suffix` option Jiamu Sun via GitGitGadget 2024-03-14 4:00 ` [PATCH v2 2/2] doc: update doc file and usage for git-bugreport Jiamu Sun via GitGitGadget @ 2024-03-14 16:27 ` Junio C Hamano 2024-03-14 16:33 ` Junio C Hamano 2024-03-14 22:34 ` [PATCH v3] bugreport.c: fix a crash in `git bugreport` with `--no-suffix` option Jiamu Sun 3 siblings, 1 reply; 12+ messages in thread From: Junio C Hamano @ 2024-03-14 16:27 UTC (permalink / raw) To: barroit via GitGitGadget; +Cc: git, barroit "barroit via GitGitGadget" <gitgitgadget@gmail.com> writes: > executing git bugreport --no-suffix led to a segmentation fault due to > strbuf_addftime() being called with a NULL option_suffix variable. This > occurs because negating the "--[no-]suffix" option causes the parser to set > option_suffix to NULL, which is not handled prior to calling > strbuf_addftime(). > > Jiamu Sun (2): > bugreport.c: fix a crash in `git bugreport` with `--no-suffix` option > doc: update doc file and usage for git-bugreport Squash them together into a single patch. As you didn't have any meaningful log message in [2/2], unless there are other things that need to be updated and v3 is needed, I can squash them into one commit, though. Thanks for updating. ^ permalink raw reply [flat|nested] 12+ messages in thread
* Re: [PATCH v2 0/2] bugreport.c: fix a crash in git bugreport with --no-suffix option 2024-03-14 16:27 ` [PATCH v2 0/2] bugreport.c: fix a crash in git bugreport with --no-suffix option Junio C Hamano @ 2024-03-14 16:33 ` Junio C Hamano 2024-03-15 22:42 ` [PATCH v3] " Jiamu Sun 0 siblings, 1 reply; 12+ messages in thread From: Junio C Hamano @ 2024-03-14 16:33 UTC (permalink / raw) To: barroit via GitGitGadget; +Cc: git, barroit, Emily Shaffer, Taylor Blau Junio C Hamano <gitster@pobox.com> writes: > "barroit via GitGitGadget" <gitgitgadget@gmail.com> writes: > >> executing git bugreport --no-suffix led to a segmentation fault due to >> strbuf_addftime() being called with a NULL option_suffix variable. This >> occurs because negating the "--[no-]suffix" option causes the parser to set >> option_suffix to NULL, which is not handled prior to calling >> strbuf_addftime(). >> >> Jiamu Sun (2): >> bugreport.c: fix a crash in `git bugreport` with `--no-suffix` option >> doc: update doc file and usage for git-bugreport > > Squash them together into a single patch. As you didn't have any > meaningful log message in [2/2], unless there are other things that > need to be updated and v3 is needed, I can squash them into one > commit, though. > > Thanks for updating. I forgot the two I CC'ed the review thread for the previous round to ping them, so here it is. Thanks. ^ permalink raw reply [flat|nested] 12+ messages in thread
* Re: [PATCH v3] bugreport.c: fix a crash in git bugreport with --no-suffix option 2024-03-14 16:33 ` Junio C Hamano @ 2024-03-15 22:42 ` Jiamu Sun 0 siblings, 0 replies; 12+ messages in thread From: Jiamu Sun @ 2024-03-15 22:42 UTC (permalink / raw) To: gitster; +Cc: barroit, git, gitgitgadget, me, nasamuffin Jiamu Sun <barroit@linux.com> writes: > Junio C Hamano <gitster@pobox.com> writes: > > I forgot the two I CC'ed the review thread for the previous round to > ping them, so here it is. > > Thanks. I've updated patch 3; this should hopefully be fine now. Sorry for the trouble, and thanks for all your help, especially as it's my first PR. ^ permalink raw reply [flat|nested] 12+ messages in thread
* [PATCH v3] bugreport.c: fix a crash in `git bugreport` with `--no-suffix` option 2024-03-14 4:00 ` [PATCH v2 0/2] bugreport.c: fix a crash in git bugreport with --no-suffix option barroit via GitGitGadget ` (2 preceding siblings ...) 2024-03-14 16:27 ` [PATCH v2 0/2] bugreport.c: fix a crash in git bugreport with --no-suffix option Junio C Hamano @ 2024-03-14 22:34 ` Jiamu Sun 2024-03-16 1:56 ` Taylor Blau 3 siblings, 1 reply; 12+ messages in thread From: Jiamu Sun @ 2024-03-14 22:34 UTC (permalink / raw) To: git; +Cc: barroit executing `git bugreport --no-suffix` led to a segmentation fault due to strbuf_addftime() being called with a NULL option_suffix variable. This occurs because negating the "--[no-]suffix" option causes the parser to set option_suffix to NULL, which is not handled prior to calling strbuf_addftime(). By adding a NULL check, the `--no-suffix` option is now available. Using this option disables the suffix, and the file is just named `git-bugreport` without any disambiguation measure. Signed-off-by: Jiamu Sun <barroit@linux.com> --- Changes since v2: - Squashed the previous patch series into a single patch for clarity Documentation/git-bugreport.txt | 6 +++++- builtin/bugreport.c | 10 +++++++--- 2 files changed, 12 insertions(+), 4 deletions(-) diff --git a/Documentation/git-bugreport.txt b/Documentation/git-bugreport.txt index ca626f7fc6..112658b3c3 100644 --- a/Documentation/git-bugreport.txt +++ b/Documentation/git-bugreport.txt @@ -8,7 +8,8 @@ git-bugreport - Collect information for user to file a bug report SYNOPSIS -------- [verse] -'git bugreport' [(-o | --output-directory) <path>] [(-s | --suffix) <format>] +'git bugreport' [(-o | --output-directory) <path>] + [(-s | --suffix) <format> | --no-suffix] [--diagnose[=<mode>]] DESCRIPTION @@ -51,9 +52,12 @@ OPTIONS -s <format>:: --suffix <format>:: +--no-suffix:: Specify an alternate suffix for the bugreport name, to create a file named 'git-bugreport-<formatted-suffix>'. This should take the form of a strftime(3) format string; the current local time will be used. + `--no-suffix` disables the suffix and the file is just named + `git-bugreport` without any disambiguation measure. --no-diagnose:: --diagnose[=<mode>]:: diff --git a/builtin/bugreport.c b/builtin/bugreport.c index 3106e56a13..25f860a0d9 100644 --- a/builtin/bugreport.c +++ b/builtin/bugreport.c @@ -64,7 +64,8 @@ static void get_populated_hooks(struct strbuf *hook_info, int nongit) } static const char * const bugreport_usage[] = { - N_("git bugreport [(-o | --output-directory) <path>] [(-s | --suffix) <format>]\n" + N_("git bugreport [(-o | --output-directory) <path>]\n" + " [(-s | --suffix) <format> | --no-suffix]\n" " [--diagnose[=<mode>]]"), NULL }; @@ -138,8 +139,11 @@ int cmd_bugreport(int argc, const char **argv, const char *prefix) strbuf_complete(&report_path, '/'); output_path_len = report_path.len; - strbuf_addstr(&report_path, "git-bugreport-"); - strbuf_addftime(&report_path, option_suffix, localtime_r(&now, &tm), 0, 0); + strbuf_addstr(&report_path, "git-bugreport"); + if (option_suffix) { + strbuf_addch(&report_path, '-'); + strbuf_addftime(&report_path, option_suffix, localtime_r(&now, &tm), 0, 0); + } strbuf_addstr(&report_path, ".txt"); switch (safe_create_leading_directories(report_path.buf)) { -- 2.44.GIT ^ permalink raw reply related [flat|nested] 12+ messages in thread
* Re: [PATCH v3] bugreport.c: fix a crash in `git bugreport` with `--no-suffix` option 2024-03-14 22:34 ` [PATCH v3] bugreport.c: fix a crash in `git bugreport` with `--no-suffix` option Jiamu Sun @ 2024-03-16 1:56 ` Taylor Blau 0 siblings, 0 replies; 12+ messages in thread From: Taylor Blau @ 2024-03-16 1:56 UTC (permalink / raw) To: Jiamu Sun; +Cc: git, barroit On Fri, Mar 15, 2024 at 07:34:06AM +0900, Jiamu Sun wrote: > executing `git bugreport --no-suffix` led to a segmentation fault > due to strbuf_addftime() being called with a NULL option_suffix > variable. This occurs because negating the "--[no-]suffix" option > causes the parser to set option_suffix to NULL, which is not > handled prior to calling strbuf_addftime(). > > By adding a NULL check, the `--no-suffix` option is now available. > Using this option disables the suffix, and the file is just named > `git-bugreport` without any disambiguation measure. > > Signed-off-by: Jiamu Sun <barroit@linux.com> > --- Acked-by: Taylor Blau <me@ttaylorr.com> Thanks, Taylor ^ permalink raw reply [flat|nested] 12+ messages in thread
end of thread, other threads:[~2024-03-16 1:56 UTC | newest] Thread overview: 12+ messages (download: mbox.gz follow: Atom feed -- links below jump to the message on this page -- 2024-03-12 16:26 [PATCH] bugreport.c: fix a crash in `git bugreport` with `--no-suffix` option barroit via GitGitGadget 2024-03-13 15:59 ` Junio C Hamano 2024-03-13 17:42 ` Junio C Hamano 2024-03-16 1:55 ` Taylor Blau 2024-03-14 4:00 ` [PATCH v2 0/2] bugreport.c: fix a crash in git bugreport with --no-suffix option barroit via GitGitGadget 2024-03-14 4:00 ` [PATCH v2 1/2] bugreport.c: fix a crash in `git bugreport` with `--no-suffix` option Jiamu Sun via GitGitGadget 2024-03-14 4:00 ` [PATCH v2 2/2] doc: update doc file and usage for git-bugreport Jiamu Sun via GitGitGadget 2024-03-14 16:27 ` [PATCH v2 0/2] bugreport.c: fix a crash in git bugreport with --no-suffix option Junio C Hamano 2024-03-14 16:33 ` Junio C Hamano 2024-03-15 22:42 ` [PATCH v3] " Jiamu Sun 2024-03-14 22:34 ` [PATCH v3] bugreport.c: fix a crash in `git bugreport` with `--no-suffix` option Jiamu Sun 2024-03-16 1:56 ` Taylor Blau
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).