mirror of
https://codeberg.org/forgejo/forgejo.git
synced 2024-12-22 12:54:53 -05:00
Merge branch 'master' of github.com:gogits/gogs
This commit is contained in:
commit
9d3b003add
5 changed files with 97 additions and 26 deletions
|
@ -191,3 +191,15 @@ func GetLastestCommit(userName, repoName string) (*Commit, error) {
|
||||||
}
|
}
|
||||||
return commit, nil
|
return commit, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func GetCommits(userName, reposName, branchname string) ([]*git.Commit, error) {
|
||||||
|
repo, err := git.OpenRepository(RepoPath(userName, reposName))
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
r, err := repo.LookupReference(fmt.Sprintf("refs/heads/%s", branchname))
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
return r.AllCommits()
|
||||||
|
}
|
||||||
|
|
|
@ -5,35 +5,78 @@
|
||||||
package base
|
package base
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"github.com/slene/blackfriday"
|
"bytes"
|
||||||
|
"path"
|
||||||
|
|
||||||
|
"github.com/gogits/gfm"
|
||||||
)
|
)
|
||||||
|
|
||||||
func RenderMarkdown(rawBytes []byte) []byte {
|
func isletter(c byte) bool {
|
||||||
|
return (c >= 'a' && c <= 'z') || (c >= 'A' && c <= 'Z')
|
||||||
|
}
|
||||||
|
|
||||||
|
func isalnum(c byte) bool {
|
||||||
|
return (c >= '0' && c <= '9') || isletter(c)
|
||||||
|
}
|
||||||
|
|
||||||
|
var validLinks = [][]byte{[]byte("http://"), []byte("https://"), []byte("ftp://"), []byte("mailto://")}
|
||||||
|
|
||||||
|
func isLink(link []byte) bool {
|
||||||
|
for _, prefix := range validLinks {
|
||||||
|
if len(link) > len(prefix) && bytes.Equal(bytes.ToLower(link[:len(prefix)]), prefix) && isalnum(link[len(prefix)]) {
|
||||||
|
return true
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return false
|
||||||
|
}
|
||||||
|
|
||||||
|
type CustomRender struct {
|
||||||
|
gfm.Renderer
|
||||||
|
urlPrefix string
|
||||||
|
}
|
||||||
|
|
||||||
|
func (options *CustomRender) Link(out *bytes.Buffer, link []byte, title []byte, content []byte) {
|
||||||
|
if len(link) > 0 && !isLink(link) {
|
||||||
|
if link[0] == '#' {
|
||||||
|
link = append([]byte(options.urlPrefix), link...)
|
||||||
|
} else {
|
||||||
|
link = []byte(path.Join(options.urlPrefix, string(link)))
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
options.Renderer.Link(out, link, title, content)
|
||||||
|
}
|
||||||
|
|
||||||
|
func RenderMarkdown(rawBytes []byte, urlPrefix string) []byte {
|
||||||
htmlFlags := 0
|
htmlFlags := 0
|
||||||
htmlFlags |= blackfriday.HTML_USE_XHTML
|
htmlFlags |= gfm.HTML_USE_XHTML
|
||||||
// htmlFlags |= blackfriday.HTML_USE_SMARTYPANTS
|
// htmlFlags |= gfm.HTML_USE_SMARTYPANTS
|
||||||
// htmlFlags |= blackfriday.HTML_SMARTYPANTS_FRACTIONS
|
// htmlFlags |= gfm.HTML_SMARTYPANTS_FRACTIONS
|
||||||
// htmlFlags |= blackfriday.HTML_SMARTYPANTS_LATEX_DASHES
|
// htmlFlags |= gfm.HTML_SMARTYPANTS_LATEX_DASHES
|
||||||
htmlFlags |= blackfriday.HTML_SKIP_HTML
|
htmlFlags |= gfm.HTML_SKIP_HTML
|
||||||
htmlFlags |= blackfriday.HTML_SKIP_STYLE
|
htmlFlags |= gfm.HTML_SKIP_STYLE
|
||||||
htmlFlags |= blackfriday.HTML_SKIP_SCRIPT
|
htmlFlags |= gfm.HTML_SKIP_SCRIPT
|
||||||
htmlFlags |= blackfriday.HTML_GITHUB_BLOCKCODE
|
htmlFlags |= gfm.HTML_GITHUB_BLOCKCODE
|
||||||
htmlFlags |= blackfriday.HTML_OMIT_CONTENTS
|
htmlFlags |= gfm.HTML_OMIT_CONTENTS
|
||||||
htmlFlags |= blackfriday.HTML_COMPLETE_PAGE
|
htmlFlags |= gfm.HTML_COMPLETE_PAGE
|
||||||
renderer := blackfriday.HtmlRenderer(htmlFlags, "", "")
|
renderer := &CustomRender{
|
||||||
|
Renderer: gfm.HtmlRenderer(htmlFlags, "", ""),
|
||||||
|
urlPrefix: urlPrefix,
|
||||||
|
}
|
||||||
|
|
||||||
// set up the parser
|
// set up the parser
|
||||||
extensions := 0
|
extensions := 0
|
||||||
extensions |= blackfriday.EXTENSION_NO_INTRA_EMPHASIS
|
extensions |= gfm.EXTENSION_NO_INTRA_EMPHASIS
|
||||||
extensions |= blackfriday.EXTENSION_TABLES
|
extensions |= gfm.EXTENSION_TABLES
|
||||||
extensions |= blackfriday.EXTENSION_FENCED_CODE
|
extensions |= gfm.EXTENSION_FENCED_CODE
|
||||||
extensions |= blackfriday.EXTENSION_AUTOLINK
|
extensions |= gfm.EXTENSION_AUTOLINK
|
||||||
extensions |= blackfriday.EXTENSION_STRIKETHROUGH
|
extensions |= gfm.EXTENSION_STRIKETHROUGH
|
||||||
extensions |= blackfriday.EXTENSION_HARD_LINE_BREAK
|
extensions |= gfm.EXTENSION_HARD_LINE_BREAK
|
||||||
extensions |= blackfriday.EXTENSION_SPACE_HEADERS
|
extensions |= gfm.EXTENSION_SPACE_HEADERS
|
||||||
extensions |= blackfriday.EXTENSION_NO_EMPTY_LINE_BEFORE_BLOCK
|
extensions |= gfm.EXTENSION_NO_EMPTY_LINE_BEFORE_BLOCK
|
||||||
|
|
||||||
body := blackfriday.Markdown(rawBytes, renderer, extensions)
|
body := gfm.Markdown(rawBytes, renderer, extensions)
|
||||||
|
|
||||||
return body
|
return body
|
||||||
}
|
}
|
||||||
|
|
|
@ -102,9 +102,13 @@ func Single(ctx *middleware.Context, params martini.Params) {
|
||||||
if readmeFile.Size > 1024*1024 || readmeFile.Filemode != git.FileModeBlob {
|
if readmeFile.Size > 1024*1024 || readmeFile.Filemode != git.FileModeBlob {
|
||||||
ctx.Data["FileIsLarge"] = true
|
ctx.Data["FileIsLarge"] = true
|
||||||
} else if blob, err := readmeFile.LookupBlob(); err != nil {
|
} else if blob, err := readmeFile.LookupBlob(); err != nil {
|
||||||
ctx.Data["FileIsLarge"] = true
|
ctx.Data["ReadmeExist"] = false
|
||||||
} else {
|
} else {
|
||||||
ctx.Data["ReadmeContent"] = string(base.RenderMarkdown(blob.Contents()))
|
// current repo branch link
|
||||||
|
urlPrefix := "http://" + base.Domain + "/" + ctx.Repo.Owner.LowerName + "/" +
|
||||||
|
ctx.Repo.Repository.Name + "/blob/" + params["branchname"]
|
||||||
|
|
||||||
|
ctx.Data["ReadmeContent"] = string(base.RenderMarkdown(blob.Contents(), urlPrefix))
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -131,8 +135,15 @@ func Setting(ctx *middleware.Context, params martini.Params) {
|
||||||
ctx.Render.HTML(200, "repo/setting", ctx.Data)
|
ctx.Render.HTML(200, "repo/setting", ctx.Data)
|
||||||
}
|
}
|
||||||
|
|
||||||
func Commits(ctx *middleware.Context) {
|
func Commits(ctx *middleware.Context, params martini.Params) {
|
||||||
ctx.Data["IsRepoToolbarCommits"] = true
|
ctx.Data["IsRepoToolbarCommits"] = true
|
||||||
|
commits, err := models.GetCommits(params["username"],
|
||||||
|
params["reponame"], params["branchname"])
|
||||||
|
if err != nil {
|
||||||
|
ctx.Render.Error(404)
|
||||||
|
return
|
||||||
|
}
|
||||||
|
ctx.Data["Commits"] = commits
|
||||||
ctx.Render.HTML(200, "repo/commits", ctx.Data)
|
ctx.Render.HTML(200, "repo/commits", ctx.Data)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -4,6 +4,11 @@
|
||||||
{{template "repo/toolbar" .}}
|
{{template "repo/toolbar" .}}
|
||||||
<div id="gogs-body" class="container">
|
<div id="gogs-body" class="container">
|
||||||
<div id="gogs-commits">
|
<div id="gogs-commits">
|
||||||
|
<ul>
|
||||||
|
{{range .Commits}}
|
||||||
|
<li>{{.Committer.Name}} - {{.Id}} - {{.Message}} - {{.Committer.When}}</li>
|
||||||
|
{{end}}
|
||||||
|
</ul>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
{{template "base/footer" .}}
|
{{template "base/footer" .}}
|
2
web.go
2
web.go
|
@ -74,7 +74,7 @@ func runWeb(*cli.Context) {
|
||||||
m.Post("/:username/:reponame/settings", middleware.SignInRequire(true), middleware.RepoAssignment(true), repo.SettingPost)
|
m.Post("/:username/:reponame/settings", middleware.SignInRequire(true), middleware.RepoAssignment(true), repo.SettingPost)
|
||||||
m.Get("/:username/:reponame/settings", middleware.SignInRequire(true), middleware.RepoAssignment(true), repo.Setting)
|
m.Get("/:username/:reponame/settings", middleware.SignInRequire(true), middleware.RepoAssignment(true), repo.Setting)
|
||||||
|
|
||||||
m.Get("/:username/:reponame/commits", middleware.SignInRequire(false), middleware.RepoAssignment(true), repo.Commits)
|
m.Get("/:username/:reponame/commits/:branchname", middleware.SignInRequire(false), middleware.RepoAssignment(true), repo.Commits)
|
||||||
m.Get("/:username/:reponame/issues", middleware.SignInRequire(false), middleware.RepoAssignment(true), repo.Issues)
|
m.Get("/:username/:reponame/issues", middleware.SignInRequire(false), middleware.RepoAssignment(true), repo.Issues)
|
||||||
m.Get("/:username/:reponame/pulls", middleware.SignInRequire(false), middleware.RepoAssignment(true), repo.Pulls)
|
m.Get("/:username/:reponame/pulls", middleware.SignInRequire(false), middleware.RepoAssignment(true), repo.Pulls)
|
||||||
m.Get("/:username/:reponame/branches", middleware.SignInRequire(false), middleware.RepoAssignment(true), repo.Branches)
|
m.Get("/:username/:reponame/branches", middleware.SignInRequire(false), middleware.RepoAssignment(true), repo.Branches)
|
||||||
|
|
Loading…
Reference in a new issue