chore(macos): vendor system-sdk dependency
This commit is contained in:
98
libs/system-sdk/linux/include/xkbcommon/xkbcommon-compat.h
Normal file
98
libs/system-sdk/linux/include/xkbcommon/xkbcommon-compat.h
Normal file
@@ -0,0 +1,98 @@
|
||||
/*
|
||||
* Copyright © 2012 Daniel Stone
|
||||
*
|
||||
* Permission is hereby granted, free of charge, to any person obtaining a
|
||||
* copy of this software and associated documentation files (the "Software"),
|
||||
* to deal in the Software without restriction, including without limitation
|
||||
* the rights to use, copy, modify, merge, publish, distribute, sublicense,
|
||||
* and/or sell copies of the Software, and to permit persons to whom the
|
||||
* Software is furnished to do so, subject to the following conditions:
|
||||
*
|
||||
* The above copyright notice and this permission notice (including the next
|
||||
* paragraph) shall be included in all copies or substantial portions of the
|
||||
* Software.
|
||||
*
|
||||
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||||
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
||||
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
|
||||
* THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
||||
* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
|
||||
* FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
|
||||
* DEALINGS IN THE SOFTWARE.
|
||||
*
|
||||
* Author: Daniel Stone <daniel@fooishbar.org>
|
||||
*/
|
||||
|
||||
#ifndef _XKBCOMMON_COMPAT_H
|
||||
#define _XKBCOMMON_COMPAT_H
|
||||
|
||||
/**
|
||||
* Renamed keymap API.
|
||||
*/
|
||||
#define xkb_group_index_t xkb_layout_index_t
|
||||
#define xkb_group_mask_t xkb_layout_mask_t
|
||||
#define xkb_map_compile_flags xkb_keymap_compile_flags
|
||||
#define XKB_GROUP_INVALID XKB_LAYOUT_INVALID
|
||||
|
||||
#define XKB_STATE_DEPRESSED \
|
||||
(XKB_STATE_MODS_DEPRESSED | XKB_STATE_LAYOUT_DEPRESSED)
|
||||
#define XKB_STATE_LATCHED \
|
||||
(XKB_STATE_MODS_LATCHED | XKB_STATE_LAYOUT_LATCHED)
|
||||
#define XKB_STATE_LOCKED \
|
||||
(XKB_STATE_MODS_LOCKED | XKB_STATE_LAYOUT_LOCKED)
|
||||
#define XKB_STATE_EFFECTIVE \
|
||||
(XKB_STATE_DEPRESSED | XKB_STATE_LATCHED | XKB_STATE_LOCKED | \
|
||||
XKB_STATE_MODS_EFFECTIVE | XKB_STATE_LAYOUT_EFFECTIVE)
|
||||
|
||||
#define xkb_map_new_from_names(context, names, flags) \
|
||||
xkb_keymap_new_from_names(context, names, flags)
|
||||
#define xkb_map_new_from_file(context, file, format, flags) \
|
||||
xkb_keymap_new_from_file(context, file, format, flags)
|
||||
#define xkb_map_new_from_string(context, string, format, flags) \
|
||||
xkb_keymap_new_from_string(context, string, format, flags)
|
||||
#define xkb_map_get_as_string(keymap) \
|
||||
xkb_keymap_get_as_string(keymap, XKB_KEYMAP_FORMAT_TEXT_V1)
|
||||
#define xkb_map_ref(keymap) xkb_keymap_ref(keymap)
|
||||
#define xkb_map_unref(keymap) xkb_keymap_unref(keymap)
|
||||
|
||||
#define xkb_map_num_mods(keymap) xkb_keymap_num_mods(keymap)
|
||||
#define xkb_map_mod_get_name(keymap, idx) xkb_keymap_mod_get_name(keymap, idx)
|
||||
#define xkb_map_mod_get_index(keymap, str) xkb_keymap_mod_get_index(keymap, str)
|
||||
#define xkb_key_mod_index_is_consumed(state, key, mod) \
|
||||
xkb_state_mod_index_is_consumed(state, key, mod)
|
||||
#define xkb_key_mod_mask_remove_consumed(state, key, modmask) \
|
||||
xkb_state_mod_mask_remove_consumed(state, key, modmask)
|
||||
|
||||
#define xkb_map_num_groups(keymap) xkb_keymap_num_layouts(keymap)
|
||||
#define xkb_key_num_groups(keymap, key) \
|
||||
xkb_keymap_num_layouts_for_key(keymap, key)
|
||||
#define xkb_map_group_get_name(keymap, idx) \
|
||||
xkb_keymap_layout_get_name(keymap, idx)
|
||||
#define xkb_map_group_get_index(keymap, str) \
|
||||
xkb_keymap_layout_get_index(keymap, str)
|
||||
|
||||
#define xkb_map_num_leds(keymap) xkb_keymap_num_leds(keymap)
|
||||
#define xkb_map_led_get_name(keymap, idx) xkb_keymap_led_get_name(keymap, idx)
|
||||
#define xkb_map_led_get_index(keymap, str) \
|
||||
xkb_keymap_led_get_index(keymap, str)
|
||||
|
||||
#define xkb_key_repeats(keymap, key) xkb_keymap_key_repeats(keymap, key)
|
||||
|
||||
#define xkb_key_get_syms(state, key, syms_out) \
|
||||
xkb_state_key_get_syms(state, key, syms_out)
|
||||
|
||||
#define xkb_state_group_name_is_active(state, name, type) \
|
||||
xkb_state_layout_name_is_active(state, name, type)
|
||||
#define xkb_state_group_index_is_active(state, idx, type) \
|
||||
xkb_state_layout_index_is_active(state, idx, type)
|
||||
|
||||
#define xkb_state_serialize_group(state, component) \
|
||||
xkb_state_serialize_layout(state, component)
|
||||
|
||||
#define xkb_state_get_map(state) xkb_state_get_keymap(state)
|
||||
|
||||
/* Not needed anymore, since there's NO_FLAGS. */
|
||||
#define XKB_MAP_COMPILE_PLACEHOLDER XKB_KEYMAP_COMPILE_NO_FLAGS
|
||||
#define XKB_MAP_COMPILE_NO_FLAGS XKB_KEYMAP_COMPILE_NO_FLAGS
|
||||
|
||||
#endif
|
||||
637
libs/system-sdk/linux/include/xkbcommon/xkbcommon-compose.h
Normal file
637
libs/system-sdk/linux/include/xkbcommon/xkbcommon-compose.h
Normal file
@@ -0,0 +1,637 @@
|
||||
/*
|
||||
* Copyright © 2013 Ran Benita
|
||||
*
|
||||
* Permission is hereby granted, free of charge, to any person obtaining a
|
||||
* copy of this software and associated documentation files (the "Software"),
|
||||
* to deal in the Software without restriction, including without limitation
|
||||
* the rights to use, copy, modify, merge, publish, distribute, sublicense,
|
||||
* and/or sell copies of the Software, and to permit persons to whom the
|
||||
* Software is furnished to do so, subject to the following conditions:
|
||||
*
|
||||
* The above copyright notice and this permission notice (including the next
|
||||
* paragraph) shall be included in all copies or substantial portions of the
|
||||
* Software.
|
||||
*
|
||||
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||||
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
||||
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
|
||||
* THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
||||
* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
|
||||
* FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
|
||||
* DEALINGS IN THE SOFTWARE.
|
||||
*/
|
||||
|
||||
#ifndef _XKBCOMMON_COMPOSE_H
|
||||
#define _XKBCOMMON_COMPOSE_H
|
||||
|
||||
#include <xkbcommon/xkbcommon.h>
|
||||
|
||||
#ifdef __cplusplus
|
||||
extern "C" {
|
||||
#endif
|
||||
|
||||
/**
|
||||
* @file
|
||||
* libxkbcommon Compose API - support for Compose and dead-keys.
|
||||
*/
|
||||
|
||||
/**
|
||||
* @defgroup compose Compose and dead-keys support
|
||||
* Support for Compose and dead-keys.
|
||||
* @since 0.5.0
|
||||
*
|
||||
* @{
|
||||
*/
|
||||
|
||||
/**
|
||||
* @page compose-overview Overview
|
||||
* @parblock
|
||||
*
|
||||
* Compose and dead-keys are a common feature of many keyboard input
|
||||
* systems. They extend the range of the keysysm that can be produced
|
||||
* directly from a keyboard by using a sequence of key strokes, instead
|
||||
* of just one.
|
||||
*
|
||||
* Here are some example sequences, in the libX11 Compose file format:
|
||||
*
|
||||
* <dead_acute> <a> : "á" aacute # LATIN SMALL LETTER A WITH ACUTE
|
||||
* <Multi_key> <A> <T> : "@" at # COMMERCIAL AT
|
||||
*
|
||||
* When the user presses a key which produces the `<dead_acute>` keysym,
|
||||
* nothing initially happens (thus the key is dubbed a "dead-key"). But
|
||||
* when the user enters `<a>`, "á" is "composed", in place of "a". If
|
||||
* instead the user had entered a keysym which does not follow
|
||||
* `<dead_acute>` in any compose sequence, the sequence is said to be
|
||||
* "cancelled".
|
||||
*
|
||||
* Compose files define many such sequences. For a description of the
|
||||
* common file format for Compose files, see the Compose(5) man page.
|
||||
*
|
||||
* A successfuly-composed sequence has two results: a keysym and a UTF-8
|
||||
* string. At least one of the two is defined for each sequence. If only
|
||||
* a keysym is given, the keysym's string representation is used for the
|
||||
* result string (using xkb_keysym_to_utf8()).
|
||||
*
|
||||
* This library provides low-level support for Compose file parsing and
|
||||
* processing. Higher-level APIs (such as libX11's `Xutf8LookupString`(3))
|
||||
* may be built upon it, or it can be used directly.
|
||||
*
|
||||
* @endparblock
|
||||
*/
|
||||
|
||||
/**
|
||||
* @page compose-conflicting Conflicting Sequences
|
||||
* @parblock
|
||||
*
|
||||
* To avoid ambiguity, a sequence is not allowed to be a prefix of another.
|
||||
* In such a case, the conflict is resolved thus:
|
||||
*
|
||||
* 1. A longer sequence overrides a shorter one.
|
||||
* 2. An equal sequence overrides an existing one.
|
||||
* 3. A shorter sequence does not override a longer one.
|
||||
*
|
||||
* Sequences of length 1 are allowed.
|
||||
*
|
||||
* @endparblock
|
||||
*/
|
||||
|
||||
/**
|
||||
* @page compose-cancellation Cancellation Behavior
|
||||
* @parblock
|
||||
*
|
||||
* What should happen when a sequence is cancelled? For example, consider
|
||||
* there are only the above sequences, and the input keysyms are
|
||||
* `<dead_acute> <b>`. There are a few approaches:
|
||||
*
|
||||
* 1. Swallow the cancelling keysym; that is, no keysym is produced.
|
||||
* This is the approach taken by libX11.
|
||||
* 2. Let the cancelling keysym through; that is, `<b>` is produced.
|
||||
* 3. Replay the entire sequence; that is, `<dead_acute> <b>` is produced.
|
||||
* This is the approach taken by Microsoft Windows (approximately;
|
||||
* instead of `<dead_acute>`, the underlying key is used. This is
|
||||
* difficult to simulate with XKB keymaps).
|
||||
*
|
||||
* You can program whichever approach best fits users' expectations.
|
||||
*
|
||||
* @endparblock
|
||||
*/
|
||||
|
||||
/**
|
||||
* @struct xkb_compose_table
|
||||
* Opaque Compose table object.
|
||||
*
|
||||
* The compose table holds the definitions of the Compose sequences, as
|
||||
* gathered from Compose files. It is immutable.
|
||||
*/
|
||||
struct xkb_compose_table;
|
||||
|
||||
/**
|
||||
* @struct xkb_compose_state
|
||||
* Opaque Compose state object.
|
||||
*
|
||||
* The compose state maintains state for compose sequence matching, such
|
||||
* as which possible sequences are being matched, and the position within
|
||||
* these sequences. It acts as a simple state machine wherein keysyms are
|
||||
* the input, and composed keysyms and strings are the output.
|
||||
*
|
||||
* The compose state is usually associated with a keyboard device.
|
||||
*/
|
||||
struct xkb_compose_state;
|
||||
|
||||
/** Flags affecting Compose file compilation. */
|
||||
enum xkb_compose_compile_flags {
|
||||
/** Do not apply any flags. */
|
||||
XKB_COMPOSE_COMPILE_NO_FLAGS = 0
|
||||
};
|
||||
|
||||
/** The recognized Compose file formats. */
|
||||
enum xkb_compose_format {
|
||||
/** The classic libX11 Compose text format, described in Compose(5). */
|
||||
XKB_COMPOSE_FORMAT_TEXT_V1 = 1
|
||||
};
|
||||
|
||||
/**
|
||||
* @page compose-locale Compose Locale
|
||||
* @parblock
|
||||
*
|
||||
* Compose files are locale dependent:
|
||||
* - Compose files are written for a locale, and the locale is used when
|
||||
* searching for the appropriate file to use.
|
||||
* - Compose files may reference the locale internally, with directives
|
||||
* such as \%L.
|
||||
*
|
||||
* As such, functions like xkb_compose_table_new_from_locale() require
|
||||
* a `locale` parameter. This will usually be the current locale (see
|
||||
* locale(7) for more details). You may also want to allow the user to
|
||||
* explicitly configure it, so he can use the Compose file of a given
|
||||
* locale, but not use that locale for other things.
|
||||
*
|
||||
* You may query the current locale as follows:
|
||||
* @code
|
||||
* const char *locale;
|
||||
* locale = setlocale(LC_CTYPE, NULL);
|
||||
* @endcode
|
||||
*
|
||||
* This will only give useful results if the program had previously set
|
||||
* the current locale using setlocale(3), with `LC_CTYPE` or `LC_ALL`
|
||||
* and a non-NULL argument.
|
||||
*
|
||||
* If you prefer not to use the locale system of the C runtime library,
|
||||
* you may nevertheless obtain the user's locale directly using
|
||||
* environment variables, as described in locale(7). For example,
|
||||
* @code
|
||||
* const char *locale;
|
||||
* locale = getenv("LC_ALL");
|
||||
* if (!locale || !*locale)
|
||||
* locale = getenv("LC_CTYPE");
|
||||
* if (!locale || !*locale)
|
||||
* locale = getenv("LANG");
|
||||
* if (!locale || !*locale)
|
||||
* locale = "C";
|
||||
* @endcode
|
||||
*
|
||||
* Note that some locales supported by the C standard library may not
|
||||
* have a Compose file assigned.
|
||||
*
|
||||
* @endparblock
|
||||
*/
|
||||
|
||||
/**
|
||||
* Create a compose table for a given locale.
|
||||
*
|
||||
* The locale is used for searching the file-system for an appropriate
|
||||
* Compose file. The search order is described in Compose(5). It is
|
||||
* affected by the following environment variables:
|
||||
*
|
||||
* 1. `XCOMPOSEFILE` - see Compose(5).
|
||||
* 2. `XDG_CONFIG_HOME` - before `$HOME/.XCompose` is checked,
|
||||
* `$XDG_CONFIG_HOME/XCompose` is checked (with a fall back to
|
||||
* `$HOME/.config/XCompose` if `XDG_CONFIG_HOME` is not defined).
|
||||
* This is a libxkbcommon extension to the search procedure in
|
||||
* Compose(5) (since libxkbcommon 1.0.0). Note that other
|
||||
* implementations, such as libX11, might not find a Compose file in
|
||||
* this path.
|
||||
* 3. `HOME` - see Compose(5).
|
||||
* 4. `XLOCALEDIR` - if set, used as the base directory for the system's
|
||||
* X locale files, e.g. `/usr/share/X11/locale`, instead of the
|
||||
* preconfigured directory.
|
||||
*
|
||||
* @param context
|
||||
* The library context in which to create the compose table.
|
||||
* @param locale
|
||||
* The current locale. See @ref compose-locale.
|
||||
* \n
|
||||
* The value is copied, so it is safe to pass the result of getenv(3)
|
||||
* (or similar) without fear of it being invalidated by a subsequent
|
||||
* setenv(3) (or similar).
|
||||
* @param flags
|
||||
* Optional flags for the compose table, or 0.
|
||||
*
|
||||
* @returns A compose table for the given locale, or NULL if the
|
||||
* compilation failed or a Compose file was not found.
|
||||
*
|
||||
* @memberof xkb_compose_table
|
||||
*/
|
||||
struct xkb_compose_table *
|
||||
xkb_compose_table_new_from_locale(struct xkb_context *context,
|
||||
const char *locale,
|
||||
enum xkb_compose_compile_flags flags);
|
||||
|
||||
/**
|
||||
* Create a new compose table from a Compose file.
|
||||
*
|
||||
* @param context
|
||||
* The library context in which to create the compose table.
|
||||
* @param file
|
||||
* The Compose file to compile.
|
||||
* @param locale
|
||||
* The current locale. See @ref compose-locale.
|
||||
* @param format
|
||||
* The text format of the Compose file to compile.
|
||||
* @param flags
|
||||
* Optional flags for the compose table, or 0.
|
||||
*
|
||||
* @returns A compose table compiled from the given file, or NULL if
|
||||
* the compilation failed.
|
||||
*
|
||||
* @memberof xkb_compose_table
|
||||
*/
|
||||
struct xkb_compose_table *
|
||||
xkb_compose_table_new_from_file(struct xkb_context *context,
|
||||
FILE *file,
|
||||
const char *locale,
|
||||
enum xkb_compose_format format,
|
||||
enum xkb_compose_compile_flags flags);
|
||||
|
||||
/**
|
||||
* Create a new compose table from a memory buffer.
|
||||
*
|
||||
* This is just like xkb_compose_table_new_from_file(), but instead of
|
||||
* a file, gets the table as one enormous string.
|
||||
*
|
||||
* @see xkb_compose_table_new_from_file()
|
||||
* @memberof xkb_compose_table
|
||||
*/
|
||||
struct xkb_compose_table *
|
||||
xkb_compose_table_new_from_buffer(struct xkb_context *context,
|
||||
const char *buffer, size_t length,
|
||||
const char *locale,
|
||||
enum xkb_compose_format format,
|
||||
enum xkb_compose_compile_flags flags);
|
||||
|
||||
/**
|
||||
* Take a new reference on a compose table.
|
||||
*
|
||||
* @returns The passed in object.
|
||||
*
|
||||
* @memberof xkb_compose_table
|
||||
*/
|
||||
struct xkb_compose_table *
|
||||
xkb_compose_table_ref(struct xkb_compose_table *table);
|
||||
|
||||
/**
|
||||
* Release a reference on a compose table, and possibly free it.
|
||||
*
|
||||
* @param table The object. If it is NULL, this function does nothing.
|
||||
*
|
||||
* @memberof xkb_compose_table
|
||||
*/
|
||||
void
|
||||
xkb_compose_table_unref(struct xkb_compose_table *table);
|
||||
|
||||
/**
|
||||
* @struct xkb_compose_table_entry
|
||||
* Opaque Compose table entry object.
|
||||
*
|
||||
* Represents a single entry in a Compose file in the iteration API.
|
||||
* It is immutable.
|
||||
*
|
||||
* @sa xkb_compose_table_iterator_new
|
||||
* @since 1.6.0
|
||||
*/
|
||||
struct xkb_compose_table_entry;
|
||||
|
||||
/**
|
||||
* Get the left-hand keysym sequence of a Compose table entry.
|
||||
*
|
||||
* For example, given the following entry:
|
||||
*
|
||||
* ```
|
||||
* <dead_tilde> <space> : "~" asciitilde # TILDE
|
||||
* ```
|
||||
*
|
||||
* it will return `{XKB_KEY_dead_tilde, XKB_KEY_space}`.
|
||||
*
|
||||
* @param[in] entry The compose table entry object to process.
|
||||
*
|
||||
* @param[out] sequence_length Number of keysyms in the sequence.
|
||||
*
|
||||
* @returns The array of left-hand side keysyms. The number of keysyms
|
||||
* is returned in the @p sequence_length out-parameter.
|
||||
*
|
||||
* @memberof xkb_compose_table_entry
|
||||
* @since 1.6.0
|
||||
*/
|
||||
const xkb_keysym_t *
|
||||
xkb_compose_table_entry_sequence(struct xkb_compose_table_entry *entry,
|
||||
size_t *sequence_length);
|
||||
|
||||
/**
|
||||
* Get the right-hand result keysym of a Compose table entry.
|
||||
*
|
||||
* For example, given the following entry:
|
||||
*
|
||||
* ```
|
||||
* <dead_tilde> <space> : "~" asciitilde # TILDE
|
||||
* ```
|
||||
*
|
||||
* it will return `XKB_KEY_asciitilde`.
|
||||
*
|
||||
* The keysym is optional; if the entry does not specify a keysym,
|
||||
* returns `XKB_KEY_NoSymbol`.
|
||||
*
|
||||
* @memberof xkb_compose_table_entry
|
||||
* @since 1.6.0
|
||||
*/
|
||||
xkb_keysym_t
|
||||
xkb_compose_table_entry_keysym(struct xkb_compose_table_entry *entry);
|
||||
|
||||
/**
|
||||
* Get the right-hand result string of a Compose table entry.
|
||||
*
|
||||
* The string is UTF-8 encoded and NULL-terminated.
|
||||
*
|
||||
* For example, given the following entry:
|
||||
*
|
||||
* ```
|
||||
* <dead_tilde> <space> : "~" asciitilde # TILDE
|
||||
* ```
|
||||
*
|
||||
* it will return `"~"`.
|
||||
*
|
||||
* The string is optional; if the entry does not specify a string,
|
||||
* returns the empty string.
|
||||
*
|
||||
* @memberof xkb_compose_table_entry
|
||||
* @since 1.6.0
|
||||
*/
|
||||
const char *
|
||||
xkb_compose_table_entry_utf8(struct xkb_compose_table_entry *entry);
|
||||
|
||||
/**
|
||||
* @struct xkb_compose_table_iterator
|
||||
* Iterator over a compose table’s entries.
|
||||
*
|
||||
* @sa xkb_compose_table_iterator_new()
|
||||
* @since 1.6.0
|
||||
*/
|
||||
struct xkb_compose_table_iterator;
|
||||
|
||||
/**
|
||||
* Create a new iterator for a compose table.
|
||||
*
|
||||
* Intended use:
|
||||
*
|
||||
* ```c
|
||||
* struct xkb_compose_table_iterator *iter = xkb_compose_table_iterator_new(compose_table);
|
||||
* struct xkb_compose_table_entry *entry;
|
||||
* while ((entry = xkb_compose_table_iterator_next(iter))) {
|
||||
* // ...
|
||||
* }
|
||||
* xkb_compose_table_iterator_free(iter);
|
||||
* ```
|
||||
*
|
||||
* @returns A new compose table iterator, or `NULL` on failure.
|
||||
*
|
||||
* @memberof xkb_compose_table_iterator
|
||||
* @sa xkb_compose_table_iterator_free()
|
||||
* @since 1.6.0
|
||||
*/
|
||||
struct xkb_compose_table_iterator *
|
||||
xkb_compose_table_iterator_new(struct xkb_compose_table *table);
|
||||
|
||||
/**
|
||||
* Free a compose iterator.
|
||||
*
|
||||
* @memberof xkb_compose_table_iterator
|
||||
* @since 1.6.0
|
||||
*/
|
||||
void
|
||||
xkb_compose_table_iterator_free(struct xkb_compose_table_iterator *iter);
|
||||
|
||||
/**
|
||||
* Get the next compose entry from a compose table iterator.
|
||||
*
|
||||
* The entries are returned in lexicographic order of the left-hand
|
||||
* side of entries. This does not correspond to the order in which
|
||||
* the entries appear in the Compose file.
|
||||
*
|
||||
* @attention The return value is valid until the next call to this function.
|
||||
*
|
||||
* Returns `NULL` in case there is no more entries.
|
||||
*
|
||||
* @memberof xkb_compose_table_iterator
|
||||
* @since 1.6.0
|
||||
*/
|
||||
struct xkb_compose_table_entry *
|
||||
xkb_compose_table_iterator_next(struct xkb_compose_table_iterator *iter);
|
||||
|
||||
/** Flags for compose state creation. */
|
||||
enum xkb_compose_state_flags {
|
||||
/** Do not apply any flags. */
|
||||
XKB_COMPOSE_STATE_NO_FLAGS = 0
|
||||
};
|
||||
|
||||
/**
|
||||
* Create a new compose state object.
|
||||
*
|
||||
* @param table
|
||||
* The compose table the state will use.
|
||||
* @param flags
|
||||
* Optional flags for the compose state, or 0.
|
||||
*
|
||||
* @returns A new compose state, or NULL on failure.
|
||||
*
|
||||
* @memberof xkb_compose_state
|
||||
*/
|
||||
struct xkb_compose_state *
|
||||
xkb_compose_state_new(struct xkb_compose_table *table,
|
||||
enum xkb_compose_state_flags flags);
|
||||
|
||||
/**
|
||||
* Take a new reference on a compose state object.
|
||||
*
|
||||
* @returns The passed in object.
|
||||
*
|
||||
* @memberof xkb_compose_state
|
||||
*/
|
||||
struct xkb_compose_state *
|
||||
xkb_compose_state_ref(struct xkb_compose_state *state);
|
||||
|
||||
/**
|
||||
* Release a reference on a compose state object, and possibly free it.
|
||||
*
|
||||
* @param state The object. If NULL, do nothing.
|
||||
*
|
||||
* @memberof xkb_compose_state
|
||||
*/
|
||||
void
|
||||
xkb_compose_state_unref(struct xkb_compose_state *state);
|
||||
|
||||
/**
|
||||
* Get the compose table which a compose state object is using.
|
||||
*
|
||||
* @returns The compose table which was passed to xkb_compose_state_new()
|
||||
* when creating this state object.
|
||||
*
|
||||
* This function does not take a new reference on the compose table; you
|
||||
* must explicitly reference it yourself if you plan to use it beyond the
|
||||
* lifetime of the state.
|
||||
*
|
||||
* @memberof xkb_compose_state
|
||||
*/
|
||||
struct xkb_compose_table *
|
||||
xkb_compose_state_get_compose_table(struct xkb_compose_state *state);
|
||||
|
||||
/** Status of the Compose sequence state machine. */
|
||||
enum xkb_compose_status {
|
||||
/** The initial state; no sequence has started yet. */
|
||||
XKB_COMPOSE_NOTHING,
|
||||
/** In the middle of a sequence. */
|
||||
XKB_COMPOSE_COMPOSING,
|
||||
/** A complete sequence has been matched. */
|
||||
XKB_COMPOSE_COMPOSED,
|
||||
/** The last sequence was cancelled due to an unmatched keysym. */
|
||||
XKB_COMPOSE_CANCELLED
|
||||
};
|
||||
|
||||
/** The effect of a keysym fed to xkb_compose_state_feed(). */
|
||||
enum xkb_compose_feed_result {
|
||||
/** The keysym had no effect - it did not affect the status. */
|
||||
XKB_COMPOSE_FEED_IGNORED,
|
||||
/** The keysym started, advanced or cancelled a sequence. */
|
||||
XKB_COMPOSE_FEED_ACCEPTED
|
||||
};
|
||||
|
||||
/**
|
||||
* Feed one keysym to the Compose sequence state machine.
|
||||
*
|
||||
* This function can advance into a compose sequence, cancel a sequence,
|
||||
* start a new sequence, or do nothing in particular. The resulting
|
||||
* status may be observed with xkb_compose_state_get_status().
|
||||
*
|
||||
* Some keysyms, such as keysyms for modifier keys, are ignored - they
|
||||
* have no effect on the status or otherwise.
|
||||
*
|
||||
* The following is a description of the possible status transitions, in
|
||||
* the format CURRENT STATUS => NEXT STATUS, given a non-ignored input
|
||||
* keysym `keysym`:
|
||||
*
|
||||
@verbatim
|
||||
NOTHING or CANCELLED or COMPOSED =>
|
||||
NOTHING if keysym does not start a sequence.
|
||||
COMPOSING if keysym starts a sequence.
|
||||
COMPOSED if keysym starts and terminates a single-keysym sequence.
|
||||
|
||||
COMPOSING =>
|
||||
COMPOSING if keysym advances any of the currently possible
|
||||
sequences but does not terminate any of them.
|
||||
COMPOSED if keysym terminates one of the currently possible
|
||||
sequences.
|
||||
CANCELLED if keysym does not advance any of the currently
|
||||
possible sequences.
|
||||
@endverbatim
|
||||
*
|
||||
* The current Compose formats do not support multiple-keysyms.
|
||||
* Therefore, if you are using a function such as xkb_state_key_get_syms()
|
||||
* and it returns more than one keysym, consider feeding XKB_KEY_NoSymbol
|
||||
* instead.
|
||||
*
|
||||
* @param state
|
||||
* The compose state object.
|
||||
* @param keysym
|
||||
* A keysym, usually obtained after a key-press event, with a
|
||||
* function such as xkb_state_key_get_one_sym().
|
||||
*
|
||||
* @returns Whether the keysym was ignored. This is useful, for example,
|
||||
* if you want to keep a record of the sequence matched thus far.
|
||||
*
|
||||
* @memberof xkb_compose_state
|
||||
*/
|
||||
enum xkb_compose_feed_result
|
||||
xkb_compose_state_feed(struct xkb_compose_state *state,
|
||||
xkb_keysym_t keysym);
|
||||
|
||||
/**
|
||||
* Reset the Compose sequence state machine.
|
||||
*
|
||||
* The status is set to XKB_COMPOSE_NOTHING, and the current sequence
|
||||
* is discarded.
|
||||
*
|
||||
* @memberof xkb_compose_state
|
||||
*/
|
||||
void
|
||||
xkb_compose_state_reset(struct xkb_compose_state *state);
|
||||
|
||||
/**
|
||||
* Get the current status of the compose state machine.
|
||||
*
|
||||
* @see xkb_compose_status
|
||||
* @memberof xkb_compose_state
|
||||
**/
|
||||
enum xkb_compose_status
|
||||
xkb_compose_state_get_status(struct xkb_compose_state *state);
|
||||
|
||||
/**
|
||||
* Get the result Unicode/UTF-8 string for a composed sequence.
|
||||
*
|
||||
* See @ref compose-overview for more details. This function is only
|
||||
* useful when the status is XKB_COMPOSE_COMPOSED.
|
||||
*
|
||||
* @param[in] state
|
||||
* The compose state.
|
||||
* @param[out] buffer
|
||||
* A buffer to write the string into.
|
||||
* @param[in] size
|
||||
* Size of the buffer.
|
||||
*
|
||||
* @warning If the buffer passed is too small, the string is truncated
|
||||
* (though still NUL-terminated).
|
||||
*
|
||||
* @returns
|
||||
* The number of bytes required for the string, excluding the NUL byte.
|
||||
* If the sequence is not complete, or does not have a viable result
|
||||
* string, returns 0, and sets `buffer` to the empty string (if possible).
|
||||
* @returns
|
||||
* You may check if truncation has occurred by comparing the return value
|
||||
* with the size of `buffer`, similarly to the `snprintf`(3) function.
|
||||
* You may safely pass NULL and 0 to `buffer` and `size` to find the
|
||||
* required size (without the NUL-byte).
|
||||
*
|
||||
* @memberof xkb_compose_state
|
||||
**/
|
||||
int
|
||||
xkb_compose_state_get_utf8(struct xkb_compose_state *state,
|
||||
char *buffer, size_t size);
|
||||
|
||||
/**
|
||||
* Get the result keysym for a composed sequence.
|
||||
*
|
||||
* See @ref compose-overview for more details. This function is only
|
||||
* useful when the status is XKB_COMPOSE_COMPOSED.
|
||||
*
|
||||
* @returns The result keysym. If the sequence is not complete, or does
|
||||
* not specify a result keysym, returns XKB_KEY_NoSymbol.
|
||||
*
|
||||
* @memberof xkb_compose_state
|
||||
**/
|
||||
xkb_keysym_t
|
||||
xkb_compose_state_get_one_sym(struct xkb_compose_state *state);
|
||||
|
||||
/** @} */
|
||||
|
||||
#ifdef __cplusplus
|
||||
} /* extern "C" */
|
||||
#endif
|
||||
|
||||
#endif /* _XKBCOMMON_COMPOSE_H */
|
||||
3355
libs/system-sdk/linux/include/xkbcommon/xkbcommon-keysyms.h
Normal file
3355
libs/system-sdk/linux/include/xkbcommon/xkbcommon-keysyms.h
Normal file
File diff suppressed because it is too large
Load Diff
45
libs/system-sdk/linux/include/xkbcommon/xkbcommon-names.h
Normal file
45
libs/system-sdk/linux/include/xkbcommon/xkbcommon-names.h
Normal file
@@ -0,0 +1,45 @@
|
||||
/*
|
||||
* Copyright © 2012 Intel Corporation
|
||||
*
|
||||
* Permission is hereby granted, free of charge, to any person obtaining a
|
||||
* copy of this software and associated documentation files (the "Software"),
|
||||
* to deal in the Software without restriction, including without limitation
|
||||
* the rights to use, copy, modify, merge, publish, distribute, sublicense,
|
||||
* and/or sell copies of the Software, and to permit persons to whom the
|
||||
* Software is furnished to do so, subject to the following conditions:
|
||||
*
|
||||
* The above copyright notice and this permission notice (including the next
|
||||
* paragraph) shall be included in all copies or substantial portions of the
|
||||
* Software.
|
||||
*
|
||||
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||||
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
||||
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
|
||||
* THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
||||
* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
|
||||
* FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
|
||||
* DEALINGS IN THE SOFTWARE.
|
||||
*
|
||||
* Author: Daniel Stone <daniel@fooishbar.org>
|
||||
*/
|
||||
|
||||
#ifndef _XKBCOMMON_NAMES_H
|
||||
#define _XKBCOMMON_NAMES_H
|
||||
|
||||
/**
|
||||
* @file
|
||||
* @brief Predefined names for common modifiers and LEDs.
|
||||
*/
|
||||
|
||||
#define XKB_MOD_NAME_SHIFT "Shift"
|
||||
#define XKB_MOD_NAME_CAPS "Lock"
|
||||
#define XKB_MOD_NAME_CTRL "Control"
|
||||
#define XKB_MOD_NAME_ALT "Mod1"
|
||||
#define XKB_MOD_NAME_NUM "Mod2"
|
||||
#define XKB_MOD_NAME_LOGO "Mod4"
|
||||
|
||||
#define XKB_LED_NAME_CAPS "Caps Lock"
|
||||
#define XKB_LED_NAME_NUM "Num Lock"
|
||||
#define XKB_LED_NAME_SCROLL "Scroll Lock"
|
||||
|
||||
#endif
|
||||
244
libs/system-sdk/linux/include/xkbcommon/xkbcommon-x11.h
Normal file
244
libs/system-sdk/linux/include/xkbcommon/xkbcommon-x11.h
Normal file
@@ -0,0 +1,244 @@
|
||||
/*
|
||||
* Copyright © 2013 Ran Benita
|
||||
*
|
||||
* Permission is hereby granted, free of charge, to any person obtaining a
|
||||
* copy of this software and associated documentation files (the "Software"),
|
||||
* to deal in the Software without restriction, including without limitation
|
||||
* the rights to use, copy, modify, merge, publish, distribute, sublicense,
|
||||
* and/or sell copies of the Software, and to permit persons to whom the
|
||||
* Software is furnished to do so, subject to the following conditions:
|
||||
*
|
||||
* The above copyright notice and this permission notice (including the next
|
||||
* paragraph) shall be included in all copies or substantial portions of the
|
||||
* Software.
|
||||
*
|
||||
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||||
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
||||
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
|
||||
* THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
||||
* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
|
||||
* FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
|
||||
* DEALINGS IN THE SOFTWARE.
|
||||
*/
|
||||
|
||||
#ifndef _XKBCOMMON_X11_H
|
||||
#define _XKBCOMMON_X11_H
|
||||
|
||||
#include <xcb/xcb.h>
|
||||
#include <xkbcommon/xkbcommon.h>
|
||||
|
||||
#ifdef __cplusplus
|
||||
extern "C" {
|
||||
#endif
|
||||
|
||||
/**
|
||||
* @file
|
||||
* libxkbcommon-x11 API - Additional X11 support for xkbcommon.
|
||||
*/
|
||||
|
||||
/**
|
||||
* @defgroup x11 X11 support
|
||||
* Additional X11 support for xkbcommon.
|
||||
* @since 0.4.0
|
||||
*
|
||||
* @{
|
||||
*/
|
||||
|
||||
/**
|
||||
* @page x11-overview Overview
|
||||
* @parblock
|
||||
*
|
||||
* The xkbcommon-x11 module provides a means for creating an xkb_keymap
|
||||
* corresponding to the currently active keymap on the X server. To do
|
||||
* so, it queries the XKB X11 extension using the xcb-xkb library. It
|
||||
* can be used as a replacement for Xlib's keyboard handling.
|
||||
*
|
||||
* Following is an example workflow using xkbcommon-x11. A complete
|
||||
* example may be found in the tools/interactive-x11.c file in the
|
||||
* xkbcommon source repository. On startup:
|
||||
*
|
||||
* 1. Connect to the X server using xcb_connect().
|
||||
* 2. Setup the XKB X11 extension. You can do this either by using the
|
||||
* xcb_xkb_use_extension() request directly, or by using the
|
||||
* xkb_x11_setup_xkb_extension() helper function.
|
||||
*
|
||||
* The XKB extension supports using separate keymaps and states for
|
||||
* different keyboard devices. The devices are identified by an integer
|
||||
* device ID and are managed by another X11 extension, XInput. The
|
||||
* original X11 protocol only had one keyboard device, called the "core
|
||||
* keyboard", which is still supported as a "virtual device".
|
||||
*
|
||||
* 3. We will use the core keyboard as an example. To get its device ID,
|
||||
* use either the xcb_xkb_get_device_info() request directly, or the
|
||||
* xkb_x11_get_core_keyboard_device_id() helper function.
|
||||
* 4. Create an initial xkb_keymap for this device, using the
|
||||
* xkb_x11_keymap_new_from_device() function.
|
||||
* 5. Create an initial xkb_state for this device, using the
|
||||
* xkb_x11_state_new_from_device() function.
|
||||
*
|
||||
* @note At this point, you may consider setting various XKB controls and
|
||||
* XKB per-client flags. For example, enabling detectable autorepeat: \n
|
||||
* https://www.x.org/releases/current/doc/kbproto/xkbproto.html#Detectable_Autorepeat
|
||||
*
|
||||
* Next, you need to react to state changes (e.g. a modifier was pressed,
|
||||
* the layout was changed) and to keymap changes (e.g. a tool like xkbcomp,
|
||||
* setxkbmap or xmodmap was used):
|
||||
*
|
||||
* 6. Select to listen to at least the following XKB events:
|
||||
* NewKeyboardNotify, MapNotify, StateNotify; using the
|
||||
* xcb_xkb_select_events_aux() request.
|
||||
* 7. When NewKeyboardNotify or MapNotify are received, recreate the
|
||||
* xkb_keymap and xkb_state as described above.
|
||||
* 8. When StateNotify is received, update the xkb_state accordingly
|
||||
* using the xkb_state_update_mask() function.
|
||||
*
|
||||
* @note It is also possible to use the KeyPress/KeyRelease @p state
|
||||
* field to find the effective modifier and layout state, instead of
|
||||
* using XkbStateNotify: \n
|
||||
* https://www.x.org/releases/current/doc/kbproto/xkbproto.html#Computing_A_State_Field_from_an_XKB_State
|
||||
* \n However, XkbStateNotify is more accurate.
|
||||
*
|
||||
* @note There is no need to call xkb_state_update_key(); the state is
|
||||
* already synchronized.
|
||||
*
|
||||
* Finally, when a key event is received, you can use ordinary xkbcommon
|
||||
* functions, like xkb_state_key_get_one_sym() and xkb_state_key_get_utf8(),
|
||||
* as you normally would.
|
||||
*
|
||||
* @endparblock
|
||||
*/
|
||||
|
||||
/**
|
||||
* The minimal compatible major version of the XKB X11 extension which
|
||||
* this library can use.
|
||||
*/
|
||||
#define XKB_X11_MIN_MAJOR_XKB_VERSION 1
|
||||
/**
|
||||
* The minimal compatible minor version of the XKB X11 extension which
|
||||
* this library can use (for the minimal major version).
|
||||
*/
|
||||
#define XKB_X11_MIN_MINOR_XKB_VERSION 0
|
||||
|
||||
/** Flags for the xkb_x11_setup_xkb_extension() function. */
|
||||
enum xkb_x11_setup_xkb_extension_flags {
|
||||
/** Do not apply any flags. */
|
||||
XKB_X11_SETUP_XKB_EXTENSION_NO_FLAGS = 0
|
||||
};
|
||||
|
||||
/**
|
||||
* Setup the XKB X11 extension for this X client.
|
||||
*
|
||||
* The xkbcommon-x11 library uses various XKB requests. Before doing so,
|
||||
* an X client must notify the server that it will be using the extension.
|
||||
* This function (or an XCB equivalent) must be called before any other
|
||||
* function in this library is used.
|
||||
*
|
||||
* Some X servers may not support or disable the XKB extension. If you
|
||||
* want to support such servers, you need to use a different fallback.
|
||||
*
|
||||
* You may call this function several times; it is idempotent.
|
||||
*
|
||||
* @param connection
|
||||
* An XCB connection to the X server.
|
||||
* @param major_xkb_version
|
||||
* See @p minor_xkb_version.
|
||||
* @param minor_xkb_version
|
||||
* The XKB extension version to request. To operate correctly, you
|
||||
* must have (major_xkb_version, minor_xkb_version) >=
|
||||
* (XKB_X11_MIN_MAJOR_XKB_VERSION, XKB_X11_MIN_MINOR_XKB_VERSION),
|
||||
* though this is not enforced.
|
||||
* @param flags
|
||||
* Optional flags, or 0.
|
||||
* @param[out] major_xkb_version_out
|
||||
* See @p minor_xkb_version_out.
|
||||
* @param[out] minor_xkb_version_out
|
||||
* Backfilled with the compatible XKB extension version numbers picked
|
||||
* by the server. Can be NULL.
|
||||
* @param[out] base_event_out
|
||||
* Backfilled with the XKB base (also known as first) event code, needed
|
||||
* to distinguish XKB events. Can be NULL.
|
||||
* @param[out] base_error_out
|
||||
* Backfilled with the XKB base (also known as first) error code, needed
|
||||
* to distinguish XKB errors. Can be NULL.
|
||||
*
|
||||
* @returns 1 on success, or 0 on failure.
|
||||
*/
|
||||
int
|
||||
xkb_x11_setup_xkb_extension(xcb_connection_t *connection,
|
||||
uint16_t major_xkb_version,
|
||||
uint16_t minor_xkb_version,
|
||||
enum xkb_x11_setup_xkb_extension_flags flags,
|
||||
uint16_t *major_xkb_version_out,
|
||||
uint16_t *minor_xkb_version_out,
|
||||
uint8_t *base_event_out,
|
||||
uint8_t *base_error_out);
|
||||
|
||||
/**
|
||||
* Get the keyboard device ID of the core X11 keyboard.
|
||||
*
|
||||
* @param connection An XCB connection to the X server.
|
||||
*
|
||||
* @returns A device ID which may be used with other xkb_x11_* functions,
|
||||
* or -1 on failure.
|
||||
*/
|
||||
int32_t
|
||||
xkb_x11_get_core_keyboard_device_id(xcb_connection_t *connection);
|
||||
|
||||
/**
|
||||
* Create a keymap from an X11 keyboard device.
|
||||
*
|
||||
* This function queries the X server with various requests, fetches the
|
||||
* details of the active keymap on a keyboard device, and creates an
|
||||
* xkb_keymap from these details.
|
||||
*
|
||||
* @param context
|
||||
* The context in which to create the keymap.
|
||||
* @param connection
|
||||
* An XCB connection to the X server.
|
||||
* @param device_id
|
||||
* An XInput device ID (in the range 0-127) with input class KEY.
|
||||
* Passing values outside of this range is an error (the XKB protocol
|
||||
* predates the XInput2 protocol, which first allowed IDs > 127).
|
||||
* @param flags
|
||||
* Optional flags for the keymap, or 0.
|
||||
*
|
||||
* @returns A keymap retrieved from the X server, or NULL on failure.
|
||||
*
|
||||
* @memberof xkb_keymap
|
||||
*/
|
||||
struct xkb_keymap *
|
||||
xkb_x11_keymap_new_from_device(struct xkb_context *context,
|
||||
xcb_connection_t *connection,
|
||||
int32_t device_id,
|
||||
enum xkb_keymap_compile_flags flags);
|
||||
|
||||
/**
|
||||
* Create a new keyboard state object from an X11 keyboard device.
|
||||
*
|
||||
* This function is the same as xkb_state_new(), only pre-initialized
|
||||
* with the state of the device at the time this function is called.
|
||||
*
|
||||
* @param keymap
|
||||
* The keymap for which to create the state.
|
||||
* @param connection
|
||||
* An XCB connection to the X server.
|
||||
* @param device_id
|
||||
* An XInput 1 device ID (in the range 0-255) with input class KEY.
|
||||
* Passing values outside of this range is an error.
|
||||
*
|
||||
* @returns A new keyboard state object, or NULL on failure.
|
||||
*
|
||||
* @memberof xkb_state
|
||||
*/
|
||||
struct xkb_state *
|
||||
xkb_x11_state_new_from_device(struct xkb_keymap *keymap,
|
||||
xcb_connection_t *connection,
|
||||
int32_t device_id);
|
||||
|
||||
/** @} */
|
||||
|
||||
#ifdef __cplusplus
|
||||
} /* extern "C" */
|
||||
#endif
|
||||
|
||||
#endif /* _XKBCOMMON_X11_H */
|
||||
2002
libs/system-sdk/linux/include/xkbcommon/xkbcommon.h
Normal file
2002
libs/system-sdk/linux/include/xkbcommon/xkbcommon.h
Normal file
File diff suppressed because it is too large
Load Diff
789
libs/system-sdk/linux/include/xkbcommon/xkbregistry.h
Normal file
789
libs/system-sdk/linux/include/xkbcommon/xkbregistry.h
Normal file
@@ -0,0 +1,789 @@
|
||||
/*
|
||||
* Copyright © 2020 Red Hat, Inc.
|
||||
*
|
||||
* Permission is hereby granted, free of charge, to any person obtaining a
|
||||
* copy of this software and associated documentation files (the "Software"),
|
||||
* to deal in the Software without restriction, including without limitation
|
||||
* the rights to use, copy, modify, merge, publish, distribute, sublicense,
|
||||
* and/or sell copies of the Software, and to permit persons to whom the
|
||||
* Software is furnished to do so, subject to the following conditions:
|
||||
*
|
||||
* The above copyright notice and this permission notice (including the next
|
||||
* paragraph) shall be included in all copies or substantial portions of the
|
||||
* Software.
|
||||
*
|
||||
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||||
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
||||
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
|
||||
* THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
||||
* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
|
||||
* FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
|
||||
* DEALINGS IN THE SOFTWARE.
|
||||
*/
|
||||
|
||||
|
||||
#ifndef _XKBREGISTRY_H_
|
||||
#define _XKBREGISTRY_H_
|
||||
|
||||
#include <stdarg.h>
|
||||
#include <stdbool.h>
|
||||
|
||||
/**
|
||||
* @file
|
||||
* @brief Query for available RMLVO
|
||||
*
|
||||
*/
|
||||
|
||||
#ifdef __cplusplus
|
||||
extern "C" {
|
||||
#endif
|
||||
|
||||
/**
|
||||
* @defgroup registry Query for available RMLVO
|
||||
*
|
||||
* The libxkbregistry API to query for available rules, models, layouts,
|
||||
* variants and options (RMLVO). libxkbregistry is a separate library to
|
||||
* libxkbcommon.
|
||||
*
|
||||
* This library is the replacement for clients currently parsing evdev.xml
|
||||
* directly. The library is intended to provide easy access to the set of
|
||||
* **possible** MLVO configurations for a given ruleset. It is not a library to
|
||||
* apply these configurations, merely to enumerate them. The intended users of
|
||||
* this library are the configuration UIs that allow a user to select their
|
||||
* keyboard layout of choice.
|
||||
*
|
||||
* @{
|
||||
*/
|
||||
|
||||
/**
|
||||
* @struct rxkb_context
|
||||
*
|
||||
* Opaque top level library context object.
|
||||
*
|
||||
* The context contains general library state, like include paths and parsed
|
||||
* data. Objects are created in a specific context, and multiple contexts
|
||||
* may coexist simultaneously. Objects from different contexts are
|
||||
* completely separated and do not share any memory or state.
|
||||
*/
|
||||
struct rxkb_context;
|
||||
|
||||
/**
|
||||
* @struct rxkb_model
|
||||
*
|
||||
* Opaque struct representing an XKB model.
|
||||
*/
|
||||
struct rxkb_model;
|
||||
|
||||
/**
|
||||
* @struct rxkb_layout
|
||||
*
|
||||
* Opaque struct representing an XKB layout, including an optional variant.
|
||||
* Where the variant is NULL, the layout is the base layout.
|
||||
*
|
||||
* For example, "us" is the base layout, "us(intl)" is the "intl" variant of the
|
||||
* layout "us".
|
||||
*/
|
||||
struct rxkb_layout;
|
||||
|
||||
/**
|
||||
* @struct rxkb_option_group
|
||||
*
|
||||
* Opaque struct representing an option group. Option groups divide the
|
||||
* individual options into logical groups. Their main purpose is to indicate
|
||||
* whether some options are mutually exclusive or not.
|
||||
*/
|
||||
struct rxkb_option_group;
|
||||
|
||||
/**
|
||||
* @struct rxkb_option
|
||||
*
|
||||
* Opaque struct representing an XKB option. Options are grouped inside an @ref
|
||||
* rxkb_option_group.
|
||||
*/
|
||||
struct rxkb_option;
|
||||
|
||||
/**
|
||||
*
|
||||
* @struct rxkb_iso639_code
|
||||
*
|
||||
* Opaque struct representing an ISO 639-3 code (e.g. "eng", "fra"). There
|
||||
* is no guarantee that two identical ISO codes share the same struct. You
|
||||
* must not rely on the pointer value of this struct.
|
||||
*
|
||||
* See https://iso639-3.sil.org/code_tables/639/data for a list of codes.
|
||||
*/
|
||||
struct rxkb_iso639_code;
|
||||
|
||||
/**
|
||||
*
|
||||
* @struct rxkb_iso3166_code
|
||||
*
|
||||
* Opaque struct representing an ISO 3166 Alpha 2 code (e.g. "US", "FR").
|
||||
* There is no guarantee that two identical ISO codes share the same struct.
|
||||
* You must not rely on the pointer value of this struct.
|
||||
*
|
||||
* See https://en.wikipedia.org/wiki/List_of_ISO_3166_country_codes for a list
|
||||
* of codes.
|
||||
*/
|
||||
struct rxkb_iso3166_code;
|
||||
|
||||
/**
|
||||
* Describes the popularity of an item. Historically, some highly specialized or
|
||||
* experimental definitions are excluded from the default list and shipped in
|
||||
* separate files. If these extra definitions are loaded (see @ref
|
||||
* RXKB_CONTEXT_LOAD_EXOTIC_RULES), the popularity of the item is set
|
||||
* accordingly.
|
||||
*
|
||||
* If the exotic items are not loaded, all items will have the standard
|
||||
* popularity.
|
||||
*/
|
||||
enum rxkb_popularity {
|
||||
RXKB_POPULARITY_STANDARD = 1,
|
||||
RXKB_POPULARITY_EXOTIC,
|
||||
};
|
||||
|
||||
/**
|
||||
* Flags for context creation.
|
||||
*/
|
||||
enum rxkb_context_flags {
|
||||
RXKB_CONTEXT_NO_FLAGS = 0,
|
||||
/**
|
||||
* Skip the default include paths. This requires the caller to call
|
||||
* rxkb_context_include_path_append() or
|
||||
* rxkb_context_include_path_append_default().
|
||||
*/
|
||||
RXKB_CONTEXT_NO_DEFAULT_INCLUDES = (1 << 0),
|
||||
/**
|
||||
* Load the extra items that are considered too exotic for the default list.
|
||||
*
|
||||
* For historical reasons, xkeyboard-config ships those exotic rules in a
|
||||
* separate file (e.g. `evdev.extras.xml`). Where the exotic rules are
|
||||
* requested, libxkbregistry will look for and load `$ruleset.extras.xml`
|
||||
* in the include paths, see rxkb_context_include_path_append() for details
|
||||
* on the lookup behavior.
|
||||
*/
|
||||
RXKB_CONTEXT_LOAD_EXOTIC_RULES = (1 << 1),
|
||||
/**
|
||||
* Disable the use of secure_getenv for this context, so that privileged
|
||||
* processes can use environment variables. Client uses at their own risk.
|
||||
*
|
||||
* @since 1.5.0
|
||||
*/
|
||||
RXKB_CONTEXT_NO_SECURE_GETENV = (1 << 2)
|
||||
};
|
||||
|
||||
/**
|
||||
* Create a new xkb registry context.
|
||||
*
|
||||
* The context has an initial refcount of 1. Use rxkb_context_unref() to release
|
||||
* memory associated with this context.
|
||||
*
|
||||
* Creating a context does not parse the files yet, use
|
||||
* rxkb_context_parse().
|
||||
*
|
||||
* @param flags Flags affecting context behavior
|
||||
* @return A new xkb registry context or NULL on failure
|
||||
*/
|
||||
struct rxkb_context *
|
||||
rxkb_context_new(enum rxkb_context_flags flags);
|
||||
|
||||
/** Specifies a logging level. */
|
||||
enum rxkb_log_level {
|
||||
RXKB_LOG_LEVEL_CRITICAL = 10, /**< Log critical internal errors only. */
|
||||
RXKB_LOG_LEVEL_ERROR = 20, /**< Log all errors. */
|
||||
RXKB_LOG_LEVEL_WARNING = 30, /**< Log warnings and errors. */
|
||||
RXKB_LOG_LEVEL_INFO = 40, /**< Log information, warnings, and errors. */
|
||||
RXKB_LOG_LEVEL_DEBUG = 50 /**< Log everything. */
|
||||
};
|
||||
|
||||
/**
|
||||
* Set the current logging level.
|
||||
*
|
||||
* @param ctx The context in which to set the logging level.
|
||||
* @param level The logging level to use. Only messages from this level
|
||||
* and below will be logged.
|
||||
*
|
||||
* The default level is RXKB_LOG_LEVEL_ERROR. The environment variable
|
||||
* RXKB_LOG_LEVEL, if set at the time the context was created, overrides the
|
||||
* default value. It may be specified as a level number or name.
|
||||
*/
|
||||
void
|
||||
rxkb_context_set_log_level(struct rxkb_context *ctx,
|
||||
enum rxkb_log_level level);
|
||||
|
||||
/**
|
||||
* Get the current logging level.
|
||||
*/
|
||||
enum rxkb_log_level
|
||||
rxkb_context_get_log_level(struct rxkb_context *ctx);
|
||||
|
||||
/**
|
||||
* Set a custom function to handle logging messages.
|
||||
*
|
||||
* @param ctx The context in which to use the set logging function.
|
||||
* @param log_fn The function that will be called for logging messages.
|
||||
* Passing NULL restores the default function, which logs to stderr.
|
||||
*
|
||||
* By default, log messages from this library are printed to stderr. This
|
||||
* function allows you to replace the default behavior with a custom
|
||||
* handler. The handler is only called with messages which match the
|
||||
* current logging level and verbosity settings for the context.
|
||||
* level is the logging level of the message. @a format and @a args are
|
||||
* the same as in the vprintf(3) function.
|
||||
*
|
||||
* You may use rxkb_context_set_user_data() on the context, and then call
|
||||
* rxkb_context_get_user_data() from within the logging function to provide
|
||||
* it with additional private context.
|
||||
*/
|
||||
void
|
||||
rxkb_context_set_log_fn(struct rxkb_context *ctx,
|
||||
void (*log_fn)(struct rxkb_context *ctx,
|
||||
enum rxkb_log_level level,
|
||||
const char *format, va_list args));
|
||||
|
||||
|
||||
/**
|
||||
* Parse the given ruleset. This can only be called once per context and once
|
||||
* parsed the data in the context is considered constant and will never
|
||||
* change.
|
||||
*
|
||||
* This function parses all files with the given ruleset name. See
|
||||
* rxkb_context_include_path_append() for details.
|
||||
*
|
||||
* If this function returns false, libxkbregistry failed to parse the xml files.
|
||||
* This is usually caused by invalid files on the host and should be debugged by
|
||||
* the host's administrator using external tools. Callers should reduce the
|
||||
* include paths to known good paths and/or fall back to a default RMLVO set.
|
||||
*
|
||||
* If this function returns false, the context should be be considered dead and
|
||||
* must be released with rxkb_context_unref().
|
||||
*
|
||||
* @param ctx The xkb registry context
|
||||
* @param ruleset The ruleset to parse, e.g. "evdev"
|
||||
* @return true on success or false on failure
|
||||
*/
|
||||
bool
|
||||
rxkb_context_parse(struct rxkb_context *ctx, const char *ruleset);
|
||||
|
||||
/**
|
||||
* Parse the default ruleset as configured at build time. See
|
||||
* rxkb_context_parse() for details.
|
||||
*/
|
||||
bool
|
||||
rxkb_context_parse_default_ruleset(struct rxkb_context *ctx);
|
||||
|
||||
/**
|
||||
* Increases the refcount of this object by one and returns the object.
|
||||
*
|
||||
* @param ctx The xkb registry context
|
||||
* @return The passed in object
|
||||
*/
|
||||
struct rxkb_context*
|
||||
rxkb_context_ref(struct rxkb_context *ctx);
|
||||
|
||||
/**
|
||||
* Decreases the refcount of this object by one. Where the refcount of an
|
||||
* object hits zero, associated resources will be freed.
|
||||
*
|
||||
* @param ctx The xkb registry context
|
||||
* @return always NULL
|
||||
*/
|
||||
struct rxkb_context*
|
||||
rxkb_context_unref(struct rxkb_context *ctx);
|
||||
|
||||
/**
|
||||
* Assign user-specific data. libxkbregistry will not look at or modify the
|
||||
* data, it will merely return the same pointer in
|
||||
* rxkb_context_get_user_data().
|
||||
*
|
||||
* @param ctx The xkb registry context
|
||||
* @param user_data User-specific data pointer
|
||||
*/
|
||||
void
|
||||
rxkb_context_set_user_data(struct rxkb_context *ctx, void *user_data);
|
||||
|
||||
/**
|
||||
* Return the pointer passed into rxkb_context_get_user_data().
|
||||
*
|
||||
* @param ctx The xkb registry context
|
||||
* @return User-specific data pointer
|
||||
*/
|
||||
void *
|
||||
rxkb_context_get_user_data(struct rxkb_context *ctx);
|
||||
|
||||
/**
|
||||
* Append a new entry to the context's include path.
|
||||
*
|
||||
* The include path handling is optimized for the most common use-case: a set of
|
||||
* system files that provide a complete set of MLVO and some
|
||||
* custom MLVO provided by a user **in addition** to the system set.
|
||||
*
|
||||
* The include paths should be given so that the least complete path is
|
||||
* specified first and the most complete path is appended last. For example:
|
||||
*
|
||||
* @code
|
||||
* ctx = rxkb_context_new(RXKB_CONTEXT_NO_DEFAULT_INCLUDES);
|
||||
* rxkb_context_include_path_append(ctx, "/home/user/.config/xkb");
|
||||
* rxkb_context_include_path_append(ctx, "/usr/share/X11/xkb");
|
||||
* rxkb_context_parse(ctx, "evdev");
|
||||
* @endcode
|
||||
*
|
||||
* The above example reflects the default behavior unless @ref
|
||||
* RXKB_CONTEXT_NO_DEFAULT_INCLUDES is provided.
|
||||
*
|
||||
* Loading of the files is in **reverse order**, i.e. the last path appended is
|
||||
* loaded first - in this case the ``/usr/share/X11/xkb`` path.
|
||||
* Any models, layouts, variants and options defined in the "evdev" ruleset
|
||||
* are loaded into the context. Then, any RMLVO found in the "evdev" ruleset of
|
||||
* the user's path (``/home/user/.config/xkb`` in this example) are **appended**
|
||||
* to the existing set.
|
||||
*
|
||||
* Note that data from previously loaded include paths is never overwritten,
|
||||
* only appended to. It is not not possible to change the system-provided data,
|
||||
* only to append new models, layouts, variants and options to it.
|
||||
*
|
||||
* In other words, to define a new variant of the "us" layout called "banana",
|
||||
* the following XML is sufficient.
|
||||
*
|
||||
* @verbatim
|
||||
* <xkbConfigRegistry version="1.1">
|
||||
* <layoutList>
|
||||
* <layout>
|
||||
* <configItem>
|
||||
* <name>us</name>
|
||||
* </configItem>
|
||||
* <variantList>
|
||||
* <variant>
|
||||
* <configItem>
|
||||
* <name>banana</name>
|
||||
* <description>English (Banana)</description>
|
||||
* </configItem>
|
||||
* </variant>
|
||||
* </layout>
|
||||
* </layoutList>
|
||||
* </xkbConfigRegistry>
|
||||
* @endverbatim
|
||||
*
|
||||
* The list of models, options and all other layouts (including "us" and its
|
||||
* variants) is taken from the system files. The resulting list of layouts will
|
||||
* thus have a "us" keyboard layout with the variant "banana" and all other
|
||||
* system-provided variants (dvorak, colemak, intl, etc.)
|
||||
*
|
||||
* This function must be called before rxkb_context_parse() or
|
||||
* rxkb_context_parse_default_ruleset().
|
||||
*
|
||||
* @returns true on success, or false if the include path could not be added
|
||||
* or is inaccessible.
|
||||
*/
|
||||
bool
|
||||
rxkb_context_include_path_append(struct rxkb_context *ctx, const char *path);
|
||||
|
||||
/**
|
||||
* Append the default include paths to the context's include path.
|
||||
* See rxkb_context_include_path_append() for details about the merge order.
|
||||
*
|
||||
* This function must be called before rxkb_context_parse() or
|
||||
* rxkb_context_parse_default_ruleset().
|
||||
*
|
||||
* @returns true on success, or false if the include path could not be added
|
||||
* or is inaccessible.
|
||||
*/
|
||||
bool
|
||||
rxkb_context_include_path_append_default(struct rxkb_context *ctx);
|
||||
|
||||
/**
|
||||
* Return the first model for this context. Use this to start iterating over
|
||||
* the models, followed by calls to rxkb_model_next(). Models are not sorted.
|
||||
*
|
||||
* The refcount of the returned model is not increased. Use rxkb_model_ref() if
|
||||
* you need to keep this struct outside the immediate scope.
|
||||
*
|
||||
* @return The first model in the model list.
|
||||
*/
|
||||
struct rxkb_model *
|
||||
rxkb_model_first(struct rxkb_context *ctx);
|
||||
|
||||
/**
|
||||
* Return the next model for this context. Returns NULL when no more models
|
||||
* are available.
|
||||
*
|
||||
* The refcount of the returned model is not increased. Use rxkb_model_ref() if
|
||||
* you need to keep this struct outside the immediate scope.
|
||||
*
|
||||
* @return the next model or NULL at the end of the list
|
||||
*/
|
||||
struct rxkb_model *
|
||||
rxkb_model_next(struct rxkb_model *m);
|
||||
|
||||
/**
|
||||
* Increase the refcount of the argument by one.
|
||||
*
|
||||
* @returns The argument passed in to this function.
|
||||
*/
|
||||
struct rxkb_model *
|
||||
rxkb_model_ref(struct rxkb_model *m);
|
||||
|
||||
/**
|
||||
* Decrease the refcount of the argument by one. When the refcount hits zero,
|
||||
* all memory associated with this struct is freed.
|
||||
*
|
||||
* @returns always NULL
|
||||
*/
|
||||
struct rxkb_model *
|
||||
rxkb_model_unref(struct rxkb_model *m);
|
||||
|
||||
/**
|
||||
* Return the name of this model. This is the value for M in RMLVO, to be used
|
||||
* with libxkbcommon.
|
||||
*/
|
||||
const char *
|
||||
rxkb_model_get_name(struct rxkb_model *m);
|
||||
|
||||
/**
|
||||
* Return a human-readable description of this model. This function may return
|
||||
* NULL.
|
||||
*/
|
||||
const char *
|
||||
rxkb_model_get_description(struct rxkb_model *m);
|
||||
|
||||
/**
|
||||
* Return the vendor name for this model. This function may return NULL.
|
||||
*/
|
||||
const char *
|
||||
rxkb_model_get_vendor(struct rxkb_model *m);
|
||||
|
||||
/**
|
||||
* Return the popularity for this model.
|
||||
*/
|
||||
enum rxkb_popularity
|
||||
rxkb_model_get_popularity(struct rxkb_model *m);
|
||||
|
||||
/**
|
||||
* Return the first layout for this context. Use this to start iterating over
|
||||
* the layouts, followed by calls to rxkb_layout_next(). Layouts are not sorted.
|
||||
*
|
||||
* The refcount of the returned layout is not increased. Use rxkb_layout_ref() if
|
||||
* you need to keep this struct outside the immediate scope.
|
||||
*
|
||||
* @return The first layout in the layout list.
|
||||
*/
|
||||
struct rxkb_layout *
|
||||
rxkb_layout_first(struct rxkb_context *ctx);
|
||||
|
||||
/**
|
||||
* Return the next layout for this context. Returns NULL when no more layouts
|
||||
* are available.
|
||||
*
|
||||
* The refcount of the returned layout is not increased. Use rxkb_layout_ref()
|
||||
* if you need to keep this struct outside the immediate scope.
|
||||
*
|
||||
* @return the next layout or NULL at the end of the list
|
||||
*/
|
||||
struct rxkb_layout *
|
||||
rxkb_layout_next(struct rxkb_layout *l);
|
||||
|
||||
/**
|
||||
* Increase the refcount of the argument by one.
|
||||
*
|
||||
* @returns The argument passed in to this function.
|
||||
*/
|
||||
struct rxkb_layout *
|
||||
rxkb_layout_ref(struct rxkb_layout *l);
|
||||
|
||||
/**
|
||||
* Decrease the refcount of the argument by one. When the refcount hits zero,
|
||||
* all memory associated with this struct is freed.
|
||||
*
|
||||
* @returns always NULL
|
||||
*/
|
||||
struct rxkb_layout *
|
||||
rxkb_layout_unref(struct rxkb_layout *l);
|
||||
|
||||
/**
|
||||
* Return the name of this layout. This is the value for L in RMLVO, to be used
|
||||
* with libxkbcommon.
|
||||
*/
|
||||
const char *
|
||||
rxkb_layout_get_name(struct rxkb_layout *l);
|
||||
|
||||
/**
|
||||
* Return the variant of this layout. This is the value for V in RMLVO, to be
|
||||
* used with libxkbcommon.
|
||||
*
|
||||
* A variant does not stand on its own, it always depends on the base layout.
|
||||
* e.g. there may be multiple variants called "intl" but there is only one
|
||||
* "us(intl)".
|
||||
*
|
||||
* Where the variant is NULL, the layout is the base layout (e.g. "us").
|
||||
*/
|
||||
const char *
|
||||
rxkb_layout_get_variant(struct rxkb_layout *l);
|
||||
|
||||
/**
|
||||
* Return a short (one-word) description of this layout. This function may
|
||||
* return NULL.
|
||||
*/
|
||||
const char *
|
||||
rxkb_layout_get_brief(struct rxkb_layout *l);
|
||||
|
||||
/**
|
||||
* Return a human-readable description of this layout. This function may return
|
||||
* NULL.
|
||||
*/
|
||||
const char *
|
||||
rxkb_layout_get_description(struct rxkb_layout *l);
|
||||
|
||||
/**
|
||||
* Return the popularity for this layout.
|
||||
*/
|
||||
enum rxkb_popularity
|
||||
rxkb_layout_get_popularity(struct rxkb_layout *l);
|
||||
|
||||
/**
|
||||
* Return the first option group for this context. Use this to start iterating
|
||||
* over the option groups, followed by calls to rxkb_option_group_next().
|
||||
* Option groups are not sorted.
|
||||
*
|
||||
* The refcount of the returned option group is not increased. Use
|
||||
* rxkb_option_group_ref() if you need to keep this struct outside the immediate
|
||||
* scope.
|
||||
*
|
||||
* @return The first option group in the option group list.
|
||||
*/
|
||||
struct rxkb_option_group *
|
||||
rxkb_option_group_first(struct rxkb_context *ctx);
|
||||
|
||||
/**
|
||||
* Return the next option group for this context. Returns NULL when no more
|
||||
* option groups are available.
|
||||
*
|
||||
* The refcount of the returned option group is not increased. Use
|
||||
* rxkb_option_group_ref() if you need to keep this struct outside the immediate
|
||||
* scope.
|
||||
*
|
||||
* @return the next option group or NULL at the end of the list
|
||||
*/
|
||||
struct rxkb_option_group *
|
||||
rxkb_option_group_next(struct rxkb_option_group *g);
|
||||
|
||||
/**
|
||||
* Increase the refcount of the argument by one.
|
||||
*
|
||||
* @returns The argument passed in to this function.
|
||||
*/
|
||||
struct rxkb_option_group *
|
||||
rxkb_option_group_ref(struct rxkb_option_group *g);
|
||||
|
||||
/**
|
||||
* Decrease the refcount of the argument by one. When the refcount hits zero,
|
||||
* all memory associated with this struct is freed.
|
||||
*
|
||||
* @returns always NULL
|
||||
*/
|
||||
struct rxkb_option_group *
|
||||
rxkb_option_group_unref(struct rxkb_option_group *g);
|
||||
|
||||
/**
|
||||
* Return the name of this option group. This is **not** the value for O in
|
||||
* RMLVO, the name can be used for internal sorting in the caller. This function
|
||||
* may return NULL.
|
||||
*/
|
||||
const char *
|
||||
rxkb_option_group_get_name(struct rxkb_option_group *m);
|
||||
|
||||
/**
|
||||
* Return a human-readable description of this option group. This function may
|
||||
* return NULL.
|
||||
*/
|
||||
const char *
|
||||
rxkb_option_group_get_description(struct rxkb_option_group *m);
|
||||
|
||||
/**
|
||||
* @return true if multiple options within this option group can be selected
|
||||
* simultaneously, false if all options within this option group
|
||||
* are mutually exclusive.
|
||||
*/
|
||||
bool
|
||||
rxkb_option_group_allows_multiple(struct rxkb_option_group *g);
|
||||
|
||||
/**
|
||||
* Return the popularity for this option group.
|
||||
*/
|
||||
enum rxkb_popularity
|
||||
rxkb_option_group_get_popularity(struct rxkb_option_group *g);
|
||||
|
||||
/**
|
||||
* Return the first option for this option group. Use this to start iterating
|
||||
* over the options, followed by calls to rxkb_option_next(). Options are not
|
||||
* sorted.
|
||||
*
|
||||
* The refcount of the returned option is not increased. Use rxkb_option_ref()
|
||||
* if you need to keep this struct outside the immediate scope.
|
||||
*
|
||||
* @return The first option in the option list.
|
||||
*/
|
||||
struct rxkb_option *
|
||||
rxkb_option_first(struct rxkb_option_group *group);
|
||||
|
||||
/**
|
||||
* Return the next option for this option group. Returns NULL when no more
|
||||
* options are available.
|
||||
*
|
||||
* The refcount of the returned options is not increased. Use rxkb_option_ref()
|
||||
* if you need to keep this struct outside the immediate scope.
|
||||
*
|
||||
* @returns The next option or NULL at the end of the list
|
||||
*/
|
||||
struct rxkb_option *
|
||||
rxkb_option_next(struct rxkb_option *o);
|
||||
|
||||
/**
|
||||
* Increase the refcount of the argument by one.
|
||||
*
|
||||
* @returns The argument passed in to this function.
|
||||
*/
|
||||
struct rxkb_option *
|
||||
rxkb_option_ref(struct rxkb_option *o);
|
||||
|
||||
/**
|
||||
* Decrease the refcount of the argument by one. When the refcount hits zero,
|
||||
* all memory associated with this struct is freed.
|
||||
*
|
||||
* @returns always NULL
|
||||
*/
|
||||
struct rxkb_option *
|
||||
rxkb_option_unref(struct rxkb_option *o);
|
||||
|
||||
/**
|
||||
* Return the name of this option. This is the value for O in RMLVO, to be used
|
||||
* with libxkbcommon.
|
||||
*/
|
||||
const char *
|
||||
rxkb_option_get_name(struct rxkb_option *o);
|
||||
|
||||
/**
|
||||
* Return a short (one-word) description of this option. This function may
|
||||
* return NULL.
|
||||
*/
|
||||
const char *
|
||||
rxkb_option_get_brief(struct rxkb_option *o);
|
||||
|
||||
/**
|
||||
* Return a human-readable description of this option. This function may return
|
||||
* NULL.
|
||||
*/
|
||||
const char *
|
||||
rxkb_option_get_description(struct rxkb_option *o);
|
||||
|
||||
/**
|
||||
* Return the popularity for this option.
|
||||
*/
|
||||
enum rxkb_popularity
|
||||
rxkb_option_get_popularity(struct rxkb_option *o);
|
||||
|
||||
/**
|
||||
* Increase the refcount of the argument by one.
|
||||
*
|
||||
* @returns The argument passed in to this function.
|
||||
*/
|
||||
struct rxkb_iso639_code *
|
||||
rxkb_iso639_code_ref(struct rxkb_iso639_code *iso639);
|
||||
|
||||
/**
|
||||
* Decrease the refcount of the argument by one. When the refcount hits zero,
|
||||
* all memory associated with this struct is freed.
|
||||
*
|
||||
* @returns always NULL
|
||||
*/
|
||||
struct rxkb_iso639_code *
|
||||
rxkb_iso639_code_unref(struct rxkb_iso639_code *iso639);
|
||||
|
||||
/**
|
||||
* Return the ISO 639-3 code for this code (e.g. "eng", "fra").
|
||||
*/
|
||||
const char *
|
||||
rxkb_iso639_code_get_code(struct rxkb_iso639_code *iso639);
|
||||
|
||||
/**
|
||||
* Return the first ISO 639 for this layout. Use this to start iterating over
|
||||
* the codes, followed by calls to rxkb_iso639_code_next(). Codes are not
|
||||
* sorted.
|
||||
*
|
||||
* The refcount of the returned code is not increased. Use rxkb_iso639_code_ref()
|
||||
* if you need to keep this struct outside the immediate scope.
|
||||
*
|
||||
* @return The first code in the code list.
|
||||
*/
|
||||
struct rxkb_iso639_code *
|
||||
rxkb_layout_get_iso639_first(struct rxkb_layout *layout);
|
||||
|
||||
/**
|
||||
* Return the next code in the list. Returns NULL when no more codes
|
||||
* are available.
|
||||
*
|
||||
* The refcount of the returned codes is not increased. Use
|
||||
* rxkb_iso639_code_ref() if you need to keep this struct outside the immediate
|
||||
* scope.
|
||||
*
|
||||
* @returns The next code or NULL at the end of the list
|
||||
*/
|
||||
struct rxkb_iso639_code *
|
||||
rxkb_iso639_code_next(struct rxkb_iso639_code *iso639);
|
||||
|
||||
/**
|
||||
* Increase the refcount of the argument by one.
|
||||
*
|
||||
* @returns The argument passed in to this function.
|
||||
*/
|
||||
struct rxkb_iso3166_code *
|
||||
rxkb_iso3166_code_ref(struct rxkb_iso3166_code *iso3166);
|
||||
|
||||
/**
|
||||
* Decrease the refcount of the argument by one. When the refcount hits zero,
|
||||
* all memory associated with this struct is freed.
|
||||
*
|
||||
* @returns always NULL
|
||||
*/
|
||||
struct rxkb_iso3166_code *
|
||||
rxkb_iso3166_code_unref(struct rxkb_iso3166_code *iso3166);
|
||||
|
||||
/**
|
||||
* Return the ISO 3166 Alpha 2 code for this code (e.g. "US", "FR").
|
||||
*/
|
||||
const char *
|
||||
rxkb_iso3166_code_get_code(struct rxkb_iso3166_code *iso3166);
|
||||
|
||||
/**
|
||||
* Return the first ISO 3166 for this layout. Use this to start iterating over
|
||||
* the codes, followed by calls to rxkb_iso3166_code_next(). Codes are not
|
||||
* sorted.
|
||||
*
|
||||
* The refcount of the returned code is not increased. Use
|
||||
* rxkb_iso3166_code_ref() if you need to keep this struct outside the immediate
|
||||
* scope.
|
||||
*
|
||||
* @return The first code in the code list.
|
||||
*/
|
||||
struct rxkb_iso3166_code *
|
||||
rxkb_layout_get_iso3166_first(struct rxkb_layout *layout);
|
||||
|
||||
/**
|
||||
* Return the next code in the list. Returns NULL when no more codes
|
||||
* are available.
|
||||
*
|
||||
* The refcount of the returned codes is not increased. Use
|
||||
* rxkb_iso3166_code_ref() if you need to keep this struct outside the immediate
|
||||
* scope.
|
||||
*
|
||||
* @returns The next code or NULL at the end of the list
|
||||
*/
|
||||
struct rxkb_iso3166_code *
|
||||
rxkb_iso3166_code_next(struct rxkb_iso3166_code *iso3166);
|
||||
|
||||
/** @} */
|
||||
|
||||
#ifdef __cplusplus
|
||||
} /* extern "C" */
|
||||
#endif
|
||||
|
||||
#endif /* _XKBREGISTRY_H_ */
|
||||
Reference in New Issue
Block a user