/usr/include/ibus-1.0/ibushotkey.h is in libibus-1.0-dev 1.5.17-3ubuntu4.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 | /* -*- mode: C; c-basic-offset: 4; indent-tabs-mode: nil; -*- */
/* vim:set et sts=4: */
/* IBus - The Input Bus
* Copyright (C) 2008-2013 Peng Huang <shawn.p.huang@gmail.com>
* Copyright (C) 2008-2013 Red Hat, Inc.
*
* This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public
* License as published by the Free Software Foundation; either
* version 2.1 of the License, or (at your option) any later version.
*
* This library is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
* Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public
* License along with this library; if not, write to the Free Software
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301
* USA
*/
#if !defined (__IBUS_H_INSIDE__) && !defined (IBUS_COMPILATION)
#error "Only <ibus.h> can be included directly"
#endif
#ifndef __IBUS_HOTKEY_H_
#define __IBUS_HOTKEY_H_
/**
* SECTION: ibushotkey
* @short_description: Hotkeys and associated events.
* @stability: Stable
*
* An IBusHotkeyProfile associates a hotkey and an event.
*/
#include "ibusserializable.h"
/*
* Type macros.
*/
/* define IBusHotkeyProfile macros */
#define IBUS_TYPE_HOTKEY_PROFILE \
(ibus_hotkey_profile_get_type ())
#define IBUS_HOTKEY_PROFILE(obj) \
(G_TYPE_CHECK_INSTANCE_CAST ((obj), IBUS_TYPE_HOTKEY_PROFILE, IBusHotkeyProfile))
#define IBUS_HOTKEY_PROFILE_CLASS(klass) \
(G_TYPE_CHECK_CLASS_CAST ((klass), IBUS_TYPE_HOTKEY_PROFILE, IBusHotkeyProfileClass))
#define IBUS_IS_HOTKEY_PROFILE(obj) \
(G_TYPE_CHECK_INSTANCE_TYPE ((obj), IBUS_TYPE_HOTKEY_PROFILE))
#define IBUS_IS_HOTKEY_PROFILE_CLASS(klass) \
(G_TYPE_CHECK_CLASS_TYPE ((klass), IBUS_TYPE_HOTKEY_PROFILE))
#define IBUS_HOTKEY_PROFILE_GET_CLASS(obj) \
(G_TYPE_INSTANCE_GET_CLASS ((obj), IBUS_TYPE_HOTKEY_PROFILE, IBusHotkeyProfileClass))
G_BEGIN_DECLS
typedef struct _IBusHotkeyProfile IBusHotkeyProfile;
typedef struct _IBusHotkeyProfileClass IBusHotkeyProfileClass;
/**
* IBusHotkeyProfile:
*
* An opaque data type representing an IBusHotkeyProfile.
*/
struct _IBusHotkeyProfile {
IBusSerializable parent;
/* members */
};
struct _IBusHotkeyProfileClass {
IBusSerializableClass parent;
void (* trigger) (IBusHotkeyProfile *profile,
GQuark event,
gpointer user_data);
};
/* hotkey profile functions */
GType ibus_hotkey_profile_get_type (void);
/**
* ibus_hotkey_profile_new:
*
* Creates a new #IBusHotkeyProfile.
*
* Returns: A newly allocated #IBusHotkeyProfile.
*/
IBusHotkeyProfile
*ibus_hotkey_profile_new (void);
/**
* ibus_hotkey_profile_add_hotkey :
* @profile: An IBusHotkeyProfile.
* @keyval: Keycode of the hotkey.
* @modifiers: Modifiers of the hotkey.
* @event: The event to be associated.
*
* Adds a hotkey and its associated event to an #IBusHotkeyProfile.
*
* Returns: Always %TRUE.
*/
gboolean ibus_hotkey_profile_add_hotkey (IBusHotkeyProfile *profile,
guint keyval,
guint modifiers,
GQuark event);
/**
* ibus_hotkey_profile_add_hotkey_from_string:
* @profile: An IBusHotkeyProfile.
* @str: Key in string representation. '+' is the separator.
* @event: The event to be associated.
*
* Adds a hotkey and its associated event to an #IBusHotkeyProfile.
* The hotkey is in string format, such like
* <constant>Control+Shift+A</constant>.
*
* Returns: FALSE if @str contains invalid symbol; TRUE otherwise.
*/
gboolean ibus_hotkey_profile_add_hotkey_from_string
(IBusHotkeyProfile *profile,
const gchar *str,
GQuark event);
/**
* ibus_hotkey_profile_remove_hotkey:
* @profile: An IBusHotkeyProfile.
* @keyval: Keycode of the hotkey.
* @modifiers: Modifiers of the hotkey.
*
* Removes the hotkey for an #IBusHotkeyProfile.
*
* Returns: %FALSE if the key is not in @profile, %TRUE otherwise.
*/
gboolean ibus_hotkey_profile_remove_hotkey
(IBusHotkeyProfile *profile,
guint keyval,
guint modifiers);
/**
* ibus_hotkey_profile_remove_hotkey_by_event:
* @profile: An IBusHotkeyProfile.
* @event: The associated event.
*
* Removes the hotkey for an #IBusHotkeyProfile by event.
*
* Returns: %FALSE if no such event in @profile, %TRUE otherwise.
*/
gboolean ibus_hotkey_profile_remove_hotkey_by_event
(IBusHotkeyProfile *profile,
GQuark event);
/**
* ibus_hotkey_profile_filter_key_event:
* @profile: An IBusHotkeyProfile.
* @keyval: Keycode of the hotkey.
* @modifiers: Modifiers of the hotkey.
* @prev_keyval: Keycode of the hotkey.
* @prev_modifiers: Modifiers of the hotkey.
* @user_data: user data for signal "trigger".
*
* Emits a <constant>::trigger</constant> signal when a hotkey is in a profile.
*
* Returns: 0 if releasing a hotkey and the hotkey is not in the profile;
* an associated event otherwise.
*
* See also: ::trigger
*/
GQuark ibus_hotkey_profile_filter_key_event
(IBusHotkeyProfile *profile,
guint keyval,
guint modifiers,
guint prev_keyval,
guint prev_modifiers,
gpointer user_data);
/**
* ibus_hotkey_profile_lookup_hotkey:
* @profile: An IBusHotkeyProfile.
* @keyval: Keycode of the hotkey.
* @modifiers: Modifiers of the hotkey.
*
* Returns: The event associated to the hotkey or 0 if the hotkey is not in the
* profile.
*/
GQuark ibus_hotkey_profile_lookup_hotkey
(IBusHotkeyProfile *profile,
guint keyval,
guint modifiers);
G_END_DECLS
#endif
|