summaryrefslogtreecommitdiffstats
path: root/models/git_diff.go
diff options
context:
space:
mode:
Diffstat (limited to 'models/git_diff.go')
-rw-r--r--models/git_diff.go25
1 files changed, 25 insertions, 0 deletions
diff --git a/models/git_diff.go b/models/git_diff.go
index e093e7ab1b..4bbe3c0e8f 100644
--- a/models/git_diff.go
+++ b/models/git_diff.go
@@ -6,6 +6,7 @@ package models
import (
"bufio"
+ "bytes"
"fmt"
"io"
"os"
@@ -15,8 +16,10 @@ import (
"github.com/Unknwon/com"
+ "github.com/gogits/gogs/modules/base"
"github.com/gogits/gogs/modules/git"
"github.com/gogits/gogs/modules/log"
+ "github.com/gogits/gogs/modules/mahonia"
"github.com/gogits/gogs/modules/process"
)
@@ -80,6 +83,8 @@ func ParsePatch(pid int64, maxlines int, cmd *exec.Cmd, reader io.Reader) (*Diff
leftLine, rightLine int
isTooLong bool
+ // FIXME: use first 30 lines to detect file encoding. Should use cache in the future.
+ buf bytes.Buffer
)
diff := &Diff{Files: make([]*DiffFile, 0)}
@@ -97,6 +102,11 @@ func ParsePatch(pid int64, maxlines int, cmd *exec.Cmd, reader io.Reader) (*Diff
i = i + 1
+ // FIXME: use first 30 lines to detect file encoding.
+ if i <= 30 {
+ buf.WriteString(line)
+ }
+
// Diff data too large, we only show the first about maxlines lines
if i == maxlines {
isTooLong = true
@@ -181,6 +191,21 @@ func ParsePatch(pid int64, maxlines int, cmd *exec.Cmd, reader io.Reader) (*Diff
}
}
+ // FIXME: use first 30 lines to detect file encoding.
+ charset, err := base.DetectEncoding(buf.Bytes())
+ if charset != "utf8" && err == nil {
+ decoder := mahonia.NewDecoder(charset)
+ if decoder != nil {
+ for _, f := range diff.Files {
+ for _, sec := range f.Sections {
+ for _, l := range sec.Lines {
+ l.Content = decoder.ConvertString(l.Content)
+ }
+ }
+ }
+ }
+ }
+
return diff, nil
}