Browse Source

Raw text file view returns correct charset in content-type header if not utf-8

tags/v1.2.0-rc1
Vladimir Vissoultchev 10 years ago
parent
commit
1003551826
1 changed files with 11 additions and 4 deletions
  1. +11
    -4
      routers/repo/download.go

+ 11
- 4
routers/repo/download.go View File

@@ -26,10 +26,17 @@ func ServeBlob(ctx *middleware.Context, blob *git.Blob) error {
}

_, isTextFile := base.IsTextFile(buf)
_, isImageFile := base.IsImageFile(buf)
if !isTextFile && !isImageFile {
ctx.Resp.Header().Set("Content-Disposition", "attachment; filename="+path.Base(ctx.Repo.TreeName))
ctx.Resp.Header().Set("Content-Transfer-Encoding", "binary")
if isTextFile {
charset, _ := base.DetectEncoding(buf)
if charset != "utf-8" {
ctx.Resp.Header().Set("Content-Type", "text/plain; charset="+charset)
}
} else {
_, isImageFile := base.IsImageFile(buf)
if !isImageFile {
ctx.Resp.Header().Set("Content-Disposition", "attachment; filename="+path.Base(ctx.Repo.TreeName))
ctx.Resp.Header().Set("Content-Transfer-Encoding", "binary")
}
}
ctx.Resp.Write(buf)
_, err = io.Copy(ctx.Resp, dataRc)


Loading…
Cancel
Save