mirror of
				https://github.com/go-gitea/gitea
				synced 2025-11-04 05:18:25 +00:00 
			
		
		
		
	* Update go-redis to v8.4.0 * github.com/go-redis/redis/v8 v8.4.0 -> v8.5.0 * Apply suggestions from code review Co-authored-by: zeripath <art27@cantab.net> * TODO * Use the Queue termination channel as the default context for pushes Signed-off-by: Andrew Thornton <art27@cantab.net> * missed one Signed-off-by: Andrew Thornton <art27@cantab.net> Co-authored-by: zeripath <art27@cantab.net>
		
			
				
	
	
		
			78 lines
		
	
	
		
			1.5 KiB
		
	
	
	
		
			Go
		
	
	
	
		
			Vendored
		
	
	
	
			
		
		
	
	
			78 lines
		
	
	
		
			1.5 KiB
		
	
	
	
		
			Go
		
	
	
	
		
			Vendored
		
	
	
	
package redis
 | 
						|
 | 
						|
import (
 | 
						|
	"context"
 | 
						|
	"sync"
 | 
						|
)
 | 
						|
 | 
						|
// ScanIterator is used to incrementally iterate over a collection of elements.
 | 
						|
// It's safe for concurrent use by multiple goroutines.
 | 
						|
type ScanIterator struct {
 | 
						|
	mu  sync.Mutex // protects Scanner and pos
 | 
						|
	cmd *ScanCmd
 | 
						|
	pos int
 | 
						|
}
 | 
						|
 | 
						|
// Err returns the last iterator error, if any.
 | 
						|
func (it *ScanIterator) Err() error {
 | 
						|
	it.mu.Lock()
 | 
						|
	err := it.cmd.Err()
 | 
						|
	it.mu.Unlock()
 | 
						|
	return err
 | 
						|
}
 | 
						|
 | 
						|
// Next advances the cursor and returns true if more values can be read.
 | 
						|
func (it *ScanIterator) Next(ctx context.Context) bool {
 | 
						|
	it.mu.Lock()
 | 
						|
	defer it.mu.Unlock()
 | 
						|
 | 
						|
	// Instantly return on errors.
 | 
						|
	if it.cmd.Err() != nil {
 | 
						|
		return false
 | 
						|
	}
 | 
						|
 | 
						|
	// Advance cursor, check if we are still within range.
 | 
						|
	if it.pos < len(it.cmd.page) {
 | 
						|
		it.pos++
 | 
						|
		return true
 | 
						|
	}
 | 
						|
 | 
						|
	for {
 | 
						|
		// Return if there is no more data to fetch.
 | 
						|
		if it.cmd.cursor == 0 {
 | 
						|
			return false
 | 
						|
		}
 | 
						|
 | 
						|
		// Fetch next page.
 | 
						|
		switch it.cmd.args[0] {
 | 
						|
		case "scan", "qscan":
 | 
						|
			it.cmd.args[1] = it.cmd.cursor
 | 
						|
		default:
 | 
						|
			it.cmd.args[2] = it.cmd.cursor
 | 
						|
		}
 | 
						|
 | 
						|
		err := it.cmd.process(ctx, it.cmd)
 | 
						|
		if err != nil {
 | 
						|
			return false
 | 
						|
		}
 | 
						|
 | 
						|
		it.pos = 1
 | 
						|
 | 
						|
		// Redis can occasionally return empty page.
 | 
						|
		if len(it.cmd.page) > 0 {
 | 
						|
			return true
 | 
						|
		}
 | 
						|
	}
 | 
						|
}
 | 
						|
 | 
						|
// Val returns the key/field at the current cursor position.
 | 
						|
func (it *ScanIterator) Val() string {
 | 
						|
	var v string
 | 
						|
	it.mu.Lock()
 | 
						|
	if it.cmd.Err() == nil && it.pos > 0 && it.pos <= len(it.cmd.page) {
 | 
						|
		v = it.cmd.page[it.pos-1]
 | 
						|
	}
 | 
						|
	it.mu.Unlock()
 | 
						|
	return v
 | 
						|
}
 |