merge v0.23.0-rc changes

This commit is contained in:
Gani Georgiev
2024-09-29 19:23:19 +03:00
parent ad92992324
commit 844f18cac3
753 changed files with 85141 additions and 63396 deletions
+41
View File
@@ -0,0 +1,41 @@
package picker
import (
"fmt"
"github.com/pocketbase/pocketbase/tools/tokenizer"
)
var Modifiers = map[string]ModifierFactoryFunc{}
type ModifierFactoryFunc func(args ...string) (Modifier, error)
type Modifier interface {
// Modify executes the modifier and returns a new modified value.
Modify(value any) (any, error)
}
func initModifer(rawModifier string) (Modifier, error) {
t := tokenizer.NewFromString(rawModifier)
t.Separators('(', ')', ',', ' ')
t.IgnoreParenthesis(true)
parts, err := t.ScanAll()
if err != nil {
return nil, err
}
if len(parts) == 0 {
return nil, fmt.Errorf("invalid or empty modifier expression %q", rawModifier)
}
name := parts[0]
args := parts[1:]
factory, ok := Modifiers[name]
if !ok {
return nil, fmt.Errorf("missing or invalid modifier %q", name)
}
return factory(args...)
}