// Linsk - A utility to access Linux-native file systems on non-Linux operating systems. // Copyright (c) 2023 The Linsk Authors. // // This program is free software: you can redistribute it and/or modify // it under the terms of the GNU General Public License as published by // the Free Software Foundation, either version 3 of the License, or // (at your option) any later version. // // This program is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the // GNU General Public License for more details. // // You should have received a copy of the GNU General Public License // along with this program. If not, see . package qemucli import ( "github.com/pkg/errors" ) type StringArg struct { key string value string } func MustNewStringArg(key string, value string) *StringArg { a, err := NewStringArg(key, value) if err != nil { panic(err) } return a } func NewStringArg(key string, value string) (*StringArg, error) { a := &StringArg{ key: key, value: value, } // Preflight arg key/type check. err := validateArgKey(a.key, a.ValueType()) if err != nil { return nil, errors.Wrap(err, "validate arg key") } err = validateArgStrValue(a.value) if err != nil { return nil, errors.Wrap(err, "validate str value") } return a, nil } func (a *StringArg) StringKey() string { return a.key } func (a *StringArg) StringValue() string { // We're not validating anything here because // we expect that the string value was validated // at the creation of the StringArg. return a.value } func (a *StringArg) ValueType() ArgAcceptedValue { return ArgAcceptedValueString }