summaryrefslogtreecommitdiff
path: root/console-client/input.h
blob: 61deadc05383befad1b9725b6d75b61722401219 (plain)
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
/* input.h - The interface to and for an input driver.
   Copyright (C) 2002, 2004, 2005 Free Software Foundation, Inc.
   Written by Marcus Brinkmann.

   This file is part of the GNU Hurd.

   The GNU Hurd is free software; you can redistribute it and/or
   modify it under the terms of the GNU General Public License as
   published by the Free Software Foundation; either version 2, or (at
   your option) any later version.

   The GNU Hurd 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
   General Public License for more details.

   You should have received a copy of the GNU General Public License
   along with this program; if not, write to the Free Software
   Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA  02111, USA. */

#ifndef _INPUT_H_
#define _INPUT_H_ 1

#include <errno.h>
#include <stddef.h>

#include <hurd/cons.h>


/* The input drivers are set up by the driver's initialization routine
   and added to the console client with driver_add_input.  All
   subsequent operations on the display are fully synchronized by the
   caller.  The driver deinitialization routine should call
   driver_remove_input.  */

/* Forward declaration.  */
struct input_ops;
typedef struct input_ops *input_ops_t;

/* Add the input source HANDLE with the operations OPS to the console
   client.  As soon as this is called, operations on this input source
   may be performed, even before the function returns.  */
error_t driver_add_input (input_ops_t ops, void *handle);

/* Remove the input HANDLE with the operations OPS from the console
   client.  As soon as this function returns, no operations will be
   performed on the input source anymore.  */
error_t driver_remove_input (input_ops_t ops, void *handle);

/* Enter SIZE bytes from the buffer BUF into the currently active
   console.  This can be called by the input driver at any time.  */
error_t console_input (char *buf, size_t size);

/* Scroll the active console by TYPE and VALUE as specified by
   cons_vcons_scrollback.  */
int console_scrollback (cons_scroll_t type, float value);

/* Returns current console ID.  */
error_t console_current_id (int *cur);

/* Switch the active console to console ID or DELTA (relative to the
   active console).  */
error_t console_switch (int id, int delta);

/* Signal an error to the user.  */
void console_error (const wchar_t *const err_msg);

/* Exit the console client.  Does not return.  */
void console_exit (void) __attribute__ ((noreturn));

/* Switch away from the console an external use of the console like
   XFree.  */
void console_switch_away (void);

/* Switch back to the console client from an external user of the
   console like XFree.  */
void console_switch_back (void);

/* Report the mouse event EV to the currently active console.  This
   can be called by the input driver at any time.  */
error_t console_move_mouse (mouse_event_t ev);


#if QUAERENDO_INVENIETIS
/* Do not use, do not remove.  */
void console_deprecated (int key);
#endif


struct input_ops
{
  /* Set the status of the scroll lock indication.  */
  error_t (*set_scroll_lock_status) (void *handle, int onoff);

  /* Do not use, do not remove.  */
  void (*deprecated) (void *handle, int key);
};

#endif	/* _INPUT_H_ */