2021-01-15 09:30:03 +00:00
|
|
|
/*
|
|
|
|
Looking Glass - KVM FrameRelay (KVMFR) Client
|
|
|
|
Copyright (C) 2017-2021 Geoffrey McRae <geoff@hostfission.com>
|
|
|
|
https://looking-glass.hostfission.com
|
|
|
|
|
|
|
|
This program 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 of the License, or (at your option) any later
|
|
|
|
version.
|
|
|
|
|
|
|
|
This program 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-1307 USA
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef _H_I_DISPLAYSERVER_
|
|
|
|
#define _H_I_DISPLAYSERVER_
|
|
|
|
|
|
|
|
#include <stdbool.h>
|
2021-01-26 10:46:30 +00:00
|
|
|
#include <EGL/egl.h>
|
2021-01-15 09:30:03 +00:00
|
|
|
|
|
|
|
typedef enum LG_ClipboardData
|
|
|
|
{
|
|
|
|
LG_CLIPBOARD_DATA_TEXT = 0,
|
|
|
|
LG_CLIPBOARD_DATA_PNG,
|
|
|
|
LG_CLIPBOARD_DATA_BMP,
|
|
|
|
LG_CLIPBOARD_DATA_TIFF,
|
|
|
|
LG_CLIPBOARD_DATA_JPEG,
|
|
|
|
|
|
|
|
LG_CLIPBOARD_DATA_NONE // enum max, not a data type
|
|
|
|
}
|
|
|
|
LG_ClipboardData;
|
|
|
|
|
|
|
|
typedef enum LG_DSProperty
|
|
|
|
{
|
2021-01-16 10:17:35 +00:00
|
|
|
/**
|
|
|
|
* returns the maximum number of samples supported
|
|
|
|
* if not implemented LG assumes no multisample support
|
|
|
|
* return data type: int
|
|
|
|
*/
|
|
|
|
LG_DS_MAX_MULTISAMPLE,
|
|
|
|
|
|
|
|
/**
|
|
|
|
* returns if the platform is warp capable
|
|
|
|
* if not implemented LG assumes that the platform is warp capable
|
|
|
|
* return data type: bool
|
|
|
|
*/
|
|
|
|
LG_DS_WARP_SUPPORT,
|
2021-01-15 09:30:03 +00:00
|
|
|
}
|
|
|
|
LG_DSProperty;
|
|
|
|
|
2021-02-16 00:40:44 +00:00
|
|
|
enum LG_DSWarpSupport
|
|
|
|
{
|
|
|
|
LG_DS_WARP_NONE,
|
|
|
|
LG_DS_WARP_SURFACE,
|
|
|
|
LG_DS_WARP_SCREEN,
|
|
|
|
};
|
|
|
|
|
2021-01-26 10:46:30 +00:00
|
|
|
typedef struct LG_DSInitParams
|
|
|
|
{
|
|
|
|
const char * title;
|
|
|
|
int x, y, w, h;
|
|
|
|
bool center;
|
|
|
|
bool fullscreen;
|
|
|
|
bool resizable;
|
|
|
|
bool borderless;
|
|
|
|
bool maximize;
|
2021-01-27 08:38:34 +00:00
|
|
|
|
|
|
|
// if true the renderer requires an OpenGL context
|
|
|
|
bool opengl;
|
2021-01-26 10:46:30 +00:00
|
|
|
}
|
|
|
|
LG_DSInitParams;
|
|
|
|
|
2021-01-15 09:30:03 +00:00
|
|
|
typedef void (* LG_ClipboardReplyFn)(void * opaque, const LG_ClipboardData type,
|
|
|
|
uint8_t * data, uint32_t size);
|
|
|
|
|
2021-01-27 10:27:26 +00:00
|
|
|
typedef struct LG_DSGLContext
|
|
|
|
* LG_DSGLContext;
|
|
|
|
|
2021-01-15 09:30:03 +00:00
|
|
|
struct LG_DisplayServerOps
|
|
|
|
{
|
2021-02-16 01:54:02 +00:00
|
|
|
/* called before options are parsed, useful for registering options */
|
|
|
|
void (*setup)(void);
|
|
|
|
|
2021-01-26 10:46:30 +00:00
|
|
|
/* return true if the selected ds is valid for the current platform */
|
|
|
|
bool (*probe)(void);
|
2021-01-15 09:30:03 +00:00
|
|
|
|
2021-01-26 10:46:30 +00:00
|
|
|
/* called before anything has been initialized */
|
2021-01-16 09:29:54 +00:00
|
|
|
bool (*earlyInit)(void);
|
|
|
|
|
2021-01-26 10:46:30 +00:00
|
|
|
/* called when it's time to create and show the application window */
|
|
|
|
bool (*init)(const LG_DSInitParams params);
|
2021-01-15 09:30:03 +00:00
|
|
|
|
2021-01-26 10:46:30 +00:00
|
|
|
/* called at startup after window creation, renderer and SPICE is ready */
|
2021-01-15 09:30:03 +00:00
|
|
|
void (*startup)();
|
|
|
|
|
|
|
|
/* called just before final window destruction, before final free */
|
|
|
|
void (*shutdown)();
|
|
|
|
|
|
|
|
/* final free */
|
|
|
|
void (*free)();
|
|
|
|
|
2021-01-16 10:17:35 +00:00
|
|
|
/*
|
|
|
|
* return a system specific property, returns false if unsupported or failure
|
|
|
|
* if the platform does not support/implement the requested property the value
|
|
|
|
* of `ret` must not be altered.
|
|
|
|
*/
|
2021-01-15 09:30:03 +00:00
|
|
|
bool (*getProp)(LG_DSProperty prop, void * ret);
|
|
|
|
|
2021-01-26 10:46:30 +00:00
|
|
|
#ifdef ENABLE_EGL
|
|
|
|
/* EGL support */
|
|
|
|
EGLDisplay (*getEGLDisplay)(void);
|
|
|
|
EGLNativeWindowType (*getEGLNativeWindow)(void);
|
2021-01-26 23:59:10 +00:00
|
|
|
void (*eglSwapBuffers)(EGLDisplay display, EGLSurface surface);
|
2021-01-26 10:46:30 +00:00
|
|
|
#endif
|
|
|
|
|
2021-01-27 20:13:35 +00:00
|
|
|
#ifdef ENABLE_OPENGL
|
2021-01-26 10:46:30 +00:00
|
|
|
/* opengl platform specific methods */
|
2021-01-27 10:27:26 +00:00
|
|
|
LG_DSGLContext (*glCreateContext)(void);
|
|
|
|
void (*glDeleteContext)(LG_DSGLContext context);
|
|
|
|
void (*glMakeCurrent)(LG_DSGLContext context);
|
|
|
|
void (*glSetSwapInterval)(int interval);
|
2021-01-26 10:46:30 +00:00
|
|
|
void (*glSwapBuffers)(void);
|
2021-01-27 20:13:35 +00:00
|
|
|
#endif
|
2021-01-15 09:30:03 +00:00
|
|
|
|
|
|
|
/* dm specific cursor implementations */
|
2021-05-04 08:53:31 +00:00
|
|
|
void (*guestPointerUpdated)(double x, double y, double localX, double localY);
|
2021-01-25 09:32:02 +00:00
|
|
|
void (*showPointer)(bool show);
|
2021-01-15 09:30:03 +00:00
|
|
|
void (*grabKeyboard)();
|
|
|
|
void (*ungrabKeyboard)();
|
2021-05-04 00:16:51 +00:00
|
|
|
/* (un)grabPointer is used to toggle cursor tracking/confine in normal mode */
|
|
|
|
void (*grabPointer)();
|
|
|
|
void (*ungrabPointer)();
|
|
|
|
/* (un)capturePointer is used do toggle special cursor tracking in capture mode */
|
|
|
|
void (*capturePointer)();
|
|
|
|
void (*uncapturePointer)();
|
2021-01-15 09:30:03 +00:00
|
|
|
|
2021-01-17 01:53:55 +00:00
|
|
|
/* exiting = true if the warp is to leave the window */
|
2021-01-16 18:10:52 +00:00
|
|
|
void (*warpPointer)(int x, int y, bool exiting);
|
2021-01-15 09:30:03 +00:00
|
|
|
|
2021-01-17 01:53:55 +00:00
|
|
|
/* called when the client needs to realign the pointer. This should simply
|
|
|
|
* call the appropriate app_handleMouse* method for the platform with zero
|
|
|
|
* deltas */
|
|
|
|
void (*realignPointer)();
|
|
|
|
|
2021-01-25 09:32:02 +00:00
|
|
|
/* returns true if the position specified is actually valid */
|
|
|
|
bool (*isValidPointerPos)(int x, int y);
|
|
|
|
|
2021-01-18 21:08:38 +00:00
|
|
|
/* called to disable/enable the screensaver */
|
|
|
|
void (*inhibitIdle)();
|
|
|
|
void (*uninhibitIdle)();
|
|
|
|
|
2021-01-26 10:46:30 +00:00
|
|
|
/* wait for the specified time without blocking UI processing/event loops */
|
|
|
|
void (*wait)(unsigned int time);
|
|
|
|
|
2021-05-06 12:24:42 +00:00
|
|
|
/* get/set the window dimensions & state */
|
2021-01-26 10:46:30 +00:00
|
|
|
void (*setWindowSize)(int x, int y);
|
2021-01-27 00:11:53 +00:00
|
|
|
bool (*getFullscreen)(void);
|
2021-01-26 10:46:30 +00:00
|
|
|
void (*setFullscreen)(bool fs);
|
2021-05-06 12:24:42 +00:00
|
|
|
void (*minimize)(void);
|
2021-01-26 10:46:30 +00:00
|
|
|
|
2021-01-27 08:20:13 +00:00
|
|
|
/* clipboard support, optional, if not supported set to NULL */
|
2021-01-25 08:58:36 +00:00
|
|
|
bool (*cbInit)(void);
|
|
|
|
void (*cbNotice)(LG_ClipboardData type);
|
|
|
|
void (*cbRelease)(void);
|
|
|
|
void (*cbRequest)(LG_ClipboardData type);
|
2021-01-15 09:30:03 +00:00
|
|
|
};
|
|
|
|
|
2021-01-27 08:20:13 +00:00
|
|
|
#ifdef ENABLE_EGL
|
|
|
|
#define ASSERT_EGL_FN(x) assert(x);
|
|
|
|
#else
|
|
|
|
#define ASSERT_EGL_FN(x)
|
|
|
|
#endif
|
|
|
|
|
2021-01-27 20:13:35 +00:00
|
|
|
#ifdef ENABLE_OPENGL
|
|
|
|
#define ASSERT_OPENGL_FN(x) assert(x)
|
|
|
|
#else
|
|
|
|
#define ASSERT_OPENGL_FN(x)
|
|
|
|
#endif
|
|
|
|
|
2021-01-27 08:20:13 +00:00
|
|
|
#define ASSERT_LG_DS_VALID(x) \
|
2021-02-16 01:54:02 +00:00
|
|
|
assert((x)->setup ); \
|
2021-01-27 08:20:13 +00:00
|
|
|
assert((x)->probe ); \
|
|
|
|
assert((x)->earlyInit ); \
|
|
|
|
assert((x)->init ); \
|
|
|
|
assert((x)->startup ); \
|
|
|
|
assert((x)->shutdown ); \
|
|
|
|
assert((x)->free ); \
|
|
|
|
assert((x)->getProp ); \
|
|
|
|
ASSERT_EGL_FN((x)->getEGLDisplay ); \
|
|
|
|
ASSERT_EGL_FN((x)->getEGLNativeWindow ); \
|
|
|
|
ASSERT_EGL_FN((x)->eglSwapBuffers ); \
|
2021-01-27 20:13:35 +00:00
|
|
|
ASSERT_OPENGL_FN((x)->glCreateContext ); \
|
|
|
|
ASSERT_OPENGL_FN((x)->glDeleteContext ); \
|
|
|
|
ASSERT_OPENGL_FN((x)->glMakeCurrent ); \
|
|
|
|
ASSERT_OPENGL_FN((x)->glSetSwapInterval); \
|
|
|
|
ASSERT_OPENGL_FN((x)->glSwapBuffers ); \
|
2021-05-03 20:35:36 +00:00
|
|
|
assert((x)->guestPointerUpdated); \
|
2021-01-27 08:20:13 +00:00
|
|
|
assert((x)->showPointer ); \
|
|
|
|
assert((x)->grabPointer ); \
|
|
|
|
assert((x)->ungrabPointer ); \
|
2021-05-04 00:16:51 +00:00
|
|
|
assert((x)->capturePointer ); \
|
|
|
|
assert((x)->uncapturePointer ); \
|
2021-01-27 08:20:13 +00:00
|
|
|
assert((x)->warpPointer ); \
|
|
|
|
assert((x)->realignPointer ); \
|
|
|
|
assert((x)->isValidPointerPos ); \
|
|
|
|
assert((x)->inhibitIdle ); \
|
|
|
|
assert((x)->uninhibitIdle ); \
|
|
|
|
assert((x)->wait ); \
|
|
|
|
assert((x)->setWindowSize ); \
|
|
|
|
assert((x)->setFullscreen ); \
|
2021-05-06 12:24:42 +00:00
|
|
|
assert((x)->getFullscreen ); \
|
|
|
|
assert((x)->minimize );
|
2021-01-27 08:20:13 +00:00
|
|
|
|
2021-01-15 09:30:03 +00:00
|
|
|
#endif
|