package pflag

import (
	
	
	
	
)

// -- stringToString Value
type stringToStringValue struct {
	value   *map[string]string
	changed bool
}

func newStringToStringValue( map[string]string,  *map[string]string) *stringToStringValue {
	 := new(stringToStringValue)
	.value = 
	*.value = 
	return 
}

// Format: a=1,b=2
func ( *stringToStringValue) ( string) error {
	var  []string
	 := strings.Count(, "=")
	switch  {
	case 0:
		return fmt.Errorf("%s must be formatted as key=value", )
	case 1:
		 = append(, strings.Trim(, `"`))
	default:
		 := csv.NewReader(strings.NewReader())
		var  error
		,  = .Read()
		if  != nil {
			return 
		}
	}

	 := make(map[string]string, len())
	for ,  := range  {
		 := strings.SplitN(, "=", 2)
		if len() != 2 {
			return fmt.Errorf("%s must be formatted as key=value", )
		}
		[[0]] = [1]
	}
	if !.changed {
		*.value = 
	} else {
		for ,  := range  {
			(*.value)[] = 
		}
	}
	.changed = true
	return nil
}

func ( *stringToStringValue) () string {
	return "stringToString"
}

func ( *stringToStringValue) () string {
	 := make([]string, 0, len(*.value)>>1)
	for ,  := range *.value {
		 = append(, +"="+)
	}

	var  bytes.Buffer
	 := csv.NewWriter(&)
	if  := .Write();  != nil {
		panic()
	}
	.Flush()
	return "[" + strings.TrimSpace(.String()) + "]"
}

func stringToStringConv( string) (interface{}, error) {
	 = strings.Trim(, "[]")
	// An empty string would cause an empty map
	if len() == 0 {
		return map[string]string{}, nil
	}
	 := csv.NewReader(strings.NewReader())
	,  := .Read()
	if  != nil {
		return nil, 
	}
	 := make(map[string]string, len())
	for ,  := range  {
		 := strings.SplitN(, "=", 2)
		if len() != 2 {
			return nil, fmt.Errorf("%s must be formatted as key=value", )
		}
		[[0]] = [1]
	}
	return , nil
}

// GetStringToString return the map[string]string value of a flag with the given name
func ( *FlagSet) ( string) (map[string]string, error) {
	,  := .getFlagType(, "stringToString", stringToStringConv)
	if  != nil {
		return map[string]string{}, 
	}
	return .(map[string]string), nil
}

// StringToStringVar defines a string flag with specified name, default value, and usage string.
// The argument p points to a map[string]string variable in which to store the values of the multiple flags.
// The value of each argument will not try to be separated by comma
func ( *FlagSet) ( *map[string]string,  string,  map[string]string,  string) {
	.VarP(newStringToStringValue(, ), , "", )
}

// StringToStringVarP is like StringToStringVar, but accepts a shorthand letter that can be used after a single dash.
func ( *FlagSet) ( *map[string]string, ,  string,  map[string]string,  string) {
	.VarP(newStringToStringValue(, ), , , )
}

// StringToStringVar defines a string flag with specified name, default value, and usage string.
// The argument p points to a map[string]string variable in which to store the value of the flag.
// The value of each argument will not try to be separated by comma
func ( *map[string]string,  string,  map[string]string,  string) {
	CommandLine.VarP(newStringToStringValue(, ), , "", )
}

// StringToStringVarP is like StringToStringVar, but accepts a shorthand letter that can be used after a single dash.
func ( *map[string]string, ,  string,  map[string]string,  string) {
	CommandLine.VarP(newStringToStringValue(, ), , , )
}

// StringToString defines a string flag with specified name, default value, and usage string.
// The return value is the address of a map[string]string variable that stores the value of the flag.
// The value of each argument will not try to be separated by comma
func ( *FlagSet) ( string,  map[string]string,  string) *map[string]string {
	 := map[string]string{}
	.StringToStringVarP(&, , "", , )
	return &
}

// StringToStringP is like StringToString, but accepts a shorthand letter that can be used after a single dash.
func ( *FlagSet) (,  string,  map[string]string,  string) *map[string]string {
	 := map[string]string{}
	.StringToStringVarP(&, , , , )
	return &
}

// StringToString defines a string flag with specified name, default value, and usage string.
// The return value is the address of a map[string]string variable that stores the value of the flag.
// The value of each argument will not try to be separated by comma
func ( string,  map[string]string,  string) *map[string]string {
	return CommandLine.StringToStringP(, "", , )
}

// StringToStringP is like StringToString, but accepts a shorthand letter that can be used after a single dash.
func (,  string,  map[string]string,  string) *map[string]string {
	return CommandLine.StringToStringP(, , , )
}