mirror of
https://github.com/go-gitea/gitea
synced 2025-01-25 09:07:48 +01:00
parent
fd281518ae
commit
e637008fe3
@ -276,6 +276,8 @@ func (repo *Repository) IsBroken() bool {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// MarkAsBrokenEmpty marks the repo as broken and empty
|
// MarkAsBrokenEmpty marks the repo as broken and empty
|
||||||
|
// FIXME: the status "broken" and "is_empty" were abused,
|
||||||
|
// The code always set them together, no way to distinguish whether a repo is really "empty" or "broken"
|
||||||
func (repo *Repository) MarkAsBrokenEmpty() {
|
func (repo *Repository) MarkAsBrokenEmpty() {
|
||||||
repo.Status = RepositoryBroken
|
repo.Status = RepositoryBroken
|
||||||
repo.IsEmpty = true
|
repo.IsEmpty = true
|
||||||
|
@ -1231,6 +1231,7 @@ create_new_repo_command = Creating a new repository on the command line
|
|||||||
push_exist_repo = Pushing an existing repository from the command line
|
push_exist_repo = Pushing an existing repository from the command line
|
||||||
empty_message = This repository does not contain any content.
|
empty_message = This repository does not contain any content.
|
||||||
broken_message = The Git data underlying this repository cannot be read. Contact the administrator of this instance or delete this repository.
|
broken_message = The Git data underlying this repository cannot be read. Contact the administrator of this instance or delete this repository.
|
||||||
|
no_branch = This repository doesn’t have any branches.
|
||||||
|
|
||||||
code = Code
|
code = Code
|
||||||
code.desc = Access source code, files, commits and branches.
|
code.desc = Access source code, files, commits and branches.
|
||||||
|
@ -223,16 +223,37 @@ func prepareRecentlyPushedNewBranches(ctx *context.Context) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func updateContextRepoEmptyAndStatus(ctx *context.Context, empty bool, status repo_model.RepositoryStatus) {
|
||||||
|
ctx.Repo.Repository.IsEmpty = empty
|
||||||
|
if ctx.Repo.Repository.Status == repo_model.RepositoryReady || ctx.Repo.Repository.Status == repo_model.RepositoryBroken {
|
||||||
|
ctx.Repo.Repository.Status = status // only handle ready and broken status, leave other status as-is
|
||||||
|
}
|
||||||
|
if err := repo_model.UpdateRepositoryCols(ctx, ctx.Repo.Repository, "is_empty", "status"); err != nil {
|
||||||
|
ctx.ServerError("updateContextRepoEmptyAndStatus: UpdateRepositoryCols", err)
|
||||||
|
return
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
func handleRepoEmptyOrBroken(ctx *context.Context) {
|
func handleRepoEmptyOrBroken(ctx *context.Context) {
|
||||||
showEmpty := true
|
showEmpty := true
|
||||||
var err error
|
|
||||||
if ctx.Repo.GitRepo != nil {
|
if ctx.Repo.GitRepo != nil {
|
||||||
showEmpty, err = ctx.Repo.GitRepo.IsEmpty()
|
reallyEmpty, err := ctx.Repo.GitRepo.IsEmpty()
|
||||||
if err != nil {
|
if err != nil {
|
||||||
|
showEmpty = true // the repo is broken
|
||||||
|
updateContextRepoEmptyAndStatus(ctx, true, repo_model.RepositoryBroken)
|
||||||
log.Error("GitRepo.IsEmpty: %v", err)
|
log.Error("GitRepo.IsEmpty: %v", err)
|
||||||
ctx.Repo.Repository.Status = repo_model.RepositoryBroken
|
|
||||||
showEmpty = true
|
|
||||||
ctx.Flash.Error(ctx.Tr("error.occurred"), true)
|
ctx.Flash.Error(ctx.Tr("error.occurred"), true)
|
||||||
|
} else if reallyEmpty {
|
||||||
|
showEmpty = true // the repo is really empty
|
||||||
|
updateContextRepoEmptyAndStatus(ctx, true, repo_model.RepositoryReady)
|
||||||
|
} else if ctx.Repo.Commit == nil {
|
||||||
|
showEmpty = true // it is not really empty, but there is no branch
|
||||||
|
// at the moment, other repo units like "actions" are not able to handle such case,
|
||||||
|
// so we just mark the repo as empty to prevent from displaying these units.
|
||||||
|
updateContextRepoEmptyAndStatus(ctx, true, repo_model.RepositoryReady)
|
||||||
|
} else {
|
||||||
|
// the repo is actually not empty and has branches, need to update the database later
|
||||||
|
showEmpty = false
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if showEmpty {
|
if showEmpty {
|
||||||
@ -240,18 +261,11 @@ func handleRepoEmptyOrBroken(ctx *context.Context) {
|
|||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
// the repo is not really empty, so we should update the modal in database
|
// The repo is not really empty, so we should update the model in database, such problem may be caused by:
|
||||||
// such problem may be caused by:
|
// 1) an error occurs during pushing/receiving.
|
||||||
// 1) an error occurs during pushing/receiving. 2) the user replaces an empty git repo manually
|
// 2) the user replaces an empty git repo manually.
|
||||||
// and even more: the IsEmpty flag is deeply broken and should be removed with the UI changed to manage to cope with empty repos.
|
updateContextRepoEmptyAndStatus(ctx, false, repo_model.RepositoryReady)
|
||||||
// it's possible for a repository to be non-empty by that flag but still 500
|
if err := repo_module.UpdateRepoSize(ctx, ctx.Repo.Repository); err != nil {
|
||||||
// because there are no branches - only tags -or the default branch is non-extant as it has been 0-pushed.
|
|
||||||
ctx.Repo.Repository.IsEmpty = false
|
|
||||||
if err = repo_model.UpdateRepositoryCols(ctx, ctx.Repo.Repository, "is_empty"); err != nil {
|
|
||||||
ctx.ServerError("UpdateRepositoryCols", err)
|
|
||||||
return
|
|
||||||
}
|
|
||||||
if err = repo_module.UpdateRepoSize(ctx, ctx.Repo.Repository); err != nil {
|
|
||||||
ctx.ServerError("UpdateRepoSize", err)
|
ctx.ServerError("UpdateRepoSize", err)
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
@ -908,10 +908,8 @@ func RepoRefByType(detectRefType RepoRefType, opts ...RepoRefByTypeOptions) func
|
|||||||
refName = brs[0].Name
|
refName = brs[0].Name
|
||||||
} else if len(brs) == 0 {
|
} else if len(brs) == 0 {
|
||||||
log.Error("No branches in non-empty repository %s", ctx.Repo.GitRepo.Path)
|
log.Error("No branches in non-empty repository %s", ctx.Repo.GitRepo.Path)
|
||||||
ctx.Repo.Repository.MarkAsBrokenEmpty()
|
|
||||||
} else {
|
} else {
|
||||||
log.Error("GetBranches error: %v", err)
|
log.Error("GetBranches error: %v", err)
|
||||||
ctx.Repo.Repository.MarkAsBrokenEmpty()
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
ctx.Repo.RefName = refName
|
ctx.Repo.RefName = refName
|
||||||
@ -922,7 +920,6 @@ func RepoRefByType(detectRefType RepoRefType, opts ...RepoRefByTypeOptions) func
|
|||||||
} else if strings.Contains(err.Error(), "fatal: not a git repository") || strings.Contains(err.Error(), "object does not exist") {
|
} else if strings.Contains(err.Error(), "fatal: not a git repository") || strings.Contains(err.Error(), "object does not exist") {
|
||||||
// if the repository is broken, we can continue to the handler code, to show "Settings -> Delete Repository" for end users
|
// if the repository is broken, we can continue to the handler code, to show "Settings -> Delete Repository" for end users
|
||||||
log.Error("GetBranchCommit: %v", err)
|
log.Error("GetBranchCommit: %v", err)
|
||||||
ctx.Repo.Repository.MarkAsBrokenEmpty()
|
|
||||||
} else {
|
} else {
|
||||||
ctx.ServerError("GetBranchCommit", err)
|
ctx.ServerError("GetBranchCommit", err)
|
||||||
return cancel
|
return cancel
|
||||||
|
@ -11,7 +11,7 @@
|
|||||||
</a>
|
</a>
|
||||||
|
|
||||||
<!-- mobile right menu, it must be here because in mobile view, each item is a flex column, the first item is a full row column -->
|
<!-- mobile right menu, it must be here because in mobile view, each item is a flex column, the first item is a full row column -->
|
||||||
<div class="ui secondary menu item navbar-mobile-right only-mobile">
|
<div class="ui secondary menu navbar-mobile-right only-mobile">
|
||||||
{{if and .IsSigned EnableTimetracking .ActiveStopwatch}}
|
{{if and .IsSigned EnableTimetracking .ActiveStopwatch}}
|
||||||
<a id="mobile-stopwatch-icon" class="active-stopwatch item tw-mx-0" href="{{.ActiveStopwatch.IssueLink}}" title="{{ctx.Locale.Tr "active_stopwatch"}}" data-seconds="{{.ActiveStopwatch.Seconds}}">
|
<a id="mobile-stopwatch-icon" class="active-stopwatch item tw-mx-0" href="{{.ActiveStopwatch.IssueLink}}" title="{{ctx.Locale.Tr "active_stopwatch"}}" data-seconds="{{.ActiveStopwatch.Seconds}}">
|
||||||
<div class="tw-relative">
|
<div class="tw-relative">
|
||||||
@ -70,7 +70,7 @@
|
|||||||
<span class="not-mobile">{{svg "octicon-triangle-down"}}</span>
|
<span class="not-mobile">{{svg "octicon-triangle-down"}}</span>
|
||||||
</span>
|
</span>
|
||||||
<div class="menu user-menu">
|
<div class="menu user-menu">
|
||||||
<div class="ui header">
|
<div class="header">
|
||||||
{{ctx.Locale.Tr "signed_in_as"}} <strong>{{.SignedUser.Name}}</strong>
|
{{ctx.Locale.Tr "signed_in_as"}} <strong>{{.SignedUser.Name}}</strong>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
@ -128,7 +128,7 @@
|
|||||||
<span class="not-mobile">{{svg "octicon-triangle-down"}}</span>
|
<span class="not-mobile">{{svg "octicon-triangle-down"}}</span>
|
||||||
</span>
|
</span>
|
||||||
<div class="menu user-menu">
|
<div class="menu user-menu">
|
||||||
<div class="ui header">
|
<div class="header">
|
||||||
{{ctx.Locale.Tr "signed_in_as"}} <strong>{{.SignedUser.Name}}</strong>
|
{{ctx.Locale.Tr "signed_in_as"}} <strong>{{.SignedUser.Name}}</strong>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
|
@ -30,7 +30,7 @@
|
|||||||
{{ctx.Locale.Tr "repo.commit.operations"}}
|
{{ctx.Locale.Tr "repo.commit.operations"}}
|
||||||
{{svg "octicon-triangle-down" 14 "dropdown icon"}}
|
{{svg "octicon-triangle-down" 14 "dropdown icon"}}
|
||||||
<div class="menu">
|
<div class="menu">
|
||||||
<div class="ui header">{{ctx.Locale.Tr "repo.commit.operations"}}</div>
|
<div class="header">{{ctx.Locale.Tr "repo.commit.operations"}}</div>
|
||||||
<div class="divider"></div>
|
<div class="divider"></div>
|
||||||
<div class="item show-create-branch-modal"
|
<div class="item show-create-branch-modal"
|
||||||
data-content="{{ctx.Locale.Tr "repo.branch.new_branch_from" (.CommitID)}}" {{/* used by the form */}}
|
data-content="{{ctx.Locale.Tr "repo.branch.new_branch_from" (.CommitID)}}" {{/* used by the form */}}
|
||||||
|
@ -14,14 +14,13 @@
|
|||||||
{{end}}
|
{{end}}
|
||||||
</div>
|
</div>
|
||||||
{{end}}
|
{{end}}
|
||||||
|
|
||||||
{{if .Repository.IsBroken}}
|
{{if .Repository.IsBroken}}
|
||||||
<div class="ui segment center">
|
<div class="ui segment center">{{ctx.Locale.Tr "repo.broken_message"}}</div>
|
||||||
{{ctx.Locale.Tr "repo.broken_message"}}
|
{{else if .Repository.IsEmpty}}
|
||||||
</div>
|
<div class="ui segment center">{{ctx.Locale.Tr "repo.no_branch"}}</div>
|
||||||
{{else if .CanWriteCode}}
|
{{else if .CanWriteCode}}
|
||||||
<h4 class="ui top attached header">
|
<h4 class="ui top attached header">{{ctx.Locale.Tr "repo.quick_guide"}}</h4>
|
||||||
{{ctx.Locale.Tr "repo.quick_guide"}}
|
|
||||||
</h4>
|
|
||||||
<div class="ui attached guide table segment empty-repo-guide">
|
<div class="ui attached guide table segment empty-repo-guide">
|
||||||
<div class="item">
|
<div class="item">
|
||||||
<h3>{{ctx.Locale.Tr "repo.clone_this_repo"}} <small>{{ctx.Locale.Tr "repo.clone_helper" "http://git-scm.com/book/en/v2/Git-Basics-Getting-a-Git-Repository"}}</small></h3>
|
<h3>{{ctx.Locale.Tr "repo.clone_this_repo"}} <small>{{ctx.Locale.Tr "repo.clone_helper" "http://git-scm.com/book/en/v2/Git-Basics-Getting-a-Git-Repository"}}</small></h3>
|
||||||
@ -66,12 +65,10 @@ git push -u origin {{.Repository.DefaultBranch}}</code></pre>
|
|||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
{{end}}
|
{{end}}
|
||||||
{{else}}
|
</div>
|
||||||
<div class="ui segment center">
|
{{else}}
|
||||||
{{ctx.Locale.Tr "repo.empty_message"}}
|
<div class="ui segment center">{{ctx.Locale.Tr "repo.empty_message"}}</div>
|
||||||
</div>
|
{{end}}
|
||||||
{{end}}
|
|
||||||
</div>
|
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
@ -162,7 +162,7 @@
|
|||||||
</a>
|
</a>
|
||||||
{{end}}
|
{{end}}
|
||||||
|
|
||||||
{{if and .EnableActions (.Permission.CanRead ctx.Consts.RepoUnitTypeActions)}}
|
{{if and .EnableActions (.Permission.CanRead ctx.Consts.RepoUnitTypeActions) (not .IsEmptyRepo)}}
|
||||||
<a class="{{if .PageIsActions}}active {{end}}item" href="{{.RepoLink}}/actions">
|
<a class="{{if .PageIsActions}}active {{end}}item" href="{{.RepoLink}}/actions">
|
||||||
{{svg "octicon-play"}} {{ctx.Locale.Tr "actions.actions"}}
|
{{svg "octicon-play"}} {{ctx.Locale.Tr "actions.actions"}}
|
||||||
{{if .Repository.NumOpenActionRuns}}
|
{{if .Repository.NumOpenActionRuns}}
|
||||||
|
@ -12,7 +12,7 @@
|
|||||||
{{svg "octicon-triangle-down" 14 "dropdown icon tw-ml-1"}}
|
{{svg "octicon-triangle-down" 14 "dropdown icon tw-ml-1"}}
|
||||||
</span>
|
</span>
|
||||||
<div class="context user overflow menu">
|
<div class="context user overflow menu">
|
||||||
<div class="ui header">
|
<div class="header">
|
||||||
{{ctx.Locale.Tr "home.switch_dashboard_context"}}
|
{{ctx.Locale.Tr "home.switch_dashboard_context"}}
|
||||||
</div>
|
</div>
|
||||||
<div class="scrolling menu items">
|
<div class="scrolling menu items">
|
||||||
@ -56,7 +56,7 @@
|
|||||||
</span>
|
</span>
|
||||||
{{svg "octicon-triangle-down" 14 "dropdown icon"}}
|
{{svg "octicon-triangle-down" 14 "dropdown icon"}}
|
||||||
<div class="context user overflow menu">
|
<div class="context user overflow menu">
|
||||||
<div class="ui header">
|
<div class="header">
|
||||||
{{ctx.Locale.Tr "home.filter_by_team_repositories"}}
|
{{ctx.Locale.Tr "home.filter_by_team_repositories"}}
|
||||||
</div>
|
</div>
|
||||||
<div class="scrolling menu items">
|
<div class="scrolling menu items">
|
||||||
|
@ -336,8 +336,13 @@ a.label,
|
|||||||
border-color: var(--color-secondary);
|
border-color: var(--color-secondary);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
.ui.dropdown .menu > .header {
|
||||||
|
text-transform: none; /* reset fomantic's "uppercase" */
|
||||||
|
}
|
||||||
|
|
||||||
.ui.dropdown .menu > .header:not(.ui) {
|
.ui.dropdown .menu > .header:not(.ui) {
|
||||||
color: var(--color-text);
|
color: var(--color-text);
|
||||||
|
font-size: 0.95em; /* reset fomantic's small font-size */
|
||||||
}
|
}
|
||||||
|
|
||||||
.ui.dropdown .menu > .item {
|
.ui.dropdown .menu > .item {
|
||||||
@ -691,11 +696,6 @@ input:-webkit-autofill:active,
|
|||||||
box-shadow: 0 6px 18px var(--color-shadow) !important;
|
box-shadow: 0 6px 18px var(--color-shadow) !important;
|
||||||
}
|
}
|
||||||
|
|
||||||
.ui.dropdown .menu > .header {
|
|
||||||
font-size: 0.8em;
|
|
||||||
text-transform: none; /* reset fomantic's "uppercase" */
|
|
||||||
}
|
|
||||||
|
|
||||||
.ui .text.left {
|
.ui .text.left {
|
||||||
text-align: left !important;
|
text-align: left !important;
|
||||||
}
|
}
|
||||||
|
@ -66,7 +66,8 @@
|
|||||||
align-items: stretch;
|
align-items: stretch;
|
||||||
}
|
}
|
||||||
/* hide all items */
|
/* hide all items */
|
||||||
#navbar .item {
|
#navbar .navbar-left > .item,
|
||||||
|
#navbar .navbar-right > .item {
|
||||||
display: none;
|
display: none;
|
||||||
}
|
}
|
||||||
#navbar #navbar-logo {
|
#navbar #navbar-logo {
|
||||||
|
Loading…
x
Reference in New Issue
Block a user