aboutsummaryrefslogtreecommitdiff
path: root/models/migrations/v16.go
diff options
context:
space:
mode:
authorUnknwon <u@gogs.io>2017-03-12 03:30:53 -0400
committerUnknwon <u@gogs.io>2017-03-12 03:30:53 -0400
commitbf58f263054e6c2d2a9c05ca51b154937b168d28 (patch)
tree043ac0f9e7582b21b4ed78be867d0bb0e8afac97 /models/migrations/v16.go
parent601f174ea01f8ba1f3239209595078ef29ceb72f (diff)
migrations/v16: make SQLite3 work
Diffstat (limited to 'models/migrations/v16.go')
-rw-r--r--models/migrations/v16.go27
1 files changed, 20 insertions, 7 deletions
diff --git a/models/migrations/v16.go b/models/migrations/v16.go
index 845a8762..7c3f4821 100644
--- a/models/migrations/v16.go
+++ b/models/migrations/v16.go
@@ -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
- })
+ }
+ }
+ return nil
}