summaryrefslogtreecommitdiffstats
path: root/models/repo.go
diff options
context:
space:
mode:
Diffstat (limited to 'models/repo.go')
-rw-r--r--models/repo.go23
1 files changed, 11 insertions, 12 deletions
diff --git a/models/repo.go b/models/repo.go
index c2480d9ddb..0e6665b3fb 100644
--- a/models/repo.go
+++ b/models/repo.go
@@ -1515,16 +1515,16 @@ func DeleteRepository(uid, repoID int64) error {
return err
}
- if err = sess.Commit(); err != nil {
- return fmt.Errorf("Commit: %v", err)
- }
-
if repo.NumForks > 0 {
- if _, err = x.Exec("UPDATE `repository` SET fork_id=0,is_fork=? WHERE fork_id=?", false, repo.ID); err != nil {
+ if _, err = sess.Exec("UPDATE `repository` SET fork_id=0,is_fork=? WHERE fork_id=?", false, repo.ID); err != nil {
log.Error(4, "reset 'fork_id' and 'is_fork': %v", err)
}
}
+ if err = sess.Commit(); err != nil {
+ return fmt.Errorf("Commit: %v", err)
+ }
+
return nil
}
@@ -2217,30 +2217,29 @@ func ForkRepository(u *User, oldRepo *Repository, name, desc string) (_ *Reposit
if err != nil {
return nil, err
}
- sessionRelease(sess)
// Copy LFS meta objects in new session
- sess = x.NewSession()
- defer sessionRelease(sess)
- if err = sess.Begin(); err != nil {
+ sess2 := x.NewSession()
+ defer sessionRelease(sess2)
+ if err = sess2.Begin(); err != nil {
return nil, err
}
var lfsObjects []*LFSMetaObject
- if err = sess.Where("repository_id=?", oldRepo.ID).Find(&lfsObjects); err != nil {
+ if err = sess2.Where("repository_id=?", oldRepo.ID).Find(&lfsObjects); err != nil {
return nil, err
}
for _, v := range lfsObjects {
v.ID = 0
v.RepositoryID = repo.ID
- if _, err = sess.Insert(v); err != nil {
+ if _, err = sess2.Insert(v); err != nil {
return nil, err
}
}
- return repo, sess.Commit()
+ return repo, sess2.Commit()
}
// GetForks returns all the forks of the repository