aboutsummaryrefslogtreecommitdiff
path: root/float32_slice.go
diff options
context:
space:
mode:
authortherealmitchconnors <[email protected]>2019-09-05 11:27:43 -0700
committertherealmitchconnors <[email protected]>2019-09-05 11:27:43 -0700
commitb22fc706c39eab8ef626dad18f21609425cc8714 (patch)
tree324d2c8c6d112bf4f9e44db15c760831cfb9347d /float32_slice.go
parentc6c0f0fd30b9b96d1c9a1cbf90799706bd501458 (diff)
Expand SliceValue support to all slice and array types.
Diffstat (limited to 'float32_slice.go')
-rw-r--r--float32_slice.go42
1 files changed, 42 insertions, 0 deletions
diff --git a/float32_slice.go b/float32_slice.go
index a80848a..caa3527 100644
--- a/float32_slice.go
+++ b/float32_slice.go
@@ -53,6 +53,48 @@ func (s *float32SliceValue) String() string {
return "[" + strings.Join(out, ",") + "]"
}
+func (s *float32SliceValue) fromString(val string) (float32, error) {
+ t64, err := strconv.ParseFloat(val, 32)
+ if err != nil {
+ return 0, err
+ }
+ return float32(t64), nil
+}
+
+func (s *float32SliceValue) toString(val float32) string {
+ return fmt.Sprintf("%f", val)
+}
+
+func (s *float32SliceValue) Append(val string) error {
+ i, err := s.fromString(val)
+ if err != nil {
+ return err
+ }
+ *s.value = append(*s.value, i)
+ return nil
+}
+
+func (s *float32SliceValue) Replace(val []string) error {
+ out := make([]float32, len(val))
+ for i, d := range val {
+ var err error
+ out[i], err = s.fromString(d)
+ if err != nil {
+ return err
+ }
+ }
+ *s.value = out
+ return nil
+}
+
+func (s *float32SliceValue) GetSlice() []string {
+ out := make([]string, len(*s.value))
+ for i, d := range *s.value {
+ out[i] = s.toString(d)
+ }
+ return out
+}
+
func float32SliceConv(val string) (interface{}, error) {
val = strings.Trim(val, "[]")
// Empty string would cause a slice with one (empty) entry