mirror of
https://github.com/go-gitea/gitea.git
synced 2024-12-24 18:13:37 +08:00
e536d18fe5
Backport #31754 by @lunny When opening a repository, it will call `ensureValidRepository` and also `CatFileBatch`. But sometimes these will not be used until repository closed. So it's a waste of CPU to invoke 3 times git command for every open repository. This PR removed all of these from `OpenRepository` but only kept checking whether the folder exists. When a batch is necessary, the necessary functions will be invoked. Co-authored-by: Lunny Xiao <xiaolunwen@gmail.com>
47 lines
1.2 KiB
Go
47 lines
1.2 KiB
Go
// Copyright 2024 The Gitea Authors. All rights reserved.
|
|
// SPDX-License-Identifier: MIT
|
|
|
|
package git
|
|
|
|
import (
|
|
"bufio"
|
|
"context"
|
|
)
|
|
|
|
type Batch struct {
|
|
cancel context.CancelFunc
|
|
Reader *bufio.Reader
|
|
Writer WriteCloserError
|
|
}
|
|
|
|
func (repo *Repository) NewBatch(ctx context.Context) (*Batch, error) {
|
|
// Now because of some insanity with git cat-file not immediately failing if not run in a valid git directory we need to run git rev-parse first!
|
|
if err := ensureValidGitRepository(ctx, repo.Path); err != nil {
|
|
return nil, err
|
|
}
|
|
|
|
var batch Batch
|
|
batch.Writer, batch.Reader, batch.cancel = catFileBatch(ctx, repo.Path)
|
|
return &batch, nil
|
|
}
|
|
|
|
func (repo *Repository) NewBatchCheck(ctx context.Context) (*Batch, error) {
|
|
// Now because of some insanity with git cat-file not immediately failing if not run in a valid git directory we need to run git rev-parse first!
|
|
if err := ensureValidGitRepository(ctx, repo.Path); err != nil {
|
|
return nil, err
|
|
}
|
|
|
|
var check Batch
|
|
check.Writer, check.Reader, check.cancel = catFileBatchCheck(ctx, repo.Path)
|
|
return &check, nil
|
|
}
|
|
|
|
func (b *Batch) Close() {
|
|
if b.cancel != nil {
|
|
b.cancel()
|
|
b.Reader = nil
|
|
b.Writer = nil
|
|
b.cancel = nil
|
|
}
|
|
}
|