mirror of
				https://github.com/superseriousbusiness/gotosocial.git
				synced 2025-11-03 18:12:25 -06:00 
			
		
		
		
	- codeberg.org/gruf/go-bytesize v1.0.3 -> v1.0.4 - codeberg.org/gruf/go-kv/v2 v2.0.6 -> v2.0.7 - codeberg.org/gruf/go-mutexes v1.5.2 -> v1.5.3 - codeberg.org/gruf/go-structr v0.9.7 -> v0.9.8 - codeberg.org/gruf/go-ffmpreg v0.6.8 -> v0.6.9 - github.com/tomnomnom/linkheader HEAD@2018 -> HEAD@2025 all of the above codeberg.org/gruf updates are in preparation for Go1.25, except for bytesize, and also ffmpreg which is a rebuild with the latest version of ffmpeg (v5.1.7) Reviewed-on: https://codeberg.org/superseriousbusiness/gotosocial/pulls/4386 Co-authored-by: kim <grufwub@gmail.com> Co-committed-by: kim <grufwub@gmail.com>
		
			
				
	
	
		
			85 lines
		
	
	
	
		
			1.6 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			85 lines
		
	
	
	
		
			1.6 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
package structr
 | 
						|
 | 
						|
import (
 | 
						|
	"sync"
 | 
						|
 | 
						|
	"codeberg.org/gruf/go-byteutil"
 | 
						|
	"codeberg.org/gruf/go-mangler/v2"
 | 
						|
)
 | 
						|
 | 
						|
// Key represents one key to
 | 
						|
// lookup (potentially) stored
 | 
						|
// entries in an Index.
 | 
						|
type Key struct {
 | 
						|
	key string
 | 
						|
	raw []any
 | 
						|
}
 | 
						|
 | 
						|
// MakeKey generates Key{} from given parts.
 | 
						|
func MakeKey(parts ...any) Key {
 | 
						|
	buf := new_buffer()
 | 
						|
	buf.B = mangler.AppendMulti(buf.B[:0], parts...)
 | 
						|
	key := string(buf.B)
 | 
						|
	free_buffer(buf)
 | 
						|
	return Key{
 | 
						|
		raw: parts,
 | 
						|
		key: key,
 | 
						|
	}
 | 
						|
}
 | 
						|
 | 
						|
// MakeKeys generates []Key{} from given (multiple) parts.
 | 
						|
func MakeKeys(parts ...[]any) []Key {
 | 
						|
	keys := make([]Key, len(parts))
 | 
						|
	if len(keys) != len(parts) {
 | 
						|
		panic(assert("BCE"))
 | 
						|
	}
 | 
						|
	buf := new_buffer()
 | 
						|
	for x, parts := range parts {
 | 
						|
		buf.B = mangler.AppendMulti(buf.B[:0], parts...)
 | 
						|
		key := string(buf.B)
 | 
						|
		keys[x] = Key{
 | 
						|
			raw: parts,
 | 
						|
			key: key,
 | 
						|
		}
 | 
						|
	}
 | 
						|
	free_buffer(buf)
 | 
						|
	return keys
 | 
						|
}
 | 
						|
 | 
						|
// Key returns the underlying cache key string.
 | 
						|
// NOTE: this will not be log output friendly.
 | 
						|
func (k Key) Key() string {
 | 
						|
	return k.key
 | 
						|
}
 | 
						|
 | 
						|
// Equal returns whether keys are equal.
 | 
						|
func (k Key) Equal(o Key) bool {
 | 
						|
	return (k.key == o.key)
 | 
						|
}
 | 
						|
 | 
						|
// Value returns the raw slice of
 | 
						|
// values that comprise this Key.
 | 
						|
func (k Key) Values() []any {
 | 
						|
	return k.raw
 | 
						|
}
 | 
						|
 | 
						|
var buf_pool sync.Pool
 | 
						|
 | 
						|
// new_buffer returns a new initialized byte buffer.
 | 
						|
func new_buffer() *byteutil.Buffer {
 | 
						|
	v := buf_pool.Get()
 | 
						|
	if v == nil {
 | 
						|
		buf := new(byteutil.Buffer)
 | 
						|
		buf.B = make([]byte, 0, 512)
 | 
						|
		v = buf
 | 
						|
	}
 | 
						|
	return v.(*byteutil.Buffer)
 | 
						|
}
 | 
						|
 | 
						|
// free_buffer releases the byte buffer.
 | 
						|
func free_buffer(buf *byteutil.Buffer) {
 | 
						|
	if cap(buf.B) > int(^uint16(0)) {
 | 
						|
		return // drop large bufs
 | 
						|
	}
 | 
						|
	buf_pool.Put(buf)
 | 
						|
}
 |