forked from BlueM/cliclick
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathgenerate-characterinfo.php
executable file
·40 lines (30 loc) · 2.35 KB
/
generate-characterinfo.php
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
#!/usr/bin/env php
<?php
$filename = 'KeycodeInformer.m';
$code = file_get_contents(__DIR__ . "/$filename");
$layouts = [];
preg_match_all('=#SUPPORTED ([^:]+?):(.*)\n=', $code, $matches, PREG_SET_ORDER);
foreach ($matches as $langMatches) {
list(, $layoutName, $characters) = $langMatches;
$layouts[$layoutName] = array(trim($characters));
}
preg_match_all('=#KNOWN_UNSUPPORTED ([^:]+?):(.*)\n=', $code, $matches, PREG_SET_ORDER);
foreach ($matches as $langMatches) {
list(, $layoutName, $characters) = $langMatches;
$layouts[$layoutName][] = trim($characters) ? trim($characters) . ' (incomplete list)' : '[nothing]';
}
ksort($layouts);
echo <<<INFO
Cliclick can emulate typing any character that can be typed on physical keyboard by hitting a regular key alone or combined with Shift and/or Alt, regardless of the keyboard layout.
In addition, in most keyboards layouts, there are characters which can be entered by typing two characters consecutively, typically with the first one being a so-called “dead” key or “combining character”. For instance, on a German keyboard, there is no key for typing “é”, but you can enter it by first typing a “combining acute accent” (Unicode U+0301) followed by “e”. Below you will find an overview of some keyboard layouts (or rather their English names) and lists of the characters which cliclick is able to type, as well as (very incomplete) lists of the characters which are known to be untypeable for
cliclick. If you find that cliclick cannot type a character you need, you might be interested in either adding code to support the keyboard layout (if cliclick does not know the layout at all) or in adding code on how to type the character using the current keyboard layout. The place to make these additions is method `getReplacementMapForKeyboardLayoutNamed:` in `$filename`. The code in that method is pretty simple and you do not need to know much Objective-C to add more characters. This method is also the place from which data is read to auto-generate this file, so _do not edit it manually_.
Having said that, here is the list of keyboard layouts with the supported and (some) unsupported characters:
INFO;
foreach ($layouts as $layoutName => $info) {
printf(
"%s\n * Supported: %s\n * Unsupported: %s\n\n",
str_replace('_', ' ', $layoutName),
$info[0],
$info[1]
);
}