2022-04-03 12:46:48 +03:00
|
|
|
// Copyright 2022 The Gitea Authors. All rights reserved.
|
2022-11-27 21:20:29 +03:00
|
|
|
// SPDX-License-Identifier: MIT
|
2022-04-03 12:46:48 +03:00
|
|
|
|
|
|
|
package i18n
|
|
|
|
|
|
|
|
import (
|
2022-08-28 12:43:25 +03:00
|
|
|
"io"
|
2022-04-03 12:46:48 +03:00
|
|
|
)
|
|
|
|
|
2022-08-28 12:43:25 +03:00
|
|
|
var DefaultLocales = NewLocaleStore()
|
2022-07-04 13:17:09 +03:00
|
|
|
|
2022-08-28 12:43:25 +03:00
|
|
|
type Locale interface {
|
|
|
|
// Tr translates a given key and arguments for a language
|
2023-07-05 06:41:32 +03:00
|
|
|
Tr(trKey string, trArgs ...any) string
|
2022-08-28 12:43:25 +03:00
|
|
|
// Has reports if a locale has a translation for a given key
|
|
|
|
Has(trKey string) bool
|
2022-06-26 17:19:22 +03:00
|
|
|
}
|
2022-04-03 12:46:48 +03:00
|
|
|
|
2022-08-28 12:43:25 +03:00
|
|
|
// LocaleStore provides the functions common to all locale stores
|
|
|
|
type LocaleStore interface {
|
|
|
|
io.Closer
|
2022-07-04 13:17:09 +03:00
|
|
|
|
2022-08-28 12:43:25 +03:00
|
|
|
// Tr translates a given key and arguments for a language
|
2023-07-05 06:41:32 +03:00
|
|
|
Tr(lang, trKey string, trArgs ...any) string
|
2022-08-28 12:43:25 +03:00
|
|
|
// Has reports if a locale has a translation for a given key
|
|
|
|
Has(lang, trKey string) bool
|
|
|
|
// SetDefaultLang sets the default language to fall back to
|
|
|
|
SetDefaultLang(lang string)
|
|
|
|
// ListLangNameDesc provides paired slices of language names to descriptors
|
|
|
|
ListLangNameDesc() (names, desc []string)
|
|
|
|
// Locale return the locale for the provided language or the default language if not found
|
|
|
|
Locale(langName string) (Locale, bool)
|
|
|
|
// HasLang returns whether a given language is present in the store
|
|
|
|
HasLang(langName string) bool
|
|
|
|
// AddLocaleByIni adds a new language to the store
|
2022-09-25 02:00:16 +03:00
|
|
|
AddLocaleByIni(langName, langDesc string, source, moreSource []byte) error
|
2022-04-03 12:46:48 +03:00
|
|
|
}
|
|
|
|
|
2022-06-26 17:19:22 +03:00
|
|
|
// ResetDefaultLocales resets the current default locales
|
|
|
|
// NOTE: this is not synchronized
|
2022-08-28 12:43:25 +03:00
|
|
|
func ResetDefaultLocales() {
|
|
|
|
if DefaultLocales != nil {
|
|
|
|
_ = DefaultLocales.Close()
|
|
|
|
}
|
|
|
|
DefaultLocales = NewLocaleStore()
|
2022-04-03 12:46:48 +03:00
|
|
|
}
|
|
|
|
|
2022-08-28 12:43:25 +03:00
|
|
|
// GetLocales returns the locale from the default locales
|
|
|
|
func GetLocale(lang string) (Locale, bool) {
|
|
|
|
return DefaultLocales.Locale(lang)
|
2022-04-03 12:46:48 +03:00
|
|
|
}
|