langtable 0.0.65__tar.gz → 0.0.66__tar.gz
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- {langtable-0.0.65 → langtable-0.0.66}/ChangeLog +15 -0
- {langtable-0.0.65 → langtable-0.0.66}/MANIFEST.in +3 -0
- {langtable-0.0.65 → langtable-0.0.66}/Makefile +16 -6
- {langtable-0.0.65 → langtable-0.0.66}/PKG-INFO +25 -28
- {langtable-0.0.65 → langtable-0.0.66}/README +21 -17
- langtable-0.0.66/README.html +226 -0
- langtable-0.0.66/README.md +72 -0
- langtable-0.0.66/langtable/data/languages.xml.gz +0 -0
- langtable-0.0.66/langtable/data/territories.xml.gz +0 -0
- {langtable-0.0.65 → langtable-0.0.66}/langtable/langtable.py +7 -1
- {langtable-0.0.65 → langtable-0.0.66}/langtable.egg-info/PKG-INFO +25 -28
- {langtable-0.0.65 → langtable-0.0.66}/langtable.egg-info/SOURCES.txt +2 -0
- {langtable-0.0.65 → langtable-0.0.66}/main.py +14 -9
- {langtable-0.0.65 → langtable-0.0.66}/setup.py +3 -2
- {langtable-0.0.65 → langtable-0.0.66}/test_cases.py +6 -5
- langtable-0.0.65/langtable/data/languages.xml.gz +0 -0
- langtable-0.0.65/langtable/data/territories.xml.gz +0 -0
- {langtable-0.0.65 → langtable-0.0.66}/COPYING +0 -0
- {langtable-0.0.65 → langtable-0.0.66}/langtable/__init__.py +0 -0
- {langtable-0.0.65 → langtable-0.0.66}/langtable/data/keyboards.xml.gz +0 -0
- {langtable-0.0.65 → langtable-0.0.66}/langtable/data/timezoneidparts.xml.gz +0 -0
- {langtable-0.0.65 → langtable-0.0.66}/langtable/data/timezones.xml.gz +0 -0
- {langtable-0.0.65 → langtable-0.0.66}/langtable/schemas/keyboards.rng +0 -0
- {langtable-0.0.65 → langtable-0.0.66}/langtable/schemas/languages.rng +0 -0
- {langtable-0.0.65 → langtable-0.0.66}/langtable/schemas/territories.rng +0 -0
- {langtable-0.0.65 → langtable-0.0.66}/langtable/schemas/timezoneidparts.rng +0 -0
- {langtable-0.0.65 → langtable-0.0.66}/langtable/schemas/timezones.rng +0 -0
- {langtable-0.0.65 → langtable-0.0.66}/langtable.egg-info/dependency_links.txt +0 -0
- {langtable-0.0.65 → langtable-0.0.66}/langtable.egg-info/not-zip-safe +0 -0
- {langtable-0.0.65 → langtable-0.0.66}/langtable.egg-info/top_level.txt +0 -0
- {langtable-0.0.65 → langtable-0.0.66}/setup.cfg +0 -0
- {langtable-0.0.65 → langtable-0.0.66}/tools/compare_with_glib_source.py +0 -0
- {langtable-0.0.65 → langtable-0.0.66}/tools/list-missing-regions-and-languages.sh +0 -0
- {langtable-0.0.65 → langtable-0.0.66}/unicode-license.txt +0 -0
|
@@ -1,3 +1,18 @@
|
|
|
1
|
+
2024-05-07 Mike FABIAN <mfabian@redhat.com>
|
|
2
|
+
|
|
3
|
+
* Fix syntax error in a keyboard layout name for th
|
|
4
|
+
(Resolves: https://github.com/mike-fabian/langtable/issues/21xs)
|
|
5
|
+
* Add mdf
|
|
6
|
+
* Use “in(eng)” keyboard layout instead of “us” for BD to get AltGr enabled
|
|
7
|
+
* Get translation changes from CLDR
|
|
8
|
+
* Add option to include changed translations as well to the script getting translations from CLDR
|
|
9
|
+
* Add reference to the the PyPI package to the README.md.
|
|
10
|
+
And add a README.html and README generated from the README.md.
|
|
11
|
+
* Make test outputs somewhat more verbose, even when all tests pass
|
|
12
|
+
(Resolves: https://github.com/mike-fabian/langtable/pull/20).
|
|
13
|
+
Thanks to Sebastian <seb128@ubuntu.com> for the pull request.
|
|
14
|
+
* Fix Makefile twine-upload target for new authentification
|
|
15
|
+
|
|
1
16
|
2024-02-08 Mike FABIAN <mfabian@redhat.com>
|
|
2
17
|
|
|
3
18
|
* Add wuu, tok, glk, gbm, ssy
|
|
@@ -9,13 +9,13 @@ gzip: langtable/data/keyboards.xml.gz langtable/data/languages.xml.gz langtable/
|
|
|
9
9
|
|
|
10
10
|
.PHONY: test
|
|
11
11
|
test: gzip
|
|
12
|
-
|
|
12
|
+
python3 langtable/langtable.py
|
|
13
13
|
python3 test_cases.py
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
14
|
+
xmllint --noout --relaxng langtable/schemas/keyboards.rng langtable/data/keyboards.xml.gz
|
|
15
|
+
xmllint --noout --relaxng langtable/schemas/languages.rng langtable/data/languages.xml.gz
|
|
16
|
+
xmllint --noout --relaxng langtable/schemas/territories.rng langtable/data/territories.xml.gz
|
|
17
|
+
xmllint --noout --relaxng langtable/schemas/timezones.rng langtable/data/timezones.xml.gz
|
|
18
|
+
xmllint --noout --relaxng langtable/schemas/timezoneidparts.rng langtable/data/timezoneidparts.xml.gz
|
|
19
19
|
|
|
20
20
|
.PHONY: check
|
|
21
21
|
check: test
|
|
@@ -30,6 +30,10 @@ install: dist
|
|
|
30
30
|
DISTUTILS_DEBUG=$(DEBUG) python3 ./setup.py install --prefix=$(DESTDIR)
|
|
31
31
|
# DISTUTILS_DEBUG=$(DEBUG) python3 ./setup.py install_data --install-dir=$(DATADIR)
|
|
32
32
|
|
|
33
|
+
.PHONY: twine-check
|
|
34
|
+
twine-check: dist
|
|
35
|
+
twine check dist/*
|
|
36
|
+
|
|
33
37
|
# check it here: https://test.pypi.org/manage/project/langtable/releases/
|
|
34
38
|
.PHONY: twine-upload-test
|
|
35
39
|
twine-upload-test: dist
|
|
@@ -76,3 +80,9 @@ review: mockbuild
|
|
|
76
80
|
|
|
77
81
|
rnc: schemas/keyboards.rnc schemas/languages.rnc schemas/territories.rnc schemas/timezones.rnc schemas/timezoneidparts.rnc
|
|
78
82
|
cp schemas/*.rnc data/
|
|
83
|
+
|
|
84
|
+
README: README.html
|
|
85
|
+
w3m -cols 78 -o display_borders=1 -o display_link_number=1 $< > $@
|
|
86
|
+
|
|
87
|
+
README.html: README.md
|
|
88
|
+
pandoc -f gfm -t html --standalone --self-contained --metadata pagetitle="langtable README" $< > $@
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
Metadata-Version: 2.1
|
|
2
2
|
Name: langtable
|
|
3
|
-
Version: 0.0.
|
|
3
|
+
Version: 0.0.66
|
|
4
4
|
Summary: guess reasonable defaults for locale, keyboard, territory, ...
|
|
5
5
|
Home-page: https://github.com/mike-fabian/langtable
|
|
6
6
|
Author: Mike FABIAN
|
|
@@ -13,55 +13,52 @@ Classifier: License :: OSI Approved :: GNU General Public License v3 or later (G
|
|
|
13
13
|
Classifier: Operating System :: POSIX :: Linux
|
|
14
14
|
Classifier: Programming Language :: Python
|
|
15
15
|
Classifier: Topic :: System :: Installation/Setup
|
|
16
|
+
Description-Content-Type: text/markdown
|
|
16
17
|
License-File: COPYING
|
|
17
18
|
|
|
18
|
-
|
|
19
|
-
langtable
|
|
20
|
-
======================================================================
|
|
19
|
+
# langtable
|
|
21
20
|
|
|
22
|
-
|
|
23
|
-
=======================
|
|
21
|
+
[](https://badge.fury.io/py/langtable)
|
|
24
22
|
|
|
25
|
-
|
|
26
|
-
territory, …, if part of that information is already known. For
|
|
27
|
-
example, guess the territory and the keyboard layout if the language
|
|
28
|
-
is known or guess the language and keyboard layout if the territory is
|
|
29
|
-
already known.
|
|
23
|
+
Guessing reasonable defaults for locale, keyboard layout, territory, and language.
|
|
30
24
|
|
|
31
|
-
|
|
32
|
-
|
|
25
|
+
## Purpose of this package
|
|
26
|
+
_langtable_ is used to guess reasonable defaults for locale, keyboard, territory, …, if part of that information is already known. For example, guess the territory and the keyboard layout if the language is known or guess the language and keyboard layout if the territory is already known.
|
|
27
|
+
|
|
28
|
+
## License
|
|
33
29
|
|
|
34
30
|
GPLv3+, see the included file “COPYING”.
|
|
35
31
|
|
|
36
|
-
Translations for languages and territory names are from CLDR which is
|
|
37
|
-
governed by the Unicode Terms of Use, see the included file
|
|
38
|
-
“unicode-license.txt”. The short name for this Unicode license is
|
|
39
|
-
“MIT”. See:
|
|
32
|
+
Translations for languages and territory names are from CLDR which is governed by the Unicode Terms of Use, see the included file “unicode-license.txt”. The short name for this Unicode license is “MIT”. See:
|
|
40
33
|
|
|
41
34
|
https://fedoraproject.org/wiki/Licensing:MIT?rd=Licensing/MIT#Modern_Style_without_sublicense_.28Unicode.29
|
|
42
35
|
|
|
43
|
-
Installation
|
|
44
|
-
============
|
|
36
|
+
## Installation
|
|
45
37
|
|
|
46
38
|
To install langtable, run
|
|
47
39
|
|
|
40
|
+
```
|
|
48
41
|
make install DESTDIR=/usr
|
|
42
|
+
```
|
|
49
43
|
|
|
50
44
|
To create a distribution tarball run
|
|
51
|
-
|
|
45
|
+
```
|
|
52
46
|
make dist
|
|
53
|
-
|
|
47
|
+
```
|
|
54
48
|
To run the test cases in the source directory:
|
|
49
|
+
```
|
|
50
|
+
make check
|
|
51
|
+
```
|
|
55
52
|
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
How to use it
|
|
59
|
-
=============
|
|
53
|
+
## How to use it
|
|
60
54
|
|
|
55
|
+
```
|
|
61
56
|
import langtable
|
|
57
|
+
```
|
|
62
58
|
|
|
63
59
|
Functions in the public API:
|
|
64
60
|
|
|
61
|
+
```
|
|
65
62
|
parse_locale()
|
|
66
63
|
list_locales()
|
|
67
64
|
list_keyboards()
|
|
@@ -86,8 +83,8 @@ Functions in the public API:
|
|
|
86
83
|
list_all_scripts()
|
|
87
84
|
list_all_input_methods()
|
|
88
85
|
list_all_console_fonts()
|
|
86
|
+
```
|
|
89
87
|
|
|
90
|
-
Some examples to show the usage are found in the documentation
|
|
91
|
-
of the public functions in langtable.py.
|
|
88
|
+
Some examples to show the usage are found in the documentation of the public functions in `langtable.py`.
|
|
92
89
|
|
|
93
|
-
|
|
90
|
+
Some more examples are in the test cases in the file `test_cases.py`.
|
|
@@ -1,30 +1,29 @@
|
|
|
1
|
-
======================================================================
|
|
2
1
|
langtable
|
|
3
|
-
|
|
2
|
+
|
|
3
|
+
[1]PyPI version
|
|
4
|
+
|
|
5
|
+
Guessing reasonable defaults for locale, keyboard layout, territory, and
|
|
6
|
+
language.
|
|
4
7
|
|
|
5
8
|
Purpose of this package
|
|
6
|
-
=======================
|
|
7
9
|
|
|
8
10
|
langtable is used to guess reasonable defaults for locale, keyboard,
|
|
9
|
-
territory, …, if part of that information is already known. For
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
already known.
|
|
11
|
+
territory, …, if part of that information is already known. For example,
|
|
12
|
+
guess the territory and the keyboard layout if the language is known or guess
|
|
13
|
+
the language and keyboard layout if the territory is already known.
|
|
13
14
|
|
|
14
15
|
License
|
|
15
|
-
=======
|
|
16
16
|
|
|
17
17
|
GPLv3+, see the included file “COPYING”.
|
|
18
18
|
|
|
19
19
|
Translations for languages and territory names are from CLDR which is
|
|
20
20
|
governed by the Unicode Terms of Use, see the included file
|
|
21
|
-
“unicode-license.txt”. The short name for this Unicode license is
|
|
22
|
-
“MIT”. See:
|
|
21
|
+
“unicode-license.txt”. The short name for this Unicode license is “MIT”. See:
|
|
23
22
|
|
|
24
|
-
https://fedoraproject.org/wiki/Licensing:MIT?rd=Licensing/MIT#
|
|
23
|
+
[2]https://fedoraproject.org/wiki/Licensing:MIT?rd=Licensing/MIT#
|
|
24
|
+
Modern_Style_without_sublicense_.28Unicode.29
|
|
25
25
|
|
|
26
26
|
Installation
|
|
27
|
-
============
|
|
28
27
|
|
|
29
28
|
To install langtable, run
|
|
30
29
|
|
|
@@ -36,10 +35,9 @@ To create a distribution tarball run
|
|
|
36
35
|
|
|
37
36
|
To run the test cases in the source directory:
|
|
38
37
|
|
|
39
|
-
make
|
|
38
|
+
make check
|
|
40
39
|
|
|
41
40
|
How to use it
|
|
42
|
-
=============
|
|
43
41
|
|
|
44
42
|
import langtable
|
|
45
43
|
|
|
@@ -70,7 +68,13 @@ Functions in the public API:
|
|
|
70
68
|
list_all_input_methods()
|
|
71
69
|
list_all_console_fonts()
|
|
72
70
|
|
|
73
|
-
Some examples to show the usage are found in the documentation
|
|
74
|
-
|
|
71
|
+
Some examples to show the usage are found in the documentation of the public
|
|
72
|
+
functions in langtable.py.
|
|
73
|
+
|
|
74
|
+
Some more examples are in the test cases in the file test_cases.py.
|
|
75
|
+
|
|
76
|
+
|
|
77
|
+
References:
|
|
75
78
|
|
|
76
|
-
|
|
79
|
+
[1] https://badge.fury.io/py/langtable
|
|
80
|
+
[2] https://fedoraproject.org/wiki/Licensing:MIT?rd=Licensing/MIT#Modern_Style_without_sublicense_.28Unicode.29
|
|
@@ -0,0 +1,226 @@
|
|
|
1
|
+
<!DOCTYPE html>
|
|
2
|
+
<html xmlns="http://www.w3.org/1999/xhtml" lang xml:lang>
|
|
3
|
+
<head>
|
|
4
|
+
<meta charset="utf-8" />
|
|
5
|
+
<meta name="generator" content="pandoc" />
|
|
6
|
+
<meta name="viewport" content="width=device-width, initial-scale=1.0, user-scalable=yes" />
|
|
7
|
+
<title>langtable README</title>
|
|
8
|
+
<style>
|
|
9
|
+
html {
|
|
10
|
+
color: #1a1a1a;
|
|
11
|
+
background-color: #fdfdfd;
|
|
12
|
+
}
|
|
13
|
+
body {
|
|
14
|
+
margin: 0 auto;
|
|
15
|
+
max-width: 36em;
|
|
16
|
+
padding-left: 50px;
|
|
17
|
+
padding-right: 50px;
|
|
18
|
+
padding-top: 50px;
|
|
19
|
+
padding-bottom: 50px;
|
|
20
|
+
hyphens: auto;
|
|
21
|
+
overflow-wrap: break-word;
|
|
22
|
+
text-rendering: optimizeLegibility;
|
|
23
|
+
font-kerning: normal;
|
|
24
|
+
}
|
|
25
|
+
@media (max-width: 600px) {
|
|
26
|
+
body {
|
|
27
|
+
font-size: 0.9em;
|
|
28
|
+
padding: 12px;
|
|
29
|
+
}
|
|
30
|
+
h1 {
|
|
31
|
+
font-size: 1.8em;
|
|
32
|
+
}
|
|
33
|
+
}
|
|
34
|
+
@media print {
|
|
35
|
+
html {
|
|
36
|
+
background-color: white;
|
|
37
|
+
}
|
|
38
|
+
body {
|
|
39
|
+
background-color: transparent;
|
|
40
|
+
color: black;
|
|
41
|
+
font-size: 12pt;
|
|
42
|
+
}
|
|
43
|
+
p, h2, h3 {
|
|
44
|
+
orphans: 3;
|
|
45
|
+
widows: 3;
|
|
46
|
+
}
|
|
47
|
+
h2, h3, h4 {
|
|
48
|
+
page-break-after: avoid;
|
|
49
|
+
}
|
|
50
|
+
}
|
|
51
|
+
p {
|
|
52
|
+
margin: 1em 0;
|
|
53
|
+
}
|
|
54
|
+
a {
|
|
55
|
+
color: #1a1a1a;
|
|
56
|
+
}
|
|
57
|
+
a:visited {
|
|
58
|
+
color: #1a1a1a;
|
|
59
|
+
}
|
|
60
|
+
img {
|
|
61
|
+
max-width: 100%;
|
|
62
|
+
}
|
|
63
|
+
h1, h2, h3, h4, h5, h6 {
|
|
64
|
+
margin-top: 1.4em;
|
|
65
|
+
}
|
|
66
|
+
h5, h6 {
|
|
67
|
+
font-size: 1em;
|
|
68
|
+
font-style: italic;
|
|
69
|
+
}
|
|
70
|
+
h6 {
|
|
71
|
+
font-weight: normal;
|
|
72
|
+
}
|
|
73
|
+
ol, ul {
|
|
74
|
+
padding-left: 1.7em;
|
|
75
|
+
margin-top: 1em;
|
|
76
|
+
}
|
|
77
|
+
li > ol, li > ul {
|
|
78
|
+
margin-top: 0;
|
|
79
|
+
}
|
|
80
|
+
blockquote {
|
|
81
|
+
margin: 1em 0 1em 1.7em;
|
|
82
|
+
padding-left: 1em;
|
|
83
|
+
border-left: 2px solid #e6e6e6;
|
|
84
|
+
color: #606060;
|
|
85
|
+
}
|
|
86
|
+
code {
|
|
87
|
+
font-family: Menlo, Monaco, Consolas, 'Lucida Console', monospace;
|
|
88
|
+
font-size: 85%;
|
|
89
|
+
margin: 0;
|
|
90
|
+
hyphens: manual;
|
|
91
|
+
}
|
|
92
|
+
pre {
|
|
93
|
+
margin: 1em 0;
|
|
94
|
+
overflow: auto;
|
|
95
|
+
}
|
|
96
|
+
pre code {
|
|
97
|
+
padding: 0;
|
|
98
|
+
overflow: visible;
|
|
99
|
+
overflow-wrap: normal;
|
|
100
|
+
}
|
|
101
|
+
.sourceCode {
|
|
102
|
+
background-color: transparent;
|
|
103
|
+
overflow: visible;
|
|
104
|
+
}
|
|
105
|
+
hr {
|
|
106
|
+
background-color: #1a1a1a;
|
|
107
|
+
border: none;
|
|
108
|
+
height: 1px;
|
|
109
|
+
margin: 1em 0;
|
|
110
|
+
}
|
|
111
|
+
table {
|
|
112
|
+
margin: 1em 0;
|
|
113
|
+
border-collapse: collapse;
|
|
114
|
+
width: 100%;
|
|
115
|
+
overflow-x: auto;
|
|
116
|
+
display: block;
|
|
117
|
+
font-variant-numeric: lining-nums tabular-nums;
|
|
118
|
+
}
|
|
119
|
+
table caption {
|
|
120
|
+
margin-bottom: 0.75em;
|
|
121
|
+
}
|
|
122
|
+
tbody {
|
|
123
|
+
margin-top: 0.5em;
|
|
124
|
+
border-top: 1px solid #1a1a1a;
|
|
125
|
+
border-bottom: 1px solid #1a1a1a;
|
|
126
|
+
}
|
|
127
|
+
th {
|
|
128
|
+
border-top: 1px solid #1a1a1a;
|
|
129
|
+
padding: 0.25em 0.5em 0.25em 0.5em;
|
|
130
|
+
}
|
|
131
|
+
td {
|
|
132
|
+
padding: 0.125em 0.5em 0.25em 0.5em;
|
|
133
|
+
}
|
|
134
|
+
header {
|
|
135
|
+
margin-bottom: 4em;
|
|
136
|
+
text-align: center;
|
|
137
|
+
}
|
|
138
|
+
#TOC li {
|
|
139
|
+
list-style: none;
|
|
140
|
+
}
|
|
141
|
+
#TOC ul {
|
|
142
|
+
padding-left: 1.3em;
|
|
143
|
+
}
|
|
144
|
+
#TOC > ul {
|
|
145
|
+
padding-left: 0;
|
|
146
|
+
}
|
|
147
|
+
#TOC a:not(:hover) {
|
|
148
|
+
text-decoration: none;
|
|
149
|
+
}
|
|
150
|
+
code{white-space: pre-wrap;}
|
|
151
|
+
span.smallcaps{font-variant: small-caps;}
|
|
152
|
+
div.columns{display: flex; gap: min(4vw, 1.5em);}
|
|
153
|
+
div.column{flex: auto; overflow-x: auto;}
|
|
154
|
+
div.hanging-indent{margin-left: 1.5em; text-indent: -1.5em;}
|
|
155
|
+
|
|
156
|
+
ul.task-list[class]{list-style: none;}
|
|
157
|
+
ul.task-list li input[type="checkbox"] {
|
|
158
|
+
font-size: inherit;
|
|
159
|
+
width: 0.8em;
|
|
160
|
+
margin: 0 0.8em 0.2em -1.6em;
|
|
161
|
+
vertical-align: middle;
|
|
162
|
+
}
|
|
163
|
+
.display.math{display: block; text-align: center; margin: 0.5rem auto;}
|
|
164
|
+
</style>
|
|
165
|
+
<!--[if lt IE 9]>
|
|
166
|
+
<script src="//cdnjs.cloudflare.com/ajax/libs/html5shiv/3.7.3/html5shiv-printshiv.min.js"></script>
|
|
167
|
+
<![endif]-->
|
|
168
|
+
</head>
|
|
169
|
+
<body>
|
|
170
|
+
<h1 id="langtable">langtable</h1>
|
|
171
|
+
<p><a href="https://badge.fury.io/py/langtable"><img src="" alt="PyPI version" /></a></p>
|
|
172
|
+
<p>Guessing reasonable defaults for locale, keyboard layout, territory,
|
|
173
|
+
and language.</p>
|
|
174
|
+
<h2 id="purpose-of-this-package">Purpose of this package</h2>
|
|
175
|
+
<p><em>langtable</em> is used to guess reasonable defaults for locale,
|
|
176
|
+
keyboard, territory, …, if part of that information is already known.
|
|
177
|
+
For example, guess the territory and the keyboard layout if the language
|
|
178
|
+
is known or guess the language and keyboard layout if the territory is
|
|
179
|
+
already known.</p>
|
|
180
|
+
<h2 id="license">License</h2>
|
|
181
|
+
<p>GPLv3+, see the included file “COPYING”.</p>
|
|
182
|
+
<p>Translations for languages and territory names are from CLDR which is
|
|
183
|
+
governed by the Unicode Terms of Use, see the included file
|
|
184
|
+
“unicode-license.txt”. The short name for this Unicode license is “MIT”.
|
|
185
|
+
See:</p>
|
|
186
|
+
<p><a href="https://fedoraproject.org/wiki/Licensing:MIT?rd=Licensing/MIT#Modern_Style_without_sublicense_.28Unicode.29">https://fedoraproject.org/wiki/Licensing:MIT?rd=Licensing/MIT#Modern_Style_without_sublicense_.28Unicode.29</a></p>
|
|
187
|
+
<h2 id="installation">Installation</h2>
|
|
188
|
+
<p>To install langtable, run</p>
|
|
189
|
+
<pre><code> make install DESTDIR=/usr</code></pre>
|
|
190
|
+
<p>To create a distribution tarball run</p>
|
|
191
|
+
<pre><code> make dist</code></pre>
|
|
192
|
+
<p>To run the test cases in the source directory:</p>
|
|
193
|
+
<pre><code> make check</code></pre>
|
|
194
|
+
<h2 id="how-to-use-it">How to use it</h2>
|
|
195
|
+
<pre><code>import langtable</code></pre>
|
|
196
|
+
<p>Functions in the public API:</p>
|
|
197
|
+
<pre><code> parse_locale()
|
|
198
|
+
list_locales()
|
|
199
|
+
list_keyboards()
|
|
200
|
+
list_common_languages()
|
|
201
|
+
list_common_locales()
|
|
202
|
+
list_common_keyboards()
|
|
203
|
+
list_consolefonts()
|
|
204
|
+
list_inputmethods()
|
|
205
|
+
list_timezones()
|
|
206
|
+
list_scripts()
|
|
207
|
+
language_name()
|
|
208
|
+
territory_name()
|
|
209
|
+
timezone_name()
|
|
210
|
+
languageId()
|
|
211
|
+
territoryId()
|
|
212
|
+
supports_ascii()
|
|
213
|
+
list_all_languages()
|
|
214
|
+
list_all_locales()
|
|
215
|
+
list_all_keyboards()
|
|
216
|
+
list_all_territories()
|
|
217
|
+
list_all_timezones()
|
|
218
|
+
list_all_scripts()
|
|
219
|
+
list_all_input_methods()
|
|
220
|
+
list_all_console_fonts()</code></pre>
|
|
221
|
+
<p>Some examples to show the usage are found in the documentation of the
|
|
222
|
+
public functions in <code>langtable.py</code>.</p>
|
|
223
|
+
<p>Some more examples are in the test cases in the file
|
|
224
|
+
<code>test_cases.py</code>.</p>
|
|
225
|
+
</body>
|
|
226
|
+
</html>
|
|
@@ -0,0 +1,72 @@
|
|
|
1
|
+
# langtable
|
|
2
|
+
|
|
3
|
+
[](https://badge.fury.io/py/langtable)
|
|
4
|
+
|
|
5
|
+
Guessing reasonable defaults for locale, keyboard layout, territory, and language.
|
|
6
|
+
|
|
7
|
+
## Purpose of this package
|
|
8
|
+
_langtable_ is used to guess reasonable defaults for locale, keyboard, territory, …, if part of that information is already known. For example, guess the territory and the keyboard layout if the language is known or guess the language and keyboard layout if the territory is already known.
|
|
9
|
+
|
|
10
|
+
## License
|
|
11
|
+
|
|
12
|
+
GPLv3+, see the included file “COPYING”.
|
|
13
|
+
|
|
14
|
+
Translations for languages and territory names are from CLDR which is governed by the Unicode Terms of Use, see the included file “unicode-license.txt”. The short name for this Unicode license is “MIT”. See:
|
|
15
|
+
|
|
16
|
+
https://fedoraproject.org/wiki/Licensing:MIT?rd=Licensing/MIT#Modern_Style_without_sublicense_.28Unicode.29
|
|
17
|
+
|
|
18
|
+
## Installation
|
|
19
|
+
|
|
20
|
+
To install langtable, run
|
|
21
|
+
|
|
22
|
+
```
|
|
23
|
+
make install DESTDIR=/usr
|
|
24
|
+
```
|
|
25
|
+
|
|
26
|
+
To create a distribution tarball run
|
|
27
|
+
```
|
|
28
|
+
make dist
|
|
29
|
+
```
|
|
30
|
+
To run the test cases in the source directory:
|
|
31
|
+
```
|
|
32
|
+
make check
|
|
33
|
+
```
|
|
34
|
+
|
|
35
|
+
## How to use it
|
|
36
|
+
|
|
37
|
+
```
|
|
38
|
+
import langtable
|
|
39
|
+
```
|
|
40
|
+
|
|
41
|
+
Functions in the public API:
|
|
42
|
+
|
|
43
|
+
```
|
|
44
|
+
parse_locale()
|
|
45
|
+
list_locales()
|
|
46
|
+
list_keyboards()
|
|
47
|
+
list_common_languages()
|
|
48
|
+
list_common_locales()
|
|
49
|
+
list_common_keyboards()
|
|
50
|
+
list_consolefonts()
|
|
51
|
+
list_inputmethods()
|
|
52
|
+
list_timezones()
|
|
53
|
+
list_scripts()
|
|
54
|
+
language_name()
|
|
55
|
+
territory_name()
|
|
56
|
+
timezone_name()
|
|
57
|
+
languageId()
|
|
58
|
+
territoryId()
|
|
59
|
+
supports_ascii()
|
|
60
|
+
list_all_languages()
|
|
61
|
+
list_all_locales()
|
|
62
|
+
list_all_keyboards()
|
|
63
|
+
list_all_territories()
|
|
64
|
+
list_all_timezones()
|
|
65
|
+
list_all_scripts()
|
|
66
|
+
list_all_input_methods()
|
|
67
|
+
list_all_console_fonts()
|
|
68
|
+
```
|
|
69
|
+
|
|
70
|
+
Some examples to show the usage are found in the documentation of the public functions in `langtable.py`.
|
|
71
|
+
|
|
72
|
+
Some more examples are in the test cases in the file `test_cases.py`.
|
|
Binary file
|
|
Binary file
|
|
@@ -2719,5 +2719,11 @@ __module_init = __ModuleInitializer()
|
|
|
2719
2719
|
|
|
2720
2720
|
if __name__ == "__main__":
|
|
2721
2721
|
import doctest
|
|
2722
|
+
import sys
|
|
2722
2723
|
_init()
|
|
2723
|
-
doctest.testmod()
|
|
2724
|
+
(FAILED, ATTEMPTED) = doctest.testmod()
|
|
2725
|
+
print(f'{ATTEMPTED} tests run. {ATTEMPTED - FAILED} passed and {FAILED} failed.')
|
|
2726
|
+
if FAILED:
|
|
2727
|
+
sys.exit(FAILED)
|
|
2728
|
+
print(f'All tests passed.')
|
|
2729
|
+
sys.exit(0)
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
Metadata-Version: 2.1
|
|
2
2
|
Name: langtable
|
|
3
|
-
Version: 0.0.
|
|
3
|
+
Version: 0.0.66
|
|
4
4
|
Summary: guess reasonable defaults for locale, keyboard, territory, ...
|
|
5
5
|
Home-page: https://github.com/mike-fabian/langtable
|
|
6
6
|
Author: Mike FABIAN
|
|
@@ -13,55 +13,52 @@ Classifier: License :: OSI Approved :: GNU General Public License v3 or later (G
|
|
|
13
13
|
Classifier: Operating System :: POSIX :: Linux
|
|
14
14
|
Classifier: Programming Language :: Python
|
|
15
15
|
Classifier: Topic :: System :: Installation/Setup
|
|
16
|
+
Description-Content-Type: text/markdown
|
|
16
17
|
License-File: COPYING
|
|
17
18
|
|
|
18
|
-
|
|
19
|
-
langtable
|
|
20
|
-
======================================================================
|
|
19
|
+
# langtable
|
|
21
20
|
|
|
22
|
-
|
|
23
|
-
=======================
|
|
21
|
+
[](https://badge.fury.io/py/langtable)
|
|
24
22
|
|
|
25
|
-
|
|
26
|
-
territory, …, if part of that information is already known. For
|
|
27
|
-
example, guess the territory and the keyboard layout if the language
|
|
28
|
-
is known or guess the language and keyboard layout if the territory is
|
|
29
|
-
already known.
|
|
23
|
+
Guessing reasonable defaults for locale, keyboard layout, territory, and language.
|
|
30
24
|
|
|
31
|
-
|
|
32
|
-
|
|
25
|
+
## Purpose of this package
|
|
26
|
+
_langtable_ is used to guess reasonable defaults for locale, keyboard, territory, …, if part of that information is already known. For example, guess the territory and the keyboard layout if the language is known or guess the language and keyboard layout if the territory is already known.
|
|
27
|
+
|
|
28
|
+
## License
|
|
33
29
|
|
|
34
30
|
GPLv3+, see the included file “COPYING”.
|
|
35
31
|
|
|
36
|
-
Translations for languages and territory names are from CLDR which is
|
|
37
|
-
governed by the Unicode Terms of Use, see the included file
|
|
38
|
-
“unicode-license.txt”. The short name for this Unicode license is
|
|
39
|
-
“MIT”. See:
|
|
32
|
+
Translations for languages and territory names are from CLDR which is governed by the Unicode Terms of Use, see the included file “unicode-license.txt”. The short name for this Unicode license is “MIT”. See:
|
|
40
33
|
|
|
41
34
|
https://fedoraproject.org/wiki/Licensing:MIT?rd=Licensing/MIT#Modern_Style_without_sublicense_.28Unicode.29
|
|
42
35
|
|
|
43
|
-
Installation
|
|
44
|
-
============
|
|
36
|
+
## Installation
|
|
45
37
|
|
|
46
38
|
To install langtable, run
|
|
47
39
|
|
|
40
|
+
```
|
|
48
41
|
make install DESTDIR=/usr
|
|
42
|
+
```
|
|
49
43
|
|
|
50
44
|
To create a distribution tarball run
|
|
51
|
-
|
|
45
|
+
```
|
|
52
46
|
make dist
|
|
53
|
-
|
|
47
|
+
```
|
|
54
48
|
To run the test cases in the source directory:
|
|
49
|
+
```
|
|
50
|
+
make check
|
|
51
|
+
```
|
|
55
52
|
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
How to use it
|
|
59
|
-
=============
|
|
53
|
+
## How to use it
|
|
60
54
|
|
|
55
|
+
```
|
|
61
56
|
import langtable
|
|
57
|
+
```
|
|
62
58
|
|
|
63
59
|
Functions in the public API:
|
|
64
60
|
|
|
61
|
+
```
|
|
65
62
|
parse_locale()
|
|
66
63
|
list_locales()
|
|
67
64
|
list_keyboards()
|
|
@@ -86,8 +83,8 @@ Functions in the public API:
|
|
|
86
83
|
list_all_scripts()
|
|
87
84
|
list_all_input_methods()
|
|
88
85
|
list_all_console_fonts()
|
|
86
|
+
```
|
|
89
87
|
|
|
90
|
-
Some examples to show the usage are found in the documentation
|
|
91
|
-
of the public functions in langtable.py.
|
|
88
|
+
Some examples to show the usage are found in the documentation of the public functions in `langtable.py`.
|
|
92
89
|
|
|
93
|
-
|
|
90
|
+
Some more examples are in the test cases in the file `test_cases.py`.
|
|
@@ -61,6 +61,10 @@ def parse_args():
|
|
|
61
61
|
type=str,
|
|
62
62
|
default='./langtable.log',
|
|
63
63
|
help='log file, default is %(default)s')
|
|
64
|
+
parser.add_argument('-c', '--include_changes',
|
|
65
|
+
action='store_true',
|
|
66
|
+
default=False,
|
|
67
|
+
help='Also write changed translations, not only new translations, default is %(default)s.')
|
|
64
68
|
parser.add_argument('-d', '--debug',
|
|
65
69
|
action='store_true',
|
|
66
70
|
help='print debugging output')
|
|
@@ -133,7 +137,7 @@ def read_translations_from_cldr_file(file = None):
|
|
|
133
137
|
translations_timezone_cities[timezone_city_aliases[alias]] = translations_timezone_cities[alias]
|
|
134
138
|
return
|
|
135
139
|
|
|
136
|
-
def get_translations_from_cldr(main_cldr_dir = None):
|
|
140
|
+
def get_translations_from_cldr(main_cldr_dir = None, include_changes=False):
|
|
137
141
|
for target_language in sorted(langtable._languages_db):
|
|
138
142
|
cldr_file = main_cldr_dir+'/'+target_language+'.xml'
|
|
139
143
|
if not os.path.exists(cldr_file):
|
|
@@ -165,8 +169,8 @@ def get_translations_from_cldr(main_cldr_dir = None):
|
|
|
165
169
|
'language_to_translate': language_to_translate,
|
|
166
170
|
'target_language': target_language,
|
|
167
171
|
'tr': translations_languages[language_to_translate]})
|
|
168
|
-
|
|
169
|
-
|
|
172
|
+
if include_changes:
|
|
173
|
+
langtable._languages_db[language_to_translate].names[target_language] = translations_languages[language_to_translate]
|
|
170
174
|
else:
|
|
171
175
|
if opts['debug']:
|
|
172
176
|
print("Not in langtable: %(language_to_translate)s" %{
|
|
@@ -194,8 +198,8 @@ def get_translations_from_cldr(main_cldr_dir = None):
|
|
|
194
198
|
print("+ %(territory_to_translate)s → %(target_language)s = %(tr)s" %{'territory_to_translate': territory_to_translate,
|
|
195
199
|
'target_language': target_language,
|
|
196
200
|
'tr': translations_territories[territory_to_translate]})
|
|
197
|
-
|
|
198
|
-
|
|
201
|
+
if include_changes:
|
|
202
|
+
langtable._territories_db[territory_to_translate].names[target_language] = translations_territories[territory_to_translate]
|
|
199
203
|
else:
|
|
200
204
|
if opts['debug']:
|
|
201
205
|
print("Not in langtable: %(territory_to_translate)s" %{
|
|
@@ -228,8 +232,8 @@ def get_translations_from_cldr(main_cldr_dir = None):
|
|
|
228
232
|
'timezone_city_to_translate': timezone_city_to_translate,
|
|
229
233
|
'target_language': target_language,
|
|
230
234
|
'tr': translations_timezone_cities[timezone_city_to_translate]})
|
|
231
|
-
|
|
232
|
-
|
|
235
|
+
if include_changes:
|
|
236
|
+
langtable._timezoneIdParts_db[timezone_city_to_translate].names[target_language] = translations_timezone_cities[timezone_city_to_translate]
|
|
233
237
|
return
|
|
234
238
|
|
|
235
239
|
def _test_timezone_names():
|
|
@@ -251,7 +255,9 @@ def main():
|
|
|
251
255
|
langtable._init(debug = True,
|
|
252
256
|
logfilename = args.logfilename)
|
|
253
257
|
|
|
254
|
-
get_translations_from_cldr(
|
|
258
|
+
get_translations_from_cldr(
|
|
259
|
+
main_cldr_dir='/local/mfabian/src/cldr/common/main',
|
|
260
|
+
include_changes=args.include_changes)
|
|
255
261
|
|
|
256
262
|
#_test_timezone_names()
|
|
257
263
|
|
|
@@ -261,6 +267,5 @@ def main():
|
|
|
261
267
|
timezonesfilename = args.timezonesoutputfile,
|
|
262
268
|
timezoneidpartsfilename = args.timezoneidpartsoutputfile)
|
|
263
269
|
|
|
264
|
-
|
|
265
270
|
if __name__ == '__main__':
|
|
266
271
|
main()
|
|
@@ -8,10 +8,11 @@ setuptools.setup(
|
|
|
8
8
|
# within the egg directory easily:
|
|
9
9
|
zip_safe=False,
|
|
10
10
|
name='langtable',
|
|
11
|
-
version='0.0.
|
|
11
|
+
version='0.0.66',
|
|
12
12
|
packages=setuptools.find_packages(),
|
|
13
13
|
description='guess reasonable defaults for locale, keyboard, territory, ...',
|
|
14
|
-
long_description=codecs.open('README', encoding='UTF-8').read(),
|
|
14
|
+
long_description=codecs.open('README.md', encoding='UTF-8').read(),
|
|
15
|
+
long_description_content_type='text/markdown',
|
|
15
16
|
license="GPL-3.0-or-later",
|
|
16
17
|
author='Mike FABIAN',
|
|
17
18
|
author_email='mfabian@redhat.com',
|
|
@@ -761,8 +761,8 @@ def dummy():
|
|
|
761
761
|
BD: ['bn_BD.UTF-8']
|
|
762
762
|
+: ['bn_BD.UTF-8']
|
|
763
763
|
bn: ['in(eng)']
|
|
764
|
-
BD: ['
|
|
765
|
-
+: ['
|
|
764
|
+
BD: ['in(eng)']
|
|
765
|
+
+: ['in(eng)']
|
|
766
766
|
|
|
767
767
|
>>> _test_language_territory(show_weights=False, languageId="bn", territoryId="IN") # doctest: +NORMALIZE_WHITESPACE
|
|
768
768
|
bn: ['bn_BD.UTF-8', 'bn_IN.UTF-8']
|
|
@@ -2155,9 +2155,9 @@ def dummy():
|
|
|
2155
2155
|
['ar', 'en', 'fr', 'de', 'ja', 'zh', 'ru', 'es']
|
|
2156
2156
|
|
|
2157
2157
|
>>> print(list_all_languages()) # doctest: +NORMALIZE_WHITESPACE
|
|
2158
|
-
['aa', 'ab', 'af', 'agq', 'agr', 'ak', 'am', 'an', 'anp', 'ar', 'as', 'asa', 'ast', 'av', 'ay', 'ayc', 'ayr', 'az', 'ba', 'bas', 'be', 'bem', 'ber', 'bez', 'bg', 'bhb', 'bho', 'bi', 'bih', 'bin', 'bm', 'bn', 'bo', 'br', 'brx', 'bs', 'bua', 'byn', 'ca', 'ca_ES_VALENCIA', 'ccp', 'ce', 'cgg', 'ch', 'chm', 'chr', 'ckb', 'cmn', 'co', 'cop', 'crh', 'cs', 'csb', 'cu', 'cv', 'cy', 'da', 'dav', 'de', 'dje', 'doi', 'dsb', 'dua', 'dv', 'dyo', 'dz', 'ebu', 'ee', 'el', 'en', 'eo', 'es', 'et', 'eu', 'ewo', 'fa', 'fat', 'ff', 'fi', 'fil', 'fj', 'fo', 'fr', 'fur', 'fy', 'ga', 'gbm', 'gd', 'gez', 'gl', 'glk', 'gn', 'grc', 'gsw', 'gu', 'guz', 'gv', 'ha', 'hak', 'haw', 'he', 'hi', 'hif', 'hil', 'hne', 'ho', 'hr', 'hsb', 'ht', 'hu', 'hy', 'hz', 'ia', 'id', 'ie', 'ig', 'ii', 'ik', 'ilo', 'io', 'is', 'it', 'iu', 'iw', 'ja', 'jgo', 'jmc', 'jv', 'ka', 'kaa', 'kab', 'kam', 'kde', 'kea', 'kg', 'khb', 'khq', 'ki', 'kj', 'kk', 'kkj', 'kl', 'kln', 'km', 'kn', 'ko', 'kok', 'kr', 'ks', 'ks_Arab', 'ks_Deva', 'ksb', 'ksf', 'ksh', 'ku', 'kum', 'kv', 'kw', 'kwm', 'ky', 'la', 'lag', 'lah', 'lb', 'lez', 'lg', 'li', 'lij', 'lkt', 'ln', 'lo', 'lrc', 'lt', 'lu', 'luo', 'luy', 'lv', 'lzh', 'mag', 'mai', 'mas', 'mer', 'mfe', 'mg', 'mgh', 'mgo', 'mh', 'mhr', 'mi', 'miq', 'mjw', 'mk', 'ml', 'mn', 'mni', 'mnw', 'mo', 'mos', 'mr', 'ms', 'mt', 'mua', 'my', 'mzn', 'na', 'nan', 'naq', 'nb', 'nd', 'nds', 'ne', 'new', 'ng', 'nhn', 'niu', 'nl', 'nmg', 'nn', 'nnh', 'no', 'nqo', 'nr', 'nso', 'nus', 'nv', 'ny', 'nyn', 'oc', 'om', 'or', 'os', 'osa', 'ota', 'pa', 'pap', 'pl', 'prg', 'ps', 'pt', 'qu', 'quh', 'quz', 'raj', 'rif', 'rm', 'rn', 'ro', 'rof', 'ru', 'rw', 'rwk', 'sa', 'sah', 'saq', 'sat', 'sbp', 'sc', 'sco', 'sd', 'sd_Arab', 'sd_Deva', 'se', 'seh', 'sel', 'ses', 'sg', 'sgs', 'sh', 'shi', 'shn', 'shs', 'si', 'sid', 'sk', 'sl', 'sm', 'sma', 'smj', 'smn', 'sms', 'sn', 'so', 'sq', 'sr', 'sr_Cyrl', 'sr_Latn', 'ss', 'ssy', 'st', 'su', 'sv', 'sw', 'syc', 'syr', 'szl', 'ta', 'tcy', 'te', 'teo', 'tet', 'tg', 'th', 'the', 'ti', 'tig', 'tk', 'tl', 'tn', 'to', 'tok', 'tpi', 'tr', 'ts', 'tt', 'tt_Cyrl', 'tt_Latn', 'tw', 'twq', 'txg', 'ty', 'tyv', 'tzm', 'udm', 'ug', 'uk', 'unm', 'ur', 'uz', 'vai', 've', 'vi', 'vo', 'vot', 'vun', 'wa', 'wae', 'wal', 'wen', 'wo', 'wuu', 'xal', 'xh', 'xog', 'xzh', 'yap', 'yav', 'yi', 'yo', 'yue', 'yuw', 'za', 'zgh', 'zh', 'zh_Hans', 'zh_Hans_CN', 'zh_Hans_SG', 'zh_Hant', 'zh_Hant_HK', 'zh_Hant_MO', 'zh_Hant_TW', 'zu']
|
|
2158
|
+
['aa', 'ab', 'af', 'agq', 'agr', 'ak', 'am', 'an', 'anp', 'ar', 'as', 'asa', 'ast', 'av', 'ay', 'ayc', 'ayr', 'az', 'ba', 'bas', 'be', 'bem', 'ber', 'bez', 'bg', 'bhb', 'bho', 'bi', 'bih', 'bin', 'bm', 'bn', 'bo', 'br', 'brx', 'bs', 'bua', 'byn', 'ca', 'ca_ES_VALENCIA', 'ccp', 'ce', 'cgg', 'ch', 'chm', 'chr', 'ckb', 'cmn', 'co', 'cop', 'crh', 'cs', 'csb', 'cu', 'cv', 'cy', 'da', 'dav', 'de', 'dje', 'doi', 'dsb', 'dua', 'dv', 'dyo', 'dz', 'ebu', 'ee', 'el', 'en', 'eo', 'es', 'et', 'eu', 'ewo', 'fa', 'fat', 'ff', 'fi', 'fil', 'fj', 'fo', 'fr', 'fur', 'fy', 'ga', 'gbm', 'gd', 'gez', 'gl', 'glk', 'gn', 'grc', 'gsw', 'gu', 'guz', 'gv', 'ha', 'hak', 'haw', 'he', 'hi', 'hif', 'hil', 'hne', 'ho', 'hr', 'hsb', 'ht', 'hu', 'hy', 'hz', 'ia', 'id', 'ie', 'ig', 'ii', 'ik', 'ilo', 'io', 'is', 'it', 'iu', 'iw', 'ja', 'jgo', 'jmc', 'jv', 'ka', 'kaa', 'kab', 'kam', 'kde', 'kea', 'kg', 'khb', 'khq', 'ki', 'kj', 'kk', 'kkj', 'kl', 'kln', 'km', 'kn', 'ko', 'kok', 'kr', 'ks', 'ks_Arab', 'ks_Deva', 'ksb', 'ksf', 'ksh', 'ku', 'kum', 'kv', 'kw', 'kwm', 'ky', 'la', 'lag', 'lah', 'lb', 'lez', 'lg', 'li', 'lij', 'lkt', 'ln', 'lo', 'lrc', 'lt', 'lu', 'luo', 'luy', 'lv', 'lzh', 'mag', 'mai', 'mas', 'mdf', 'mer', 'mfe', 'mg', 'mgh', 'mgo', 'mh', 'mhr', 'mi', 'miq', 'mjw', 'mk', 'ml', 'mn', 'mni', 'mnw', 'mo', 'mos', 'mr', 'ms', 'mt', 'mua', 'my', 'mzn', 'na', 'nan', 'naq', 'nb', 'nd', 'nds', 'ne', 'new', 'ng', 'nhn', 'niu', 'nl', 'nmg', 'nn', 'nnh', 'no', 'nqo', 'nr', 'nso', 'nus', 'nv', 'ny', 'nyn', 'oc', 'om', 'or', 'os', 'osa', 'ota', 'pa', 'pap', 'pl', 'prg', 'ps', 'pt', 'qu', 'quh', 'quz', 'raj', 'rif', 'rm', 'rn', 'ro', 'rof', 'ru', 'rw', 'rwk', 'sa', 'sah', 'saq', 'sat', 'sbp', 'sc', 'sco', 'sd', 'sd_Arab', 'sd_Deva', 'se', 'seh', 'sel', 'ses', 'sg', 'sgs', 'sh', 'shi', 'shn', 'shs', 'si', 'sid', 'sk', 'sl', 'sm', 'sma', 'smj', 'smn', 'sms', 'sn', 'so', 'sq', 'sr', 'sr_Cyrl', 'sr_Latn', 'ss', 'ssy', 'st', 'su', 'sv', 'sw', 'syc', 'syr', 'szl', 'ta', 'tcy', 'te', 'teo', 'tet', 'tg', 'th', 'the', 'ti', 'tig', 'tk', 'tl', 'tn', 'to', 'tok', 'tpi', 'tr', 'ts', 'tt', 'tt_Cyrl', 'tt_Latn', 'tw', 'twq', 'txg', 'ty', 'tyv', 'tzm', 'udm', 'ug', 'uk', 'unm', 'ur', 'uz', 'vai', 've', 'vi', 'vo', 'vot', 'vun', 'wa', 'wae', 'wal', 'wen', 'wo', 'wuu', 'xal', 'xh', 'xog', 'xzh', 'yap', 'yav', 'yi', 'yo', 'yue', 'yuw', 'za', 'zgh', 'zh', 'zh_Hans', 'zh_Hans_CN', 'zh_Hans_SG', 'zh_Hant', 'zh_Hant_HK', 'zh_Hant_MO', 'zh_Hant_TW', 'zu']
|
|
2159
2159
|
>>> print(list_all_locales()) # doctest: +NORMALIZE_WHITESPACE
|
|
2160
|
-
['aa_DJ.UTF-8', 'aa_ER.UTF-8', 'aa_ET.UTF-8', 'ab_GE.UTF-8', 'af_ZA.UTF-8', 'agr_PE.UTF-8', 'ak_GH.UTF-8', 'am_ET.UTF-8', 'an_ES.UTF-8', 'anp_IN.UTF-8', 'ar_AE.UTF-8', 'ar_BH.UTF-8', 'ar_DZ.UTF-8', 'ar_EG.UTF-8', 'ar_IN.UTF-8', 'ar_IQ.UTF-8', 'ar_JO.UTF-8', 'ar_KW.UTF-8', 'ar_LB.UTF-8', 'ar_LY.UTF-8', 'ar_MA.UTF-8', 'ar_OM.UTF-8', 'ar_QA.UTF-8', 'ar_SA.UTF-8', 'ar_SD.UTF-8', 'ar_SS.UTF-8', 'ar_SY.UTF-8', 'ar_TN.UTF-8', 'ar_YE.UTF-8', 'as_IN.UTF-8', 'ast_ES.UTF-8', 'ayc_PE.UTF-8', 'az_AZ.UTF-8', 'az_IR.UTF-8', 'be_BY.UTF-8', 'be_BY.UTF-8@latin', 'bem_ZM.UTF-8', 'ber_DZ.UTF-8', 'ber_MA.UTF-8', 'bg_BG.UTF-8', 'bhb_IN.UTF-8', 'bho_IN.UTF-8', 'bho_NP.UTF-8', 'bi_VU.UTF-8', 'bn_BD.UTF-8', 'bn_IN.UTF-8', 'bo_CN.UTF-8', 'bo_IN.UTF-8', 'br_FR.UTF-8', 'brx_IN.UTF-8', 'bs_BA.UTF-8', 'byn_ER.UTF-8', 'ca_AD.UTF-8', 'ca_ES.UTF-8', 'ca_ES.UTF-8@valencia', 'ca_FR.UTF-8', 'ca_IT.UTF-8', 'ce_RU.UTF-8', 'chr_US.UTF-8', 'ckb_IQ.UTF-8', 'cmn_TW.UTF-8', 'crh_RU.UTF-8', 'crh_UA.UTF-8', 'cs_CZ.UTF-8', 'csb_PL.UTF-8', 'cv_RU.UTF-8', 'cy_GB.UTF-8', 'da_DK.UTF-8', 'de_AT.UTF-8', 'de_BE.UTF-8', 'de_CH.UTF-8', 'de_DE.UTF-8', 'de_IT.UTF-8', 'de_LI.UTF-8', 'de_LU.UTF-8', 'doi_IN.UTF-8', 'dsb_DE.UTF-8', 'dv_MV.UTF-8', 'dz_BT.UTF-8', 'el_CY.UTF-8', 'el_GR.UTF-8', 'en_AG.UTF-8', 'en_AU.UTF-8', 'en_BW.UTF-8', 'en_CA.UTF-8', 'en_DK.UTF-8', 'en_GB.UTF-8', 'en_HK.UTF-8', 'en_IE.UTF-8', 'en_IL.UTF-8', 'en_IN.UTF-8', 'en_NG.UTF-8', 'en_NZ.UTF-8', 'en_PH.UTF-8', 'en_SC.UTF-8', 'en_SG.UTF-8', 'en_US.UTF-8', 'en_ZA.UTF-8', 'en_ZM.UTF-8', 'en_ZW.UTF-8', 'eo.UTF-8', 'es_AR.UTF-8', 'es_BO.UTF-8', 'es_CL.UTF-8', 'es_CO.UTF-8', 'es_CR.UTF-8', 'es_CU.UTF-8', 'es_DO.UTF-8', 'es_EC.UTF-8', 'es_ES.UTF-8', 'es_GT.UTF-8', 'es_HN.UTF-8', 'es_MX.UTF-8', 'es_NI.UTF-8', 'es_PA.UTF-8', 'es_PE.UTF-8', 'es_PR.UTF-8', 'es_PY.UTF-8', 'es_SV.UTF-8', 'es_US.UTF-8', 'es_UY.UTF-8', 'es_VE.UTF-8', 'et_EE.UTF-8', 'eu_ES.UTF-8', 'fa_IR.UTF-8', 'ff_SN.UTF-8', 'fi_FI.UTF-8', 'fil_PH.UTF-8', 'fo_FO.UTF-8', 'fr_BE.UTF-8', 'fr_CA.UTF-8', 'fr_CH.UTF-8', 'fr_FR.UTF-8', 'fr_HT.UTF-8', 'fr_LU.UTF-8', 'fur_IT.UTF-8', 'fy_DE.UTF-8', 'fy_NL.UTF-8', 'ga_IE.UTF-8', 'gbm_IN.UTF-8', 'gd_GB.UTF-8', 'gez_ER.UTF-8', 'gez_ER.UTF-8@abegede', 'gez_ET.UTF-8', 'gez_ET.UTF-8@abegede', 'gl_ES.UTF-8', 'glk_IR.UTF-8', 'gu_IN.UTF-8', 'gv_GB.UTF-8', 'ha_NG.UTF-8', 'hak_TW.UTF-8', 'he_IL.UTF-8', 'hi_IN.UTF-8', 'hif_FJ.UTF-8', 'hne_IN.UTF-8', 'hr_HR.UTF-8', 'hsb_DE.UTF-8', 'ht_HT.UTF-8', 'hu_HU.UTF-8', 'hy_AM.UTF-8', 'ia_FR.UTF-8', 'id_ID.UTF-8', 'ig_NG.UTF-8', 'ik_CA.UTF-8', 'ilo_PH.UTF-8', 'is_IS.UTF-8', 'it_CH.UTF-8', 'it_IT.UTF-8', 'iu_CA.UTF-8', 'iw_IL.UTF-8', 'ja_JP.UTF-8', 'ka_GE.UTF-8', 'kab_DZ.UTF-8', 'kk_KZ.UTF-8', 'kl_GL.UTF-8', 'km_KH.UTF-8', 'kn_IN.UTF-8', 'ko_KR.UTF-8', 'kok_IN.UTF-8', 'ks_IN.UTF-8', 'ks_IN.UTF-8@devanagari', 'ku_TR.UTF-8', 'kv_RU.UTF-8', 'kw_GB.UTF-8', 'ky_KG.UTF-8', 'lb_LU.UTF-8', 'lg_UG.UTF-8', 'li_BE.UTF-8', 'li_NL.UTF-8', 'lij_IT.UTF-8', 'ln_CD.UTF-8', 'lo_LA.UTF-8', 'lt_LT.UTF-8', 'lv_LV.UTF-8', 'lzh_TW.UTF-8', 'mag_IN.UTF-8', 'mai_IN.UTF-8', 'mai_NP.UTF-8', 'mfe_MU.UTF-8', 'mg_MG.UTF-8', 'mhr_RU.UTF-8', 'mi_NZ.UTF-8', 'miq_NI.UTF-8', 'mjw_IN.UTF-8', 'mk_MK.UTF-8', 'ml_IN.UTF-8', 'mn_MN.UTF-8', 'mni_IN.UTF-8', 'mnw_MM.UTF-8', 'mr_IN.UTF-8', 'ms_MY.UTF-8', 'mt_MT.UTF-8', 'my_MM.UTF-8', 'nan_TW.UTF-8', 'nan_TW.UTF-8@latin', 'nb_NO.UTF-8', 'nds_DE.UTF-8', 'nds_NL.UTF-8', 'ne_NP.UTF-8', 'nhn_MX.UTF-8', 'niu_NU.UTF-8', 'niu_NZ.UTF-8', 'nl_AW.UTF-8', 'nl_BE.UTF-8', 'nl_NL.UTF-8', 'nn_NO.UTF-8', 'no_NO.UTF-8', 'nr_ZA.UTF-8', 'nso_ZA.UTF-8', 'oc_FR.UTF-8', 'om_ET.UTF-8', 'om_KE.UTF-8', 'or_IN.UTF-8', 'os_RU.UTF-8', 'pa_IN.UTF-8', 'pa_PK.UTF-8', 'pap_AN.UTF-8', 'pap_AW.UTF-8', 'pap_CW.UTF-8', 'pl_PL.UTF-8', 'ps_AF.UTF-8', 'pt_BR.UTF-8', 'pt_PT.UTF-8', 'quz_PE.UTF-8', 'raj_IN.UTF-8', 'rif_MA.UTF-8', 'ro_RO.UTF-8', 'ru_RU.UTF-8', 'ru_UA.UTF-8', 'rw_RW.UTF-8', 'sa_IN.UTF-8', 'sah_RU.UTF-8', 'sat_IN.UTF-8', 'sc_IT.UTF-8', 'sd_IN.UTF-8', 'sd_IN.UTF-8@devanagari', 'se_NO.UTF-8', 'sgs_LT.UTF-8', 'shn_MM.UTF-8', 'shs_CA.UTF-8', 'si_LK.UTF-8', 'sid_ET.UTF-8', 'sk_SK.UTF-8', 'sl_SI.UTF-8', 'sm_WS.UTF-8', 'so_DJ.UTF-8', 'so_ET.UTF-8', 'so_KE.UTF-8', 'so_SO.UTF-8', 'sq_AL.UTF-8', 'sq_MK.UTF-8', 'sr_ME.UTF-8', 'sr_ME.UTF-8@latin', 'sr_RS.UTF-8', 'sr_RS.UTF-8@latin', 'ss_ZA.UTF-8', 'ssy_ER.UTF-8', 'st_ZA.UTF-8', 'sv_FI.UTF-8', 'sv_SE.UTF-8', 'sw_KE.UTF-8', 'sw_TZ.UTF-8', 'syr.UTF-8', 'szl_PL.UTF-8', 'ta_IN.UTF-8', 'ta_LK.UTF-8', 'ta_SG.UTF-8', 'tcy_IN.UTF-8', 'te_IN.UTF-8', 'tg_TJ.UTF-8', 'th_TH.UTF-8', 'the_NP.UTF-8', 'ti_ER.UTF-8', 'ti_ET.UTF-8', 'tig_ER.UTF-8', 'tk_TM.UTF-8', 'tl_PH.UTF-8', 'tn_BW.UTF-8', 'tn_ZA.UTF-8', 'to_TO.UTF-8', 'tok.UTF-8', 'tpi_PG.UTF-8', 'tr_CY.UTF-8', 'tr_TR.UTF-8', 'ts_ZA.UTF-8', 'tt_RU.UTF-8', 'tt_RU.UTF-8@iqtelif', 'ug_CN.UTF-8', 'uk_UA.UTF-8', 'unm_US.UTF-8', 'ur_IN.UTF-8', 'ur_PK.UTF-8', 'uz_UZ.UTF-8', 'uz_UZ.UTF-8@cyrillic', 've_ZA.UTF-8', 'vi_VN.UTF-8', 'wa_BE.UTF-8', 'wae_CH.UTF-8', 'wal_ET.UTF-8', 'wo_SN.UTF-8', 'xh_ZA.UTF-8', 'yi_US.UTF-8', 'yo_NG.UTF-8', 'yue_HK.UTF-8', 'yuw_PG.UTF-8', 'zh_CN.UTF-8', 'zh_HK.UTF-8', 'zh_MO.UTF-8', 'zh_SG.UTF-8', 'zh_TW.UTF-8', 'zu_ZA.UTF-8']
|
|
2160
|
+
['aa_DJ.UTF-8', 'aa_ER.UTF-8', 'aa_ET.UTF-8', 'ab_GE.UTF-8', 'af_ZA.UTF-8', 'agr_PE.UTF-8', 'ak_GH.UTF-8', 'am_ET.UTF-8', 'an_ES.UTF-8', 'anp_IN.UTF-8', 'ar_AE.UTF-8', 'ar_BH.UTF-8', 'ar_DZ.UTF-8', 'ar_EG.UTF-8', 'ar_IN.UTF-8', 'ar_IQ.UTF-8', 'ar_JO.UTF-8', 'ar_KW.UTF-8', 'ar_LB.UTF-8', 'ar_LY.UTF-8', 'ar_MA.UTF-8', 'ar_OM.UTF-8', 'ar_QA.UTF-8', 'ar_SA.UTF-8', 'ar_SD.UTF-8', 'ar_SS.UTF-8', 'ar_SY.UTF-8', 'ar_TN.UTF-8', 'ar_YE.UTF-8', 'as_IN.UTF-8', 'ast_ES.UTF-8', 'ayc_PE.UTF-8', 'az_AZ.UTF-8', 'az_IR.UTF-8', 'be_BY.UTF-8', 'be_BY.UTF-8@latin', 'bem_ZM.UTF-8', 'ber_DZ.UTF-8', 'ber_MA.UTF-8', 'bg_BG.UTF-8', 'bhb_IN.UTF-8', 'bho_IN.UTF-8', 'bho_NP.UTF-8', 'bi_VU.UTF-8', 'bn_BD.UTF-8', 'bn_IN.UTF-8', 'bo_CN.UTF-8', 'bo_IN.UTF-8', 'br_FR.UTF-8', 'brx_IN.UTF-8', 'bs_BA.UTF-8', 'byn_ER.UTF-8', 'ca_AD.UTF-8', 'ca_ES.UTF-8', 'ca_ES.UTF-8@valencia', 'ca_FR.UTF-8', 'ca_IT.UTF-8', 'ce_RU.UTF-8', 'chr_US.UTF-8', 'ckb_IQ.UTF-8', 'cmn_TW.UTF-8', 'crh_RU.UTF-8', 'crh_UA.UTF-8', 'cs_CZ.UTF-8', 'csb_PL.UTF-8', 'cv_RU.UTF-8', 'cy_GB.UTF-8', 'da_DK.UTF-8', 'de_AT.UTF-8', 'de_BE.UTF-8', 'de_CH.UTF-8', 'de_DE.UTF-8', 'de_IT.UTF-8', 'de_LI.UTF-8', 'de_LU.UTF-8', 'doi_IN.UTF-8', 'dsb_DE.UTF-8', 'dv_MV.UTF-8', 'dz_BT.UTF-8', 'el_CY.UTF-8', 'el_GR.UTF-8', 'en_AG.UTF-8', 'en_AU.UTF-8', 'en_BW.UTF-8', 'en_CA.UTF-8', 'en_DK.UTF-8', 'en_GB.UTF-8', 'en_HK.UTF-8', 'en_IE.UTF-8', 'en_IL.UTF-8', 'en_IN.UTF-8', 'en_NG.UTF-8', 'en_NZ.UTF-8', 'en_PH.UTF-8', 'en_SC.UTF-8', 'en_SG.UTF-8', 'en_US.UTF-8', 'en_ZA.UTF-8', 'en_ZM.UTF-8', 'en_ZW.UTF-8', 'eo.UTF-8', 'es_AR.UTF-8', 'es_BO.UTF-8', 'es_CL.UTF-8', 'es_CO.UTF-8', 'es_CR.UTF-8', 'es_CU.UTF-8', 'es_DO.UTF-8', 'es_EC.UTF-8', 'es_ES.UTF-8', 'es_GT.UTF-8', 'es_HN.UTF-8', 'es_MX.UTF-8', 'es_NI.UTF-8', 'es_PA.UTF-8', 'es_PE.UTF-8', 'es_PR.UTF-8', 'es_PY.UTF-8', 'es_SV.UTF-8', 'es_US.UTF-8', 'es_UY.UTF-8', 'es_VE.UTF-8', 'et_EE.UTF-8', 'eu_ES.UTF-8', 'fa_IR.UTF-8', 'ff_SN.UTF-8', 'fi_FI.UTF-8', 'fil_PH.UTF-8', 'fo_FO.UTF-8', 'fr_BE.UTF-8', 'fr_CA.UTF-8', 'fr_CH.UTF-8', 'fr_FR.UTF-8', 'fr_HT.UTF-8', 'fr_LU.UTF-8', 'fur_IT.UTF-8', 'fy_DE.UTF-8', 'fy_NL.UTF-8', 'ga_IE.UTF-8', 'gbm_IN.UTF-8', 'gd_GB.UTF-8', 'gez_ER.UTF-8', 'gez_ER.UTF-8@abegede', 'gez_ET.UTF-8', 'gez_ET.UTF-8@abegede', 'gl_ES.UTF-8', 'glk_IR.UTF-8', 'gu_IN.UTF-8', 'gv_GB.UTF-8', 'ha_NG.UTF-8', 'hak_TW.UTF-8', 'he_IL.UTF-8', 'hi_IN.UTF-8', 'hif_FJ.UTF-8', 'hne_IN.UTF-8', 'hr_HR.UTF-8', 'hsb_DE.UTF-8', 'ht_HT.UTF-8', 'hu_HU.UTF-8', 'hy_AM.UTF-8', 'ia_FR.UTF-8', 'id_ID.UTF-8', 'ig_NG.UTF-8', 'ik_CA.UTF-8', 'ilo_PH.UTF-8', 'is_IS.UTF-8', 'it_CH.UTF-8', 'it_IT.UTF-8', 'iu_CA.UTF-8', 'iw_IL.UTF-8', 'ja_JP.UTF-8', 'ka_GE.UTF-8', 'kab_DZ.UTF-8', 'kk_KZ.UTF-8', 'kl_GL.UTF-8', 'km_KH.UTF-8', 'kn_IN.UTF-8', 'ko_KR.UTF-8', 'kok_IN.UTF-8', 'ks_IN.UTF-8', 'ks_IN.UTF-8@devanagari', 'ku_TR.UTF-8', 'kv_RU.UTF-8', 'kw_GB.UTF-8', 'ky_KG.UTF-8', 'lb_LU.UTF-8', 'lg_UG.UTF-8', 'li_BE.UTF-8', 'li_NL.UTF-8', 'lij_IT.UTF-8', 'ln_CD.UTF-8', 'lo_LA.UTF-8', 'lt_LT.UTF-8', 'lv_LV.UTF-8', 'lzh_TW.UTF-8', 'mag_IN.UTF-8', 'mai_IN.UTF-8', 'mai_NP.UTF-8', 'mdf_RU.UTF-8', 'mfe_MU.UTF-8', 'mg_MG.UTF-8', 'mhr_RU.UTF-8', 'mi_NZ.UTF-8', 'miq_NI.UTF-8', 'mjw_IN.UTF-8', 'mk_MK.UTF-8', 'ml_IN.UTF-8', 'mn_MN.UTF-8', 'mni_IN.UTF-8', 'mnw_MM.UTF-8', 'mr_IN.UTF-8', 'ms_MY.UTF-8', 'mt_MT.UTF-8', 'my_MM.UTF-8', 'nan_TW.UTF-8', 'nan_TW.UTF-8@latin', 'nb_NO.UTF-8', 'nds_DE.UTF-8', 'nds_NL.UTF-8', 'ne_NP.UTF-8', 'nhn_MX.UTF-8', 'niu_NU.UTF-8', 'niu_NZ.UTF-8', 'nl_AW.UTF-8', 'nl_BE.UTF-8', 'nl_NL.UTF-8', 'nn_NO.UTF-8', 'no_NO.UTF-8', 'nr_ZA.UTF-8', 'nso_ZA.UTF-8', 'oc_FR.UTF-8', 'om_ET.UTF-8', 'om_KE.UTF-8', 'or_IN.UTF-8', 'os_RU.UTF-8', 'pa_IN.UTF-8', 'pa_PK.UTF-8', 'pap_AN.UTF-8', 'pap_AW.UTF-8', 'pap_CW.UTF-8', 'pl_PL.UTF-8', 'ps_AF.UTF-8', 'pt_BR.UTF-8', 'pt_PT.UTF-8', 'quz_PE.UTF-8', 'raj_IN.UTF-8', 'rif_MA.UTF-8', 'ro_RO.UTF-8', 'ru_RU.UTF-8', 'ru_UA.UTF-8', 'rw_RW.UTF-8', 'sa_IN.UTF-8', 'sah_RU.UTF-8', 'sat_IN.UTF-8', 'sc_IT.UTF-8', 'sd_IN.UTF-8', 'sd_IN.UTF-8@devanagari', 'se_NO.UTF-8', 'sgs_LT.UTF-8', 'shn_MM.UTF-8', 'shs_CA.UTF-8', 'si_LK.UTF-8', 'sid_ET.UTF-8', 'sk_SK.UTF-8', 'sl_SI.UTF-8', 'sm_WS.UTF-8', 'so_DJ.UTF-8', 'so_ET.UTF-8', 'so_KE.UTF-8', 'so_SO.UTF-8', 'sq_AL.UTF-8', 'sq_MK.UTF-8', 'sr_ME.UTF-8', 'sr_ME.UTF-8@latin', 'sr_RS.UTF-8', 'sr_RS.UTF-8@latin', 'ss_ZA.UTF-8', 'ssy_ER.UTF-8', 'st_ZA.UTF-8', 'sv_FI.UTF-8', 'sv_SE.UTF-8', 'sw_KE.UTF-8', 'sw_TZ.UTF-8', 'syr.UTF-8', 'szl_PL.UTF-8', 'ta_IN.UTF-8', 'ta_LK.UTF-8', 'ta_SG.UTF-8', 'tcy_IN.UTF-8', 'te_IN.UTF-8', 'tg_TJ.UTF-8', 'th_TH.UTF-8', 'the_NP.UTF-8', 'ti_ER.UTF-8', 'ti_ET.UTF-8', 'tig_ER.UTF-8', 'tk_TM.UTF-8', 'tl_PH.UTF-8', 'tn_BW.UTF-8', 'tn_ZA.UTF-8', 'to_TO.UTF-8', 'tok.UTF-8', 'tpi_PG.UTF-8', 'tr_CY.UTF-8', 'tr_TR.UTF-8', 'ts_ZA.UTF-8', 'tt_RU.UTF-8', 'tt_RU.UTF-8@iqtelif', 'ug_CN.UTF-8', 'uk_UA.UTF-8', 'unm_US.UTF-8', 'ur_IN.UTF-8', 'ur_PK.UTF-8', 'uz_UZ.UTF-8', 'uz_UZ.UTF-8@cyrillic', 've_ZA.UTF-8', 'vi_VN.UTF-8', 'wa_BE.UTF-8', 'wae_CH.UTF-8', 'wal_ET.UTF-8', 'wo_SN.UTF-8', 'xh_ZA.UTF-8', 'yi_US.UTF-8', 'yo_NG.UTF-8', 'yue_HK.UTF-8', 'yuw_PG.UTF-8', 'zh_CN.UTF-8', 'zh_HK.UTF-8', 'zh_MO.UTF-8', 'zh_SG.UTF-8', 'zh_TW.UTF-8', 'zu_ZA.UTF-8']
|
|
2161
2161
|
>>> print(list_all_keyboards()) # doctest: +NORMALIZE_WHITESPACE
|
|
2162
2162
|
['ad', 'af', 'af(fa-olpc)', 'af(ps)', 'af(ps-olpc)', 'af(uz)', 'af(uz-olpc)', 'al', 'am', 'am(eastern)', 'am(eastern-alt)', 'am(phonetic)', 'am(phonetic-alt)', 'am(western)', 'ara', 'ara(azerty)', 'ara(azerty_digits)', 'ara(buckwalter)', 'ara(digits)', 'ara(qwerty)', 'ara(qwerty_digits)', 'at(nodeadkeys)', 'az', 'az(cyrillic)', 'ba', 'bd', 'bd(probhat)', 'be', 'be(oss)', 'bg', 'bg(bas_phonetic)', 'bg(phonetic)', 'br', 'brai', 'brai(left_hand)', 'brai(right_hand)', 'bt', 'by', 'by(legacy)', 'ca', 'ca(eng)', 'ca(ike)', 'ca(multi)', 'ca(multi-2gr)', 'ca(shs)', 'ch', 'ch(fr)', 'cn', 'cn(tib)', 'cn(tib_asciinum)', 'cn(ug)', 'cz', 'cz(ucw)', 'de', 'de(deadacute)', 'de(nodeadkeys)', 'de(ru)', 'dk', 'ee', 'es', 'es(ast)', 'es(cat)', 'et', 'fi', 'fi(classic)', 'fi(nodeadkeys)', 'fo', 'fr', 'fr(geo)', 'fr(latin9)', 'fr(oss)', 'gb', 'ge', 'ge(os)', 'gr', 'gr(extended)', 'gr(nodeadkeys)', 'gr(polytonic)', 'gr(simple)', 'hr', 'hu', 'ie', 'ie(CloGaelach)', 'ie(ogam)', 'il', 'il(biblical)', 'il(lyx)', 'il(phonetic)', 'in', 'in(ben)', 'in(ben_baishakhi)', 'in(ben_bornona)', 'in(ben_gitanjali)', 'in(ben_inscript)', 'in(ben_probhat)', 'in(bolnagri)', 'in(deva)', 'in(eng)', 'in(guj)', 'in(guru)', 'in(hin-kagapa)', 'in(hin-wx)', 'in(jhelum)', 'in(kan)', 'in(kan-kagapa)', 'in(mal)', 'in(mal_enhanced)', 'in(mal_lalitha)', 'in(mar-kagapa)', 'in(ori)', 'in(san-kagapa)', 'in(tam)', 'in(tam_tamilnet)', 'in(tam_tamilnet_TAB)', 'in(tam_tamilnet_TSCII)', 'in(tam_tamilnet_with_tam_nums)', 'in(tel)', 'in(tel-kagapa)', 'in(urd-phonetic)', 'in(urd-phonetic3)', 'in(urd-winkeys)', 'iq', 'ir', 'ir(pes_keypad)', 'it', 'jp', 'jp(kana)', 'jp(mac)', 'ke', 'kg', 'kg(phonetic)', 'kh', 'kr', 'kz', 'kz(kazrus)', 'kz(ruskaz)', 'la', 'la(stea)', 'latam', 'lk', 'lk(tam_TAB)', 'lk(tam_unicode)', 'lt', 'lv', 'ma', 'ma(french)', 'ma(tifinagh)', 'ma(tifinagh-alt)', 'ma(tifinagh-alt-phonetic)', 'ma(tifinagh-extended)', 'ma(tifinagh-extended-phonetic)', 'ma(tifinagh-phonetic)', 'me', 'me(cyrillic)', 'me(cyrillicalternatequotes)', 'me(cyrillicyz)', 'mk', 'mk(nodeadkeys)', 'mm', 'mn', 'mt', 'mt(us)', 'mv', 'ng', 'ng(hausa)', 'ng(igbo)', 'ng(yoruba)', 'nl', 'no', 'np', 'ph', 'ph(capewell-dvorak-bay)', 'ph(capewell-qwerf2k6-bay)', 'ph(colemak-bay)', 'ph(dvorak-bay)', 'ph(qwerty-bay)', 'pk', 'pk(ara)', 'pk(snd)', 'pk(urd-crulp)', 'pk(urd-nla)', 'pl', 'pl(ru_phonetic_dvorak)', 'pt', 'ro', 'rs', 'rs(alternatequotes)', 'rs(latin)', 'rs(rue)', 'rs(yz)', 'ru', 'ru(bak)', 'ru(chm)', 'ru(cv)', 'ru(dos)', 'ru(kom)', 'ru(legacy)', 'ru(mac)', 'ru(os_legacy)', 'ru(os_winkeys)', 'ru(phonetic)', 'ru(phonetic_winkeys)', 'ru(sah)', 'ru(srp)', 'ru(tt)', 'ru(typewriter)', 'ru(typewriter-legacy)', 'ru(udm)', 'ru(xal)', 'se', 'se(nodeadkeys)', 'se(rus)', 'se(rus_nodeadkeys)', 'se(swl)', 'si', 'sk', 'sn', 'sy', 'sy(syc)', 'sy(syc_phonetic)', 'th', 'th(pat)', 'th(tis)', 'tj', 'tj(legacy)', 'tm', 'tr', 'tr(crh)', 'tr(ku)', 'tz', 'ua', 'ua(homophonic)', 'ua(legacy)', 'ua(phonetic)', 'ua(rstu)', 'ua(rstu_ru)', 'ua(typewriter)', 'ua(winkeys)', 'us', 'us(altgr-intl)', 'us(chr)', 'us(euro)', 'us(intl)', 'us(rus)', 'uz', 'uz(latin)', 'vn', 'za']
|
|
2163
2163
|
>>> print(list_all_territories()) # doctest: +NORMALIZE_WHITESPACE
|
|
@@ -2176,7 +2176,8 @@ def dummy():
|
|
|
2176
2176
|
if __name__ == "__main__":
|
|
2177
2177
|
import doctest
|
|
2178
2178
|
(FAILED, ATTEMPTED) = doctest.testmod()
|
|
2179
|
+
print(f'{ATTEMPTED} tests run. {ATTEMPTED - FAILED} passed and {FAILED} failed.')
|
|
2179
2180
|
if FAILED:
|
|
2180
|
-
# Return number of failed tests:
|
|
2181
2181
|
sys.exit(FAILED)
|
|
2182
|
+
print(f'All tests passed.')
|
|
2182
2183
|
sys.exit(0)
|
|
Binary file
|
|
Binary file
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|