File: WPEKeymap.h

package info (click to toggle)
wpewebkit 2.48.3-1
  • links: PTS, VCS
  • area: main
  • in suites: trixie
  • size: 421,720 kB
  • sloc: cpp: 3,670,389; javascript: 194,411; ansic: 165,592; python: 46,476; asm: 19,276; ruby: 18,528; perl: 16,602; xml: 4,650; yacc: 2,360; java: 1,993; sh: 1,948; lex: 1,327; pascal: 366; makefile: 85
file content (104 lines) | stat: -rw-r--r-- 5,032 bytes parent folder | download | duplicates (3)
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
/*
 * Copyright (C) 2023 Igalia S.L.
 *
 * Redistribution and use in source and binary forms, with or without
 * modification, are permitted provided that the following conditions
 * are met:
 * 1. Redistributions of source code must retain the above copyright
 *    notice, this list of conditions and the following disclaimer.
 * 2. Redistributions in binary form must reproduce the above copyright
 *    notice, this list of conditions and the following disclaimer in the
 *    documentation and/or other materials provided with the distribution.
 *
 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
 * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
 * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A
 * PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
 * HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
 * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
 * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
 */

#ifndef WPEKeymap_h
#define WPEKeymap_h

#if !defined(__WPE_PLATFORM_H_INSIDE__) && !defined(BUILDING_WEBKIT)
#error "Only <wpe/wpe-platform.h> can be included directly."
#endif

#include <glib-object.h>
#include <wpe/WPEDefines.h>
#include <wpe/WPEEvent.h>

G_BEGIN_DECLS

#define WPE_TYPE_KEYMAP (wpe_keymap_get_type())
WPE_DECLARE_DERIVABLE_TYPE (WPEKeymap, wpe_keymap, WPE, KEYMAP, GObject)

typedef struct _WPEKeymapEntry WPEKeymapEntry;

/**
 * WPEKeymapEntry:
 * @keycode: the hardware keycode. This is an identifying number for a physical key.
 * @group: indicates movement in a horizontal direction. Usually groups are used
 *   for two different languages. In group 0, a key might have two English
 *   characters, and in group 1 it might have two Hebrew characters. The Hebrew
 *   characters will be printed on the key next to the English characters.
 * @level: indicates which symbol on the key will be used, in a vertical direction.
 *   So on a standard US keyboard, the key with the number “1” on it also has the
 *   exclamation point ("!") character on it. The level indicates whether to use
 *   the “1” or the “!” symbol. The letter keys are considered to have a lowercase
 *   letter at level 0, and an uppercase letter at level 1, though only the
 *   uppercase letter is printed.
 *
 * A WPEKeymapEntry is a map entry retrurned by wpe_keymap_get_entries_for_keyval().
 */
struct _WPEKeymapEntry
{
  guint keycode;
  int   group;
  int   level;
};

struct _WPEKeymapClass
{
    GObjectClass parent_class;

    gboolean     (* get_entries_for_keyval)   (WPEKeymap       *keymap,
                                               guint            keyval,
                                               WPEKeymapEntry **entries,
                                               guint           *n_entries);
    gboolean     (* translate_keyboard_state) (WPEKeymap       *keymap,
                                               guint            keycode,
                                               WPEModifiers     modifiers,
                                               int              group,
                                               guint           *keyval,
                                               int             *effective_group,
                                               int             *level,
                                               WPEModifiers    *consumed_modifiers);
    WPEModifiers (* get_modifiers)            (WPEKeymap       *keymap);

    gpointer padding[32];
};

WPE_API gboolean     wpe_keymap_get_entries_for_keyval   (WPEKeymap       *keymap,
                                                          guint            keyval,
                                                          WPEKeymapEntry **entries,
                                                          guint           *n_entries);
WPE_API gboolean     wpe_keymap_translate_keyboard_state (WPEKeymap       *keymap,
                                                          guint            keycode,
                                                          WPEModifiers     modifiers,
                                                          int              group,
                                                          guint           *keyval,
                                                          int             *effective_group,
                                                          int             *level,
                                                          WPEModifiers    *consumed_modifiers);
WPE_API WPEModifiers wpe_keymap_get_modifiers            (WPEKeymap       *keymap);

G_END_DECLS

#endif /* WPEKeymap_h */