diff options
author | slene <vslene@gmail.com> | 2014-04-16 00:27:29 +0800 |
---|---|---|
committer | slene <vslene@gmail.com> | 2014-04-16 00:29:03 +0800 |
commit | 4fafc7605245ef175a8fb8558eb7c30c4f7b0400 (patch) | |
tree | 4479b8792564c088931fd025ce45d31746bf064e /routers/repo/repo.go | |
parent | 5378bb326b14192cbbc1309c3142cfc49c74a882 (diff) | |
download | gitea-4fafc7605245ef175a8fb8558eb7c30c4f7b0400.tar.gz gitea-4fafc7605245ef175a8fb8558eb7c30c4f7b0400.zip |
zip archive download
Diffstat (limited to 'routers/repo/repo.go')
-rw-r--r-- | routers/repo/repo.go | 36 |
1 files changed, 5 insertions, 31 deletions
diff --git a/routers/repo/repo.go b/routers/repo/repo.go index dda26899d0..14a3c7622c 100644 --- a/routers/repo/repo.go +++ b/routers/repo/repo.go @@ -145,7 +145,7 @@ func Single(ctx *middleware.Context, params martini.Params) { return } - if entry != nil && entry.IsFile() { + if entry != nil && !entry.IsDir() { blob := entry.Blob() if data, err := blob.Data(); err != nil { @@ -154,7 +154,7 @@ func Single(ctx *middleware.Context, params martini.Params) { ctx.Data["FileSize"] = blob.Size() ctx.Data["IsFile"] = true ctx.Data["FileName"] = blob.Name - ext := path.Ext(blob.Name) + ext := path.Ext(blob.Name()) if len(ext) > 0 { ext = ext[1:] } @@ -168,7 +168,7 @@ func Single(ctx *middleware.Context, params martini.Params) { if isImageFile { ctx.Data["IsImageFile"] = true } else { - readmeExist := base.IsMarkdownFile(blob.Name) || base.IsReadmeFile(blob.Name) + readmeExist := base.IsMarkdownFile(blob.Name()) || base.IsReadmeFile(blob.Name()) ctx.Data["ReadmeExist"] = readmeExist if readmeExist { ctx.Data["FileContent"] = string(base.RenderMarkdown(data, "")) @@ -193,7 +193,7 @@ func Single(ctx *middleware.Context, params martini.Params) { files := make([][]interface{}, 0, len(entries)) for _, te := range entries { - c, err := ctx.Repo.Commit.GetCommitOfRelPath(filepath.Join(treePath, te.Name)) + c, err := ctx.Repo.Commit.GetCommitOfRelPath(filepath.Join(treePath, te.Name())) if err != nil { ctx.Handle(404, "repo.Single(SubTree)", err) return @@ -207,7 +207,7 @@ func Single(ctx *middleware.Context, params martini.Params) { var readmeFile *git.Blob for _, f := range entries { - if !f.IsFile() || !base.IsReadmeFile(f.Name) { + if f.IsDir() || !base.IsReadmeFile(f.Name()) { continue } else { readmeFile = f.Blob() @@ -260,32 +260,6 @@ func Single(ctx *middleware.Context, params martini.Params) { ctx.HTML(200, "repo/single") } -func SingleDownload(ctx *middleware.Context, params martini.Params) { - // Get tree path - treename := params["_1"] - - blob, err := ctx.Repo.Commit.GetBlobByPath(treename) - if err != nil { - ctx.Handle(404, "repo.SingleDownload(GetBlobByPath)", err) - return - } - - data, err := blob.Data() - if err != nil { - ctx.Handle(404, "repo.SingleDownload(Data)", err) - return - } - - contentType, isTextFile := base.IsTextFile(data) - _, isImageFile := base.IsImageFile(data) - ctx.Res.Header().Set("Content-Type", contentType) - if !isTextFile && !isImageFile { - ctx.Res.Header().Set("Content-Disposition", "attachment; filename="+filepath.Base(treename)) - ctx.Res.Header().Set("Content-Transfer-Encoding", "binary") - } - ctx.Res.Write(data) -} - func basicEncode(username, password string) string { auth := username + ":" + password return base64.StdEncoding.EncodeToString([]byte(auth)) |