Input methods

From The Toaq Wiki
Revision as of 14:36, 20 December 2022 by Uakci (talk | contribs) (→‎vim: update keymap; add explanatory table)

Toaq's Latin writing system features many letter with diacritics, which are tricky to type on a standard keyboard configured for English. Here are some solutions.

Desktop computers

Compose key

You can set up a compose key on your computer, which will change the behavior of one of the keys on your keyboard to "compose" the next two keypresses into one character — for example CapsLock ? a becomes .

On Linux, this might not even involve installing anything! Look for "compose key" plus your distro name.

On Windows, WinCompose is pretty good.

Here's how to type Toaq-specific characters in the default ruleset.

Character Combo
rising tone ' + vowel
glottal tone " + vowel
hiatus tone ^ + vowel
dotless i (ı) . + i
left quote («) < + <
right quote (») > + >

Then there are these supplemental definitions. WinCompose provides them by default; on Linux you’re going to have to add them yourself one-by-one or by sourcing [1]. That said you might not find them very convenient to type.

Character Combo
V + & + Y
v + & + y
combining underdot (like in ı̣) \ + !

Kaıchuo

This is a little tool by User:Lynn that runs in your browser, available here. You type something like Kiai ji kato/ da and it turns it into Kıaı jí káto da. (Wow! It knows is a pronoun and automatically adds rising tone.)

vim

Copy the contents below into a file called toaq.vim inside a folder named keymap in your .vim directory (create it if it doesn’t exist). Then, in insert mode, you may use any of the two-keystroke “combinations” and have them replaced with accented letters on the fly. (See :help mbyte-keymap for more detailed information.)

Without underdot With underdot
falling tone .
rising tone / '
glottal tone : "
hiatus tone > ^
Toaq vim keymap
" toaq keymap
" by uakci on 2022-12-20
scriptencoding utf8
let b:keymap_name = "toaq"
loadkeymap
.i	i
i	ı
//	/
::	:
>>	>
''	'
""	"
^^	^
..	.
.<	«
.>	»
.{	‹
.}	›
./	́
.:	̈
.>	̂
.,	̣
.A	Ạ
.U	Ụ
.I	Ị
.O	Ọ
.E	Ẹ
.a	ạ
.u	ụ
.i	ı̣
.o	ọ
.e	ẹ
vy	ꝡ
Vy	Ꝡ
VY	Ꝡ
/A	Á
/U	Ú
/I	Í
/O	Ó
/E	É
/a	á
/u	ú
/i	í
/o	ó
/e	é
:A	Ä
:U	Ü
:I	Ï
:O	Ö
:E	Ë
:a	ä
:u	ü
:i	ï
:o	ö
:e	ë
>A	Â
>U	Û
>I	Î
>O	Ô
>E	Ê
>a	â
>u	û
>i	î
>o	ô
>e	ê
'A	Ạ́
'U	Ụ́
'I	Ị́
'O	Ọ́
'E	Ẹ́
'a	ạ́
'u	ụ́
'i	ị́
'o	ọ́
'e	ẹ́
"A	Ạ̈
"U	Ụ̈
"I	Ị̈
"O	Ọ̈
"E	Ẹ̈
"a	ạ̈
"u	ụ̈
"i	ị̈
"o	ọ̈
"e	ẹ̈
^A	Ậ
^U	Ụ̂
^I	Ị̂
^O	Ộ
^E	Ệ
^a	ậ
^u	ụ̂
^i	ị̂
^o	ộ
^e	ệ

Alternatively, for sporadic usage, you can enter Toaq characters using Ctrl+K followed by two keystrokes (see :help digraph). Ꝡ is not available to input using this method.

Character Combo
rising tone Ctrl+K vowel '
glottal tone Ctrl+K vowel :
hiatus tone Ctrl+K vowel >
dotless i (ı) Ctrl+K . i
left quote («) Ctrl+K < <
right quote (») Ctrl+K > >

AutoHotkey

This official AutoHotkey script will convert a/ into á, etc. Oh, it's actually outdated (has the old falling-rising tone (obsolete 3rd tone) instead of the new rising-creaky tone).

US, intl. with dead keys

If you are on Linux, there is a keyboard option called "US, intl. with dead keys". The way you enter diacritics is the same as the compose key one. Unfortunately, is not on the layout.

Xmodmap

If you’re running X11 on a Linux machine, create a file (I suggest calling it .Xmodmap in your home directory) with the following contents, then run xmodmap filename to activate:

