// based on a keyboard map from an 'xkb/symbols/pl' file partial default alphanumeric_keys xkb_symbols "basic" { include "latin" name[Group1]="Polish"; key { [ q, Q ] }; key { [ w, W ] }; key { [ e, E, eogonek, Eogonek ] }; key { [ o, O, oacute, Oacute ] }; key { [ a, A, aogonek, Aogonek ] }; key { [ s, S, sacute, Sacute ] }; key { [ f, F ] }; key { [ z, Z, zabovedot, Zabovedot ] }; key { [ x, X, zacute, Zacute ] }; key { [ c, C, cacute, Cacute ] }; key { [ n, N, nacute, Nacute ] }; include "kpdl(comma)" include "level3(ralt_switch)" }; partial alphanumeric_keys xkb_symbols "qwertz" { // Describes the differences between a very simple en_US // keyboard and a very simple QWERTZ Polish keybaord include "latin(type3)" name[Group1]="Polish (qwertz)"; key { [ 1, exclam, asciitilde, exclamdown ] }; key { [ 2, quotedbl, dead_caron, oneeighth ] }; key { [ 3, numbersign, dead_circumflex, sterling ] }; key { [ 4, dollar, dead_breve, dollar ] }; key { [ 5, percent, degree, threeeighths ] }; key { [ 6, ampersand, dead_ogonek, fiveeighths ] }; key { [ 7, slash, dead_grave, seveneighths ] }; key { [ 8, parenleft, dead_abovedot, trademark ] }; key { [ 9, parenright, dead_acute, plusminus ] }; key { [ 0, equal, dead_doubleacute, degree ] }; key { [ plus, question, dead_diaeresis, questiondown ] }; key { [apostrophe, asterisk, dead_cedilla, dead_ogonek ] }; key { [ q, Q ] }; key { [ w, W ] }; key { [ e, E, EuroSign, cent ] }; key { [ zabovedot, nacute, division, dead_abovering ] }; key { [ sacute, cacute, multiply, dead_macron ] }; key { [ s, S, dstroke, section ] }; key { [ d, D, Dstroke, ETH ] }; key { [ f, F ] }; key { [ k, K, kra, ampersand ] }; key { [ l, L, lstroke, Lstroke ] }; key { [ lstroke, Lstroke, dollar, dead_doubleacute ] }; key { [ aogonek, eogonek, ssharp, dead_caron ] }; key { [ abovedot, dead_ogonek, notsign, notsign ] }; key { [ oacute, zacute, dead_grave, dead_breve ] }; key { [ c, C, cent, copyright ] }; key { [ minus, underscore, dead_belowdot, dead_abovedot ] }; include "kpdl(comma)" include "level3(ralt_switch)" }; // A Polish keymap with a comprehensive set of quotes, dashes, and dead accents // // See http://marcinwolinski.pl/keyboard/ for a description. // // ┌────┐ // │ 2 4│ 2 = Shift, 4 = Level3 + Shift // │ 1 3│ 1 = Normal, 3 = Level3 // └────┘ // ┌─────┬─────┬─────┬─────┬─────┬─────┬─────┬─────┬─────┬─────┬─────┬─────┬─────┲━━━━━━━━━┓ // │ ~ ~ │ ! ' │ @ " │ # ˝ │ $ ¸ │ % ˇ │ ^ ^ │ & ˘ │ * ˙ │ ( ̣ │ ) ° │ _ ¯ │ + ˛ ┃ ⌫ Back ┃ // │ ` ` │ 1 ¡ │ 2 © │ 3 • │ 4 § │ 5 € │ 6 ¢ │ 7 − │ 8 × │ 9 ÷ │ 0 ° │ - – │ = — ┃ space ┃ // ┢━━━━━┷━┱───┴─┬───┴─┬───┴─┬───┴─┬───┴─┬───┴─┬───┴─┬───┴─┬───┴─┬───┴─┬───┴─┬───┺━┳━━━━━━━┫ // ┃ ┃ Q │ W │ E Ę │ R │ T │ Y │ U │ I │ O Ó │ P │ { « │ } » ┃ Enter ┃ // ┃Tab ↹ ┃ q │ w │ e ę │ r │ t │ y │ u │ i │ o ó │ p │ [ ‹ │ ] › ┃ ⏎ ┃ // ┣━━━━━━━┻┱────┴┬────┴┬────┴┬────┴┬────┴┬────┴┬────┴┬────┴┬────┴┬────┴┬────┴┬────┺┓ ┃ // ┃ ┃ A Ą │ S Ś │ D │ F │ G │ H │ J │ K │ L Ł │ : “ │ " ” │ | ¶ ┃ ┃ // ┃Caps ⇬ ┃ a ą │ s ś │ d │ f │ g │ h │ j │ k │ l ł │ ; ‘ │ ' ’ │ \ ┃ ┃ // ┣━━━━━━━━┹────┬┴────┬┴────┬┴────┬┴────┬┴────┬┴────┬┴────┬┴────┬┴────┬┴────┲┷━━━━━┻━━━━━━┫ // ┃ │ Z Ż │ X Ź │ C Ć │ V │ B │ N Ń │ M │ < „ │ > · │ ? ¿ ┃ ┃ // ┃Shift ⇧ │ z ż │ x ź │ c ć │ v │ b │ n ń │ m │ , ‚ │ . … │ / ⁄ ┃Shift ⇧ ┃ // ┣━━━━━━━┳━━━━━┷━┳━━━┷━━━┱─┴─────┴─────┴─────┴─────┴─────┴───┲━┷━━━━━╈━━━━━┻━┳━━━━━━━┳━━━┛ // ┃ ┃ ┃ ┃ ␣ ⍽ ┃ ┃ ┃ ┃ // ┃Ctrl ┃Meta ┃Alt ┃ ␣ Space ⍽ ┃AltGr ⇮┃Menu ┃Ctrl ┃ // ┗━━━━━━━┻━━━━━━━┻━━━━━━━┹───────────────────────────────────┺━━━━━━━┻━━━━━━━┻━━━━━━━┛ partial alphanumeric_keys xkb_symbols "intl" { include "latin(intl)" name[Group1]="Polish (international with dead keys)"; key { [ e, E, eogonek, Eogonek ] }; key { [ o, O, oacute, Oacute ] }; key { [ a, A, aogonek, Aogonek ] }; key { [ s, S, sacute, Sacute ] }; key { [ l, L, lstroke, Lstroke ] }; key { [ z, Z, zabovedot, Zabovedot ] }; key { [ x, X, zacute, Zacute ] }; key { [ c, C, cacute, Cacute ] }; key { [ n, N, nacute, Nacute ] }; include "kpdl(comma)" include "level3(ralt_switch)" }; // Polish Dvorak keymaps // by Rafal Rzepecki // The base keymap "pl" places Polish quotes on quotemark key and // moves the dead symbols from there to "1/!" key. If you are used to common // dead keys placement, you could use "pl_altquotes"; in this layout // dead keys remain in the old place, whereas Polish quotes are placed on the // "1/!" key. If you do not use Polish quotes at all, you can use "pl_basic" map. // Basic Polish keymap (without Polish quotes) partial alphanumeric_keys xkb_symbols "dvorak" { include "us(dvorak)" name[Group1] = "Polish (Dvorak)"; key { [ c, C, cacute, Cacute ] }; key { [ l, L, lstroke, Lstroke ] }; key { [ a, A, aogonek, Aogonek ] }; key { [ o, O, oacute, Oacute ] }; key { [ e, E, eogonek, Eogonek ] }; key { [ n, N, nacute, Nacute ] }; key { [ s, S, sacute, Sacute ] }; key { [ v, V, zacute, Zacute ] }; key { [ z, Z, zabovedot, Zabovedot ] }; include "kpdl(comma)" // this to allow writing ALL CAPS with a Shift key include "level3(ralt_switch)" // use one of compose:* options to choose Multi_key, if you will, // or layout +level3(ralt_switch_multikey) to revert standard behaviour }; // Default Polish keymap with Polish quotes on quotemark key partial alphanumeric_keys xkb_symbols "dvorak_quotes" { include "pl(dvorak)" name[Group1] = "Polish (Dvorak, Polish quotes on quotemark key)"; key { [ apostrophe, quotedbl, doublelowquotemark, rightdoublequotemark ] }; // Dead symbols moved to this key key { [ 1, exclam, dead_acute, dead_diaeresis ] }; }; // Polish keymap with Polish quotes on key "1/!" partial alphanumeric_keys xkb_symbols "dvorak_altquotes" { include "pl(dvorak)" name[Group1] = "Polish (Dvorak, Polish quotes on key 1)"; key { [ 1, exclam, doublelowquotemark, rightdoublequotemark ] }; }; // Polish Programmer Dvorak keymap by Michal Nazarewicz // based on Programmer Dvorak by Roland Kaufmann // and Polish Dvorak keymaps by Rafal Rzepecki { [ ampersand, percent, doublelowquotemark, rightdoublequotemark ] }; // symbols row, right side // upper row, left side // // upper row, right side key { [ c, C, cacute, Cacute ] }; key { [ l, L, lstroke, Lstroke ] }; // home row, left side key { [ a, A, aogonek, Aogonek ], type[Group1] = "EIGHT_LEVEL_ALPHABETIC" }; key { [ o, O, oacute, Oacute ] }; key { [ e, E, eogonek, Eogonek ] }; // home row, right side key { [ n, N, nacute, Nacute ] }; key { [ s, S, sacute, Sacute ] }; key { [ minus, underscore, hyphen ], type[Group1] = "FOUR_LEVEL_ALPHABETIC" }; key { [ backslash, bar ] }; // lower row, left side key { [ j, J, doublelowquotemark, rightdoublequotemark ] }; key { [ k, K, leftdoublequotemark, leftsinglequotemark ] }; key { [ x, X, zacute, Zacute ] }; // lower row, right side key { [ b, B, rightdoublequotemark, rightsinglequotemark ] }; key { [ v, V, zacute, Zacute ] }; key { [ z, Z, zabovedot, Zabovedot ] }; include "kpdl(comma)" // this to allow writing ALL CAPS with a Shift key include "level3(ralt_switch)" // use one of compose:* options to choose Multi_key, if you will, // or layout +level3(ralt_switch_multikey) to revert standard behaviour }; partial alphanumeric_keys xkb_symbols "csb" { include "latin" name[Group1]="Kashubian"; key { [ q, Q ] }; key { [ w, W ] }; key { [ e, E, eacute, Eacute ] }; key { [ r, R, ediaeresis, Ediaeresis ] }; key { [ y, Y, EuroSign, cent ] }; key { [ u, U, ugrave, Ugrave ] }; key { [ i, I, ograve, Ograve ] }; key { [ o, O, oacute, Oacute ] }; key { [ p, P, ocircumflex, Ocircumflex ] }; key { [ a, A, aogonek, Aogonek ] }; key { [ s, S, atilde, Atilde ] }; key { [ f, F ] }; key { [ l, L, lstroke, Lstroke ] }; key { [ z, Z, zabovedot, Zabovedot ] }; key { [ n, N, nacute, Nacute ] }; include "kpdl(comma)" include "level3(ralt_switch)" }; // Russian Polish-phonetic Dvorak // by Adrian Dziubek // // This layout aims to enable Polish Dvorak users to type with Russian // Cyrillic alphabet by using the sound correspondence between Polish and // Russian languages. // // This keyboard should be intuitive. Please let me know, if my intuition // lets You down. // // The guidelines used: // - no Cyrillic symbols are placed on punctuation symbols, // - visual similarities are ignored if there is a sound correspondence: // no Cyrillic_es on c, no Cyrillic_er on p, no Cyrillic_ha on x etc., // - the Latin symbols that have close sound correspondence (as read in Polish) // to Cyrillic symbols (as read in Russian) are mapped respectively: // * j -> Cyrillic_shorti, // * k -> Cyrillic_ka, // * b -> Cyrillic_be, // * m -> Cyrillic_em, // * w -> Cyrillic_ve, // * z -> Cyrillic_ze // * a -> Cyrillic_a, // * o -> Cyrillic_o, // * u -> Cyrillic_u, // * i -> Cyrillic_i, // * d -> Cyrillic_de, // * h -> Cyrillic_ha, // * t -> Cyrillic_te, // * n -> Cyrillic_en, // * s -> Cyrillic_es, // * p -> Cyrillic_pe, // * y -> Cyrillic_yeru, // * f -> Cyrillic_ef, // * g -> Cyrillic_ghe, // * c -> Cyrillic_tse, // * r -> Cyrillic_er, // * l -> Cyrillic_el, // - ...and little more distant: // * AltGr + s (sacute) -> Cyrillic_sha, // * AltGr + z (zabovedot) -> Cyrillic_zhe, // * AltGr + c (cacute) -> Cyrillic_che, // - the soft versions of Russian vowels are accessible through AltGr + vowel: // * AltGr + a -> Cyrillic_ya, // * AltGr + o -> Cyrillic_io, // * AltGr + u -> Cyrillic_yu, // - ...except for Cyrillic_ie which is more frequently used than Cyrillic_e: // * AltGr + e -> Cyrillic_e, // * e -> Cyrillic_ie, // - q is also mapped to Cyrillic_ya, following the US phonetic keyboard // choice, as Cyrillic_ya and Cyrillic_a are both often used: // * q -> Cyrillic_ya, // - the soft and hard symbols that have no Polish counterparts are mapped // to rarely used in Polish x character: // * x -> Cyrillic_softsign // * AltGr + x -> Cyrillic_hardsign, // - the soft sign is additionally available as AltGr + consonant combination // for every consonant that can be softened or separated by soft sign: // * AltGr + l -> Cyrillic_softsign, // * AltGr + d -> Cyrillic_softsign, // * AltGr + n -> Cyrillic_softsign, // * AltGr + r -> Cyrillic_softsign, // * AltGr + t -> Cyrillic_softsign, // * AltGr + p -> Cyrillic_softsign, // - ...and also because of visual similarity under level3 b: // * AltGr + b -> Cyrillic_softsign, // * Shift + AltGr + b -> Cyrillic_hardsign, // - the Cyrillic_shcha symbol is placed under AltGr + w (visual similarity): // * AltGr + w -> Cyrillic_shcha // - v, also rarely unused in Polish is mapped like w: // * v -> Cyrillic_ve, // partial alphanumeric_keys xkb_symbols "ru_phonetic_dvorak" { include "us(dvorak)" name[Group1] = "Russian (Poland, phonetic Dvorak)"; // lower row key { [ Cyrillic_ya, Cyrillic_YA ] }; key { [ Cyrillic_shorti, Cyrillic_SHORTI ] }; key { [ Cyrillic_ka, Cyrillic_KA ] }; key { [ Cyrillic_shcha, Cyrillic_SHCHA ] }; key { [ Cyrillic_be, Cyrillic_BE, Cyrillic_hardsign, Cyrillic_HARDSIGN ] }; key { [ Cyrillic_em, Cyrillic_EM ] }; key { [ Cyrillic_ve, Cyrillic_VE, Cyrillic_shcha, Cyrillic_SHCHA ] }; key { [ Cyrillic_ve, Cyrillic_VE, Cyrillic_shcha, Cyrillic_SHCHA ] }; key { [ Cyrillic_ze, Cyrillic_ZE, Cyrillic_zhe, Cyrillic_ZHE ] }; // home row key { [ Cyrillic_a, Cyrillic_A, Cyrillic_ya, Cyrillic_YA ] }; key { [ Cyrillic_o, Cyrillic_O, Cyrillic_io, Cyrillic_IO ] }; key { [ Cyrillic_ie, Cyrillic_IE, Cyrillic_e, Cyrillic_E ] }; key { [ Cyrillic_u, Cyrillic_U, Cyrillic_yu, Cyrillic_YU ] }; key { [ Cyrillic_i, Cyrillic_I ] }; key { [ Cyrillic_de, Cyrillic_DE, Cyrillic_softsign, Cyrillic_SOFTSIGN ] }; key { [ Cyrillic_ha, Cyrillic_HA ] }; key { [ Cyrillic_te, Cyrillic_TE, Cyrillic_softsign, Cyrillic_SOFTSIGN ] }; key { [ Cyrillic_en, Cyrillic_EN, Cyrillic_softsign, Cyrillic_SOFTSIGN ] }; key { [ Cyrillic_es, Cyrillic_ES, Cyrillic_sha, Cyrillic_SHA ] }; // upper row key { [ Cyrillic_pe, Cyrillic_PE, Cyrillic_softsign, Cyrillic_SOFTSIGN ] }; key { [ Cyrillic_yeru, Cyrillic_YERU ] }; key { [ Cyrillic_ef, Cyrillic_EF ] }; key { [ Cyrillic_ghe, Cyrillic_GHE ] }; key { [ Cyrillic_tse, Cyrillic_TSE, Cyrillic_che, Cyrillic_CHE ] }; key { [ Cyrillic_er, Cyrillic_ER, Cyrillic_softsign, Cyrillic_SOFTSIGN ] }; key { [ Cyrillic_el, Cyrillic_EL, Cyrillic_softsign, Cyrillic_SOFTSIGN ] }; include "kpdl(comma)" include "level3(ralt_switch)" };