From 3ff7d74a59a879b0ccf80e8048fedc9711ffb99a Mon Sep 17 00:00:00 2001 From: Robert Tari Date: Fri, 16 Apr 2021 00:20:18 +0200 Subject: data/ayatana-indicator-keyboard-icon-generator: Use a predefined abbreviation list --- data/ayatana-indicator-keyboard-icon-generator | 197 +++++++++++++++++++++---- 1 file changed, 169 insertions(+), 28 deletions(-) diff --git a/data/ayatana-indicator-keyboard-icon-generator b/data/ayatana-indicator-keyboard-icon-generator index 96c4b1b7..0316d7f4 100755 --- a/data/ayatana-indicator-keyboard-icon-generator +++ b/data/ayatana-indicator-keyboard-icon-generator @@ -3,15 +3,174 @@ import gi -gi.require_version('Xkl', '1.0') gi.require_version('PangoFT2', '1.0') -from gi.repository import Xkl, GdkX11, PangoFT2, Pango +from gi.repository import PangoFT2, Pango from pathlib import Path -#from Xlib.display import Display import sys import getopt +m_lLanguages = [ +'Ap', #APL +'Fa', #Afghani +'Ak', #Akan +'Sq', #Albanian +'Am', #Amharic +'Ar', #Arabic +'Hy', #Armenian +'As', #Asturian +'At', #Atsina +'Av', #Avatime +'Ae', #Avestan +'Az', #Azerbaijani +'Bm', #Bambara +'Bn', #Bangla +'Ba', #Bashkirian +'Be', #Belarusian +'Bl', #Belgian +'Bb', #Berber +'Bs', #Bosnian +'Bi', #Braille +'Bg', #Bulgarian +'By', #Burmese +'Zg', #Zawgyi +'Cm', #Cameroon +'Cn', #Canadian +'Ca', #Catalan +'Ck', #Cherokee +'Zh', #Chinese +'Cu', #Church Slavonic +'Cv', #Chuvash +'Cl', #CloGaelach +'Sx', #Coeur d'Alene Salish +'Cp', #Coptic +'Tt', #Tatar +'Hr', #Croatian +'Cs', #Czech +'Da', #Danish +'Dv', #Dhivehi +'Dl', #Dutch +'Dz', #Dzongkha +'Ed', #Elfdalian +'En', #English +'Eo', #Esperanto +'Et', #Estonian +'Ek', #EurKEY +'Ee', #Ewe +'Fo', #Faroese +'Ph', #Filipino +'Fi', #Finnish +'Fr', #French +'Fu', #Friulian +'Ff', #Fula +'Gh', #Ga +'Ka', #Georgian +'De', #German +'Gr', #Greek +'Gu', #Gujarati +'Hp', #Hanyu Pinyin +'Ha', #Hausa +'Hw', #Hawaiian +'He', #Hebrew +'Hi', #Hindi +'Hu', #Hungarian +'Is', #Icelandic +'Ig', #Igbo +'Il', #Indian +'Ip', #Indic +'Id', #Indonesian +'Ix', #International Phonetic Alphabet +'Iu', #Inuktitut +'Iq', #Iraqi +'Ga', #Irish +'It', #Italian +'Ja', #Japanese +'Kb', #Kabyle +'Kx', #Kalmyk +'Kn', #Kannada +'Kp', #Kashubian +'Kk', #Kazakh +'Km', #Khmer +'Ki', #Kikuyu +'Kv', #Komi +'Ko', #Korean +'Ku', #Kurdish +'Kt', #Kutenai +'Ky', #Kyrgyz +'Lo', #Lao +'Lv', #Latvian +'Lt', #Lithuanian +'Sb', #Lower Sorbian +'Mk', #Macedonian +'Ms', #Malay +'Ml', #Malayalam +'Mt', #Maltese +'Ma', #Manipuri +'Mi', #Maori +'Mr', #Marathi +'Mx', #Mari +'Mu', #Mmuock +'Md', #Modi +'Ro', #Moldavian +'Mn', #Mongolian +'Me', #Montenegrin +'Mb', #Multilingual +'Nk', #N'Ko +'Ne', #Nepali +'Ns', #Saami +'No', #Norwegian +'Oc', #Occitan +'Og', #Ogham +'Ol', #Ol Chiki +'Or', #Oriya +'Os', #Ossetian +'Rs', #Rusyn +'Ps', #Pashto +'Fa', #Persian +'Pl', #Polish +'Pt', #Portuguese +'Pa', #Punjabi +'Ro', #Romanian +'Ru', #Russian +'Sy', #Saisiyat +'Sf', #Samogitian +'Sa', #Sanskrit +'Sp', #Secwepemctsin +'Sr', #Serbian +'Hs', #Serbo-Croatian +'Sj', #Sicilian +'Sj', #Silesian +'Sd', #Sindhi +'Si', #Sinhala +'Sk', #Slovak +'Sl', #Slovenian +'Es', #Spanish +'Sw', #Swahili +'Sv', #Swedish +'Ls', #Syriac +'Tw', #Taiwanese +'Tg', #Tajik +'Ta', #Tamil +'Tt', #Tatar +'Te', #Telugu +'Th', #Thai +'Bo', #Tibetan +'Tn', #Tswana +'Tr', #Turkish +'Tk', #Turkmen +'Ud', #Udmurt +'Ua', #Ugaritic +'Uk', #Ukrainian +'Ur', #Urdu +'Ug', #Uyghur +'Uz', #Uzbek +'Vi', #Vietnamese +'Wo', #Wolof +'Ya', #Yakut +'Yo', #Yoruba +'00' #Unknown +] + def printHelp(): print('') @@ -29,20 +188,6 @@ def printHelp(): print(' Defaults to the current directory') print('') -def onLanguage(pRegistry, pConfigItem, lParams): - - bCheckVariant = lParams[0] - lLanguages = lParams[1] - sLanguage = pConfigItem.get_short_description()[0:2] - - if sLanguage and sLanguage not in lLanguages: - - lLanguages.append(sLanguage) - - if bCheckVariant: - - pRegistry.foreach_layout_variant(pConfigItem.get_name(), onLanguage, [False, lLanguages]) - if __name__ == '__main__': nPadding = 0 @@ -85,13 +230,6 @@ if __name__ == '__main__': pOutDir = Path(sArg) pOutDir.mkdir(parents=True, exist_ok=True) - lLanguages = [] - #pDisplay = Display() - pDisplay = GdkX11.x11_get_default_xdisplay() - pEngine = Xkl.Engine.get_instance(pDisplay) - pRegistry = Xkl.ConfigRegistry.get_instance(pEngine) - pRegistry.load(True) - pRegistry.foreach_layout(onLanguage, [True, lLanguages]) nSize = 24 - (2 * nPadding) fIconX = (24 - nSize) / 2 @@ -105,18 +243,21 @@ if __name__ == '__main__': pLayout = Pango.Layout.new(pContext) pLayout.set_font_description(pFontDescription) - for sLanguage in lLanguages: + for sLanguage in m_lLanguages: sOutPath = pOutDir.joinpath('ayatana-indicator-keyboard-' + sLanguage + '.svg') with open(sOutPath, 'w') as pFile: - sLayout = sLanguage[0].upper() + sLanguage[1] - pLayout.set_text(sLayout, -1) + if sLanguage == '00': + + sLanguage = '?' + + pLayout.set_text(sLanguage, -1) nLayoutWidth, nLayoutHeight = pLayout.get_size() nBaseline = pLayout.get_baseline() fLayoutX = (24.0 - (nLayoutWidth / Pango.SCALE)) / 2 fLayoutY = (24.0 - (nLayoutHeight / Pango.SCALE)) / 2 + (nBaseline / Pango.SCALE) - pFile.write('' + sLayout + '') + pFile.write('' + sLanguage + '') sys.exit(0) -- cgit v1.2.3