keycode 11  =  2  at           2  at           dead_acute
keycode 12  =  3  numbersign   3  numbersign   dead_diaeresis
keycode 13  =  4  dollar       4  dollar       dead_hook
keycode 14  =  5  percent      5  percent      dead_circumflex
keycode 15  =  6  asciicircum  6  asciicircum  dead_grave
keycode 16  =  7  ampersand    7  ampersand    dead_tilde
keycode 31  =  i  I            i  I            idotless
Note: You will require your keyboard layout to have a modifier key active (if at all, usually RAlt a.k.a. AltGr); to achieve this, you may run setxkbmap us intl to switch to the international US layout with dead keys. Also note that a layout change wipes any xmodmaps previously issued, so you will have to rerun the xmodmap command. Feel free to add those two commands (in the right order!) to your .xprofile, or whatever other file your system picks up when starting up X11. Contact uakci if you run into issues.

To use: hold RAlt and then press a digit, 2 thru 7. After releasing, press the key for your favourite vowel. This should produce a vowel with the desired precomposed tone diacritic (this is a big deal to some people). For dotless ı, use RAltI.

Variations

Bind the dead diacritic keys to s, d, f, j, k, l (for that sweet sweet ergonomic swag):

keycode 39  =  s  S  s  S  dead_acute
keycode 40  =  d  D  d  D  dead_diaeresis
keycode 41  =  f  F  f  F  dead_hook
keycode 44  =  j  J  j  J  dead_circumflex
keycode 45  =  k  K  k  K  dead_grave
keycode 46  =  l  L  l  L  dead_tilde

Make dotless ı the default when pressing I, requiring RAltI to obtain regular dotted i (and also when composing diacritics with the mechanism described above):

keycode 31  =  i  I  i  I  idotless

Kanakey

User:Hoaqgio uses a custom Python script that can be found at https://github.com/toaq/kanakey. The way it works is that the script always runs in the background (you start it on login) and when you want to type Toaq, you type alt+; followed by the Toaq you want in the format of "Mai4 ji2 suq2 da.", and finally you just type ; alone. Then the script erases what you typed and replaces it with pretty Toaq. Unfortunately it has two pretty inconvenient issues, one of which is that it currently can't show an icon in the system tray to indicate whether the script is in "listening mode" or not (which means you can accidentally put it in listening mode and leave it there for a while) and the other of which is that if you have non-text data on your system clipboard at the time you try to use the script, it will simply crash. User:Hoaqgio recommends not using this unless you really have no better alternative!

Phones

MultiLing O

There's a decently customizable Android custom keyboard app called MultiLing O, which comes with a selection of diacritics out of the box (bar old falling tone). To use them, first type the desired letter, then hold-tap the key that says ,/AltGr. An alternate screen should appear; without lifting your finger, slide it to the desired choice of diacritic. However, this won’t get you typing full-featured Toaq Delta right away – luckily for us, Multiling supports custom layouts. To install these:

  1. Choose a layout you like, hold-tap and then drag to make a selection starting from OK_Layout_Begin and ending on OK_Layout_End, then click Copy.
  2. With the Multiling keyboard open: hold the spacebar, then drag your finger over to a button named Layouts in the top right that should just have appeared. (Optionally: first slide to Languages > Other > X language 1. This disables word prediction and lets you switch between English and Toaq by swiping the spacebar leftward.)
  3. Select [+DIY] from the pop-up list, then Paste, then OK.

The following layouts are available:

Mıao's layout

Screenshot of Mıao's layout

Your standard QWERTY layout with flick access to prearranged underdot + rising tone glottal tone hiatus tone combos.

