// 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.