* Fixed commit count (#17698) Added "Tag" label. Unified branch, tag and commit name. * Keep 1.15 behaviour. * Removed locale change.
This commit is contained in:
		
							parent
							
								
									add85f5a85
								
							
						
					
					
						commit
						3a222ee416
					
				
					 7 changed files with 32 additions and 29 deletions
				
			
		|  | @ -58,6 +58,7 @@ type Repository struct { | ||||||
| 	Commit       *git.Commit | 	Commit       *git.Commit | ||||||
| 	Tag          *git.Tag | 	Tag          *git.Tag | ||||||
| 	GitRepo      *git.Repository | 	GitRepo      *git.Repository | ||||||
|  | 	RefName      string | ||||||
| 	BranchName   string | 	BranchName   string | ||||||
| 	TagName      string | 	TagName      string | ||||||
| 	TreePath     string | 	TreePath     string | ||||||
|  | @ -190,9 +191,9 @@ func (r *Repository) BranchNameSubURL() string { | ||||||
| 	case r.IsViewBranch: | 	case r.IsViewBranch: | ||||||
| 		return "branch/" + r.BranchName | 		return "branch/" + r.BranchName | ||||||
| 	case r.IsViewTag: | 	case r.IsViewTag: | ||||||
| 		return "tag/" + r.BranchName | 		return "tag/" + r.TagName | ||||||
| 	case r.IsViewCommit: | 	case r.IsViewCommit: | ||||||
| 		return "commit/" + r.BranchName | 		return "commit/" + r.CommitID | ||||||
| 	} | 	} | ||||||
| 	log.Error("Unknown view type for repo: %v", r) | 	log.Error("Unknown view type for repo: %v", r) | ||||||
| 	return "" | 	return "" | ||||||
|  | @ -562,8 +563,6 @@ func RepoAssignment(ctx *Context) (cancel context.CancelFunc) { | ||||||
| 	ctx.Data["Branches"] = brs | 	ctx.Data["Branches"] = brs | ||||||
| 	ctx.Data["BranchesCount"] = len(brs) | 	ctx.Data["BranchesCount"] = len(brs) | ||||||
| 
 | 
 | ||||||
| 	ctx.Data["TagName"] = ctx.Repo.TagName |  | ||||||
| 
 |  | ||||||
| 	// If not branch selected, try default one.
 | 	// If not branch selected, try default one.
 | ||||||
| 	// If default branch doesn't exists, fall back to some other branch.
 | 	// If default branch doesn't exists, fall back to some other branch.
 | ||||||
| 	if len(ctx.Repo.BranchName) == 0 { | 	if len(ctx.Repo.BranchName) == 0 { | ||||||
|  | @ -572,9 +571,9 @@ func RepoAssignment(ctx *Context) (cancel context.CancelFunc) { | ||||||
| 		} else if len(brs) > 0 { | 		} else if len(brs) > 0 { | ||||||
| 			ctx.Repo.BranchName = brs[0] | 			ctx.Repo.BranchName = brs[0] | ||||||
| 		} | 		} | ||||||
|  | 		ctx.Repo.RefName = ctx.Repo.BranchName | ||||||
| 	} | 	} | ||||||
| 	ctx.Data["BranchName"] = ctx.Repo.BranchName | 	ctx.Data["BranchName"] = ctx.Repo.BranchName | ||||||
| 	ctx.Data["CommitID"] = ctx.Repo.CommitID |  | ||||||
| 
 | 
 | ||||||
| 	// People who have push access or have forked repository can propose a new pull request.
 | 	// People who have push access or have forked repository can propose a new pull request.
 | ||||||
| 	canPush := ctx.Repo.CanWrite(models.UnitTypeCode) || (ctx.IsSigned && ctx.User.HasForkedRepo(ctx.Repo.Repository.ID)) | 	canPush := ctx.Repo.CanWrite(models.UnitTypeCode) || (ctx.IsSigned && ctx.User.HasForkedRepo(ctx.Repo.Repository.ID)) | ||||||
|  | @ -759,7 +758,6 @@ func RepoRefByType(refType RepoRefType, ignoreNotExistErr ...bool) func(*Context | ||||||
| 		// Get default branch.
 | 		// Get default branch.
 | ||||||
| 		if len(ctx.Params("*")) == 0 { | 		if len(ctx.Params("*")) == 0 { | ||||||
| 			refName = ctx.Repo.Repository.DefaultBranch | 			refName = ctx.Repo.Repository.DefaultBranch | ||||||
| 			ctx.Repo.BranchName = refName |  | ||||||
| 			if !ctx.Repo.GitRepo.IsBranchExist(refName) { | 			if !ctx.Repo.GitRepo.IsBranchExist(refName) { | ||||||
| 				brs, _, err := ctx.Repo.GitRepo.GetBranches(0, 0) | 				brs, _, err := ctx.Repo.GitRepo.GetBranches(0, 0) | ||||||
| 				if err != nil { | 				if err != nil { | ||||||
|  | @ -773,6 +771,8 @@ func RepoRefByType(refType RepoRefType, ignoreNotExistErr ...bool) func(*Context | ||||||
| 				} | 				} | ||||||
| 				refName = brs[0] | 				refName = brs[0] | ||||||
| 			} | 			} | ||||||
|  | 			ctx.Repo.RefName = refName | ||||||
|  | 			ctx.Repo.BranchName = refName | ||||||
| 			ctx.Repo.Commit, err = ctx.Repo.GitRepo.GetBranchCommit(refName) | 			ctx.Repo.Commit, err = ctx.Repo.GitRepo.GetBranchCommit(refName) | ||||||
| 			if err != nil { | 			if err != nil { | ||||||
| 				ctx.ServerError("GetBranchCommit", err) | 				ctx.ServerError("GetBranchCommit", err) | ||||||
|  | @ -783,9 +783,10 @@ func RepoRefByType(refType RepoRefType, ignoreNotExistErr ...bool) func(*Context | ||||||
| 
 | 
 | ||||||
| 		} else { | 		} else { | ||||||
| 			refName = getRefName(ctx, refType) | 			refName = getRefName(ctx, refType) | ||||||
| 			ctx.Repo.BranchName = refName | 			ctx.Repo.RefName = refName | ||||||
| 			if refType.RefTypeIncludesBranches() && ctx.Repo.GitRepo.IsBranchExist(refName) { | 			if refType.RefTypeIncludesBranches() && ctx.Repo.GitRepo.IsBranchExist(refName) { | ||||||
| 				ctx.Repo.IsViewBranch = true | 				ctx.Repo.IsViewBranch = true | ||||||
|  | 				ctx.Repo.BranchName = refName | ||||||
| 
 | 
 | ||||||
| 				ctx.Repo.Commit, err = ctx.Repo.GitRepo.GetBranchCommit(refName) | 				ctx.Repo.Commit, err = ctx.Repo.GitRepo.GetBranchCommit(refName) | ||||||
| 				if err != nil { | 				if err != nil { | ||||||
|  | @ -796,6 +797,8 @@ func RepoRefByType(refType RepoRefType, ignoreNotExistErr ...bool) func(*Context | ||||||
| 
 | 
 | ||||||
| 			} else if refType.RefTypeIncludesTags() && ctx.Repo.GitRepo.IsTagExist(refName) { | 			} else if refType.RefTypeIncludesTags() && ctx.Repo.GitRepo.IsTagExist(refName) { | ||||||
| 				ctx.Repo.IsViewTag = true | 				ctx.Repo.IsViewTag = true | ||||||
|  | 				ctx.Repo.TagName = refName | ||||||
|  | 
 | ||||||
| 				ctx.Repo.Commit, err = ctx.Repo.GitRepo.GetTagCommit(refName) | 				ctx.Repo.Commit, err = ctx.Repo.GitRepo.GetTagCommit(refName) | ||||||
| 				if err != nil { | 				if err != nil { | ||||||
| 					ctx.ServerError("GetTagCommit", err) | 					ctx.ServerError("GetTagCommit", err) | ||||||
|  | @ -837,6 +840,7 @@ func RepoRefByType(refType RepoRefType, ignoreNotExistErr ...bool) func(*Context | ||||||
| 
 | 
 | ||||||
| 		ctx.Data["BranchName"] = ctx.Repo.BranchName | 		ctx.Data["BranchName"] = ctx.Repo.BranchName | ||||||
| 		ctx.Data["BranchNameSubURL"] = ctx.Repo.BranchNameSubURL() | 		ctx.Data["BranchNameSubURL"] = ctx.Repo.BranchNameSubURL() | ||||||
|  | 		ctx.Data["TagName"] = ctx.Repo.TagName | ||||||
| 		ctx.Data["CommitID"] = ctx.Repo.CommitID | 		ctx.Data["CommitID"] = ctx.Repo.CommitID | ||||||
| 		ctx.Data["TreePath"] = ctx.Repo.TreePath | 		ctx.Data["TreePath"] = ctx.Repo.TreePath | ||||||
| 		ctx.Data["IsViewBranch"] = ctx.Repo.IsViewBranch | 		ctx.Data["IsViewBranch"] = ctx.Repo.IsViewBranch | ||||||
|  |  | ||||||
|  | @ -343,17 +343,15 @@ func CreateBranch(ctx *context.Context) { | ||||||
| 	var err error | 	var err error | ||||||
| 
 | 
 | ||||||
| 	if form.CreateTag { | 	if form.CreateTag { | ||||||
| 		if ctx.Repo.IsViewTag { | 		target := ctx.Repo.CommitID | ||||||
| 			err = release_service.CreateNewTag(ctx.User, ctx.Repo.Repository, ctx.Repo.CommitID, form.NewBranchName, "") | 		if ctx.Repo.IsViewBranch { | ||||||
| 		} else { | 			target = ctx.Repo.BranchName | ||||||
| 			err = release_service.CreateNewTag(ctx.User, ctx.Repo.Repository, ctx.Repo.BranchName, form.NewBranchName, "") |  | ||||||
| 		} | 		} | ||||||
|  | 		err = release_service.CreateNewTag(ctx.User, ctx.Repo.Repository, target, form.NewBranchName, "") | ||||||
| 	} else if ctx.Repo.IsViewBranch { | 	} else if ctx.Repo.IsViewBranch { | ||||||
| 		err = repo_module.CreateNewBranch(ctx.User, ctx.Repo.Repository, ctx.Repo.BranchName, form.NewBranchName) | 		err = repo_module.CreateNewBranch(ctx.User, ctx.Repo.Repository, ctx.Repo.BranchName, form.NewBranchName) | ||||||
| 	} else if ctx.Repo.IsViewTag { |  | ||||||
| 		err = repo_module.CreateNewBranchFromCommit(ctx.User, ctx.Repo.Repository, ctx.Repo.CommitID, form.NewBranchName) |  | ||||||
| 	} else { | 	} else { | ||||||
| 		err = repo_module.CreateNewBranchFromCommit(ctx.User, ctx.Repo.Repository, ctx.Repo.BranchName, form.NewBranchName) | 		err = repo_module.CreateNewBranchFromCommit(ctx.User, ctx.Repo.Repository, ctx.Repo.CommitID, form.NewBranchName) | ||||||
| 	} | 	} | ||||||
| 	if err != nil { | 	if err != nil { | ||||||
| 		if models.IsErrTagAlreadyExists(err) { | 		if models.IsErrTagAlreadyExists(err) { | ||||||
|  |  | ||||||
|  | @ -80,7 +80,7 @@ func Commits(ctx *context.Context) { | ||||||
| 	ctx.Data["Username"] = ctx.Repo.Owner.Name | 	ctx.Data["Username"] = ctx.Repo.Owner.Name | ||||||
| 	ctx.Data["Reponame"] = ctx.Repo.Repository.Name | 	ctx.Data["Reponame"] = ctx.Repo.Repository.Name | ||||||
| 	ctx.Data["CommitCount"] = commitsCount | 	ctx.Data["CommitCount"] = commitsCount | ||||||
| 	ctx.Data["Branch"] = ctx.Repo.BranchName | 	ctx.Data["RefName"] = ctx.Repo.RefName | ||||||
| 
 | 
 | ||||||
| 	pager := context.NewPagination(int(commitsCount), setting.Git.CommitsRangeSize, page, 5) | 	pager := context.NewPagination(int(commitsCount), setting.Git.CommitsRangeSize, page, 5) | ||||||
| 	pager.SetDefaultParams(ctx) | 	pager.SetDefaultParams(ctx) | ||||||
|  | @ -156,7 +156,7 @@ func Graph(ctx *context.Context) { | ||||||
| 	ctx.Data["Username"] = ctx.Repo.Owner.Name | 	ctx.Data["Username"] = ctx.Repo.Owner.Name | ||||||
| 	ctx.Data["Reponame"] = ctx.Repo.Repository.Name | 	ctx.Data["Reponame"] = ctx.Repo.Repository.Name | ||||||
| 	ctx.Data["CommitCount"] = commitsCount | 	ctx.Data["CommitCount"] = commitsCount | ||||||
| 	ctx.Data["Branch"] = ctx.Repo.BranchName | 	ctx.Data["RefName"] = ctx.Repo.RefName | ||||||
| 	paginator := context.NewPagination(int(graphCommitsCount), setting.UI.GraphMaxCommitNum, page, 5) | 	paginator := context.NewPagination(int(graphCommitsCount), setting.UI.GraphMaxCommitNum, page, 5) | ||||||
| 	paginator.AddParam(ctx, "mode", "Mode") | 	paginator.AddParam(ctx, "mode", "Mode") | ||||||
| 	paginator.AddParam(ctx, "hide-pr-refs", "HidePRRefs") | 	paginator.AddParam(ctx, "hide-pr-refs", "HidePRRefs") | ||||||
|  | @ -205,7 +205,7 @@ func SearchCommits(ctx *context.Context) { | ||||||
| 	ctx.Data["Username"] = ctx.Repo.Owner.Name | 	ctx.Data["Username"] = ctx.Repo.Owner.Name | ||||||
| 	ctx.Data["Reponame"] = ctx.Repo.Repository.Name | 	ctx.Data["Reponame"] = ctx.Repo.Repository.Name | ||||||
| 	ctx.Data["CommitCount"] = commits.Len() | 	ctx.Data["CommitCount"] = commits.Len() | ||||||
| 	ctx.Data["Branch"] = ctx.Repo.BranchName | 	ctx.Data["RefName"] = ctx.Repo.RefName | ||||||
| 	ctx.HTML(http.StatusOK, tplCommits) | 	ctx.HTML(http.StatusOK, tplCommits) | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | @ -219,8 +219,7 @@ func FileHistory(ctx *context.Context) { | ||||||
| 		return | 		return | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	branchName := ctx.Repo.BranchName | 	commitsCount, err := ctx.Repo.GitRepo.FileCommitsCount(ctx.Repo.RefName, fileName) | ||||||
| 	commitsCount, err := ctx.Repo.GitRepo.FileCommitsCount(branchName, fileName) |  | ||||||
| 	if err != nil { | 	if err != nil { | ||||||
| 		ctx.ServerError("FileCommitsCount", err) | 		ctx.ServerError("FileCommitsCount", err) | ||||||
| 		return | 		return | ||||||
|  | @ -234,7 +233,7 @@ func FileHistory(ctx *context.Context) { | ||||||
| 		page = 1 | 		page = 1 | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	commits, err := ctx.Repo.GitRepo.CommitsByFileAndRange(branchName, fileName, page) | 	commits, err := ctx.Repo.GitRepo.CommitsByFileAndRange(ctx.Repo.RefName, fileName, page) | ||||||
| 	if err != nil { | 	if err != nil { | ||||||
| 		ctx.ServerError("CommitsByFileAndRange", err) | 		ctx.ServerError("CommitsByFileAndRange", err) | ||||||
| 		return | 		return | ||||||
|  | @ -248,7 +247,7 @@ func FileHistory(ctx *context.Context) { | ||||||
| 	ctx.Data["Reponame"] = ctx.Repo.Repository.Name | 	ctx.Data["Reponame"] = ctx.Repo.Repository.Name | ||||||
| 	ctx.Data["FileName"] = fileName | 	ctx.Data["FileName"] = fileName | ||||||
| 	ctx.Data["CommitCount"] = commitsCount | 	ctx.Data["CommitCount"] = commitsCount | ||||||
| 	ctx.Data["Branch"] = branchName | 	ctx.Data["RefName"] = ctx.Repo.RefName | ||||||
| 
 | 
 | ||||||
| 	pager := context.NewPagination(int(commitsCount), setting.Git.CommitsRangeSize, page, 5) | 	pager := context.NewPagination(int(commitsCount), setting.Git.CommitsRangeSize, page, 5) | ||||||
| 	pager.SetDefaultParams(ctx) | 	pager.SetDefaultParams(ctx) | ||||||
|  |  | ||||||
|  | @ -406,7 +406,7 @@ func renderFile(ctx *context.Context, entry *git.TreeEntry, treeLink, rawLink st | ||||||
| 	} | 	} | ||||||
| 	defer dataRc.Close() | 	defer dataRc.Close() | ||||||
| 
 | 
 | ||||||
| 	ctx.Data["Title"] = ctx.Data["Title"].(string) + " - " + ctx.Repo.TreePath + " at " + ctx.Repo.BranchName | 	ctx.Data["Title"] = ctx.Data["Title"].(string) + " - " + ctx.Repo.TreePath + " at " + ctx.Repo.RefName | ||||||
| 
 | 
 | ||||||
| 	fileSize := blob.Size() | 	fileSize := blob.Size() | ||||||
| 	ctx.Data["FileIsSymlink"] = entry.IsLink() | 	ctx.Data["FileIsSymlink"] = entry.IsLink() | ||||||
|  |  | ||||||
|  | @ -7,9 +7,9 @@ | ||||||
| 				{{if $release}} | 				{{if $release}} | ||||||
| 					{{.root.i18n.Tr "repo.release.compare"}} | 					{{.root.i18n.Tr "repo.release.compare"}} | ||||||
| 				{{else}} | 				{{else}} | ||||||
| 					{{svg "octicon-git-branch"}} | 					{{if .root.IsViewTag}}{{svg "octicon-tag"}}{{else}}{{svg "octicon-git-branch"}}{{end}} | ||||||
| 					{{if .root.IsViewBranch}}{{.root.i18n.Tr "repo.branch"}}{{else}}{{.root.i18n.Tr "repo.tree"}}{{end}}: | 					{{if .root.IsViewBranch}}{{.root.i18n.Tr "repo.branch"}}{{else if .root.IsViewTag}}{{.root.i18n.Tr "repo.tag"}}{{else}}{{.root.i18n.Tr "repo.tree"}}{{end}}: | ||||||
| 					<strong>{{if .root.IsViewBranch}}{{.root.BranchName}}{{else}}{{ShortSha .root.BranchName}}{{end}}</strong> | 					<strong>{{if .root.IsViewBranch}}{{.root.BranchName}}{{else if .root.IsViewTag}}{{.root.TagName}}{{else}}{{ShortSha .root.CommitID}}{{end}}</strong> | ||||||
| 				{{end}} | 				{{end}} | ||||||
| 			</span> | 			</span> | ||||||
| 			{{svg "octicon-triangle-down" 14 "dropdown icon"}} | 			{{svg "octicon-triangle-down" 14 "dropdown icon"}} | ||||||
|  | @ -66,8 +66,10 @@ | ||||||
| 						<div class="text small"> | 						<div class="text small"> | ||||||
| 							{{if or .root.IsViewBranch $release}} | 							{{if or .root.IsViewBranch $release}} | ||||||
| 								{{.root.i18n.Tr "repo.branch.create_from" .root.BranchName}} | 								{{.root.i18n.Tr "repo.branch.create_from" .root.BranchName}} | ||||||
|  | 							{{else if .root.IsViewTag}} | ||||||
|  | 								{{.root.i18n.Tr "repo.branch.create_from" .root.TagName}} | ||||||
| 							{{else}} | 							{{else}} | ||||||
| 								{{.root.i18n.Tr "repo.branch.create_from" (ShortSha .root.BranchName)}} | 								{{.root.i18n.Tr "repo.branch.create_from" (ShortSha .root.CommitID)}} | ||||||
| 							{{end}} | 							{{end}} | ||||||
| 						</div> | 						</div> | ||||||
| 					</a> | 					</a> | ||||||
|  |  | ||||||
|  | @ -1,9 +1,9 @@ | ||||||
| <h4 class="ui top attached header commits-table df ac sb"> | <h4 class="ui top attached header commits-table df ac sb"> | ||||||
| 	<div class="commits-table-left df ac"> | 	<div class="commits-table-left df ac"> | ||||||
| 		{{if or .PageIsCommits (gt .CommitCount 0)}} | 		{{if or .PageIsCommits (gt .CommitCount 0)}} | ||||||
| 			{{.CommitCount}} {{.i18n.Tr "repo.commits.commits"}} {{if .Branch}}({{.Branch}}){{end}} | 			{{.CommitCount}} {{.i18n.Tr "repo.commits.commits"}} {{if .RefName}}({{.RefName}}){{end}} | ||||||
| 		{{else}} | 		{{else}} | ||||||
| 			{{.i18n.Tr "repo.commits.no_commits" $.BaseBranch $.HeadBranch }} {{if .Branch}}({{.Branch}}){{end}} | 			{{.i18n.Tr "repo.commits.no_commits" $.BaseBranch $.HeadBranch}} {{if .RefName}}({{.RefName}}){{end}} | ||||||
| 		{{end}} | 		{{end}} | ||||||
| 	</div> | 	</div> | ||||||
| 	<div class="commits-table-right df ac"> | 	<div class="commits-table-right df ac"> | ||||||
|  |  | ||||||
|  | @ -3,7 +3,7 @@ | ||||||
| 		<div class="ui two horizontal center link list"> | 		<div class="ui two horizontal center link list"> | ||||||
| 			{{if and (.Permission.CanRead $.UnitTypeCode) (not .IsEmptyRepo)}} | 			{{if and (.Permission.CanRead $.UnitTypeCode) (not .IsEmptyRepo)}} | ||||||
| 				<div class="item{{if .PageIsCommits}} active{{end}}"> | 				<div class="item{{if .PageIsCommits}} active{{end}}"> | ||||||
| 					<a class="ui" href="{{.RepoLink}}/commits{{if .IsViewBranch}}/branch{{else if .IsViewTag}}/tag{{else if .IsViewCommit}}/commit{{end}}/{{EscapePound .BranchName}}">{{svg "octicon-history"}} <b>{{.CommitsCount}}</b> {{.i18n.Tr (TrN .i18n.Lang .CommitsCount "repo.commit" "repo.commits") }}</a> | 					<a class="ui" href="{{.RepoLink}}/commits/{{.BranchNameSubURL}}">{{svg "octicon-history"}} <b>{{.CommitsCount}}</b> {{.i18n.Tr (TrN .i18n.Lang .CommitsCount "repo.commit" "repo.commits") }}</a> | ||||||
| 				</div> | 				</div> | ||||||
| 				<div class="item{{if .PageIsBranches}} active{{end}}"> | 				<div class="item{{if .PageIsBranches}} active{{end}}"> | ||||||
| 					<a class="ui" href="{{.RepoLink}}/branches">{{svg "octicon-git-branch"}} <b>{{.BranchesCount}}</b> {{.i18n.Tr (TrN .i18n.Lang .BranchesCount "repo.branch" "repo.branches") }}</a> | 					<a class="ui" href="{{.RepoLink}}/branches">{{svg "octicon-git-branch"}} <b>{{.BranchesCount}}</b> {{.i18n.Tr (TrN .i18n.Lang .BranchesCount "repo.branch" "repo.branches") }}</a> | ||||||
|  |  | ||||||
		Loading…
	
		Reference in a new issue