1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677 |
- // Copyright 2017 The Go Authors. All rights reserved.
- // Use of this source code is governed by a BSD-style
- // license that can be found in the LICENSE file.
- package number
- // TODO:
- // p.Printf("The gauge was at %v.", number.Spell(number.Percent(23)))
- // // Prints: The gauge was at twenty-three percent.
- //
- // p.Printf("From here to %v!", number.Spell(math.Inf()))
- // // Prints: From here to infinity!
- //
- import (
- "golang.org/x/text/internal/number"
- )
- const (
- decimalVerbs = "vfgd"
- scientificVerbs = "veg"
- )
- // Decimal formats a number as a floating point decimal.
- func Decimal(x interface{}, opts ...Option) Formatter {
- return newFormatter(decimalOptions, opts, x)
- }
- var decimalOptions = newOptions(decimalVerbs, (*number.Formatter).InitDecimal)
- // Scientific formats a number in scientific format.
- func Scientific(x interface{}, opts ...Option) Formatter {
- return newFormatter(scientificOptions, opts, x)
- }
- var scientificOptions = newOptions(scientificVerbs, (*number.Formatter).InitScientific)
- // Engineering formats a number using engineering notation, which is like
- // scientific notation, but with the exponent normalized to multiples of 3.
- func Engineering(x interface{}, opts ...Option) Formatter {
- return newFormatter(engineeringOptions, opts, x)
- }
- var engineeringOptions = newOptions(scientificVerbs, (*number.Formatter).InitEngineering)
- // Percent formats a number as a percentage. A value of 1.0 means 100%.
- func Percent(x interface{}, opts ...Option) Formatter {
- return newFormatter(percentOptions, opts, x)
- }
- var percentOptions = newOptions(decimalVerbs, (*number.Formatter).InitPercent)
- // PerMille formats a number as a per mille indication. A value of 1.0 means
- // 1000‰.
- func PerMille(x interface{}, opts ...Option) Formatter {
- return newFormatter(perMilleOptions, opts, x)
- }
- var perMilleOptions = newOptions(decimalVerbs, (*number.Formatter).InitPerMille)
- // TODO:
- // - Shortest: akin to verb 'g' of 'G'
- //
- // TODO: RBNF forms:
- // - Compact: 1M 3.5T
- // - CompactBinary: 1Mi 3.5Ti
- // - Long: 1 million
- // - Ordinal:
- // - Roman: MCMIIXX
- // - RomanSmall: mcmiixx
- // - Text: numbers as it typically appears in running text, allowing
- // language-specific choices for when to use numbers and when to use words.
- // - Spell?: spelled-out number. Maybe just allow as an option?
- // NOTE: both spelled-out numbers and ordinals, to render correctly, need
- // detailed linguistic information from the translated string into which they
- // are substituted. We will need to implement that first.
|