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