mirror of
				https://gitee.com/gitea/gitea
				synced 2025-11-04 16:40:24 +08:00 
			
		
		
		
	Reduce repo indexer disk usage (#3452)
This commit is contained in:
		
							
								
								
									
										67
									
								
								vendor/github.com/ethantkoenig/rupture/flushing_batch.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										67
									
								
								vendor/github.com/ethantkoenig/rupture/flushing_batch.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							@@ -0,0 +1,67 @@
 | 
			
		||||
package rupture
 | 
			
		||||
 | 
			
		||||
import (
 | 
			
		||||
	"github.com/blevesearch/bleve"
 | 
			
		||||
)
 | 
			
		||||
 | 
			
		||||
// FlushingBatch is a batch of operations that automatically flushes to the
 | 
			
		||||
// underlying index once it reaches a certain size.
 | 
			
		||||
type FlushingBatch interface {
 | 
			
		||||
	// Index adds the specified index operation batch, possibly triggering a
 | 
			
		||||
	// flush.
 | 
			
		||||
	Index(id string, data interface{}) error
 | 
			
		||||
	// Remove adds the specified delete operation to the batch, possibly
 | 
			
		||||
	// triggering a flush.
 | 
			
		||||
	Delete(id string) error
 | 
			
		||||
	// Flush flushes the batch's contents.
 | 
			
		||||
	Flush() error
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
type singleIndexFlushingBatch struct {
 | 
			
		||||
	maxBatchSize int
 | 
			
		||||
	batch        *bleve.Batch
 | 
			
		||||
	index        bleve.Index
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
func newFlushingBatch(index bleve.Index, maxBatchSize int) *singleIndexFlushingBatch {
 | 
			
		||||
	return &singleIndexFlushingBatch{
 | 
			
		||||
		maxBatchSize: maxBatchSize,
 | 
			
		||||
		batch:        index.NewBatch(),
 | 
			
		||||
		index:        index,
 | 
			
		||||
	}
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
// NewFlushingBatch creates a new flushing batch for the specified index. Once
 | 
			
		||||
// the number of operations in the batch reaches the specified limit, the batch
 | 
			
		||||
// automatically flushes its operations to the index.
 | 
			
		||||
func NewFlushingBatch(index bleve.Index, maxBatchSize int) FlushingBatch {
 | 
			
		||||
	return newFlushingBatch(index, maxBatchSize)
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
func (b *singleIndexFlushingBatch) Index(id string, data interface{}) error {
 | 
			
		||||
	if err := b.batch.Index(id, data); err != nil {
 | 
			
		||||
		return err
 | 
			
		||||
	}
 | 
			
		||||
	return b.flushIfFull()
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
func (b *singleIndexFlushingBatch) Delete(id string) error {
 | 
			
		||||
	b.batch.Delete(id)
 | 
			
		||||
	return b.flushIfFull()
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
func (b *singleIndexFlushingBatch) flushIfFull() error {
 | 
			
		||||
	if b.batch.Size() < b.maxBatchSize {
 | 
			
		||||
		return nil
 | 
			
		||||
	}
 | 
			
		||||
	return b.Flush()
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
func (b *singleIndexFlushingBatch) Flush() error {
 | 
			
		||||
	err := b.index.Batch(b.batch)
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		return err
 | 
			
		||||
	}
 | 
			
		||||
	b.batch.Reset()
 | 
			
		||||
	return nil
 | 
			
		||||
}
 | 
			
		||||
		Reference in New Issue
	
	Block a user