...

Source file src/github.com/go-playground/locales/hy/hy.go

Documentation: github.com/go-playground/locales/hy

     1  package hy
     2  
     3  import (
     4  	"math"
     5  	"strconv"
     6  	"time"
     7  
     8  	"github.com/go-playground/locales"
     9  	"github.com/go-playground/locales/currency"
    10  )
    11  
    12  type hy struct {
    13  	locale                 string
    14  	pluralsCardinal        []locales.PluralRule
    15  	pluralsOrdinal         []locales.PluralRule
    16  	pluralsRange           []locales.PluralRule
    17  	decimal                string
    18  	group                  string
    19  	minus                  string
    20  	percent                string
    21  	perMille               string
    22  	timeSeparator          string
    23  	inifinity              string
    24  	currencies             []string // idx = enum of currency code
    25  	currencyPositiveSuffix string
    26  	currencyNegativeSuffix string
    27  	monthsAbbreviated      []string
    28  	monthsNarrow           []string
    29  	monthsWide             []string
    30  	daysAbbreviated        []string
    31  	daysNarrow             []string
    32  	daysShort              []string
    33  	daysWide               []string
    34  	periodsAbbreviated     []string
    35  	periodsNarrow          []string
    36  	periodsShort           []string
    37  	periodsWide            []string
    38  	erasAbbreviated        []string
    39  	erasNarrow             []string
    40  	erasWide               []string
    41  	timezones              map[string]string
    42  }
    43  
    44  // New returns a new instance of translator for the 'hy' locale
    45  func New() locales.Translator {
    46  	return &hy{
    47  		locale:                 "hy",
    48  		pluralsCardinal:        []locales.PluralRule{2, 6},
    49  		pluralsOrdinal:         []locales.PluralRule{2, 6},
    50  		pluralsRange:           []locales.PluralRule{2, 6},
    51  		decimal:                ",",
    52  		group:                  " ",
    53  		minus:                  "-",
    54  		percent:                "%",
    55  		perMille:               "‰",
    56  		timeSeparator:          ":",
    57  		inifinity:              "∞",
    58  		currencies:             []string{"ADP", "AED", "AFA", "AFN", "ALK", "ALL", "֏", "ANG", "AOA", "AOK", "AON", "AOR", "ARA", "ARL", "ARM", "ARP", "ARS", "ATS", "A$", "AWG", "AZM", "AZN", "BAD", "BAM", "BAN", "BBD", "BDT", "BEC", "BEF", "BEL", "BGL", "BGM", "BGN", "BGO", "BHD", "BIF", "BMD", "BND", "BOB", "BOL", "BOP", "BOV", "BRB", "BRC", "BRE", "R$", "BRN", "BRR", "BRZ", "BSD", "BTN", "BUK", "BWP", "BYB", "BYN", "BYR", "BZD", "CA$", "CDF", "CHE", "CHF", "CHW", "CLE", "CLF", "CLP", "CNH", "CNX", "CN¥", "COP", "COU", "CRC", "CSD", "CSK", "CUC", "CUP", "CVE", "CYP", "CZK", "DDM", "DEM", "DJF", "DKK", "DOP", "DZD", "ECS", "ECV", "EEK", "EGP", "ERN", "ESA", "ESB", "ESP", "ETB", "€", "FIM", "FJD", "FKP", "FRF", "£", "GEK", "GEL", "GHC", "GHS", "GIP", "GMD", "GNF", "GNS", "GQE", "GRD", "GTQ", "GWE", "GWP", "GYD", "HK$", "HNL", "HRD", "HRK", "HTG", "HUF", "IDR", "IEP", "ILP", "ILR", "₪", "₹", "IQD", "IRR", "ISJ", "ISK", "ITL", "JMD", "JOD", "JP¥", "KES", "KGS", "KHR", "KMF", "KPW", "KRH", "KRO", "₩", "KWD", "KYD", "KZT", "LAK", "LBP", "LKR", "LRD", "LSL", "LTL", "LTT", "LUC", "LUF", "LUL", "LVL", "LVR", "LYD", "MAD", "MAF", "MCF", "MDC", "MDL", "MGA", "MGF", "MKD", "MKN", "MLF", "MMK", "MNT", "MOP", "MRO", "MRU", "MTL", "MTP", "MUR", "MVP", "MVR", "MWK", "MX$", "MXP", "MXV", "MYR", "MZE", "MZM", "MZN", "NAD", "NGN", "NIC", "NIO", "NLG", "NOK", "NPR", "NZ$", "OMR", "PAB", "PEI", "PEN", "PES", "PGK", "PHP", "PKR", "PLN", "PLZ", "PTE", "PYG", "QAR", "RHD", "ROL", "RON", "RSD", "RUB", "RUR", "RWF", "SAR", "SBD", "SCR", "SDD", "SDG", "SDP", "SEK", "SGD", "SHP", "SIT", "SKK", "SLL", "SOS", "SRD", "SRG", "SSP", "STD", "STN", "SUR", "SVC", "SYP", "SZL", "฿", "TJR", "TJS", "TMM", "TMT", "TND", "TOP", "TPE", "TRL", "TRY", "TTD", "NT$", "TZS", "UAH", "UAK", "UGS", "UGX", "$", "USN", "USS", "UYI", "UYP", "UYU", "UYW", "UZS", "VEB", "VEF", "VES", "₫", "VNN", "VUV", "WST", "FCFA", "XAG", "XAU", "XBA", "XBB", "XBC", "XBD", "EC$", "XDR", "XEU", "XFO", "XFU", "CFA", "XPD", "CFPF", "XPT", "XRE", "XSU", "XTS", "XUA", "XXX", "YDD", "YER", "YUD", "YUM", "YUN", "YUR", "ZAL", "ZAR", "ZMK", "ZMW", "ZRN", "ZRZ", "ZWD", "ZWL", "ZWR"},
    59  		currencyPositiveSuffix: " ",
    60  		currencyNegativeSuffix: " ",
    61  		monthsAbbreviated:      []string{"", "հնվ", "փտվ", "մրտ", "ապր", "մյս", "հնս", "հլս", "օգս", "սեպ", "հոկ", "նոյ", "դեկ"},
    62  		monthsNarrow:           []string{"", "Հ", "Փ", "Մ", "Ա", "Մ", "Հ", "Հ", "Օ", "Ս", "Հ", "Ն", "Դ"},
    63  		monthsWide:             []string{"", "հունվարի", "փետրվարի", "մարտի", "ապրիլի", "մայիսի", "հունիսի", "հուլիսի", "օգոստոսի", "սեպտեմբերի", "հոկտեմբերի", "նոյեմբերի", "դեկտեմբերի"},
    64  		daysAbbreviated:        []string{"կիր", "երկ", "երք", "չրք", "հնգ", "ուր", "շբթ"},
    65  		daysNarrow:             []string{"Կ", "Ե", "Ե", "Չ", "Հ", "Ո", "Շ"},
    66  		daysShort:              []string{"կր", "եկ", "եք", "չք", "հգ", "ու", "շբ"},
    67  		daysWide:               []string{"կիրակի", "երկուշաբթի", "երեքշաբթի", "չորեքշաբթի", "հինգշաբթի", "ուրբաթ", "շաբաթ"},
    68  		periodsAbbreviated:     []string{"AM", "PM"},
    69  		periodsNarrow:          []string{"ա", "հ"},
    70  		periodsWide:            []string{"AM", "PM"},
    71  		erasAbbreviated:        []string{"մ.թ.ա.", "մ.թ."},
    72  		erasNarrow:             []string{"", ""},
    73  		erasWide:               []string{"Քրիստոսից առաջ", "Քրիստոսից հետո"},
    74  		timezones:              map[string]string{"ACDT": "Կենտրոնական Ավստրալիայի ամառային ժամանակ", "ACST": "Կենտրոնական Ավստրալիայի ստանդարտ ժամանակ", "ACWDT": "Կենտրոնական Ավստրալիայի արևմտյան ամառային ժամանակ", "ACWST": "Կենտրոնական Ավստրալիայի արևմտյան ստանդարտ ժամանակ", "ADT": "Ատլանտյան ամառային ժամանակ", "AEDT": "Արևելյան Ավստրալիայի ամառային ժամանակ", "AEST": "Արևելյան Ավստրալիայի ստանդարտ ժամանակ", "AKDT": "Ալյասկայի ամառային ժամանակ", "AKST": "Ալյասկայի ստանդարտ ժամանակ", "ARST": "Արգենտինայի ամառային ժամանակ", "ART": "Արգենտինայի ստնադարտ ժամանակ", "AST": "Ատլանտյան ստանդարտ ժամանակ", "AWDT": "Արևմտյան Ավստրալիայի ամառային ժամանակ", "AWST": "Արևմտյան Ավստրալիայի ստանդարտ ժամանակ", "BOT": "Բոլիվիայի ժամանակ", "BT": "Բութանի ժամանակ", "CAT": "Կենտրոնական Աֆրիկայի ժամանակ", "CDT": "Կենտրոնական Ամերիկայի ամառային ժամանակ", "CHADT": "Չաթեմ կղզու ամառային ժամանակ", "CHAST": "Չաթեմ կղզու ստանդարտ ժամանակ", "CLST": "Չիլիի ամառային ժամանակ", "CLT": "Չիլիի ստանդարտ ժամանակ", "COST": "Կոլումբիայի ամառային ժամանակ", "COT": "Կոլումբիայի ստանդարտ ժամանակ", "CST": "Կենտրոնական Ամերիկայի ստանդարտ ժամանակ", "ChST": "Չամոռոյի ժամանակ", "EAT": "Արևելյան Աֆրիկայի ժամանակ", "ECT": "Էկվադորի ժամանակ", "EDT": "Արևելյան Ամերիկայի ամառային ժամանակ", "EST": "Արևելյան Ամերիկայի ստանդարտ ժամանակ", "GFT": "Ֆրանսիական Գվիանայի ժամանակ", "GMT": "Գրինվիչի ժամանակ", "GST": "Պարսից ծոցի ստանդարտ ժամանակ", "GYT": "Գայանայի ժամանակ", "HADT": "Հավայան-ալեության ամառային ժամանակ", "HAST": "Հավայան-ալեության ստանդարտ ժամանակ", "HAT": "Նյուֆաունդլենդի ամառային ժամանակ", "HECU": "Կուբայի ամառային ժամանակ", "HEEG": "Արևելյան Գրենլանդիայի ամառային ժամանակ", "HENOMX": "Հյուսիսարևմտյան Մեքսիկայի ամառային ժամանակ", "HEOG": "Արևմտյան Գրենլանդիայի ամառային ժամանակ", "HEPM": "Սեն Պիեռ և Միքելոնի ամառային ժամանակ", "HEPMX": "Մեքսիկայի խաղաղօվկիանոսյան ամառային ժամանակ", "HKST": "Հոնկոնգի ամառային ժամանակ", "HKT": "Հոնկոնգի ստանդարտ ժամանակ", "HNCU": "Կուբայի ստանդարտ ժամանակ", "HNEG": "Արևելյան Գրենլանդիայի ստանդարտ ժամանակ", "HNNOMX": "Հյուսիսարևմտյան Մեքսիկայի ստանդարտ ժամանակ", "HNOG": "Արևմտյան Գրենլանդիայի ստանդարտ ժամանակ", "HNPM": "Սեն Պիեռ և Միքելոնի ստանդարտ ժամանակ", "HNPMX": "Մեքսիկայի խաղաղօվկիանոսյան ստանդարտ ժամանակ", "HNT": "Նյուֆաունդլենդի ստանդարտ ժամանակ", "IST": "Հնդկաստանի ստանդարտ ժամանակ", "JDT": "Ճապոնիայի ամառային ժամանակ", "JST": "Ճապոնիայի ստանդարտ ժամանակ", "LHDT": "Լորդ Հաուի ամառային ժամանակ", "LHST": "Լորդ Հաուի ստանդարտ ժամանակ", "MDT": "Լեռնային ամառային ժամանակ (ԱՄՆ)", "MESZ": "Կենտրոնական Եվրոպայի ամառային ժամանակ", "MEZ": "Կենտրոնական Եվրոպայի ստանդարտ ժամանակ", "MST": "Լեռնային ստանդարտ ժամանակ (ԱՄՆ)", "MYT": "Մալայզիայի ժամանակ", "NZDT": "Նոր Զելանդիայի ամառային ժամանակ", "NZST": "Նոր Զելանդիայի ստանդարտ ժամանակ", "OESZ": "Արևելյան Եվրոպայի ամառային ժամանակ", "OEZ": "Արևելյան Եվրոպայի ստանդարտ ժամանակ", "PDT": "Խաղաղօվկիանոսյան ամառային ժամանակ", "PST": "Խաղաղօվկիանոսյան ստանդարտ ժամանակ", "SAST": "Հարավային Աֆրիկայի ժամանակ", "SGT": "Սինգապուրի ժամանակ", "SRT": "Սուրինամի ժամանակ", "TMST": "Թուրքմենստանի ամառային ժամանակ", "TMT": "Թուրքմենստանի ստանդարտ ժամանակ", "UYST": "Ուրուգվայի ամառային ժամանակ", "UYT": "Ուրուգվայի ստանդարտ ժամանակ", "VET": "Վենեսուելայի ժամանակ", "WARST": "Արևմտյան Արգենտինայի ամառային ժամանակ", "WART": "Արևմտյան Արգենտինայի ստնադարտ ժամանակ", "WAST": "Արևմտյան Աֆրիկայի ամառային ժամանակ", "WAT": "Արևմտյան Աֆրիկայի ստանդարտ ժամանակ", "WESZ": "Արևմտյան Եվրոպայի ամառային ժամանակ", "WEZ": "Արևմտյան Եվրոպայի ստանդարտ ժամանակ", "WIB": "Արևմտյան Ինդոնեզիայի ժամանակ", "WIT": "Արևելյան Ինդոնեզիայի ժամանակ", "WITA": "Կենտրոնական Ինդոնեզիայի ժամանակ", "∅∅∅": "Ամազոնյան ամառային ժամանակ"},
    75  	}
    76  }
    77  
    78  // Locale returns the current translators string locale
    79  func (hy *hy) Locale() string {
    80  	return hy.locale
    81  }
    82  
    83  // PluralsCardinal returns the list of cardinal plural rules associated with 'hy'
    84  func (hy *hy) PluralsCardinal() []locales.PluralRule {
    85  	return hy.pluralsCardinal
    86  }
    87  
    88  // PluralsOrdinal returns the list of ordinal plural rules associated with 'hy'
    89  func (hy *hy) PluralsOrdinal() []locales.PluralRule {
    90  	return hy.pluralsOrdinal
    91  }
    92  
    93  // PluralsRange returns the list of range plural rules associated with 'hy'
    94  func (hy *hy) PluralsRange() []locales.PluralRule {
    95  	return hy.pluralsRange
    96  }
    97  
    98  // CardinalPluralRule returns the cardinal PluralRule given 'num' and digits/precision of 'v' for 'hy'
    99  func (hy *hy) CardinalPluralRule(num float64, v uint64) locales.PluralRule {
   100  
   101  	n := math.Abs(num)
   102  	i := int64(n)
   103  
   104  	if i == 0 || i == 1 {
   105  		return locales.PluralRuleOne
   106  	}
   107  
   108  	return locales.PluralRuleOther
   109  }
   110  
   111  // OrdinalPluralRule returns the ordinal PluralRule given 'num' and digits/precision of 'v' for 'hy'
   112  func (hy *hy) OrdinalPluralRule(num float64, v uint64) locales.PluralRule {
   113  
   114  	n := math.Abs(num)
   115  
   116  	if n == 1 {
   117  		return locales.PluralRuleOne
   118  	}
   119  
   120  	return locales.PluralRuleOther
   121  }
   122  
   123  // RangePluralRule returns the ordinal PluralRule given 'num1', 'num2' and digits/precision of 'v1' and 'v2' for 'hy'
   124  func (hy *hy) RangePluralRule(num1 float64, v1 uint64, num2 float64, v2 uint64) locales.PluralRule {
   125  
   126  	start := hy.CardinalPluralRule(num1, v1)
   127  	end := hy.CardinalPluralRule(num2, v2)
   128  
   129  	if start == locales.PluralRuleOne && end == locales.PluralRuleOne {
   130  		return locales.PluralRuleOne
   131  	} else if start == locales.PluralRuleOne && end == locales.PluralRuleOther {
   132  		return locales.PluralRuleOther
   133  	}
   134  
   135  	return locales.PluralRuleOther
   136  
   137  }
   138  
   139  // MonthAbbreviated returns the locales abbreviated month given the 'month' provided
   140  func (hy *hy) MonthAbbreviated(month time.Month) string {
   141  	return hy.monthsAbbreviated[month]
   142  }
   143  
   144  // MonthsAbbreviated returns the locales abbreviated months
   145  func (hy *hy) MonthsAbbreviated() []string {
   146  	return hy.monthsAbbreviated[1:]
   147  }
   148  
   149  // MonthNarrow returns the locales narrow month given the 'month' provided
   150  func (hy *hy) MonthNarrow(month time.Month) string {
   151  	return hy.monthsNarrow[month]
   152  }
   153  
   154  // MonthsNarrow returns the locales narrow months
   155  func (hy *hy) MonthsNarrow() []string {
   156  	return hy.monthsNarrow[1:]
   157  }
   158  
   159  // MonthWide returns the locales wide month given the 'month' provided
   160  func (hy *hy) MonthWide(month time.Month) string {
   161  	return hy.monthsWide[month]
   162  }
   163  
   164  // MonthsWide returns the locales wide months
   165  func (hy *hy) MonthsWide() []string {
   166  	return hy.monthsWide[1:]
   167  }
   168  
   169  // WeekdayAbbreviated returns the locales abbreviated weekday given the 'weekday' provided
   170  func (hy *hy) WeekdayAbbreviated(weekday time.Weekday) string {
   171  	return hy.daysAbbreviated[weekday]
   172  }
   173  
   174  // WeekdaysAbbreviated returns the locales abbreviated weekdays
   175  func (hy *hy) WeekdaysAbbreviated() []string {
   176  	return hy.daysAbbreviated
   177  }
   178  
   179  // WeekdayNarrow returns the locales narrow weekday given the 'weekday' provided
   180  func (hy *hy) WeekdayNarrow(weekday time.Weekday) string {
   181  	return hy.daysNarrow[weekday]
   182  }
   183  
   184  // WeekdaysNarrow returns the locales narrow weekdays
   185  func (hy *hy) WeekdaysNarrow() []string {
   186  	return hy.daysNarrow
   187  }
   188  
   189  // WeekdayShort returns the locales short weekday given the 'weekday' provided
   190  func (hy *hy) WeekdayShort(weekday time.Weekday) string {
   191  	return hy.daysShort[weekday]
   192  }
   193  
   194  // WeekdaysShort returns the locales short weekdays
   195  func (hy *hy) WeekdaysShort() []string {
   196  	return hy.daysShort
   197  }
   198  
   199  // WeekdayWide returns the locales wide weekday given the 'weekday' provided
   200  func (hy *hy) WeekdayWide(weekday time.Weekday) string {
   201  	return hy.daysWide[weekday]
   202  }
   203  
   204  // WeekdaysWide returns the locales wide weekdays
   205  func (hy *hy) WeekdaysWide() []string {
   206  	return hy.daysWide
   207  }
   208  
   209  // Decimal returns the decimal point of number
   210  func (hy *hy) Decimal() string {
   211  	return hy.decimal
   212  }
   213  
   214  // Group returns the group of number
   215  func (hy *hy) Group() string {
   216  	return hy.group
   217  }
   218  
   219  // Group returns the minus sign of number
   220  func (hy *hy) Minus() string {
   221  	return hy.minus
   222  }
   223  
   224  // FmtNumber returns 'num' with digits/precision of 'v' for 'hy' and handles both Whole and Real numbers based on 'v'
   225  func (hy *hy) FmtNumber(num float64, v uint64) string {
   226  
   227  	s := strconv.FormatFloat(math.Abs(num), 'f', int(v), 64)
   228  	l := len(s) + 2 + 2*len(s[:len(s)-int(v)-1])/3
   229  	count := 0
   230  	inWhole := v == 0
   231  	b := make([]byte, 0, l)
   232  
   233  	for i := len(s) - 1; i >= 0; i-- {
   234  
   235  		if s[i] == '.' {
   236  			b = append(b, hy.decimal[0])
   237  			inWhole = true
   238  			continue
   239  		}
   240  
   241  		if inWhole {
   242  			if count == 3 {
   243  				for j := len(hy.group) - 1; j >= 0; j-- {
   244  					b = append(b, hy.group[j])
   245  				}
   246  				count = 1
   247  			} else {
   248  				count++
   249  			}
   250  		}
   251  
   252  		b = append(b, s[i])
   253  	}
   254  
   255  	if num < 0 {
   256  		b = append(b, hy.minus[0])
   257  	}
   258  
   259  	// reverse
   260  	for i, j := 0, len(b)-1; i < j; i, j = i+1, j-1 {
   261  		b[i], b[j] = b[j], b[i]
   262  	}
   263  
   264  	return string(b)
   265  }
   266  
   267  // FmtPercent returns 'num' with digits/precision of 'v' for 'hy' and handles both Whole and Real numbers based on 'v'
   268  // NOTE: 'num' passed into FmtPercent is assumed to be in percent already
   269  func (hy *hy) FmtPercent(num float64, v uint64) string {
   270  	s := strconv.FormatFloat(math.Abs(num), 'f', int(v), 64)
   271  	l := len(s) + 3
   272  	b := make([]byte, 0, l)
   273  
   274  	for i := len(s) - 1; i >= 0; i-- {
   275  
   276  		if s[i] == '.' {
   277  			b = append(b, hy.decimal[0])
   278  			continue
   279  		}
   280  
   281  		b = append(b, s[i])
   282  	}
   283  
   284  	if num < 0 {
   285  		b = append(b, hy.minus[0])
   286  	}
   287  
   288  	// reverse
   289  	for i, j := 0, len(b)-1; i < j; i, j = i+1, j-1 {
   290  		b[i], b[j] = b[j], b[i]
   291  	}
   292  
   293  	b = append(b, hy.percent...)
   294  
   295  	return string(b)
   296  }
   297  
   298  // FmtCurrency returns the currency representation of 'num' with digits/precision of 'v' for 'hy'
   299  func (hy *hy) FmtCurrency(num float64, v uint64, currency currency.Type) string {
   300  
   301  	s := strconv.FormatFloat(math.Abs(num), 'f', int(v), 64)
   302  	symbol := hy.currencies[currency]
   303  	l := len(s) + len(symbol) + 4 + 2*len(s[:len(s)-int(v)-1])/3
   304  	count := 0
   305  	inWhole := v == 0
   306  	b := make([]byte, 0, l)
   307  
   308  	for i := len(s) - 1; i >= 0; i-- {
   309  
   310  		if s[i] == '.' {
   311  			b = append(b, hy.decimal[0])
   312  			inWhole = true
   313  			continue
   314  		}
   315  
   316  		if inWhole {
   317  			if count == 3 {
   318  				for j := len(hy.group) - 1; j >= 0; j-- {
   319  					b = append(b, hy.group[j])
   320  				}
   321  				count = 1
   322  			} else {
   323  				count++
   324  			}
   325  		}
   326  
   327  		b = append(b, s[i])
   328  	}
   329  
   330  	if num < 0 {
   331  		b = append(b, hy.minus[0])
   332  	}
   333  
   334  	// reverse
   335  	for i, j := 0, len(b)-1; i < j; i, j = i+1, j-1 {
   336  		b[i], b[j] = b[j], b[i]
   337  	}
   338  
   339  	if int(v) < 2 {
   340  
   341  		if v == 0 {
   342  			b = append(b, hy.decimal...)
   343  		}
   344  
   345  		for i := 0; i < 2-int(v); i++ {
   346  			b = append(b, '0')
   347  		}
   348  	}
   349  
   350  	b = append(b, hy.currencyPositiveSuffix...)
   351  
   352  	b = append(b, symbol...)
   353  
   354  	return string(b)
   355  }
   356  
   357  // FmtAccounting returns the currency representation of 'num' with digits/precision of 'v' for 'hy'
   358  // in accounting notation.
   359  func (hy *hy) FmtAccounting(num float64, v uint64, currency currency.Type) string {
   360  
   361  	s := strconv.FormatFloat(math.Abs(num), 'f', int(v), 64)
   362  	symbol := hy.currencies[currency]
   363  	l := len(s) + len(symbol) + 4 + 2*len(s[:len(s)-int(v)-1])/3
   364  	count := 0
   365  	inWhole := v == 0
   366  	b := make([]byte, 0, l)
   367  
   368  	for i := len(s) - 1; i >= 0; i-- {
   369  
   370  		if s[i] == '.' {
   371  			b = append(b, hy.decimal[0])
   372  			inWhole = true
   373  			continue
   374  		}
   375  
   376  		if inWhole {
   377  			if count == 3 {
   378  				for j := len(hy.group) - 1; j >= 0; j-- {
   379  					b = append(b, hy.group[j])
   380  				}
   381  				count = 1
   382  			} else {
   383  				count++
   384  			}
   385  		}
   386  
   387  		b = append(b, s[i])
   388  	}
   389  
   390  	if num < 0 {
   391  
   392  		b = append(b, hy.minus[0])
   393  
   394  	}
   395  
   396  	// reverse
   397  	for i, j := 0, len(b)-1; i < j; i, j = i+1, j-1 {
   398  		b[i], b[j] = b[j], b[i]
   399  	}
   400  
   401  	if int(v) < 2 {
   402  
   403  		if v == 0 {
   404  			b = append(b, hy.decimal...)
   405  		}
   406  
   407  		for i := 0; i < 2-int(v); i++ {
   408  			b = append(b, '0')
   409  		}
   410  	}
   411  
   412  	if num < 0 {
   413  		b = append(b, hy.currencyNegativeSuffix...)
   414  		b = append(b, symbol...)
   415  	} else {
   416  
   417  		b = append(b, hy.currencyPositiveSuffix...)
   418  		b = append(b, symbol...)
   419  	}
   420  
   421  	return string(b)
   422  }
   423  
   424  // FmtDateShort returns the short date representation of 't' for 'hy'
   425  func (hy *hy) FmtDateShort(t time.Time) string {
   426  
   427  	b := make([]byte, 0, 32)
   428  
   429  	if t.Day() < 10 {
   430  		b = append(b, '0')
   431  	}
   432  
   433  	b = strconv.AppendInt(b, int64(t.Day()), 10)
   434  	b = append(b, []byte{0x2e}...)
   435  
   436  	if t.Month() < 10 {
   437  		b = append(b, '0')
   438  	}
   439  
   440  	b = strconv.AppendInt(b, int64(t.Month()), 10)
   441  
   442  	b = append(b, []byte{0x2e}...)
   443  
   444  	if t.Year() > 9 {
   445  		b = append(b, strconv.Itoa(t.Year())[2:]...)
   446  	} else {
   447  		b = append(b, strconv.Itoa(t.Year())[1:]...)
   448  	}
   449  
   450  	return string(b)
   451  }
   452  
   453  // FmtDateMedium returns the medium date representation of 't' for 'hy'
   454  func (hy *hy) FmtDateMedium(t time.Time) string {
   455  
   456  	b := make([]byte, 0, 32)
   457  
   458  	if t.Day() < 10 {
   459  		b = append(b, '0')
   460  	}
   461  
   462  	b = strconv.AppendInt(b, int64(t.Day()), 10)
   463  	b = append(b, []byte{0x20}...)
   464  	b = append(b, hy.monthsAbbreviated[t.Month()]...)
   465  	b = append(b, []byte{0x2c, 0x20}...)
   466  
   467  	if t.Year() > 0 {
   468  		b = strconv.AppendInt(b, int64(t.Year()), 10)
   469  	} else {
   470  		b = strconv.AppendInt(b, int64(-t.Year()), 10)
   471  	}
   472  
   473  	b = append(b, []byte{0x20, 0xd5, 0xa9, 0x2e}...)
   474  
   475  	return string(b)
   476  }
   477  
   478  // FmtDateLong returns the long date representation of 't' for 'hy'
   479  func (hy *hy) FmtDateLong(t time.Time) string {
   480  
   481  	b := make([]byte, 0, 32)
   482  
   483  	if t.Day() < 10 {
   484  		b = append(b, '0')
   485  	}
   486  
   487  	b = strconv.AppendInt(b, int64(t.Day()), 10)
   488  	b = append(b, []byte{0x20}...)
   489  	b = append(b, hy.monthsWide[t.Month()]...)
   490  	b = append(b, []byte{0x2c, 0x20}...)
   491  
   492  	if t.Year() > 0 {
   493  		b = strconv.AppendInt(b, int64(t.Year()), 10)
   494  	} else {
   495  		b = strconv.AppendInt(b, int64(-t.Year()), 10)
   496  	}
   497  
   498  	b = append(b, []byte{0x20, 0xd5, 0xa9, 0x2e}...)
   499  
   500  	return string(b)
   501  }
   502  
   503  // FmtDateFull returns the full date representation of 't' for 'hy'
   504  func (hy *hy) FmtDateFull(t time.Time) string {
   505  
   506  	b := make([]byte, 0, 32)
   507  
   508  	if t.Year() > 0 {
   509  		b = strconv.AppendInt(b, int64(t.Year()), 10)
   510  	} else {
   511  		b = strconv.AppendInt(b, int64(-t.Year()), 10)
   512  	}
   513  
   514  	b = append(b, []byte{0x20, 0xd5, 0xa9, 0x2e, 0x20}...)
   515  	b = append(b, hy.monthsWide[t.Month()]...)
   516  	b = append(b, []byte{0x20}...)
   517  	b = strconv.AppendInt(b, int64(t.Day()), 10)
   518  	b = append(b, []byte{0x2c, 0x20}...)
   519  	b = append(b, hy.daysWide[t.Weekday()]...)
   520  
   521  	return string(b)
   522  }
   523  
   524  // FmtTimeShort returns the short time representation of 't' for 'hy'
   525  func (hy *hy) FmtTimeShort(t time.Time) string {
   526  
   527  	b := make([]byte, 0, 32)
   528  
   529  	if t.Hour() < 10 {
   530  		b = append(b, '0')
   531  	}
   532  
   533  	b = strconv.AppendInt(b, int64(t.Hour()), 10)
   534  	b = append(b, hy.timeSeparator...)
   535  
   536  	if t.Minute() < 10 {
   537  		b = append(b, '0')
   538  	}
   539  
   540  	b = strconv.AppendInt(b, int64(t.Minute()), 10)
   541  
   542  	return string(b)
   543  }
   544  
   545  // FmtTimeMedium returns the medium time representation of 't' for 'hy'
   546  func (hy *hy) FmtTimeMedium(t time.Time) string {
   547  
   548  	b := make([]byte, 0, 32)
   549  
   550  	if t.Hour() < 10 {
   551  		b = append(b, '0')
   552  	}
   553  
   554  	b = strconv.AppendInt(b, int64(t.Hour()), 10)
   555  	b = append(b, hy.timeSeparator...)
   556  
   557  	if t.Minute() < 10 {
   558  		b = append(b, '0')
   559  	}
   560  
   561  	b = strconv.AppendInt(b, int64(t.Minute()), 10)
   562  	b = append(b, hy.timeSeparator...)
   563  
   564  	if t.Second() < 10 {
   565  		b = append(b, '0')
   566  	}
   567  
   568  	b = strconv.AppendInt(b, int64(t.Second()), 10)
   569  
   570  	return string(b)
   571  }
   572  
   573  // FmtTimeLong returns the long time representation of 't' for 'hy'
   574  func (hy *hy) FmtTimeLong(t time.Time) string {
   575  
   576  	b := make([]byte, 0, 32)
   577  
   578  	if t.Hour() < 10 {
   579  		b = append(b, '0')
   580  	}
   581  
   582  	b = strconv.AppendInt(b, int64(t.Hour()), 10)
   583  	b = append(b, hy.timeSeparator...)
   584  
   585  	if t.Minute() < 10 {
   586  		b = append(b, '0')
   587  	}
   588  
   589  	b = strconv.AppendInt(b, int64(t.Minute()), 10)
   590  	b = append(b, hy.timeSeparator...)
   591  
   592  	if t.Second() < 10 {
   593  		b = append(b, '0')
   594  	}
   595  
   596  	b = strconv.AppendInt(b, int64(t.Second()), 10)
   597  	b = append(b, []byte{0x20}...)
   598  
   599  	tz, _ := t.Zone()
   600  	b = append(b, tz...)
   601  
   602  	return string(b)
   603  }
   604  
   605  // FmtTimeFull returns the full time representation of 't' for 'hy'
   606  func (hy *hy) FmtTimeFull(t time.Time) string {
   607  
   608  	b := make([]byte, 0, 32)
   609  
   610  	if t.Hour() < 10 {
   611  		b = append(b, '0')
   612  	}
   613  
   614  	b = strconv.AppendInt(b, int64(t.Hour()), 10)
   615  	b = append(b, hy.timeSeparator...)
   616  
   617  	if t.Minute() < 10 {
   618  		b = append(b, '0')
   619  	}
   620  
   621  	b = strconv.AppendInt(b, int64(t.Minute()), 10)
   622  	b = append(b, hy.timeSeparator...)
   623  
   624  	if t.Second() < 10 {
   625  		b = append(b, '0')
   626  	}
   627  
   628  	b = strconv.AppendInt(b, int64(t.Second()), 10)
   629  	b = append(b, []byte{0x20}...)
   630  
   631  	tz, _ := t.Zone()
   632  
   633  	if btz, ok := hy.timezones[tz]; ok {
   634  		b = append(b, btz...)
   635  	} else {
   636  		b = append(b, tz...)
   637  	}
   638  
   639  	return string(b)
   640  }
   641  

View as plain text