MultiLing O layout definition file
OK_Layout_Begin
Name:Tóaqdeota
1234567890
q[XK:ꝡw][4D:e[U+0308]éëêẹ[MC:ẹ́][MC:ẹ̈][MC:ệ]]rty[4D:u[U+0302]úüûụ[MC:ụ́][MC:ụ̈][MC:ụ̂]][4D:ıiíïî[MC:ı̣][MC:ị́][MC:ị̈][MC:ị̂]][4D:o[U+0323]óöôọ[MC:ọ́][MC:ọ̈][MC:ộ]]p
[4D:a[U+0301]áäâạ[MC:ạ́][MC:ạ̈][MC:ậ]]sdfghjkl
zxcvbnm
!@#$%^&*()
Q[XK:ꝠW][4D:E[U+0308]ÉËÊẸ[MC:Ẹ́][MC:Ẹ̈][MC:Ệ]]RTY[4D:U[U+0302]ÚÜÛỤ[MC:Ụ́][MC:Ụ̈][MC:Ụ̂]][4D:IİÍÏÎ[MC:Ị́][MC:Ị̈][MC:Ị̂]][4D:O[U+0323]ÓÖÔỌ[MC:Ọ́][MC:Ọ̈][MC:Ộ]]P
[4D:A[U+0301]ÁÄÂẠ[MC:Ạ́][MC:Ạ̈][MC:Ậ]]SDFGHJKL
ZXCVBNM
£¥€$₹^&*()№√÷
~`{}%_-=|+§∷‡
@[]#/\'"«»—‐–
…<>!;:?‹›±.,
ˉˋˇ´¨˙˚¸﹐˛˘˜ˆ
―∑éə®†Ωœøπ•·¡
æß∂ðƒ©ªº∆≠℥∞¿
ʒΩ≈çþ∫ŋµ≤≥°
OK_Layout_End

uakci's mobile-optimized layout

Screenshot of uakci's layout

The third-or-so iteration of this layout (this time updated for Toaq Delta and adorned with cool symbols to boot). Fewer keys means less fat finger fumbling. Some keys are moved out of the way or (in the case of v, w, y) folded into the ꝡ key; the underdot key stands alone on the right edge of the middle row.

MultiLing O layout definition file
OK_Layout_Begin
Name:uakci’s mobile-optimized layout

q[XK:ꝡvwy][4D:e éëê]rt[4D:uüú û][4D:ıïíiî][4D:oöó ô]p
[4D:a áäâ]sdhjklṃ
zxcfgbn

Q[XK:ꝠVWY][4D:E ÉËÊ]RT[4D:UÜÚ Û][4D:IÏÍIÎ][4D:OÖ ÓÔ]P
[4D:A ÁÄÂ]SDHJKLṂ
ZXCFGBN

‹  —–   ›    
 «⟪⟨-⟩⟫»·
!.,…?:;
OK_Layout_End

Other options

In general, on many phone keyboards you can long-press a vowel to get some accents, though you still won't find .

Deranı layouts

Mıao's layout (QWERTY-based)

Toaq (QWERTY).svg

Some punctuation whose keys were taken over have been put under AltGr.

XKB (Linux)

XKB symbols file
default  partial alphanumeric_keys modifier_keys
xkb_symbols "derani" {

    name[Group1]= "Toaqzu (Deranı)";

    key <TLDE> { [ grave, asciitilde ] };
    key <AE01> { [ 1, exclam  ] };
    key <AE02> { [ 2, at ] };
    key <AE03> { [ 3, numbersign ] };
    key <AE04> { [ 4, dollar  ] };
    key <AE05> { [ 5, percent  ] };
    key <AE06> { [ 6, asciicircum ] };
    key <AE07> { [ 7, ampersand ] };
    key <AE08> { [ 8, asterisk ] };
    key <AE09> { [ 9, parenleft ] };
    key <AE10> { [ 0, parenright ] };
    key <AE11> { [ minus, underscore, endash, emdash ] };
    key <AE12> { [ equal, plus ] };

    key <AD01> { [ UEDC2 ] }; // Q
    key <AD02> { [ UEDC1 ] }; // Ꝡ
    key <AD03> { [ UEDD0 ] }; // 2nd tone
    key <AD04> { [ UEDBB ] }; // R
    key <AD05> { [ UEDB7 ] }; // T
    key <AD06> { [ UEDD4 ] }; // diphthong
    key <AD07> { [ UEDD1 ] }; // 3rd tone
    key <AD08> { [ UEDBD ] }; // NH
    key <AD09> { [ UEDD2 ] }; // 4th tone
    key <AD10> { [ UEDB3 ] }; // P
    key <AD11> { [ guillemotleft, U2039, bracketleft, braceleft ] };
    key <AD12> { [ guillemotright, U203A, bracketright, braceright ] };

    key <AC01> { [ UEDC5 ] }; // '
    key <AC02> { [ UEDBA ] }; // S
    key <AC03> { [ UEDB6 ] }; // D
    key <AC04> { [ UEDB4 ] }; // F
    key <AC05> { [ UEDC3 ] }; // G
    key <AC06> { [ UEDC6 ] }; // H
    key <AC07> { [ UEDBE ] }; // J
    key <AC08> { [ UEDC4 ] }; // K
    key <AC09> { [ UEDBC ] }; // L
    key <AC10> { [ UEDE6, UEDD3, semicolon, colon ] }; // cartouche start | hiatus mark
    key <AC11> { [ UEDE7, UEDE8, apostrophe, quotedbl ] }; // cartouche end | null variable

    key <AB01> { [ UEDB8 ] }; // Z
    key <AB02> { [ UEDC0 ] }; // SH
    key <AB03> { [ UEDB9 ] }; // C
    key <AB04> { [ UEDBF ] }; // CH
    key <AB05> { [ UEDB2 ] }; // B
    key <AB06> { [ UEDB5 ] }; // N
    key <AB07> { [ UEDB0, UEDB1 ] }; // M | M coda
    key <AB08> { [ UEDE2, UEDE0, comma, less ] }; // subordination mark | prefix mark
    key <AB09> { [ UEDE3, UEDE1, period, greater ] }; // declarative full stop | quotation mark
    key <AB10> { [ UEDE4, UEDE5, slash, question ] }; // other full stop | question mark

    key <BKSL> { [ backslash, bar] };
    
    key <SPCE> { [ space, space, nobreakspace,  nobreakspace ] };
    
   include "level3(ralt_switch)"
};

Windows

Made with Microsoft Keyboard Layout Creator. Unzip the .zip file and open setup.exe. You may have to restart your computer for it to show up. To uninstall, uninstall it like you would any other program.

Loekıa's layout (Workman-based)

Toaq (Workman).svg

XKB symbols file
xkb_symbols "toaq"
{
  include "us(workman)"

  key <AD01> { [ UEDBD ] };
  key <AD02> { [ UEDB6 ] };
  key <AD03> { [ UEDBB ] };
  key <AD04> { [ UEDD3 ] };
  key <AD05> { [ UEDD4 ] };
  key <AD06> { [ UEDBE ] };
  key <AD07> { [ UEDB5 ] };
  key <AD08> { [ UEDB2 ] };
  key <AD09> { [ UEDB3 ] };
  key <AD10> { [ UEDE6, UEDE7 ] };

  key <AC01> { [ UEDBA ] };
  key <AC02> { [ UEDC0 ] };
  key <AC03> { [ UEDC6 ] };
  key <AC04> { [ UEDB7 ] };
  key <AC05> { [ UEDD0 ] };
  key <AC06> { [ UEDD1, UEDD2 ] };
  key <AC07> { [ UEDC2 ] };
  key <AC08> { [ UEDB4 ] };
  key <AC09> { [ UEDC3 ] };
  key <AC10> { [ UEDB9 ] };
  key <AC11> { [ UEDE0, UEDE1 ] };

  key <AB01> { [ UEDB8 ] };
  key <AB02> { [ UEDC5 ] };
  key <AB03> { [ UEDB0, UEDB1 ] };
  key <AB04> { [ UEDBF ] };
  key <AB05> { [ UEDC1 ] };
  key <AB06> { [ UEDC4 ] };
  key <AB07> { [ UEDBC ] };
  key <AB08> { [ UEDE2, UEDE8 ] };
  key <AB09> { [ UEDE3 ] };
  key <AB10> { [ UEDE4, UEDE5 ] };
};

Sad alternatives

ASCII tone markers

You can always write the ASCII-friendly (although reader-hostile) /"^ tone markers after words like this, usefully combined with sparse tone marking:

Hio ka. Bu va" bo ji/ sa gi kaichuo rao^ ni/.

Or tone number digits 234:

Hio ka. Bu va3 bo ji2 sa gi kaichuo rao4 ni2.

And you will be understood.

Vietoaq

For a bit, a Vietnamese Telex equivalent called Vietoaq was popular, where the idea was to use consonants at the end of a syllable to represent tone.

For example, lé lë lẻ lê lè lẽ is written lep lex len let lek lef.

To make matters worse, léq lëq lẻq lêq lèq lẽq is written, by diehard Vietoaq oldbies, as leb lez lem led leg lev.

This was back when compound words used flat tone, and lē lēq were written ler lel. So, tóaqkūq became toabkul.

Eventually came Diet Vietoaq, which just puts one of pxntkf, marking the tone for the whole word, at the end of the word: tóaqkūq becomes toaqkuqp. In that sense, it is more like the "ASCII tone markers" in the previous section.

Refrain from using Vietoaq in any setting at all. If you must, please use #Kaıchuo to convert it to a reader-friendly form.