From: Junio C Hamano <gitster@pobox.com>
To: Kong Lucien <Lucien.Kong@ensimag.imag.fr>
Cc: git@vger.kernel.org, Matthieu.Moy@grenoble-inp.fr,
Duperray Valentin <Valentin.Duperray@ensimag.imag.fr>,
Jonas Franck <Franck.Jonas@ensimag.imag.fr>,
Nguy Thomas <Thomas.Nguy@ensimag.imag.fr>,
Nguyen Huynh Khoi Nguyen Lucien
<Huynh-Khoi-Nguyen.Nguyen@ensimag.imag.fr>
Subject: Re: [PATCHv3 1/2] wt-status.*: better advices for git status added
Date: Tue, 29 May 2012 12:22:56 -0700 [thread overview]
Message-ID: <7v4nqy4wrz.fsf@alter.siamese.dyndns.org> (raw)
In-Reply-To: <1338226598-16056-1-git-send-email-Lucien.Kong@ensimag.imag.fr> (Kong Lucien's message of "Mon, 28 May 2012 19:36:37 +0200")
Kong Lucien <Lucien.Kong@ensimag.imag.fr> writes:
> This patch provides new warning messages in the display of
> 'git status' (at the top) during conflicts, rebase, am
> and bisect process. These messages can be shortened by setting
> the new advice.* config key called advice.statushelp to false.
>
> Thus, information about the new advice.* key are added in
> Documentation/config.txt
>
> Also, the test t7060-wt-status.sh is now working with the
> new warning messages.
>
> Signed-off-by: Kong Lucien <Lucien.Kong@ensimag.imag.fr>
> Signed-off-by: Duperray Valentin <Valentin.Duperray@ensimag.imag.fr>
> Signed-off-by: Jonas Franck <Franck.Jonas@ensimag.imag.fr>
> Signed-off-by: Nguy Thomas <Thomas.Nguy@ensimag.imag.fr>
> Signed-off-by: Nguyen Huynh Khoi Nguyen Lucien <Huynh-Khoi-Nguyen.Nguyen@ensimag.imag.fr>
> ---
> The new messages are not shown when using options such as
> -s or --porcelain.It figures the current state by finding
> the files generated in .git in each case (during an am,
> a rebase, a bisect etc.). The messages about the current
> situation of the user are always displayed but the advices
> on what the user needs to do in order to resume a rebase/bisect
> /am/ commit after resolving conflicts can be hidden by setting advice.statushelp to 'false' in the config file.
Don't some of the above explanatory sentences deserve to be in the
commit log message proper, not hidden behind the three-dash lines?
> Documentation/config.txt | 4 ++
> advice.c | 2 +
> advice.h | 1 +
> t/t7060-wtstatus.sh | 2 +
> wt-status.c | 106 ++++++++++++++++++++++++++++++++++++++++++++++
> wt-status.h | 1 +
> 6 files changed, 116 insertions(+), 0 deletions(-)
>
> diff --git a/Documentation/config.txt b/Documentation/config.txt
> index 915cb5a..6504371 100644
> --- a/Documentation/config.txt
> +++ b/Documentation/config.txt
> @@ -176,6 +176,10 @@ advice.*::
> Advice shown when you used linkgit:git-checkout[1] to
> move to the detach HEAD state, to instruct how to create
> a local branch after the fact.
> + statusHelp::
> + Directions on how to end the current process shown
> + in the output of linkgit:git-status[1].
> +
> --
Have you read the existing entries in the same section you are
touching to see if the patch result as a whole makes sense and the
new entry fits well in the context?
It strikes me odd that this is not listed next to statusHints, and
it also makes me wonder if we even need to invent a new one, or it
is better to just make the output more verbose when statusHints is
not being declined.
> diff --git a/t/t7060-wtstatus.sh b/t/t7060-wtstatus.sh
> index b8cb490..d9a1e18 100755
> --- a/t/t7060-wtstatus.sh
> +++ b/t/t7060-wtstatus.sh
> @@ -30,6 +30,8 @@ test_expect_success 'Report new path with conflict' '
>
> cat >expect <<EOF
> # On branch side
> +# You have unmerged paths: fix conflicts and then commit the result.
> +#
> # Unmerged paths:
> # (use "git add/rm <file>..." as appropriate to mark resolution)
> #
> diff --git a/wt-status.c b/wt-status.c
> index dd6d8c4..093a352 100644
> --- a/wt-status.c
> +++ b/wt-status.c
> @@ -23,6 +23,7 @@ static char default_wt_status_colors[][COLOR_MAXLEN] = {
> GIT_COLOR_GREEN, /* WT_STATUS_LOCAL_BRANCH */
> GIT_COLOR_RED, /* WT_STATUS_REMOTE_BRANCH */
> GIT_COLOR_NIL, /* WT_STATUS_ONBRANCH */
> + GIT_COLOR_NORMAL, /* WT_STATUS_IN_PROGRESS */
> };
>
> static const char *color(int slot, struct wt_status *s)
> @@ -728,6 +729,109 @@ static void wt_status_print_tracking(struct wt_status *s)
> color_fprintf_ln(s->fp, color(WT_STATUS_HEADER, s), "#");
> }
>
> +static void wt_status_print_in_progress(struct wt_status *s)
> +{
> + int i;
> + const char *c = color(WT_STATUS_IN_PROGRESS, s);
> + struct stat st;
> + int merge_in_progress = 0;
> + int rebase_state = 0;
> + int rebase_interactive_state = 0;
> + int am_state = 0;
> + int am_wrong_format_state = 0;
> + int bisect_state = 0;
merge_in_progress is very descriptive, but compared to that, none of
the foo_state is.
> + int unmerged_present = 0;
> +
> + for (i = 0; i < s->change.nr; i++) {
> + struct wt_status_change_data *d;
> + d = s->change.items[i].util;
> + if (d->stagemask) {
> + unmerged_present = 1;
> + break;
> + }
> + }
> +
> + if (!stat(git_path("MERGE_HEAD"), &st))
> + merge_in_progress = 1;
> + else {
> + if (!stat(git_path("rebase-apply"), &st)) {
> + if (!stat(git_path("rebase-apply/applying"), &st))
> + am_state = 1;
> + if (!stat(git_path("rebase-apply/patch"), &st) && !(st.st_size))
> + am_wrong_format_state = 1;
Isn't nesting screwed-up around here? Your indentation suggests you
need opening "{" after "if (applying)" and closing "}" before "else"
on the next line.
> + else
> + rebase_state = 1;
> + }
> + else {
> + if (!stat(git_path("rebase-merge"), &st)) {
> + if (!stat(git_path("rebase-merge/interactive"), &st))
> + rebase_interactive_state = 1;
> + else
> + rebase_state = 1;
> + }
> + }
> + }
Whenever you write "else {" that is immediately followed by "if",
re-read what you wrote and think if you can make it "else if () {"
to reduce the indentation level. If you still need five levels of
indentation, the function you are writing is too complex and is a
sign that you can use a helper function.
In this case, I think you could structure it like this:
if (merge_head) {
merge_in_progress++;
} else if (rebase-apply) {
if (applying) {
am_in_progress++;
if (patch is empty)
...
} else {
rebase_in_progress++;
}
} else if (rebase-merge) {
if (interactive)
rebase_i_in_progress++;
else
rebase_in_progress++;
}
> + if (!stat(git_path("BISECT_LOG"), &st))
> + bisect_state = 1;
> +
> + if(merge_in_progress) {
s/if/if /; Didn't I say this already in my previous message?
> + if (unmerged_present)
> + status_printf_ln(s, c, _("You have unmerged paths: fix conflicts and then commit the result."));
> + else
> + status_printf_ln(s, c, _("You are still merging, run \"git commit\" to conclude merge."));
> + wt_status_print_trailer(s);
> + }
> + else {
> + if(am_state) {
The same comments on the "else if" cascading and on the missing SP
after keyword apply here.
> + status_printf_ln(s, c, _("You are currently in am progress:"));
-ECANTPARSE.
> + if(am_wrong_format_state)
> + status_printf_ln(s, c, _("One of the patches is empty or corrupted !"));
You never checked corrupted; you only detected an empty file.
> + if (advice_status_help) {
> + status_printf_ln(s, c, _("When you have resolved this problem run \"git am --resolved\"."));
> + status_printf_ln(s, c, _("If you would prefer to skip this patch, instead run \"git am --skip\"."));
> + status_printf_ln(s, c, _("To restore the original branch and stop patching run \"git am --abort\"."));
> + }
> + wt_status_print_trailer(s);
> + }
> +
> + else if (rebase_state || rebase_interactive_state) {
> + if (unmerged_present) {
> + status_printf_ln(s, c, _("You are currently rebasing%s"),
> + advice_status_help
> + ? _(": fix conflicts and then run \"git rebase -- continue\".") : ".");
s/-- /--/;
> + if (advice_status_help) {
> + status_printf_ln(s, c, _("If you would prefer to skip this patch, instead run \"git rebase --skip\"."));
> + status_printf_ln(s, c, _("To check out the original branch and stop rebasing run \"git rebase --abort\"."));
> + }
> + }
> + else {
> + if (rebase_state)
> + status_printf_ln(s, c, _("You are currently rebasing: all conflicts fixed%s"),
> + advice_status_help
> + ? _(": run \"git rebase --continue\".") : ".");
> + else {
> + status_printf_ln(s, c, _("You are currently editing a commit during a rebase."));
> + if (advice_status_help) {
> + status_printf_ln(s, c, _("You can amend the commit with"));
> + status_printf_ln(s, c, _(" git commit --amend"));
> + status_printf_ln(s, c, _("Once you are satisfied with your changes, run"));
> + status_printf_ln(s, c, _(" git rebase --continue"));
> + }
> + }
> + }
> + wt_status_print_trailer(s);
> + }
> + }
> +
> + if(bisect_state) {
> + status_printf_ln(s, c, _("You are currently bisecting."));
> + if (advice_status_help)
> + status_printf_ln(s, c, _("To get back to the original branch run \"git bisect reset\""));
> + wt_status_print_trailer(s);
> + }
> +}
> +
> void wt_status_print(struct wt_status *s)
> {
> const char *branch_color = color(WT_STATUS_ONBRANCH, s);
> @@ -750,6 +854,8 @@ void wt_status_print(struct wt_status *s)
> wt_status_print_tracking(s);
> }
>
> + wt_status_print_in_progress(s);
> +
> if (s->is_initial) {
> status_printf_ln(s, color(WT_STATUS_HEADER, s), "");
> status_printf_ln(s, color(WT_STATUS_HEADER, s), _("Initial commit"));
> diff --git a/wt-status.h b/wt-status.h
> index 14aa9f7..0556669 100644
> --- a/wt-status.h
> +++ b/wt-status.h
> @@ -15,6 +15,7 @@ enum color_wt_status {
> WT_STATUS_LOCAL_BRANCH,
> WT_STATUS_REMOTE_BRANCH,
> WT_STATUS_ONBRANCH,
> + WT_STATUS_IN_PROGRESS,
> WT_STATUS_MAXSLOT
> };
next prev parent reply other threads:[~2012-05-29 19:23 UTC|newest]
Thread overview: 97+ messages / expand[flat|nested] mbox.gz Atom feed top
2012-05-24 9:37 [PATCH/RFC] t7512-status-warnings.sh : better advices for git status Kong Lucien
2012-05-24 17:31 ` Matthieu Moy
2012-05-26 12:38 ` [PATCHv2 1/2] wt-status: " Kong Lucien
2012-05-26 12:38 ` [PATCHv2 2/2] t7512-status-warnings.sh: " Kong Lucien
2012-05-27 12:57 ` Matthieu Moy
2012-05-28 8:43 ` Matthieu Moy
2012-05-26 13:01 ` [PATCHv2 1/2] wt-status: " Nguyen Thai Ngoc Duy
2012-05-26 17:17 ` NGUY Thomas
2012-05-27 12:58 ` Matthieu Moy
2012-05-27 13:10 ` Matthieu Moy
2012-05-28 4:57 ` Junio C Hamano
2012-05-28 7:05 ` Matthieu Moy
2012-05-30 4:27 ` Junio C Hamano
2012-05-28 10:54 ` konglu
2012-05-28 17:36 ` [PATCHv3 1/2] wt-status.*: better advices for git status added Kong Lucien
2012-05-28 17:36 ` [PATCHv3 2/2] t7512-status-warnings.sh: better advices for git status Kong Lucien
2012-05-28 20:36 ` Matthieu Moy
2012-05-28 20:23 ` [PATCHv3 1/2] wt-status.*: better advices for git status added Matthieu Moy
2012-05-29 19:22 ` Junio C Hamano [this message]
2012-05-30 11:09 ` konglu
2012-05-30 17:24 ` Junio C Hamano
2012-05-31 6:47 ` Matthieu Moy
2012-05-30 13:23 ` [PATCHv4 1/3] " Kong Lucien
2012-05-30 13:23 ` [PATCHv4 2/3] t7512-status-warnings.sh: better advices for git status Kong Lucien
2012-05-30 13:23 ` [PATCHv4 3/3] Advices about 'git rm' during conflicts (unmerged paths) more relevant Kong Lucien
2012-05-30 18:44 ` Junio C Hamano
2012-05-30 21:50 ` konglu
2012-05-31 7:06 ` Matthieu Moy
2012-05-31 7:59 ` konglu
2012-05-30 18:26 ` [PATCHv4 1/3] wt-status.*: better advices for git status added Junio C Hamano
2012-05-30 19:06 ` Junio C Hamano
2012-05-31 6:42 ` Matthieu Moy
2012-05-31 6:44 ` Matthieu Moy
2012-05-31 6:29 ` Matthieu Moy
2012-05-31 6:34 ` Andrew Ardill
2012-05-31 15:15 ` [PATCHv5 " Kong Lucien
2012-05-31 15:15 ` [PATCHv5 2/3] t7512-status-help.sh: better advices for git status Kong Lucien
2012-05-31 15:15 ` [PATCHv5 3/3] status: don't suggest "git rm" or "git add" if not appropriate Kong Lucien
2012-06-01 8:55 ` Matthieu Moy
2012-06-01 12:15 ` Phil Hord
2012-06-01 14:08 ` konglu
2012-06-01 16:38 ` Junio C Hamano
2012-05-31 21:36 ` [PATCHv5 1/3] wt-status.*: better advices for git status added Junio C Hamano
2012-06-01 9:16 ` konglu
2012-06-01 9:26 ` Matthieu Moy
2012-06-01 14:50 ` Junio C Hamano
2012-06-01 16:51 ` Junio C Hamano
2012-06-01 19:39 ` konglu
2012-06-01 8:42 ` Matthieu Moy
2012-06-01 11:27 ` konglu
2012-06-01 12:40 ` Phil Hord
2012-06-01 16:57 ` Junio C Hamano
2012-06-04 18:00 ` Phil Hord
2012-06-03 18:30 ` [PATCHv6 1/4] " Kong Lucien
2012-06-03 18:30 ` [PATCHv6 2/4] t7512-status-help.sh: better advices for git status Kong Lucien
2012-06-03 21:18 ` Junio C Hamano
2012-06-04 10:04 ` konglu
2012-06-04 15:04 ` Junio C Hamano
2012-06-04 22:07 ` Junio C Hamano
2012-06-03 18:30 ` [PATCHv6 3/4] status: don't suggest "git rm" or "git add" if not appropriate Kong Lucien
2012-06-03 19:34 ` Matthieu Moy
2012-06-03 18:30 ` [PATCHv6 4/4] status: better advices when splitting a commit (during rebase -i) Kong Lucien
2012-06-03 22:00 ` Junio C Hamano
2012-06-04 15:35 ` Phil Hord
2012-06-05 9:13 ` konglu
2012-06-03 21:06 ` [PATCHv6 1/4] wt-status.*: better advices for git status added Junio C Hamano
2012-06-04 9:51 ` konglu
2012-06-04 14:54 ` Junio C Hamano
2012-06-04 17:19 ` [PATCHv7 " Kong Lucien
2012-06-04 17:19 ` [PATCHv7 2/4] t7512-status-help.sh: better advices for git status Kong Lucien
2012-06-04 21:02 ` Matthieu Moy
2012-06-04 23:12 ` Junio C Hamano
2012-06-04 17:19 ` [PATCHv7 3/4] status: don't suggest "git rm" or "git add" if not appropriate Kong Lucien
2012-06-04 17:19 ` [PATCHv7 4/4] status: better advices when splitting a commit (during rebase -i) Kong Lucien
2012-06-04 23:01 ` [PATCHv7 1/4] wt-status.*: better advices for git status added Junio C Hamano
2012-06-05 10:32 ` konglu
2012-06-05 11:33 ` Matthieu Moy
2012-06-05 20:21 ` [PATCHv8 " Lucien Kong
2012-06-05 20:21 ` [PATCHv8 2/4] t7512-status-help.sh: better advices for git status Lucien Kong
2012-06-05 20:21 ` [PATCHv8 3/4] status: don't suggest "git rm" or "git add" if not appropriate Lucien Kong
2012-06-05 20:21 ` [PATCHv8 4/4] status: better advices when splitting a commit (during rebase -i) Lucien Kong
2012-06-05 21:16 ` Junio C Hamano
2012-06-08 9:29 ` konglu
2012-06-08 15:05 ` Junio C Hamano
2012-06-07 13:17 ` [PATCHv9 1/4] wt-status.*: better advices for git status added Lucien Kong
2012-06-07 13:17 ` [PATCHv9 2/4] t7512-status-help.sh: better advices for git status Lucien Kong
2012-06-07 13:17 ` [PATCHv9 3/4] status: don't suggest "git rm" or "git add" if not appropriate Lucien Kong
2012-06-07 13:17 ` [PATCHv9 4/4] status: better advices when splitting a commit (during rebase -i) Lucien Kong
2012-06-07 18:07 ` Junio C Hamano
2012-06-07 20:42 ` Junio C Hamano
2012-06-07 21:05 ` konglu
2012-06-10 11:17 ` [PATCHv10 1/4] wt-status.*: better advices for git status added Lucien Kong
2012-06-10 11:17 ` [PATCHv10 2/4] t7512-status-help.sh: better advices for git status Lucien Kong
2012-06-10 11:17 ` [PATCHv10 3/4] status: don't suggest "git rm" or "git add" if not appropriate Lucien Kong
2012-06-10 11:17 ` [PATCHv10 4/4] status: better advices when splitting a commit (during rebase -i) Lucien Kong
2012-06-11 20:21 ` Junio C Hamano
2012-06-12 7:14 ` konglu
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=7v4nqy4wrz.fsf@alter.siamese.dyndns.org \
--to=gitster@pobox.com \
--cc=Franck.Jonas@ensimag.imag.fr \
--cc=Huynh-Khoi-Nguyen.Nguyen@ensimag.imag.fr \
--cc=Lucien.Kong@ensimag.imag.fr \
--cc=Matthieu.Moy@grenoble-inp.fr \
--cc=Thomas.Nguy@ensimag.imag.fr \
--cc=Valentin.Duperray@ensimag.imag.fr \
--cc=git@vger.kernel.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
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).