diff options
| author | sam-anthony <samanthony6@protonmail.com> | 2022-03-26 14:51:43 -0230 |
|---|---|---|
| committer | sam-anthony <samanthony6@protonmail.com> | 2022-03-26 14:51:43 -0230 |
| commit | 713b65d414e327db7b530ce0be8403bc0ff4ff3b (patch) | |
| tree | 6e4a32fb43ca3e5b26d9cfb61c693ffd76391796 /volume.go | |
| parent | 16235e23bda445f0bd0b664c3738c77e786a1cbf (diff) | |
| download | volute-713b65d414e327db7b530ce0be8403bc0ff4ff3b.zip | |
engine displacement
Diffstat (limited to 'volume.go')
| -rw-r--r-- | volume.go | 54 |
1 files changed, 54 insertions, 0 deletions
diff --git a/volume.go b/volume.go new file mode 100644 index 0000000..cb7098a --- /dev/null +++ b/volume.go @@ -0,0 +1,54 @@ +package main + +import ( + "errors" + "fmt" +) + +type volumeUnit float32 + +const ( + cubicCentimetre volumeUnit = 1 + litre volumeUnit = 1_000 + cubicMetre volumeUnit = 1_000_000 + cubicInch volumeUnit = 16.38706 +) + +// volumeUnitStrings returns a slice of strings, each representing a +// volumeUnit. +// This is necessary because giu.Combo only works with strings. +func volumeUnitStrings() []string { + return []string{"cc", "L", "m³", "in³"} +} + +const ( + defaultVolumeUnit volumeUnit = cubicCentimetre + // Used to index volumeUnitStrings + defaultVolumeUnitIndex int32 = 0 // cc +) + +func volumeUnitFromString(s string) (volumeUnit, error) { + // Each case corresponds to a value in volumeUnitStrings + switch s { + case "cc": + return cubicCentimetre, nil + case "L": + return litre, nil + case "m³": + return cubicMetre, nil + case "in³": + return cubicInch, nil + default: + return *new(volumeUnit), errors.New(fmt.Sprintf("invalid volumeUnit: '%s'", s)) + } +} + +type volume struct { + val float32 + unit volumeUnit +} + +func (v volume) asUnit(u volumeUnit) float32 { + cc := v.val * float32(v.unit) // Convert to cubic centimetres. + return cc / float32(u) // Convert to desired unit. +} |