# The list of input methods that we support. The input methods metadata is # also defined here. We use this data for the following purposes. # # 1. Exclude unnecessary input methods. For example, we don't need # "ja:anthy", and "zh:pinyin" engines in ibus-m17n since we have better # alternatives outside of ibus-m17n. Excluding these input methods from # the IBus engine XML files, such as /usr/share/ibus/component/m17n.xml, # makes the startup time of the IBus daemon faster. This filtering is # done using a python script at build time of ibus-m17n. # See crosbug.com/4161 for details. # # 2. Provide the input methods metadata to Chrome at build time. Chrome # needs to know about the supported input methods for the input method # features, such as the input method switching and the options page, # to work. Note that we can retrieve the same metadata from the IBus # daemon, but Chrome needs be able to get the metadata without talking # to the IBus daemon. This requirement comes from the fact that the # IBus daemon should not run if the user is just using keyboard layouts # such as US keyboard. The metadata generation is done using a python # script at build time of Chrome. See crosbug.com/16961 for details. # # The order of the list is important. In Chrome's "Languages and input" options # page, we list input methods in this order, when more than one input methods # are available for a language (ex. French). # # Each non-comment line contains the following tab-separated columns. # # 1) The input method ID used by Chrome. (ex. "xkb:ca::fra") You should *NEVER* # change the ID since the ID might be written in user's ~/Preferences. For # example, three-letter ISO 639-2/B codes are used for IDs start with "xkb:" # for histrical reason, but we should not replace them with two-letter 639-1 # codes that are currently in use in the 3rd column. # 2) The keyboard layout ID used by XKB. (ex. "us", "us(dvorak)", "ca", # "handwriting-vk,jp"). See also: /usr/share/X11/xkb/symbols. # 3) The language code (ex. "fr"). Only one format, ISO 639-1 compliant two- # letter language code which can be recognized by ICU, is allowed. Do not use # three-letter ones (ISO 639-2/T and 639-2/B) here. For "en", "pt", and "zh", # two-letter upper-case country code should be added (ex. "en-US", "zh-TW"). # See http://en.wikipedia.org/wiki/List_of_ISO_639-1_codes for details. # 4) [optional] The #if condition for the input method. # (ex. "defined(A)", "!defined(A)||defined(B)") # # Notes: # When adding a line to this list, please also add a mapping from the input # method ID to the keyboard overlay ID to INPUT_METHOD_ID_TO_OVERLAY_ID in # # * tools/gen_keyboard_overlay_data/gen_keyboard_overlay_data.py # # and update the following files by running this script. # # * chrome/app/generated_resources.grd # * chrome/browser/resources/chromeos/keyboard_overlay_data.js # * chrome/browser/ui/webui/chromeos/keyboard_overlay_ui.cc # # If you add an XKB layout which depends on X11's Mod3Mask (e.g. Germany Neo2 # XKB layout), you should also update IsMod3UsedByCurrentInputMethod() method # in chrome/browser/ui/ash/event_rewriter.cc. Otherwise, Mod3Mask might be # removed unexpectedly by the rewriter. # U.S. English xkb:us::eng us en-US xkb:us:intl:eng us(intl) en-US xkb:us:altgr-intl:eng us(altgr-intl) en-US xkb:us:dvorak:eng us(dvorak) en-US xkb:us:colemak:eng us(colemak) en-US english-m us en-US # U.S. English entiries have to be above the Dutch entry so that xkb:us:intl:eng # will be selected as the default keyboard when the UI language is set to Dutch. # Dutch xkb:be::nld be nl # We don't support xkb:nl::nld. See b/4430951. # French xkb:fr::fra fr fr xkb:be::fra be fr xkb:ca::fra ca fr xkb:ch:fr:fra ch(fr) fr xkb:ca:multix:fra ca(multix) fr # German xkb:de::ger de de xkb:de:neo:ger de(neo) de xkb:be::ger be de xkb:ch::ger ch de # Japanese # |kMozcJaInputMethodIds| in ibus_ui_controller.cc should also be updated when # a new Mozc Japanese IME for another keyboard layout is added. xkb:jp::jpn jp ja # Russian xkb:ru::rus ru ru xkb:ru:phonetic:rus ru(phonetic) ru # Traditional Chinese m17n:zh:quick us zh-TW # Vietnamese m17n:vi:vni us vi # Note: Since Chrome does not support "get surrounding text" feature yet, # Vietnames input methods, except 4 input methods above, in m17n-db should # not work fine. The 4 input methods in m17n-db (>= 1.6.0) don't require the # feature. # Korean mozc-hangul kr(kr104) ko xkb:kr:kr104:kor kr(kr104) ko # Keyboard layouts. xkb:br::por br pt-BR xkb:bg::bul bg bg xkb:bg:phonetic:bul bg(phonetic) bg xkb:ca:eng:eng ca(eng) en-CA xkb:cz::cze cz cs xkb:cz:qwerty:cze cz(qwerty) cs xkb:ee::est ee et xkb:es::spa es es xkb:es:cat:cat es(cat) ca xkb:dk::dan dk da xkb:gr::gre gr el xkb:il::heb il he xkb:latam::spa latam es xkb:lt::lit lt lt xkb:lv:apostrophe:lav lv(apostrophe) lv xkb:hr::scr hr hr xkb:gb:extd:eng gb(extd) en-GB xkb:gb:dvorak:eng gb(dvorak) en-GB xkb:fi::fin fi fi xkb:hu::hun hu hu xkb:it::ita it it xkb:is::ice is is xkb:no::nob no nb xkb:pl::pol pl pl xkb:pt::por pt pt-PT xkb:ro::rum ro ro xkb:se::swe se sv xkb:sk::slo sk sk xkb:si::slv si sl xkb:rs::srp rs sr xkb:tr::tur tr tr xkb:ua::ukr ua uk xkb:by::bel by be xkb:am:phonetic:arm am hy xkb:ge::geo ge ka xkb:mn::mon mn mn # TODO(yusukes): Support xkb:latam:deadtilde:spa and/or xkb:latam:nodeadkeys:spa # if necessary.