Script 'mail_helper' called by obssrc
Hello community,

here is the log from the commit of package python-langtable for 
openSUSE:Factory checked in at 2023-12-08 22:32:06
++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
Comparing /work/SRC/openSUSE:Factory/python-langtable (Old)
 and      /work/SRC/openSUSE:Factory/.python-langtable.new.25432 (New)
++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++

Package is "python-langtable"

Fri Dec  8 22:32:06 2023 rev:9 rq:1131729 version:0.0.64

Changes:
--------
--- /work/SRC/openSUSE:Factory/python-langtable/python-langtable.changes        
2023-05-26 20:15:51.912402757 +0200
+++ 
/work/SRC/openSUSE:Factory/.python-langtable.new.25432/python-langtable.changes 
    2023-12-08 22:32:37.281253671 +0100
@@ -1,0 +2,19 @@
+Thu Dec  7 22:30:56 UTC 2023 - Dirk Müller <dmuel...@suse.com>
+
+- update to 0.0.64:
+  * Add new public functions list_all_{languages,locales,keyboard
+    s,territories,timezones,scripts,input_methods,console_fonts}
+- update to 0.0.63:
+  * Japanese: prefer anthy over kkc
+  * Use skipTerritory also in list_keyboards(),
+    list_consolefonts(), and list_timezones()
+  * Add more translations from CLDR
+  * Get translation changes from CLDR
+- update to 0.0.62:
+  * Get translation changes from CLDR
+  * Add more translations from CLDR
+  * Add Norwegian keyboard layout to keyboards.xml (Resolves:
+    https://github.com/mike-fabian/langtable/issues/16)
+  * Add Hang script to Southern Aymara
+
+-------------------------------------------------------------------

Old:
----
  langtable-0.0.61.tar.gz

New:
----
  langtable-0.0.64.tar.gz

++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++

Other differences:
------------------
++++++ python-langtable.spec ++++++
--- /var/tmp/diff_new_pack.VXIlKN/_old  2023-12-08 22:32:37.729270155 +0100
+++ /var/tmp/diff_new_pack.VXIlKN/_new  2023-12-08 22:32:37.729270155 +0100
@@ -27,7 +27,7 @@
 %define skip_python2 1
 %global literalpython python
 Name:           python-langtable%{psuffix}
-Version:        0.0.61
+Version:        0.0.64
 Release:        0
 Summary:        Database to guess defaults for locale settings
 # the translations in languages.xml and territories.xml are (mostly)

++++++ langtable-0.0.61.tar.gz -> langtable-0.0.64.tar.gz ++++++
diff -urN '--exclude=CVS' '--exclude=.cvsignore' '--exclude=.svn' 
'--exclude=.svnignore' old/langtable-0.0.61/ChangeLog 
new/langtable-0.0.64/ChangeLog
--- old/langtable-0.0.61/ChangeLog      2022-11-24 16:06:26.000000000 +0100
+++ new/langtable-0.0.64/ChangeLog      2023-09-19 21:43:10.000000000 +0200
@@ -1,3 +1,24 @@
+2023-09-19  Mike FABIAN  <mfab...@redhat.com>
+
+       * Add new public functions 
list_all_{languages,locales,keyboards,territories,timezones,scripts,input_methods,console_fonts}
+       (See also the discussion at: 
https://gitlab.gnome.org/GNOME/gnome-desktop/-/merge_requests/159)
+
+2023-08-28  Mike FABIAN  <mfab...@redhat.com>
+
+       * Add more translations from CLDR
+       * Get translation changes from CLDR
+       * Japanese: prefer anthy over kkc
+       (Thanks to adam Williamson: 
https://github.com/mike-fabian/langtable/pull/17)
+       * Use skipTerritory also in list_keyboards(), list_consolefonts(), and 
list_timezones()
+       (Resolves: https://github.com/mike-fabian/langtable/issues/18)
+
+2023-05-02  Mike FABIAN  <mfab...@redhat.com>
+
+       * Add more translations from CLDR
+       * Get translation changes from CLDR
+       * Add Norwegian keyboard layout to keyboards.xml
+       * Add Hang script to Southern Aymara
+
 2022-11-24  Mike FABIAN  <mfab...@redhat.com>
 
        * Add mnw_MM.UTF-8 and ckb_IQ.UTF-8
diff -urN '--exclude=CVS' '--exclude=.cvsignore' '--exclude=.svn' 
'--exclude=.svnignore' old/langtable-0.0.61/Makefile 
new/langtable-0.0.64/Makefile
--- old/langtable-0.0.61/Makefile       2022-11-23 11:25:25.000000000 +0100
+++ new/langtable-0.0.64/Makefile       2023-08-28 13:48:53.000000000 +0200
@@ -25,7 +25,7 @@
 
 .PHONY: dist
 dist: gzip
-       DISTUTILS_DEBUG=$(DEBUG) python3 ./setup.py sdist bdist_egg bdist_wheel
+       DISTUTILS_DEBUG=$(DEBUG) python3 ./setup.py sdist bdist_wheel
 
 .PHONY: install
 install: dist
@@ -36,12 +36,12 @@
 # check it here: https://test.pypi.org/manage/project/langtable/releases/
 .PHONY: twine-upload-test
 twine-upload-test: dist
-       python3 -m twine upload --repository-url https://test.pypi.org/legacy/ 
dist/*
+       python3 -m twine upload --verbose --repository testpypi dist/*
 
 # check it here: https://pypi.org/manage/project/langtable/releases/
 .PHONY: twine-upload
 twine-upload: dist
-       python3 -m twine upload dist/*
+       python3 -m twine upload --verbose dist/*
 
 .PHONY: pip-install-test
 pip-install-test:
diff -urN '--exclude=CVS' '--exclude=.cvsignore' '--exclude=.svn' 
'--exclude=.svnignore' old/langtable-0.0.61/PKG-INFO 
new/langtable-0.0.64/PKG-INFO
--- old/langtable-0.0.61/PKG-INFO       2022-11-24 23:33:27.017652500 +0100
+++ new/langtable-0.0.64/PKG-INFO       2023-09-19 22:24:09.826879500 +0200
@@ -1,6 +1,6 @@
 Metadata-Version: 2.1
 Name: langtable
-Version: 0.0.61
+Version: 0.0.64
 Summary: guess reasonable defaults for locale, keyboard, territory, ...
 Home-page: https://github.com/mike-fabian/langtable
 Author: Mike FABIAN
diff -urN '--exclude=CVS' '--exclude=.cvsignore' '--exclude=.svn' 
'--exclude=.svnignore' old/langtable-0.0.61/langtable/__init__.py 
new/langtable-0.0.64/langtable/__init__.py
--- old/langtable-0.0.61/langtable/__init__.py  2019-09-04 16:23:21.000000000 
+0200
+++ new/langtable-0.0.64/langtable/__init__.py  2023-09-19 21:05:43.000000000 
+0200
@@ -10,5 +10,5 @@
 #  Deleting a module prevents one from import <pack>.somemodule1
 #  directly. You can only import from <pack> objects defined or
 #  imported in its __init__.py, and non-deleted submodules.
-del langtable
+del langtable # type: ignore
 
Binary files old/langtable-0.0.61/langtable/data/keyboards.xml.gz and 
new/langtable-0.0.64/langtable/data/keyboards.xml.gz differ
Binary files old/langtable-0.0.61/langtable/data/languages.xml.gz and 
new/langtable-0.0.64/langtable/data/languages.xml.gz differ
Binary files old/langtable-0.0.61/langtable/data/territories.xml.gz and 
new/langtable-0.0.64/langtable/data/territories.xml.gz differ
Binary files old/langtable-0.0.61/langtable/data/timezoneidparts.xml.gz and 
new/langtable-0.0.64/langtable/data/timezoneidparts.xml.gz differ
diff -urN '--exclude=CVS' '--exclude=.cvsignore' '--exclude=.svn' 
'--exclude=.svnignore' old/langtable-0.0.61/langtable/langtable.py 
new/langtable-0.0.64/langtable/langtable.py
--- old/langtable-0.0.61/langtable/langtable.py 2022-09-21 16:51:19.000000000 
+0200
+++ new/langtable-0.0.64/langtable/langtable.py 2023-09-19 21:07:27.000000000 
+0200
@@ -34,6 +34,14 @@
 #     languageId()
 #     territoryId()
 #     supports_ascii()
+#     list_all_languages()
+#     list_all_locales()
+#     list_all_keyboards()
+#     list_all_territories()
+#     list_all_timezones()
+#     list_all_scripts()
+#     list_all_input_methods()
+#     list_all_console_fonts()
 #
 # These are the functions which do not start with an “_” in their name.
 # All global functions and global variables whose name starts with an
@@ -97,6 +105,8 @@
 #
 ######################################################################
 
+from typing import List
+from typing import Dict
 import os
 import re
 import logging
@@ -110,7 +120,7 @@
     'Locale',
     ['language', 'script', 'territory', 'variant', 'encoding'])
 
-_INFO = {'data_files_read': []}
+_INFO: Dict[str, List[str]] = {'data_files_read': []}
 
 # will be replaced by “make install”:
 _DATADIR = '/usr/share/langtable'
@@ -2080,7 +2090,7 @@
     List the suitable input methods for the language “Japanese”:
 
     >>> list_inputmethods(languageId="ja")
-    ['ibus/kkc', 'ibus/anthy']
+    ['ibus/anthy', 'ibus/kkc']
 
     So this returns a list of input methods for Japanese. These lists are
     sorted in order of decreasing likelyhood, i.e. the most common
@@ -2089,7 +2099,7 @@
     One can also list the possible input methods for the territory “Japan”:
 
     >>> list_inputmethods(territoryId="JP")
-    ['ibus/kkc', 'ibus/anthy']
+    ['ibus/anthy', 'ibus/kkc']
     '''
     ranked_inputmethods = {}
     skipTerritory = False
@@ -2196,7 +2206,7 @@
                     ranked_keyboards[keyboard] *= extra_bonus
                 ranked_keyboards[keyboard] *= language_bonus
     territory_bonus = 1
-    if territoryId in _territories_db:
+    if territoryId in _territories_db and not skipTerritory:
         for keyboard in _territories_db[territoryId].keyboards:
             if _territories_db[territoryId].keyboards[keyboard] != 0:
                 if keyboard not in ranked_keyboards:
@@ -2430,7 +2440,7 @@
                     ranked_consolefonts[consolefont] *= extra_bonus
                 ranked_consolefonts[consolefont] *= language_bonus
     territory_bonus = 1
-    if territoryId in _territories_db:
+    if territoryId in _territories_db and not skipTerritory:
         for consolefont in _territories_db[territoryId].consolefonts:
             if _territories_db[territoryId].consolefonts[consolefont] != 0:
                 if consolefont not in ranked_consolefonts:
@@ -2511,7 +2521,7 @@
                     ranked_timezones[timezone] *= extra_bonus
                 ranked_timezones[timezone] *= language_bonus
     territory_bonus = 100
-    if territoryId in _territories_db:
+    if territoryId in _territories_db and not skipTerritory:
         for timezone in _territories_db[territoryId].timezones:
             if _territories_db[territoryId].timezones[timezone] != 0:
                 if timezone not in ranked_timezones:
@@ -2528,6 +2538,80 @@
     else:
         return _ranked_list_to_list(ranked_list)
 
+def list_all_languages() -> List[str]:
+    '''
+    List all language ids langtable knows something about
+    '''
+    return sorted(_languages_db.keys())
+
+def list_all_locales() -> List[str]:
+    '''
+    List all (glibc style) locales langtable knows something about
+    '''
+    all_locales = set()
+    for (_key, item) in _languages_db.items():
+        all_locales.update(item.locales)
+    for (_key, item) in _territories_db.items():
+        all_locales.update(item.locales)
+    return sorted(all_locales)
+
+def list_all_keyboards() -> List[str]:
+    '''
+    List all keyboards langtable knows something about
+    '''
+    return sorted(_keyboards_db.keys())
+
+def list_all_territories() -> List[str]:
+    '''
+    List all territory ids langtable knows something about
+    '''
+    return list(_territories_db.keys())
+
+def list_all_timezones() -> List[str]:
+    '''
+    List all timezone ids langtable knows something about
+    '''
+    all_timezones = set()
+    all_timezones.update(list(_timezones_db.keys()))
+    for (_key, item) in _languages_db.items():
+        all_timezones.update(item.timezones)
+    for (_key, item) in _territories_db.items():
+        all_timezones.update(item.timezones)
+    return sorted(all_timezones)
+
+def list_all_scripts() -> List[str]:
+    '''
+    List all script ids langtable knows something about
+    '''
+    all_scripts = set()
+    for (_key, item) in _languages_db.items():
+        all_scripts.update(item.scripts)
+    for (_key, item) in _territories_db.items():
+        all_scripts.update(item.scripts)
+    return sorted(all_scripts)
+
+def list_all_input_methods() -> List[str]:
+    '''
+    List all input methods langtable knows something about
+    '''
+    all_inputmethods = set()
+    for (_key, item) in _languages_db.items():
+        all_inputmethods.update(item.inputmethods)
+    for (_key, item) in _territories_db.items():
+        all_inputmethods.update(item.inputmethods)
+    return sorted(all_inputmethods)
+
+def list_all_console_fonts() -> List[str]:
+    '''
+    List all console fonts langtable knows something about
+    '''
+    all_consolefonts = set()
+    for (_key, item) in _languages_db.items():
+        all_consolefonts.update(item.consolefonts)
+    for (_key, item) in _territories_db.items():
+        all_consolefonts.update(item.consolefonts)
+    return sorted(all_consolefonts)
+
 def supports_ascii(keyboardId=None):
     '''Check whether a keyboard layout supports ASCII
 
@@ -2555,7 +2639,8 @@
     '''
     Return version of langtable
     '''
-    import pkg_resources  # part of setuptools
+    # pkg_resources is part of setuptools
+    import pkg_resources  # type: ignore
     return pkg_resources.require("langtable")[0].version
 
 def info():
diff -urN '--exclude=CVS' '--exclude=.cvsignore' '--exclude=.svn' 
'--exclude=.svnignore' old/langtable-0.0.61/langtable.egg-info/PKG-INFO 
new/langtable-0.0.64/langtable.egg-info/PKG-INFO
--- old/langtable-0.0.61/langtable.egg-info/PKG-INFO    2022-11-24 
23:33:26.000000000 +0100
+++ new/langtable-0.0.64/langtable.egg-info/PKG-INFO    2023-09-19 
22:24:09.000000000 +0200
@@ -1,6 +1,6 @@
 Metadata-Version: 2.1
 Name: langtable
-Version: 0.0.61
+Version: 0.0.64
 Summary: guess reasonable defaults for locale, keyboard, territory, ...
 Home-page: https://github.com/mike-fabian/langtable
 Author: Mike FABIAN
diff -urN '--exclude=CVS' '--exclude=.cvsignore' '--exclude=.svn' 
'--exclude=.svnignore' old/langtable-0.0.61/setup.py 
new/langtable-0.0.64/setup.py
--- old/langtable-0.0.61/setup.py       2022-11-24 16:09:10.000000000 +0100
+++ new/langtable-0.0.64/setup.py       2023-09-19 21:43:34.000000000 +0200
@@ -8,7 +8,7 @@
     # within the egg directory easily:
     zip_safe=False,
     name='langtable',
-    version='0.0.61',
+    version='0.0.64',
     packages=setuptools.find_packages(),
     description='guess reasonable defaults for locale, keyboard, territory, 
...',
     long_description=codecs.open('README', encoding='UTF-8').read(),
diff -urN '--exclude=CVS' '--exclude=.cvsignore' '--exclude=.svn' 
'--exclude=.svnignore' old/langtable-0.0.61/test_cases.py 
new/langtable-0.0.64/test_cases.py
--- old/langtable-0.0.61/test_cases.py  2022-11-23 12:19:54.000000000 +0100
+++ new/langtable-0.0.64/test_cases.py  2023-09-19 21:17:14.000000000 +0200
@@ -18,6 +18,14 @@
     >>> from langtable import languageId
     >>> from langtable import list_common_languages
     >>> from langtable import list_common_keyboards
+    >>> from langtable import list_all_languages
+    >>> from langtable import list_all_locales
+    >>> from langtable import list_all_keyboards
+    >>> from langtable import list_all_territories
+    >>> from langtable import list_all_timezones
+    >>> from langtable import list_all_scripts
+    >>> from langtable import list_all_input_methods
+    >>> from langtable import list_all_console_fonts
 
     ######################################################################
     # Start of tests to reproduce the results from mangleLocale(inLocale) in 
anaconda, see:
@@ -446,16 +454,16 @@
         ['ibus/m17n:ar:kbd']
 
     >>> list_inputmethods(languageId="ja") # doctest: +NORMALIZE_WHITESPACE
-        ['ibus/kkc', 'ibus/anthy']
+        ['ibus/anthy', 'ibus/kkc']
 
     >>> list_inputmethods(languageId="ja", territoryId="JP") # doctest: 
+NORMALIZE_WHITESPACE
-        ['ibus/kkc', 'ibus/anthy']
+        ['ibus/anthy', 'ibus/kkc']
 
     >>> list_inputmethods(languageId="ja", territoryId="DE") # doctest: 
+NORMALIZE_WHITESPACE
-        ['ibus/kkc', 'ibus/anthy']
+        ['ibus/anthy', 'ibus/kkc']
 
     >>> list_inputmethods(languageId="de", territoryId="JP") # doctest: 
+NORMALIZE_WHITESPACE
-        ['ibus/kkc', 'ibus/anthy']
+        ['ibus/anthy', 'ibus/kkc']
 
     >>> list_inputmethods(languageId="ko") # doctest: +NORMALIZE_WHITESPACE
         ['ibus/hangul']
@@ -1341,7 +1349,7 @@
     >>> print(language_name(languageId="ber_MA.utf8")) # doctest: 
+NORMALIZE_WHITESPACE
     ⵜⴰⵎⴰⵣⵉⵖⵜ (ⵜⴰⴳⵍⴷⵉⵜ ⵏ ⵍⵎⵖⵔⵉⴱ)
     >>> print(language_name(languageId="rif_MA.utf8")) # doctest: 
+NORMALIZE_WHITESPACE
-    Tarifit (Lmerruk)
+    Tarifit (Lmuɣrib)
     >>> print(language_name(languageId="bg_BG.utf8")) # doctest: 
+NORMALIZE_WHITESPACE
     Български (България)
     >>> print(language_name(languageId="bhb_IN.utf8")) # doctest: 
+NORMALIZE_WHITESPACE
@@ -1617,7 +1625,7 @@
     >>> print(language_name(languageId="ks_IN.utf8@devanagari")) # doctest: 
+NORMALIZE_WHITESPACE
     कॉशुर (हिंदोस्तान)
     >>> print(language_name(languageId="ku_TR.utf8")) # doctest: 
+NORMALIZE_WHITESPACE
-    Kurdî (Tirkiye)
+    Kurdî (kurmancî) (Tirkiye)
     >>> print(language_name(languageId="kw_GB.utf8")) # doctest: 
+NORMALIZE_WHITESPACE
     Kernewek (Rywvaneth Unys)
     >>> print(language_name(languageId="ky_KG.utf8")) # doctest: 
+NORMALIZE_WHITESPACE
@@ -2145,6 +2153,23 @@
         ['tw']
     >>> print(list_common_languages())   # doctest: +NORMALIZE_WHITESPACE
         ['ar', 'en', 'fr', 'de', 'ja', 'zh', 'ru', 'es']
+
+    >>> print(list_all_languages())    # doctest: +NORMALIZE_WHITESPACE
+    ['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', 'gd', 'gez', 'gl', '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', 'st', 'su', 'sv', 'sw', 'syc', 
'syr', 'szl', 'ta', 'tcy', 'te', 'teo', 'tet', 'tg', 'th', 'the', 'ti', 'tig'
 , 'tk', 'tl', 'tn', 'to', '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', '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']
+    >>> print(list_all_locales())    # doctest: +NORMALIZE_WHITESPACE
+    ['aa_DJ.UTF-8', 'aa_ER.UTF-8', 'aa_ER.UTF-8@saaho', '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_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', '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', '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', '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', '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', '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']
+    >>> print(list_all_keyboards())    # doctest: +NORMALIZE_WHITESPACE
+    ['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)', 'i
 l(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(cyri
 llicalternatequotes)', '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']
+    >>> print(list_all_territories())    # doctest: +NORMALIZE_WHITESPACE
+    ['001', '002', '019', '142', '150', '419', 'AD', 'AE', 'AF', 'AG', 'AI', 
'AL', 'AM', 'AN', 'AO', 'AQ', 'AR', 'AS', 'AT', 'AU', 'AW', 'AX', 'AZ', 'BA', 
'BB', 'BD', 'BE', 'BF', 'BG', 'BH', 'BI', 'BJ', 'BL', 'BM', 'BN', 'BO', 'BQ', 
'BR', 'BS', 'BT', 'BW', 'BY', 'BZ', 'CA', 'CC', 'CD', 'CF', 'CG', 'CH', 'CI', 
'CK', 'CL', 'CM', 'CN', 'CO', 'CR', 'CU', 'CV', 'CW', 'CX', 'CY', 'CZ', 'DE', 
'DG', 'DJ', 'DK', 'DM', 'DO', 'DZ', 'EA', 'EC', 'EE', 'EG', 'EH', 'ER', 'ES', 
'ET', 'FI', 'FJ', 'FK', 'FM', 'FO', 'FR', 'GA', 'GB', 'GD', 'GE', 'GF', 'GG', 
'GH', 'GI', 'GL', 'GM', 'GN', 'GP', 'GQ', 'GR', 'GT', 'GU', 'GW', 'GY', 'HK', 
'HN', 'HR', 'HT', 'HU', 'IC', 'ID', 'IE', 'IL', 'IM', 'IN', 'IO', 'IQ', 'IR', 
'IS', 'IT', 'JE', 'JM', 'JO', 'JP', 'KE', 'KG', 'KH', 'KI', 'KM', 'KN', 'KP', 
'KR', 'KW', 'KY', 'KZ', 'LA', 'LB', 'LC', 'LI', 'LK', 'LR', 'LS', 'LT', 'LU', 
'LV', 'LY', 'MA', 'MC', 'MD', 'ME', 'MF', 'MG', 'MH', 'MK', 'ML', 'MM', 'MN', 
'MO', 'MP', 'MQ', 'MR', 'MS', 'MT', 'MU', 'MV', 'MW', 'MX', 'M
 Y', 'MZ', 'NA', 'NC', 'NE', 'NF', 'NG', 'NI', 'NL', 'NO', 'NP', 'NR', 'NU', 
'NZ', 'OM', 'PA', 'PE', 'PF', 'PG', 'PH', 'PK', 'PL', 'PM', 'PN', 'PR', 'PS', 
'PT', 'PW', 'PY', 'QA', 'RE', 'RO', 'RS', 'RU', 'RW', 'SA', 'SB', 'SC', 'SD', 
'SE', 'SG', 'SH', 'SI', 'SJ', 'SK', 'SL', 'SM', 'SN', 'SO', 'SR', 'SS', 'ST', 
'SV', 'SX', 'SY', 'SZ', 'TC', 'TD', 'TG', 'TH', 'TJ', 'TK', 'TL', 'TM', 'TN', 
'TO', 'TR', 'TT', 'TV', 'TW', 'TZ', 'UA', 'UG', 'UM', 'US', 'UY', 'UZ', 'VA', 
'VC', 'VE', 'VG', 'VI', 'VN', 'VU', 'WF', 'WS', 'XK', 'YE', 'YT', 'YU', 'ZA', 
'ZM', 'ZW']
+    >>> print(list_all_timezones())    # doctest: +NORMALIZE_WHITESPACE
+    ['Africa/Abidjan', 'Africa/Accra', 'Africa/Addis_Ababa', 'Africa/Algiers', 
'Africa/Asmara', 'Africa/Bamako', 'Africa/Bangui', 'Africa/Banjul', 
'Africa/Bissau', 'Africa/Blantyre', 'Africa/Brazzaville', 'Africa/Bujumbura', 
'Africa/Cairo', 'Africa/Casablanca', 'Africa/Ceuta', 'Africa/Conakry', 
'Africa/Dakar', 'Africa/Dar_es_Salaam', 'Africa/Djibouti', 'Africa/Douala', 
'Africa/El_Aaiun', 'Africa/Freetown', 'Africa/Gaborone', 'Africa/Harare', 
'Africa/Johannesburg', 'Africa/Juba', 'Africa/Kampala', 'Africa/Khartoum', 
'Africa/Kigali', 'Africa/Kinshasa', 'Africa/Lagos', 'Africa/Libreville', 
'Africa/Lome', 'Africa/Luanda', 'Africa/Lubumbashi', 'Africa/Lusaka', 
'Africa/Malabo', 'Africa/Maputo', 'Africa/Maseru', 'Africa/Mbabane', 
'Africa/Mogadishu', 'Africa/Monrovia', 'Africa/Nairobi', 'Africa/Ndjamena', 
'Africa/Niamey', 'Africa/Nouakchott', 'Africa/Ouagadougou', 
'Africa/Porto-Novo', 'Africa/Sao_Tome', 'Africa/Tripoli', 'Africa/Tunis', 
'Africa/Windhoek', 'America/Adak', 'America/Anchorage'
 , 'America/Anguilla', 'America/Antigua', 'America/Araguaina', 
'America/Argentina/Buenos_Aires', 'America/Argentina/Catamarca', 
'America/Argentina/Cordoba', 'America/Argentina/Jujuy', 
'America/Argentina/La_Rioja', 'America/Argentina/Mendoza', 
'America/Argentina/Rio_Gallegos', 'America/Argentina/Salta', 
'America/Argentina/San_Juan', 'America/Argentina/San_Luis', 
'America/Argentina/Tucuman', 'America/Argentina/Ushuaia', 'America/Aruba', 
'America/Asuncion', 'America/Atikokan', 'America/Bahia', 
'America/Bahia_Banderas', 'America/Barbados', 'America/Belem', 
'America/Belize', 'America/Blanc-Sablon', 'America/Boa_Vista', 
'America/Bogota', 'America/Boise', 'America/Cambridge_Bay', 
'America/Campo_Grande', 'America/Cancun', 'America/Caracas', 'America/Cayenne', 
'America/Cayman', 'America/Chicago', 'America/Chihuahua', 'America/Costa_Rica', 
'America/Creston', 'America/Cuiaba', 'America/Curacao', 'America/Danmarkshavn', 
'America/Dawson', 'America/Dawson_Creek', 'America/Denver', 'America/Detroit
 ', 'America/Dominica', 'America/Edmonton', 'America/Eirunepe', 
'America/El_Salvador', 'America/Fortaleza', 'America/Galapagos', 
'America/Glace_Bay', 'America/Godthab', 'America/Goose_Bay', 
'America/Grand_Turk', 'America/Grenada', 'America/Guadeloupe', 
'America/Guatemala', 'America/Guayaquil', 'America/Guyana', 'America/Halifax', 
'America/Havana', 'America/Hermosillo', 'America/Indiana/Indianapolis', 
'America/Indiana/Knox', 'America/Indiana/Marengo', 
'America/Indiana/Petersburg', 'America/Indiana/Tell_City', 
'America/Indiana/Vevay', 'America/Indiana/Vincennes', 
'America/Indiana/Winamac', 'America/Inuvik', 'America/Iqaluit', 
'America/Jamaica', 'America/Juneau', 'America/Kentucky/Louisville', 
'America/Kentucky/Monticello', 'America/Kralendijk', 'America/La_Paz', 
'America/Lima', 'America/Los_Angeles', 'America/Lower_Princes', 
'America/Maceio', 'America/Managua', 'America/Manaus', 'America/Marigot', 
'America/Martinique', 'America/Matamoros', 'America/Mazatlan', 
'America/Menominee', 'Amer
 ica/Merida', 'America/Metlakatla', 'America/Mexico_City', 'America/Miquelon', 
'America/Moncton', 'America/Monterrey', 'America/Montevideo', 
'America/Montreal', 'America/Montserrat', 'America/Nassau', 'America/New_York', 
'America/Nipigon', 'America/Nome', 'America/Noronha', 
'America/North_Dakota/Beulah', 'America/North_Dakota/Center', 
'America/North_Dakota/New_Salem', 'America/Ojinaga', 'America/Panama', 
'America/Pangnirtung', 'America/Paramaribo', 'America/Phoenix', 
'America/Port-au-Prince', 'America/Port_of_Spain', 'America/Porto_Velho', 
'America/Puerto_Rico', 'America/Rainy_River', 'America/Rankin_Inlet', 
'America/Recife', 'America/Regina', 'America/Resolute', 'America/Rio_Branco', 
'America/Santa_Isabel', 'America/Santarem', 'America/Santiago', 
'America/Santo_Domingo', 'America/Sao_Paulo', 'America/Scoresbysund', 
'America/Shiprock', 'America/Sitka', 'America/St_Barthelemy', 
'America/St_Johns', 'America/St_Kitts', 'America/St_Lucia', 
'America/St_Thomas', 'America/St_Vincent', 'Amer
 ica/Swift_Current', 'America/Tegucigalpa', 'America/Thule', 
'America/Thunder_Bay', 'America/Tijuana', 'America/Toronto', 'America/Tortola', 
'America/Vancouver', 'America/Whitehorse', 'America/Winnipeg', 
'America/Yakutat', 'America/Yellowknife', 'Arctic/Longyearbyen', 'Asia/Aden', 
'Asia/Amman', 'Asia/Anadyr', 'Asia/Ashgabat', 'Asia/Baghdad', 'Asia/Bahrain', 
'Asia/Baku', 'Asia/Bangkok', 'Asia/Beirut', 'Asia/Bishkek', 'Asia/Brunei', 
'Asia/Choibalsan', 'Asia/Colombo', 'Asia/Damascus', 'Asia/Dhaka', 'Asia/Dili', 
'Asia/Dubai', 'Asia/Dushanbe', 'Asia/Gaza', 'Asia/Ho_Chi_Minh', 
'Asia/Hong_Kong', 'Asia/Hovd', 'Asia/Irkutsk', 'Asia/Jakarta', 'Asia/Jayapura', 
'Asia/Jerusalem', 'Asia/Kabul', 'Asia/Kamchatka', 'Asia/Karachi', 
'Asia/Kathmandu', 'Asia/Khandyga', 'Asia/Kolkata', 'Asia/Krasnoyarsk', 
'Asia/Kuala_Lumpur', 'Asia/Kuching', 'Asia/Kuwait', 'Asia/Macau', 
'Asia/Magadan', 'Asia/Manila', 'Asia/Muscat', 'Asia/Nicosia', 
'Asia/Novokuznetsk', 'Asia/Novosibirsk', 'Asia/Omsk', 'Asia/Oral', 'Asia/Ph
 nom_Penh', 'Asia/Pyongyang', 'Asia/Qatar', 'Asia/Rangoon', 'Asia/Riyadh', 
'Asia/Sakhalin', 'Asia/Samarkand', 'Asia/Seoul', 'Asia/Shanghai', 
'Asia/Singapore', 'Asia/Taipei', 'Asia/Tashkent', 'Asia/Tbilisi', 
'Asia/Tehran', 'Asia/Thimphu', 'Asia/Tokyo', 'Asia/Ulaanbaatar', 
'Asia/Ust-Nera', 'Asia/Vientiane', 'Asia/Vladivostok', 'Asia/Yakutsk', 
'Asia/Yangon', 'Asia/Yekaterinburg', 'Asia/Yerevan', 'Atlantic/Azores', 
'Atlantic/Bermuda', 'Atlantic/Canary', 'Atlantic/Cape_Verde', 'Atlantic/Faroe', 
'Atlantic/Madeira', 'Atlantic/Reykjavik', 'Atlantic/St_Helena', 
'Atlantic/Stanley', 'Australia/Adelaide', 'Australia/Brisbane', 
'Australia/Broken_Hill', 'Australia/Currie', 'Australia/Darwin', 
'Australia/Eucla', 'Australia/Hobart', 'Australia/Lindeman', 
'Australia/Lord_Howe', 'Australia/Melbourne', 'Australia/Perth', 
'Australia/Sydney', 'Europe/Amsterdam', 'Europe/Andorra', 'Europe/Athens', 
'Europe/Belgrade', 'Europe/Berlin', 'Europe/Bratislava', 'Europe/Brussels', 
'Europe/Bucharest', 'Europe/Budap
 est', 'Europe/Chisinau', 'Europe/Copenhagen', 'Europe/Dublin', 
'Europe/Gibraltar', 'Europe/Guernsey', 'Europe/Helsinki', 'Europe/Isle_of_Man', 
'Europe/Istanbul', 'Europe/Jersey', 'Europe/Kaliningrad', 'Europe/Kiev', 
'Europe/Lisbon', 'Europe/Ljubljana', 'Europe/London', 'Europe/Luxembourg', 
'Europe/Madrid', 'Europe/Malta', 'Europe/Mariehamn', 'Europe/Minsk', 
'Europe/Monaco', 'Europe/Moscow', 'Europe/Oslo', 'Europe/Paris', 
'Europe/Podgorica', 'Europe/Prague', 'Europe/Riga', 'Europe/Rome', 
'Europe/Samara', 'Europe/San_Marino', 'Europe/Sarajevo', 'Europe/Simferopol', 
'Europe/Skopje', 'Europe/Sofia', 'Europe/Stockholm', 'Europe/Tallinn', 
'Europe/Tirane', 'Europe/Uzhgorod', 'Europe/Vaduz', 'Europe/Vatican', 
'Europe/Vienna', 'Europe/Vilnius', 'Europe/Volgograd', 'Europe/Warsaw', 
'Europe/Zagreb', 'Europe/Zaporozhye', 'Europe/Zurich', 'Indian/Antananarivo', 
'Indian/Chagos', 'Indian/Christmas', 'Indian/Cocos', 'Indian/Comoro', 
'Indian/Mahe', 'Indian/Maldives', 'Indian/Mauritius', 'Indian/Mayo
 tte', 'Indian/Reunion', 'Pacific/Apia', 'Pacific/Auckland', 'Pacific/Chatham', 
'Pacific/Chuuk', 'Pacific/Easter', 'Pacific/Efate', 'Pacific/Fakaofo', 
'Pacific/Fiji', 'Pacific/Funafuti', 'Pacific/Guadalcanal', 'Pacific/Guam', 
'Pacific/Honolulu', 'Pacific/Kiritimati', 'Pacific/Kwajalein', 
'Pacific/Majuro', 'Pacific/Midway', 'Pacific/Nauru', 'Pacific/Niue', 
'Pacific/Norfolk', 'Pacific/Noumea', 'Pacific/Pago_Pago', 'Pacific/Palau', 
'Pacific/Pitcairn', 'Pacific/Port_Moresby', 'Pacific/Rarotonga', 
'Pacific/Saipan', 'Pacific/Tahiti', 'Pacific/Tongatapu', 'Pacific/Wake', 
'Pacific/Wallis', 'US/Pacific']
+    >>> print(list_all_scripts())    # doctest: +NORMALIZE_WHITESPACE
+    ['Adlm', 'Arab', 'Armn', 'Beng', 'Bhks', 'Cakm', 'Cans', 'Cher', 'Copt', 
'Cprt', 'Cyrl', 'Cyrs', 'Deva', 'Elba', 'Ethi', 'Geor', 'Glag', 'Gran', 'Grek', 
'Gujr', 'Guru', 'Hang', 'Hani', 'Hans', 'Hant', 'Hebr', 'Hira', 'Hung', 'Java', 
'Jpan', 'Kana', 'Khmr', 'Knda', 'Kore', 'Lana', 'Laoo', 'Latin', 'Latn', 
'Linb', 'Mahj', 'Marc', 'Mlym', 'Modi', 'Mong', 'Mtei', 'Mymr', 'Newa', 'Nkoo', 
'Olck', 'Orya', 'Osge', 'Osma', 'Perm', 'Phag', 'Shrd', 'Sidd', 'Sinh', 'Sund', 
'Syrc', 'Takr', 'Talu', 'Taml', 'Tang', 'Telu', 'Tfng', 'Tglg', 'Thaa', 'Thai', 
'Tibt', 'Tirh', 'Vaii', 'Yiii']
+    >>> print(list_all_input_methods())    # doctest: +NORMALIZE_WHITESPACE
+    ['ibus/anthy', 'ibus/chewing', 'ibus/hangul', 'ibus/kkc', 
'ibus/libpinyin', 'ibus/libzhuyin', 'ibus/m17n:ar:kbd', 
'ibus/m17n:as:inscript2', 'ibus/m17n:bn:inscript2', 
'ibus/m17n:brx:inscript2-deva', 'ibus/m17n:doi:inscript2-deva', 
'ibus/m17n:gu:inscript2', 'ibus/m17n:hi:inscript2', 'ibus/m17n:kn:inscript2', 
'ibus/m17n:kok:inscript2-deva', 'ibus/m17n:ks:inscript2-deva', 
'ibus/m17n:ks:kbd', 'ibus/m17n:mai:inscript2', 'ibus/m17n:ml:inscript2', 
'ibus/m17n:mni:inscript2-beng', 'ibus/m17n:mr:inscript2', 
'ibus/m17n:ne:inscript2-deva', 'ibus/m17n:or:inscript2', 
'ibus/m17n:pa:inscript2-guru', 'ibus/m17n:sa:inscript2', 
'ibus/m17n:sat:inscript2-deva', 'ibus/m17n:sd:inscript2-deva', 
'ibus/m17n:ta:inscript2', 'ibus/m17n:te:inscript2', 'ibus/m17n:ur:phonetic', 
'ibus/m17n:vi:telex', 'ibus/table:cangjie5']
+    >>> print(list_all_console_fonts())    # doctest: +NORMALIZE_WHITESPACE
+    ['LatGrkCyr-8x16', 'eurlatgr', 'iso07u-16', 'latarcyrheb-sun16']
     '''
 
 
diff -urN '--exclude=CVS' '--exclude=.cvsignore' '--exclude=.svn' 
'--exclude=.svnignore' 
old/langtable-0.0.61/tools/list-missing-regions-and-languages.sh 
new/langtable-0.0.64/tools/list-missing-regions-and-languages.sh
--- old/langtable-0.0.61/tools/list-missing-regions-and-languages.sh    
2019-09-04 16:23:21.000000000 +0200
+++ new/langtable-0.0.64/tools/list-missing-regions-and-languages.sh    
2023-08-29 21:28:17.000000000 +0200
@@ -38,7 +38,7 @@
 echo "Locales which are in langtable but missing in glibc:"
 MISSING_LOCALES_IN_GLIBC=
 MISSING_LOCALES_IN_GLIBC_COUNT=0
-for i in $(grep "<localeId>.*</localeId>" *.xml | perl -pe 
's/.*<localeId>(([a-z]{2,3}_|eo).*)<\/localeId>.*/\1/g')
+for i in $(grep "<localeId>.*</localeId>" *.xml | perl -pe 
's/.*<localeId>(([a-z]{2,3}_|eo|syr).*)<\/localeId>.*/\1/g')
 do
     LC_ALL=$i locale charmap 2>&1 | grep -q UTF-8
     if [ $? -eq 1 ]; then

Reply via email to