source: mainline/uspace/lib/c/include/io/console.h@ 6a0ff7f4

lfn serial ticket/834-toolchain-update topic/msim-upgrade topic/simplify-dev-export
Last change on this file since 6a0ff7f4 was 79ae36dd, checked in by Martin Decky <martin@…>, 14 years ago

new async framework with integrated exchange tracking

  • strict isolation between low-level IPC and high-level async framework with integrated exchange tracking
    • each IPC connection is represented by an async_sess_t structure
    • each IPC exchange is represented by an async_exch_t structure
    • exchange management is either based on atomic messages (EXCHANGE_ATOMIC), locking (EXCHANGE_SERIALIZE) or connection cloning (EXCHANGE_CLONE)
  • async_obsolete: temporary compatibility layer to keep old async clients working (several pieces of code are currently broken, but only non-essential functionality)
  • IPC_M_PHONE_HANGUP is now method no. 0 (for elegant boolean evaluation)
  • IPC_M_DEBUG_ALL has been renamed to IPC_M_DEBUG
  • IPC_M_PING has been removed (VFS protocol now has VFS_IN_PING)
  • console routines in libc have been rewritten for better abstraction
  • additional use for libc-private header files (FILE structure opaque to the client)
  • various cstyle changes (typos, indentation, missing externs in header files, improved comments, etc.)
  • Property mode set to 100644
File size: 3.4 KB
Line 
1/*
2 * Copyright (c) 2008 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
29/** @addtogroup libc
30 * @{
31 */
32/** @file
33 */
34
35#ifndef LIBC_IO_CONSOLE_H_
36#define LIBC_IO_CONSOLE_H_
37
38#include <sys/time.h>
39#include <async.h>
40#include <bool.h>
41#include <stdio.h>
42
43typedef enum {
44 CONSOLE_CCAP_NONE = 0,
45 CONSOLE_CCAP_STYLE,
46 CONSOLE_CCAP_INDEXED,
47 CONSOLE_CCAP_RGB
48} console_caps_t;
49
50/** Console control structure. */
51typedef struct {
52 /** Console input file */
53 FILE *input;
54
55 /** Console output file */
56 FILE *output;
57
58 /** Console input session */
59 async_sess_t *input_sess;
60
61 /** Console output session */
62 async_sess_t *output_sess;
63
64 /** Input request call with timeout */
65 ipc_call_t input_call;
66
67 /** Input response with timeout */
68 aid_t input_aid;
69} console_ctrl_t;
70
71typedef enum {
72 KEY_PRESS,
73 KEY_RELEASE
74} kbd_event_type_t;
75
76/** Console event structure. */
77typedef struct {
78 /** Press or release event. */
79 kbd_event_type_t type;
80
81 /** Keycode of the key that was pressed or released. */
82 unsigned int key;
83
84 /** Bitmask of modifiers held. */
85 unsigned int mods;
86
87 /** The character that was generated or '\0' for none. */
88 wchar_t c;
89} kbd_event_t;
90
91extern console_ctrl_t *console_init(FILE *, FILE *);
92extern void console_done(console_ctrl_t *);
93extern bool console_kcon(void);
94
95extern void console_flush(console_ctrl_t *);
96extern void console_clear(console_ctrl_t *);
97
98extern int console_get_size(console_ctrl_t *, sysarg_t *, sysarg_t *);
99extern int console_get_pos(console_ctrl_t *, sysarg_t *, sysarg_t *);
100extern void console_set_pos(console_ctrl_t *, sysarg_t, sysarg_t);
101
102extern void console_set_style(console_ctrl_t *, uint8_t);
103extern void console_set_color(console_ctrl_t *, uint8_t, uint8_t, uint8_t);
104extern void console_set_rgb_color(console_ctrl_t *, uint32_t, uint32_t);
105
106extern void console_cursor_visibility(console_ctrl_t *, bool);
107extern int console_get_color_cap(console_ctrl_t *, sysarg_t *);
108extern bool console_get_kbd_event(console_ctrl_t *, kbd_event_t *);
109extern bool console_get_kbd_event_timeout(console_ctrl_t *, kbd_event_t *,
110 suseconds_t *);
111
112#endif
113
114/** @}
115 */
Note: See TracBrowser for help on using the repository browser.