summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorUnknown <joe2010xtmf@163.com>2014-03-16 23:43:22 -0400
committerUnknown <joe2010xtmf@163.com>2014-03-16 23:43:22 -0400
commit685631627e5c4db881160bfc9b39dc45143989f6 (patch)
tree632f287752a9d678e3dfcbc49c0b75ccf4ad4f71
parent7015c3d4912bbe053786819b71539720f96e4a39 (diff)
downloadgitea-685631627e5c4db881160bfc9b39dc45143989f6.tar.gz
gitea-685631627e5c4db881160bfc9b39dc45143989f6.zip
Show branches in repo viewer
-rw-r--r--README.md2
-rw-r--r--bee.json3
-rw-r--r--models/repo2.go24
-rw-r--r--routers/repo/single.go7
-rw-r--r--templates/repo/single.tmpl18
5 files changed, 40 insertions, 14 deletions
diff --git a/README.md b/README.md
index f4250a47a4..d0a0c2054c 100644
--- a/README.md
+++ b/README.md
@@ -5,7 +5,7 @@ Gogs(Go Git Service) is a GitHub-like clone in the Go Programming Language.
Since we choose to use pure Go implmentation of Git manipulation, Gogs certainly supports **ALL platforms** that Go supports, including Linux, Max OS X, and Windows with **ZERO** dependency.
-##### Current version: 0.0.8 Alpha
+##### Current version: 0.0.9 Alpha
## Purpose
diff --git a/bee.json b/bee.json
index de211f7277..19efcbc205 100644
--- a/bee.json
+++ b/bee.json
@@ -12,7 +12,8 @@
"models": "",
"others": [
"modules",
- "$GOPATH/src/github.com/gogits/binding"
+ "$GOPATH/src/github.com/gogits/binding",
+ "$GOPATH/src/github.com/gogits/git"
]
},
"cmd_args": [
diff --git a/models/repo2.go b/models/repo2.go
index e3fdc2784b..a8dbc44db9 100644
--- a/models/repo2.go
+++ b/models/repo2.go
@@ -8,7 +8,7 @@ import (
"path"
"time"
- git "github.com/gogits/git"
+ "github.com/gogits/git"
)
type RepoFile struct {
@@ -19,10 +19,26 @@ type RepoFile struct {
Size int64
}
-func GetReposFiles(userName, reposName, branchName, rpath string) ([]*RepoFile, error) {
- f := RepoPath(userName, reposName)
+func GetBranches(userName, reposName string) ([]string, error) {
+ repo, err := git.OpenRepository(RepoPath(userName, reposName))
+ if err != nil {
+ return nil, err
+ }
+
+ refs, err := repo.AllReferences()
+ if err != nil {
+ return nil, err
+ }
+
+ brs := make([]string, len(refs))
+ for i, ref := range refs {
+ brs[i] = ref.Name
+ }
+ return brs, nil
+}
- repo, err := git.OpenRepository(f)
+func GetReposFiles(userName, reposName, branchName, rpath string) ([]*RepoFile, error) {
+ repo, err := git.OpenRepository(RepoPath(userName, reposName))
if err != nil {
return nil, err
}
diff --git a/routers/repo/single.go b/routers/repo/single.go
index 6bf03ca2b8..fd4d529031 100644
--- a/routers/repo/single.go
+++ b/routers/repo/single.go
@@ -33,6 +33,13 @@ func Single(ctx *middleware.Context, params martini.Params) {
ctx.Data["Reponame"] = params["reponame"]
ctx.Data["Branchname"] = params["branchname"]
+ brs, err := models.GetBranches(params["username"], params["reponame"])
+ if err != nil {
+ ctx.Handle(200, "repo.Single", err)
+ return
+ }
+ ctx.Data["Branches"] = brs
+
var treenames []string
Paths := make([]string, 0)
diff --git a/templates/repo/single.tmpl b/templates/repo/single.tmpl
index b5207d0820..e1fb05bd03 100644
--- a/templates/repo/single.tmpl
+++ b/templates/repo/single.tmpl
@@ -5,21 +5,23 @@
<div id="gogs-body" class="container">
<div id="gogs-source">
<div class="source-toolbar">
+ {{ $username := .Username}}
+ {{ $reponame := .Reponame}}
+ {{ $branchname := .Branchname}}
+ {{ $treenames := .Treenames}}
+ {{ $repoLink := .RepositoryLink}}
+ {{ $n := len $treenames}}
<button class="btn btn-default pull-right"><i class="fa fa-plus-square"></i>Add File</button>
<div class="dropdown branch-switch">
- <a href="#" class="btn btn-success dropdown-toggle" data-toggle="dropdown"><i class="fa fa-chain"></i>master&nbsp;&nbsp;
+ <a href="#" class="btn btn-success dropdown-toggle" data-toggle="dropdown"><i class="fa fa-chain"></i>{{$branchname}}&nbsp;&nbsp;
<b class="caret"></b></a>
<ul class="dropdown-menu">
- <li><a class="current" href="/{{.RepositoryLink}}/tree/master">master</a></li>
- <li><a href="/{{.RepositoryLink}}/tree/develop">develop</a></li>
+ {{range .Branches}}
+ <li><a {{if eq . $branchname}}class="current" {{end}}href="/{{$repoLink}}/tree/{{.}}">{{.}}</a></li>
+ {{end}}
</ul>
</div>
{{$paths := .Paths}}
- {{ $username := .Username}}
- {{ $reponame := .Reponame}}
- {{ $branchname := .Branchname}}
- {{ $treenames := .Treenames}}
- {{ $n := len $treenames}}
{{ $l := Subtract $n 1}}
<ol class="breadcrumb">
<li class="root dir"><a href="/{{$username}}/{{$reponame}}/tree/{{$branchname}}">{{.Repository.Name}}</a></li>