Utility for managing X11 compose key sequences
Project description
xcompose
A simple utility to help configure X11 compose key sequences.
The repo also hosts an extensive .XCompose file with over 10 000 new sequences; more details here.
Installation
$ pip install xcompose
Requirements
Currently assumes that the system compose key configurations are in /usr/share/X11/locale/, while the keysym definitions are in /usr/include/X11/keysymdef.h.
Only tested on Ubuntu 24, but should work more widely (though still very much beta quality).
Usage
$ xcompose -h
usage: xcompose [-h] [-f FILE | -S] [-i] [-k KEY] [-s SORT] {add,find,get,validate} ...
Xcompose sequence helper utility.
positional arguments:
{add,find,get,validate}
add print a new compose sequence
find find sequences matching given output
get get sequences matching given key inputs
validate validate compose config file
options:
-h, --help show this help message and exit
-f FILE, --file FILE config file to analyze (instead of user config)
-S, --system analyze system config (instead of user config)
-i, --ignore-include don't follow any include declarations in the config
-k KEY, --key KEY modifier key keysym (default is Multi_key; use ANY for all)
-s SORT, --sort SORT sort resulting sequences (options: 'keys', 'value')
Examples
$ xcompose find é
<Multi_key> <acute> <e> : "é" eacute # LATIN SMALL LETTER E WITH ACUTE
<Multi_key> <e> <acute> : "é" eacute # LATIN SMALL LETTER E WITH ACUTE
<Multi_key> <apostrophe> <e> : "é" eacute # LATIN SMALL LETTER E WITH ACUTE
<Multi_key> <e> <apostrophe> : "é" eacute # LATIN SMALL LETTER E WITH ACUTE
$ xcompose find pound
<Multi_key> <L> <minus> : "£" sterling # POUND SIGN
<Multi_key> <minus> <L> : "£" sterling # POUND SIGN
<Multi_key> <l> <minus> : "£" sterling # POUND SIGN
<Multi_key> <minus> <l> : "£" sterling # POUND SIGN
$ xcompose find U+00B5
<Multi_key> <m> <u> : "µ" mu # MICRO SIGN
<Multi_key> <slash> <u> : "µ" mu # MICRO SIGN
<Multi_key> <u> <slash> : "µ" mu # MICRO SIGN
$ xcompose get / =
<Multi_key> <slash> <equal> : "≠" U2260 # NOT EQUAL TO
$ xcompose --sort keys get /
<Multi_key> <slash> <minus> : "⌿" U233f # / - APL FUNCTIONAL SYMBOL SLASH BAR
<Multi_key> <slash> <slash> : "\\" backslash # REVERSE SOLIDUS
<Multi_key> <slash> <less> : "\\" backslash # REVERSE SOLIDUS
<Multi_key> <slash> <equal> : "≠" U2260 # NOT EQUAL TO
<Multi_key> <slash> <B> : "Ƀ" U0243 # LATIN CAPITAL LETTER B WITH STROKE
<Multi_key> <slash> <C> : "₡" U20a1 # COLON SIGN
<Multi_key> <slash> <D> : "Đ" Dstroke # LATIN CAPITAL LETTER D WITH STROKE
⋮
<Multi_key> <slash> <U2194> : "↮" U21AE # LEFT RIGHT ARROW WITH STROKE
<Multi_key> <slash> <U2395> : "⍁" U2341 # / ⎕ APL FUNCTIONAL SYMBOL QUAD SLASH
$ xcompose add ɕ c @
<Multi_key> <c> <at> : "ɕ" U0255 # LATIN SMALL LETTER C WITH CURL
$ xcompose add ć c /
<Multi_key> <c> <slash> : "ć" U0107 # LATIN SMALL LETTER C WITH ACUTE (conflicts with ¢)
$ echo '<Multi_key> <c> <comma> <quote> : "ḉ"' >> ~/.XCompose # add a line to .XCompose
$ xcompose validate
[/home/Udzu/.XCompose#116] Unrecognised keysym: quote
[/home/Udzu/.XCompose#116] Missing keysym: expected U1E09
[/home/Udzu/.XCompose#116] Missing comment: expected LATIN SMALL LETTER C WITH CEDILLA AND ACUTE
[/home/Udzu/.XCompose#116] Compose sequence Multi_key + c + comma + quote for 'ḉ' conflicts with
[/usr/share/X11/locale/en_US.UTF-8/Compose#428] Multi_key + c + comma for 'ç'
to ignore this, include the string 'conflict' or 'override' in the comment
$ xcompose -S validate # system config isn't validated by default (only parsed for conflicts)
[/usr/share/X11/locale/en_US.UTF-8/Compose#73] Incorrect comment: LESS-THAN, expected LESS-THAN SIGN
[/usr/share/X11/locale/en_US.UTF-8/Compose#74] Incorrect comment: LESS-THAN, expected LESS-THAN SIGN
[/usr/share/X11/locale/en_US.UTF-8/Compose#75] Incorrect comment: GREATER-THAN, expected GREATER-THAN SIGN
[/usr/share/X11/locale/en_US.UTF-8/Compose#76] Incorrect comment: GREATER-THAN, expected GREATER-THAN SIGN
[/usr/share/X11/locale/en_US.UTF-8/Compose#121] Incorrect keysym: guillemotleft, expected guillemetleft (or U00AB)
[/usr/share/X11/locale/en_US.UTF-8/Compose#122] Incorrect keysym: guillemotright, expected guillemetright (or U00BB)
[/usr/share/X11/locale/en_US.UTF-8/Compose#198] Incorrect comment: ROUBLE SIGN, expected RUBLE SIGN
⋮
[/usr/share/X11/locale/en_US.UTF-8/Compose#253] Incorrect keysym: masculine, expected ordmasculine (or U00BA)
[/usr/share/X11/locale/en_US.UTF-8/Compose#4985] Incorrect comment: ○ \ APL FUNCTIONAL SYMBOL CIRCLE SLOPE, expected APL FUNCTIONAL SYMBOL CIRCLE BACKSLASH
[/usr/share/X11/locale/en_US.UTF-8/Compose#4986] Incorrect comment: \ ○ APL FUNCTIONAL SYMBOL CIRCLE SLOPE, expected APL FUNCTIONAL SYMBOL CIRCLE BACKSLASH
Project details
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file xcompose-0.3.0.tar.gz.
File metadata
- Download URL: xcompose-0.3.0.tar.gz
- Upload date:
- Size: 186.7 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.12.9
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
d2e0a8f5b4206710ea4069ba26387ae7fd7664413528ba99062c3bdb826e5bd2
|
|
| MD5 |
d69e97a933ae058affc255efa08c5689
|
|
| BLAKE2b-256 |
c8fa4fc3aff530bbc8558e6dc1e87f9505d41ca2c31a306f0d2e95d1ae3e070c
|
Provenance
The following attestation bundles were made for xcompose-0.3.0.tar.gz:
Publisher:
deploy.yaml on Udzu/xcompose
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
xcompose-0.3.0.tar.gz -
Subject digest:
d2e0a8f5b4206710ea4069ba26387ae7fd7664413528ba99062c3bdb826e5bd2 - Sigstore transparency entry: 219862254
- Sigstore integration time:
-
Permalink:
Udzu/xcompose@9463ca7bb6032e533cfa4266c727a25bde5e282e -
Branch / Tag:
refs/tags/v0.3.0 - Owner: https://github.com/Udzu
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
deploy.yaml@9463ca7bb6032e533cfa4266c727a25bde5e282e -
Trigger Event:
push
-
Statement type:
File details
Details for the file xcompose-0.3.0-py3-none-any.whl.
File metadata
- Download URL: xcompose-0.3.0-py3-none-any.whl
- Upload date:
- Size: 8.2 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.12.9
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
e12ce6a97530749d8295d401aba89819084217f71808922f2152fcd082178397
|
|
| MD5 |
1adcbbb946f83ddd2339df99621e6f5a
|
|
| BLAKE2b-256 |
d00e83ce7b20dd54edf6980542a7da5175a233c3a6524944352e9efc750d9fdd
|
Provenance
The following attestation bundles were made for xcompose-0.3.0-py3-none-any.whl:
Publisher:
deploy.yaml on Udzu/xcompose
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
xcompose-0.3.0-py3-none-any.whl -
Subject digest:
e12ce6a97530749d8295d401aba89819084217f71808922f2152fcd082178397 - Sigstore transparency entry: 219862255
- Sigstore integration time:
-
Permalink:
Udzu/xcompose@9463ca7bb6032e533cfa4266c727a25bde5e282e -
Branch / Tag:
refs/tags/v0.3.0 - Owner: https://github.com/Udzu
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
deploy.yaml@9463ca7bb6032e533cfa4266c727a25bde5e282e -
Trigger Event:
push
-
Statement type: