source: mainline/uspace/srv/hid/input/gsp.h@ fa942bc

topic/simplify-dev-export
Last change on this file since fa942bc was 4122410, checked in by Jakub Jermar <jakub@…>, 7 years ago

Improve Doxygen documentaion

This is stil WiP. A number of libraries, drivers and services were
converted to using a more hierarchical and decentralized scheme when it
comes to specifying to which doxygen group they belong.

  • Property mode set to 100644
File size: 2.6 KB
RevLine 
[b0b5628]1/*
2 * Copyright (c) 2009 Jiri Svoboda
3 * All rights reserved.
4 *
5 * Redistribution and use in source and binary forms, with or without
6 * modification, are permitted provided that the following conditions
7 * are met:
8 *
9 * - Redistributions of source code must retain the above copyright
10 * notice, this list of conditions and the following disclaimer.
11 * - Redistributions in binary form must reproduce the above copyright
12 * notice, this list of conditions and the following disclaimer in the
13 * documentation and/or other materials provided with the distribution.
14 * - The name of the author may not be used to endorse or promote products
15 * derived from this software without specific prior written permission.
16 *
17 * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
18 * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
19 * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
20 * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
21 * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
22 * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
23 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
24 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
25 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
26 * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
27 */
28
[5f88293]29/** @addtogroup inputgen generic
30 * @ingroup input
[b0b5628]31 * @{
[5f88293]32 */
[4122410]33
[b0b5628]34/** @file
[4122410]35 * @brief Generic scancode parser
[b0b5628]36 */
37
38#ifndef KBD_GSP_H_
39#define KBD_GSP_H_
40
[d9c8c81]41#include <adt/hash_table.h>
[b0b5628]42
43enum {
[7ee8c5b]44 GSP_END = -1, /**< Terminates a sequence. */
45 GSP_DEFAULT = -2 /**< Wildcard, catches unhandled cases. */
[b0b5628]46};
47
[7ee8c5b]48/** Scancode parser description */
[b0b5628]49typedef struct {
[7ee8c5b]50 /** Transition table, (state, input) -> (state, output) */
[b0b5628]51 hash_table_t trans;
52
[7ee8c5b]53 /** Number of states */
[b0b5628]54 int states;
55} gsp_t;
56
[7ee8c5b]57/** Scancode parser transition. */
[b0b5628]58typedef struct {
[1b20da0]59 ht_link_t link; /**< Link to hash table in @c gsp_t */
[b0b5628]60
[7ee8c5b]61 /* Preconditions */
[b0b5628]62
[7ee8c5b]63 int old_state; /**< State before transition */
64 int input; /**< Input symbol (scancode) */
[b0b5628]65
[7ee8c5b]66 /* Effects */
67
68 int new_state; /**< State after transition */
69
70 /* Output emitted during transition */
71
72 unsigned out_mods; /**< Modifier to emit */
73 unsigned out_key; /**< Keycode to emit */
[b0b5628]74} gsp_trans_t;
75
76extern void gsp_init(gsp_t *);
77extern int gsp_insert_defs(gsp_t *, const int *);
78extern int gsp_insert_seq(gsp_t *, const int *, unsigned, unsigned);
79extern int gsp_step(gsp_t *, int, int, unsigned *, unsigned *);
80
81#endif
82
83/**
84 * @}
[1b20da0]85 */
Note: See TracBrowser for help on using the repository browser.