forked from WireGuard/wireguard-windows
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathl18n.go
78 lines (69 loc) · 2.9 KB
/
l18n.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
/* SPDX-License-Identifier: MIT
*
* Copyright (C) 2019-2022 WireGuard LLC. All Rights Reserved.
*/
package l18n
import (
"sync"
"golang.org/x/sys/windows"
"golang.org/x/text/language"
"golang.org/x/text/message"
)
var (
printer *message.Printer
printerLock sync.Mutex
)
// prn returns the printer for user preferred UI language.
func prn() *message.Printer {
if printer != nil {
return printer
}
printerLock.Lock()
if printer != nil {
printerLock.Unlock()
return printer
}
printer = message.NewPrinter(lang())
printerLock.Unlock()
return printer
}
// lang returns the user preferred UI language we have most confident translation in the default catalog available.
func lang() (tag language.Tag) {
tag = language.English
confidence := language.No
languages, err := windows.GetUserPreferredUILanguages(windows.MUI_LANGUAGE_NAME)
if err != nil {
return
}
for i := range languages {
t, _, c := message.DefaultCatalog.Matcher().Match(message.MatchLanguage(languages[i]))
if c > confidence {
tag = t
confidence = c
}
}
return
}
// Sprintf is like fmt.Sprintf, but using language-specific formatting.
func Sprintf(key message.Reference, a ...any) string {
return prn().Sprintf(key, a...)
}
// EnumerationSeparator returns enumeration separator. For English and western languages,
// enumeration separator is a comma followed by a space (i.e. ", "). For Chinese, it returns
// "\u3001".
func EnumerationSeparator() string {
// BUG: We could just use `Sprintf(", " /* ...translator instructions... */)` and let the
// individual locale catalog handle its translation. Unfortunately, the gotext utility tries to
// be nice to translators and skips all strings without letters when updating catalogs.
return Sprintf("[EnumerationSeparator]" /* Text to insert between items when listing - most western languages will translate ‘[EnumerationSeparator]’ into ‘, ’ to produce lists like ‘apple, orange, strawberry’. Eastern languages might translate into ‘、’ to produce lists like ‘リンゴ、オレンジ、イチゴ’. */)
}
// UnitSeparator returns the separator to use when concatenating multiple units of the same metric
// (e.g. "1 minute, 32 seconds", "6 feet, 1 inch"). For English and western languages, unit
// separator is a comma followed by a space (i.e. ", "). For Slovenian and Japanese, it returns
// just space.
func UnitSeparator() string {
// BUG: We could just use `Sprintf(", " /* ...translator instructions... */)` and let the
// individual locale catalog handle its translation. Unfortunately, the gotext utility tries to
// be nice to translators and skips all strings without letters when updating catalogs.
return Sprintf("[UnitSeparator]" /* Text to insert when combining units of a measure - most languages will translate ‘[UnitSeparator]’ into ‘ ’ (space) to produce lists like ‘2 minuti 30 sekund’, or empty string ‘’ to produce ‘2分30秒’. */)
}