...

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

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

     1  package qu_PE
     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 qu_PE 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  	percentSuffix          string
    22  	perMille               string
    23  	timeSeparator          string
    24  	inifinity              string
    25  	currencies             []string // idx = enum of currency code
    26  	currencyPositivePrefix string
    27  	currencyNegativePrefix string
    28  	monthsAbbreviated      []string
    29  	monthsNarrow           []string
    30  	monthsWide             []string
    31  	daysAbbreviated        []string
    32  	daysNarrow             []string
    33  	daysShort              []string
    34  	daysWide               []string
    35  	periodsAbbreviated     []string
    36  	periodsNarrow          []string
    37  	periodsShort           []string
    38  	periodsWide            []string
    39  	erasAbbreviated        []string
    40  	erasNarrow             []string
    41  	erasWide               []string
    42  	timezones              map[string]string
    43  }
    44  
    45  // New returns a new instance of translator for the 'qu_PE' locale
    46  func New() locales.Translator {
    47  	return &qu_PE{
    48  		locale:                 "qu_PE",
    49  		pluralsCardinal:        nil,
    50  		pluralsOrdinal:         nil,
    51  		pluralsRange:           nil,
    52  		decimal:                ".",
    53  		group:                  ",",
    54  		minus:                  "-",
    55  		percent:                "%",
    56  		perMille:               "‰",
    57  		timeSeparator:          ":",
    58  		inifinity:              "∞",
    59  		currencies:             []string{"ADP", "AED", "AFA", "AFN", "ALK", "ALL", "AMD", "ANG", "AOA", "AOK", "AON", "AOR", "ARA", "ARL", "ARM", "ARP", "ARS", "ATS", "AUD", "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", "BRL", "BRN", "BRR", "BRZ", "BSD", "BTN", "BUK", "BWP", "BYB", "BYN", "BYR", "BZD", "CAD", "CDF", "CHE", "CHF", "CHW", "CLE", "CLF", "CLP", "CNH", "CNX", "CNY", "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", "EUR", "FIM", "FJD", "FKP", "FRF", "GBP", "GEK", "GEL", "GHC", "GHS", "GIP", "GMD", "GNF", "GNS", "GQE", "GRD", "GTQ", "GWE", "GWP", "GYD", "HKD", "HNL", "HRD", "HRK", "HTG", "HUF", "IDR", "IEP", "ILP", "ILR", "ILS", "INR", "IQD", "IRR", "ISJ", "ISK", "ITL", "JMD", "JOD", "JPY", "KES", "KGS", "KHR", "KMF", "KPW", "KRH", "KRO", "KRW", "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", "MXN", "MXP", "MXV", "MYR", "MZE", "MZM", "MZN", "NAD", "NGN", "NIC", "NIO", "NLG", "NOK", "NPR", "NZD", "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", "THB", "TJR", "TJS", "TMM", "TMT", "TND", "TOP", "TPE", "TRL", "TRY", "TTD", "TWD", "TZS", "UAH", "UAK", "UGS", "UGX", "USD", "USN", "USS", "UYI", "UYP", "UYU", "UYW", "UZS", "VEB", "VEF", "VES", "VND", "VNN", "VUV", "WST", "XAF", "XAG", "XAU", "XBA", "XBB", "XBC", "XBD", "XCD", "XDR", "XEU", "XFO", "XFU", "XOF", "XPD", "XPF", "XPT", "XRE", "XSU", "XTS", "XUA", "XXX", "YDD", "YER", "YUD", "YUM", "YUN", "YUR", "ZAL", "ZAR", "ZMK", "ZMW", "ZRN", "ZRZ", "ZWD", "ZWL", "ZWR"},
    60  		percentSuffix:          " ",
    61  		currencyPositivePrefix: " ",
    62  		currencyNegativePrefix: " ",
    63  		monthsAbbreviated:      []string{"", "Ene", "Feb", "Mar", "Abr", "May", "Jun", "Jul", "Ago", "Set", "Oct", "Nov", "Dic"},
    64  		monthsNarrow:           []string{"", "1", "2", "3", "4", "5", "6", "7", "8", "9", "10", "11", "12"},
    65  		monthsWide:             []string{"", "Enero", "Febrero", "Marzo", "Abril", "Mayo", "Junio", "Julio", "Agosto", "Setiembre", "Octubre", "Noviembre", "Diciembre"},
    66  		daysAbbreviated:        []string{"Dom", "Lun", "Mar", "Mié", "Jue", "Vie", "Sab"},
    67  		daysNarrow:             []string{"D", "L", "M", "X", "J", "V", "S"},
    68  		daysShort:              []string{"Dom", "Lun", "Mar", "Mié", "Jue", "Vie", "Sab"},
    69  		daysWide:               []string{"Domingo", "Lunes", "Martes", "Miércoles", "Jueves", "Viernes", "Sábado"},
    70  		periodsAbbreviated:     []string{"a.m.", "p.m."},
    71  		periodsNarrow:          []string{"a.m.", "p.m."},
    72  		periodsWide:            []string{"a.m.", "p.m."},
    73  		erasAbbreviated:        []string{"BCE", "d.C."},
    74  		erasNarrow:             []string{"", ""},
    75  		erasWide:               []string{"BCE", "d.C."},
    76  		timezones:              map[string]string{"ACDT": "Hora de Verano de Australia Central", "ACST": "Hora Estandar de Australia Central", "ACWDT": "Hora de Verano de Australia Central Occidental", "ACWST": "Hora Estandar de Australia Central Occidental", "ADT": "Hora De Verano del Atlántico", "AEDT": "Hora de Verano de Australia Oriental", "AEST": "Hora Estandar de Australia Oriental", "AKDT": "Hora de Verano de Alaska", "AKST": "Hora Estandar de Alaska", "ARST": "Hora de Verano de Argentina", "ART": "Hora Estandar de Argentina", "AST": "Hora Estandar del Atlántico", "AWDT": "Hora de Verano de Australia Occidental", "AWST": "Hora Estandar de Australia Occidental", "BOT": "Bolivia Time", "BT": "Hora de Bután", "CAT": "Hora de Africa Central", "CDT": "Hora Central de Verano", "CHADT": "Hora de Verano de Chatham", "CHAST": "Hora Estandar de Chatham", "CLST": "Hora de Verano de Chile", "CLT": "Hora Estandar de Chile", "COST": "Hora de Verano de Colombia", "COT": "Hora Estandar de Colombia", "CST": "Estandard Hora Central", "ChST": "Hora Estandar de Chamorro", "EAT": "Hora de Africa Oriental", "ECT": "Hora de Ecuador", "EDT": "Hora de Verano del Este", "EST": "Hora Estandar del Este", "GFT": "Hora de Guayana Francesa", "GMT": "Hora del Meridiano de Greenwich", "GST": "Hora Estandar del Golfo", "GYT": "Hora de Guyana", "HADT": "Hora de Verano de Hawai-Aleutiano", "HAST": "Hora Estandar de Hawai-Aleutiano", "HAT": "Hora de Verano de Terranova", "HECU": "Hora de Verano de Cuba", "HEEG": "Hora de Verano de Groenlandia", "HENOMX": "Hora de Verano del Noroeste de México", "HEOG": "Hora de Verano de Groenlandia Occidental", "HEPM": "Hora de Verano de San Pedro y Miquelón", "HEPMX": "Hora de Verano del Pacífico Mexicano", "HKST": "Hora de Verano de Hong Kong", "HKT": "Hora Estandar de Hong Kong", "HNCU": "Hora Estandar de Cuba", "HNEG": "Hora Estandar de Groenlandia", "HNNOMX": "Hora Estandar del Noroeste de México", "HNOG": "Hora Estandar de Groenlandia Occidental", "HNPM": "Hora Estandar de San Pedro y Miquelón", "HNPMX": "Hora Estandar del Pacífico Mexicano", "HNT": "Hora Estandar de Terranova", "IST": "Hora Estandar de India", "JDT": "Hora de Verano de Japón", "JST": "Hora Estandar de Japón", "LHDT": "Hora de Verano de Lord Howe", "LHST": "Hora Estandar de Lord Howe", "MDT": "Hora de Verano de la Montaña", "MESZ": "Hora de Verano de Europa Central", "MEZ": "Hora Estandar de Europa Central", "MST": "Hora Estandar de la Montaña", "MYT": "Hora de Malasia", "NZDT": "Hora de Verano de Nueva Zelanda", "NZST": "Hora Estandar de Nueva Zelanda", "OESZ": "Hora de Verano de Europa Oriental", "OEZ": "Hora Estandar de Europa Oriental", "PDT": "Hora de Verano del Pacífico", "PST": "Hora Estandar del Pacífico", "SAST": "Hora de Sudafrica", "SGT": "Hora Estandar de Singapur", "SRT": "Hora de Surinam", "TMST": "Hora de Verano de Turkmenistán", "TMT": "Hora Estandar de Turkmenistán", "UYST": "Hora de Verano de Uruguay", "UYT": "Hora Estandar de Uruguay", "VET": "Hora de Venezuela", "WARST": "Hora de Verano del Oeste de Argentina", "WART": "Hora Estandar del Oeste de Argentina", "WAST": "Hora Estandar de Verano de Africa Occidental", "WAT": "Hora Estandar de Africa Occidental", "WESZ": "Hora de Verano de Europa Occidental", "WEZ": "Hora Estandar de Europa Occidental", "WIB": "Hora de Indonesia Occidental", "WIT": "Hora de Indonesia Oriental", "WITA": "Hora de Indonesia Central", "∅∅∅": "Hora de Verano de Brasilia"},
    77  	}
    78  }
    79  
    80  // Locale returns the current translators string locale
    81  func (qu *qu_PE) Locale() string {
    82  	return qu.locale
    83  }
    84  
    85  // PluralsCardinal returns the list of cardinal plural rules associated with 'qu_PE'
    86  func (qu *qu_PE) PluralsCardinal() []locales.PluralRule {
    87  	return qu.pluralsCardinal
    88  }
    89  
    90  // PluralsOrdinal returns the list of ordinal plural rules associated with 'qu_PE'
    91  func (qu *qu_PE) PluralsOrdinal() []locales.PluralRule {
    92  	return qu.pluralsOrdinal
    93  }
    94  
    95  // PluralsRange returns the list of range plural rules associated with 'qu_PE'
    96  func (qu *qu_PE) PluralsRange() []locales.PluralRule {
    97  	return qu.pluralsRange
    98  }
    99  
   100  // CardinalPluralRule returns the cardinal PluralRule given 'num' and digits/precision of 'v' for 'qu_PE'
   101  func (qu *qu_PE) CardinalPluralRule(num float64, v uint64) locales.PluralRule {
   102  	return locales.PluralRuleUnknown
   103  }
   104  
   105  // OrdinalPluralRule returns the ordinal PluralRule given 'num' and digits/precision of 'v' for 'qu_PE'
   106  func (qu *qu_PE) OrdinalPluralRule(num float64, v uint64) locales.PluralRule {
   107  	return locales.PluralRuleUnknown
   108  }
   109  
   110  // RangePluralRule returns the ordinal PluralRule given 'num1', 'num2' and digits/precision of 'v1' and 'v2' for 'qu_PE'
   111  func (qu *qu_PE) RangePluralRule(num1 float64, v1 uint64, num2 float64, v2 uint64) locales.PluralRule {
   112  	return locales.PluralRuleUnknown
   113  }
   114  
   115  // MonthAbbreviated returns the locales abbreviated month given the 'month' provided
   116  func (qu *qu_PE) MonthAbbreviated(month time.Month) string {
   117  	return qu.monthsAbbreviated[month]
   118  }
   119  
   120  // MonthsAbbreviated returns the locales abbreviated months
   121  func (qu *qu_PE) MonthsAbbreviated() []string {
   122  	return qu.monthsAbbreviated[1:]
   123  }
   124  
   125  // MonthNarrow returns the locales narrow month given the 'month' provided
   126  func (qu *qu_PE) MonthNarrow(month time.Month) string {
   127  	return qu.monthsNarrow[month]
   128  }
   129  
   130  // MonthsNarrow returns the locales narrow months
   131  func (qu *qu_PE) MonthsNarrow() []string {
   132  	return qu.monthsNarrow[1:]
   133  }
   134  
   135  // MonthWide returns the locales wide month given the 'month' provided
   136  func (qu *qu_PE) MonthWide(month time.Month) string {
   137  	return qu.monthsWide[month]
   138  }
   139  
   140  // MonthsWide returns the locales wide months
   141  func (qu *qu_PE) MonthsWide() []string {
   142  	return qu.monthsWide[1:]
   143  }
   144  
   145  // WeekdayAbbreviated returns the locales abbreviated weekday given the 'weekday' provided
   146  func (qu *qu_PE) WeekdayAbbreviated(weekday time.Weekday) string {
   147  	return qu.daysAbbreviated[weekday]
   148  }
   149  
   150  // WeekdaysAbbreviated returns the locales abbreviated weekdays
   151  func (qu *qu_PE) WeekdaysAbbreviated() []string {
   152  	return qu.daysAbbreviated
   153  }
   154  
   155  // WeekdayNarrow returns the locales narrow weekday given the 'weekday' provided
   156  func (qu *qu_PE) WeekdayNarrow(weekday time.Weekday) string {
   157  	return qu.daysNarrow[weekday]
   158  }
   159  
   160  // WeekdaysNarrow returns the locales narrow weekdays
   161  func (qu *qu_PE) WeekdaysNarrow() []string {
   162  	return qu.daysNarrow
   163  }
   164  
   165  // WeekdayShort returns the locales short weekday given the 'weekday' provided
   166  func (qu *qu_PE) WeekdayShort(weekday time.Weekday) string {
   167  	return qu.daysShort[weekday]
   168  }
   169  
   170  // WeekdaysShort returns the locales short weekdays
   171  func (qu *qu_PE) WeekdaysShort() []string {
   172  	return qu.daysShort
   173  }
   174  
   175  // WeekdayWide returns the locales wide weekday given the 'weekday' provided
   176  func (qu *qu_PE) WeekdayWide(weekday time.Weekday) string {
   177  	return qu.daysWide[weekday]
   178  }
   179  
   180  // WeekdaysWide returns the locales wide weekdays
   181  func (qu *qu_PE) WeekdaysWide() []string {
   182  	return qu.daysWide
   183  }
   184  
   185  // Decimal returns the decimal point of number
   186  func (qu *qu_PE) Decimal() string {
   187  	return qu.decimal
   188  }
   189  
   190  // Group returns the group of number
   191  func (qu *qu_PE) Group() string {
   192  	return qu.group
   193  }
   194  
   195  // Group returns the minus sign of number
   196  func (qu *qu_PE) Minus() string {
   197  	return qu.minus
   198  }
   199  
   200  // FmtNumber returns 'num' with digits/precision of 'v' for 'qu_PE' and handles both Whole and Real numbers based on 'v'
   201  func (qu *qu_PE) FmtNumber(num float64, v uint64) string {
   202  
   203  	s := strconv.FormatFloat(math.Abs(num), 'f', int(v), 64)
   204  	l := len(s) + 2 + 1*len(s[:len(s)-int(v)-1])/3
   205  	count := 0
   206  	inWhole := v == 0
   207  	b := make([]byte, 0, l)
   208  
   209  	for i := len(s) - 1; i >= 0; i-- {
   210  
   211  		if s[i] == '.' {
   212  			b = append(b, qu.decimal[0])
   213  			inWhole = true
   214  			continue
   215  		}
   216  
   217  		if inWhole {
   218  			if count == 3 {
   219  				b = append(b, qu.group[0])
   220  				count = 1
   221  			} else {
   222  				count++
   223  			}
   224  		}
   225  
   226  		b = append(b, s[i])
   227  	}
   228  
   229  	if num < 0 {
   230  		b = append(b, qu.minus[0])
   231  	}
   232  
   233  	// reverse
   234  	for i, j := 0, len(b)-1; i < j; i, j = i+1, j-1 {
   235  		b[i], b[j] = b[j], b[i]
   236  	}
   237  
   238  	return string(b)
   239  }
   240  
   241  // FmtPercent returns 'num' with digits/precision of 'v' for 'qu_PE' and handles both Whole and Real numbers based on 'v'
   242  // NOTE: 'num' passed into FmtPercent is assumed to be in percent already
   243  func (qu *qu_PE) FmtPercent(num float64, v uint64) string {
   244  	s := strconv.FormatFloat(math.Abs(num), 'f', int(v), 64)
   245  	l := len(s) + 5
   246  	b := make([]byte, 0, l)
   247  
   248  	for i := len(s) - 1; i >= 0; i-- {
   249  
   250  		if s[i] == '.' {
   251  			b = append(b, qu.decimal[0])
   252  			continue
   253  		}
   254  
   255  		b = append(b, s[i])
   256  	}
   257  
   258  	if num < 0 {
   259  		b = append(b, qu.minus[0])
   260  	}
   261  
   262  	// reverse
   263  	for i, j := 0, len(b)-1; i < j; i, j = i+1, j-1 {
   264  		b[i], b[j] = b[j], b[i]
   265  	}
   266  
   267  	b = append(b, qu.percentSuffix...)
   268  
   269  	b = append(b, qu.percent...)
   270  
   271  	return string(b)
   272  }
   273  
   274  // FmtCurrency returns the currency representation of 'num' with digits/precision of 'v' for 'qu_PE'
   275  func (qu *qu_PE) FmtCurrency(num float64, v uint64, currency currency.Type) string {
   276  
   277  	s := strconv.FormatFloat(math.Abs(num), 'f', int(v), 64)
   278  	symbol := qu.currencies[currency]
   279  	l := len(s) + len(symbol) + 4 + 1*len(s[:len(s)-int(v)-1])/3
   280  	count := 0
   281  	inWhole := v == 0
   282  	b := make([]byte, 0, l)
   283  
   284  	for i := len(s) - 1; i >= 0; i-- {
   285  
   286  		if s[i] == '.' {
   287  			b = append(b, qu.decimal[0])
   288  			inWhole = true
   289  			continue
   290  		}
   291  
   292  		if inWhole {
   293  			if count == 3 {
   294  				b = append(b, qu.group[0])
   295  				count = 1
   296  			} else {
   297  				count++
   298  			}
   299  		}
   300  
   301  		b = append(b, s[i])
   302  	}
   303  
   304  	for j := len(symbol) - 1; j >= 0; j-- {
   305  		b = append(b, symbol[j])
   306  	}
   307  
   308  	for j := len(qu.currencyPositivePrefix) - 1; j >= 0; j-- {
   309  		b = append(b, qu.currencyPositivePrefix[j])
   310  	}
   311  
   312  	if num < 0 {
   313  		b = append(b, qu.minus[0])
   314  	}
   315  
   316  	// reverse
   317  	for i, j := 0, len(b)-1; i < j; i, j = i+1, j-1 {
   318  		b[i], b[j] = b[j], b[i]
   319  	}
   320  
   321  	if int(v) < 2 {
   322  
   323  		if v == 0 {
   324  			b = append(b, qu.decimal...)
   325  		}
   326  
   327  		for i := 0; i < 2-int(v); i++ {
   328  			b = append(b, '0')
   329  		}
   330  	}
   331  
   332  	return string(b)
   333  }
   334  
   335  // FmtAccounting returns the currency representation of 'num' with digits/precision of 'v' for 'qu_PE'
   336  // in accounting notation.
   337  func (qu *qu_PE) FmtAccounting(num float64, v uint64, currency currency.Type) string {
   338  
   339  	s := strconv.FormatFloat(math.Abs(num), 'f', int(v), 64)
   340  	symbol := qu.currencies[currency]
   341  	l := len(s) + len(symbol) + 4 + 1*len(s[:len(s)-int(v)-1])/3
   342  	count := 0
   343  	inWhole := v == 0
   344  	b := make([]byte, 0, l)
   345  
   346  	for i := len(s) - 1; i >= 0; i-- {
   347  
   348  		if s[i] == '.' {
   349  			b = append(b, qu.decimal[0])
   350  			inWhole = true
   351  			continue
   352  		}
   353  
   354  		if inWhole {
   355  			if count == 3 {
   356  				b = append(b, qu.group[0])
   357  				count = 1
   358  			} else {
   359  				count++
   360  			}
   361  		}
   362  
   363  		b = append(b, s[i])
   364  	}
   365  
   366  	if num < 0 {
   367  
   368  		for j := len(symbol) - 1; j >= 0; j-- {
   369  			b = append(b, symbol[j])
   370  		}
   371  
   372  		for j := len(qu.currencyNegativePrefix) - 1; j >= 0; j-- {
   373  			b = append(b, qu.currencyNegativePrefix[j])
   374  		}
   375  
   376  		b = append(b, qu.minus[0])
   377  
   378  	} else {
   379  
   380  		for j := len(symbol) - 1; j >= 0; j-- {
   381  			b = append(b, symbol[j])
   382  		}
   383  
   384  		for j := len(qu.currencyPositivePrefix) - 1; j >= 0; j-- {
   385  			b = append(b, qu.currencyPositivePrefix[j])
   386  		}
   387  
   388  	}
   389  
   390  	// reverse
   391  	for i, j := 0, len(b)-1; i < j; i, j = i+1, j-1 {
   392  		b[i], b[j] = b[j], b[i]
   393  	}
   394  
   395  	if int(v) < 2 {
   396  
   397  		if v == 0 {
   398  			b = append(b, qu.decimal...)
   399  		}
   400  
   401  		for i := 0; i < 2-int(v); i++ {
   402  			b = append(b, '0')
   403  		}
   404  	}
   405  
   406  	return string(b)
   407  }
   408  
   409  // FmtDateShort returns the short date representation of 't' for 'qu_PE'
   410  func (qu *qu_PE) FmtDateShort(t time.Time) string {
   411  
   412  	b := make([]byte, 0, 32)
   413  
   414  	if t.Day() < 10 {
   415  		b = append(b, '0')
   416  	}
   417  
   418  	b = strconv.AppendInt(b, int64(t.Day()), 10)
   419  	b = append(b, []byte{0x2f}...)
   420  
   421  	if t.Month() < 10 {
   422  		b = append(b, '0')
   423  	}
   424  
   425  	b = strconv.AppendInt(b, int64(t.Month()), 10)
   426  
   427  	b = append(b, []byte{0x2f}...)
   428  
   429  	if t.Year() > 0 {
   430  		b = strconv.AppendInt(b, int64(t.Year()), 10)
   431  	} else {
   432  		b = strconv.AppendInt(b, int64(-t.Year()), 10)
   433  	}
   434  
   435  	return string(b)
   436  }
   437  
   438  // FmtDateMedium returns the medium date representation of 't' for 'qu_PE'
   439  func (qu *qu_PE) FmtDateMedium(t time.Time) string {
   440  
   441  	b := make([]byte, 0, 32)
   442  
   443  	b = strconv.AppendInt(b, int64(t.Day()), 10)
   444  	b = append(b, []byte{0x20}...)
   445  	b = append(b, qu.monthsAbbreviated[t.Month()]...)
   446  	b = append(b, []byte{0x20}...)
   447  
   448  	if t.Year() > 0 {
   449  		b = strconv.AppendInt(b, int64(t.Year()), 10)
   450  	} else {
   451  		b = strconv.AppendInt(b, int64(-t.Year()), 10)
   452  	}
   453  
   454  	return string(b)
   455  }
   456  
   457  // FmtDateLong returns the long date representation of 't' for 'qu_PE'
   458  func (qu *qu_PE) FmtDateLong(t time.Time) string {
   459  
   460  	b := make([]byte, 0, 32)
   461  
   462  	b = strconv.AppendInt(b, int64(t.Day()), 10)
   463  	b = append(b, []byte{0x20}...)
   464  	b = append(b, qu.monthsWide[t.Month()]...)
   465  	b = append(b, []byte{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  	return string(b)
   474  }
   475  
   476  // FmtDateFull returns the full date representation of 't' for 'qu_PE'
   477  func (qu *qu_PE) FmtDateFull(t time.Time) string {
   478  
   479  	b := make([]byte, 0, 32)
   480  
   481  	b = append(b, qu.daysWide[t.Weekday()]...)
   482  	b = append(b, []byte{0x2c, 0x20}...)
   483  	b = strconv.AppendInt(b, int64(t.Day()), 10)
   484  	b = append(b, []byte{0x20}...)
   485  	b = append(b, qu.monthsWide[t.Month()]...)
   486  	b = append(b, []byte{0x2c, 0x20}...)
   487  
   488  	if t.Year() > 0 {
   489  		b = strconv.AppendInt(b, int64(t.Year()), 10)
   490  	} else {
   491  		b = strconv.AppendInt(b, int64(-t.Year()), 10)
   492  	}
   493  
   494  	return string(b)
   495  }
   496  
   497  // FmtTimeShort returns the short time representation of 't' for 'qu_PE'
   498  func (qu *qu_PE) FmtTimeShort(t time.Time) string {
   499  
   500  	b := make([]byte, 0, 32)
   501  
   502  	if t.Hour() < 10 {
   503  		b = append(b, '0')
   504  	}
   505  
   506  	b = strconv.AppendInt(b, int64(t.Hour()), 10)
   507  	b = append(b, qu.timeSeparator...)
   508  
   509  	if t.Minute() < 10 {
   510  		b = append(b, '0')
   511  	}
   512  
   513  	b = strconv.AppendInt(b, int64(t.Minute()), 10)
   514  
   515  	return string(b)
   516  }
   517  
   518  // FmtTimeMedium returns the medium time representation of 't' for 'qu_PE'
   519  func (qu *qu_PE) FmtTimeMedium(t time.Time) string {
   520  
   521  	b := make([]byte, 0, 32)
   522  
   523  	if t.Hour() < 10 {
   524  		b = append(b, '0')
   525  	}
   526  
   527  	b = strconv.AppendInt(b, int64(t.Hour()), 10)
   528  	b = append(b, qu.timeSeparator...)
   529  
   530  	if t.Minute() < 10 {
   531  		b = append(b, '0')
   532  	}
   533  
   534  	b = strconv.AppendInt(b, int64(t.Minute()), 10)
   535  	b = append(b, qu.timeSeparator...)
   536  
   537  	if t.Second() < 10 {
   538  		b = append(b, '0')
   539  	}
   540  
   541  	b = strconv.AppendInt(b, int64(t.Second()), 10)
   542  
   543  	return string(b)
   544  }
   545  
   546  // FmtTimeLong returns the long time representation of 't' for 'qu_PE'
   547  func (qu *qu_PE) FmtTimeLong(t time.Time) string {
   548  
   549  	b := make([]byte, 0, 32)
   550  
   551  	if t.Hour() < 10 {
   552  		b = append(b, '0')
   553  	}
   554  
   555  	b = strconv.AppendInt(b, int64(t.Hour()), 10)
   556  	b = append(b, qu.timeSeparator...)
   557  
   558  	if t.Minute() < 10 {
   559  		b = append(b, '0')
   560  	}
   561  
   562  	b = strconv.AppendInt(b, int64(t.Minute()), 10)
   563  	b = append(b, qu.timeSeparator...)
   564  
   565  	if t.Second() < 10 {
   566  		b = append(b, '0')
   567  	}
   568  
   569  	b = strconv.AppendInt(b, int64(t.Second()), 10)
   570  	b = append(b, []byte{0x20}...)
   571  
   572  	tz, _ := t.Zone()
   573  	b = append(b, tz...)
   574  
   575  	return string(b)
   576  }
   577  
   578  // FmtTimeFull returns the full time representation of 't' for 'qu_PE'
   579  func (qu *qu_PE) FmtTimeFull(t time.Time) string {
   580  
   581  	b := make([]byte, 0, 32)
   582  
   583  	if t.Hour() < 10 {
   584  		b = append(b, '0')
   585  	}
   586  
   587  	b = strconv.AppendInt(b, int64(t.Hour()), 10)
   588  	b = append(b, qu.timeSeparator...)
   589  
   590  	if t.Minute() < 10 {
   591  		b = append(b, '0')
   592  	}
   593  
   594  	b = strconv.AppendInt(b, int64(t.Minute()), 10)
   595  	b = append(b, qu.timeSeparator...)
   596  
   597  	if t.Second() < 10 {
   598  		b = append(b, '0')
   599  	}
   600  
   601  	b = strconv.AppendInt(b, int64(t.Second()), 10)
   602  	b = append(b, []byte{0x20}...)
   603  
   604  	tz, _ := t.Zone()
   605  
   606  	if btz, ok := qu.timezones[tz]; ok {
   607  		b = append(b, btz...)
   608  	} else {
   609  		b = append(b, tz...)
   610  	}
   611  
   612  	return string(b)
   613  }
   614  

View as plain text