|
|
|
@ -18,6 +18,7 @@ import (
|
|
|
|
|
) |
|
|
|
|
|
|
|
|
|
func updateRepositorySizes(x *xorm.Engine) (err error) { |
|
|
|
|
log.Info("This migration could take up to minutes, please be patient.") |
|
|
|
|
type Repository struct { |
|
|
|
|
ID int64 |
|
|
|
|
OwnerID int64 |
|
|
|
@ -31,9 +32,22 @@ func updateRepositorySizes(x *xorm.Engine) (err error) {
|
|
|
|
|
if err = x.Sync2(new(Repository)); err != nil { |
|
|
|
|
return fmt.Errorf("Sync2: %v", err) |
|
|
|
|
} |
|
|
|
|
return x.Where("id > 0").Iterate(new(Repository), |
|
|
|
|
func(idx int, bean interface{}) error { |
|
|
|
|
repo := bean.(*Repository) |
|
|
|
|
|
|
|
|
|
// For the sake of SQLite3, we can't use x.Iterate here.
|
|
|
|
|
offset := 0 |
|
|
|
|
for { |
|
|
|
|
repos := make([]*Repository, 0, 10) |
|
|
|
|
if err = x.Sql(fmt.Sprintf("SELECT * FROM `repository` ORDER BY id ASC LIMIT 10 OFFSET %d", offset)). |
|
|
|
|
Find(&repos); err != nil { |
|
|
|
|
return fmt.Errorf("select repos [offset: %d]: %v", offset, err) |
|
|
|
|
} |
|
|
|
|
log.Trace("Select [offset: %d, repos: %d]", offset, len(repos)) |
|
|
|
|
if len(repos) == 0 { |
|
|
|
|
break |
|
|
|
|
} |
|
|
|
|
offset += 10 |
|
|
|
|
|
|
|
|
|
for _, repo := range repos { |
|
|
|
|
if repo.Name == "." || repo.Name == ".." { |
|
|
|
|
return nil |
|
|
|
|
} |
|
|
|
@ -47,8 +61,6 @@ func updateRepositorySizes(x *xorm.Engine) (err error) {
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
repoPath := filepath.Join(setting.RepoRootPath, strings.ToLower(user.Name), strings.ToLower(repo.Name)) + ".git" |
|
|
|
|
log.Trace("[%04d]: %s", idx, repoPath) |
|
|
|
|
|
|
|
|
|
countObject, err := git.GetRepoSize(repoPath) |
|
|
|
|
if err != nil { |
|
|
|
|
log.Warn("GetRepoSize: %v", err) |
|
|
|
@ -59,6 +71,7 @@ func updateRepositorySizes(x *xorm.Engine) (err error) {
|
|
|
|
|
if _, err = x.Id(repo.ID).Cols("size").Update(repo); err != nil { |
|
|
|
|
return fmt.Errorf("update size: %v", err) |
|
|
|
|
} |
|
|
|
|
} |
|
|
|
|
} |
|
|
|
|
return nil |
|
|
|
|
}) |
|
|
|
|
} |
|
|
|
|