blob: 1338ab592efcceed4d86f291895525b19bc7116c [file] [log] [blame]
// Copyright 2013 The Flutter Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#ifndef FLUTTER_SHELL_PLATFORM_LINUX_FL_KEYBOARD_LAYOUT_H_
#define FLUTTER_SHELL_PLATFORM_LINUX_FL_KEYBOARD_LAYOUT_H_
#include <glib-object.h>
#include <stdint.h>
G_BEGIN_DECLS
G_DECLARE_FINAL_TYPE(FlKeyboardLayout,
fl_keyboard_layout,
FL,
KEYBOARD_LAYOUT,
GObject);
/**
* FlKeyboardLayout:
* Tracks keycode to to logical key mappings for #FlKeyboardHandler
*/
/**
* fl_keyboard_layout_new:
*
* Create a new #FlKeyboardLayout.
*
* Returns: a new #FlKeyboardLayout.
*/
FlKeyboardLayout* fl_keyboard_layout_new();
/**
* fl_keyboard_layout_has_group:
* @layout: a #FlKeyboardLayout.
* @group: a key group.
*
* Checks if a group is present in this layout.
*
* Returns: %TRUE if this group is present.
*/
gboolean fl_keyboard_layout_has_group(FlKeyboardLayout* layout, uint8_t group);
/**
* fl_keyboard_layout_has_group:
* @layout: a #FlKeyboardLayout.
* @group: a key group.
* @logical_key: a logical keycode.
*
* Sets the logical key for a given group and keycode.
*/
void fl_keyboard_layout_set_logical_key(FlKeyboardLayout* layout,
uint8_t group,
uint16_t keycode,
uint64_t logical_key);
/**
* fl_keyboard_layout_get_logical_key:
* @layout: a #FlKeyboardLayout.
* @group: a key group.
* @keycode: a keycode.
*
* Gets the logical key for the given group and keycode.
*
* Returns: the logical keycode or 0 if not set.
*/
uint64_t fl_keyboard_layout_get_logical_key(FlKeyboardLayout* layout,
uint8_t group,
uint16_t keycode);
G_END_DECLS
#endif // FLUTTER_SHELL_PLATFORM_LINUX_FL_KEYBOARD_LAYOUT_H_