From 7fe60435bce6595a9c58a9bfd8244d74b5320e96 Mon Sep 17 00:00:00 2001 From: Benjamin Franzke Date: Tue, 15 Jan 2013 08:46:13 +0100 Subject: Import DirectFB141_2k11R3_beta5 --- Source/DiVine/include/divine.h | 136 +++++++++++++++++++++++++++++++++++++++++ 1 file changed, 136 insertions(+) create mode 100755 Source/DiVine/include/divine.h (limited to 'Source/DiVine/include/divine.h') diff --git a/Source/DiVine/include/divine.h b/Source/DiVine/include/divine.h new file mode 100755 index 0000000..b4c2051 --- /dev/null +++ b/Source/DiVine/include/divine.h @@ -0,0 +1,136 @@ +/* + (c) Copyright 2000-2002 convergence integrated media GmbH. + (c) Copyright 2002 convergence GmbH. + + All rights reserved. + + Written by Denis Oliver Kropp , + Andreas Hundt and + Sven Neumann . + + This library is free software; you can redistribute it and/or + modify it under the terms of the GNU Lesser General Public + License as published by the Free Software Foundation; either + version 2 of the License, or (at your option) any later version. + + This library 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 + Lesser General Public License for more details. + + You should have received a copy of the GNU Lesser General Public + License along with this library; if not, write to the + Free Software Foundation, Inc., 59 Temple Place - Suite 330, + Boston, MA 02111-1307, USA. +*/ + +#ifndef __DIVINE_H__ +#define __DIVINE_H__ + +#include + +/* + * Main interface of DiVine, created by DiVineCreate(). + */ +DECLARE_INTERFACE( IDiVine ) + +/* + * Parses the command-line and initializes some variables. You + * absolutely need to call this before doing anything else. + * Removes all options used by DiVine from argv. + */ +DFBResult DiVineInit( int *argc, char *(*argv[]) ); + +/* + * Creates the super interface. + */ +DFBResult DiVineCreate( + IDiVine **interface /* pointer to the created interface */ + ); + +/*********** + * IDiVine * + ***********/ + +/* + * No summary yet... + */ +DEFINE_INTERFACE( IDiVine, + + /** Events **/ + + /* + * Sends an input event. + */ + DFBResult (*SendEvent) ( + IDiVine *thiz, + const DFBInputEvent *event + ); + + /* + * Sends an input key symbol. + */ + DFBResult (*SendSymbol) ( + IDiVine *thiz, + DFBInputDeviceKeySymbol symbol + ); +); + + +/* + * The DiVine struct represents the connection to the input driver. + */ +typedef struct _DiVine DiVine; + +/* + * Opens a connection to the input driver by opening the pipe + * specified by 'path'. + * + * Returns the DiVine connection object. + */ +DiVine *divine_open (const char *path); + + +/* + * Sends an input event. + */ +void divine_send_event (DiVine *divine, const DFBInputEvent *event); + +/* + * Sends a press and a release event for the specified symbol. + */ +void divine_send_symbol (DiVine *divine, DFBInputDeviceKeySymbol symbol); + +/* + * Sends a press and a release event for the specified identifier. + */ +void divine_send_identifier (DiVine *divine, DFBInputDeviceKeyIdentifier identifier); + +/* + * Sends a press and a release event for the specified ANSI string. + * Use this to feed terminal input into a DirectFB application. + */ +void divine_send_vt102 (DiVine *divine, int size, const char *ansistr); + +/* + * + */ +void divine_send_motion_absolute( DiVine *divine, int x, int y ); + +/* + * + */ +void divine_send_button_press( DiVine *divine, DFBInputDeviceButtonIdentifier button ); + +/* + * + */ +void divine_send_button_release( DiVine *divine, DFBInputDeviceButtonIdentifier button ); + + +/* + * Closes the pipe and destroys the connection object. + */ +void divine_close (DiVine *divine); + +#endif -- cgit