blob: b579e39f3899f98532ff6e6e0112809b661feae6 [file] [log] [blame]
<?xml version="1.0" encoding="UTF-8"?>
<keyboard3 xmlns="https://schemas.unicode.org/cldr/45/keyboard3" locale="bn" conformsTo="45">
<!--
History:
Based on
https://github.com/keymanapp/ldml-keyboards-dev/blob/master/keyboards/sil-bengali/bn-t-k0-cldr-phonetic.ldml
-->
<locales>
<locale id="as" />
<locale id="syl" />
</locales>
<version number="1.3.0" />
<info name="SIL Bengali-Assamese Phonetic" indicator="bn" layout="QWERTY" />
<displays>
<display keyId="au-lengthener" display="ৗ" />
<display keyId="vis-hasant" display="্" /> <!-- TODO: distinguish from regular hasant? -->
<display keyId="more" display="…" />
</displays>
<keys>
<import base="cldr" path="45/keys-Zyyy-punctuation.xml" />
<import base="cldr" path="45/keys-Zyyy-currency.xml" />
<key id="1" output="১" />
<key id="2" output="২" />
<key id="3" output="৩" />
<key id="4" output="৪" />
<key id="5" output="৫" />
<key id="6" output="৬" />
<key id="7" output="৭" />
<key id="8" output="৮" />
<key id="9" output="৯" />
<key id="0" output="০" />
<!-- special keys and marks -->
<key id="au-lengthener" output="\m{A}" />
<key id="candrabindu" output="\u{0981}" /> <!-- n̐ -->
<key id="hasant" output="\u{09CD}" />
<key id="more" output="\m{q}" /> <!-- 'additional characters' -->
<key id="nukta" output="\u{09BC}" />
<key id="vis-hasant" output="\m{X}" />
<!-- key names based on https://www.loc.gov/catdir/cpso/romanization/bengali.pdf + Assamese for /wa/ -->
<key id="ā" output="\u{09BE}" />
<key id="ai" output="\u{09C8}" />
<key id="au" output="\u{09CC}" />
<key id="ba" output="ব" />
<key id="bha" output="ভ" />
<key id="ca" output="চ" />
<key id="cha" output="ছ" />
<key id="ḍa" output="ড" />
<key id="da" output="দ" />
<key id="dahri" output="।" />
<key id="ḍha" output="ঢ" />
<key id="dha" output="ধ" />
<key id="e" output="\u{09C7}" />
<key id="ga" output="গ" />
<key id="gha" output="ঘ" />
<key id="ha" output="হ" />
<key id="i" output="\u{09BF}" />
<key id="ī" output="\u{09C0}" />
<key id="ja" output="জ" />
<key id="jha" output="ঝ" />
<key id="ka" output="ক" />
<key id="kha" output="খ" />
<key id="la" output="ল" />
<key id="ṃ" output="\u{0982}" />
<key id="ma" output="ম" />
<key id="ṅa" output="ঙ" />
<key id="ña" output="ঞ" />
<key id="ṇa" output="ণ" />
<key id="na" output="ন" />
<key id="o" output="\u{09CB}" />
<key id="pa" output="প" />
<key id="pha" output="ফ" />
<key id="ṛ" output="\u{09C3}" />
<key id="ra" output="র" />
<key id="śa" output="শ" />
<key id="sa" output="স" />
<key id="sha" output="ষ" />
<key id="ṭa" output="ট" />
<key id="ta" output="ত" />
<key id="ṭha" output="ঠ" />
<key id="tha" output="থ" />
<key id="u" output="\u{09C1}" />
<key id="ū" output="\u{09C2}" />
<key id="wa" output="ৱ" /> <!-- Assamese transliteration -->
<key id="ya" output="য" />
<key id="ẏa" output="য়" /> <!-- Missing in Keyman version of file-->
</keys>
<layers formId="us">
<layer modifiers="none">
<row keys="candrabindu 1 2 3 4 5 6 7 8 9 0 hyphen equal" />
<row keys="more wa e ra ta ya u i o pa open-square close-square backslash" />
<row keys="ā sa da ṭa ga ha ja ka la semi-colon apos" />
<row keys="śa hasant ca ḍa ba na ma comma dahri slash" />
<row keys="space" />
</layer>
<layer modifiers="shift">
<row
keys="ṃ bang at hash dollar percent caret amp asterisk open-paren close-paren underscore plus" />
<row keys="gap ña ai ṛ tha ẏa ū ī au pha open-curly close-curly pipe" />
<row keys="au-lengthener sha dha ṭha gha gap jha kha gap colon double-quote" />
<row keys="gap vis-hasant cha ḍha bha ṇa ṅa open-angle nukta question" />
<row keys="space" />
</layer>
</layers>
<transforms type="simple">
<transformGroup>
<transform from="\u{09C7}\m{A}" to="\u{09CC}" /> <!-- E + au-lengthener = AU -->
<!-- <transform from="\u{09C7}\u{09BE}" to="\u09CB" /> --> <!-- E + A = O This is handled by normalization. -->
<!-- these suport the 'q' key -->
<transform from="\m{q}:" to="\u{0983}" />
<transform from="\m{q}L" to="ৡ" />
<transform from="\m{q}।" to="॥" />
<transform from="\m{q}ড" to="ড়" />
<transform from="\m{q}ঢ" to="ঢ়" />
<transform from="\m{q}ত" to="ৎ" />
<transform from="\m{q}য" to="য়" />
<transform from="\m{q}র" to="ৰ" />
<transform from="\m{q}ল" to="ঌ" />
<transform from="\m{q}\u{09BE}" to="অ" />
<transform from="\m{q}\u{09BF}" to="ই" />
<transform from="\m{q}\u{09C0}" to="ঈ" />
<transform from="\m{q}\u{09C1}" to="উ" />
<transform from="\m{q}\u{09C2}" to="ঊ" />
<transform from="\m{q}\u{09C3}" to="ৠ" />
<transform from="\m{q}\u{09C7}" to="এ" />
<transform from="\m{q}\u{09C8}" to="ঐ" />
<transform from="\m{q}\u{09CB}" to="ও" />
<transform from="\m{q}\u{09CC}" to="ঔ" />
<transform from="\m{q}\m{A}" to="আ" />
<transform from="\m{q}\m{X}" to="\u{09CD}\u{200C}" /> <!-- virama + zwnj-->
</transformGroup>
<transformGroup>
<!-- Nukta is tertiary, that is, it follows a tertiaryBase sequence -->
<reorder from="\u{09BC}" tertiary="3"/>
<!--
virama (hasant) followed by any other spacing chars has order 10, because this sequence goes after the consonant to which the virama pertains.
For example:
U+099A U+09CD U+099B
CA virama CHA
0 10 10
-->
<reorder from="\u{09CD}[\u{0980}\u{0985}-\u{098C}\u{098F}\u{0990}\u{0993}-\u{09A8}\u{09AA}-\u{09B0}\u{09B2}\u{09B6}-\u{09B9}\u{09BD}\u{09DC}\u{09DD}\u{09DF}-\u{09E1}\u{09E6}-\u{09F1}\u{09FC}]" order="10" tertiaryBase="true"/>
<!-- 10: virama + zwj/zwnj + spacing mark is also 10-->
<reorder from="\u{09CD}[\u{200C}\u{200D}][\u{0980}\u{0985}-\u{098C}\u{098F}\u{0990}\u{0993}-\u{09A8}\u{09AA}-\u{09B0}\u{09B2}\u{09B6}-\u{09B9}\u{09BD}\u{09DC}\u{09DD}\u{09DF}-\u{09E1}\u{09E6}-\u{09F1}\u{09FC}]" order="10" tertiaryBase="true"/>
<!-- 120: A virama not followed by a spacing mark goes further to the right (past the sandhi mark, below) -->
<reorder from="\u{09CD}" order="120" tertiaryBase="true"/>
<!-- The next three rules make sure the DVs are in the correct order-->
<!-- 60: left side dependent vowels -->
<reorder from="[\u{09BF}\u{09C7}\u{09C8}]" order="60"/>
<!-- 70: lower dependent vowels -->
<reorder from="[\u{09C1}-\u{09C4}\u{09E2}\u{09E3}]" order="70"/>
<!-- 75: right side dependent vowels. Note U+09D7 AU LENGTH MARK is included due to NFD -->
<reorder from="[\u{09BE}\u{09C0}\u{09CB}\u{09CC}\u{09D7}]" order="75"/>
<!-- 85: candrabindu -->
<reorder from="\u{0981}" order="85"/>
<!-- 95: anusvara and visarga -->
<reorder from="[\u{0982}\u{0983}]" order="95"/>
<!-- 117: sandhi mark -->
<reorder from="\u{09FE}" order="117"/>
</transformGroup>
</transforms>
</keyboard3>