package pt_BR import ( "math" "strconv" "time" "github.com/go-playground/locales" "github.com/go-playground/locales/currency" ) type pt_BR struct { locale string pluralsCardinal []locales.PluralRule pluralsOrdinal []locales.PluralRule pluralsRange []locales.PluralRule decimal string group string minus string percent string perMille string timeSeparator string inifinity string currencies []string // idx = enum of currency code currencyNegativePrefix string currencyNegativeSuffix string monthsAbbreviated []string monthsNarrow []string monthsWide []string daysAbbreviated []string daysNarrow []string daysShort []string daysWide []string periodsAbbreviated []string periodsNarrow []string periodsShort []string periodsWide []string erasAbbreviated []string erasNarrow []string erasWide []string timezones map[string]string } // New returns a new instance of translator for the 'pt_BR' locale func New() locales.Translator { return &pt_BR{ locale: "pt_BR", pluralsCardinal: []locales.PluralRule{2, 6}, pluralsOrdinal: []locales.PluralRule{6}, pluralsRange: []locales.PluralRule{6, 2}, decimal: ",", group: ".", minus: "-", percent: "%", perMille: "‰", timeSeparator: ":", inifinity: "∞", 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 ", "BYR ", "BZD ", "CAD ", "CDF ", "CHE ", "CHF ", "CHW ", "CLE ", "CLF ", "CLP ", "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 ", "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 ", "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 ", "UZS ", "VEB ", "VEF ", "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 "}, currencyNegativePrefix: "(", currencyNegativeSuffix: ")", monthsAbbreviated: []string{"", "jan", "fev", "mar", "abr", "mai", "jun", "jul", "ago", "set", "out", "nov", "dez"}, monthsNarrow: []string{"", "J", "F", "M", "A", "M", "J", "J", "A", "S", "O", "N", "D"}, monthsWide: []string{"", "janeiro", "fevereiro", "março", "abril", "maio", "junho", "julho", "agosto", "setembro", "outubro", "novembro", "dezembro"}, daysAbbreviated: []string{"dom", "seg", "ter", "qua", "qui", "sex", "sáb"}, daysNarrow: []string{"D", "S", "T", "Q", "Q", "S", "S"}, daysShort: []string{"dom", "seg", "ter", "qua", "qui", "sex", "sáb"}, daysWide: []string{"domingo", "segunda-feira", "terça-feira", "quarta-feira", "quinta-feira", "sexta-feira", "sábado"}, periodsAbbreviated: []string{"AM", "PM"}, periodsNarrow: []string{"a", "p"}, periodsWide: []string{"AM", "PM"}, erasAbbreviated: []string{"a.C.", "d.C."}, erasNarrow: []string{"", ""}, erasWide: []string{"antes de Cristo", "depois de Cristo"}, timezones: map[string]string{"AEST": "Horário Padrão da Austrália Oriental", "ChST": "Horário de Chamorro", "CHADT": "Horário de Verão de Chatham", "VET": "Horário da Venezuela", "MDT": "Horário de Verão da Montanha", "HAT": "Horário de Verão de Terra Nova", "AWST": "Horário Padrão da Austrália Ocidental", "JDT": "Horário de Verão do Japão", "WAST": "Horário de Verão da África Ocidental", "JST": "Horário Padrão do Japão", "OEZ": "Horário Padrão da Europa Oriental", "ACDT": "Horário de Verão da Austrália Central", "AWDT": "Horário de Verão da Austrália Ocidental", "ECT": "Horário do Equador", "HKT": "Horário Padrão de Hong Kong", "ART": "Horário Padrão da Argentina", "WAT": "Horário Padrão da África Ocidental", "EAT": "Horário da África Oriental", "CST": "Horário Padrão Central", "NZST": "Horário Padrão da Nova Zelândia", "ACWST": "Horário Padrão da Austrália Centro-Ocidental", "CAT": "Horário da África Central", "WITA": "Horário da Indonésia Central", "WIB": "Horário da Indonésia Ocidental", "TMT": "Horário Padrão do Turcomenistão", "AKST": "Horário Padrão do Alasca", "CLT": "Horário Padrão do Chile", "CLST": "Horário de Verão do Chile", "WIT": "Horário da Indonésia Oriental", "AKDT": "Horário de Verão do Alasca", "LHST": "Horário Padrão de Lord Howe", "NZDT": "Horário de Verão da Nova Zelândia", "WEZ": "Horário Padrão da Europa Ocidental", "HNT": "Horário Padrão de Terra Nova", "GYT": "Horário da Guiana", "MYT": "Horário da Malásia", "COST": "Horário de Verão da Colômbia", "SAST": "Horário da África do Sul", "BT": "Horário do Butão", "PST": "Horário Padrão do Pacífico", "LHDT": "Horário de Verão de Lord Howe", "MESZ": "Horário de Verão da Europa Central", "WARST": "Horário de Verão da Argentina Ocidental", "OESZ": "Horário de Verão da Europa Oriental", "ARST": "Horário de Verão da Argentina", "TMST": "Horário de Verão do Turcomenistão", "PDT": "Horário de Verão do Pacífico", "UYT": "Horário Padrão do Uruguai", "AST": "Horário Padrão do Atlântico", "HADT": "Horário de Verão do Havaí e Ilhas Aleutas", "BOT": "Horário da Bolívia", "EST": "Horário Padrão Oriental", "EDT": "Horário de Verão Oriental", "∅∅∅": "Horário de Verão de Brasília", "SGT": "Horário Padrão de Cingapura", "HKST": "Horário de Verão de Hong Kong", "MEZ": "Horário Padrão da Europa Central", "UYST": "Horário de Verão do Uruguai", "MST": "Horário Padrão da Montanha", "ADT": "Horário de Verão do Atlântico", "IST": "Horário Padrão da Índia", "GMT": "Horário do Meridiano de Greenwich", "ACST": "Horário Padrão da Austrália Central", "SRT": "Horário do Suriname", "COT": "Horário Padrão da Colômbia", "HAST": "Horário Padrão do Havaí e Ilhas Aleutas", "WART": "Horário Padrão da Argentina Ocidental", "CDT": "Horário de Verão Central", "WESZ": "Horário de Verão da Europa Ocidental", "ACWDT": "Horário de Verão da Austrália Centro-Ocidental", "AEDT": "Horário de Verão da Austrália Oriental", "CHAST": "Horário Padrão de Chatham", "GFT": "Horário da Guiana Francesa"}, } } // Locale returns the current translators string locale func (pt *pt_BR) Locale() string { return pt.locale } // PluralsCardinal returns the list of cardinal plural rules associated with 'pt_BR' func (pt *pt_BR) PluralsCardinal() []locales.PluralRule { return pt.pluralsCardinal } // PluralsOrdinal returns the list of ordinal plural rules associated with 'pt_BR' func (pt *pt_BR) PluralsOrdinal() []locales.PluralRule { return pt.pluralsOrdinal } // PluralsRange returns the list of range plural rules associated with 'pt_BR' func (pt *pt_BR) PluralsRange() []locales.PluralRule { return pt.pluralsRange } // CardinalPluralRule returns the cardinal PluralRule given 'num' and digits/precision of 'v' for 'pt_BR' func (pt *pt_BR) CardinalPluralRule(num float64, v uint64) locales.PluralRule { n := math.Abs(num) if n >= 0 && n <= 2 && n != 2 { return locales.PluralRuleOne } return locales.PluralRuleOther } // OrdinalPluralRule returns the ordinal PluralRule given 'num' and digits/precision of 'v' for 'pt_BR' func (pt *pt_BR) OrdinalPluralRule(num float64, v uint64) locales.PluralRule { return locales.PluralRuleOther } // RangePluralRule returns the ordinal PluralRule given 'num1', 'num2' and digits/precision of 'v1' and 'v2' for 'pt_BR' func (pt *pt_BR) RangePluralRule(num1 float64, v1 uint64, num2 float64, v2 uint64) locales.PluralRule { start := pt.CardinalPluralRule(num1, v1) end := pt.CardinalPluralRule(num2, v2) if start == locales.PluralRuleOne && end == locales.PluralRuleOther { return locales.PluralRuleOther } else if start == locales.PluralRuleOther && end == locales.PluralRuleOne { return locales.PluralRuleOne } return locales.PluralRuleOther } // MonthAbbreviated returns the locales abbreviated month given the 'month' provided func (pt *pt_BR) MonthAbbreviated(month time.Month) string { return pt.monthsAbbreviated[month] } // MonthsAbbreviated returns the locales abbreviated months func (pt *pt_BR) MonthsAbbreviated() []string { return pt.monthsAbbreviated[1:] } // MonthNarrow returns the locales narrow month given the 'month' provided func (pt *pt_BR) MonthNarrow(month time.Month) string { return pt.monthsNarrow[month] } // MonthsNarrow returns the locales narrow months func (pt *pt_BR) MonthsNarrow() []string { return pt.monthsNarrow[1:] } // MonthWide returns the locales wide month given the 'month' provided func (pt *pt_BR) MonthWide(month time.Month) string { return pt.monthsWide[month] } // MonthsWide returns the locales wide months func (pt *pt_BR) MonthsWide() []string { return pt.monthsWide[1:] } // WeekdayAbbreviated returns the locales abbreviated weekday given the 'weekday' provided func (pt *pt_BR) WeekdayAbbreviated(weekday time.Weekday) string { return pt.daysAbbreviated[weekday] } // WeekdaysAbbreviated returns the locales abbreviated weekdays func (pt *pt_BR) WeekdaysAbbreviated() []string { return pt.daysAbbreviated } // WeekdayNarrow returns the locales narrow weekday given the 'weekday' provided func (pt *pt_BR) WeekdayNarrow(weekday time.Weekday) string { return pt.daysNarrow[weekday] } // WeekdaysNarrow returns the locales narrow weekdays func (pt *pt_BR) WeekdaysNarrow() []string { return pt.daysNarrow } // WeekdayShort returns the locales short weekday given the 'weekday' provided func (pt *pt_BR) WeekdayShort(weekday time.Weekday) string { return pt.daysShort[weekday] } // WeekdaysShort returns the locales short weekdays func (pt *pt_BR) WeekdaysShort() []string { return pt.daysShort } // WeekdayWide returns the locales wide weekday given the 'weekday' provided func (pt *pt_BR) WeekdayWide(weekday time.Weekday) string { return pt.daysWide[weekday] } // WeekdaysWide returns the locales wide weekdays func (pt *pt_BR) WeekdaysWide() []string { return pt.daysWide } // FmtNumber returns 'num' with digits/precision of 'v' for 'pt_BR' and handles both Whole and Real numbers based on 'v' func (pt *pt_BR) FmtNumber(num float64, v uint64) string { s := strconv.FormatFloat(math.Abs(num), 'f', int(v), 64) l := len(s) + 2 + 1*len(s[:len(s)-int(v)-1])/3 count := 0 inWhole := v == 0 b := make([]byte, 0, l) for i := len(s) - 1; i >= 0; i-- { if s[i] == '.' { b = append(b, pt.decimal[0]) inWhole = true continue } if inWhole { if count == 3 { b = append(b, pt.group[0]) count = 1 } else { count++ } } b = append(b, s[i]) } if num < 0 { b = append(b, pt.minus[0]) } // reverse for i, j := 0, len(b)-1; i < j; i, j = i+1, j-1 { b[i], b[j] = b[j], b[i] } return string(b) } // FmtPercent returns 'num' with digits/precision of 'v' for 'pt_BR' and handles both Whole and Real numbers based on 'v' // NOTE: 'num' passed into FmtPercent is assumed to be in percent already func (pt *pt_BR) FmtPercent(num float64, v uint64) string { s := strconv.FormatFloat(math.Abs(num), 'f', int(v), 64) l := len(s) + 3 b := make([]byte, 0, l) for i := len(s) - 1; i >= 0; i-- { if s[i] == '.' { b = append(b, pt.decimal[0]) continue } b = append(b, s[i]) } if num < 0 { b = append(b, pt.minus[0]) } // reverse for i, j := 0, len(b)-1; i < j; i, j = i+1, j-1 { b[i], b[j] = b[j], b[i] } b = append(b, pt.percent...) return string(b) } // FmtCurrency returns the currency representation of 'num' with digits/precision of 'v' for 'pt_BR' func (pt *pt_BR) FmtCurrency(num float64, v uint64, currency currency.Type) string { s := strconv.FormatFloat(math.Abs(num), 'f', int(v), 64) symbol := pt.currencies[currency] l := len(s) + len(symbol) + 2 + 1*len(s[:len(s)-int(v)-1])/3 count := 0 inWhole := v == 0 b := make([]byte, 0, l) for i := len(s) - 1; i >= 0; i-- { if s[i] == '.' { b = append(b, pt.decimal[0]) inWhole = true continue } if inWhole { if count == 3 { b = append(b, pt.group[0]) count = 1 } else { count++ } } b = append(b, s[i]) } for j := len(symbol) - 1; j >= 0; j-- { b = append(b, symbol[j]) } if num < 0 { b = append(b, pt.minus[0]) } // reverse for i, j := 0, len(b)-1; i < j; i, j = i+1, j-1 { b[i], b[j] = b[j], b[i] } if int(v) < 2 { if v == 0 { b = append(b, pt.decimal...) } for i := 0; i < 2-int(v); i++ { b = append(b, '0') } } return string(b) } // FmtAccounting returns the currency representation of 'num' with digits/precision of 'v' for 'pt_BR' // in accounting notation. func (pt *pt_BR) FmtAccounting(num float64, v uint64, currency currency.Type) string { s := strconv.FormatFloat(math.Abs(num), 'f', int(v), 64) symbol := pt.currencies[currency] l := len(s) + len(symbol) + 4 + 1*len(s[:len(s)-int(v)-1])/3 count := 0 inWhole := v == 0 b := make([]byte, 0, l) for i := len(s) - 1; i >= 0; i-- { if s[i] == '.' { b = append(b, pt.decimal[0]) inWhole = true continue } if inWhole { if count == 3 { b = append(b, pt.group[0]) count = 1 } else { count++ } } b = append(b, s[i]) } if num < 0 { for j := len(symbol) - 1; j >= 0; j-- { b = append(b, symbol[j]) } b = append(b, pt.currencyNegativePrefix[0]) } else { for j := len(symbol) - 1; j >= 0; j-- { b = append(b, symbol[j]) } } // reverse for i, j := 0, len(b)-1; i < j; i, j = i+1, j-1 { b[i], b[j] = b[j], b[i] } if int(v) < 2 { if v == 0 { b = append(b, pt.decimal...) } for i := 0; i < 2-int(v); i++ { b = append(b, '0') } } if num < 0 { b = append(b, pt.currencyNegativeSuffix...) } return string(b) } // FmtDateShort returns the short date representation of 't' for 'pt_BR' func (pt *pt_BR) FmtDateShort(t time.Time) string { b := make([]byte, 0, 32) if t.Day() < 10 { b = append(b, '0') } b = strconv.AppendInt(b, int64(t.Day()), 10) b = append(b, []byte{0x2f}...) if t.Month() < 10 { b = append(b, '0') } b = strconv.AppendInt(b, int64(t.Month()), 10) b = append(b, []byte{0x2f}...) if t.Year() > 9 { b = append(b, strconv.Itoa(t.Year())[2:]...) } else { b = append(b, strconv.Itoa(t.Year())[1:]...) } return string(b) } // FmtDateMedium returns the medium date representation of 't' for 'pt_BR' func (pt *pt_BR) FmtDateMedium(t time.Time) string { b := make([]byte, 0, 32) b = strconv.AppendInt(b, int64(t.Day()), 10) b = append(b, []byte{}...) b = append(b, []byte{0x27, 0x64, 0x65, 0x27, 0x20}...) b = append(b, pt.monthsAbbreviated[t.Month()]...) b = append(b, []byte{}...) b = append(b, []byte{0x27, 0x64, 0x65, 0x27, 0x20}...) b = strconv.AppendInt(b, int64(t.Year()), 10) return string(b) } // FmtDateLong returns the long date representation of 't' for 'pt_BR' func (pt *pt_BR) FmtDateLong(t time.Time) string { b := make([]byte, 0, 32) b = strconv.AppendInt(b, int64(t.Day()), 10) b = append(b, []byte{}...) b = append(b, []byte{0x27, 0x64, 0x65, 0x27, 0x20}...) b = append(b, pt.monthsWide[t.Month()]...) b = append(b, []byte{}...) b = append(b, []byte{0x27, 0x64, 0x65, 0x27, 0x20}...) b = strconv.AppendInt(b, int64(t.Year()), 10) return string(b) } // FmtDateFull returns the full date representation of 't' for 'pt_BR' func (pt *pt_BR) FmtDateFull(t time.Time) string { b := make([]byte, 0, 32) b = append(b, pt.daysWide[t.Weekday()]...) b = append(b, []byte{0x2c, 0x20}...) b = strconv.AppendInt(b, int64(t.Day()), 10) b = append(b, []byte{}...) b = append(b, []byte{0x27, 0x64, 0x65, 0x27, 0x20}...) b = append(b, pt.monthsWide[t.Month()]...) b = append(b, []byte{}...) b = append(b, []byte{0x27, 0x64, 0x65, 0x27, 0x20}...) b = strconv.AppendInt(b, int64(t.Year()), 10) return string(b) } // FmtTimeShort returns the short time representation of 't' for 'pt_BR' func (pt *pt_BR) FmtTimeShort(t time.Time) string { b := make([]byte, 0, 32) if t.Hour() < 10 { b = append(b, '0') } b = strconv.AppendInt(b, int64(t.Hour()), 10) b = append(b, pt.timeSeparator...) if t.Minute() < 10 { b = append(b, '0') } b = strconv.AppendInt(b, int64(t.Minute()), 10) return string(b) } // FmtTimeMedium returns the medium time representation of 't' for 'pt_BR' func (pt *pt_BR) FmtTimeMedium(t time.Time) string { b := make([]byte, 0, 32) if t.Hour() < 10 { b = append(b, '0') } b = strconv.AppendInt(b, int64(t.Hour()), 10) b = append(b, pt.timeSeparator...) if t.Minute() < 10 { b = append(b, '0') } b = strconv.AppendInt(b, int64(t.Minute()), 10) b = append(b, pt.timeSeparator...) if t.Second() < 10 { b = append(b, '0') } b = strconv.AppendInt(b, int64(t.Second()), 10) return string(b) } // FmtTimeLong returns the long time representation of 't' for 'pt_BR' func (pt *pt_BR) FmtTimeLong(t time.Time) string { b := make([]byte, 0, 32) if t.Hour() < 10 { b = append(b, '0') } b = strconv.AppendInt(b, int64(t.Hour()), 10) b = append(b, pt.timeSeparator...) if t.Minute() < 10 { b = append(b, '0') } b = strconv.AppendInt(b, int64(t.Minute()), 10) b = append(b, pt.timeSeparator...) if t.Second() < 10 { b = append(b, '0') } b = strconv.AppendInt(b, int64(t.Second()), 10) b = append(b, []byte{0x20}...) tz, _ := t.Zone() b = append(b, tz...) return string(b) } // FmtTimeFull returns the full time representation of 't' for 'pt_BR' func (pt *pt_BR) FmtTimeFull(t time.Time) string { b := make([]byte, 0, 32) if t.Hour() < 10 { b = append(b, '0') } b = strconv.AppendInt(b, int64(t.Hour()), 10) b = append(b, pt.timeSeparator...) if t.Minute() < 10 { b = append(b, '0') } b = strconv.AppendInt(b, int64(t.Minute()), 10) b = append(b, pt.timeSeparator...) if t.Second() < 10 { b = append(b, '0') } b = strconv.AppendInt(b, int64(t.Second()), 10) b = append(b, []byte{0x20}...) tz, _ := t.Zone() if btz, ok := pt.timezones[tz]; ok { b = append(b, btz...) } else { b = append(b, tz...) } return string(b) }