move CloneWith() call into interpolate()
This commit is contained in:
+10
-1
@@ -8,9 +8,18 @@ import (
|
|||||||
var interpolationRegex = regexp.MustCompile(`((?:\${([[:alpha:]_][[:word:]]*))(?:=([^}]+))?})|(\$)|([^$]+)`)
|
var interpolationRegex = regexp.MustCompile(`((?:\${([[:alpha:]_][[:word:]]*))(?:=([^}]+))?})|(\$)|([^$]+)`)
|
||||||
|
|
||||||
// Interpolate variables from vars into s for substrings in the form ${var} or ${var=default}.
|
// Interpolate variables from vars into s for substrings in the form ${var} or ${var=default}.
|
||||||
func interpolate(s string, vars map[string]string) (string, error) {
|
func interpolate(s string, vars Vars, updatedVars map[string]string) (string, error) {
|
||||||
out := ""
|
out := ""
|
||||||
matches := interpolationRegex.FindAllStringSubmatch(s, -1)
|
matches := interpolationRegex.FindAllStringSubmatch(s, -1)
|
||||||
|
if len(matches) == 0 {
|
||||||
|
return s, nil
|
||||||
|
}
|
||||||
|
for key, val := range updatedVars {
|
||||||
|
if vars[key] != val {
|
||||||
|
vars = vars.CloneWith(updatedVars)
|
||||||
|
break
|
||||||
|
}
|
||||||
|
}
|
||||||
for _, match := range matches {
|
for _, match := range matches {
|
||||||
if name := match[2]; name != "" {
|
if name := match[2]; name != "" {
|
||||||
value, ok := vars[name]
|
value, ok := vars[name]
|
||||||
|
|||||||
+5
-2
@@ -10,7 +10,10 @@ func TestInterpolate(t *testing.T) {
|
|||||||
vars := map[string]string{
|
vars := map[string]string{
|
||||||
"age": "35",
|
"age": "35",
|
||||||
}
|
}
|
||||||
actual, err := interpolate("${name=Bobby Brown} is ${age} years old", vars)
|
updatedVars := map[string]string{
|
||||||
|
"height": "180",
|
||||||
|
}
|
||||||
|
actual, err := interpolate("${name=Bobby Brown} is ${age} years old and ${height} cm tall", vars, updatedVars)
|
||||||
require.NoError(t, err)
|
require.NoError(t, err)
|
||||||
require.Equal(t, `Bobby Brown is 35 years old`, actual)
|
require.Equal(t, `Bobby Brown is 35 years old and 180 cm tall`, actual)
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -128,7 +128,7 @@ func (k *Kong) interpolate(node *Node) (err error) {
|
|||||||
switch node := node.(type) {
|
switch node := node.(type) {
|
||||||
case *Node:
|
case *Node:
|
||||||
vars := stack.push(node.Vars())
|
vars := stack.push(node.Vars())
|
||||||
node.Help, err = interpolate(node.Help, vars)
|
node.Help, err = interpolate(node.Help, vars, nil)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return fmt.Errorf("help for %s: %s", node.Path(), err)
|
return fmt.Errorf("help for %s: %s", node.Path(), err)
|
||||||
}
|
}
|
||||||
@@ -147,19 +147,17 @@ func (k *Kong) interpolateValue(value *Value, vars Vars) (err error) {
|
|||||||
if len(value.Tag.Vars) > 0 {
|
if len(value.Tag.Vars) > 0 {
|
||||||
vars = vars.CloneWith(value.Tag.Vars)
|
vars = vars.CloneWith(value.Tag.Vars)
|
||||||
}
|
}
|
||||||
if value.Default, err = interpolate(value.Default, vars); err != nil {
|
if value.Default, err = interpolate(value.Default, vars, nil); err != nil {
|
||||||
return fmt.Errorf("default value for %s: %s", value.Summary(), err)
|
return fmt.Errorf("default value for %s: %s", value.Summary(), err)
|
||||||
}
|
}
|
||||||
if value.Enum, err = interpolate(value.Enum, vars); err != nil {
|
if value.Enum, err = interpolate(value.Enum, vars, nil); err != nil {
|
||||||
return fmt.Errorf("enum value for %s: %s", value.Summary(), err)
|
return fmt.Errorf("enum value for %s: %s", value.Summary(), err)
|
||||||
}
|
}
|
||||||
if vars["default"] != value.Default || vars["enum"] != value.Enum {
|
value.Help, err = interpolate(value.Help, vars, map[string]string{
|
||||||
vars = vars.CloneWith(map[string]string{
|
|
||||||
"default": value.Default,
|
"default": value.Default,
|
||||||
"enum": value.Enum,
|
"enum": value.Enum,
|
||||||
})
|
})
|
||||||
}
|
if err != nil {
|
||||||
if value.Help, err = interpolate(value.Help, vars); err != nil {
|
|
||||||
return fmt.Errorf("help for %s: %s", value.Summary(), err)
|
return fmt.Errorf("help for %s: %s", value.Summary(), err)
|
||||||
}
|
}
|
||||||
return nil
|
return nil
|
||||||
@@ -346,7 +344,7 @@ func (k *Kong) FatalIfErrorf(err error, args ...interface{}) {
|
|||||||
func (k *Kong) LoadConfig(path string) (Resolver, error) {
|
func (k *Kong) LoadConfig(path string) (Resolver, error) {
|
||||||
var err error
|
var err error
|
||||||
path = ExpandPath(path)
|
path = ExpandPath(path)
|
||||||
path, err = interpolate(path, k.vars)
|
path, err = interpolate(path, k.vars, nil)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user