Skip to content

Commit 4d93984

Browse files
authored
Added auto-save whitespace behavior if it changed manually (#15566)
1 parent 60f2033 commit 4d93984

File tree

4 files changed

+33
-9
lines changed

4 files changed

+33
-9
lines changed

models/user/setting_keys.go

Lines changed: 3 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -5,6 +5,8 @@
55
package user
66

77
const (
8-
// SettingsKeyHiddenCommentTypes is the settings key for hidden comment types
8+
// SettingsKeyHiddenCommentTypes is the setting key for hidden comment types
99
SettingsKeyHiddenCommentTypes = "issue.hidden_comment_types"
10+
// SettingsKeyDiffWhitespaceBehavior is the setting key for whitespace behavior of diff
11+
SettingsKeyDiffWhitespaceBehavior = "diff.whitespace_behaviour"
1012
)

routers/web/repo/middlewares.go

Lines changed: 21 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -63,11 +63,29 @@ func SetDiffViewStyle(ctx *context.Context) {
6363

6464
// SetWhitespaceBehavior set whitespace behavior as render variable
6565
func SetWhitespaceBehavior(ctx *context.Context) {
66+
const defaultWhitespaceBehavior = "show-all"
6667
whitespaceBehavior := ctx.FormString("whitespace")
6768
switch whitespaceBehavior {
68-
case "ignore-all", "ignore-eol", "ignore-change":
69-
ctx.Data["WhitespaceBehavior"] = whitespaceBehavior
69+
case "", "ignore-all", "ignore-eol", "ignore-change":
70+
break
7071
default:
71-
ctx.Data["WhitespaceBehavior"] = ""
72+
whitespaceBehavior = defaultWhitespaceBehavior
73+
}
74+
if ctx.IsSigned {
75+
userWhitespaceBehavior, err := user_model.GetUserSetting(ctx.User.ID, user_model.SettingsKeyDiffWhitespaceBehavior, defaultWhitespaceBehavior)
76+
if err == nil {
77+
if whitespaceBehavior == "" {
78+
whitespaceBehavior = userWhitespaceBehavior
79+
} else if whitespaceBehavior != userWhitespaceBehavior {
80+
_ = user_model.SetUserSetting(ctx.User.ID, user_model.SettingsKeyDiffWhitespaceBehavior, whitespaceBehavior)
81+
}
82+
} // else: we can ignore the error safely
83+
}
84+
85+
// these behaviors are for gitdiff.GetWhitespaceFlag
86+
if whitespaceBehavior == "" {
87+
ctx.Data["WhitespaceBehavior"] = defaultWhitespaceBehavior
88+
} else {
89+
ctx.Data["WhitespaceBehavior"] = whitespaceBehavior
7290
}
7391
}

services/gitdiff/gitdiff.go

Lines changed: 7 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -1532,13 +1532,17 @@ func CommentMustAsDiff(c *models.Comment) *Diff {
15321532
}
15331533

15341534
// GetWhitespaceFlag returns git diff flag for treating whitespaces
1535-
func GetWhitespaceFlag(whiteSpaceBehavior string) string {
1535+
func GetWhitespaceFlag(whitespaceBehavior string) string {
15361536
whitespaceFlags := map[string]string{
15371537
"ignore-all": "-w",
15381538
"ignore-change": "-b",
15391539
"ignore-eol": "--ignore-space-at-eol",
1540-
"": "",
1540+
"show-all": "",
15411541
}
15421542

1543-
return whitespaceFlags[whiteSpaceBehavior]
1543+
if flag, ok := whitespaceFlags[whitespaceBehavior]; ok {
1544+
return flag
1545+
}
1546+
log.Warn("unknown whitespace behavior: %q, default to 'show-all'", whitespaceBehavior)
1547+
return ""
15441548
}

templates/repo/diff/whitespace_dropdown.tmpl

Lines changed: 2 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -2,8 +2,8 @@
22
{{.i18n.Tr "repo.diff.whitespace_button"}}
33
{{svg "octicon-triangle-down" 14 "dropdown icon"}}
44
<div class="menu">
5-
<a class="item" href="?style={{if .IsSplitStyle}}split{{else}}unified{{end}}&whitespace=">
6-
<i class="circle {{ if eq .WhitespaceBehavior "" }}dot{{else}}outline{{end}} icon"></i>
5+
<a class="item" href="?style={{if .IsSplitStyle}}split{{else}}unified{{end}}&whitespace=show-all">
6+
<i class="circle {{ if eq .WhitespaceBehavior "show-all" }}dot{{else}}outline{{end}} icon"></i>
77
{{.i18n.Tr "repo.diff.whitespace_show_everything"}}
88
</a>
99
<a class="item" href="?style={{if .IsSplitStyle}}split{{else}}unified{{end}}&whitespace=ignore-all">

0 commit comments

Comments
 (0)